aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/OpenSim/Framework
diff options
context:
space:
mode:
Diffstat (limited to 'OpenSim/Framework')
-rw-r--r--OpenSim/Framework/Data.MySQL/MySQLDataStore.cs61
1 files changed, 24 insertions, 37 deletions
diff --git a/OpenSim/Framework/Data.MySQL/MySQLDataStore.cs b/OpenSim/Framework/Data.MySQL/MySQLDataStore.cs
index b25924c..54f39bb 100644
--- a/OpenSim/Framework/Data.MySQL/MySQLDataStore.cs
+++ b/OpenSim/Framework/Data.MySQL/MySQLDataStore.cs
@@ -50,7 +50,6 @@ namespace OpenSim.Framework.Data.MySQL
50 private const string m_landAccessListSelect = "select * from landaccesslist"; 50 private const string m_landAccessListSelect = "select * from landaccesslist";
51 51
52 private DataSet m_dataSet; 52 private DataSet m_dataSet;
53 private static object DBAccessLock = new object(); // Trying to use a static object because there might be other regions that keep modifying table
54 private MySqlDataAdapter m_primDataAdapter; 53 private MySqlDataAdapter m_primDataAdapter;
55 private MySqlDataAdapter m_shapeDataAdapter; 54 private MySqlDataAdapter m_shapeDataAdapter;
56 private MySqlDataAdapter m_itemsDataAdapter; 55 private MySqlDataAdapter m_itemsDataAdapter;
@@ -104,7 +103,7 @@ namespace OpenSim.Framework.Data.MySQL
104 103
105 TestTables(m_connection); 104 TestTables(m_connection);
106 105
107 lock (DBAccessLock) 106 lock (m_dataSet)
108 { 107 {
109 m_primTable = createPrimTable(); 108 m_primTable = createPrimTable();
110 m_dataSet.Tables.Add(m_primTable); 109 m_dataSet.Tables.Add(m_primTable);
@@ -143,7 +142,7 @@ namespace OpenSim.Framework.Data.MySQL
143 142
144 public void StoreObject(SceneObjectGroup obj, LLUUID regionUUID) 143 public void StoreObject(SceneObjectGroup obj, LLUUID regionUUID)
145 { 144 {
146 lock (DBAccessLock) 145 lock (m_dataSet)
147 { 146 {
148 foreach (SceneObjectPart prim in obj.Children.Values) 147 foreach (SceneObjectPart prim in obj.Children.Values)
149 { 148 {
@@ -170,7 +169,7 @@ namespace OpenSim.Framework.Data.MySQL
170 DataTable shapes = m_shapeTable; 169 DataTable shapes = m_shapeTable;
171 170
172 string selectExp = "SceneGroupID = '" + Util.ToRawUuidString(obj) + "'"; 171 string selectExp = "SceneGroupID = '" + Util.ToRawUuidString(obj) + "'";
173 lock (DBAccessLock) 172 lock (m_dataSet)
174 { 173 {
175 DataRow[] primRows = prims.Select(selectExp); 174 DataRow[] primRows = prims.Select(selectExp);
176 foreach (DataRow row in primRows) 175 foreach (DataRow row in primRows)
@@ -226,7 +225,7 @@ namespace OpenSim.Framework.Data.MySQL
226 string byRegion = "RegionUUID = '" + Util.ToRawUuidString(regionUUID) + "'"; 225 string byRegion = "RegionUUID = '" + Util.ToRawUuidString(regionUUID) + "'";
227 string orderByParent = "ParentID ASC"; 226 string orderByParent = "ParentID ASC";
228 227
229 lock (DBAccessLock) 228 lock (m_dataSet)
230 { 229 {
231 DataRow[] primsForRegion = prims.Select(byRegion, orderByParent); 230 DataRow[] primsForRegion = prims.Select(byRegion, orderByParent);
232 MainLog.Instance.Verbose("DATASTORE", 231 MainLog.Instance.Verbose("DATASTORE",
@@ -336,7 +335,7 @@ namespace OpenSim.Framework.Data.MySQL
336 MainLog.Instance.Verbose("DATASTORE", "Storing terrain revision r" + revision.ToString()); 335 MainLog.Instance.Verbose("DATASTORE", "Storing terrain revision r" + revision.ToString());
337 336
338 DataTable terrain = m_dataSet.Tables["terrain"]; 337 DataTable terrain = m_dataSet.Tables["terrain"];
339 lock (DBAccessLock) 338 lock (m_dataSet)
340 { 339 {
341 MySqlCommand cmd = new MySqlCommand("insert into terrain(RegionUUID, Revision, Heightfield)" + 340 MySqlCommand cmd = new MySqlCommand("insert into terrain(RegionUUID, Revision, Heightfield)" +
342 " values(?RegionUUID, ?Revision, ?Heightfield)", m_connection); 341 " values(?RegionUUID, ?Revision, ?Heightfield)", m_connection);
@@ -397,7 +396,7 @@ namespace OpenSim.Framework.Data.MySQL
397 396
398 public void RemoveLandObject(LLUUID globalID) 397 public void RemoveLandObject(LLUUID globalID)
399 { 398 {
400 lock (DBAccessLock) 399 lock (m_dataSet)
401 { 400 {
402 using (MySqlCommand cmd = new MySqlCommand("delete from land where UUID=?UUID", m_connection)) 401 using (MySqlCommand cmd = new MySqlCommand("delete from land where UUID=?UUID", m_connection))
403 { 402 {
@@ -422,7 +421,7 @@ namespace OpenSim.Framework.Data.MySQL
422 MainLog.Instance.Verbose("DATASTORE", "Tedds temp fix: Waiting 3 seconds for stuff to catch up. (Someone please fix! :))"); 421 MainLog.Instance.Verbose("DATASTORE", "Tedds temp fix: Waiting 3 seconds for stuff to catch up. (Someone please fix! :))");
423 System.Threading.Thread.Sleep(2500 + rnd.Next(300, 900)); 422 System.Threading.Thread.Sleep(2500 + rnd.Next(300, 900));
424 423
425 lock (DBAccessLock) 424 lock (m_dataSet)
426 { 425 {
427 DataTable land = m_landTable; 426 DataTable land = m_landTable;
428 DataTable landaccesslist = m_landAccessListTable; 427 DataTable landaccesslist = m_landAccessListTable;
@@ -454,14 +453,14 @@ namespace OpenSim.Framework.Data.MySQL
454 landaccesslist.Rows.Add(newAccessRow); 453 landaccesslist.Rows.Add(newAccessRow);
455 } 454 }
456 455
457 Commit_NoLock();
458 } 456 }
457 Commit();
459 } 458 }
460 459
461 public List<LandData> LoadLandObjects(LLUUID regionUUID) 460 public List<LandData> LoadLandObjects(LLUUID regionUUID)
462 { 461 {
463 List<LandData> landDataForRegion = new List<LandData>(); 462 List<LandData> landDataForRegion = new List<LandData>();
464 lock (DBAccessLock) 463 lock (m_dataSet)
465 { 464 {
466 DataTable land = m_landTable; 465 DataTable land = m_landTable;
467 DataTable landaccesslist = m_landAccessListTable; 466 DataTable landaccesslist = m_landAccessListTable;
@@ -523,39 +522,27 @@ namespace OpenSim.Framework.Data.MySQL
523 m_connection.Open(); 522 m_connection.Open();
524 } 523 }
525 524
526 lock (DBAccessLock) 525 lock (m_dataSet)
527 { 526 {
528 // Moved code to own sub that can be called directly by "StoreLandObject". 527 // DisplayDataSet(m_dataSet, "Region DataSet");
529 // Problem is that:
530 // - StoreLandObject locks
531 // - Some other function waits for lock
532 // - StoreLandObject releases lock
533 // - Other function obtains lock
534 // - StoreLandObject calls Commit that tries to take lock back
535 // - When StoreLandObject's Commit finally gets lock the table has been changed and we crash
536 Commit_NoLock();
537 }
538 }
539 528
540 private void Commit_NoLock() 529 m_primDataAdapter.Update(m_primTable);
541 { 530 m_shapeDataAdapter.Update(m_shapeTable);
542 // DisplayDataSet(m_dataSet, "Region DataSet");
543 531
544 m_primDataAdapter.Update(m_primTable); 532 if (persistPrimInventories)
545 m_shapeDataAdapter.Update(m_shapeTable); 533 {
546 534 m_itemsDataAdapter.Update(m_itemsTable);
547 if (persistPrimInventories) 535 }
548 {
549 m_itemsDataAdapter.Update(m_itemsTable);
550 }
551 536
552 m_terrainDataAdapter.Update(m_terrainTable); 537 m_terrainDataAdapter.Update(m_terrainTable);
553 m_landDataAdapter.Update(m_landTable); 538 m_landDataAdapter.Update(m_landTable);
554 m_landAccessListDataAdapter.Update(m_landAccessListTable); 539 m_landAccessListDataAdapter.Update(m_landAccessListTable);
555 540
556 m_dataSet.AcceptChanges(); 541 m_dataSet.AcceptChanges();
542 }
557 } 543 }
558 544
545
559 public void Shutdown() 546 public void Shutdown()
560 { 547 {
561 Commit(); 548 Commit();
@@ -1231,7 +1218,7 @@ namespace OpenSim.Framework.Data.MySQL
1231 1218
1232 // For now, we're just going to crudely remove all the previous inventory items 1219 // For now, we're just going to crudely remove all the previous inventory items
1233 // no matter whether they have changed or not, and replace them with the current set. 1220 // no matter whether they have changed or not, and replace them with the current set.
1234 lock (DBAccessLock) 1221 lock (m_dataSet)
1235 { 1222 {
1236 RemoveItems(primID); 1223 RemoveItems(primID);
1237 1224