diff options
Diffstat (limited to 'OpenSim/Region/ClientStack/Linden/Caps/GetMeshModule.cs')
-rw-r--r-- | OpenSim/Region/ClientStack/Linden/Caps/GetMeshModule.cs | 81 |
1 files changed, 25 insertions, 56 deletions
diff --git a/OpenSim/Region/ClientStack/Linden/Caps/GetMeshModule.cs b/OpenSim/Region/ClientStack/Linden/Caps/GetMeshModule.cs index a721454..ba917e39 100644 --- a/OpenSim/Region/ClientStack/Linden/Caps/GetMeshModule.cs +++ b/OpenSim/Region/ClientStack/Linden/Caps/GetMeshModule.cs | |||
@@ -221,7 +221,7 @@ namespace OpenSim.Region.ClientStack.Linden | |||
221 | PollServiceMeshEventArgs args; | 221 | PollServiceMeshEventArgs args; |
222 | if (m_pollservices.TryGetValue(user, out args)) | 222 | if (m_pollservices.TryGetValue(user, out args)) |
223 | { | 223 | { |
224 | args.UpdateThrottle(imagethrottle, p); | 224 | args.UpdateThrottle(imagethrottle); |
225 | } | 225 | } |
226 | } | 226 | } |
227 | 227 | ||
@@ -238,14 +238,13 @@ namespace OpenSim.Region.ClientStack.Linden | |||
238 | base(null, uri, null, null, null, pId, int.MaxValue) | 238 | base(null, uri, null, null, null, pId, int.MaxValue) |
239 | { | 239 | { |
240 | m_scene = scene; | 240 | m_scene = scene; |
241 | m_throttler = new MeshCapsDataThrottler(100000, 1400000, 10000, scene, pId); | 241 | m_throttler = new MeshCapsDataThrottler(100000); |
242 | // x is request id, y is userid | 242 | // x is request id, y is userid |
243 | HasEvents = (x, y) => | 243 | HasEvents = (x, y) => |
244 | { | 244 | { |
245 | lock (responses) | 245 | lock (responses) |
246 | { | 246 | { |
247 | bool ret = m_throttler.hasEvents(x, responses); | 247 | bool ret = m_throttler.hasEvents(x, responses); |
248 | m_throttler.ProcessTime(); | ||
249 | return ret; | 248 | return ret; |
250 | 249 | ||
251 | } | 250 | } |
@@ -260,8 +259,8 @@ namespace OpenSim.Region.ClientStack.Linden | |||
260 | } | 259 | } |
261 | finally | 260 | finally |
262 | { | 261 | { |
263 | m_throttler.ProcessTime(); | ||
264 | responses.Remove(x); | 262 | responses.Remove(x); |
263 | m_throttler.PassTime(); | ||
265 | } | 264 | } |
266 | } | 265 | } |
267 | }; | 266 | }; |
@@ -274,6 +273,7 @@ namespace OpenSim.Region.ClientStack.Linden | |||
274 | reqinfo.request = y; | 273 | reqinfo.request = y; |
275 | 274 | ||
276 | m_queue.Enqueue(reqinfo); | 275 | m_queue.Enqueue(reqinfo); |
276 | m_throttler.PassTime(); | ||
277 | }; | 277 | }; |
278 | 278 | ||
279 | // this should never happen except possible on shutdown | 279 | // this should never happen except possible on shutdown |
@@ -335,12 +335,15 @@ namespace OpenSim.Region.ClientStack.Linden | |||
335 | }; | 335 | }; |
336 | 336 | ||
337 | } | 337 | } |
338 | m_throttler.ProcessTime(); | 338 | m_throttler.PassTime(); |
339 | } | 339 | } |
340 | 340 | ||
341 | internal void UpdateThrottle(int pimagethrottle, ScenePresence p) | 341 | internal void UpdateThrottle(int pthrottle) |
342 | { | 342 | { |
343 | m_throttler.UpdateThrottle(pimagethrottle, p); | 343 | int tmp = 2 * pthrottle; |
344 | if(tmp < 10000) | ||
345 | tmp = 10000; | ||
346 | m_throttler.ThrottleBytes = tmp; | ||
344 | } | 347 | } |
345 | } | 348 | } |
346 | 349 | ||
@@ -394,25 +397,15 @@ namespace OpenSim.Region.ClientStack.Linden | |||
394 | 397 | ||
395 | internal sealed class MeshCapsDataThrottler | 398 | internal sealed class MeshCapsDataThrottler |
396 | { | 399 | { |
400 | private double lastTimeElapsed = 0; | ||
401 | private double BytesSent = 0; | ||
397 | 402 | ||
398 | private volatile int currenttime = 0; | 403 | public MeshCapsDataThrottler(int pBytes) |
399 | private volatile int lastTimeElapsed = 0; | ||
400 | private volatile int BytesSent = 0; | ||
401 | private int CapSetThrottle = 0; | ||
402 | private float CapThrottleDistributon = 0.30f; | ||
403 | private readonly Scene m_scene; | ||
404 | private ThrottleOutPacketType Throttle; | ||
405 | private readonly UUID User; | ||
406 | |||
407 | public MeshCapsDataThrottler(int pBytes, int max, int min, Scene pScene, UUID puser) | ||
408 | { | 404 | { |
405 | if(pBytes < 10000) | ||
406 | pBytes = 10000; | ||
409 | ThrottleBytes = pBytes; | 407 | ThrottleBytes = pBytes; |
410 | if(ThrottleBytes < 10000) | 408 | lastTimeElapsed = Util.GetTimeStampMS(); |
411 | ThrottleBytes = 10000; | ||
412 | lastTimeElapsed = Util.EnvironmentTickCount(); | ||
413 | Throttle = ThrottleOutPacketType.Asset; | ||
414 | m_scene = pScene; | ||
415 | User = puser; | ||
416 | } | 409 | } |
417 | 410 | ||
418 | public bool hasEvents(UUID key, Dictionary<UUID, aPollResponse> responses) | 411 | public bool hasEvents(UUID key, Dictionary<UUID, aPollResponse> responses) |
@@ -442,46 +435,22 @@ namespace OpenSim.Region.ClientStack.Linden | |||
442 | return haskey; | 435 | return haskey; |
443 | } | 436 | } |
444 | 437 | ||
445 | public void ProcessTime() | 438 | public void PassTime() |
446 | { | ||
447 | PassTime(); | ||
448 | } | ||
449 | |||
450 | private void PassTime() | ||
451 | { | 439 | { |
452 | currenttime = Util.EnvironmentTickCount(); | 440 | double currenttime = Util.GetTimeStampMS(); |
453 | int timeElapsed = Util.EnvironmentTickCountSubtract(currenttime, lastTimeElapsed); | 441 | double timeElapsed = currenttime - lastTimeElapsed; |
454 | if (timeElapsed >= 100) | 442 | if(timeElapsed < 50.0) |
443 | return; | ||
444 | int add = (int)(ThrottleBytes * timeElapsed * 0.001); | ||
445 | if (add >= 1000) | ||
455 | { | 446 | { |
456 | lastTimeElapsed = currenttime; | 447 | lastTimeElapsed = currenttime; |
457 | BytesSent -= (ThrottleBytes * timeElapsed / 1000); | 448 | BytesSent -= add; |
458 | if (BytesSent < 0) BytesSent = 0; | 449 | if (BytesSent < 0) BytesSent = 0; |
459 | } | 450 | } |
460 | } | 451 | } |
461 | 452 | ||
462 | private void AlterThrottle(int setting, ScenePresence p) | 453 | public int ThrottleBytes; |
463 | { | ||
464 | p.ControllingClient.SetAgentThrottleSilent((int)Throttle,setting); | ||
465 | } | ||
466 | |||
467 | public int ThrottleBytes | ||
468 | { | ||
469 | get { return CapSetThrottle; } | ||
470 | set | ||
471 | { | ||
472 | if (value > 10000) | ||
473 | CapSetThrottle = value; | ||
474 | else | ||
475 | CapSetThrottle = 10000; | ||
476 | } | ||
477 | } | ||
478 | |||
479 | internal void UpdateThrottle(int pimagethrottle, ScenePresence p) | ||
480 | { | ||
481 | // Client set throttle ! | ||
482 | CapSetThrottle = 2 * pimagethrottle; | ||
483 | ProcessTime(); | ||
484 | } | ||
485 | } | 454 | } |
486 | } | 455 | } |
487 | } | 456 | } |