------- Comment #5 from bkoz at gcc dot gnu dot org  2005-10-13 05:36 -------

This locking code looks really strange to me. 

  void
  release() // nothrow
  {
    if (__gnu_cxx::__exchange_and_add(&_M_use_count, -1) == 1)
    {
      dispose();
      __glibcxx_mutex_lock(_M_mutex);
      __glibcxx_mutex_unlock(_M_mutex);
      weak_release();
    }
  }

Anyway. Any chance this could be commented? What's being attempted?

Also, Paolo, if you've been able to reproduce this problem, I'd appreciate a
test case that demonstrates the issue checked in with the patch. Then, if the
locking bits get changed in the future we won't run into this regression if
things aren't quite right.

As it stands now, I have no idea what the problem is, or was, other than the
mutex was never initialized.

-benjamin


-- 


http://gcc.gnu.org/bugzilla/show_bug.cgi?id=24244

Reply via email to