diff options
| author | Peter Tyser <ptyser@xes-inc.com> | 2010-04-12 22:28:08 -0500 | 
|---|---|---|
| committer | Wolfgang Denk <wd@denx.de> | 2010-04-13 09:13:12 +0200 | 
| commit | 819833af39a91fa1c1e8252862bbda6f5a602f7b (patch) | |
| tree | d5c9d1628643347ab2b5a8085acfa6f96709fda3 /arch/sparc/include/asm/stack.h | |
| parent | 61f2b38a17f5b21c59f2afe6cf1cbb5f28638cf9 (diff) | |
| download | olio-uboot-2014.01-819833af39a91fa1c1e8252862bbda6f5a602f7b.tar.xz olio-uboot-2014.01-819833af39a91fa1c1e8252862bbda6f5a602f7b.zip | |
Move architecture-specific includes to arch/$ARCH/include/asm
This helps to clean up the include/ directory so that it only contains
non-architecture-specific headers and also matches Linux's directory
layout which many U-Boot developers are already familiar with.
Signed-off-by: Peter Tyser <ptyser@xes-inc.com>
Diffstat (limited to 'arch/sparc/include/asm/stack.h')
| -rw-r--r-- | arch/sparc/include/asm/stack.h | 162 | 
1 files changed, 162 insertions, 0 deletions
| diff --git a/arch/sparc/include/asm/stack.h b/arch/sparc/include/asm/stack.h new file mode 100644 index 000000000..b40a9f355 --- /dev/null +++ b/arch/sparc/include/asm/stack.h @@ -0,0 +1,162 @@ +/* SPARC stack layout Macros and structures, + * mainly taken from BCC (the Bare C compiler for + * SPARC LEON2/3) sources. + * + * (C) Copyright 2007 + * Daniel Hellstrom, Gaisler Research, daniel@gaisler.com. + * + * This program is free software; you can redistribute it and/or + * modify it under the terms of the GNU General Public License as + * published by the Free Software Foundation; either version 2 of + * the License, or (at your option) any later version. + * + * This program 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 General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with this program; if not, write to the Free Software + * Foundation, Inc., 59 Temple Place, Suite 330, Boston, + * MA 02111-1307 USA + * + */ + +#ifndef __SPARC_STACK_H__ +#define __SPARC_STACK_H__ + +#include <asm/ptrace.h> + +#ifndef __ASSEMBLER__ + +#ifdef __cplusplus +extern "C" { +#endif + +#define PT_REGS_SZ   sizeof(struct pt_regs) + +/* A Sparc stack frame */ +	struct sparc_stackframe_regs { +		unsigned long sf_locals[8]; +		unsigned long sf_ins[6]; +		struct sparc_stackframe_regs *sf_fp; +		unsigned long sf_callers_pc; +		char *sf_structptr; +		unsigned long sf_xargs[6]; +		unsigned long sf_xxargs[1]; +	}; +#define SF_REGS_SZ sizeof(struct sparc_stackframe_regs) + +/* A register window */ +	struct sparc_regwindow_regs { +		unsigned long locals[8]; +		unsigned long ins[8]; +	}; +#define RW_REGS_SZ sizeof(struct sparc_regwindow_regs) + +/* A fpu window */ +	struct sparc_fpuwindow_regs { +		unsigned long locals[32]; +		unsigned long fsr; +		unsigned long lastctx; +	}; +#define FW_REGS_SZ sizeof(struct sparc_fpuwindow_regs) + +#ifdef __cplusplus +} +#endif +#else +#define PT_REGS_SZ	0x50	/* 20*4 */ +#define SF_REGS_SZ	0x60	/* 24*4 */ +#define RW_REGS_SZ	0x20	/* 16*4 */ +#define FW_REGS_SZ	0x88	/* 34*4 */ +#endif				/* !ASM */ + +/* These are for pt_regs. */ +#define PT_PSR		0x0 +#define PT_PC		0x4 +#define PT_NPC		0x8 +#define PT_Y		0xc +#define PT_G0		0x10 +#define PT_WIM		PT_G0 +#define PT_G1		0x14 +#define PT_G2		0x18 +#define PT_G3		0x1c +#define PT_G4		0x20 +#define PT_G5		0x24 +#define PT_G6		0x28 +#define PT_G7		0x2c +#define PT_I0		0x30 +#define PT_I1		0x34 +#define PT_I2		0x38 +#define PT_I3		0x3c +#define PT_I4		0x40 +#define PT_I5		0x44 +#define PT_I6		0x48 +#define PT_FP		PT_I6 +#define PT_I7		0x4c + +/* Stack_frame offsets */ +#define SF_L0		0x00 +#define SF_L1		0x04 +#define SF_L2		0x08 +#define SF_L3		0x0c +#define SF_L4		0x10 +#define SF_L5		0x14 +#define SF_L6		0x18 +#define SF_L7		0x1c +#define SF_I0		0x20 +#define SF_I1		0x24 +#define SF_I2		0x28 +#define SF_I3		0x2c +#define SF_I4		0x30 +#define SF_I5		0x34 +#define SF_FP		0x38 +#define SF_PC		0x3c +#define SF_RETP		0x40 +#define SF_XARG0	0x44 +#define	SF_XARG1	0x48 +#define	SF_XARG2	0x4c +#define	SF_XARG3	0x50 +#define	SF_XARG4	0x54 +#define	SF_XARG5	0x58 +#define	SF_XXARG	0x5c + +/* Reg_window offsets */ +#define RW_L0		0x00 +#define RW_L1		0x04 +#define RW_L2		0x08 +#define RW_L3		0x0c +#define RW_L4		0x10 +#define RW_L5		0x14 +#define RW_L6		0x18 +#define RW_L7		0x1c +#define RW_I0		0x20 +#define RW_I1		0x24 +#define RW_I2		0x28 +#define RW_I3		0x2c +#define RW_I4		0x30 +#define RW_I5		0x34 +#define RW_I6		0x38 +#define RW_I7		0x3c + +/* Fpu_window offsets */ +#define FW_F0		0x00 +#define FW_F2		0x08 +#define FW_F4		0x10 +#define FW_F6		0x18 +#define FW_F8		0x20 +#define FW_F10		0x28 +#define FW_F12		0x30 +#define FW_F14		0x38 +#define FW_F16		0x40 +#define FW_F18		0x48 +#define FW_F20		0x50 +#define FW_F22		0x58 +#define FW_F24		0x60 +#define FW_F26		0x68 +#define FW_F28		0x70 +#define FW_F30		0x78 +#define FW_FSR		0x80 + +#endif |