projects
/
musl
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
new dlstart stage-2 chaining for mips
[musl]
/
src
/
env
/
__init_tls.c
diff --git
a/src/env/__init_tls.c
b/src/env/__init_tls.c
index
67f1409
..
73551e6
100644
(file)
--- a/
src/env/__init_tls.c
+++ b/
src/env/__init_tls.c
@@
-8,6
+8,9
@@
#include "atomic.h"
#include "syscall.h"
#include "atomic.h"
#include "syscall.h"
+#ifndef SHARED
+static
+#endif
int __init_tp(void *p)
{
pthread_t td = p;
int __init_tp(void *p)
{
pthread_t td = p;
@@
-33,7
+36,7
@@
static struct builtin_tls {
struct tls_image {
void *image;
size_t len, size, align;
struct tls_image {
void *image;
size_t len, size, align;
-} __static_tls
ATTR_LIBC_VISIBILITY
;
+} __static_tls;
#define T __static_tls
#define T __static_tls
@@
-74,8
+77,6
@@
void __init_tls(size_t *aux)
size_t base = 0;
void *mem;
size_t base = 0;
void *mem;
- libc.tls_size = sizeof(struct pthread);
-
for (p=(void *)aux[AT_PHDR],n=aux[AT_PHNUM]; n; n--,p+=aux[AT_PHENT]) {
phdr = (void *)p;
if (phdr->p_type == PT_PHDR)
for (p=(void *)aux[AT_PHDR],n=aux[AT_PHNUM]; n; n--,p+=aux[AT_PHENT]) {
phdr = (void *)p;
if (phdr->p_type == PT_PHDR)
@@
-94,7
+95,8
@@
void __init_tls(size_t *aux)
T.size += (-T.size - (uintptr_t)T.image) & (T.align-1);
if (T.align < MIN_TLS_ALIGN) T.align = MIN_TLS_ALIGN;
T.size += (-T.size - (uintptr_t)T.image) & (T.align-1);
if (T.align < MIN_TLS_ALIGN) T.align = MIN_TLS_ALIGN;
- libc.tls_size = 2*sizeof(void *)+T.size+T.align+sizeof(struct pthread);
+ libc.tls_size = 2*sizeof(void *)+T.size+T.align+sizeof(struct pthread)
+ + MIN_TLS_ALIGN-1 & -MIN_TLS_ALIGN;
if (libc.tls_size > sizeof builtin_tls) {
#ifndef SYS_mmap2
if (libc.tls_size > sizeof builtin_tls) {
#ifndef SYS_mmap2