summary refs log tree commit diff
path: root/sysdeps/unix/sysv/linux/i386
diff options
context:
space:
mode:
authorUlrich Drepper <drepper@redhat.com>2002-05-30 23:35:59 +0000
committerUlrich Drepper <drepper@redhat.com>2002-05-30 23:35:59 +0000
commit9bd646022380b5eef343c61f8a8274135540db09 (patch)
treed2badaf6dbf17a5958b89f4c1b024d56f9512b98 /sysdeps/unix/sysv/linux/i386
parent5c24bb7d7bf2df8085bbf8a5b6ccfdcec6c8cafc (diff)
downloadglibc-9bd646022380b5eef343c61f8a8274135540db09.tar.gz
glibc-9bd646022380b5eef343c61f8a8274135540db09.tar.xz
glibc-9bd646022380b5eef343c61f8a8274135540db09.zip
Update.
2002-05-30  Ulrich Drepper  <drepper@redhat.com>

	* sysdeps/unix/sysv/linux/Makefile [$(subdir)==misc] (sysdep_routines):
	Add readahead.
	* sysdeps/unix/sysv/linux/readahead.c: New file.
	* sysdeps/unix/sysv/linux/syscalls.list: Add sendfile64 syscall.
	* sysdeps/unix/sysv/linux/Versions: Export readahead and sendfile64.
	* sysdeps/unix/sysv/linux/alpha/syscalls.list: Add readahead syscall.
	Add sendfile64 alias to sendfile syscall.
	* sysdeps/unix/sysv/linux/ia64/syscalls.list: Likewise.
	* sysdeps/unix/sysv/linux/sparc/sparc64/syscalls.list: Likewise.
	* sysdeps/unix/sysv/linux/x86_64/syscalls.list: Likewise.
	* sysdeps/unix/sysv/linux/powerpc/syscalls.list: Add s_readahead
	syscall.

	* sysdeps/unix/sysv/linux/i386/sysdep.h: Use __i686.get_pc_thunk.XX
	special section for PIC register loading.
	* sysdeps/unix/sysv/linux/i386/i686/sysdep.h: Likewise.

	* config.h.in: Define HAVE_HIDDEN.
	* configure.in: Also define HAVE_HIDDEN if HAVE_PROTECTED is defined.

	* elf/elf.h: Correct Alpha TLS relocations according to last spec.
Diffstat (limited to 'sysdeps/unix/sysv/linux/i386')
-rw-r--r--sysdeps/unix/sysv/linux/i386/i686/sysdep.h52
-rw-r--r--sysdeps/unix/sysv/linux/i386/sysdep.h42
2 files changed, 83 insertions, 11 deletions
diff --git a/sysdeps/unix/sysv/linux/i386/i686/sysdep.h b/sysdeps/unix/sysv/linux/i386/i686/sysdep.h
index 8e7e5e0420..6b54a81d32 100644
--- a/sysdeps/unix/sysv/linux/i386/i686/sysdep.h
+++ b/sysdeps/unix/sysv/linux/i386/i686/sysdep.h
@@ -1,4 +1,4 @@
-/* Copyright (C) 1998, 2000 Free Software Foundation, Inc.
+/* Copyright (C) 1998, 2000, 2002 Free Software Foundation, Inc.
    This file is part of the GNU C Library.
    Contributed by Ulrich Drepper, <drepper@cygnus.com>, 1998.
 
@@ -32,11 +32,30 @@
 
 /* Store (- %eax) into errno through the GOT.  */
 # ifdef _LIBC_REENTRANT
-#  define SYSCALL_ERROR_HANDLER						      \
-1:movl (%esp),%ebx;							      \
+
+#  ifndef HAVE_HIDDEN
+#   define SETUP_PIC_REG \
+  call 1f;								      \
+  .subsection 1;							      \
+1:movl (%esp), %ebx;							      \
+  ret;									      \
+  .previous
+#  else
+#   define SETUP_PIC_REG \
+  .section .gnu.linkonce.t.__i686.get_pc_thunk.bx,"ax",@progbits;	      \
+  .globl __i686.get_pc_thunk.bx;					      \
+  .hidden __i686.get_pc_thunk.bx;					      \
+  .type __i686.get_pc_thunk.bx,@function;				      \
+__i686.get_pc_thunk.bx:							      \
+  movl (%esp), %ebx;							      \
   ret;									      \
+  .previous;								      \
+  call __i686.get_pc_thunk.bx
+#  endif
+
+#  define SYSCALL_ERROR_HANDLER						      \
 0:pushl %ebx;								      \
