git: libthread_xu - Clean up the red zone on library unload
    Matthew Dillon 
    dillon at crater.dragonflybsd.org
       
    Wed Apr 16 10:04:57 PDT 2014
    
    
  
commit 0dc5e56d98ab5fc55416a204886f8b132cc9b7f1
Author: Matthew Dillon <dillon at apollo.backplane.com>
Date:   Wed Apr 16 10:01:14 2014 -0700
    libthread_xu - Clean up the red zone on library unload
    
    * If the main program is not linked against -pthread but dynamically
      loads a shared library that is via dlopen(), then dlclose()'s it,
      libthread_xu leaves red-zone and cached thread stacks dangling.
    
      The second attempt to (indirectly) load libthread_xu then fails with a
      red-zone panic.
    
    * Add a destructor for libthread_xu to unmap the red-zone and to clean out
      any cached thread stacks.
    
    * Note that neither libthread_xu nor most other large libraries are designed
      to be unloaded.  That is, even if loading/unloading works, numerous libraries
      will almost certainly leak memory.  This change prevents the fatal error but
      doesn't fix the general memory leakage problem.
    
      IMHO Only libraries designed to be unloadable should be unloaded.
    
    Reported-by: Vasily Postnicov <shamaz.mazum at gmail.com>
Summary of changes:
 lib/libthread_xu/thread/thr_init.c    | 28 +++++++++++++++++++++++++---
 lib/libthread_xu/thread/thr_private.h |  1 +
 lib/libthread_xu/thread/thr_stack.c   | 12 ++++++++++++
 3 files changed, 38 insertions(+), 3 deletions(-)
http://gitweb.dragonflybsd.org/dragonfly.git/commitdiff/0dc5e56d98ab5fc55416a204886f8b132cc9b7f1
-- 
DragonFly BSD source repository
    
    
More information about the Commits
mailing list