|
@@ -188,8 +188,7 @@ enet_protocol_remove_sent_unreliable_commands (ENetPeer * peer)
|
|
} while (! enet_list_empty (& peer -> sentUnreliableCommands));
|
|
} while (! enet_list_empty (& peer -> sentUnreliableCommands));
|
|
|
|
|
|
if (peer -> state == ENET_PEER_STATE_DISCONNECT_LATER &&
|
|
if (peer -> state == ENET_PEER_STATE_DISCONNECT_LATER &&
|
|
- enet_list_empty (& peer -> outgoingReliableCommands) &&
|
|
|
|
- enet_list_empty (& peer -> outgoingUnreliableCommands) &&
|
|
|
|
|
|
+ enet_list_empty (& peer -> outgoingCommands) &&
|
|
enet_list_empty (& peer -> sentReliableCommands))
|
|
enet_list_empty (& peer -> sentReliableCommands))
|
|
enet_peer_disconnect (peer, peer -> eventData);
|
|
enet_peer_disconnect (peer, peer -> eventData);
|
|
}
|
|
}
|
|
@@ -215,12 +214,15 @@ enet_protocol_remove_sent_reliable_command (ENetPeer * peer, enet_uint16 reliabl
|
|
|
|
|
|
if (currentCommand == enet_list_end (& peer -> sentReliableCommands))
|
|
if (currentCommand == enet_list_end (& peer -> sentReliableCommands))
|
|
{
|
|
{
|
|
- for (currentCommand = enet_list_begin (& peer -> outgoingReliableCommands);
|
|
|
|
- currentCommand != enet_list_end (& peer -> outgoingReliableCommands);
|
|
|
|
|
|
+ for (currentCommand = enet_list_begin (& peer -> outgoingCommands);
|
|
|
|
+ currentCommand != enet_list_end (& peer -> outgoingCommands);
|
|
currentCommand = enet_list_next (currentCommand))
|
|
currentCommand = enet_list_next (currentCommand))
|
|
{
|
|
{
|
|
outgoingCommand = (ENetOutgoingCommand *) currentCommand;
|
|
outgoingCommand = (ENetOutgoingCommand *) currentCommand;
|
|
|
|
|
|
|
|
+ if (! (outgoingCommand -> command.header.command & ENET_PROTOCOL_COMMAND_FLAG_ACKNOWLEDGE))
|
|
|
|
+ continue;
|
|
|
|
+
|
|
if (outgoingCommand -> sendAttempts < 1) return ENET_PROTOCOL_COMMAND_NONE;
|
|
if (outgoingCommand -> sendAttempts < 1) return ENET_PROTOCOL_COMMAND_NONE;
|
|
|
|
|
|
if (outgoingCommand -> reliableSequenceNumber == reliableSequenceNumber &&
|
|
if (outgoingCommand -> reliableSequenceNumber == reliableSequenceNumber &&
|
|
@@ -228,7 +230,7 @@ enet_protocol_remove_sent_reliable_command (ENetPeer * peer, enet_uint16 reliabl
|
|
break;
|
|
break;
|
|
}
|
|
}
|
|
|
|
|
|
- if (currentCommand == enet_list_end (& peer -> outgoingReliableCommands))
|
|
|
|
|
|
+ if (currentCommand == enet_list_end (& peer -> outgoingCommands))
|
|
return ENET_PROTOCOL_COMMAND_NONE;
|
|
return ENET_PROTOCOL_COMMAND_NONE;
|
|
|
|
|
|
wasSent = 0;
|
|
wasSent = 0;
|
|
@@ -623,7 +625,7 @@ enet_protocol_handle_send_fragment (ENetHost * host, ENetPeer * peer, const ENet
|
|
fragmentLength);
|
|
fragmentLength);
|
|
|
|
|
|
if (startCommand -> fragmentsRemaining <= 0)
|
|
if (startCommand -> fragmentsRemaining <= 0)
|
|
- enet_peer_dispatch_incoming_reliable_commands (peer, channel);
|
|
|
|
|
|
+ enet_peer_dispatch_incoming_reliable_commands (peer, channel, NULL);
|
|
}
|
|
}
|
|
|
|
|
|
return 0;
|
|
return 0;
|
|
@@ -741,7 +743,7 @@ enet_protocol_handle_send_unreliable_fragment (ENetHost * host, ENetPeer * peer,
|
|
fragmentLength);
|
|
fragmentLength);
|
|
|
|
|
|
if (startCommand -> fragmentsRemaining <= 0)
|
|
if (startCommand -> fragmentsRemaining <= 0)
|
|
- enet_peer_dispatch_incoming_unreliable_commands (peer, channel);
|
|
|
|
|
|
+ enet_peer_dispatch_incoming_unreliable_commands (peer, channel, NULL);
|
|
}
|
|
}
|
|
|
|
|
|
return 0;
|
|
return 0;
|
|
@@ -856,19 +858,22 @@ enet_protocol_handle_acknowledge (ENetHost * host, ENetEvent * event, ENetPeer *
|
|
|
|
|
|
if (peer -> lastReceiveTime > 0)
|
|
if (peer -> lastReceiveTime > 0)
|
|
{
|
|
{
|
|
- enet_uint32 accumRoundTripTime = (peer -> roundTripTime << 8) + peer -> roundTripTimeRemainder;
|
|
|
|
- enet_uint32 accumRoundTripTimeVariance = (peer -> roundTripTimeVariance << 8) + peer -> roundTripTimeVarianceRemainder;
|
|
|
|
-
|
|
|
|
enet_peer_throttle (peer, roundTripTime);
|
|
enet_peer_throttle (peer, roundTripTime);
|
|
|
|
|
|
- roundTripTime <<= 8;
|
|
|
|
- accumRoundTripTimeVariance = (accumRoundTripTimeVariance * 3 + ENET_DIFFERENCE (roundTripTime, accumRoundTripTime)) / 4;
|
|
|
|
- accumRoundTripTime = (accumRoundTripTime * 7 + roundTripTime) / 8;
|
|
|
|
|
|
+ peer -> roundTripTimeVariance -= peer -> roundTripTimeVariance / 4;
|
|
|
|
|
|
- peer -> roundTripTime = accumRoundTripTime >> 8;
|
|
|
|
- peer -> roundTripTimeRemainder = accumRoundTripTime & 0xFF;
|
|
|
|
- peer -> roundTripTimeVariance = accumRoundTripTimeVariance >> 8;
|
|
|
|
- peer -> roundTripTimeVarianceRemainder = accumRoundTripTimeVariance & 0xFF;
|
|
|
|
|
|
+ if (roundTripTime >= peer -> roundTripTime)
|
|
|
|
+ {
|
|
|
|
+ enet_uint32 diff = roundTripTime - peer -> roundTripTime;
|
|
|
|
+ peer -> roundTripTimeVariance += diff / 4;
|
|
|
|
+ peer -> roundTripTime += diff / 8;
|
|
|
|
+ }
|
|
|
|
+ else
|
|
|
|
+ {
|
|
|
|
+ enet_uint32 diff = peer -> roundTripTime - roundTripTime;
|
|
|
|
+ peer -> roundTripTimeVariance += diff / 4;
|
|
|
|
+ peer -> roundTripTime -= diff / 8;
|
|
|
|
+ }
|
|
}
|
|
}
|
|
else
|
|
else
|
|
{
|
|
{
|
|
@@ -879,14 +884,14 @@ enet_protocol_handle_acknowledge (ENetHost * host, ENetEvent * event, ENetPeer *
|
|
if (peer -> roundTripTime < peer -> lowestRoundTripTime)
|
|
if (peer -> roundTripTime < peer -> lowestRoundTripTime)
|
|
peer -> lowestRoundTripTime = peer -> roundTripTime;
|
|
peer -> lowestRoundTripTime = peer -> roundTripTime;
|
|
|
|
|
|
- if (peer -> roundTripTimeVariance > peer -> highestRoundTripTimeVariance)
|
|
|
|
|
|
+ if (peer -> roundTripTimeVariance > peer -> highestRoundTripTimeVariance)
|
|
peer -> highestRoundTripTimeVariance = peer -> roundTripTimeVariance;
|
|
peer -> highestRoundTripTimeVariance = peer -> roundTripTimeVariance;
|
|
|
|
|
|
if (peer -> packetThrottleEpoch == 0 ||
|
|
if (peer -> packetThrottleEpoch == 0 ||
|
|
ENET_TIME_DIFFERENCE (host -> serviceTime, peer -> packetThrottleEpoch) >= peer -> packetThrottleInterval)
|
|
ENET_TIME_DIFFERENCE (host -> serviceTime, peer -> packetThrottleEpoch) >= peer -> packetThrottleInterval)
|
|
{
|
|
{
|
|
peer -> lastRoundTripTime = peer -> lowestRoundTripTime;
|
|
peer -> lastRoundTripTime = peer -> lowestRoundTripTime;
|
|
- peer -> lastRoundTripTimeVariance = ENET_MAX (peer -> highestRoundTripTimeVariance, 2);
|
|
|
|
|
|
+ peer -> lastRoundTripTimeVariance = ENET_MAX (peer -> highestRoundTripTimeVariance, 1);
|
|
peer -> lowestRoundTripTime = peer -> roundTripTime;
|
|
peer -> lowestRoundTripTime = peer -> roundTripTime;
|
|
peer -> highestRoundTripTimeVariance = peer -> roundTripTimeVariance;
|
|
peer -> highestRoundTripTimeVariance = peer -> roundTripTimeVariance;
|
|
peer -> packetThrottleEpoch = host -> serviceTime;
|
|
peer -> packetThrottleEpoch = host -> serviceTime;
|
|
@@ -916,8 +921,7 @@ enet_protocol_handle_acknowledge (ENetHost * host, ENetEvent * event, ENetPeer *
|
|
break;
|
|
break;
|
|
|
|
|
|
case ENET_PEER_STATE_DISCONNECT_LATER:
|
|
case ENET_PEER_STATE_DISCONNECT_LATER:
|
|
- if (enet_list_empty (& peer -> outgoingReliableCommands) &&
|
|
|
|
- enet_list_empty (& peer -> outgoingUnreliableCommands) &&
|
|
|
|
|
|
+ if (enet_list_empty (& peer -> outgoingCommands) &&
|
|
enet_list_empty (& peer -> sentReliableCommands))
|
|
enet_list_empty (& peer -> sentReliableCommands))
|
|
enet_peer_disconnect (peer, peer -> eventData);
|
|
enet_peer_disconnect (peer, peer -> eventData);
|
|
break;
|
|
break;
|
|
@@ -1325,108 +1329,6 @@ enet_protocol_send_acknowledgements (ENetHost * host, ENetPeer * peer)
|
|
host -> bufferCount = buffer - host -> buffers;
|
|
host -> bufferCount = buffer - host -> buffers;
|
|
}
|
|
}
|
|
|
|
|
|
-static void
|
|
|
|
-enet_protocol_send_unreliable_outgoing_commands (ENetHost * host, ENetPeer * peer)
|
|
|
|
-{
|
|
|
|
- ENetProtocol * command = & host -> commands [host -> commandCount];
|
|
|
|
- ENetBuffer * buffer = & host -> buffers [host -> bufferCount];
|
|
|
|
- ENetOutgoingCommand * outgoingCommand;
|
|
|
|
- ENetListIterator currentCommand;
|
|
|
|
-
|
|
|
|
- currentCommand = enet_list_begin (& peer -> outgoingUnreliableCommands);
|
|
|
|
-
|
|
|
|
- while (currentCommand != enet_list_end (& peer -> outgoingUnreliableCommands))
|
|
|
|
- {
|
|
|
|
- size_t commandSize;
|
|
|
|
-
|
|
|
|
- outgoingCommand = (ENetOutgoingCommand *) currentCommand;
|
|
|
|
- commandSize = commandSizes [outgoingCommand -> command.header.command & ENET_PROTOCOL_COMMAND_MASK];
|
|
|
|
-
|
|
|
|
- if (command >= & host -> commands [sizeof (host -> commands) / sizeof (ENetProtocol)] ||
|
|
|
|
- buffer + 1 >= & host -> buffers [sizeof (host -> buffers) / sizeof (ENetBuffer)] ||
|
|
|
|
- peer -> mtu - host -> packetSize < commandSize ||
|
|
|
|
- (outgoingCommand -> packet != NULL &&
|
|
|
|
- peer -> mtu - host -> packetSize < commandSize + outgoingCommand -> fragmentLength))
|
|
|
|
- {
|
|
|
|
- host -> continueSending = 1;
|
|
|
|
-
|
|
|
|
- break;
|
|
|
|
- }
|
|
|
|
-
|
|
|
|
- currentCommand = enet_list_next (currentCommand);
|
|
|
|
-
|
|
|
|
- if (outgoingCommand -> packet != NULL && outgoingCommand -> fragmentOffset == 0)
|
|
|
|
- {
|
|
|
|
- peer -> packetThrottleCounter += ENET_PEER_PACKET_THROTTLE_COUNTER;
|
|
|
|
- peer -> packetThrottleCounter %= ENET_PEER_PACKET_THROTTLE_SCALE;
|
|
|
|
-
|
|
|
|
- if (peer -> packetThrottleCounter > peer -> packetThrottle)
|
|
|
|
- {
|
|
|
|
- enet_uint16 reliableSequenceNumber = outgoingCommand -> reliableSequenceNumber,
|
|
|
|
- unreliableSequenceNumber = outgoingCommand -> unreliableSequenceNumber;
|
|
|
|
- for (;;)
|
|
|
|
- {
|
|
|
|
- -- outgoingCommand -> packet -> referenceCount;
|
|
|
|
-
|
|
|
|
- if (outgoingCommand -> packet -> referenceCount == 0)
|
|
|
|
- enet_packet_destroy (outgoingCommand -> packet);
|
|
|
|
-
|
|
|
|
- enet_list_remove (& outgoingCommand -> outgoingCommandList);
|
|
|
|
- enet_free (outgoingCommand);
|
|
|
|
-
|
|
|
|
- if (currentCommand == enet_list_end (& peer -> outgoingUnreliableCommands))
|
|
|
|
- break;
|
|
|
|
-
|
|
|
|
- outgoingCommand = (ENetOutgoingCommand *) currentCommand;
|
|
|
|
- if (outgoingCommand -> reliableSequenceNumber != reliableSequenceNumber ||
|
|
|
|
- outgoingCommand -> unreliableSequenceNumber != unreliableSequenceNumber)
|
|
|
|
- break;
|
|
|
|
-
|
|
|
|
- currentCommand = enet_list_next (currentCommand);
|
|
|
|
- }
|
|
|
|
-
|
|
|
|
- continue;
|
|
|
|
- }
|
|
|
|
- }
|
|
|
|
-
|
|
|
|
- buffer -> data = command;
|
|
|
|
- buffer -> dataLength = commandSize;
|
|
|
|
-
|
|
|
|
- host -> packetSize += buffer -> dataLength;
|
|
|
|
-
|
|
|
|
- * command = outgoingCommand -> command;
|
|
|
|
-
|
|
|
|
- enet_list_remove (& outgoingCommand -> outgoingCommandList);
|
|
|
|
-
|
|
|
|
- if (outgoingCommand -> packet != NULL)
|
|
|
|
- {
|
|
|
|
- ++ buffer;
|
|
|
|
-
|
|
|
|
- buffer -> data = outgoingCommand -> packet -> data + outgoingCommand -> fragmentOffset;
|
|
|
|
- buffer -> dataLength = outgoingCommand -> fragmentLength;
|
|
|
|
-
|
|
|
|
- host -> packetSize += buffer -> dataLength;
|
|
|
|
-
|
|
|
|
- enet_list_insert (enet_list_end (& peer -> sentUnreliableCommands), outgoingCommand);
|
|
|
|
- }
|
|
|
|
- else
|
|
|
|
- enet_free (outgoingCommand);
|
|
|
|
-
|
|
|
|
- ++ command;
|
|
|
|
- ++ buffer;
|
|
|
|
- }
|
|
|
|
-
|
|
|
|
- host -> commandCount = command - host -> commands;
|
|
|
|
- host -> bufferCount = buffer - host -> buffers;
|
|
|
|
-
|
|
|
|
- if (peer -> state == ENET_PEER_STATE_DISCONNECT_LATER &&
|
|
|
|
- enet_list_empty (& peer -> outgoingReliableCommands) &&
|
|
|
|
- enet_list_empty (& peer -> outgoingUnreliableCommands) &&
|
|
|
|
- enet_list_empty (& peer -> sentReliableCommands) &&
|
|
|
|
- enet_list_empty (& peer -> sentUnreliableCommands))
|
|
|
|
- enet_peer_disconnect (peer, peer -> eventData);
|
|
|
|
-}
|
|
|
|
-
|
|
|
|
static int
|
|
static int
|
|
enet_protocol_check_timeouts (ENetHost * host, ENetPeer * peer, ENetEvent * event)
|
|
enet_protocol_check_timeouts (ENetHost * host, ENetPeer * peer, ENetEvent * event)
|
|
{
|
|
{
|
|
@@ -1434,7 +1336,7 @@ enet_protocol_check_timeouts (ENetHost * host, ENetPeer * peer, ENetEvent * even
|
|
ENetListIterator currentCommand, insertPosition;
|
|
ENetListIterator currentCommand, insertPosition;
|
|
|
|
|
|
currentCommand = enet_list_begin (& peer -> sentReliableCommands);
|
|
currentCommand = enet_list_begin (& peer -> sentReliableCommands);
|
|
- insertPosition = enet_list_begin (& peer -> outgoingReliableCommands);
|
|
|
|
|
|
+ insertPosition = enet_list_begin (& peer -> outgoingCommands);
|
|
|
|
|
|
while (currentCommand != enet_list_end (& peer -> sentReliableCommands))
|
|
while (currentCommand != enet_list_end (& peer -> sentReliableCommands))
|
|
{
|
|
{
|
|
@@ -1481,7 +1383,7 @@ enet_protocol_check_timeouts (ENetHost * host, ENetPeer * peer, ENetEvent * even
|
|
}
|
|
}
|
|
|
|
|
|
static int
|
|
static int
|
|
-enet_protocol_send_reliable_outgoing_commands (ENetHost * host, ENetPeer * peer)
|
|
|
|
|
|
+enet_protocol_check_outgoing_commands (ENetHost * host, ENetPeer * peer)
|
|
{
|
|
{
|
|
ENetProtocol * command = & host -> commands [host -> commandCount];
|
|
ENetProtocol * command = & host -> commands [host -> commandCount];
|
|
ENetBuffer * buffer = & host -> buffers [host -> bufferCount];
|
|
ENetBuffer * buffer = & host -> buffers [host -> bufferCount];
|
|
@@ -1492,49 +1394,52 @@ enet_protocol_send_reliable_outgoing_commands (ENetHost * host, ENetPeer * peer)
|
|
size_t commandSize;
|
|
size_t commandSize;
|
|
int windowExceeded = 0, windowWrap = 0, canPing = 1;
|
|
int windowExceeded = 0, windowWrap = 0, canPing = 1;
|
|
|
|
|
|
- currentCommand = enet_list_begin (& peer -> outgoingReliableCommands);
|
|
|
|
|
|
+ currentCommand = enet_list_begin (& peer -> outgoingCommands);
|
|
|
|
|
|
- while (currentCommand != enet_list_end (& peer -> outgoingReliableCommands))
|
|
|
|
|
|
+ while (currentCommand != enet_list_end (& peer -> outgoingCommands))
|
|
{
|
|
{
|
|
outgoingCommand = (ENetOutgoingCommand *) currentCommand;
|
|
outgoingCommand = (ENetOutgoingCommand *) currentCommand;
|
|
|
|
|
|
- channel = outgoingCommand -> command.header.channelID < peer -> channelCount ? & peer -> channels [outgoingCommand -> command.header.channelID] : NULL;
|
|
|
|
- reliableWindow = outgoingCommand -> reliableSequenceNumber / ENET_PEER_RELIABLE_WINDOW_SIZE;
|
|
|
|
- if (channel != NULL)
|
|
|
|
|
|
+ if (outgoingCommand -> command.header.command & ENET_PROTOCOL_COMMAND_FLAG_ACKNOWLEDGE)
|
|
{
|
|
{
|
|
- if (! windowWrap &&
|
|
|
|
- outgoingCommand -> sendAttempts < 1 &&
|
|
|
|
- ! (outgoingCommand -> reliableSequenceNumber % ENET_PEER_RELIABLE_WINDOW_SIZE) &&
|
|
|
|
- (channel -> reliableWindows [(reliableWindow + ENET_PEER_RELIABLE_WINDOWS - 1) % ENET_PEER_RELIABLE_WINDOWS] >= ENET_PEER_RELIABLE_WINDOW_SIZE ||
|
|
|
|
- channel -> usedReliableWindows & ((((1 << ENET_PEER_FREE_RELIABLE_WINDOWS) - 1) << reliableWindow) |
|
|
|
|
- (((1 << ENET_PEER_FREE_RELIABLE_WINDOWS) - 1) >> (ENET_PEER_RELIABLE_WINDOWS - reliableWindow)))))
|
|
|
|
- windowWrap = 1;
|
|
|
|
- if (windowWrap)
|
|
|
|
|
|
+ channel = outgoingCommand -> command.header.channelID < peer -> channelCount ? & peer -> channels [outgoingCommand -> command.header.channelID] : NULL;
|
|
|
|
+ reliableWindow = outgoingCommand -> reliableSequenceNumber / ENET_PEER_RELIABLE_WINDOW_SIZE;
|
|
|
|
+ if (channel != NULL)
|
|
{
|
|
{
|
|
- currentCommand = enet_list_next (currentCommand);
|
|
|
|
|
|
+ if (! windowWrap &&
|
|
|
|
+ outgoingCommand -> sendAttempts < 1 &&
|
|
|
|
+ ! (outgoingCommand -> reliableSequenceNumber % ENET_PEER_RELIABLE_WINDOW_SIZE) &&
|
|
|
|
+ (channel -> reliableWindows [(reliableWindow + ENET_PEER_RELIABLE_WINDOWS - 1) % ENET_PEER_RELIABLE_WINDOWS] >= ENET_PEER_RELIABLE_WINDOW_SIZE ||
|
|
|
|
+ channel -> usedReliableWindows & ((((1 << (ENET_PEER_FREE_RELIABLE_WINDOWS + 2)) - 1) << reliableWindow) |
|
|
|
|
+ (((1 << (ENET_PEER_FREE_RELIABLE_WINDOWS + 2)) - 1) >> (ENET_PEER_RELIABLE_WINDOWS - reliableWindow)))))
|
|
|
|
+ windowWrap = 1;
|
|
|
|
+ if (windowWrap)
|
|
|
|
+ {
|
|
|
|
+ currentCommand = enet_list_next (currentCommand);
|
|
|
|
|
|
- continue;
|
|
|
|
|
|
+ continue;
|
|
|
|
+ }
|
|
}
|
|
}
|
|
- }
|
|
|
|
|
|
|
|
- if (outgoingCommand -> packet != NULL)
|
|
|
|
- {
|
|
|
|
- if (! windowExceeded)
|
|
|
|
|
|
+ if (outgoingCommand -> packet != NULL)
|
|
{
|
|
{
|
|
- enet_uint32 windowSize = (peer -> packetThrottle * peer -> windowSize) / ENET_PEER_PACKET_THROTTLE_SCALE;
|
|
|
|
|
|
+ if (! windowExceeded)
|
|
|
|
+ {
|
|
|
|
+ enet_uint32 windowSize = (peer -> packetThrottle * peer -> windowSize) / ENET_PEER_PACKET_THROTTLE_SCALE;
|
|
|
|
|
|
- if (peer -> reliableDataInTransit + outgoingCommand -> fragmentLength > ENET_MAX (windowSize, peer -> mtu))
|
|
|
|
- windowExceeded = 1;
|
|
|
|
- }
|
|
|
|
- if (windowExceeded)
|
|
|
|
- {
|
|
|
|
- currentCommand = enet_list_next (currentCommand);
|
|
|
|
|
|
+ if (peer -> reliableDataInTransit + outgoingCommand -> fragmentLength > ENET_MAX (windowSize, peer -> mtu))
|
|
|
|
+ windowExceeded = 1;
|
|
|
|
+ }
|
|
|
|
+ if (windowExceeded)
|
|
|
|
+ {
|
|
|
|
+ currentCommand = enet_list_next (currentCommand);
|
|
|
|
|
|
- continue;
|
|
|
|
|
|
+ continue;
|
|
|
|
+ }
|
|
}
|
|
}
|
|
- }
|
|
|
|
|
|
|
|
- canPing = 0;
|
|
|
|
|
|
+ canPing = 0;
|
|
|
|
+ }
|
|
|
|
|
|
commandSize = commandSizes [outgoingCommand -> command.header.command & ENET_PROTOCOL_COMMAND_MASK];
|
|
commandSize = commandSizes [outgoingCommand -> command.header.command & ENET_PROTOCOL_COMMAND_MASK];
|
|
if (command >= & host -> commands [sizeof (host -> commands) / sizeof (ENetProtocol)] ||
|
|
if (command >= & host -> commands [sizeof (host -> commands) / sizeof (ENetProtocol)] ||
|
|
@@ -1550,33 +1455,80 @@ enet_protocol_send_reliable_outgoing_commands (ENetHost * host, ENetPeer * peer)
|
|
|
|
|
|
currentCommand = enet_list_next (currentCommand);
|
|
currentCommand = enet_list_next (currentCommand);
|
|
|
|
|
|
- if (channel != NULL && outgoingCommand -> sendAttempts < 1)
|
|
|
|
|
|
+ if (outgoingCommand -> command.header.command & ENET_PROTOCOL_COMMAND_FLAG_ACKNOWLEDGE)
|
|
{
|
|
{
|
|
- channel -> usedReliableWindows |= 1 << reliableWindow;
|
|
|
|
- ++ channel -> reliableWindows [reliableWindow];
|
|
|
|
- }
|
|
|
|
|
|
+ if (channel != NULL && outgoingCommand -> sendAttempts < 1)
|
|
|
|
+ {
|
|
|
|
+ channel -> usedReliableWindows |= 1 << reliableWindow;
|
|
|
|
+ ++ channel -> reliableWindows [reliableWindow];
|
|
|
|
+ }
|
|
|
|
|
|
- ++ outgoingCommand -> sendAttempts;
|
|
|
|
|
|
+ ++ outgoingCommand -> sendAttempts;
|
|
|
|
|
|
- if (outgoingCommand -> roundTripTimeout == 0)
|
|
|
|
- {
|
|
|
|
- outgoingCommand -> roundTripTimeout = peer -> roundTripTime + 4 * peer -> roundTripTimeVariance;
|
|
|
|
- outgoingCommand -> roundTripTimeoutLimit = peer -> timeoutLimit * outgoingCommand -> roundTripTimeout;
|
|
|
|
|
|
+ if (outgoingCommand -> roundTripTimeout == 0)
|
|
|
|
+ {
|
|
|
|
+ outgoingCommand -> roundTripTimeout = peer -> roundTripTime + 4 * peer -> roundTripTimeVariance;
|
|
|
|
+ outgoingCommand -> roundTripTimeoutLimit = peer -> timeoutLimit * outgoingCommand -> roundTripTimeout;
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ if (enet_list_empty (& peer -> sentReliableCommands))
|
|
|
|
+ peer -> nextTimeout = host -> serviceTime + outgoingCommand -> roundTripTimeout;
|
|
|
|
+
|
|
|
|
+ enet_list_insert (enet_list_end (& peer -> sentReliableCommands),
|
|
|
|
+ enet_list_remove (& outgoingCommand -> outgoingCommandList));
|
|
|
|
+
|
|
|
|
+ outgoingCommand -> sentTime = host -> serviceTime;
|
|
|
|
+
|
|
|
|
+ host -> headerFlags |= ENET_PROTOCOL_HEADER_FLAG_SENT_TIME;
|
|
|
|
+
|
|
|
|
+ peer -> reliableDataInTransit += outgoingCommand -> fragmentLength;
|
|
}
|
|
}
|
|
|
|
+ else
|
|
|
|
+ {
|
|
|
|
+ if (outgoingCommand -> packet != NULL && outgoingCommand -> fragmentOffset == 0)
|
|
|
|
+ {
|
|
|
|
+ peer -> packetThrottleCounter += ENET_PEER_PACKET_THROTTLE_COUNTER;
|
|
|
|
+ peer -> packetThrottleCounter %= ENET_PEER_PACKET_THROTTLE_SCALE;
|
|
|
|
+
|
|
|
|
+ if (peer -> packetThrottleCounter > peer -> packetThrottle)
|
|
|
|
+ {
|
|
|
|
+ enet_uint16 reliableSequenceNumber = outgoingCommand -> reliableSequenceNumber,
|
|
|
|
+ unreliableSequenceNumber = outgoingCommand -> unreliableSequenceNumber;
|
|
|
|
+ for (;;)
|
|
|
|
+ {
|
|
|
|
+ -- outgoingCommand -> packet -> referenceCount;
|
|
|
|
+
|
|
|
|
+ if (outgoingCommand -> packet -> referenceCount == 0)
|
|
|
|
+ enet_packet_destroy (outgoingCommand -> packet);
|
|
|
|
|
|
- if (enet_list_empty (& peer -> sentReliableCommands))
|
|
|
|
- peer -> nextTimeout = host -> serviceTime + outgoingCommand -> roundTripTimeout;
|
|
|
|
|
|
+ enet_list_remove (& outgoingCommand -> outgoingCommandList);
|
|
|
|
+ enet_free (outgoingCommand);
|
|
|
|
|
|
- enet_list_insert (enet_list_end (& peer -> sentReliableCommands),
|
|
|
|
- enet_list_remove (& outgoingCommand -> outgoingCommandList));
|
|
|
|
|
|
+ if (currentCommand == enet_list_end (& peer -> outgoingCommands))
|
|
|
|
+ break;
|
|
|
|
|
|
- outgoingCommand -> sentTime = host -> serviceTime;
|
|
|
|
|
|
+ outgoingCommand = (ENetOutgoingCommand *) currentCommand;
|
|
|
|
+ if (outgoingCommand -> reliableSequenceNumber != reliableSequenceNumber ||
|
|
|
|
+ outgoingCommand -> unreliableSequenceNumber != unreliableSequenceNumber)
|
|
|
|
+ break;
|
|
|
|
+
|
|
|
|
+ currentCommand = enet_list_next (currentCommand);
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ continue;
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ enet_list_remove (& outgoingCommand -> outgoingCommandList);
|
|
|
|
+
|
|
|
|
+ if (outgoingCommand -> packet != NULL)
|
|
|
|
+ enet_list_insert (enet_list_end (& peer -> sentUnreliableCommands), outgoingCommand);
|
|
|
|
+ }
|
|
|
|
|
|
buffer -> data = command;
|
|
buffer -> data = command;
|
|
buffer -> dataLength = commandSize;
|
|
buffer -> dataLength = commandSize;
|
|
|
|
|
|
host -> packetSize += buffer -> dataLength;
|
|
host -> packetSize += buffer -> dataLength;
|
|
- host -> headerFlags |= ENET_PROTOCOL_HEADER_FLAG_SENT_TIME;
|
|
|
|
|
|
|
|
* command = outgoingCommand -> command;
|
|
* command = outgoingCommand -> command;
|
|
|
|
|
|
@@ -1588,9 +1540,10 @@ enet_protocol_send_reliable_outgoing_commands (ENetHost * host, ENetPeer * peer)
|
|
buffer -> dataLength = outgoingCommand -> fragmentLength;
|
|
buffer -> dataLength = outgoingCommand -> fragmentLength;
|
|
|
|
|
|
host -> packetSize += outgoingCommand -> fragmentLength;
|
|
host -> packetSize += outgoingCommand -> fragmentLength;
|
|
-
|
|
|
|
- peer -> reliableDataInTransit += outgoingCommand -> fragmentLength;
|
|
|
|
}
|
|
}
|
|
|
|
+ else
|
|
|
|
+ if (! (outgoingCommand -> command.header.command & ENET_PROTOCOL_COMMAND_FLAG_ACKNOWLEDGE))
|
|
|
|
+ enet_free (outgoingCommand);
|
|
|
|
|
|
++ peer -> packetsSent;
|
|
++ peer -> packetsSent;
|
|
|
|
|
|
@@ -1601,6 +1554,12 @@ enet_protocol_send_reliable_outgoing_commands (ENetHost * host, ENetPeer * peer)
|
|
host -> commandCount = command - host -> commands;
|
|
host -> commandCount = command - host -> commands;
|
|
host -> bufferCount = buffer - host -> buffers;
|
|
host -> bufferCount = buffer - host -> buffers;
|
|
|
|
|
|
|
|
+ if (peer -> state == ENET_PEER_STATE_DISCONNECT_LATER &&
|
|
|
|
+ enet_list_empty (& peer -> outgoingCommands) &&
|
|
|
|
+ enet_list_empty (& peer -> sentReliableCommands) &&
|
|
|
|
+ enet_list_empty (& peer -> sentUnreliableCommands))
|
|
|
|
+ enet_peer_disconnect (peer, peer -> eventData);
|
|
|
|
+
|
|
return canPing;
|
|
return canPing;
|
|
}
|
|
}
|
|
|
|
|
|
@@ -1644,18 +1603,15 @@ enet_protocol_send_outgoing_commands (ENetHost * host, ENetEvent * event, int ch
|
|
continue;
|
|
continue;
|
|
}
|
|
}
|
|
|
|
|
|
- if ((enet_list_empty (& currentPeer -> outgoingReliableCommands) ||
|
|
|
|
- enet_protocol_send_reliable_outgoing_commands (host, currentPeer)) &&
|
|
|
|
|
|
+ if ((enet_list_empty (& currentPeer -> outgoingCommands) ||
|
|
|
|
+ enet_protocol_check_outgoing_commands (host, currentPeer)) &&
|
|
enet_list_empty (& currentPeer -> sentReliableCommands) &&
|
|
enet_list_empty (& currentPeer -> sentReliableCommands) &&
|
|
ENET_TIME_DIFFERENCE (host -> serviceTime, currentPeer -> lastReceiveTime) >= currentPeer -> pingInterval &&
|
|
ENET_TIME_DIFFERENCE (host -> serviceTime, currentPeer -> lastReceiveTime) >= currentPeer -> pingInterval &&
|
|
currentPeer -> mtu - host -> packetSize >= sizeof (ENetProtocolPing))
|
|
currentPeer -> mtu - host -> packetSize >= sizeof (ENetProtocolPing))
|
|
{
|
|
{
|
|
enet_peer_ping (currentPeer);
|
|
enet_peer_ping (currentPeer);
|
|
- enet_protocol_send_reliable_outgoing_commands (host, currentPeer);
|
|
|
|
|
|
+ enet_protocol_check_outgoing_commands (host, currentPeer);
|
|
}
|
|
}
|
|
-
|
|
|
|
- if (! enet_list_empty (& currentPeer -> outgoingUnreliableCommands))
|
|
|
|
- enet_protocol_send_unreliable_outgoing_commands (host, currentPeer);
|
|
|
|
|
|
|
|
if (host -> commandCount == 0)
|
|
if (host -> commandCount == 0)
|
|
continue;
|
|
continue;
|
|
@@ -1669,7 +1625,7 @@ enet_protocol_send_outgoing_commands (ENetHost * host, ENetEvent * event, int ch
|
|
enet_uint32 packetLoss = currentPeer -> packetsLost * ENET_PEER_PACKET_LOSS_SCALE / currentPeer -> packetsSent;
|
|
enet_uint32 packetLoss = currentPeer -> packetsLost * ENET_PEER_PACKET_LOSS_SCALE / currentPeer -> packetsSent;
|
|
|
|
|
|
#ifdef ENET_DEBUG
|
|
#ifdef ENET_DEBUG
|
|
- printf ("peer %u: %f%%+-%f%% packet loss, %u+-%u ms round trip time, %f%% throttle, %u/%u outgoing, %u/%u incoming\n", currentPeer -> incomingPeerID, currentPeer -> packetLoss / (float) ENET_PEER_PACKET_LOSS_SCALE, currentPeer -> packetLossVariance / (float) ENET_PEER_PACKET_LOSS_SCALE, currentPeer -> roundTripTime, currentPeer -> roundTripTimeVariance, currentPeer -> packetThrottle / (float) ENET_PEER_PACKET_THROTTLE_SCALE, enet_list_size (& currentPeer -> outgoingReliableCommands), enet_list_size (& currentPeer -> outgoingUnreliableCommands), currentPeer -> channels != NULL ? enet_list_size (& currentPeer -> channels -> incomingReliableCommands) : 0, currentPeer -> channels != NULL ? enet_list_size (& currentPeer -> channels -> incomingUnreliableCommands) : 0);
|
|
|
|
|
|
+ printf ("peer %u: %f%%+-%f%% packet loss, %u+-%u ms round trip time, %f%% throttle, %u outgoing, %u/%u incoming\n", currentPeer -> incomingPeerID, currentPeer -> packetLoss / (float) ENET_PEER_PACKET_LOSS_SCALE, currentPeer -> packetLossVariance / (float) ENET_PEER_PACKET_LOSS_SCALE, currentPeer -> roundTripTime, currentPeer -> roundTripTimeVariance, currentPeer -> packetThrottle / (float) ENET_PEER_PACKET_THROTTLE_SCALE, enet_list_size (& currentPeer -> outgoingCommands), currentPeer -> channels != NULL ? enet_list_size (& currentPeer -> channels -> incomingReliableCommands) : 0, currentPeer -> channels != NULL ? enet_list_size (& currentPeer -> channels -> incomingUnreliableCommands) : 0);
|
|
#endif
|
|
#endif
|
|
|
|
|
|
currentPeer -> packetLossVariance = (currentPeer -> packetLossVariance * 3 + ENET_DIFFERENCE (packetLoss, currentPeer -> packetLoss)) / 4;
|
|
currentPeer -> packetLossVariance = (currentPeer -> packetLossVariance * 3 + ENET_DIFFERENCE (packetLoss, currentPeer -> packetLoss)) / 4;
|