]> sourceware.org Git - glibc.git/commitdiff
Check mismatched TLS/non-TLS symbols hjl/pr14370
authorH.J. Lu <hjl.tools@gmail.com>
Tue, 4 Sep 2012 20:18:28 +0000 (13:18 -0700)
committerH.J. Lu <hjl.tools@gmail.com>
Tue, 4 Sep 2012 20:18:28 +0000 (13:18 -0700)
ChangeLog
elf/dl-lookup.c

index 5411be313850a06ed8e8b88958f6408dbbbafa91..838c60795ffdc54945eeafa488daaa13659aa731 100644 (file)
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,9 @@
+2012-09-04  H.J. Lu  <hongjiu.lu@intel.com>
+
+       [BZ #14370]
+       * elf/dl-lookup.c (_dl_lookup_symbol_x): Check mismatched
+       TLS/non-TLS symbols.
+
 2012-09-04  Florian Weimer  <fweimer@redhat.com>
 
        * stdlib/tst-secure-getenv.c (alternative_main): Only warn on SGID
index e7f7148381257f8604677fc93f809cc6f2e5d041..85bfb51e389f57365f00ff3dd8b2d2958c31b583 100644 (file)
@@ -840,6 +840,31 @@ _dl_lookup_symbol_x (const char *undef_name, struct link_map *undef_map,
                                  ? undef_map->l_scope : symbol_scope,
                                  version, type_class, flags, skip_map);
 
+  if (__builtin_expect (*ref != NULL, 1)
+      && (__builtin_expect (ELFW(ST_TYPE) (current_value.s->st_info) == STT_TLS, 0)
+         || __builtin_expect (ELFW(ST_TYPE) ((*ref)->st_info) == STT_TLS, 0))
+      && __builtin_expect (ELFW(ST_TYPE) (current_value.s->st_info) !=
+                          ELFW(ST_TYPE) ((*ref)->st_info), 1))
+    {
+      const char *reference_name = undef_map ? undef_map->l_name : "";
+      const char *definition_name = (current_value.m->l_name[0]
+                                    ? current_value.m->l_name
+                                    : rtld_progname);
+      _dl_signal_cerror (0, (reference_name[0]
+                            ? reference_name
+                            : (rtld_progname ?: "<main program>")),
+                        N_("symbol lookup error"),
+                        make_string ((ELFW(ST_TYPE) ((*ref)->st_info) == STT_TLS
+                                      ? "TLS" : "non-TLS"),
+                                     " definition `", undef_name,
+                                     "' mismatches ",
+                                     (ELFW(ST_TYPE) (current_value.s->st_info) == STT_TLS
+                                      ? "TLS" : "non-TLS"),
+                                     " reference in ", definition_name));
+      *ref = NULL;
+      return 0;
+    }
+
   /* The object is used.  */
   if (__builtin_expect (current_value.m->l_used == 0, 0))
     current_value.m->l_used = 1;
This page took 0.112981 seconds and 5 git commands to generate.