diff options
Diffstat (limited to 'OpenSim/Region/ClientStack')
-rw-r--r-- | OpenSim/Region/ClientStack/ClientView.PacketQueue.cs | 98 |
1 files changed, 27 insertions, 71 deletions
diff --git a/OpenSim/Region/ClientStack/ClientView.PacketQueue.cs b/OpenSim/Region/ClientStack/ClientView.PacketQueue.cs index 02639bf..d7b86e8 100644 --- a/OpenSim/Region/ClientStack/ClientView.PacketQueue.cs +++ b/OpenSim/Region/ClientStack/ClientView.PacketQueue.cs | |||
@@ -220,6 +220,26 @@ namespace OpenSim.Region.ClientStack | |||
220 | } | 220 | } |
221 | } | 221 | } |
222 | 222 | ||
223 | private void ThrottleCheck(ref int TypeBytesSent, int Throttle, Queue<QueItem> q, QueItem item) | ||
224 | { | ||
225 | // The idea.. is if the packet throttle queues are empty | ||
226 | // and the client is under throttle for the type. Queue | ||
227 | // it up directly. This basically short cuts having to | ||
228 | // wait for the timer to fire to put things into the | ||
229 | // output queue | ||
230 | |||
231 | if(q.Count == 0 && TypeBytesSent <= ((int)(Throttle / throttleTimeDivisor))) | ||
232 | { | ||
233 | bytesSent += item.Packet.ToBytes().Length; | ||
234 | TypeBytesSent += item.Packet.ToBytes().Length; | ||
235 | PacketQueue.Enqueue(item); | ||
236 | } | ||
237 | else | ||
238 | { | ||
239 | q.Enqueue(item); | ||
240 | } | ||
241 | } | ||
242 | |||
223 | public virtual void OutPacket(Packet NewPack, ThrottleOutPacketType throttlePacketType) | 243 | public virtual void OutPacket(Packet NewPack, ThrottleOutPacketType throttlePacketType) |
224 | { | 244 | { |
225 | QueItem item = new QueItem(); | 245 | QueItem item = new QueItem(); |
@@ -232,92 +252,28 @@ namespace OpenSim.Region.ClientStack | |||
232 | switch (throttlePacketType) | 252 | switch (throttlePacketType) |
233 | { | 253 | { |
234 | case ThrottleOutPacketType.Resend: | 254 | case ThrottleOutPacketType.Resend: |
235 | if (ResendBytesSent <= ((int)(ResendthrottleOutbound / throttleTimeDivisor)) && ResendOutgoingPacketQueue.Count == 0) | 255 | ThrottleCheck(ref ResendBytesSent, ResendthrottleOutbound, ResendOutgoingPacketQueue, item); |
236 | { | ||
237 | bytesSent += item.Packet.ToBytes().Length; | ||
238 | ResendBytesSent += item.Packet.ToBytes().Length; | ||
239 | PacketQueue.Enqueue(item); | ||
240 | } | ||
241 | else | ||
242 | { | ||
243 | ResendOutgoingPacketQueue.Enqueue(item); | ||
244 | } | ||
245 | break; | 256 | break; |
246 | case ThrottleOutPacketType.Texture: | 257 | case ThrottleOutPacketType.Texture: |
247 | if (TextureBytesSent <= ((int)(TexturethrottleOutbound / throttleTimeDivisor)) && TextureOutgoingPacketQueue.Count == 0) | 258 | ThrottleCheck(ref TextureBytesSent, TexturethrottleOutbound, TextureOutgoingPacketQueue, item); |
248 | { | ||
249 | bytesSent += item.Packet.ToBytes().Length; | ||
250 | TextureBytesSent += item.Packet.ToBytes().Length; | ||
251 | PacketQueue.Enqueue(item); | ||
252 | } | ||
253 | else | ||
254 | { | ||
255 | TextureOutgoingPacketQueue.Enqueue(item); | ||
256 | } | ||
257 | break; | 259 | break; |
258 | case ThrottleOutPacketType.Task: | 260 | case ThrottleOutPacketType.Task: |
259 | if (TaskBytesSent <= ((int)(TexturethrottleOutbound / throttleTimeDivisor)) && TaskOutgoingPacketQueue.Count == 0) | 261 | ThrottleCheck(ref TaskBytesSent, TaskthrottleOutbound, TaskOutgoingPacketQueue, item); |
260 | { | ||
261 | bytesSent += item.Packet.ToBytes().Length; | ||
262 | TaskBytesSent += item.Packet.ToBytes().Length; | ||
263 | PacketQueue.Enqueue(item); | ||
264 | } | ||
265 | else | ||
266 | { | ||
267 | TaskOutgoingPacketQueue.Enqueue(item); | ||
268 | } | ||
269 | break; | 262 | break; |
270 | case ThrottleOutPacketType.Land: | 263 | case ThrottleOutPacketType.Land: |
271 | if (LandBytesSent <= ((int)(LandthrottleOutbound / throttleTimeDivisor)) && LandOutgoingPacketQueue.Count == 0) | 264 | ThrottleCheck(ref LandBytesSent, LandthrottleOutbound, LandOutgoingPacketQueue, item); |
272 | { | ||
273 | bytesSent += item.Packet.ToBytes().Length; | ||
274 | LandBytesSent += item.Packet.ToBytes().Length; | ||
275 | PacketQueue.Enqueue(item); | ||
276 | } | ||
277 | else | ||
278 | { | ||
279 | LandOutgoingPacketQueue.Enqueue(item); | ||
280 | } | ||
281 | break; | 265 | break; |
282 | case ThrottleOutPacketType.Asset: | 266 | case ThrottleOutPacketType.Asset: |
283 | if (AssetBytesSent <= ((int)(AssetthrottleOutbound / throttleTimeDivisor)) && AssetOutgoingPacketQueue.Count == 0) | 267 | ThrottleCheck(ref AssetBytesSent, AssetthrottleOutbound, AssetOutgoingPacketQueue, item); |
284 | { | ||
285 | bytesSent += item.Packet.ToBytes().Length; | ||
286 | AssetBytesSent += item.Packet.ToBytes().Length; | ||
287 | PacketQueue.Enqueue(item); | ||
288 | } | ||
289 | else | ||
290 | { | ||
291 | AssetOutgoingPacketQueue.Enqueue(item); | ||
292 | } | ||
293 | break; | 268 | break; |
294 | case ThrottleOutPacketType.Cloud: | 269 | case ThrottleOutPacketType.Cloud: |
295 | if (CloudBytesSent <= ((int)(CloudthrottleOutbound / throttleTimeDivisor)) && CloudOutgoingPacketQueue.Count == 0) | 270 | ThrottleCheck(ref CloudBytesSent, CloudthrottleOutbound, CloudOutgoingPacketQueue, item); |
296 | { | ||
297 | bytesSent += item.Packet.ToBytes().Length; | ||
298 | CloudBytesSent += item.Packet.ToBytes().Length; | ||
299 | PacketQueue.Enqueue(item); | ||
300 | } | ||
301 | else | ||
302 | { | ||
303 | CloudOutgoingPacketQueue.Enqueue(item); | ||
304 | } | ||
305 | break; | 271 | break; |
306 | case ThrottleOutPacketType.Wind: | 272 | case ThrottleOutPacketType.Wind: |
307 | if (WindBytesSent <= ((int)(WindthrottleOutbound / throttleTimeDivisor)) && WindOutgoingPacketQueue.Count == 0) | 273 | ThrottleCheck(ref WindBytesSent, WindthrottleOutbound, WindOutgoingPacketQueue, item); |
308 | { | ||
309 | bytesSent += item.Packet.ToBytes().Length; | ||
310 | WindBytesSent += item.Packet.ToBytes().Length; | ||
311 | PacketQueue.Enqueue(item); | ||
312 | } | ||
313 | else | ||
314 | { | ||
315 | WindOutgoingPacketQueue.Enqueue(item); | ||
316 | } | ||
317 | break; | 274 | break; |
318 | 275 | ||
319 | default: | 276 | default: |
320 | |||
321 | // Acknowledgements and other such stuff should go directly to the blocking Queue | 277 | // Acknowledgements and other such stuff should go directly to the blocking Queue |
322 | // Throttling them may and likely 'will' be problematic | 278 | // Throttling them may and likely 'will' be problematic |
323 | PacketQueue.Enqueue(item); | 279 | PacketQueue.Enqueue(item); |