mirror of
				https://sourceware.org/git/glibc.git
				synced 2025-11-03 20:53:13 +03:00 
			
		
		
		
	2006-01-03 Steven Munroe <sjmunroe@us.ibm.com> * sysdeps/generic/sysdep.h (cfi_same_value): Define macro. * sysdeps/powerpc/powerpc32/dl-trampoline.S (_dl_runtime_resolve, _dl_profile_resolve): Add CFI directives for stack and LR save. Save LR in LRSAVE of previous frame per ABI. * sysdeps/powerpc/powerpc32/fpu/__longjmp-common.S: Add CFI directives for LR save. * sysdeps/powerpc/powerpc32/lshift.S: Likewise. * sysdeps/unix/sysv/linux/powerpc/powerpc32/makecontext.S (__makecontext, __novec_makecontext): Likewise. * sysdeps/powerpc/powerpc32/fpu/s_ceil.S: Add CFI directive for LR save to register. * sysdeps/powerpc/powerpc32/fpu/s_ceilf.S: Likewise. * sysdeps/powerpc/powerpc32/fpu/s_floor.S: Likewise. * sysdeps/powerpc/powerpc32/fpu/s_floorf.S: Likewise. * sysdeps/powerpc/powerpc32/fpu/s_rint.S: Likewise. * sysdeps/powerpc/powerpc32/fpu/s_rintf.S: Likewise. * sysdeps/powerpc/powerpc32/fpu/s_round.S: Likewise. * sysdeps/powerpc/powerpc32/fpu/s_roundf.S: Likewise. * sysdeps/powerpc/powerpc32/fpu/s_trunc.S: Likewise. * sysdeps/powerpc/powerpc32/fpu/s_truncf.S: Likewise. * sysdeps/powerpc/powerpc32/fpu/setjmp-common.S: Likewise. * sysdeps/powerpc/powerpc32/fpu/s_copysign.S: Add CFI directive for stack. * sysdeps/unix/sysv/linux/powerpc/powerpc32/clone.S: Likewise. * sysdeps/powerpc/powerpc32/ppc-mcount.S: Add CFI directives for stack and LR save. * sysdeps/unix/sysv/linux/powerpc/powerpc32/brk.S: Likewise. * sysdeps/unix/sysv/linux/powerpc/powerpc32/getcontext-common.S: Likewise. * sysdeps/unix/sysv/linux/powerpc/powerpc32/setcontext-common.S: Likewise. * sysdeps/unix/sysv/linux/powerpc/powerpc32/swapcontext-common.S: Likewise. * sysdeps/powerpc/powerpc32/fpu/s_lround.S: Likewise. Don't use negative stack addressing. * sysdeps/powerpc/powerpc64/dl-trampoline.S (_dl_runtime_resolve, _dl_profile_resolve): Add CFI directives for stack and LR save. * sysdeps/powerpc/powerpc64/fpu/s_copysign.S: Add CFI directives for stack. * sysdeps/powerpc/powerpc64/ppc-mcount.S (_mcount): Add CFI directives for stack and LR save. * sysdeps/unix/sysv/linux/powerpc/powerpc64/brk.S (__brk): Add CFI directives for stack. * sysdeps/unix/sysv/linux/powerpc/powerpc64/clone.S (__clone): Add CFI directives for stack. * sysdeps/unix/sysv/linux/powerpc/powerpc64/getcontext.S (__getcontext, __novec_getcontext): Add CFI directives for stack and LR save. * sysdeps/unix/sysv/linux/powerpc/powerpc64/makecontext.S (__makecontext): Add CFI directives for stack and LR save. * sysdeps/unix/sysv/linux/powerpc/powerpc64/setcontext.S (__setcontext, __novec_setcontext): Add CFI directives for stack and LR save. * sysdeps/unix/sysv/linux/powerpc/powerpc64/swapcontext.S (__swapcontext, __novec_swapcontext): Add CFI directives for stack and LR save.
		
			
				
	
	
		
			138 lines
		
	
	
		
			4.5 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			138 lines
		
	
	
		
			4.5 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
