about summary refs log tree commit diff
path: root/ports/sysdeps/m68k/dl-trampoline.S
diff options
context:
space:
mode:
Diffstat (limited to 'ports/sysdeps/m68k/dl-trampoline.S')
-rw-r--r--ports/sysdeps/m68k/dl-trampoline.S222
1 files changed, 0 insertions, 222 deletions
diff --git a/ports/sysdeps/m68k/dl-trampoline.S b/ports/sysdeps/m68k/dl-trampoline.S
deleted file mode 100644
index 1c1bbf301b..0000000000
--- a/ports/sysdeps/m68k/dl-trampoline.S
+++ /dev/null
@@ -1,222 +0,0 @@
-/* PLT trampolines.  m68k version.
-   Copyright (C) 2005-2014 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, see
-   <http://www.gnu.org/licenses/>.  */
-
-#include <sysdep.h>
-
-#if !defined (__mcoldfire__)
-# define FMOVE		fmove.x
-# define FPSPACE	12
-#elif defined (__mcffpu__)
-# define FMOVE		fmove.d
-# define FPSPACE	8
-#else
-# define FPSPACE	0
-#endif
-
-	.text
-	.globl _dl_runtime_resolve
-	.type _dl_runtime_resolve, @function
-_dl_runtime_resolve:
-	cfi_startproc
-	cfi_adjust_cfa_offset (8)
-	| Save %a0 (struct return address) and %a1.
-	move.l %a0, -(%sp)
-	cfi_adjust_cfa_offset (4)
-	move.l %a1, -(%sp)
-	cfi_adjust_cfa_offset (4)
-	| Call the real address resolver.
-	jbsr _dl_fixup
-	| Restore register %a0 and %a1.
-	move.l (%sp)+, %a1
-	cfi_adjust_cfa_offset (-4)
-	move.l (%sp)+, %a0
-	cfi_adjust_cfa_offset (-4)
-	| Pop parameters
-	addq.l #8, %sp
-	cfi_adjust_cfa_offset (-8)
-	| Call real function.
-#ifdef __mcoldfire__
-	move.l %d0,-(%sp)
-	cfi_adjust_cfa_offset (4)
-	rts
-#else
-	jmp (%d0)
-#endif
-	cfi_endproc
-	.size _dl_runtime_resolve, . - _dl_runtime_resolve
-
-	.text
-	.globl _dl_runtime_profile
-	.type _dl_runtime_profile, @function
-_dl_runtime_profile:
-	cfi_startproc
-	cfi_adjust_cfa_offset (8)
-	pea 8(%sp)
-	cfi_adjust_cfa_offset (4)
-	move.l %a1, -(%sp)
-	cfi_adjust_cfa_offset (4)
-	move.l %a0, -(%sp)
-	cfi_adjust_cfa_offset (4)
-	pea -1.w
-	cfi_adjust_cfa_offset (4)
-	| Push parameters for _dl_profile_fixup
-	pea (%sp)
-	cfi_adjust_cfa_offset (4)
-	pea 8(%sp)
-	cfi_adjust_cfa_offset (4)
-	move.l 32(%sp), -(%sp)
-	cfi_adjust_cfa_offset (4)
-	move.l 32(%sp), -(%sp)
-	cfi_adjust_cfa_offset (4)
-	move.l 32(%sp), -(%sp)
-	cfi_adjust_cfa_offset (4)
-	subq.l #8, %sp
-	cfi_adjust_cfa_offset (8)
-	| Call the real address resolver.
-	jbsr _dl_profile_fixup
-	| Pop parameters
-	lea 28(%sp), %sp
-	cfi_adjust_cfa_offset (-28)
-	move.l (%sp), %d1
-	jpl 1f
-	addq.l #4, %sp
-	cfi_adjust_cfa_offset (-4)
-	| Restore register %a0 and %a1.
-	move.l (%sp)+, %a0
-	cfi_adjust_cfa_offset (-4)
-	move.l (%sp)+, %a1
-	cfi_adjust_cfa_offset (-4)
-	lea 12(%sp), %sp
-	cfi_adjust_cfa_offset (-12)
-	| Call real function.
-#ifdef __mcoldfire__
-	move.l %d0,-(%sp)
-	cfi_adjust_cfa_offset (4)
-	rts
-#else
-	jmp (%d0)
-#endif
-
-	/*
-	    +24     return address
-	    +20     PLT1
-	    +16     PLT2
-	    +12     %sp
-	    +8      %a1
-	    +4      %a0
-	   %sp      free
-	*/
-#ifdef __mcoldfire__
-	cfi_adjust_cfa_offset (20)
-#else
-	cfi_adjust_cfa_offset (24)
-#endif
-1:	move.l %a2, (%sp)
-	cfi_rel_offset (%a2, 0)
-	move.l %sp, %a2
-	move.l %sp, %a0
-	lea 28(%sp), %a1
-	| Round framesize up to longword alignment
-	addq.l #3, %d1
-	and.l #-3, %d1
-	sub.l %d1, %a0
-	move.l %a0, %sp
-	cfi_def_cfa_register (%a2)
-#ifdef __mcoldfire__
-	tst.l %d1
-	beq 2f
-1:	move.l (%a1)+, (%a0)+
-	subq.l #4,%d1
-	bne 1b
-2:
-#else
-	lsr.l #2,%d1
-	jra 2f
-1:	move.l (%a1)+, (%a0)+
-2:	dbra %d1,1b
-#endif
-	/*
-	   %a2+24  return address
-	   %a2+20  PLT1
-	   %a2+16  PLT2
-	   %a2+12  %sp
-	   %a2+8   %a1
-	   %a2+4   %a0
-	   %a2     %a2
-	   %sp     copied stack frame
-	*/
-
-	move.l 4(%a2), %a0
-	move.l 8(%a2), %a1
-#ifdef __mcoldfire__
-	pea 2f(%pc)
-	move.l %d0,-(%sp)
-	rts
-2:
-#else
-	jsr (%d0)
-#endif
-	move.l %a2, %sp
-	cfi_def_cfa_register (%sp)
-	move.l (%sp)+, %a2
-	cfi_adjust_cfa_offset (4)
-	cfi_restore (%a2)
-	/*
-	    +20     return address
-	    +16     PLT1
-	    +12     PLT2
-	    +8      %sp
-	    +4      %a1
-	   %sp      %a0
-	*/
-#ifdef FMOVE
-	FMOVE %fp0, -(%sp)
-	cfi_adjust_cfa_offset (FPSPACE)
-#endif
-	move.l %a0, -(%sp)
-	cfi_adjust_cfa_offset (4)
-	move.l %d1, -(%sp)
-	cfi_adjust_cfa_offset (4)
-	move.l %d0, -(%sp)
-	cfi_adjust_cfa_offset (4)
-	pea (%sp)
-	cfi_adjust_cfa_offset (4)
-	pea (16+FPSPACE)(%sp)
-	cfi_adjust_cfa_offset (4)
-	move.l (32+FPSPACE)(%sp), -(%sp)
-	cfi_adjust_cfa_offset (4)
-	move.l (32+FPSPACE)(%sp), -(%sp)
-	cfi_adjust_cfa_offset (4)
-	jbsr _dl_call_pltexit
-	lea 16(%sp), %sp
-	cfi_adjust_cfa_offset (-16)
-	move.l (%sp)+, %d0
-	cfi_adjust_cfa_offset (-4)
-	move.l (%sp)+, %d1
-	cfi_adjust_cfa_offset (-4)
-	move.l (%sp)+, %a0
-	cfi_adjust_cfa_offset (-4)
-#ifdef FMOVE
-	FMOVE (%sp)+, %fp0
-	cfi_adjust_cfa_offset (-FPSPACE)
-#endif
-	lea 20(%sp), %sp
-	cfi_adjust_cfa_offset (-20)
-	rts
-	cfi_endproc
-	.size _dl_runtime_profile, . - _dl_runtime_profile