aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/addon-modules
diff options
context:
space:
mode:
authorJustin Clark-Casey (justincc)2012-03-15 00:20:47 +0000
committerJustin Clark-Casey (justincc)2012-03-19 21:29:34 +0000
commitb01c79354c4c9ca4e0f01fc4fef3ad4fb97f1c19 (patch)
tree795fe3c6702c573afdcd37089bd15e035d1d0230 /addon-modules
parentAlleviate an issue where calling Thread.Abort() on script WorkItems can fail ... (diff)
downloadopensim-SC_OLD-b01c79354c4c9ca4e0f01fc4fef3ad4fb97f1c19.zip
opensim-SC_OLD-b01c79354c4c9ca4e0f01fc4fef3ad4fb97f1c19.tar.gz
opensim-SC_OLD-b01c79354c4c9ca4e0f01fc4fef3ad4fb97f1c19.tar.bz2
opensim-SC_OLD-b01c79354c4c9ca4e0f01fc4fef3ad4fb97f1c19.tar.xz
Fix a problem where multiple near simultaneous calls to llDie() from multiple scripts in the same linkset can cause unnecessary thread aborts.
The first llDie() could lock Scene.m_deleting_scene_object. The second llDie() would then wait at this lock. The first llDie() would go on to remove the second script but always abort it since the second script's WorkItem would not go away. Easiest solution here is to remove the m_deleting_scene_object since it's no longer justified - we no longer lock m_parts but take a copy instead. This also requires an adjustment in XEngine.OnRemoveScript not to use instance.ObjectID instead when firing the OnObjectRemoved event.
Diffstat (limited to 'addon-modules')
0 files changed, 0 insertions, 0 deletions