diff options
Diffstat (limited to '')
-rw-r--r-- | OpenSim/Region/CoreModules/Agent/Xfer/XferModule.cs | 84 |
1 files changed, 39 insertions, 45 deletions
diff --git a/OpenSim/Region/CoreModules/Agent/Xfer/XferModule.cs b/OpenSim/Region/CoreModules/Agent/Xfer/XferModule.cs index 8b7a82d..32b3523 100644 --- a/OpenSim/Region/CoreModules/Agent/Xfer/XferModule.cs +++ b/OpenSim/Region/CoreModules/Agent/Xfer/XferModule.cs | |||
@@ -50,8 +50,8 @@ namespace OpenSim.Region.CoreModules.Agent.Xfer | |||
50 | private static readonly ILog m_log = LogManager.GetLogger(MethodBase.GetCurrentMethod().DeclaringType); | 50 | private static readonly ILog m_log = LogManager.GetLogger(MethodBase.GetCurrentMethod().DeclaringType); |
51 | 51 | ||
52 | private object timeTickLock = new object(); | 52 | private object timeTickLock = new object(); |
53 | private double lastTimeTick = 0.0; | 53 | private int lastTimeTick = 0; |
54 | private double lastFilesExpire = 0.0; | 54 | private int lastFilesExpire = 0; |
55 | private bool inTimeTick = false; | 55 | private bool inTimeTick = false; |
56 | 56 | ||
57 | public struct XferRequest | 57 | public struct XferRequest |
@@ -66,15 +66,15 @@ namespace OpenSim.Region.CoreModules.Agent.Xfer | |||
66 | { | 66 | { |
67 | public byte[] Data; | 67 | public byte[] Data; |
68 | public int refsCount; | 68 | public int refsCount; |
69 | public double timeStampMS; | 69 | public int timeStampMS; |
70 | } | 70 | } |
71 | 71 | ||
72 | #region INonSharedRegionModule Members | 72 | #region INonSharedRegionModule Members |
73 | 73 | ||
74 | public void Initialise(IConfigSource config) | 74 | public void Initialise(IConfigSource config) |
75 | { | 75 | { |
76 | lastTimeTick = Util.GetTimeStampMS() + 30000.0; | 76 | lastTimeTick = (int)Util.GetTimeStampMS() + 30000; |
77 | lastFilesExpire = lastTimeTick + 180000.0; | 77 | lastFilesExpire = lastTimeTick + 180000; |
78 | } | 78 | } |
79 | 79 | ||
80 | public void AddRegion(Scene scene) | 80 | public void AddRegion(Scene scene) |
@@ -121,10 +121,9 @@ namespace OpenSim.Region.CoreModules.Agent.Xfer | |||
121 | { | 121 | { |
122 | if(!inTimeTick) | 122 | if(!inTimeTick) |
123 | { | 123 | { |
124 | double now = Util.GetTimeStampMS(); | 124 | int now = (int)Util.GetTimeStampMS(); |
125 | if(now - lastTimeTick > 750.0) | 125 | if(now - lastTimeTick > 750) |
126 | { | 126 | { |
127 | |||
128 | if(Transfers.Count == 0 && NewFiles.Count == 0) | 127 | if(Transfers.Count == 0 && NewFiles.Count == 0) |
129 | lastTimeTick = now; | 128 | lastTimeTick = now; |
130 | else | 129 | else |
@@ -163,7 +162,7 @@ namespace OpenSim.Region.CoreModules.Agent.Xfer | |||
163 | { | 162 | { |
164 | lock (NewFiles) | 163 | lock (NewFiles) |
165 | { | 164 | { |
166 | double now = Util.GetTimeStampMS(); | 165 | int now = (int)Util.GetTimeStampMS(); |
167 | if (NewFiles.ContainsKey(fileName)) | 166 | if (NewFiles.ContainsKey(fileName)) |
168 | { | 167 | { |
169 | NewFiles[fileName].refsCount++; | 168 | NewFiles[fileName].refsCount++; |
@@ -183,18 +182,18 @@ namespace OpenSim.Region.CoreModules.Agent.Xfer | |||
183 | } | 182 | } |
184 | 183 | ||
185 | #endregion | 184 | #endregion |
186 | public void expireFiles(double now) | 185 | public void expireFiles(int now) |
187 | { | 186 | { |
188 | lock (NewFiles) | 187 | lock (NewFiles) |
189 | { | 188 | { |
190 | // hopefully we will not have many files so nasty code will do it | 189 | // hopefully we will not have many files so nasty code will do it |
191 | if(now - lastFilesExpire > 120000.0) | 190 | if(now - lastFilesExpire > 120000) |
192 | { | 191 | { |
193 | lastFilesExpire = now; | 192 | lastFilesExpire = now; |
194 | List<string> expires = new List<string>(); | 193 | List<string> expires = new List<string>(); |
195 | foreach(string fname in NewFiles.Keys) | 194 | foreach(string fname in NewFiles.Keys) |
196 | { | 195 | { |
197 | if(NewFiles[fname].refsCount == 0 && now - NewFiles[fname].timeStampMS > 120000.0) | 196 | if(NewFiles[fname].refsCount == 0 && now - NewFiles[fname].timeStampMS > 120000) |
198 | expires.Add(fname); | 197 | expires.Add(fname); |
199 | } | 198 | } |
200 | foreach(string fname in expires) | 199 | foreach(string fname in expires) |
@@ -230,7 +229,7 @@ namespace OpenSim.Region.CoreModules.Agent.Xfer | |||
230 | } | 229 | } |
231 | } | 230 | } |
232 | 231 | ||
233 | public void transfersTimeTick(double now) | 232 | public void transfersTimeTick(int now) |
234 | { | 233 | { |
235 | XferDownLoad[] xfrs; | 234 | XferDownLoad[] xfrs; |
236 | lock(Transfers) | 235 | lock(Transfers) |
@@ -241,6 +240,7 @@ namespace OpenSim.Region.CoreModules.Agent.Xfer | |||
241 | xfrs = new XferDownLoad[Transfers.Count]; | 240 | xfrs = new XferDownLoad[Transfers.Count]; |
242 | Transfers.Values.CopyTo(xfrs,0); | 241 | Transfers.Values.CopyTo(xfrs,0); |
243 | } | 242 | } |
243 | |||
244 | foreach(XferDownLoad xfr in xfrs) | 244 | foreach(XferDownLoad xfr in xfrs) |
245 | { | 245 | { |
246 | if(xfr.checkTime(now)) | 246 | if(xfr.checkTime(now)) |
@@ -274,12 +274,13 @@ namespace OpenSim.Region.CoreModules.Agent.Xfer | |||
274 | byte[] fileData = NewFiles[fileName].Data; | 274 | byte[] fileData = NewFiles[fileName].Data; |
275 | int burstSize = remoteClient.GetAgentThrottleSilent((int)ThrottleOutPacketType.Task) >> 10; | 275 | int burstSize = remoteClient.GetAgentThrottleSilent((int)ThrottleOutPacketType.Task) >> 10; |
276 | burstSize *= remoteClient.PingTimeMS; | 276 | burstSize *= remoteClient.PingTimeMS; |
277 | burstSize >>= 10; // ping is ms, 1 round trips | 277 | burstSize >>= 10; // ping is ms, 1 round trip |
278 | if(burstSize > 32) | ||
279 | burstSize = 32; | ||
278 | XferDownLoad transaction = | 280 | XferDownLoad transaction = |
279 | new XferDownLoad(fileName, fileData, xferID, remoteClient, burstSize); | 281 | new XferDownLoad(fileName, fileData, xferID, remoteClient, burstSize); |
280 | 282 | ||
281 | Transfers.Add(xferID, transaction); | 283 | Transfers.Add(xferID, transaction); |
282 | |||
283 | transaction.StartSend(); | 284 | transaction.StartSend(); |
284 | 285 | ||
285 | // The transaction for this file is on its way | 286 | // The transaction for this file is on its way |
@@ -327,7 +328,7 @@ namespace OpenSim.Region.CoreModules.Agent.Xfer | |||
327 | public bool isDeleted = false; | 328 | public bool isDeleted = false; |
328 | 329 | ||
329 | private object myLock = new object(); | 330 | private object myLock = new object(); |
330 | private double lastACKTimeMS; | 331 | private int lastACKTimeMS; |
331 | private int LastPacket; | 332 | private int LastPacket; |
332 | private int lastBytes; | 333 | private int lastBytes; |
333 | private int lastSentPacket; | 334 | private int lastSentPacket; |
@@ -385,30 +386,25 @@ namespace OpenSim.Region.CoreModules.Agent.Xfer | |||
385 | 386 | ||
386 | lastAckPacket = -1; | 387 | lastAckPacket = -1; |
387 | lastSentPacket = -1; | 388 | lastSentPacket = -1; |
388 | |||
389 | double now = Util.GetTimeStampMS(); | ||
390 | retries = 0; | 389 | retries = 0; |
391 | 390 | ||
392 | SendBurst(now); | 391 | SendBurst(); |
393 | return; | 392 | return; |
394 | } | 393 | } |
395 | } | 394 | } |
396 | 395 | ||
397 | private void SendBurst(double now) | 396 | private void SendBurst() |
398 | { | 397 | { |
399 | lock(myLock) | 398 | int start = lastAckPacket + 1; |
400 | { | 399 | int end = start + burstSize; |
401 | lastACKTimeMS = (int)now; // reset timeout | 400 | if (end > LastPacket) |
402 | int start = lastAckPacket + 1; | 401 | end = LastPacket; |
403 | int end = start + burstSize; | 402 | while (start <= end) |
404 | if (end > LastPacket) | 403 | SendPacket(start++); |
405 | end = LastPacket; | 404 | lastACKTimeMS = (int)Util.GetTimeStampMS(); // reset timeout |
406 | while (start <= end) | ||
407 | SendPacket(start++ , now); | ||
408 | } | ||
409 | } | 405 | } |
410 | 406 | ||
411 | private void SendPacket(int pkt, double now) | 407 | private void SendPacket(int pkt) |
412 | { | 408 | { |
413 | if(pkt > LastPacket) | 409 | if(pkt > LastPacket) |
414 | return; | 410 | return; |
@@ -443,45 +439,43 @@ namespace OpenSim.Region.CoreModules.Agent.Xfer | |||
443 | if(isDeleted) | 439 | if(isDeleted) |
444 | return true; | 440 | return true; |
445 | 441 | ||
446 | packet &= 0x7fffffff; | 442 | packet &= 0x7fffffff; |
447 | if(lastAckPacket < packet) | 443 | if (lastAckPacket < packet) |
448 | lastAckPacket = (int)packet; | 444 | lastAckPacket = (int)packet; |
449 | 445 | else if (lastAckPacket == LastPacket) | |
450 | if(lastAckPacket == LastPacket) | ||
451 | { | 446 | { |
452 | done(); | 447 | done(); |
453 | return true; | 448 | return true; |
454 | } | 449 | } |
455 | 450 | ||
456 | double now = Util.GetTimeStampMS(); | 451 | lastACKTimeMS = (int)Util.GetTimeStampMS(); |
457 | lastACKTimeMS = (int)now; | ||
458 | retries = 0; | 452 | retries = 0; |
459 | SendPacket(lastSentPacket + 1, now); | 453 | SendPacket(lastSentPacket + 1); |
460 | return false; | 454 | return false; |
461 | } | 455 | } |
462 | } | 456 | } |
463 | 457 | ||
464 | public bool checkTime(double now) | 458 | public bool checkTime(int now) |
465 | { | 459 | { |
466 | if (Monitor.TryEnter(myLock)) | 460 | if (Monitor.TryEnter(myLock)) |
467 | { | 461 | { |
468 | if (!isDeleted) | 462 | if (!isDeleted) |
469 | { | 463 | { |
470 | double timeMS = now - lastACKTimeMS; | 464 | int timeMS = now - lastACKTimeMS; |
471 | 465 | int tout = 5 * remoteClient.PingTimeMS; | |
472 | double tout = 5 * remoteClient.PingTimeMS; | ||
473 | if(tout > 10000) | 466 | if(tout > 10000) |
474 | tout = 10000; | 467 | tout = 10000; |
475 | else if (tout < 1000) | 468 | else if (tout < 1000) |
476 | tout = 1000; | 469 | tout = 1000; |
470 | |||
477 | if (timeMS > tout) | 471 | if (timeMS > tout) |
478 | { | 472 | { |
479 | if (++retries >= 4) | 473 | if (++retries > 4) |
480 | done(); | 474 | done(); |
481 | else | 475 | else |
482 | { | 476 | { |
483 | burstSize >>= 2; | 477 | burstSize = lastSentPacket - lastAckPacket - 1; |
484 | SendBurst(now); | 478 | SendBurst(); |
485 | } | 479 | } |
486 | } | 480 | } |
487 | } | 481 | } |