diff options
Diffstat (limited to '')
-rw-r--r-- | OpenSim/Region/ClientStack/Linden/Caps/GetTextureModule.cs | 121 |
1 files changed, 61 insertions, 60 deletions
diff --git a/OpenSim/Region/ClientStack/Linden/Caps/GetTextureModule.cs b/OpenSim/Region/ClientStack/Linden/Caps/GetTextureModule.cs index d1ec4aa..dd87671 100644 --- a/OpenSim/Region/ClientStack/Linden/Caps/GetTextureModule.cs +++ b/OpenSim/Region/ClientStack/Linden/Caps/GetTextureModule.cs | |||
@@ -361,80 +361,81 @@ namespace OpenSim.Region.ClientStack.Linden | |||
361 | poolreq.thepoll.Process(poolreq); | 361 | poolreq.thepoll.Process(poolreq); |
362 | } | 362 | } |
363 | } | 363 | } |
364 | } | 364 | internal sealed class CapsDataThrottler |
365 | |||
366 | internal sealed class CapsDataThrottler | ||
367 | { | ||
368 | |||
369 | private volatile int currenttime = 0; | ||
370 | private volatile int lastTimeElapsed = 0; | ||
371 | private volatile int BytesSent = 0; | ||
372 | private int oversizedImages = 0; | ||
373 | public CapsDataThrottler(int pBytes, int max, int min) | ||
374 | { | ||
375 | ThrottleBytes = pBytes; | ||
376 | lastTimeElapsed = Util.EnvironmentTickCount(); | ||
377 | } | ||
378 | public bool hasEvents(UUID key, Dictionary<UUID, GetTextureModule.aPollResponse> responses) | ||
379 | { | 365 | { |
380 | PassTime(); | 366 | |
381 | // Note, this is called IN LOCK | 367 | private volatile int currenttime = 0; |
382 | bool haskey = responses.ContainsKey(key); | 368 | private volatile int lastTimeElapsed = 0; |
383 | if (!haskey) | 369 | private volatile int BytesSent = 0; |
370 | private int oversizedImages = 0; | ||
371 | public CapsDataThrottler(int pBytes, int max, int min) | ||
384 | { | 372 | { |
385 | return false; | 373 | ThrottleBytes = pBytes; |
374 | lastTimeElapsed = Util.EnvironmentTickCount(); | ||
386 | } | 375 | } |
387 | GetTextureModule.aPollResponse response; | 376 | public bool hasEvents(UUID key, Dictionary<UUID, GetTextureModule.aPollResponse> responses) |
388 | if (responses.TryGetValue(key,out response)) | ||
389 | { | 377 | { |
390 | 378 | PassTime(); | |
391 | // Normal | 379 | // Note, this is called IN LOCK |
392 | if (BytesSent + response.bytes <= ThrottleBytes) | 380 | bool haskey = responses.ContainsKey(key); |
381 | if (!haskey) | ||
393 | { | 382 | { |
394 | BytesSent += response.bytes; | 383 | return false; |
395 | //TimeBasedAction timeBasedAction = new TimeBasedAction { byteRemoval = response.bytes, requestId = key, timeMS = currenttime + 1000, unlockyn = false }; | ||
396 | //m_actions.Add(timeBasedAction); | ||
397 | return true; | ||
398 | } | ||
399 | // Big textures | ||
400 | else if (response.bytes > ThrottleBytes && oversizedImages <= ((ThrottleBytes%50000) + 1)) | ||
401 | { | ||
402 | Interlocked.Increment(ref oversizedImages); | ||
403 | BytesSent += response.bytes; | ||
404 | //TimeBasedAction timeBasedAction = new TimeBasedAction { byteRemoval = response.bytes, requestId = key, timeMS = currenttime + (((response.bytes % ThrottleBytes)+1)*1000) , unlockyn = false }; | ||
405 | //m_actions.Add(timeBasedAction); | ||
406 | return true; | ||
407 | } | 384 | } |
408 | else | 385 | GetTextureModule.aPollResponse response; |
386 | if (responses.TryGetValue(key, out response)) | ||
409 | { | 387 | { |
410 | return false; | 388 | |
389 | // Normal | ||
390 | if (BytesSent + response.bytes <= ThrottleBytes) | ||
391 | { | ||
392 | BytesSent += response.bytes; | ||
393 | //TimeBasedAction timeBasedAction = new TimeBasedAction { byteRemoval = response.bytes, requestId = key, timeMS = currenttime + 1000, unlockyn = false }; | ||
394 | //m_actions.Add(timeBasedAction); | ||
395 | return true; | ||
396 | } | ||
397 | // Big textures | ||
398 | else if (response.bytes > ThrottleBytes && oversizedImages <= ((ThrottleBytes % 50000) + 1)) | ||
399 | { | ||
400 | Interlocked.Increment(ref oversizedImages); | ||
401 | BytesSent += response.bytes; | ||
402 | //TimeBasedAction timeBasedAction = new TimeBasedAction { byteRemoval = response.bytes, requestId = key, timeMS = currenttime + (((response.bytes % ThrottleBytes)+1)*1000) , unlockyn = false }; | ||
403 | //m_actions.Add(timeBasedAction); | ||
404 | return true; | ||
405 | } | ||
406 | else | ||
407 | { | ||
408 | return false; | ||
409 | } | ||
411 | } | 410 | } |
411 | |||
412 | return haskey; | ||
413 | } | ||
414 | public void ProcessTime() | ||
415 | { | ||
416 | PassTime(); | ||
412 | } | 417 | } |
413 | 418 | ||
414 | return haskey; | 419 | |
415 | } | 420 | private void PassTime() |
416 | public void ProcessTime() | ||
417 | { | ||
418 | PassTime(); | ||
419 | } | ||
420 | |||
421 | |||
422 | private void PassTime() | ||
423 | { | ||
424 | currenttime = Util.EnvironmentTickCount(); | ||
425 | int timeElapsed = Util.EnvironmentTickCountSubtract(currenttime, lastTimeElapsed); | ||
426 | //processTimeBasedActions(responses); | ||
427 | if (Util.EnvironmentTickCountSubtract(currenttime, timeElapsed) >= 1000) | ||
428 | { | 421 | { |
429 | lastTimeElapsed = Util.EnvironmentTickCount(); | 422 | currenttime = Util.EnvironmentTickCount(); |
430 | BytesSent -= ThrottleBytes; | 423 | int timeElapsed = Util.EnvironmentTickCountSubtract(currenttime, lastTimeElapsed); |
431 | if (BytesSent < 0) BytesSent = 0; | 424 | //processTimeBasedActions(responses); |
432 | if (BytesSent < ThrottleBytes) | 425 | if (Util.EnvironmentTickCountSubtract(currenttime, timeElapsed) >= 1000) |
433 | { | 426 | { |
434 | oversizedImages = 0; | 427 | lastTimeElapsed = Util.EnvironmentTickCount(); |
428 | BytesSent -= ThrottleBytes; | ||
429 | if (BytesSent < 0) BytesSent = 0; | ||
430 | if (BytesSent < ThrottleBytes) | ||
431 | { | ||
432 | oversizedImages = 0; | ||
433 | } | ||
435 | } | 434 | } |
436 | } | 435 | } |
436 | public int ThrottleBytes; | ||
437 | } | 437 | } |
438 | public int ThrottleBytes; | ||
439 | } | 438 | } |
439 | |||
440 | |||
440 | } | 441 | } |