Kevin Atkinson wrote:
> 
> On Thu, 20 Feb 2003, Alexander Terekhov wrote:
> 
> > > I have changed the definition to:
> > >
> > > #ifdef FAST_MUTEX_INIT_DESTROY
> >                          ^^^^^^^
> >
> > >   static const pthread_mutex_t MUTEX_INIT = PTHREAD_MUTEX_INITIALIZER;
> >
> > Uhmm. What does your "fast destruction" do? Well, looking at the code
> > you've posted, it does nothing... and that's the "fastest" way to leak.
> 
> It depends on the implementation.  On some, including linux, there is
> nothing to free.  

But that might change overnight [on the next start, I mean]... and even 
without any recompiles (rebuilds) on the part of your clients, Kevin.

<illustration source=nptl-0.24/nptl/old_pthread_cond_wait.c>

/* Copyright (C) 2002, 2003 Free Software Foundation, Inc.
   This file is part of the GNU C Library.
   Contributed by Ulrich Drepper <[EMAIL PROTECTED]>, 2002.

   The GNU C Library is free software; you can redistribute it and/or
   modify it under the terms of the GNU Lesser General Public
   License as published by the Free Software Foundation; either
   version 2.1 of the License, or (at your option) any later version.

   The GNU C Library is distributed in the hope that it will be useful,
   but WITHOUT ANY WARRANTY; without even the implied warranty of
   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
   Lesser General Public License for more details.

   You should have received a copy of the GNU Lesser General Public
   License along with the GNU C Library; if not, write to the Free
   Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA
   02111-1307 USA.  */

#include <errno.h>
#include <stdlib.h>
#include "pthreadP.h"
#include <atomic.h>
#include <shlib-compat.h>


#if SHLIB_COMPAT(libpthread, GLIBC_2_0, GLIBC_2_3_2)
int
__pthread_cond_wait_2_0 (cond, mutex)
     pthread_cond_2_0_t *cond;
     pthread_mutex_t *mutex;
{
  if (cond->cond == NULL)
    {
      pthread_cond_t *newcond;

#if LLL_MUTEX_LOCK_INITIALIZER == 0
      newcond = (pthread_cond_t *) calloc (sizeof (pthread_cond_t), 1);
      if (newcond == NULL)
        return ENOMEM;
#else
      newcond = (pthread_cond_t *) malloc (sizeof (pthread_cond_t));
      if (newcond == NULL)
        return ENOMEM;

      /* Initialize the condvar.  */
      (void) pthread_cond_init (newcond, NULL);
#endif

      if (atomic_compare_and_exchange_acq (&cond->cond, newcond, NULL) != 0)
        /* Somebody else just initialized the condvar.  */
        free (newcond);
    }

  return __pthread_cond_wait (cond->cond, mutex);
}
compat_symbol (libpthread, __pthread_cond_wait_2_0, pthread_cond_wait,
               GLIBC_2_0);
#endif

</illustration>

This is from the latest NPTL code drop. BTW, it seems that it's broken 
with respect to memory visibility on MPs with relaxed memory ordering, 
but never mind. ;-)

regards,
alexander.

_______________________________________________
Unsubscribe & other changes: http://lists.boost.org/mailman/listinfo.cgi/boost

Reply via email to