]> git.ipfire.org Git - thirdparty/glibc.git/commitdiff
Update.
authorUlrich Drepper <drepper@redhat.com>
Thu, 11 Jan 2001 19:25:07 +0000 (19:25 +0000)
committerUlrich Drepper <drepper@redhat.com>
Thu, 11 Jan 2001 19:25:07 +0000 (19:25 +0000)
2001-01-11  Ulrich Drepper  <drepper@redhat.com>

* stdlib/Makefile (routines): Add cxa_on_exit.
* stdlib/Versions [libc] (GLIBC_2.2.1): Add __cxa_on_exit.
* stdlib/cxa_on_exit.c: New file.
* include/stdlib.h: Add prototype for __cxa_on_exit.
* stdlib/exit.c: Handle ef_cxa2.
* stdlib/exit.h (enum): Add ef_cxa2.
(struct exit_function): Add cxa2.

* Versions.def [ld]: Add GLIBC_2.2.1.

ChangeLog
Versions.def
include/stdlib.h
linuxthreads/Examples/ex15.c [new file with mode: 0644]
linuxthreads/Makefile
linuxthreads/pthread.c
stdlib/Makefile
stdlib/Versions
stdlib/cxa_on_exit.c [new file with mode: 0644]
stdlib/exit.c
stdlib/exit.h

index 930424e2e44608cbb207dd2c88b1b91947f63d9e..790c44ce67d196b84cab3c988208ded8296a9ce2 100644 (file)
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,15 @@
+2001-01-11  Ulrich Drepper  <drepper@redhat.com>
+
+       * stdlib/Makefile (routines): Add cxa_on_exit.
+       * stdlib/Versions [libc] (GLIBC_2.2.1): Add __cxa_on_exit.
+       * stdlib/cxa_on_exit.c: New file.
+       * include/stdlib.h: Add prototype for __cxa_on_exit.
+       * stdlib/exit.c: Handle ef_cxa2.
+       * stdlib/exit.h (enum): Add ef_cxa2.
+       (struct exit_function): Add cxa2.
+
+       * Versions.def [ld]: Add GLIBC_2.2.1.
+
 2001-01-10  H.J. Lu  <hjl@gnu.org>
 
        * elf/dl-libc.c (do_dlopen): Call DL_STATIC_INIT for static binaries.
index a57ec50477e56d30326cb7c047afccaf05750e1c..0c363a36c2c89039a3362aed2d5fc324a35399e2 100644 (file)
@@ -86,6 +86,7 @@ ld {
   GLIBC_2.1
   GLIBC_2.1.1
   GLIBC_2.2
+  GLIBC_2.2.1
 }
 libthread_db {
   GLIBC_2.1.3
index d3c8779fcd4e9ee7d46c6f55afe76bf14387b6aa..9f68d4d63156b0a9fb2ab8dc09f37d28ae75bbad 100644 (file)
@@ -55,6 +55,7 @@ extern void _quicksort (void *const pbase, size_t total_elems,
                        size_t size, __compar_fn_t cmp);
 
 extern int __cxa_atexit (void (*func) (void *), void *arg, void *d);
+extern int __cxa_on_exit (void (*func) (int, void *), void *arg, void *d);
 
 extern void __cxa_finalize (void *d);
 
diff --git a/linuxthreads/Examples/ex15.c b/linuxthreads/Examples/ex15.c
new file mode 100644 (file)
index 0000000..f73b940
--- /dev/null
@@ -0,0 +1,56 @@
+#include <stdio.h>
+#include <stdlib.h>
+#include <sys/types.h>
+#include <sys/wait.h>
+#include <pthread.h>
+#include <unistd.h>
+
+static void *
+worker (void *dummy)
+{
+  exit (26);
+}
+
+#define TEST_FUNCTION do_test ()
+#define TIMEOUT 10
+static int
+do_test (void)
+{
+  pthread_t th;
+  pid_t pid;
+  int status;
+
+  switch ((pid = fork ()))
+    {
+    case -1:
+      puts ("Could not fork");
+      exit (1);
+    case 0:
+      if (pthread_create(&th, NULL, worker, NULL) != 0)
+       {
+         puts ("Failed to start thread");
+         exit (1);
+       }
+      for (;;);
+      exit (1);
+    default:
+      break;
+    }
+
+  if (waitpid (pid, &status, 0) != pid)
+    {
+      puts ("waitpid failed");
+      exit (1);
+    }
+
+  if (!WIFEXITED (status) || WEXITSTATUS (status) != 26)
+    {
+      printf ("Wrong exit code %d\n", status);
+      exit (1);
+    }
+
+  puts ("All OK");
+  return 0;
+}
+
+#include "../../test-skeleton.c"
index ea8a82cfde21c142f0eb61afff91b3990f146501..ce7c5dd43762d2817fedf4b9f0d99c1b5e61946b 100644 (file)
@@ -1,4 +1,4 @@
-# Copyright (C) 1996, 1997, 1998, 1999, 2000 Free Software Foundation, Inc.
+# Copyright (C) 1996,1997,1998,1999,2000,2001 Free Software Foundation, Inc.
 # This file is part of the GNU C Library.
 
 # The GNU C Library is free software; you can redistribute it and/or
@@ -46,7 +46,7 @@ include ../Makeconfig
 
 librt-tests = ex10 ex11
 tests = ex1 ex2 ex3 ex4 ex5 ex6 ex7 ex8 ex9 $(librt-tests) ex12 ex13 joinrace \
-       tststack $(tests-nodelete-$(have-z-nodelete)) ecmutex ex14
+       tststack $(tests-nodelete-$(have-z-nodelete)) ecmutex ex14 ex15
 
 ifeq (yes,$(build-shared))
 tests-nodelete-yes = unload
index 836d8a81e1bce0b93332e5c5ee50c05408d03a36..8221787a30c49ff69b56dbe36ec8df511645c71f 100644 (file)
@@ -435,10 +435,8 @@ static void pthread_initialize(void)
   /* Do it early so that user-registered atexit functions are called
      before pthread_exit_process. */
   if (__builtin_expect (&__dso_handle != NULL, 1))
-    /* The cast is a bit unclean.  The function expects two arguments but
-       we can only pass one.  Fortunately this is not a problem since the
-       second argument of `pthread_exit_process' is simply ignored.  */
-    __cxa_atexit((void (*) (void *)) pthread_exit_process, NULL, __dso_handle);
+    __cxa_on_exit((void (*) (void *)) pthread_exit_process, NULL,
+                 __dso_handle);
   else
     __on_exit (pthread_exit_process, NULL);
   /* How many processors.  */
index e9cef42f2cc8c11608ce1fbd2b570193b5d40bbd..61d2059e556499da2893e0a17be1627d42700b46 100644 (file)
@@ -1,4 +1,4 @@
-# Copyright (C) 1991,92,93,94,95,96,97,98,99,2000 Free Software Foundation, Inc.
+# Copyright (C) 1991-1999, 2000, 2001 Free Software Foundation, Inc.
 # This file is part of the GNU C Library.
 
 # The GNU C Library is free software; you can redistribute it and/or
@@ -29,7 +29,7 @@ routines      :=                                                            \
        abort                                                                 \
        bsearch qsort msort                                                   \
        getenv putenv setenv secure-getenv                                    \
-       exit on_exit atexit cxa_atexit cxa_finalize                           \
+       exit on_exit atexit cxa_atexit cxa_on_exit cxa_finalize               \
        abs labs llabs                                                        \
        div ldiv lldiv                                                        \
        mblen mbstowcs mbtowc wcstombs wctomb                                 \
index 034125a200ecbb61668d4a9518da95ae2baa00ad..d189f4bdbd7d7a01938578fbeaf36a0f52b697c6 100644 (file)
@@ -94,4 +94,8 @@ libc {
     # used by new G++ ABI
     __cxa_atexit; __cxa_finalize;
   }
+  GLIBC_2.2.1 {
+    # used in the thread library
+    __cxa_on_exit;
+  }
 }
