summaryrefslogtreecommitdiffstats
path: root/libexec
diff options
context:
space:
mode:
authorandrew <andrew@FreeBSD.org>2015-09-08 12:00:13 +0000
committerandrew <andrew@FreeBSD.org>2015-09-08 12:00:13 +0000
commitc8580db746e3765fe9579e5c387faa65b1737915 (patch)
treecedc8abfa94316d4142a24ec0af1c4b65b3b7e22 /libexec
parentd894e2ffed5ac27e43558b5eb24237ce0bb66985 (diff)
downloadFreeBSD-src-c8580db746e3765fe9579e5c387faa65b1737915.zip
FreeBSD-src-c8580db746e3765fe9579e5c387faa65b1737915.tar.gz
MFC r287369:
Ensure we use calculate_first_tls_offset, even if the main program doesn't have TLS program header. This is needed on architectures with Variant I tls, that is arm, arm64, mips, and powerpc. These place the thread control block at the start of the buffer and, without this, this data may be trashed. This appears to not be an issue on mips or powerpc as they include a second adjustment to move the thread local data, however this is on arm64 (with a future change to fix placing this data), and should be on arm. I am unable to trigger this on arm, even after changing the code to move the data around to make it more likely to be hit. This is most likely because my tests didn't use the variable in offset 0. Reviewed by: kib MFC after: 1 week Sponsored by: ABT Systems Ltd
Diffstat (limited to 'libexec')
-rw-r--r--libexec/rtld-elf/rtld.c2
1 files changed, 1 insertions, 1 deletions
diff --git a/libexec/rtld-elf/rtld.c b/libexec/rtld-elf/rtld.c
index 36c888c..76310dd 100644
--- a/libexec/rtld-elf/rtld.c
+++ b/libexec/rtld-elf/rtld.c
@@ -4532,7 +4532,7 @@ allocate_tls_offset(Obj_Entry *obj)
return true;
}
- if (obj->tlsindex == 1)
+ if (tls_last_offset == 0)
off = calculate_first_tls_offset(obj->tlssize, obj->tlsalign);
else
off = calculate_tls_offset(tls_last_offset, tls_last_size,
OpenPOWER on IntegriCloud