machine_read_midr(void)
{
#if __arm__
- uint32_t midr = __builtin_arm_mrc(15,0,0,0,0);
+ uint32_t midr = __builtin_arm_mrc(15, 0, 0, 0, 0);
#else
uint64_t midr;
- __asm__ volatile("mrs %0, MIDR_EL1" : "=r" (midr));
+ __asm__ volatile ("mrs %0, MIDR_EL1" : "=r" (midr));
#endif
return (uint32_t)midr;
}
machine_read_clidr(void)
{
#if __arm__
- uint32_t clidr = __builtin_arm_mrc(15,1,0,0,1);
+ uint32_t clidr = __builtin_arm_mrc(15, 1, 0, 0, 1);
#else
uint64_t clidr;
- __asm__ volatile("mrs %0, CLIDR_EL1" : "=r" (clidr));
+ __asm__ volatile ("mrs %0, CLIDR_EL1" : "=r" (clidr));
#endif
return (uint32_t)clidr;
}
machine_read_ccsidr(void)
{
#if __arm__
- uint32_t ccsidr = __builtin_arm_mrc(15,1,0,0,0);
+ uint32_t ccsidr = __builtin_arm_mrc(15, 1, 0, 0, 0);
#else
uint64_t ccsidr;
- __asm__ volatile("mrs %0, CCSIDR_EL1" : "=r" (ccsidr));
+ __asm__ volatile ("mrs %0, CCSIDR_EL1" : "=r" (ccsidr));
#endif
return (uint32_t)ccsidr;
}
machine_read_isa_feat1(void)
{
arm_isa_feat1_reg isa;
- isa.value = __builtin_arm_mrc(15,0,0,2,1);
+ isa.value = __builtin_arm_mrc(15, 0, 0, 2, 1);
return isa;
}
#endif // __arm__
machine_write_csselr(csselr_cache_level level, csselr_cache_type type)
{
#if __arm__
- uint32_t csselr = (level | type);
- __builtin_arm_mcr(15,2,csselr,0,0,0);
+ uint32_t csselr = (uint32_t)level | (uint32_t)type;
+ __builtin_arm_mcr(15, 2, csselr, 0, 0, 0);
#else
- uint64_t csselr = (level | type);
- __asm__ volatile("msr CSSELR_EL1, %0" : : "r" (csselr));
+ uint64_t csselr = (uint64_t)level | (uint64_t)type;
+ __asm__ volatile ("msr CSSELR_EL1, %0" : : "r" (csselr));
#endif
__builtin_arm_isb(ISB_SY);
}
arm_debug_dbgdidr dbgdidr;
/* read CPUID ID_DFR0 */
- id_dfr0.value = __builtin_arm_mrc(15,0,0,1,2);
+ id_dfr0.value = __builtin_arm_mrc(15, 0, 0, 1, 2);
/* read DBGDIDR */
- dbgdidr.value = __builtin_arm_mrc(14,0,0,0,0);
+ dbgdidr.value = __builtin_arm_mrc(14, 0, 0, 0, 0);
cpuid_debug_info.coprocessor_core_debug = id_dfr0.debug_feature.coprocessor_core_debug != 0;
cpuid_debug_info.memory_mapped_core_debug = (id_dfr0.debug_feature.memory_mapped_core_debug != 0)
&& (getCpuDatap()->cpu_debug_interface_map != 0);
if (cpuid_debug_info.coprocessor_core_debug || cpuid_debug_info.memory_mapped_core_debug) {
- cpuid_debug_info.num_watchpoint_pairs = dbgdidr.debug_id.wrps + 1;
- cpuid_debug_info.num_breakpoint_pairs = dbgdidr.debug_id.brps + 1;
+ cpuid_debug_info.num_watchpoint_pairs = dbgdidr.debug_id.wrps + 1;
+ cpuid_debug_info.num_breakpoint_pairs = dbgdidr.debug_id.brps + 1;
}
#else
arm_cpuid_id_aa64dfr0_el1 id_dfr0;
/* read ID_AA64DFR0_EL1 */
- __asm__ volatile("mrs %0, ID_AA64DFR0_EL1" : "=r"(id_dfr0.value));
+ __asm__ volatile ("mrs %0, ID_AA64DFR0_EL1" : "=r"(id_dfr0.value));
if (id_dfr0.debug_feature.debug_arch_version) {
cpuid_debug_info.num_watchpoint_pairs = id_dfr0.debug_feature.wrps + 1;
machine_do_mvfpid()
{
#if __arm__
- arm_mvfr0_info_t arm_mvfr0_info;
- arm_mvfr1_info_t arm_mvfr1_info;
+ arm_mvfr0_info_t arm_mvfr0_info;
+ arm_mvfr1_info_t arm_mvfr1_info;
- __asm__ volatile("vmrs %0, mvfr0":"=r"(arm_mvfr0_info.value));
- __asm__ volatile("vmrs %0, mvfr1":"=r"(arm_mvfr1_info.value));
+ __asm__ volatile ("vmrs %0, mvfr0" :"=r"(arm_mvfr0_info.value));
+ __asm__ volatile ("vmrs %0, mvfr1" :"=r"(arm_mvfr1_info.value));
cpuid_mvfp_info.neon = arm_mvfr1_info.bits.SP;
cpuid_mvfp_info.neon_hpfp = arm_mvfr1_info.bits.HPFP;
#else
cpuid_mvfp_info.neon = 1;
cpuid_mvfp_info.neon_hpfp = 1;
+#if defined(__ARM_ARCH_8_2__)
+ cpuid_mvfp_info.neon_fp16 = 1;
+#endif /* defined(__ARM_ARCH_8_2__) */
#endif /* __arm__ */
-
}
arm_mvfp_info_t *
{
return &cpuid_mvfp_info;
}
-