linux-user: Add HWCAP for SH4
Only exposing FPU and LLSC as the only features supported by the translator. Signed-off-by: Richard Henderson <rth@twiddle.net> Signed-off-by: Aurelien Jarno <aurelien@aurel32.net>
This commit is contained in:
parent
91c45a38f2
commit
e42fd944f0
@ -1075,6 +1075,35 @@ static inline void elf_core_copy_regs(target_elf_gregset_t *regs,
|
|||||||
#define USE_ELF_CORE_DUMP
|
#define USE_ELF_CORE_DUMP
|
||||||
#define ELF_EXEC_PAGESIZE 4096
|
#define ELF_EXEC_PAGESIZE 4096
|
||||||
|
|
||||||
|
enum {
|
||||||
|
SH_CPU_HAS_FPU = 0x0001, /* Hardware FPU support */
|
||||||
|
SH_CPU_HAS_P2_FLUSH_BUG = 0x0002, /* Need to flush the cache in P2 area */
|
||||||
|
SH_CPU_HAS_MMU_PAGE_ASSOC = 0x0004, /* SH3: TLB way selection bit support */
|
||||||
|
SH_CPU_HAS_DSP = 0x0008, /* SH-DSP: DSP support */
|
||||||
|
SH_CPU_HAS_PERF_COUNTER = 0x0010, /* Hardware performance counters */
|
||||||
|
SH_CPU_HAS_PTEA = 0x0020, /* PTEA register */
|
||||||
|
SH_CPU_HAS_LLSC = 0x0040, /* movli.l/movco.l */
|
||||||
|
SH_CPU_HAS_L2_CACHE = 0x0080, /* Secondary cache / URAM */
|
||||||
|
SH_CPU_HAS_OP32 = 0x0100, /* 32-bit instruction support */
|
||||||
|
SH_CPU_HAS_PTEAEX = 0x0200, /* PTE ASID Extension support */
|
||||||
|
};
|
||||||
|
|
||||||
|
#define ELF_HWCAP get_elf_hwcap()
|
||||||
|
|
||||||
|
static uint32_t get_elf_hwcap(void)
|
||||||
|
{
|
||||||
|
SuperHCPU *cpu = SUPERH_CPU(thread_cpu);
|
||||||
|
uint32_t hwcap = 0;
|
||||||
|
|
||||||
|
hwcap |= SH_CPU_HAS_FPU;
|
||||||
|
|
||||||
|
if (cpu->env.features & SH_FEATURE_SH4A) {
|
||||||
|
hwcap |= SH_CPU_HAS_LLSC;
|
||||||
|
}
|
||||||
|
|
||||||
|
return hwcap;
|
||||||
|
}
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef TARGET_CRIS
|
#ifdef TARGET_CRIS
|
||||||
|
Loading…
x
Reference in New Issue
Block a user