mirror of
				https://sourceware.org/git/glibc.git
				synced 2025-10-30 10:45:40 +03:00 
			
		
		
		
	Handle prelinked libraries and binaries with new style PLT. 2005-06-07 Jakub Jelinek <jakub@redhat.com> * elf/elf.h (R_PPC_REL16, R_PPC_REL16_LO, R_PPC_REL16_HI, R_PPC_REL16_HA): Define. 2005-06-14 Alan Modra <amodra@bigpond.net.au> * config.h.in (HAVE_ASM_PPC_REL16): Add. * elf/elf.h (DT_PPC_GOT, DT_PPC_NUM): Define. * elf/tls-macros.h (PowerPC32): Include config.h. Add variants of TLS_IE, TLS_LD and TLS_GD for new PLT/GOT layout. * sysdeps/powerpc/powerpc32/configure.in: New file, * sysdeps/powerpc/powerpc32/dl-dtprocnum.h: New file. * sysdeps/powerpc/powerpc32/dl-machine.h (DT_PPC): Define. (ppc_got): New inline function. (elf_machine_dynamic): Use ppc_got. Add attribute const. (elf_machine_load_address): Add attribute const. Don't use int vars. Use bcl rather than bl to save trashing branch target stack. Use elf_machine_dynamic rather than duplicating code here. (elf_machine_runtime_setup): New inline function replacing define. Handle new PLT. (elf_machine_fixup_plt): Handle new PLT. (elf_machine_rela): Likewise. * sysdeps/powerpc/powerpc32/sysdep.h: Include config.h. (CALL_MCOUNT): Don't set up counter vars. * sysdeps/powerpc/powerpc32/ppc-mcount.S: Correct comment. * sysdeps/powerpc/powerpc32/elf/start.S (start_addressesp): Don't define when HAVE_ASM_PPC_REL16. (_start): Add HAVE_ASM_PPC_REL16 code. * sysdeps/powerpc/powerpc32/dl-start.S (_dl_start_user): Don't bl into the GOT when HAVE_ASM_PPC_REL16. * sysdeps/powerpc/powerpc32/memset.S (memset): Likewise. * sysdeps/powerpc/powerpc32/fpu/__longjmp-common.S (__longjmp): Ditto. * sysdeps/powerpc/powerpc32/fpu/s_ceil.S (__ceil): Likewise. * sysdeps/powerpc/powerpc32/fpu/s_ceilf.S (__ceilf): Likewise. * sysdeps/powerpc/powerpc32/fpu/s_floor.S (__floor): Likewise. * sysdeps/powerpc/powerpc32/fpu/s_floorf.S (__floorf): Likewise. * sysdeps/powerpc/powerpc32/fpu/s_lround.S (__lround): Likewise. * sysdeps/powerpc/powerpc32/fpu/s_rint.S (__rint): Likewise. * sysdeps/powerpc/powerpc32/fpu/s_rintf.S (__rintf): Likewise. * sysdeps/powerpc/powerpc32/fpu/s_round.S (__round): Likewise. * sysdeps/powerpc/powerpc32/fpu/s_roundf.S (__roundf): Likewise. * sysdeps/powerpc/powerpc32/fpu/s_trunc.S (__trunc): Likewise. * sysdeps/powerpc/powerpc32/fpu/s_truncf.S (__truncf): Likewise. * sysdeps/powerpc/powerpc32/fpu/setjmp-common.S (__sigsetjmp): Likewise. * sysdeps/unix/sysv/linux/powerpc/powerpc32/brk.S (__brk): Likewise. * sysdeps/unix/sysv/linux/powerpc/powerpc32/getcontext.S (__getcontext): Likewise. * sysdeps/unix/sysv/linux/powerpc/powerpc32/setcontext.S (__setcontext): Likewise. * sysdeps/unix/sysv/linux/powerpc/powerpc32/swapcontext.S (__swapcontext): Likewise. * sysdeps/unix/sysv/linux/powerpc/powerpc32/socket.S (stackblock): Comment. (__socket): Bomb if NARGS >= 7. Invoke CGOTSETUP and CGOTRESTORE. 2005-06-17 Ulrich Drepper <drepper@redhat.com> * sysdeps/posix/sigignore.c: Include <string.h> to tell the compiler to use __GI_memset. * sysdeps/posix/signal.c: Likewise. * sysdeps/posix/sigset.c: Likewise. * sysdeps/posix/sysv_signal.c: Likewise. * sysdeps/unix/sysv/linux/sleep.c: Likewise. * sysdeps/unix/sysv/linux/sysctl.c: Likewise. * sysdeps/unix/sysv/linux/system.c: Likewise.
		
			
				
	
	
		
			118 lines
		
	
	
		
			2.8 KiB
		
	
	
	
		
			ArmAsm
		
	
	
	
	
	
			
		
		
	
	
			118 lines
		
	
	
		
			2.8 KiB
		
	
	
	
		
			ArmAsm
		
	
	
	
	
	
