 5f25b383a8
			
		
	
	
		5f25b383a8
		
	
	
	
	
		
			
			The oldest supported cpu is the microsparc 1; all other cpus use CPU_DEFAULT_FEATURES. Remove the features that must always be present for sparcv7: FLOAT, SWAP, FLUSH, FSQRT, FMUL. Tested-by: Mark Cave-Ayland <mark.cave-ayland@ilande.co.uk> Acked-by: Mark Cave-Ayland <mark.cave-ayland@ilande.co.uk> Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
		
			
				
	
	
		
			58 lines
		
	
	
		
			1.3 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			58 lines
		
	
	
		
			1.3 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| #ifndef SPARC_TARGET_SYSCALL_H
 | |
| #define SPARC_TARGET_SYSCALL_H
 | |
| 
 | |
| #if defined(TARGET_SPARC64) && !defined(TARGET_ABI32)
 | |
| struct target_pt_regs {
 | |
|     abi_ulong u_regs[16];
 | |
|     abi_ulong tstate;
 | |
|     abi_ulong pc;
 | |
|     abi_ulong npc;
 | |
|     uint32_t y;
 | |
|     uint32_t magic;
 | |
| };
 | |
| #else
 | |
| struct target_pt_regs {
 | |
|     abi_ulong psr;
 | |
|     abi_ulong pc;
 | |
|     abi_ulong npc;
 | |
|     abi_ulong y;
 | |
|     abi_ulong u_regs[16];
 | |
| };
 | |
| #endif
 | |
| 
 | |
| #ifdef TARGET_SPARC64
 | |
| # define UNAME_MACHINE "sparc64"
 | |
| #else
 | |
| # define UNAME_MACHINE "sparc"
 | |
| #endif
 | |
| #define UNAME_MINIMUM_RELEASE "2.6.32"
 | |
| 
 | |
| /*
 | |
|  * SPARC kernels don't define this in their Kconfig, but they have the
 | |
|  * same ABI as if they did, implemented by sparc-specific code which fishes
 | |
|  * directly in the u_regs() struct for half the parameters in sparc_do_fork()
 | |
|  * and copy_thread().
 | |
|  */
 | |
| #define TARGET_CLONE_BACKWARDS
 | |
| #define TARGET_MCL_CURRENT 0x2000
 | |
| #define TARGET_MCL_FUTURE  0x4000
 | |
| #define TARGET_MCL_ONFAULT 0x8000
 | |
| 
 | |
| /*
 | |
|  * For SPARC SHMLBA is determined at runtime in the kernel, and
 | |
|  * libc has to runtime-detect it using the hwcaps.
 | |
|  * See glibc sysdeps/unix/sysv/linux/sparc/getshmlba.
 | |
|  */
 | |
| #define TARGET_FORCE_SHMLBA
 | |
| 
 | |
| static inline abi_ulong target_shmlba(CPUSPARCState *env)
 | |
| {
 | |
| #ifdef TARGET_SPARC64
 | |
|     return MAX(TARGET_PAGE_SIZE, 16 * 1024);
 | |
| #else
 | |
|     return 256 * 1024;
 | |
| #endif
 | |
| }
 | |
| 
 | |
| #endif /* SPARC_TARGET_SYSCALL_H */
 |