-  call 1b;								      \
+  SETUP_PIC_REG;							      \
   addl $_GLOBAL_OFFSET_TABLE_, %ebx;					      \
   xorl %edx, %edx;							      \
   subl %eax, %edx;							      \
@@ -52,10 +71,29 @@
 /* A quick note: it is assumed that the call to `__errno_location' does
    not modify the stack!  */
 # else
-#  define SYSCALL_ERROR_HANDLER						      \
-1:movl (%esp),%ecx;							      \
+
+#  ifndef HAVE_HIDDEN
+#   define SETUP_PIC_REG \
+  call 1f;								      \
+  .subsection 1;							      \
+1:movl (%esp), %ecx;							      \
+  ret;									      \
+  .previous
+#  else
+#   define SETUP_PIC_REG \
+  .section .gnu.linkonce.t.__i686.get_pc_thunk.cx,"ax",@progbits;	      \
+  .globl __i686.get_pc_thunk.cx;					      \
+  .hidden __i686.get_pc_thunk.cx;					      \
+  .type __i686.get_pc_thunk.cx,@function;				      \
+__i686.get_pc_thunk.cx:							      \
+  movl (%esp), %ecx;							      \
   ret;									      \
-0:call 1b;								      \
+  .previous;								      \
+  call __i686.get_pc_thunk.cx
+#  endif
+
+#  define SYSCALL_ERROR_HANDLER						      \
+0:SETUP_PIC_REG;							      \
   addl $_GLOBAL_OFFSET_TABLE_, %ecx;					      \
   xorl %edx, %edx;							      \
   subl %eax, %edx;							      \
diff --git a/sysdeps/unix/sysv/linux/i386/sysdep.h b/sysdeps/unix/sysv/linux/i386/sysdep.h
index 2cc39d69cd..730c4dfdf9 100644
--- a/sysdeps/unix/sysv/linux/i386/sysdep.h
+++ b/sysdeps/unix/sysv/linux/i386/sysdep.h
@@ -76,13 +76,30 @@
 #else
 /* Store (- %eax) into errno through the GOT.  */
 #ifdef _LIBC_REENTRANT
-#define SYSCALL_ERROR_HANDLER						      \
-0:pushl %ebx;								      \
+
+# ifndef HAVE_HIDDEN
+#  define SETUP_PIC_REG \
   call 1f;								      \
   .subsection 1;							      \
 1:movl (%esp), %ebx;							      \
   ret;									      \
+  .previous
+# else
+#  define SETUP_PIC_REG \
+  .section .gnu.linkonce.t.__i686.get_pc_thunk.bx,"ax",@progbits;	      \
+  .globl __i686.get_pc_thunk.bx;					      \
+  .hidden __i686.get_pc_thunk.bx;					      \
+  .type __i686.get_pc_thunk.bx,@function;				      \
+__i686.get_pc_thunk.bx:							      \
+  movl (%esp), %ebx;							      \
+  ret;									      \
   .previous;								      \
+  call __i686.get_pc_thunk.bx
+# endif
+
+#define SYSCALL_ERROR_HANDLER						      \
+0:pushl %ebx;								      \
+  SETUP_PIC_REG;							      \
   addl $_GLOBAL_OFFSET_TABLE_, %ebx;					      \
   xorl %edx, %edx;							      \
   subl %eax, %edx;							      \
@@ -98,12 +115,29 @@
 /* A quick note: it is assumed that the call to `__errno_location' does
    not modify the stack!  */
 #else
-#define SYSCALL_ERROR_HANDLER						      \
-0:call 1f;								      \
+
+# ifndef HAVE_HIDDEN
+#  define SETUP_PIC_REG \
+  call 1f;								      \
   .subsection 1;							      \
 1:movl (%esp), %ecx;							      \
   ret;									      \
+  .previous
+# else
+#  define SETUP_PIC_REG \
+  .section .gnu.linkonce.t.__i686.get_pc_thunk.cx,"ax",@progbits;	      \
+  .globl __i686.get_pc_thunk.cx;					      \
+  .hidden __i686.get_pc_thunk.cx;					      \
+  .type __i686.get_pc_thunk.cx,@function;				      \
+__i686.get_pc_thunk.cx:							      \
+  movl (%esp), %ecx;							      \
+  ret;									      \
   .previous;								      \
+  call __i686.get_pc_thunk.cx
+# endif
+
+#define SYSCALL_ERROR_HANDLER						      \
+0:define SETUP_PIC_REG;							      \
   addl $_GLOBAL_OFFSET_TABLE_, %ecx;					      \
   xorl %edx, %edx;							      \
   subl %eax, %edx;							      \