~ubuntu-branches/ubuntu/utopic/eglibc/utopic

« back to all changes in this revision

Viewing changes to libpthread/pthread/pt-exit.c

  • Committer: Package Import Robot
  • Author(s): Adam Conrad
  • Date: 2012-10-26 05:14:58 UTC
  • mfrom: (1.5.1) (4.4.22 experimental)
  • Revision ID: package-import@ubuntu.com-20121026051458-oryotr4i03ob5pab
Tags: 2.16-0ubuntu1
* Merge with unreleased 2.16 in Debian experimental, remaining changes:
  - Drop the Breaks line from libc6, which refers to a Debian transition
  - Remove the libc6 recommends on libc6-i686, which we don't build
  - Enable libc6{,-dev}-armel on armhf and libc6{-dev}-armhf on armel
  - Ship update-locale and validlocale in /usr/sbin in libc-bin
  - Don't build locales or locales-all in Ubuntu, we rely on langpacks
  - Heavily mangle the way we do service restarting on major upgrades
  - Use different MIN_KERNEL_SUPPORTED versions than Debian, due to
    buildd needs.  This should be universally bumped to 3.2.0 once all
    our buildds (including the PPA guests) are running precise kernels
  - Build i386 variants as -march=i686, build amd64 with -O3, and build
    ppc64 variants (both 64-bit and 32-bit) with -O3 -fno-tree-vectorize
  - Re-enable unsubmitted-ldconfig-cache-abi.diff and rebuild the cache
    on upgrades from previous versions that used a different constant
  - debian/patches/any/local-CVE-2012-3406.diff: switch to malloc when
    array grows too large to handle via alloca extension (CVE-2012-3406)
  - Build generic i386/i686 flavour with -mno-tls-direct-seg-refs
* Changes added/dropped with this merge while reducing our delta:
  - Stop building glibc docs from the eglibc source, and instead make
    the glibc-docs stub have a hard dependency on glibc-doc-reference
  - Remove outdated conflicts against ancient versions of ia32-libs
  - Drop the tzdata dependency from libc6, it's in required and minimal
  - Use gcc-4.7/g++-4.7 by default on all our supported architectures
  - Save our historical changelog as changelog.ubuntu in the source
  - Drop nscd's libaudit build-dep for now, as libaudit is in universe
  - Drop the unnecessary Breaks from libc6 to locales and locales-all
  - Ship xen's ld.so.conf.d snippet as /etc/ld.so.conf.d/libc6-xen.conf
* Disable hard failures on the test suite for the first upload to raring

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
/* Thread termination.
 
2
   Copyright (C) 2000, 2002, 2005, 2007, 2011 Free Software Foundation, Inc.
 
3
   This file is part of the GNU C Library.
 
4
 
 
5
   The GNU C Library is free software; you can redistribute it and/or
 
6
   modify it under the terms of the GNU Library General Public License as
 
7
   published by the Free Software Foundation; either version 2 of the
 
8
   License, or (at your option) any later version.
 
9
 
 
10
   The GNU C Library is distributed in the hope that it will be useful,
 
11
   but WITHOUT ANY WARRANTY; without even the implied warranty of
 
12
   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
 
13
   Library General Public License for more details.
 
14
 
 
15
   You should have received a copy of the GNU Library General Public
 
16
   License along with the GNU C Library; see the file COPYING.LIB.  If not,
 
17
   write to the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
 
18
   Boston, MA 02111-1307, USA.  */
 
19
 
 
20
#include <assert.h>
 
21
#include <errno.h>
 
22
#include <pthread.h>
 
23
#include <stdlib.h>
 
24
 
 
25
#include <pt-internal.h>
 
26
 
 
27
#include <bits/pt-atomic.h>
 
28
 
 
29
 
 
30
/* Terminate the current thread and make STATUS available to any
 
31
   thread that might join it.  */
 
32
void
 
33
__pthread_exit (void *status)
 
34
{
 
35
  struct __pthread *self = _pthread_self ();
 
36
  struct __pthread_cancelation_handler **handlers;
 
37
  int oldstate;
 
38
 
 
39
  /* Run any cancelation handlers.  According to POSIX, the
 
40
     cancellation cleanup handlers should be called with cancellation
 
41
     disabled.  */
 
42
  pthread_setcancelstate (PTHREAD_CANCEL_DISABLE, &oldstate);
 
43
 
 
44
  for (handlers = __pthread_get_cleanup_stack ();
 
45
       *handlers;
 
46
       *handlers = (*handlers)->next)
 
47
    (*handlers)->handler ((*handlers)->arg);
 
48
 
 
49
  pthread_setcancelstate (oldstate, &oldstate);
 
50
 
 
51
  /* Destory any thread specific data.  */
 
52
  __pthread_destroy_specific (self);
 
53
 
 
54
  /* Destroy any signal state.  */
 
55
  __pthread_sigstate_destroy (self);
 
56
 
 
57
  /* Decrease the number of threads.  We use an atomic operation to
 
58
     make sure that only the last thread calls `exit'.  */
 
59
  if (__atomic_dec_and_test (&__pthread_total))
 
60
    /* We are the last thread.  */
 
61
    exit (0);
 
62
 
 
63
  /* Note that after this point the process can be terminated at any
 
64
     point if another thread calls `pthread_exit' and happens to be
 
65
     the last thread.  */
 
66
 
 
67
  __pthread_mutex_lock (&self->state_lock);
 
68
 
 
69
  if (self->cancel_state == PTHREAD_CANCEL_ENABLE && self->cancel_pending)
 
70
    status = PTHREAD_CANCELED;
 
71
 
 
72
#ifdef ENABLE_TLS
 
73
  if (self->tcb)
 
74
    _dl_deallocate_tls (self->tcb, 1);
 
75
#endif /* ENABLE_TLS */
 
76
 
 
77
  switch (self->state)
 
78
    {
 
79
    default:
 
80
      assert (! "Consistency error: unexpected self->state");
 
81
      abort ();
 
82
      break;
 
83
 
 
84
    case PTHREAD_DETACHED:
 
85
      /* Make sure that nobody can reference this thread anymore, and
 
86
         mark it as terminated.  Our thread ID will immediately become
 
87
         available for re-use.  For obvious reasons, we cannot
 
88
         deallocate our own stack.  However, it will eventually be
 
89
         reused when this thread structure is recycled.  */
 
90
      __pthread_mutex_unlock (&self->state_lock);
 
91
 
 
92
      __pthread_dealloc (self);
 
93
 
 
94
      break;
 
95
 
 
96
    case PTHREAD_JOINABLE:
 
97
      /* We need to stay around for a while since another thread
 
98
         might want to join us.  */
 
99
      self->state = PTHREAD_EXITED;
 
100
 
 
101
      /* We need to remember the exit status.  A thread joining us
 
102
         might ask for it.  */
 
103
      self->status = status;
 
104
 
 
105
      /* Broadcast the condition.  This will wake up threads that are
 
106
         waiting to join us.  */
 
107
      pthread_cond_broadcast (&self->state_cond);
 
108
      __pthread_mutex_unlock (&self->state_lock);
 
109
 
 
110
      break;
 
111
    }
 
112
 
 
113
  /* Note that after this point the resources used by this thread can
 
114
     be freed at any moment if another thread joins or detaches us.
 
115
     This means that before freeing any resources, such a thread
 
116
     should make sure that this thread is really halted.  */
 
117
 
 
118
  __pthread_thread_halt (self);
 
119
 
 
120
  /* NOTREACHED */
 
121
  abort ();
 
122
}
 
123
 
 
124
strong_alias (__pthread_exit, pthread_exit);