 5836c3ecce
			
		
	
	
		5836c3ecce
		
			
		
	
	
	
	
		
			
			This change checks elf_flags for EF_RISCV_RVE and if present uses the RVE linux syscall ABI which uses t0 for the syscall number instead of a7. Warn and exit if a non-RVE ABI binary is run on a cpu with the RVE extension as it is incompatible. Cc: Palmer Dabbelt <palmer@sifive.com> Cc: Sagar Karandikar <sagark@eecs.berkeley.edu> Cc: Bastian Koppelmann <kbastian@mail.uni-paderborn.de> Cc: Alistair Francis <Alistair.Francis@wdc.com> Co-authored-by: Kito Cheng <kito.cheng@gmail.com> Co-authored-by: Michael Clark <mjc@sifive.com> Signed-off-by: Michael Clark <mjc@sifive.com> Signed-off-by: Alistair Francis <alistair.francis@wdc.com> Signed-off-by: Palmer Dabbelt <palmer@sifive.com>
		
			
				
	
	
		
			15 lines
		
	
	
		
			411 B
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			15 lines
		
	
	
		
			411 B
		
	
	
	
		
			C
		
	
	
	
	
	
| #define xRA 1   /* return address (aka link register) */
 | |
| #define xSP 2   /* stack pointer */
 | |
| #define xGP 3   /* global pointer */
 | |
| #define xTP 4   /* thread pointer */
 | |
| 
 | |
| #define xA0 10  /* gpr[10-17] are syscall arguments */
 | |
| #define xA1 11
 | |
| #define xA2 12
 | |
| #define xA3 13
 | |
| #define xA4 14
 | |
| #define xA5 15
 | |
| #define xA6 16
 | |
| #define xA7 17  /* syscall number for RVI ABI */
 | |
| #define xT0 5   /* syscall number for RVE ABI */
 |