diff options
| author | Carmelo Amoroso <carmelo.amoroso@st.com> | 2010-01-07 11:55:08 +0100 | 
|---|---|---|
| committer | Carmelo Amoroso <carmelo.amoroso@st.com> | 2010-02-09 07:54:22 +0100 | 
| commit | 828ba271af0e7a61154740646014c5b1d81d8fb9 (patch) | |
| tree | ff54fb8b0dd38fb54576d71ab31be999011cd969 /libc/sysdeps/linux/arm | |
| parent | 70811eeaf66e203f5376cae32b0b0d4cd4024210 (diff) | |
nptl: sysdep headers re-factoring
This patch will re-factor and simplify sysdep headers
handling for nptl branch.
The reason is to use some useful macros in asm code (i.e. ENTRY()) that are available
only into nptl branch because are defined in sysdep.h header under the nptl folder
even if they are not related to NPTL at all (this was likely due to a bad choice done
at the early stage of NPTL porting).
This is a required steps for integrating into master branch some asm code available in
nptl branch for sh4.
The main changes are described below:
nptl/sysdeps/generic/sysdep.h (moved) ---> libc/sysdeps/linux/common/sysdep.h
nptl/sysdeps/arm/sysdep.h     (moved) ---> libc/sysdeps/linux/arm/sysdep.h
nptl/sysdeps/sh/sysdep.h ---------------------|
nptl/sysdeps/unix/sh/sysdep.h ----------------|
nptl/sysdeps/unix/sysv/linux/sh/sysdep.h -----|
nptl/sysdeps/unix/sysv/linux/sh/sh4/sysdep.h -|
                                              |(merged) ---> libc/sysdeps/linux/sh
nptl/sysdeps/unix/sysdep.h (deleted)
Similarly the mips and arm sysdep.h should be merged and updated as for sh arch.
Signed-off-by: Carmelo Amoroso <carmelo.amoroso@st.com>
Diffstat (limited to 'libc/sysdeps/linux/arm')
| -rw-r--r-- | libc/sysdeps/linux/arm/sysdep.h | 91 | 
1 files changed, 91 insertions, 0 deletions
| diff --git a/libc/sysdeps/linux/arm/sysdep.h b/libc/sysdeps/linux/arm/sysdep.h new file mode 100644 index 000000000..3c7a182bb --- /dev/null +++ b/libc/sysdeps/linux/arm/sysdep.h @@ -0,0 +1,91 @@ +/* Assembler macros for ARM. +   Copyright (C) 1997, 1998, 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 <common/sysdep.h> + +#ifdef	__ASSEMBLER__ + +/* Syntactic details of assembler.  */ + +#define ALIGNARG(log2) log2 +/* For ELF we need the `.type' directive to make shared libs work right.  */ +#define ASM_TYPE_DIRECTIVE(name,typearg) .type name,%##typearg; +#define ASM_SIZE_DIRECTIVE(name) .size name,.-name + +/* In ELF C symbols are asm symbols.  */ +#undef	NO_UNDERSCORES +#define NO_UNDERSCORES + +#define PLTJMP(_x)	_x##(PLT) + +/* APCS-32 doesn't preserve the condition codes across function call. */ +#ifdef __APCS_32__ +#define LOADREGS(cond, base, reglist...)\ +	ldm##cond	base,reglist +#ifdef __USE_BX__ +#define RETINSTR(cond, reg)	\ +	bx##cond	reg +#define DO_RET(_reg)		\ +	bx _reg +#else +#define RETINSTR(cond, reg)	\ +	mov##cond	pc, reg +#define DO_RET(_reg)		\ +	mov pc, _reg +#endif +#else  /* APCS-26 */ +#define LOADREGS(cond, base, reglist...)\ +	ldm##cond	base,reglist^ +#define RETINSTR(cond, reg)	\ +	mov##cond##s	pc, reg +#define DO_RET(_reg)		\ +	movs pc, _reg +#endif + +/* Define an entry point visible from C.  */ +#define	ENTRY(name)							      \ +  ASM_GLOBAL_DIRECTIVE C_SYMBOL_NAME(name);				      \ +  ASM_TYPE_DIRECTIVE (C_SYMBOL_NAME(name),function)			      \ +  .align ALIGNARG(4);							      \ +  name##:                                                                     \ +  CALL_MCOUNT + +#undef	END +#define END(name)							      \ +  ASM_SIZE_DIRECTIVE(name) + +/* If compiled for profiling, call `mcount' at the start of each function.  */ +#ifdef	PROF +#define CALL_MCOUNT			\ +	str	lr,[sp, #-4]!	;	\ +	bl	PLTJMP(mcount)	;	\ +	ldr	lr, [sp], #4	; +#else +#define CALL_MCOUNT		/* Do nothing.  */ +#endif + +#ifdef	NO_UNDERSCORES +/* Since C identifiers are not normally prefixed with an underscore +   on this system, the asm identifier `syscall_error' intrudes on the +   C name space.  Make sure we use an innocuous name.  */ +#define	syscall_error	__syscall_error +#define mcount		_mcount +#endif + +#endif	/* __ASSEMBLER__ */ | 
