I&#39;m a C++/boost newbie, so my apologies if this is a basic question.<div><br></div><div>I&#39;ve got a multithreaded app that appears to be deadlocking when two threads are trying to acquire an upgrade_lock&lt;shared_mutex&gt; at the same time.  Specifically, I&#39;ve got a class that looks something like this:</div>
<div><br></div><div><div>#include &lt;boost/thread.hpp&gt;</div><div>using namespace boost;</div><div><br></div><div>class Manager</div><div>{</div><div><br></div><div>   public:</div><div>      Manager();</div><div>     ~Manager();</div>
<div>      void createRoom();</div><div>      void deleteRoom();</div><div>      void transmit();</div><div><br></div><div><div>   private:</div><div>      shared_mutex      roomManagersMutex;</div></div><div><br></div><div>
};</div><div><br></div><div>void Manager::createRoom()</div></div><div><div><div>{</div><div>   <span class="Apple-style-span" style="background-color: rgb(255, 255, 153);">upgrade_lock&lt;shared_mutex&gt; upgradeLock(roomManagersMutex);</span></div>
<div>   // Read stuff</div><div><br></div><div>   if(roomShouldBeCreated)</div><div>   {</div><div>      upgrade_to_unique_lock&lt;shared_mutex&gt; uniqueLock(upgradeLock);</div><div>      // Create room</div><div>   }</div>
<div>}</div></div><div><br></div><div><div><div>void Manager::deleteRoom()</div></div><div><div>{</div><div>   <span class="Apple-style-span" style="background-color: rgb(255, 255, 153);">upgrade_lock&lt;shared_mutex&gt; upgradeLock(roomManagersMutex);</span></div>
<div>   // Read stuff</div><div><br></div><div>   if (roomShouldBeDeleted)</div><div>   {</div><div>      upgrade_to_unique_lock&lt;shared_mutex&gt; uniqueLock(upgradeLock);</div><div>      // Delete the room</div><div>    }</div>
<div>}</div><div><br></div><div></div></div><div>void Manager::transmit()</div><div>{</div><div>   shared_lock&lt;shared_mutex&gt; lock(roomManagersMutex);</div><div>   // Read stuff about the room</div><div>}</div></div>
<div><br></div><div>The Manager::deleteRoom() and Manager::createRoom() methods are typically only called once every few seconds, but Manager::transmit() is called every 20 milliseconds or so, i.e., about 50 times / second.</div>
<div><br></div><div>Periodically, the app stops responding.  When it does, I can see that the transmit() method is working fine, but the createRoom() and deleteRoom() methods (on separate threads, obviously) appear to be deadlocked on the highlighted lines, waiting to acquire their upgrade_locks.  </div>
<div><br></div><div>Now that seems weird to me, because I thought the whole purpose of the upgrade locks was that they&#39;re supposed to be shared, right up until you request an upgrade to a unique lock.  Obviously the code is more complex than what I&#39;ve described, but it doesn&#39;t appear that there&#39;s a unique lock being held anywhere when the deadlock happens.</div>
<div><br></div><div>Am I doing something wrong?  Any suggestions on troubleshooting this?</div><br>Ken Smith<br>Cell: 425-443-2359<br>Email: <a href="mailto:smithkl42@gmail.com">smithkl42@gmail.com</a><br>Blog: <a href="http://blog.wouldbetheologian.com/">http://blog.wouldbetheologian.com/</a><br>

</div>