Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/lib/libc/tls Determine dynamic binaries by presence of PT_IN...
details: https://anonhg.NetBSD.org/src/rev/61e8cf457ce8
branches: trunk
changeset: 324049:61e8cf457ce8
user: joerg <joerg%NetBSD.org@localhost>
date: Fri Jul 13 19:50:21 2018 +0000
description:
Determine dynamic binaries by presence of PT_INTERP. Static PIE has
_DYNAMIC.
diffstat:
lib/libc/tls/tls.c | 18 ++++++++++--------
1 files changed, 10 insertions(+), 8 deletions(-)
diffs (68 lines):
diff -r ee68fb036ca7 -r 61e8cf457ce8 lib/libc/tls/tls.c
--- a/lib/libc/tls/tls.c Fri Jul 13 19:49:47 2018 +0000
+++ b/lib/libc/tls/tls.c Fri Jul 13 19:50:21 2018 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: tls.c,v 1.8 2014/12/14 23:49:17 chs Exp $ */
+/* $NetBSD: tls.c,v 1.9 2018/07/13 19:50:21 joerg Exp $ */
/*-
* Copyright (c) 2011 The NetBSD Foundation, Inc.
@@ -30,7 +30,7 @@
*/
#include <sys/cdefs.h>
-__RCSID("$NetBSD: tls.c,v 1.8 2014/12/14 23:49:17 chs Exp $");
+__RCSID("$NetBSD: tls.c,v 1.9 2018/07/13 19:50:21 joerg Exp $");
#include "namespace.h"
@@ -45,6 +45,7 @@
#include <sys/mman.h>
#include <link_elf.h>
#include <lwp.h>
+#include <stdbool.h>
#include <stddef.h>
#include <stdlib.h>
#include <string.h>
@@ -52,6 +53,7 @@
__dso_hidden void __libc_static_tls_setup(void);
+static bool is_dynamic;
static const void *tls_initaddr;
static size_t tls_initsize;
static size_t tls_size;
@@ -131,8 +133,6 @@
free(p);
}
-__weakref_visible int rtld_DYNAMIC __weak_reference(_DYNAMIC);
-
static int __section(".text.startup")
__libc_static_tls_setup_cb(struct dl_phdr_info *data, size_t len, void *cookie)
{
@@ -140,6 +140,10 @@
const Elf_Phdr *phlimit = data->dlpi_phdr + data->dlpi_phnum;
for (; phdr < phlimit; ++phdr) {
+ if (phdr->p_type == PT_INTERP) {
+ is_dynamic = true;
+ return -1;
+ }
if (phdr->p_type != PT_TLS)
continue;
tls_initaddr = (void *)(phdr->p_vaddr + data->dlpi_addr);
@@ -154,11 +158,9 @@
{
struct tls_tcb *tcb;
- if (&rtld_DYNAMIC != NULL) {
+ dl_iterate_phdr(__libc_static_tls_setup_cb, NULL);
+ if (is_dynamic)
return;
- }
-
- dl_iterate_phdr(__libc_static_tls_setup_cb, NULL);
tcb = _rtld_tls_allocate();
#ifdef __HAVE___LWP_SETTCB
Home |
Main Index |
Thread Index |
Old Index