diff --git a/stdlib/cxa_on_exit.c b/stdlib/cxa_on_exit.c
new file mode 100644 (file)
index 0000000..c24fa1e
--- /dev/null
@@ -0,0 +1,38 @@
+/* Copyright (C) 2001 Free Software Foundation, Inc.
+   This file is part of the GNU C Library.
+
+   The GNU C Library is free software; you can redistribute it and/or
+   modify it under the terms of the GNU Library General Public License as
+   published by the Free Software Foundation; either version 2 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
+   Library General Public License for more details.
+
+   You should have received a copy of the GNU Library General Public
+   License along with the GNU C Library; see the file COPYING.LIB.  If not,
+   write to the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
+   Boston, MA 02111-1307, USA.  */
+
+#include <stdlib.h>
+#include "exit.h"
+
+/* Register a function to be called by exit or when a shared library
+   is unloaded.  This function is only called from code generated by
+   the C++ compiler.  */
+int
+__cxa_on_exit (void (*func) (int, void *), void *arg, void *d)
+{
+  struct exit_function *new = __new_exitfn ();
+
+  if (new == NULL)
+    return -1;
+
+  new->flavor = ef_cxa2;
+  new->func.cxa2.fn = func;
+  new->func.cxa2.arg = arg;
+  new->func.cxa2.dso_handle = d;
+  return 0;
+}
index 904c2253361b85bb3c6f8a33bf77d4aeedefbb9b..5714999117d762129fc4f15127c7a0001d920c03 100644 (file)
@@ -1,4 +1,4 @@
-/* Copyright (C) 1991, 1995, 1996, 1997, 1999 Free Software Foundation, Inc.
+/* Copyright (C) 1991,1995,1996,1997,1999,2001 Free Software Foundation, Inc.
    This file is part of the GNU C Library.
 
    The GNU C Library is free software; you can redistribute it and/or
@@ -59,6 +59,9 @@ exit (int status)
            case ef_cxa:
              (*f->func.cxa.fn) (f->func.cxa.arg);
              break;
+           case ef_cxa2:
+             (*f->func.cxa2.fn) (status, f->func.cxa2.arg);
+             break;
            }
        }
 
index 9b6c1c3d4ed07ee30a2adac9d2e71292542277d4..66819dd045d0769655c48a085ad8e6d0525352c9 100644 (file)
@@ -1,4 +1,4 @@
-/* Copyright (C) 1991, 1996, 1997, 1999 Free Software Foundation, Inc.
+/* Copyright (C) 1991, 1996, 1997, 1999, 2001 Free Software Foundation, Inc.
    This file is part of the GNU C Library.
 
    The GNU C Library is free software; you can redistribute it and/or
@@ -26,7 +26,8 @@ enum
   ef_us,
   ef_on,
   ef_at,
-  ef_cxa
+  ef_cxa,
+  ef_cxa2
 };
 
 struct exit_function
@@ -48,6 +49,12 @@ struct exit_function
            void *arg;
            void *dso_handle;
          } cxa;
+       struct
+         {
+           void (*fn) (int status, void *arg);
+           void *arg;
+           void *dso_handle;
+         } cxa2;
       } func;
   };
 struct exit_function_list