linux-user: implement HWCAP bits on MIPS
Add support for the two currently defined HWCAP bits on MIPS - R6 and MSA. Buglink: https://bugs.launchpad.net/qemu/+bug/1754372 Signed-off-by: James Cowgill <james.cowgill@mips.com> Reviewed-by: Laurent Vivier <laurent@vivier.eu> Message-Id: <20180315151348.6451-1-james.cowgill@mips.com> Signed-off-by: Laurent Vivier <laurent@vivier.eu>
This commit is contained in:
		
				
					committed by
					
						
						Laurent Vivier
					
				
			
			
				
	
			
			
			
						parent
						
							947aeab311
						
					
				
				
					commit
					46a1ee4f39
				
			@@ -882,6 +882,30 @@ static void elf_core_copy_regs(target_elf_gregset_t *regs, const CPUMIPSState *e
 | 
			
		||||
#define USE_ELF_CORE_DUMP
 | 
			
		||||
#define ELF_EXEC_PAGESIZE        4096
 | 
			
		||||
 | 
			
		||||
/* See arch/mips/include/uapi/asm/hwcap.h.  */
 | 
			
		||||
enum {
 | 
			
		||||
    HWCAP_MIPS_R6           = (1 << 0),
 | 
			
		||||
    HWCAP_MIPS_MSA          = (1 << 1),
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
#define ELF_HWCAP get_elf_hwcap()
 | 
			
		||||
 | 
			
		||||
static uint32_t get_elf_hwcap(void)
 | 
			
		||||
{
 | 
			
		||||
    MIPSCPU *cpu = MIPS_CPU(thread_cpu);
 | 
			
		||||
    uint32_t hwcaps = 0;
 | 
			
		||||
 | 
			
		||||
#define GET_FEATURE(flag, hwcap) \
 | 
			
		||||
    do { if (cpu->env.insn_flags & (flag)) { hwcaps |= hwcap; } } while (0)
 | 
			
		||||
 | 
			
		||||
    GET_FEATURE(ISA_MIPS32R6 | ISA_MIPS64R6, HWCAP_MIPS_R6);
 | 
			
		||||
    GET_FEATURE(ASE_MSA, HWCAP_MIPS_MSA);
 | 
			
		||||
 | 
			
		||||
#undef GET_FEATURE
 | 
			
		||||
 | 
			
		||||
    return hwcaps;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
#endif /* TARGET_MIPS */
 | 
			
		||||
 | 
			
		||||
#ifdef TARGET_MICROBLAZE
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user