/* Generic asm macros used on many machines.
 | 
						|
   Copyright (C) 1991,92,93,96,98,2002,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.  */
 | 
						|
 | 
						|
#ifndef C_LABEL
 | 
						|
 | 
						|
/* Define a macro we can use to construct the asm name for a C symbol.  */
 | 
						|
#ifdef	NO_UNDERSCORES
 | 
						|
#ifdef	__STDC__
 | 
						|
#define C_LABEL(name)		name##:
 | 
						|
#else
 | 
						|
#define C_LABEL(name)		name/**/:
 | 
						|
#endif
 | 
						|
#else
 | 
						|
#ifdef	__STDC__
 | 
						|
#define C_LABEL(name)		_##name##:
 | 
						|
#else
 | 
						|
#define C_LABEL(name)		_/**/name/**/:
 | 
						|
#endif
 | 
						|
#endif
 | 
						|
 | 
						|
#endif
 | 
						|
 | 
						|
#ifdef __ASSEMBLER__
 | 
						|
/* Mark the end of function named SYM.  This is used on some platforms
 | 
						|
   to generate correct debugging information.  */
 | 
						|
#ifndef END
 | 
						|
#define END(sym)
 | 
						|
#endif
 | 
						|
 | 
						|
#ifndef JUMPTARGET
 | 
						|
#define JUMPTARGET(sym)		sym
 | 
						|
#endif
 | 
						|
 | 
						|
/* Makros to generate eh_frame unwind information.  */
 | 
						|
# ifdef HAVE_ASM_CFI_DIRECTIVES
 | 
						|
#  define cfi_startproc			.cfi_startproc
 | 
						|
#  define cfi_endproc			.cfi_endproc
 | 
						|
#  define cfi_def_cfa(reg, off)		.cfi_def_cfa reg, off
 | 
						|
#  define cfi_def_cfa_register(reg)	.cfi_def_cfa_register reg
 | 
						|
#  define cfi_def_cfa_offset(off)	.cfi_def_cfa_offset off
 | 
						|
#  define cfi_adjust_cfa_offset(off)	.cfi_adjust_cfa_offset off
 | 
						|
#  define cfi_offset(reg, off)		.cfi_offset reg, off
 | 
						|
#  define cfi_rel_offset(reg, off)	.cfi_rel_offset reg, off
 | 
						|
#  define cfi_register(r1, r2)		.cfi_register r1, r2
 | 
						|
#  define cfi_return_column(reg)	.cfi_return_column reg
 | 
						|
#  define cfi_restore(reg)		.cfi_restore reg
 | 
						|
#  define cfi_same_value(reg)		.cfi_same_value reg
 | 
						|
#  define cfi_undefined(reg)		.cfi_undefined reg
 | 
						|
#  define cfi_remember_state		.cfi_remember_state
 | 
						|
#  define cfi_restore_state		.cfi_restore_state
 | 
						|
#  define cfi_window_save		.cfi_window_save
 | 
						|
# else
 | 
						|
#  define cfi_startproc
 | 
						|
#  define cfi_endproc
 | 
						|
#  define cfi_def_cfa(reg, off)
 | 
						|
#  define cfi_def_cfa_register(reg)
 | 
						|
#  define cfi_def_cfa_offset(off)
 | 
						|
#  define cfi_adjust_cfa_offset(off)
 | 
						|
#  define cfi_offset(reg, off)
 | 
						|
#  define cfi_rel_offset(reg, off)
 | 
						|
#  define cfi_register(r1, r2)
 | 
						|
#  define cfi_return_column(reg)
 | 
						|
#  define cfi_restore(reg)
 | 
						|
#  define cfi_same_value(reg)
 | 
						|
#  define cfi_undefined(reg)
 | 
						|
#  define cfi_remember_state
 | 
						|
