From 01cd8014da2d369ed72cffb9b6e7fc7c9392ab3c Mon Sep 17 00:00:00 2001 From: Teravus Ovares Date: Thu, 22 Nov 2007 23:14:38 +0000 Subject: * Added another code path to skip the packet throttle queues when there's no need to queue the packet up. --- .../Region/ClientStack/ClientView.PacketQueue.cs | 80 ++++++++++++++++++++-- 1 file changed, 73 insertions(+), 7 deletions(-) (limited to 'OpenSim/Region/ClientStack/ClientView.PacketQueue.cs') diff --git a/OpenSim/Region/ClientStack/ClientView.PacketQueue.cs b/OpenSim/Region/ClientStack/ClientView.PacketQueue.cs index 3ce3d8c..bd22970 100644 --- a/OpenSim/Region/ClientStack/ClientView.PacketQueue.cs +++ b/OpenSim/Region/ClientStack/ClientView.PacketQueue.cs @@ -225,28 +225,94 @@ namespace OpenSim.Region.ClientStack item.Packet = NewPack; item.Incoming = false; item.throttleType = throttlePacketType; // Packet throttle type + + // The idea.. is if the packet throttle queues are empty and the client is under throttle for the type. + // Queue it up directly. switch (throttlePacketType) { case ThrottleOutPacketType.Resend: - ResendOutgoingPacketQueue.Enqueue(item); + if (ResendthrottleSentPeriod <= ResendthrottleOutbound && ResendOutgoingPacketQueue.Count == 0) + { + throttleSentPeriod += item.Packet.ToBytes().Length; + ResendthrottleSentPeriod += item.Packet.ToBytes().Length; + PacketQueue.Enqueue(item); + } + else + { + ResendOutgoingPacketQueue.Enqueue(item); + } break; case ThrottleOutPacketType.Texture: - TextureOutgoingPacketQueue.Enqueue(item); + if (TexturethrottleSentPeriod <= TexturethrottleOutbound && TextureOutgoingPacketQueue.Count == 0) + { + throttleSentPeriod += item.Packet.ToBytes().Length; + TexturethrottleSentPeriod += item.Packet.ToBytes().Length; + PacketQueue.Enqueue(item); + } + else + { + TextureOutgoingPacketQueue.Enqueue(item); + } break; case ThrottleOutPacketType.Task: - TaskOutgoingPacketQueue.Enqueue(item); + if (TaskthrottleSentPeriod <= TaskthrottleOutbound && TaskOutgoingPacketQueue.Count == 0) + { + throttleSentPeriod += item.Packet.ToBytes().Length; + TaskthrottleSentPeriod += item.Packet.ToBytes().Length; + PacketQueue.Enqueue(item); + } + else + { + TaskOutgoingPacketQueue.Enqueue(item); + } break; case ThrottleOutPacketType.Land: - LandOutgoingPacketQueue.Enqueue(item); + if (LandthrottleSentPeriod <= LandthrottleOutbound && LandOutgoingPacketQueue.Count == 0) + { + throttleSentPeriod += item.Packet.ToBytes().Length; + LandthrottleSentPeriod += item.Packet.ToBytes().Length; + PacketQueue.Enqueue(item); + } + else + { + LandOutgoingPacketQueue.Enqueue(item); + } break; case ThrottleOutPacketType.Asset: - AssetOutgoingPacketQueue.Enqueue(item); + if (AssetthrottleSentPeriod <= AssetthrottleOutbound && AssetOutgoingPacketQueue.Count == 0) + { + throttleSentPeriod += item.Packet.ToBytes().Length; + AssetthrottleSentPeriod += item.Packet.ToBytes().Length; + PacketQueue.Enqueue(item); + } + else + { + AssetOutgoingPacketQueue.Enqueue(item); + } break; case ThrottleOutPacketType.Cloud: - CloudOutgoingPacketQueue.Enqueue(item); + if (CloudthrottleSentPeriod <= CloudthrottleOutbound && CloudOutgoingPacketQueue.Count == 0) + { + throttleSentPeriod += item.Packet.ToBytes().Length; + CloudthrottleSentPeriod += item.Packet.ToBytes().Length; + PacketQueue.Enqueue(item); + } + else + { + CloudOutgoingPacketQueue.Enqueue(item); + } break; case ThrottleOutPacketType.Wind: - WindOutgoingPacketQueue.Enqueue(item); + if (WindthrottleSentPeriod <= WindthrottleOutbound && WindOutgoingPacketQueue.Count == 0) + { + throttleSentPeriod += item.Packet.ToBytes().Length; + WindthrottleSentPeriod += item.Packet.ToBytes().Length; + PacketQueue.Enqueue(item); + } + else + { + WindOutgoingPacketQueue.Enqueue(item); + } break; default: -- cgit v1.1