aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/OpenSim/Region (unfollow)
Commit message (Collapse)AuthorFilesLines
2013-08-01minor: Add name to debug lludp packet level feedback on consoleJustin Clark-Casey (justincc)1-1/+1
2013-08-01Add experimental "debug attachments throttle <ms>" setting (command line) ↵Justin Clark-Casey (justincc)1-15/+87
and ThrottlePer100PrimsRezzed in [Attachments] in config This is an experimental setting to control cpu spikes when an attachment heavy avatar logs in or avatars with medium attachments lgoin simultaneously. It inserts a ms sleep specified in terms of attachments prims after each rez when an avatar logs in. Default is 0 (no throttling). "debug attachments <level>" changes to "debug attachments log <level>" which controls logging. A logging level of 1 will show the throttling performed if applicable. Also adds "debug attachments status" command to show current throttle and debug logging levels.
2013-08-01Try a different approach to slow terrain update by always cycling the loop ↵Justin Clark-Casey (justincc)1-1/+2
immediately if any data was sent, rather than waiting. What I believe is happening is that on initial terrain send, this is done one packet at a time. With WaitOne, the outbound loop has enough time to loop and wait again after the first packet before the second, leading to a slower send. This approach instead does not wait if a packet was just sent but instead loops again, which appears to lead to a quicker send without losing the cpu benefit of not continually looping when there is no outbound data.
2013-08-01Revert "Issue: painfully slow terrain loading. The cause is commit ↵Justin Clark-Casey (justincc)1-5/+5
d9d995914c5fba00d4ccaf66b899384c8ea3d5eb (r/23185) -- the WaitOne on the UDPServer. Putting it back to how it was done solves the issue. But this may impact CPU usage, so I'm pushing it to test if it does." This reverts commit 59b461ac0eaae1cc34bb82431106fdf0476037f3.
2013-08-01Issue: painfully slow terrain loading. The cause is commit ↵Diva Canto1-5/+5
d9d995914c5fba00d4ccaf66b899384c8ea3d5eb (r/23185) -- the WaitOne on the UDPServer. Putting it back to how it was done solves the issue. But this may impact CPU usage, so I'm pushing it to test if it does.
2013-07-31Experimental comment to eneralize the handling of Linden caps when theMic Bowman2-1/+53
cap is something other than "localhost". A new interface for handling external caps is supported with an example implemented for Simian. The only linden cap supporting this interface right now is the GetTexture cap.
2013-07-31HGWorldMapModule: unregister event on RemoveRegionDiva Canto1-1/+10
2013-07-31HGWorldMapModule: check whether it's enabled or not.Diva Canto1-0/+6
2013-07-30Avoid another null ref opportunity.Diva Canto1-1/+1
2013-07-30Fix null ref.Diva Canto1-1/+1
2013-07-30Doing the HG Map / SimulatorFeatures "the right way": moved it to ↵Diva Canto2-14/+48
HGMapModule, hooking on to SimulatorFeatures.OnSimulatorFeaturesRequest event (similar to what the DynamicMenuModule does). Only HG Visitors get this var, to avoid spamming local users. The config var is now called MapTileURL, to be consistent with the login one, and its being picked up from either [LoginService], [HGWorldMap] or [SimulatorFeatures], just because I have a bad memory.
2013-07-30After talking to lkalif on the IRC: SimulatorFeatures response: renamed the ↵Diva Canto1-6/+7
OSDMap GridServices to OpenSimExtras, normalized the url keys under it, and moved ExportEnabled to under it too. Melanie: change your viewer code accordingly. Documentation at http://opensimulator.org/wiki/SimulatorFeatures_Extras
2013-07-30BulletSim: distribute vehicle physical settings to all members ofRobert Adams3-43/+61
a linkset. Enables constraint based linksets. Rename some internal variables to clarify whether values world or vehicle relative.
2013-07-30BulletSim: test method for debugging of extended physics script operations.Robert Adams1-8/+46
2013-07-30BulletSim: make density display and return value consistant with howRobert Adams3-8/+22
the simulator expects it (scaled to 100kg/m^3).
2013-07-29minor: Add timeout secs to connection timeout message. Change message to ↵Justin Clark-Casey (justincc)1-8/+9
reflect it is a timeout due to no data received rather than an ack issue.
2013-07-29Fix issue just introduced in 8efe4bfc2ed7086e9fdf4812297e6525f955f6ac where ↵Justin Clark-Casey (justincc)1-1/+1
I accidentally left in a test line to force very quick client unack
2013-07-29Make "abnormal thread terminations" into "ClientLogoutsDueToNoReceives" and ↵Justin Clark-Casey (justincc)1-5/+21
add this to the StatsManager This reflects the actual use of this stat - it hasn't recorded general exceptions for some time. Make the sim extra stats collector draw the data from the stats manager rather than maintaing this data itself.
2013-07-28Removed commented lines and useless debug messageDiva Canto1-1/+0
2013-07-28Added BasicSearchModule.cs which handles OnDirFindQuery events. Removed that ↵Diva Canto4-55/+206
handler from both Groups modules in core, and replaced them with an operation on IGroupsModule.
2013-07-28This makes people search work.Diva Canto1-0/+41
2013-07-27Several major improvements to group (V2) chat. Specifically: handle ↵Diva Canto3-5/+5
join/drop appropriately, invitechatboxes. The major departure from flotsam is to send only one message per destination region, as opposed to one message per group member. This reduces messaging considerably in large groups that have clusters of members in certain regions.
2013-07-26Commented out ChatSessionRequest capability in Vivox and Freeswitch. We ↵Diva Canto2-18/+18
aren't processing it in any meaningful way, and it seems to get invoked everytime someone types a message in group chat.
2013-07-26Fix regression from 056a6ee7 because the RemoteSimulationConnector uses a ↵Justin Clark-Casey (justincc)1-2/+5
copy of the LocalSimulationConnector but never initializes it (hence ServiceVersion was never set)
2013-07-26Fix failure in TestCreateDuplicateRootScenePresence().Justin Clark-Casey (justincc)1-0/+13
This is a test setup failure since code paths when adding a duplicate root scene presence now require the EntityTransferModule to be present. Test fixed by adding this module to test setup
2013-07-26Fix regression tests relating to agent transfer by making simulator use last ↵Justin Clark-Casey (justincc)3-4/+24
week's SIMULATOR/0.1 protocol for now.
2013-07-26Fix NPC regression test failures.Justin Clark-Casey (justincc)3-2/+5
These were genuine failures caused by ScenePresence.CompleteMovement() waiting for an UpdateAgent from NPC introduction that would never come. Instead, we do not wait if the agent is an NPC.
2013-07-26Comment debug messageDiva Canto1-2/+2
2013-07-26Slight improvement: no need to delay the removal of the queues in EQ, ↵Diva Canto1-8/+0
because DisableSimulator is now being sent via UDP
2013-07-25This should fix all issues with teleports. One should be able to TP as fast ↵Diva Canto4-87/+54
as needed. (Although sometimes Justin's state machine kicks in and doesn't let you) The EventQueues are a hairy mess, and it's very easy to mess things up. But it looks like this commit makes them work right. Here's what's going on: - Child and root agents are only closed after 15 sec, maybe - If the user comes back, they aren't closed, and everything is reused - On the receiving side, clients and scene presences are reused if they already exist - Caps are always recreated (this is where I spent most of my time!). It turns out that, because the agents carry the seeds around, the seed gets the same URL, except for the root agent coming back to a far away region, which gets a new seed (because we don't know what was its seed in the departing region, and we can't send it back to the client when the agent returns there).
2013-07-26Return Simulator/0.1 (V1) entity transfer behaviour to waiting only 2 ↵Justin Clark-Casey (justincc)1-7/+7
seconds before closing root agent after 15. This is because a returning viewer by teleport before 15 seconds are up will be disrupted by the close. The 2 second delay is within the scope where a normal viewer would not allow a teleport back anyway. Simulator/0.2 (V2) protocol will continue with the longer delay since this is actually the behaviour viewers get from the ll grid and an early close causes other issues (avatar being sent to infinite locations temporarily, etc.)
2013-07-26Reset DoNotClose scene presence teleport flag before pausing. Rename ↵Justin Clark-Casey (justincc)3-4/+6
DoNotClose to DoNotCloseAfterTeleport
2013-07-26If a returning teleport starts to reuse a downgraded child connection that ↵Justin Clark-Casey (justincc)3-12/+34
was a previous root agent, do not close that child agent at the end of the 15 sec teleport timer. This prevents an issue if the user teleports back to the neighbour simulator of a source before 15 seconds have elapsed. This more closely emulates observed linden behaviour, though the timeout there is 50 secs and applies to all the pre-teleport agents. Currently sticks a DoNotClose flag on ScenePresence though this may be temporary as possibly it could be incorporated into the ETM state machine
2013-07-24Increased the wait time to 15 secs. In a 0.7.5 standalone where the effect ↵Diva Canto1-2/+2
was always present, this seems to have fixed it.
2013-07-24Deleted all [ZZZ] debug messages.Diva Canto2-6/+0
2013-07-24The previous commit did fix the infinity problem! I'm putting the same time ↵Diva Canto1-7/+13
on TP_V1 and adding a big red warning on top of those lines.
2013-07-24Today's wild shot at the infinity problem. Wait on the child agent left behind.Diva Canto1-1/+3
2013-07-24Moved TriggerOnMakeRootAgent back to the end of MakeRootAgent, to see if ↵Diva Canto1-7/+2
that eliminates the temporary placement at infinity upon TPs
2013-07-24One more thing to test in order to let CompleteMovement go up the stack.Diva Canto1-2/+3
2013-07-24Minor adjustment on timings of waits.Diva Canto2-6/+21
2013-07-24Changed the RegionHandshake packet to the Unknown queue, so that it is sent ↵Diva Canto1-1/+1
with high priority and hopefully gets to the client before AgentMovementComplete
2013-07-24This commit message intentionally left blank (last commit was idiotic)Diva Canto1-1/+2
2013-07-24Improve the opening test in CompleteMovement, to account for multiple flags ↵Diva Canto1-1/+1
besides ViaLogin.
2013-07-24More on putting TP V1 as it wasDiva Canto1-16/+16
2013-07-24Minor improvements on TP V1 trying to make it exactly as it was before.Diva Canto1-15/+17
2013-07-24New Teleport protocol (V2), still compatible with V1 and older. (version of ↵Diva Canto5-74/+310
the destination is being checked) In this new protocol, and as committed before, the viewer is not sent EnableSimulator/EstablishChildCommunication for the destination. Instead, it is sent TeleportFinish directly. TeleportFinish, in turn, makes the viewer send a UserCircuitCode packet followed by CompleteMovementIntoRegion packet. These 2 packets tend to occur one after the other almost immediately to the point that when CMIR arrives the client is not even connected yet and that packet is ignored (there might have been some race conditions here before); then the viewer sends CMIR again within 5-8 secs. But the delay between them may be higher in busier regions, which may lead to race conditions. This commit improves the process so there are are no race conditions at the destination. CompleteMovement (triggered by the viewer) waits until Update has been sent from the origin. Update, in turn, waits until there is a *root* scene presence -- so making sure CompleteMovement has run MakeRoot. In other words, there are two threadlets at the destination, one from the viewer and one from the origin region, waiting for each other to do the right thing. That makes it safe to close the agent at the origin upon return of the Update call without having to wait for callback, because we are absolutely sure that the viewer knows it is in th new region. Note also that in the V1 protocol, the destination was getting UseCircuitCode from the viewer twice -- once on EstablishAgentCommunication and then again on TeleportFinish. The second UCC was being ignored, but it shows how we were not following the expected steps...
2013-07-24Further tweaks on TPs: not sending the callback URL and instead waiting ↵Diva Canto3-28/+35
15sec before closing the agent. This seems to be working fairly well. The viewer seems to have an 8 sec delay between UseCircuitCode and CompleteMovement. Also added back the position on UpdateAgent, because it's needed for TPing between neighboring regions.
2013-07-24EXPERIMENTAL: yet another variation of ES/EAC/TPFinishDiva Canto1-39/+39
2013-07-24Amend previous commit.Diva Canto1-4/+4
2013-07-24Added config var that we all thought was already there: see_into_region. ↵Diva Canto1-34/+45
(Note: different from the defunct see_into_neighboring_sim, which used to control the process from the other end). This enables child agents in neighbors for which the root agent doesn't have permission to be in.