#  define cfi_restore_state
 | 
						|
#  define cfi_window_save
 | 
						|
# endif
 | 
						|
 | 
						|
#else /* ! ASSEMBLER */
 | 
						|
# ifdef HAVE_ASM_CFI_DIRECTIVES
 | 
						|
#  define CFI_STRINGIFY(Name) CFI_STRINGIFY2 (Name)
 | 
						|
#  define CFI_STRINGIFY2(Name) #Name
 | 
						|
#  define CFI_STARTPROC	".cfi_startproc"
 | 
						|
#  define CFI_ENDPROC	".cfi_endproc"
 | 
						|
#  define CFI_DEF_CFA(reg, off)	\
 | 
						|
   ".cfi_def_cfa " CFI_STRINGIFY(reg) "," CFI_STRINGIFY(off)
 | 
						|
#  define CFI_DEF_CFA_REGISTER(reg) \
 | 
						|
   ".cfi_def_cfa_register " CFI_STRINGIFY(reg)
 | 
						|
#  define CFI_DEF_CFA_OFFSET(off) \
 | 
						|
   ".cfi_def_cfa_offset " CFI_STRINGIFY(off)
 | 
						|
#  define CFI_ADJUST_CFA_OFFSET(off) \
 | 
						|
   ".cfi_adjust_cfa_offset " CFI_STRINGIFY(off)
 | 
						|
#  define CFI_OFFSET(reg, off) \
 | 
						|
   ".cfi_offset " CFI_STRINGIFY(reg) "," CFI_STRINGIFY(off)
 | 
						|
#  define CFI_REL_OFFSET(reg, off) \
 | 
						|
   ".cfi_rel_offset " CFI_STRINGIFY(reg) "," CFI_STRINGIFY(off)
 | 
						|
#  define CFI_REGISTER(r1, r2) \
 | 
						|
   ".cfi_register " CFI_STRINGIFY(r1) "," CFI_STRINGIFY(r2)
 | 
						|
#  define CFI_RETURN_COLUMN(reg) \
 | 
						|
   ".cfi_return_column " CFI_STRINGIFY(reg)
 | 
						|
#  define CFI_RESTORE(reg) \
 | 
						|
   ".cfi_restore " CFI_STRINGIFY(reg)
 | 
						|
#  define CFI_UNDEFINED(reg) \
 | 
						|
   ".cfi_undefined " CFI_STRINGIFY(reg)
 | 
						|
#  define CFI_REMEMBER_STATE \
 | 
						|
   ".cfi_remember_state"
 | 
						|
#  define CFI_RESTORE_STATE \
 | 
						|
   ".cfi_restore_state"
 | 
						|
#  define CFI_WINDOW_SAVE \
 | 
						|
   ".cfi_window_save"
 | 
						|
# else
 | 
						|
#  define CFI_STARTPROC
 | 
						|
#  define CFI_ENDPROC
 | 
						|
#  define CFI_DEF_CFA(reg, off)
 | 
						|
#  define CFI_DEF_CFA_REGISTER(reg)
 | 
						|
#  define CFI_DEF_CFA_OFFSET(off)
 | 
						|
#  define CFI_ADJUST_CFA_OFFSET(off)
 | 
						|
#  define CFI_OFFSET(reg, off)
 | 
						|
#  define CFI_REL_OFFSET(reg, off)
 | 
						|
#  define CFI_REGISTER(r1, r2)
 | 
						|
#  define CFI_RETURN_COLUMN(reg)
 | 
						|
#  define CFI_RESTORE(reg)
 | 
						|
#  define CFI_UNDEFINED(reg)
 | 
						|
#  define CFI_REMEMBER_STATE
 | 
						|
#  define CFI_RESTORE_STATE
 | 
						|
#  define CFI_WINDOW_SAVE
 | 
						|
# endif
 | 
						|
 | 
						|
#endif /* __ASSEMBLER__ */
 |