target/arm: Remove ARM_FEATURE_VFP*
We have converted all tests against these features to ISAR tests. Reviewed-by: Peter Maydell <peter.maydell@linaro.org> Signed-off-by: Richard Henderson <richard.henderson@linaro.org> Message-id: 20200224222232.13807-15-richard.henderson@linaro.org Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
This commit is contained in:
parent
bfa8a370d2
commit
f9506e162c
@ -1208,13 +1208,6 @@ void arm_cpu_post_init(Object *obj)
|
|||||||
if (arm_feature(&cpu->env, ARM_FEATURE_M)) {
|
if (arm_feature(&cpu->env, ARM_FEATURE_M)) {
|
||||||
set_feature(&cpu->env, ARM_FEATURE_PMSA);
|
set_feature(&cpu->env, ARM_FEATURE_PMSA);
|
||||||
}
|
}
|
||||||
/* Similarly for the VFP feature bits */
|
|
||||||
if (arm_feature(&cpu->env, ARM_FEATURE_VFP4)) {
|
|
||||||
set_feature(&cpu->env, ARM_FEATURE_VFP3);
|
|
||||||
}
|
|
||||||
if (arm_feature(&cpu->env, ARM_FEATURE_VFP3)) {
|
|
||||||
set_feature(&cpu->env, ARM_FEATURE_VFP);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (arm_feature(&cpu->env, ARM_FEATURE_CBAR) ||
|
if (arm_feature(&cpu->env, ARM_FEATURE_CBAR) ||
|
||||||
arm_feature(&cpu->env, ARM_FEATURE_CBAR_RO)) {
|
arm_feature(&cpu->env, ARM_FEATURE_CBAR_RO)) {
|
||||||
@ -1442,10 +1435,6 @@ static void arm_cpu_realizefn(DeviceState *dev, Error **errp)
|
|||||||
uint64_t t;
|
uint64_t t;
|
||||||
uint32_t u;
|
uint32_t u;
|
||||||
|
|
||||||
unset_feature(env, ARM_FEATURE_VFP);
|
|
||||||
unset_feature(env, ARM_FEATURE_VFP3);
|
|
||||||
unset_feature(env, ARM_FEATURE_VFP4);
|
|
||||||
|
|
||||||
t = cpu->isar.id_aa64isar1;
|
t = cpu->isar.id_aa64isar1;
|
||||||
t = FIELD_DP64(t, ID_AA64ISAR1, JSCVT, 0);
|
t = FIELD_DP64(t, ID_AA64ISAR1, JSCVT, 0);
|
||||||
cpu->isar.id_aa64isar1 = t;
|
cpu->isar.id_aa64isar1 = t;
|
||||||
@ -1865,7 +1854,6 @@ static void arm926_initfn(Object *obj)
|
|||||||
|
|
||||||
cpu->dtb_compatible = "arm,arm926";
|
cpu->dtb_compatible = "arm,arm926";
|
||||||
set_feature(&cpu->env, ARM_FEATURE_V5);
|
set_feature(&cpu->env, ARM_FEATURE_V5);
|
||||||
set_feature(&cpu->env, ARM_FEATURE_VFP);
|
|
||||||
set_feature(&cpu->env, ARM_FEATURE_DUMMY_C15_REGS);
|
set_feature(&cpu->env, ARM_FEATURE_DUMMY_C15_REGS);
|
||||||
set_feature(&cpu->env, ARM_FEATURE_CACHE_TEST_CLEAN);
|
set_feature(&cpu->env, ARM_FEATURE_CACHE_TEST_CLEAN);
|
||||||
cpu->midr = 0x41069265;
|
cpu->midr = 0x41069265;
|
||||||
@ -1906,7 +1894,6 @@ static void arm1026_initfn(Object *obj)
|
|||||||
|
|
||||||
cpu->dtb_compatible = "arm,arm1026";
|
cpu->dtb_compatible = "arm,arm1026";
|
||||||
set_feature(&cpu->env, ARM_FEATURE_V5);
|
set_feature(&cpu->env, ARM_FEATURE_V5);
|
||||||
set_feature(&cpu->env, ARM_FEATURE_VFP);
|
|
||||||
set_feature(&cpu->env, ARM_FEATURE_AUXCR);
|
set_feature(&cpu->env, ARM_FEATURE_AUXCR);
|
||||||
set_feature(&cpu->env, ARM_FEATURE_DUMMY_C15_REGS);
|
set_feature(&cpu->env, ARM_FEATURE_DUMMY_C15_REGS);
|
||||||
set_feature(&cpu->env, ARM_FEATURE_CACHE_TEST_CLEAN);
|
set_feature(&cpu->env, ARM_FEATURE_CACHE_TEST_CLEAN);
|
||||||
@ -1954,7 +1941,6 @@ static void arm1136_r2_initfn(Object *obj)
|
|||||||
|
|
||||||
cpu->dtb_compatible = "arm,arm1136";
|
cpu->dtb_compatible = "arm,arm1136";
|
||||||
set_feature(&cpu->env, ARM_FEATURE_V6);
|
set_feature(&cpu->env, ARM_FEATURE_V6);
|
||||||
set_feature(&cpu->env, ARM_FEATURE_VFP);
|
|
||||||
set_feature(&cpu->env, ARM_FEATURE_DUMMY_C15_REGS);
|
set_feature(&cpu->env, ARM_FEATURE_DUMMY_C15_REGS);
|
||||||
set_feature(&cpu->env, ARM_FEATURE_CACHE_DIRTY_REG);
|
set_feature(&cpu->env, ARM_FEATURE_CACHE_DIRTY_REG);
|
||||||
set_feature(&cpu->env, ARM_FEATURE_CACHE_BLOCK_OPS);
|
set_feature(&cpu->env, ARM_FEATURE_CACHE_BLOCK_OPS);
|
||||||
@ -1986,7 +1972,6 @@ static void arm1136_initfn(Object *obj)
|
|||||||
cpu->dtb_compatible = "arm,arm1136";
|
cpu->dtb_compatible = "arm,arm1136";
|
||||||
set_feature(&cpu->env, ARM_FEATURE_V6K);
|
set_feature(&cpu->env, ARM_FEATURE_V6K);
|
||||||
set_feature(&cpu->env, ARM_FEATURE_V6);
|
set_feature(&cpu->env, ARM_FEATURE_V6);
|
||||||
set_feature(&cpu->env, ARM_FEATURE_VFP);
|
|
||||||
set_feature(&cpu->env, ARM_FEATURE_DUMMY_C15_REGS);
|
set_feature(&cpu->env, ARM_FEATURE_DUMMY_C15_REGS);
|
||||||
set_feature(&cpu->env, ARM_FEATURE_CACHE_DIRTY_REG);
|
set_feature(&cpu->env, ARM_FEATURE_CACHE_DIRTY_REG);
|
||||||
set_feature(&cpu->env, ARM_FEATURE_CACHE_BLOCK_OPS);
|
set_feature(&cpu->env, ARM_FEATURE_CACHE_BLOCK_OPS);
|
||||||
@ -2017,7 +2002,6 @@ static void arm1176_initfn(Object *obj)
|
|||||||
|
|
||||||
cpu->dtb_compatible = "arm,arm1176";
|
cpu->dtb_compatible = "arm,arm1176";
|
||||||
set_feature(&cpu->env, ARM_FEATURE_V6K);
|
set_feature(&cpu->env, ARM_FEATURE_V6K);
|
||||||
set_feature(&cpu->env, ARM_FEATURE_VFP);
|
|
||||||
set_feature(&cpu->env, ARM_FEATURE_VAPA);
|
set_feature(&cpu->env, ARM_FEATURE_VAPA);
|
||||||
set_feature(&cpu->env, ARM_FEATURE_DUMMY_C15_REGS);
|
set_feature(&cpu->env, ARM_FEATURE_DUMMY_C15_REGS);
|
||||||
set_feature(&cpu->env, ARM_FEATURE_CACHE_DIRTY_REG);
|
set_feature(&cpu->env, ARM_FEATURE_CACHE_DIRTY_REG);
|
||||||
@ -2050,7 +2034,6 @@ static void arm11mpcore_initfn(Object *obj)
|
|||||||
|
|
||||||
cpu->dtb_compatible = "arm,arm11mpcore";
|
cpu->dtb_compatible = "arm,arm11mpcore";
|
||||||
set_feature(&cpu->env, ARM_FEATURE_V6K);
|
set_feature(&cpu->env, ARM_FEATURE_V6K);
|
||||||
set_feature(&cpu->env, ARM_FEATURE_VFP);
|
|
||||||
set_feature(&cpu->env, ARM_FEATURE_VAPA);
|
set_feature(&cpu->env, ARM_FEATURE_VAPA);
|
||||||
set_feature(&cpu->env, ARM_FEATURE_MPIDR);
|
set_feature(&cpu->env, ARM_FEATURE_MPIDR);
|
||||||
set_feature(&cpu->env, ARM_FEATURE_DUMMY_C15_REGS);
|
set_feature(&cpu->env, ARM_FEATURE_DUMMY_C15_REGS);
|
||||||
@ -2116,7 +2099,6 @@ static void cortex_m4_initfn(Object *obj)
|
|||||||
set_feature(&cpu->env, ARM_FEATURE_M);
|
set_feature(&cpu->env, ARM_FEATURE_M);
|
||||||
set_feature(&cpu->env, ARM_FEATURE_M_MAIN);
|
set_feature(&cpu->env, ARM_FEATURE_M_MAIN);
|
||||||
set_feature(&cpu->env, ARM_FEATURE_THUMB_DSP);
|
set_feature(&cpu->env, ARM_FEATURE_THUMB_DSP);
|
||||||
set_feature(&cpu->env, ARM_FEATURE_VFP4);
|
|
||||||
cpu->midr = 0x410fc240; /* r0p0 */
|
cpu->midr = 0x410fc240; /* r0p0 */
|
||||||
cpu->pmsav7_dregion = 8;
|
cpu->pmsav7_dregion = 8;
|
||||||
cpu->isar.mvfr0 = 0x10110021;
|
cpu->isar.mvfr0 = 0x10110021;
|
||||||
@ -2147,7 +2129,6 @@ static void cortex_m7_initfn(Object *obj)
|
|||||||
set_feature(&cpu->env, ARM_FEATURE_M);
|
set_feature(&cpu->env, ARM_FEATURE_M);
|
||||||
set_feature(&cpu->env, ARM_FEATURE_M_MAIN);
|
set_feature(&cpu->env, ARM_FEATURE_M_MAIN);
|
||||||
set_feature(&cpu->env, ARM_FEATURE_THUMB_DSP);
|
set_feature(&cpu->env, ARM_FEATURE_THUMB_DSP);
|
||||||
set_feature(&cpu->env, ARM_FEATURE_VFP4);
|
|
||||||
cpu->midr = 0x411fc272; /* r1p2 */
|
cpu->midr = 0x411fc272; /* r1p2 */
|
||||||
cpu->pmsav7_dregion = 8;
|
cpu->pmsav7_dregion = 8;
|
||||||
cpu->isar.mvfr0 = 0x10110221;
|
cpu->isar.mvfr0 = 0x10110221;
|
||||||
@ -2179,7 +2160,6 @@ static void cortex_m33_initfn(Object *obj)
|
|||||||
set_feature(&cpu->env, ARM_FEATURE_M_MAIN);
|
set_feature(&cpu->env, ARM_FEATURE_M_MAIN);
|
||||||
set_feature(&cpu->env, ARM_FEATURE_M_SECURITY);
|
set_feature(&cpu->env, ARM_FEATURE_M_SECURITY);
|
||||||
set_feature(&cpu->env, ARM_FEATURE_THUMB_DSP);
|
set_feature(&cpu->env, ARM_FEATURE_THUMB_DSP);
|
||||||
set_feature(&cpu->env, ARM_FEATURE_VFP4);
|
|
||||||
cpu->midr = 0x410fd213; /* r0p3 */
|
cpu->midr = 0x410fd213; /* r0p3 */
|
||||||
cpu->pmsav7_dregion = 16;
|
cpu->pmsav7_dregion = 16;
|
||||||
cpu->sau_sregion = 8;
|
cpu->sau_sregion = 8;
|
||||||
@ -2263,7 +2243,6 @@ static void cortex_r5f_initfn(Object *obj)
|
|||||||
ARMCPU *cpu = ARM_CPU(obj);
|
ARMCPU *cpu = ARM_CPU(obj);
|
||||||
|
|
||||||
cortex_r5_initfn(obj);
|
cortex_r5_initfn(obj);
|
||||||
set_feature(&cpu->env, ARM_FEATURE_VFP3);
|
|
||||||
cpu->isar.mvfr0 = 0x10110221;
|
cpu->isar.mvfr0 = 0x10110221;
|
||||||
cpu->isar.mvfr1 = 0x00000011;
|
cpu->isar.mvfr1 = 0x00000011;
|
||||||
}
|
}
|
||||||
@ -2282,7 +2261,6 @@ static void cortex_a8_initfn(Object *obj)
|
|||||||
|
|
||||||
cpu->dtb_compatible = "arm,cortex-a8";
|
cpu->dtb_compatible = "arm,cortex-a8";
|
||||||
set_feature(&cpu->env, ARM_FEATURE_V7);
|
set_feature(&cpu->env, ARM_FEATURE_V7);
|
||||||
set_feature(&cpu->env, ARM_FEATURE_VFP3);
|
|
||||||
set_feature(&cpu->env, ARM_FEATURE_NEON);
|
set_feature(&cpu->env, ARM_FEATURE_NEON);
|
||||||
set_feature(&cpu->env, ARM_FEATURE_THUMB2EE);
|
set_feature(&cpu->env, ARM_FEATURE_THUMB2EE);
|
||||||
set_feature(&cpu->env, ARM_FEATURE_DUMMY_C15_REGS);
|
set_feature(&cpu->env, ARM_FEATURE_DUMMY_C15_REGS);
|
||||||
@ -2350,7 +2328,6 @@ static void cortex_a9_initfn(Object *obj)
|
|||||||
|
|
||||||
cpu->dtb_compatible = "arm,cortex-a9";
|
cpu->dtb_compatible = "arm,cortex-a9";
|
||||||
set_feature(&cpu->env, ARM_FEATURE_V7);
|
set_feature(&cpu->env, ARM_FEATURE_V7);
|
||||||
set_feature(&cpu->env, ARM_FEATURE_VFP3);
|
|
||||||
set_feature(&cpu->env, ARM_FEATURE_NEON);
|
set_feature(&cpu->env, ARM_FEATURE_NEON);
|
||||||
set_feature(&cpu->env, ARM_FEATURE_THUMB2EE);
|
set_feature(&cpu->env, ARM_FEATURE_THUMB2EE);
|
||||||
set_feature(&cpu->env, ARM_FEATURE_EL3);
|
set_feature(&cpu->env, ARM_FEATURE_EL3);
|
||||||
@ -2415,7 +2392,6 @@ static void cortex_a7_initfn(Object *obj)
|
|||||||
|
|
||||||
cpu->dtb_compatible = "arm,cortex-a7";
|
cpu->dtb_compatible = "arm,cortex-a7";
|
||||||
set_feature(&cpu->env, ARM_FEATURE_V7VE);
|
set_feature(&cpu->env, ARM_FEATURE_V7VE);
|
||||||
set_feature(&cpu->env, ARM_FEATURE_VFP4);
|
|
||||||
set_feature(&cpu->env, ARM_FEATURE_NEON);
|
set_feature(&cpu->env, ARM_FEATURE_NEON);
|
||||||
set_feature(&cpu->env, ARM_FEATURE_THUMB2EE);
|
set_feature(&cpu->env, ARM_FEATURE_THUMB2EE);
|
||||||
set_feature(&cpu->env, ARM_FEATURE_GENERIC_TIMER);
|
set_feature(&cpu->env, ARM_FEATURE_GENERIC_TIMER);
|
||||||
@ -2461,7 +2437,6 @@ static void cortex_a15_initfn(Object *obj)
|
|||||||
|
|
||||||
cpu->dtb_compatible = "arm,cortex-a15";
|
cpu->dtb_compatible = "arm,cortex-a15";
|
||||||
set_feature(&cpu->env, ARM_FEATURE_V7VE);
|
set_feature(&cpu->env, ARM_FEATURE_V7VE);
|
||||||
set_feature(&cpu->env, ARM_FEATURE_VFP4);
|
|
||||||
set_feature(&cpu->env, ARM_FEATURE_NEON);
|
set_feature(&cpu->env, ARM_FEATURE_NEON);
|
||||||
set_feature(&cpu->env, ARM_FEATURE_THUMB2EE);
|
set_feature(&cpu->env, ARM_FEATURE_THUMB2EE);
|
||||||
set_feature(&cpu->env, ARM_FEATURE_GENERIC_TIMER);
|
set_feature(&cpu->env, ARM_FEATURE_GENERIC_TIMER);
|
||||||
|
@ -1880,7 +1880,6 @@ QEMU_BUILD_BUG_ON(ARRAY_SIZE(((ARMCPU *)0)->ccsidr) <= R_V7M_CSSELR_INDEX_MASK);
|
|||||||
* mapping in linux-user/elfload.c:get_elf_hwcap().
|
* mapping in linux-user/elfload.c:get_elf_hwcap().
|
||||||
*/
|
*/
|
||||||
enum arm_features {
|
enum arm_features {
|
||||||
ARM_FEATURE_VFP,
|
|
||||||
ARM_FEATURE_AUXCR, /* ARM1026 Auxiliary control register. */
|
ARM_FEATURE_AUXCR, /* ARM1026 Auxiliary control register. */
|
||||||
ARM_FEATURE_XSCALE, /* Intel XScale extensions. */
|
ARM_FEATURE_XSCALE, /* Intel XScale extensions. */
|
||||||
ARM_FEATURE_IWMMXT, /* Intel iwMMXt extension. */
|
ARM_FEATURE_IWMMXT, /* Intel iwMMXt extension. */
|
||||||
@ -1889,7 +1888,6 @@ enum arm_features {
|
|||||||
ARM_FEATURE_V7,
|
ARM_FEATURE_V7,
|
||||||
ARM_FEATURE_THUMB2,
|
ARM_FEATURE_THUMB2,
|
||||||
ARM_FEATURE_PMSA, /* no MMU; may have Memory Protection Unit */
|
ARM_FEATURE_PMSA, /* no MMU; may have Memory Protection Unit */
|
||||||
ARM_FEATURE_VFP3,
|
|
||||||
ARM_FEATURE_NEON,
|
ARM_FEATURE_NEON,
|
||||||
ARM_FEATURE_M, /* Microcontroller profile. */
|
ARM_FEATURE_M, /* Microcontroller profile. */
|
||||||
ARM_FEATURE_OMAPCP, /* OMAP specific CP15 ops handling. */
|
ARM_FEATURE_OMAPCP, /* OMAP specific CP15 ops handling. */
|
||||||
@ -1900,7 +1898,6 @@ enum arm_features {
|
|||||||
ARM_FEATURE_V5,
|
ARM_FEATURE_V5,
|
||||||
ARM_FEATURE_STRONGARM,
|
ARM_FEATURE_STRONGARM,
|
||||||
ARM_FEATURE_VAPA, /* cp15 VA to PA lookups */
|
ARM_FEATURE_VAPA, /* cp15 VA to PA lookups */
|
||||||
ARM_FEATURE_VFP4, /* VFPv4 (implies that NEON is v2) */
|
|
||||||
ARM_FEATURE_GENERIC_TIMER,
|
ARM_FEATURE_GENERIC_TIMER,
|
||||||
ARM_FEATURE_MVFR, /* Media and VFP Feature Registers 0 and 1 */
|
ARM_FEATURE_MVFR, /* Media and VFP Feature Registers 0 and 1 */
|
||||||
ARM_FEATURE_DUMMY_C15_REGS, /* RAZ/WI all of cp15 crn=15 */
|
ARM_FEATURE_DUMMY_C15_REGS, /* RAZ/WI all of cp15 crn=15 */
|
||||||
|
@ -102,7 +102,6 @@ static void aarch64_a57_initfn(Object *obj)
|
|||||||
|
|
||||||
cpu->dtb_compatible = "arm,cortex-a57";
|
cpu->dtb_compatible = "arm,cortex-a57";
|
||||||
set_feature(&cpu->env, ARM_FEATURE_V8);
|
set_feature(&cpu->env, ARM_FEATURE_V8);
|
||||||
set_feature(&cpu->env, ARM_FEATURE_VFP4);
|
|
||||||
set_feature(&cpu->env, ARM_FEATURE_NEON);
|
set_feature(&cpu->env, ARM_FEATURE_NEON);
|
||||||
set_feature(&cpu->env, ARM_FEATURE_GENERIC_TIMER);
|
set_feature(&cpu->env, ARM_FEATURE_GENERIC_TIMER);
|
||||||
set_feature(&cpu->env, ARM_FEATURE_AARCH64);
|
set_feature(&cpu->env, ARM_FEATURE_AARCH64);
|
||||||
@ -156,7 +155,6 @@ static void aarch64_a53_initfn(Object *obj)
|
|||||||
|
|
||||||
cpu->dtb_compatible = "arm,cortex-a53";
|
cpu->dtb_compatible = "arm,cortex-a53";
|
||||||
set_feature(&cpu->env, ARM_FEATURE_V8);
|
set_feature(&cpu->env, ARM_FEATURE_V8);
|
||||||
set_feature(&cpu->env, ARM_FEATURE_VFP4);
|
|
||||||
set_feature(&cpu->env, ARM_FEATURE_NEON);
|
set_feature(&cpu->env, ARM_FEATURE_NEON);
|
||||||
set_feature(&cpu->env, ARM_FEATURE_GENERIC_TIMER);
|
set_feature(&cpu->env, ARM_FEATURE_GENERIC_TIMER);
|
||||||
set_feature(&cpu->env, ARM_FEATURE_AARCH64);
|
set_feature(&cpu->env, ARM_FEATURE_AARCH64);
|
||||||
@ -210,7 +208,6 @@ static void aarch64_a72_initfn(Object *obj)
|
|||||||
|
|
||||||
cpu->dtb_compatible = "arm,cortex-a72";
|
cpu->dtb_compatible = "arm,cortex-a72";
|
||||||
set_feature(&cpu->env, ARM_FEATURE_V8);
|
set_feature(&cpu->env, ARM_FEATURE_V8);
|
||||||
set_feature(&cpu->env, ARM_FEATURE_VFP4);
|
|
||||||
set_feature(&cpu->env, ARM_FEATURE_NEON);
|
set_feature(&cpu->env, ARM_FEATURE_NEON);
|
||||||
set_feature(&cpu->env, ARM_FEATURE_GENERIC_TIMER);
|
set_feature(&cpu->env, ARM_FEATURE_GENERIC_TIMER);
|
||||||
set_feature(&cpu->env, ARM_FEATURE_AARCH64);
|
set_feature(&cpu->env, ARM_FEATURE_AARCH64);
|
||||||
|
@ -147,7 +147,6 @@ bool kvm_arm_get_host_cpu_features(ARMHostCPUFeatures *ahcf)
|
|||||||
* bits, but a few must be tested.
|
* bits, but a few must be tested.
|
||||||
*/
|
*/
|
||||||
set_feature(&features, ARM_FEATURE_V7VE);
|
set_feature(&features, ARM_FEATURE_V7VE);
|
||||||
set_feature(&features, ARM_FEATURE_VFP3);
|
|
||||||
set_feature(&features, ARM_FEATURE_GENERIC_TIMER);
|
set_feature(&features, ARM_FEATURE_GENERIC_TIMER);
|
||||||
|
|
||||||
if (extract32(id_pfr0, 12, 4) == 1) {
|
if (extract32(id_pfr0, 12, 4) == 1) {
|
||||||
@ -156,10 +155,6 @@ bool kvm_arm_get_host_cpu_features(ARMHostCPUFeatures *ahcf)
|
|||||||
if (extract32(ahcf->isar.mvfr1, 12, 4) == 1) {
|
if (extract32(ahcf->isar.mvfr1, 12, 4) == 1) {
|
||||||
set_feature(&features, ARM_FEATURE_NEON);
|
set_feature(&features, ARM_FEATURE_NEON);
|
||||||
}
|
}
|
||||||
if (extract32(ahcf->isar.mvfr1, 28, 4) == 1) {
|
|
||||||
/* FMAC support implies VFPv4 */
|
|
||||||
set_feature(&features, ARM_FEATURE_VFP4);
|
|
||||||
}
|
|
||||||
|
|
||||||
ahcf->features = features;
|
ahcf->features = features;
|
||||||
|
|
||||||
|
@ -649,7 +649,6 @@ bool kvm_arm_get_host_cpu_features(ARMHostCPUFeatures *ahcf)
|
|||||||
* feature bits.
|
* feature bits.
|
||||||
*/
|
*/
|
||||||
set_feature(&features, ARM_FEATURE_V8);
|
set_feature(&features, ARM_FEATURE_V8);
|
||||||
set_feature(&features, ARM_FEATURE_VFP4);
|
|
||||||
set_feature(&features, ARM_FEATURE_NEON);
|
set_feature(&features, ARM_FEATURE_NEON);
|
||||||
set_feature(&features, ARM_FEATURE_AARCH64);
|
set_feature(&features, ARM_FEATURE_AARCH64);
|
||||||
set_feature(&features, ARM_FEATURE_PMU);
|
set_feature(&features, ARM_FEATURE_PMU);
|
||||||
|
Loading…
Reference in New Issue
Block a user