aboutsummaryrefslogtreecommitdiff
path: root/sysdeps/powerpc/powerpc64/dl-trampoline.S
diff options
context:
space:
mode:
Diffstat (limited to 'sysdeps/powerpc/powerpc64/dl-trampoline.S')
-rw-r--r--sysdeps/powerpc/powerpc64/dl-trampoline.S118
1 files changed, 118 insertions, 0 deletions
diff --git a/sysdeps/powerpc/powerpc64/dl-trampoline.S b/sysdeps/powerpc/powerpc64/dl-trampoline.S
new file mode 100644
index 0000000000..71d16f2dba
--- /dev/null
+++ b/sysdeps/powerpc/powerpc64/dl-trampoline.S
@@ -0,0 +1,118 @@
+/* PLT trampolines. PPC64 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>
+
+ .section ".text"
+
+EALIGN(_dl_runtime_resolve, 4, 0)
+/* We need to save the registers used to pass parameters, ie. r3 thru
+ r10; the registers are saved in a stack frame. */
+ stdu 1,-128(1)
+ std 3,48(1)
+ mr 3,11
+ std 4,56(1)
+ sldi 4,0,1
+ std 5,64(1)
+ add 4,4,0
+ std 6,72(1)
+ sldi 4,4,3
+ std 7,80(1)
+ mflr 0
+ std 8,88(1)
+/* Store the LR in the LR Save area of the previous frame. */
+ std 0,128+16(1)
+ mfcr 0
+ std 9,96(1)
+ std 10,104(1)
+/* I'm almost certain we don't have to save cr... be safe. */
+ std 0,8(1)
+ bl JUMPTARGET(_dl_fixup)
+/* Put the registers back. */
+ ld 0,128+16(1)
+ ld 10,104(1)
+ ld 9,96(1)
+ ld 8,88(1)
+ ld 7,80(1)
+ mtlr 0
+ ld 0,8(1)
+ ld 6,72(1)
+ ld 5,64(1)
+ ld 4,56(1)
+ mtcrf 0xFF,0
+/* Load the target address, toc and static chain reg from the function
+ descriptor returned by fixup. */
+ ld 0,0(3)
+ ld 2,8(3)
+ mtctr 0
+ ld 11,16(3)
+ ld 3,48(1)
+/* Unwind the stack frame, and jump. */
+ addi 1,1,128
+ bctr
+END(_dl_runtime_resolve)
+
+
+
+EALIGN(_dl_profile_resolve, 4, 0)
+/* We need to save the registers used to pass parameters, ie. r3 thru
+ r10; the registers are saved in a stack frame. */
+ stdu 1,-128(1)
+ std 3,48(1)
+ mr 3,11
+ std 4,56(1)
+ sldi 4,0,1
+ std 5,64(1)
+ add 4,4,0
+ std 6,72(1)
+ sldi 4,4,3
+ std 7,80(1)
+ mflr 0
+ std 8,88(1)
+/* Store the LR in the LR Save area of the previous frame. */
+ std 0,128+16(1)
+ mfcr 0
+ std 9,96(1)
+ std 10,104(1)
+/* I'm almost certain we don't have to save cr... be safe. */
+ std 0,8(1)
+ bl JUMPTARGET(_dl_profile_fixup)
+/* Put the registers back. */
+ ld 0,128+16(1)
+ ld 10,104(1)
+ ld 9,96(1)
+ ld 8,88(1)
+ ld 7,80(1)
+ mtlr 0
+ ld 0,8(1)
+ ld 6,72(1)
+ ld 5,64(1)
+ ld 4,56(1)
+ mtcrf 0xFF,0
+/* Load the target address, toc and static chain reg from the function
+ descriptor returned by fixup. */
+ ld 0,0(3)
+ ld 2,8(3)
+ mtctr 0
+ ld 11,16(3)
+ ld 3,48(1)
+/* Unwind the stack frame, and jump. */
+ addi 1,1,128
+ bctr
+END(_dl_profile_resolve)