diff options
author | David S. Miller <davem@davemloft.net> | 2012-02-18 22:31:42 -0800 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2012-02-18 22:31:42 -0800 |
commit | dd54084dd9549ae15c12db248571ad76946b8712 (patch) | |
tree | 5ca8baa1ff74716ac8fa735cee0a0f169f985e39 /sysdeps/unix/sysv/linux/sparc/sparc32/sysdep.h | |
parent | 2bcc53a3378d6e8782e1655cc18c8ac60e031a5d (diff) | |
download | glibc-dd54084dd9549ae15c12db248571ad76946b8712.tar glibc-dd54084dd9549ae15c12db248571ad76946b8712.tar.gz glibc-dd54084dd9549ae15c12db248571ad76946b8712.tar.bz2 glibc-dd54084dd9549ae15c12db248571ad76946b8712.zip |
Rework sparc PIC macros so crt{i,n}.S can use them too.
* sysdeps/unix/sparc/sysdep.h (SPARC_PIC_THUNK): New macro.
(SETUP_PIC_REG): Use SPARC_PIC_THUNK and don't save and restore
%o7 across the call.
(SETUP_PIC_REG_LEAF): Do %o7 save/restore in this new macro
instead.
* sysdeps/unix/sysv/linux/sparc/sparc32/sysdep.h: Use
SETUP_PIC_REG_LEAF.
* sysdeps/unix/sysv/linux/sparc/sparc64/sysdep.h: Likewise.
* sysdeps/sparc/crti.S: Use SETUP_PIC_REG.
* sysdeps/sparc/crtn.S: Likewise.
Diffstat (limited to 'sysdeps/unix/sysv/linux/sparc/sparc32/sysdep.h')
-rw-r--r-- | sysdeps/unix/sysv/linux/sparc/sparc32/sysdep.h | 10 |
1 files changed, 5 insertions, 5 deletions
diff --git a/sysdeps/unix/sysv/linux/sparc/sparc32/sysdep.h b/sysdeps/unix/sysv/linux/sparc/sparc32/sysdep.h index 01ee307abe..fd7ded5af9 100644 --- a/sysdeps/unix/sysv/linux/sparc/sparc32/sysdep.h +++ b/sysdeps/unix/sysv/linux/sparc/sparc32/sysdep.h @@ -1,4 +1,4 @@ -/* Copyright (C) 1997, 2002, 2003, 2004, 2006, 2008, 2011 +/* Copyright (C) 1997, 2002, 2003, 2004, 2006, 2008, 2011, 2012 Free Software Foundation, Inc. This file is part of the GNU C Library. Contributed by Miguel de Icaza <miguel@gnu.ai.mit.edu>, January 1997. @@ -89,7 +89,7 @@ ENTRY(name); \ #else # if RTLD_PRIVATE_ERRNO # define SYSCALL_ERROR_HANDLER \ -0: SETUP_PIC_REG(o2,g1) \ +0: SETUP_PIC_REG_LEAF(o2,g1) \ sethi %hi(rtld_errno), %g1; \ or %g1, %lo(rtld_errno), %g1; \ ld [%o2 + %g1], %g1; \ @@ -103,8 +103,8 @@ ENTRY(name); \ # else # define SYSCALL_ERROR_ERRNO errno # endif -# define SYSCALL_ERROR_HANDLER \ -0: SETUP_PIC_REG(o2,g1) \ +# define SYSCALL_ERROR_HANDLER \ +0: SETUP_PIC_REG_LEAF(o2,g1) \ sethi %tie_hi22(SYSCALL_ERROR_ERRNO), %g1; \ add %g1, %tie_lo10(SYSCALL_ERROR_ERRNO), %g1; \ ld [%o2 + %g1], %g1, %tie_ld(SYSCALL_ERROR_ERRNO); \ @@ -113,7 +113,7 @@ ENTRY(name); \ mov -1, %o0; # else # define SYSCALL_ERROR_HANDLER \ -0: SETUP_PIC_REG(o2,g1) \ +0: SETUP_PIC_REG_LEAF(o2,g1) \ sethi %hi(errno), %g1; \ or %g1, %lo(errno), %g1; \ ld [%o2 + %g1], %g1; \ |