aboutsummaryrefslogtreecommitdiff
path: root/sysdeps/sparc/sparc32/dl-trampoline.S
diff options
context:
space:
mode:
authorUlrich Drepper <drepper@redhat.com>2004-12-22 20:10:10 +0000
committerUlrich Drepper <drepper@redhat.com>2004-12-22 20:10:10 +0000
commita334319f6530564d22e775935d9c91663623a1b4 (patch)
treeb5877475619e4c938e98757d518bb1e9cbead751 /sysdeps/sparc/sparc32/dl-trampoline.S
parent0ecb606cb6cf65de1d9fc8a919bceb4be476c602 (diff)
downloadglibc-a334319f6530564d22e775935d9c91663623a1b4.zip
glibc-a334319f6530564d22e775935d9c91663623a1b4.tar.gz
glibc-a334319f6530564d22e775935d9c91663623a1b4.tar.bz2
(CFLAGS-tst-align.c): Add -mpreferred-stack-boundary=4.
Diffstat (limited to 'sysdeps/sparc/sparc32/dl-trampoline.S')
-rw-r--r--sysdeps/sparc/sparc32/dl-trampoline.S184
1 files changed, 0 insertions, 184 deletions
diff --git a/sysdeps/sparc/sparc32/dl-trampoline.S b/sysdeps/sparc/sparc32/dl-trampoline.S
deleted file mode 100644
index b0f86dd..0000000
--- a/sysdeps/sparc/sparc32/dl-trampoline.S
+++ /dev/null
@@ -1,184 +0,0 @@
-/* PLT trampolines. Sparc 32-bit version.
- Copyright (C) 2005 Free Software Foundation, Inc.
- This file is part of the GNU C Library.
-
- The GNU C Library is free software; you can redistribute it and/or
- modify it under the terms of the GNU Lesser General Public
- License as published by the Free Software Foundation; either
- version 2.1 of the License, or (at your option) any later version.
-
- The GNU C Library is distributed in the hope that it will be useful,
- but WITHOUT ANY WARRANTY; without even the implied warranty of
- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
- Lesser General Public License for more details.
-
- You should have received a copy of the GNU Lesser General Public
- License along with the GNU C Library; if not, write to the Free
- Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA
- 02111-1307 USA. */
-
-#include <sysdep.h>
-
- .text
- .align 32
-
- /* %g1: PLT offset loaded by PLT entry
- * %g2: callers PC, which is PLT0 + 4, and we store the
- * link map at PLT0 + 12, therefore we add 8 to get
- * the address of the link map
- */
- .globl _dl_runtime_resolve
- .type _dl_runtime_resolve, @function
-_dl_runtime_resolve:
- cfi_startproc
-
- save %sp, -104, %sp
- cfi_def_cfa_register(%fp)
- cfi_window_save
- cfi_register (%o7, %i7)
-
- ld [%g2 + 8], %o0
- srl %g1, 10, %o1
- call _dl_fixup
- sub %o1, 4*12, %o1
- jmp %o0
- restore
-
- cfi_endproc
-
- .size _dl_runtime_resolve, .-_dl_runtime_resolve
-
- /* For the profiling cases we pass in our stack frame
- * as the base of the La_sparc64_regs, so it looks
- * like:
- * %l0 %sp
- * ...
- * %l7 %sp + (7 * 8)
- * %i0 %sp + (8 * 8)
- * ...
- * %i7 %sp + (15 * 8)
- * %f0 %sp + (16 * 8)
- * %f16 %sp + (31 * 8)
- * framesize %sp + (32 * 8)
- */
-
- .globl _dl_profile_save_regs
- .type _dl_profile_save_regs, @function
-_dl_profile_save_regs:
- cfi_startproc
-
- std %l0, [%sp + ( 0 * 8)]
- std %l2, [%sp + ( 1 * 8)]
- std %l4, [%sp + ( 2 * 8)]
- std %l6, [%sp + ( 3 * 8)]
- std %i0, [%sp + ( 4 * 8)]
- std %i2, [%sp + ( 5 * 8)]
- std %i4, [%sp + ( 6 * 8)]
- std %i6, [%sp + ( 7 * 8)]
- ld [%sp + (8 * 8)], %l4
- retl
- st %l4, [%sp + (8 * 8)]
-
- cfi_endproc
-
- .size _dl_profile_save_regs, .-_dl_profile_save_regs
-
- /* If we are going to call pltexit, then we must replicate
- * the caller's stack frame.
- * %o0: PLT resolved function address
- */
- .globl _dl_profile_invoke
- .type _dl_profile_invoke, @function
-_dl_profile_invoke:
- cfi_startproc
-
- sub %sp, %l0, %sp
-1:
- srl %l0, 3, %l7
- mov %o0, %l1
- mov %i0, %o0
- mov %i1, %o1
- mov %i2, %o2
- mov %i3, %o3
- mov %i4, %o4
- mov %i5, %o5
- mov %fp, %l2
- mov %sp, %l3
-1: ldd [%l2], %g2
- add %l2, 0x8, %l2
- subcc %l7, 1, %l7
- std %g2, [%l3]
- bne 1b
- add %l3, 0x8, %l3
-
- jmpl %l1, %o7
- nop
-
- std %o0, [%sp + ( 9 * 8)]
- std %f0, [%sp + (10 * 8)]
-
- mov %l5, %o0
- mov %l6, %o1
- add %sp, %l0, %o2
- call _dl_call_pltexit
- add %sp, (16 * 8), %o3
-
- ldd [%sp + (9 * 8)], %i0
-
- jmpl %i7 + 8, %g0
- restore
-
- cfi_endproc
-
- .size _dl_profile_invoke, .-_dl_profile_invoke
-
- /* %g1: PLT offset loaded by PLT entry
- * %g2: callers PC, which is PLT0 + 4, and we store the
- * link map at PLT0 + 12, therefore we add 8 to get
- * the address of the link map
- */
- .align 32
- .globl _dl_runtime_profile
- .type _dl_runtime_profile, @function
-_dl_runtime_profile:
- cfi_startproc
-
- cmp %fp, 0
- be,a 1f
- mov 104, %g3
- sub %fp, %sp, %g3
-1: save %sp, -104, %sp
- cfi_def_cfa_register(%fp)
- cfi_window_save
- cfi_register(%o7, %i7)
-
- ld [%g2 + 8], %o0
- srl %g1, 10, %o1
- mov %i7, %o2
- sub %o1, 4*12, %o1
-
- mov %g3, %l0
- mov %o0, %l5
- mov %o1, %l6
-
- call _dl_profile_save_regs
- nop
-
- mov %sp, %o3
- call _dl_profile_fixup
- add %sp, (9 * 8), %o4
-
- ld [%sp + (9 * 8)], %o1
- cmp %o1, 0
- bgeu 1f
- nop
-
- call _dl_profile_invoke
- nop
-
-1: jmp %o0
- restore
-
- cfi_endproc
-
- .size _dl_runtime_profile, .-_dl_runtime_profile