mach, hurd: Drop __libc_lock_self0

This was used for the value of libc-lock's owner when TLS is not yet set
up, so THREAD_SELF can not be used. Since the value need not be anything
specific -- it just has to be non-NULL -- we can just use a plain
constant, such as (void *) 1, for this. This avoids accessing the symbol
through GOT, and exporting it from libc.so in the first place.

Signed-off-by: Sergey Bugaev <bugaevc@gmail.com>
Message-Id: <20230319151017.531737-12-bugaevc@gmail.com>
This commit is contained in:
Sergey Bugaev 2023-03-19 18:09:54 +03:00 committed by Samuel Thibault
parent 589bcfdeef
commit af2942cc62
3 changed files with 3 additions and 8 deletions

View File

@ -20,7 +20,7 @@ libc {
__open_nocancel; __open_nocancel;
__read_nocancel; __pread64_nocancel; __read_nocancel; __pread64_nocancel;
__write_nocancel; __write_nocancel;
__libc_lock_self0; __getcwd; __getcwd;
__stat64; __stat64;
_dl_init_first; _dl_init_first;
@ -61,7 +61,7 @@ ld {
__open_nocancel; __open_nocancel;
__read_nocancel; __pread64_nocancel; __read_nocancel; __pread64_nocancel;
__write_nocancel; __write_nocancel;
__libc_lock_self0; __getcwd; __getcwd;
__stat64; __fstat64; __stat64; __fstat64;
} }
} }

View File

@ -20,10 +20,6 @@
#include <stdlib.h> #include <stdlib.h>
#include <pthreadP.h> #include <pthreadP.h>
/* This serves as stub "self" pointer for libc locks when TLS is not initialized
yet. */
char __libc_lock_self0[0];
/* Placeholder for key creation routine from Hurd cthreads library. */ /* Placeholder for key creation routine from Hurd cthreads library. */
int int
weak_function weak_function

View File

@ -34,9 +34,8 @@ typedef struct
typedef __libc_lock_recursive_t __rtld_lock_recursive_t; typedef __libc_lock_recursive_t __rtld_lock_recursive_t;
extern char __libc_lock_self0[0];
#define __libc_lock_owner_self() \ #define __libc_lock_owner_self() \
(__LIBC_NO_TLS () ? (void *)&__libc_lock_self0 : THREAD_SELF) (__LIBC_NO_TLS () ? (void *) 1 : THREAD_SELF)
#else #else
typedef struct __libc_lock_opaque__ __libc_lock_t; typedef struct __libc_lock_opaque__ __libc_lock_t;