diff options
Diffstat (limited to 'OpenSim')
-rw-r--r-- | OpenSim/Region/ClientStack/Linden/UDP/LLUDPServer.cs | 23 |
1 files changed, 12 insertions, 11 deletions
diff --git a/OpenSim/Region/ClientStack/Linden/UDP/LLUDPServer.cs b/OpenSim/Region/ClientStack/Linden/UDP/LLUDPServer.cs index 8f345e7..f8952b0 100644 --- a/OpenSim/Region/ClientStack/Linden/UDP/LLUDPServer.cs +++ b/OpenSim/Region/ClientStack/Linden/UDP/LLUDPServer.cs | |||
@@ -286,7 +286,7 @@ namespace OpenSim.Region.ClientStack.LindenUDP | |||
286 | /// <summary>Incoming packets that are awaiting handling</summary> | 286 | /// <summary>Incoming packets that are awaiting handling</summary> |
287 | //private OpenMetaverse.BlockingQueue<IncomingPacket> packetInbox = new OpenMetaverse.BlockingQueue<IncomingPacket>(); | 287 | //private OpenMetaverse.BlockingQueue<IncomingPacket> packetInbox = new OpenMetaverse.BlockingQueue<IncomingPacket>(); |
288 | 288 | ||
289 | private DoubleQueue<IncomingPacket> packetInbox = new DoubleQueue<IncomingPacket>(); | 289 | private OpenSim.Framework.BlockingQueue<IncomingPacket> packetInbox = new OpenSim.Framework.BlockingQueue<IncomingPacket>(); |
290 | 290 | ||
291 | /// <summary>Bandwidth throttle for this UDP server</summary> | 291 | /// <summary>Bandwidth throttle for this UDP server</summary> |
292 | public TokenBucket Throttle { get; private set; } | 292 | public TokenBucket Throttle { get; private set; } |
@@ -716,7 +716,7 @@ namespace OpenSim.Region.ClientStack.LindenUDP | |||
716 | scene.Name, | 716 | scene.Name, |
717 | StatType.Pull, | 717 | StatType.Pull, |
718 | MeasuresOfInterest.AverageChangeOverTime, | 718 | MeasuresOfInterest.AverageChangeOverTime, |
719 | stat => stat.Value = packetInbox.Count, | 719 | stat => stat.Value = packetInbox.Count(), |
720 | StatVerbosity.Debug)); | 720 | StatVerbosity.Debug)); |
721 | 721 | ||
722 | // XXX: These stats are also pool stats but we register them separately since they are currently not | 722 | // XXX: These stats are also pool stats but we register them separately since they are currently not |
@@ -1552,9 +1552,9 @@ namespace OpenSim.Region.ClientStack.LindenUDP | |||
1552 | // if (incomingPacket.Packet.Type == PacketType.AgentUpdate || | 1552 | // if (incomingPacket.Packet.Type == PacketType.AgentUpdate || |
1553 | // incomingPacket.Packet.Type == PacketType.ChatFromViewer) | 1553 | // incomingPacket.Packet.Type == PacketType.ChatFromViewer) |
1554 | if (incomingPacket.Packet.Type == PacketType.ChatFromViewer) | 1554 | if (incomingPacket.Packet.Type == PacketType.ChatFromViewer) |
1555 | packetInbox.EnqueueHigh(incomingPacket); | 1555 | packetInbox.PriorityEnqueue(incomingPacket); |
1556 | else | 1556 | else |
1557 | packetInbox.EnqueueLow(incomingPacket); | 1557 | packetInbox.Enqueue(incomingPacket); |
1558 | 1558 | ||
1559 | } | 1559 | } |
1560 | 1560 | ||
@@ -2012,7 +2012,7 @@ namespace OpenSim.Region.ClientStack.LindenUDP | |||
2012 | private void IncomingPacketHandler() | 2012 | private void IncomingPacketHandler() |
2013 | { | 2013 | { |
2014 | Thread.CurrentThread.Priority = ThreadPriority.Highest; | 2014 | Thread.CurrentThread.Priority = ThreadPriority.Highest; |
2015 | 2015 | IncomingPacket incomingPacket; | |
2016 | // Set this culture for the thread that incoming packets are received | 2016 | // Set this culture for the thread that incoming packets are received |
2017 | // on to en-US to avoid number parsing issues | 2017 | // on to en-US to avoid number parsing issues |
2018 | Culture.SetCurrentCulture(); | 2018 | Culture.SetCurrentCulture(); |
@@ -2022,8 +2022,6 @@ namespace OpenSim.Region.ClientStack.LindenUDP | |||
2022 | Scene.ThreadAlive(1); | 2022 | Scene.ThreadAlive(1); |
2023 | try | 2023 | try |
2024 | { | 2024 | { |
2025 | IncomingPacket incomingPacket = null; | ||
2026 | |||
2027 | /* | 2025 | /* |
2028 | // HACK: This is a test to try and rate limit packet handling on Mono. | 2026 | // HACK: This is a test to try and rate limit packet handling on Mono. |
2029 | // If it works, a more elegant solution can be devised | 2027 | // If it works, a more elegant solution can be devised |
@@ -2033,14 +2031,17 @@ namespace OpenSim.Region.ClientStack.LindenUDP | |||
2033 | Thread.Sleep(30); | 2031 | Thread.Sleep(30); |
2034 | } | 2032 | } |
2035 | */ | 2033 | */ |
2036 | 2034 | incomingPacket = packetInbox.Dequeue(500); | |
2037 | if (packetInbox.Dequeue(100, ref incomingPacket)) | 2035 | |
2036 | if (incomingPacket != null) | ||
2038 | { | 2037 | { |
2039 | ProcessInPacket(incomingPacket);//, incomingPacket); Util.FireAndForget(ProcessInPacket, incomingPacket); | 2038 | ProcessInPacket(incomingPacket);//, incomingPacket); Util.FireAndForget(ProcessInPacket, incomingPacket); |
2040 | 2039 | ||
2041 | if (UsePools) | 2040 | if (UsePools) |
2042 | m_incomingPacketPool.ReturnObject(incomingPacket); | 2041 | m_incomingPacketPool.ReturnObject(incomingPacket); |
2043 | } | 2042 | } |
2043 | |||
2044 | incomingPacket = null; | ||
2044 | } | 2045 | } |
2045 | catch(Exception ex) | 2046 | catch(Exception ex) |
2046 | { | 2047 | { |
@@ -2050,8 +2051,8 @@ namespace OpenSim.Region.ClientStack.LindenUDP | |||
2050 | Watchdog.UpdateThread(); | 2051 | Watchdog.UpdateThread(); |
2051 | } | 2052 | } |
2052 | 2053 | ||
2053 | if (packetInbox.Count > 0) | 2054 | if (packetInbox.Count() > 0) |
2054 | m_log.Warn("[LLUDPSERVER]: IncomingPacketHandler is shutting down, dropping " + packetInbox.Count + " packets"); | 2055 | m_log.Warn("[LLUDPSERVER]: IncomingPacketHandler is shutting down, dropping " + packetInbox.Count() + " packets"); |
2055 | packetInbox.Clear(); | 2056 | packetInbox.Clear(); |
2056 | 2057 | ||
2057 | Watchdog.RemoveThread(); | 2058 | Watchdog.RemoveThread(); |