summary refs log tree commit diff
diff options
context:
space:
mode:
-rw-r--r--ChangeLog3
-rw-r--r--elf/dl-load.c8
2 files changed, 9 insertions, 2 deletions
diff --git a/ChangeLog b/ChangeLog
index c17f7cf01b..2b8d53a762 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,5 +1,8 @@
 2002-07-15  Ulrich Drepper  <drepper@redhat.com>
 
+	* elf/dl-load.c (_dl_map_object_from_fd): If loaded object uses
+	TLS fail is USE_TLS is not defined.
+
 	* libio/wfileops.c (_IO_wfile_seekoff): Reposition wide pointers
 	and adjust state for seek position.  [PR libc/4070]
 	* libio/Makefile (tests): Add bug-rewind.
diff --git a/elf/dl-load.c b/elf/dl-load.c
index fd80be60bc..0948b8f21e 100644
--- a/elf/dl-load.c
+++ b/elf/dl-load.c
@@ -940,8 +940,8 @@ _dl_map_object_from_fd (const char *name, int fd, struct filebuf *fbp,
 	  }
 	  break;
 
-#ifdef USE_TLS
 	case PT_TLS:
+#ifdef USE_TLS
 	  if (ph->p_memsz > 0)
 	    {
 	      l->l_tls_blocksize = ph->p_memsz;
@@ -954,8 +954,12 @@ _dl_map_object_from_fd (const char *name, int fd, struct filebuf *fbp,
 	      /* Assign the next available module ID.  */
 	      l->l_tls_modid = _dl_next_tls_modid ();
 	    }
-	  break;
+#else
+	  /* Uh-oh, the binary expects TLS support but we cannot
+	     provide it.  */
+	  _dl_fatal_printf ("cannot handle file '%s' with TLS data", name);
 #endif
+	  break;
 	}
 
     /* Now process the load commands and map segments into memory.  */