| /* Copyright (C) 1995, 1996, 1997, 1999, 2003 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-cancel.h>
 | |
| #include <socketcall.h>
 | |
| 
 | |
| #define P(a, b) P2(a, b)
 | |
| #define P2(a, b) a##b
 | |
| 
 | |
| /* The socket-oriented system calls are handled unusally in Linux.
 | |
|    They are all gated through the single `socketcall' system call number.
 | |
|    `socketcall' takes two arguments: the first is the subcode, specifying
 | |
|    which socket function is being called; and the second is a pointer to
 | |
|    the arguments to the specific function.
 | |
| 
 | |
|    The .S files for the other calls just #define socket and #include this.
 | |
|    They also #define a 'number-of-arguments' word in NARGS, which
 | |
|    defaults to 3.  */
 | |
| 
 | |
| #ifndef NARGS
 | |
| #ifdef socket
 | |
| #error NARGS not defined
 | |
| #endif
 | |
| #define NARGS 3
 | |
| #endif
 | |
| 
 | |
| /* 0(r1) and 4(r1) are reserved by the ABI, 8(r1), 12(r1), 16(r1) are used
 | |
|    for temp saves.  44(r1) is used to save r30.  */
 | |
| #define stackblock 20
 | |
| 
 | |
| #ifndef __socket
 | |
| #define __socket P(__,socket)
 | |
| #endif
 | |
| 
 | |
| 	.text
 | |
| ENTRY(__socket)
 | |
| 	cfi_startproc
 | |
| 	stwu r1,-48(r1)
 | |
| 	cfi_adjust_cfa_offset(48)
 | |
| #if NARGS >= 1
 | |
| 	stw  r3,stackblock(r1)
 | |
| #endif
 | |
| #if NARGS >= 2
 | |
| 	stw  r4,4+stackblock(r1)
 | |
| #endif
 | |
| #if NARGS >= 3
 | |
| 	stw  r5,8+stackblock(r1)
 | |
| #endif
 | |
| #if NARGS >= 4
 | |
| 	stw  r6,12+stackblock(r1)
 | |
| #endif
 | |
| #if NARGS >= 5
 | |
| 	stw  r7,16+stackblock(r1)
 | |
| #endif
 | |
| #if NARGS >= 6
 | |
| 	stw  r8,20+stackblock(r1)
 | |
| #endif
 | |
| #if NARGS >= 7
 | |
| #error too many arguments!
 | |
| #endif
 | |
| 
 | |
| #if defined NEED_CANCELLATION && defined CENABLE
 | |
| 	SINGLE_THREAD_P
 | |
| 	bne-	.Lsocket_cancel
 | |
| #endif
 | |
| 
 | |
| 	li	r3,P(SOCKOP_,socket)
 | |
| 	addi	r4,r1,stackblock
 | |
| 	DO_CALL(SYS_ify(socketcall))
 | |
| 	addi	r1,r1,48
 | |
| 	PSEUDO_RET
 | |
| 
 | |
| #if defined NEED_CANCELLATION && defined CENABLE
 | |
| .Lsocket_cancel:
 | |
| 	mflr	r9
 | |
| 	stw	r9,52(r1)
 | |
| 	cfi_offset (lr, 4)
 | |
| 	CGOTSETUP
 | |
| 	CENABLE
 | |
| 	stw	r3,16(r1)
 | |
| 	li	r3,P(SOCKOP_,socket)
 | |
| 	addi	r4,r1,stackblock
 | |
| 	DO_CALL(SYS_ify(socketcall))
 | |
| 	mfcr	r0
 | |
| 	stw	r3,8(r1)
 | |
| 	stw	r0,12(r1)
 | |
| 	lwz	r3,16(r1)
 | |
| 	CDISABLE
 | |
| 	lwz	r4,52(r1)
 | |
| 	lwz	r0,12(r1)
 | |
| 	lwz	r3,8(r1)
 | |
| 	CGOTRESTORE
 | |
| 	mtlr	r4
 | |
| 	mtcr	r0
 | |
| 	addi	r1,r1,48
 | |
| 	PSEUDO_RET
 | |
| #endif
 | |
| 	cfi_endproc
 | |
| 
 | |
| PSEUDO_END (__socket)
 | |
| 
 | |
| weak_alias (__socket, socket)
 |