|
@@ -98,9 +98,14 @@ bool riscv_cpu_option_set(const char *optname)
|
|
* instead.
|
|
* instead.
|
|
*/
|
|
*/
|
|
const RISCVIsaExtData isa_edata_arr[] = {
|
|
const RISCVIsaExtData isa_edata_arr[] = {
|
|
|
|
+ ISA_EXT_DATA_ENTRY(zic64b, PRIV_VERSION_1_12_0, ext_zic64b),
|
|
ISA_EXT_DATA_ENTRY(zicbom, PRIV_VERSION_1_12_0, ext_zicbom),
|
|
ISA_EXT_DATA_ENTRY(zicbom, PRIV_VERSION_1_12_0, ext_zicbom),
|
|
ISA_EXT_DATA_ENTRY(zicbop, PRIV_VERSION_1_12_0, ext_zicbop),
|
|
ISA_EXT_DATA_ENTRY(zicbop, PRIV_VERSION_1_12_0, ext_zicbop),
|
|
ISA_EXT_DATA_ENTRY(zicboz, PRIV_VERSION_1_12_0, ext_zicboz),
|
|
ISA_EXT_DATA_ENTRY(zicboz, PRIV_VERSION_1_12_0, ext_zicboz),
|
|
|
|
+ ISA_EXT_DATA_ENTRY(ziccamoa, PRIV_VERSION_1_11_0, ext_always_enabled),
|
|
|
|
+ ISA_EXT_DATA_ENTRY(ziccif, PRIV_VERSION_1_11_0, ext_always_enabled),
|
|
|
|
+ ISA_EXT_DATA_ENTRY(zicclsm, PRIV_VERSION_1_11_0, ext_always_enabled),
|
|
|
|
+ ISA_EXT_DATA_ENTRY(ziccrse, PRIV_VERSION_1_11_0, ext_always_enabled),
|
|
ISA_EXT_DATA_ENTRY(zicond, PRIV_VERSION_1_12_0, ext_zicond),
|
|
ISA_EXT_DATA_ENTRY(zicond, PRIV_VERSION_1_12_0, ext_zicond),
|
|
ISA_EXT_DATA_ENTRY(zicntr, PRIV_VERSION_1_12_0, ext_zicntr),
|
|
ISA_EXT_DATA_ENTRY(zicntr, PRIV_VERSION_1_12_0, ext_zicntr),
|
|
ISA_EXT_DATA_ENTRY(zicsr, PRIV_VERSION_1_10_0, ext_zicsr),
|
|
ISA_EXT_DATA_ENTRY(zicsr, PRIV_VERSION_1_10_0, ext_zicsr),
|
|
@@ -109,6 +114,7 @@ const RISCVIsaExtData isa_edata_arr[] = {
|
|
ISA_EXT_DATA_ENTRY(zihintpause, PRIV_VERSION_1_10_0, ext_zihintpause),
|
|
ISA_EXT_DATA_ENTRY(zihintpause, PRIV_VERSION_1_10_0, ext_zihintpause),
|
|
ISA_EXT_DATA_ENTRY(zihpm, PRIV_VERSION_1_12_0, ext_zihpm),
|
|
ISA_EXT_DATA_ENTRY(zihpm, PRIV_VERSION_1_12_0, ext_zihpm),
|
|
ISA_EXT_DATA_ENTRY(zmmul, PRIV_VERSION_1_12_0, ext_zmmul),
|
|
ISA_EXT_DATA_ENTRY(zmmul, PRIV_VERSION_1_12_0, ext_zmmul),
|
|
|
|
+ ISA_EXT_DATA_ENTRY(za64rs, PRIV_VERSION_1_12_0, ext_always_enabled),
|
|
ISA_EXT_DATA_ENTRY(zaamo, PRIV_VERSION_1_12_0, ext_zaamo),
|
|
ISA_EXT_DATA_ENTRY(zaamo, PRIV_VERSION_1_12_0, ext_zaamo),
|
|
ISA_EXT_DATA_ENTRY(zacas, PRIV_VERSION_1_12_0, ext_zacas),
|
|
ISA_EXT_DATA_ENTRY(zacas, PRIV_VERSION_1_12_0, ext_zacas),
|
|
ISA_EXT_DATA_ENTRY(zalrsc, PRIV_VERSION_1_12_0, ext_zalrsc),
|
|
ISA_EXT_DATA_ENTRY(zalrsc, PRIV_VERSION_1_12_0, ext_zalrsc),
|
|
@@ -143,6 +149,7 @@ const RISCVIsaExtData isa_edata_arr[] = {
|
|
ISA_EXT_DATA_ENTRY(zksed, PRIV_VERSION_1_12_0, ext_zksed),
|
|
ISA_EXT_DATA_ENTRY(zksed, PRIV_VERSION_1_12_0, ext_zksed),
|
|
ISA_EXT_DATA_ENTRY(zksh, PRIV_VERSION_1_12_0, ext_zksh),
|
|
ISA_EXT_DATA_ENTRY(zksh, PRIV_VERSION_1_12_0, ext_zksh),
|
|
ISA_EXT_DATA_ENTRY(zkt, PRIV_VERSION_1_12_0, ext_zkt),
|
|
ISA_EXT_DATA_ENTRY(zkt, PRIV_VERSION_1_12_0, ext_zkt),
|
|
|
|
+ ISA_EXT_DATA_ENTRY(ztso, PRIV_VERSION_1_12_0, ext_ztso),
|
|
ISA_EXT_DATA_ENTRY(zvbb, PRIV_VERSION_1_12_0, ext_zvbb),
|
|
ISA_EXT_DATA_ENTRY(zvbb, PRIV_VERSION_1_12_0, ext_zvbb),
|
|
ISA_EXT_DATA_ENTRY(zvbc, PRIV_VERSION_1_12_0, ext_zvbc),
|
|
ISA_EXT_DATA_ENTRY(zvbc, PRIV_VERSION_1_12_0, ext_zvbc),
|
|
ISA_EXT_DATA_ENTRY(zve32f, PRIV_VERSION_1_10_0, ext_zve32f),
|
|
ISA_EXT_DATA_ENTRY(zve32f, PRIV_VERSION_1_10_0, ext_zve32f),
|
|
@@ -172,8 +179,13 @@ const RISCVIsaExtData isa_edata_arr[] = {
|
|
ISA_EXT_DATA_ENTRY(smepmp, PRIV_VERSION_1_12_0, ext_smepmp),
|
|
ISA_EXT_DATA_ENTRY(smepmp, PRIV_VERSION_1_12_0, ext_smepmp),
|
|
ISA_EXT_DATA_ENTRY(smstateen, PRIV_VERSION_1_12_0, ext_smstateen),
|
|
ISA_EXT_DATA_ENTRY(smstateen, PRIV_VERSION_1_12_0, ext_smstateen),
|
|
ISA_EXT_DATA_ENTRY(ssaia, PRIV_VERSION_1_12_0, ext_ssaia),
|
|
ISA_EXT_DATA_ENTRY(ssaia, PRIV_VERSION_1_12_0, ext_ssaia),
|
|
|
|
+ ISA_EXT_DATA_ENTRY(ssccptr, PRIV_VERSION_1_11_0, ext_always_enabled),
|
|
ISA_EXT_DATA_ENTRY(sscofpmf, PRIV_VERSION_1_12_0, ext_sscofpmf),
|
|
ISA_EXT_DATA_ENTRY(sscofpmf, PRIV_VERSION_1_12_0, ext_sscofpmf),
|
|
|
|
+ ISA_EXT_DATA_ENTRY(sscounterenw, PRIV_VERSION_1_12_0, ext_always_enabled),
|
|
ISA_EXT_DATA_ENTRY(sstc, PRIV_VERSION_1_12_0, ext_sstc),
|
|
ISA_EXT_DATA_ENTRY(sstc, PRIV_VERSION_1_12_0, ext_sstc),
|
|
|
|
+ ISA_EXT_DATA_ENTRY(sstvala, PRIV_VERSION_1_12_0, ext_always_enabled),
|
|
|
|
+ ISA_EXT_DATA_ENTRY(sstvecd, PRIV_VERSION_1_12_0, ext_always_enabled),
|
|
|
|
+ ISA_EXT_DATA_ENTRY(svade, PRIV_VERSION_1_11_0, ext_svade),
|
|
ISA_EXT_DATA_ENTRY(svadu, PRIV_VERSION_1_12_0, ext_svadu),
|
|
ISA_EXT_DATA_ENTRY(svadu, PRIV_VERSION_1_12_0, ext_svadu),
|
|
ISA_EXT_DATA_ENTRY(svinval, PRIV_VERSION_1_12_0, ext_svinval),
|
|
ISA_EXT_DATA_ENTRY(svinval, PRIV_VERSION_1_12_0, ext_svinval),
|
|
ISA_EXT_DATA_ENTRY(svnapot, PRIV_VERSION_1_12_0, ext_svnapot),
|
|
ISA_EXT_DATA_ENTRY(svnapot, PRIV_VERSION_1_12_0, ext_svnapot),
|
|
@@ -949,9 +961,9 @@ static void riscv_cpu_reset_hold(Object *obj)
|
|
env->two_stage_lookup = false;
|
|
env->two_stage_lookup = false;
|
|
|
|
|
|
env->menvcfg = (cpu->cfg.ext_svpbmt ? MENVCFG_PBMTE : 0) |
|
|
env->menvcfg = (cpu->cfg.ext_svpbmt ? MENVCFG_PBMTE : 0) |
|
|
- (cpu->cfg.ext_svadu ? MENVCFG_ADUE : 0);
|
|
|
|
- env->henvcfg = (cpu->cfg.ext_svpbmt ? HENVCFG_PBMTE : 0) |
|
|
|
|
- (cpu->cfg.ext_svadu ? HENVCFG_ADUE : 0);
|
|
|
|
|
|
+ (!cpu->cfg.ext_svade && cpu->cfg.ext_svadu ?
|
|
|
|
+ MENVCFG_ADUE : 0);
|
|
|
|
+ env->henvcfg = 0;
|
|
|
|
|
|
/* Initialized default priorities of local interrupts. */
|
|
/* Initialized default priorities of local interrupts. */
|
|
for (i = 0; i < ARRAY_SIZE(env->miprio); i++) {
|
|
for (i = 0; i < ARRAY_SIZE(env->miprio); i++) {
|
|
@@ -1452,17 +1464,27 @@ const RISCVCPUMultiExtConfig riscv_cpu_extensions[] = {
|
|
MULTI_EXT_CFG_BOOL("zihintntl", ext_zihintntl, true),
|
|
MULTI_EXT_CFG_BOOL("zihintntl", ext_zihintntl, true),
|
|
MULTI_EXT_CFG_BOOL("zihintpause", ext_zihintpause, true),
|
|
MULTI_EXT_CFG_BOOL("zihintpause", ext_zihintpause, true),
|
|
MULTI_EXT_CFG_BOOL("zacas", ext_zacas, false),
|
|
MULTI_EXT_CFG_BOOL("zacas", ext_zacas, false),
|
|
|
|
+ MULTI_EXT_CFG_BOOL("zaamo", ext_zaamo, false),
|
|
|
|
+ MULTI_EXT_CFG_BOOL("zalrsc", ext_zalrsc, false),
|
|
MULTI_EXT_CFG_BOOL("zawrs", ext_zawrs, true),
|
|
MULTI_EXT_CFG_BOOL("zawrs", ext_zawrs, true),
|
|
MULTI_EXT_CFG_BOOL("zfa", ext_zfa, true),
|
|
MULTI_EXT_CFG_BOOL("zfa", ext_zfa, true),
|
|
|
|
+ MULTI_EXT_CFG_BOOL("zfbfmin", ext_zfbfmin, false),
|
|
MULTI_EXT_CFG_BOOL("zfh", ext_zfh, false),
|
|
MULTI_EXT_CFG_BOOL("zfh", ext_zfh, false),
|
|
MULTI_EXT_CFG_BOOL("zfhmin", ext_zfhmin, false),
|
|
MULTI_EXT_CFG_BOOL("zfhmin", ext_zfhmin, false),
|
|
MULTI_EXT_CFG_BOOL("zve32f", ext_zve32f, false),
|
|
MULTI_EXT_CFG_BOOL("zve32f", ext_zve32f, false),
|
|
MULTI_EXT_CFG_BOOL("zve64f", ext_zve64f, false),
|
|
MULTI_EXT_CFG_BOOL("zve64f", ext_zve64f, false),
|
|
MULTI_EXT_CFG_BOOL("zve64d", ext_zve64d, false),
|
|
MULTI_EXT_CFG_BOOL("zve64d", ext_zve64d, false),
|
|
|
|
+ MULTI_EXT_CFG_BOOL("zvfbfmin", ext_zvfbfmin, false),
|
|
|
|
+ MULTI_EXT_CFG_BOOL("zvfbfwma", ext_zvfbfwma, false),
|
|
|
|
+ MULTI_EXT_CFG_BOOL("zvfh", ext_zvfh, false),
|
|
|
|
+ MULTI_EXT_CFG_BOOL("zvfhmin", ext_zvfhmin, false),
|
|
MULTI_EXT_CFG_BOOL("sstc", ext_sstc, true),
|
|
MULTI_EXT_CFG_BOOL("sstc", ext_sstc, true),
|
|
|
|
|
|
|
|
+ MULTI_EXT_CFG_BOOL("smaia", ext_smaia, false),
|
|
MULTI_EXT_CFG_BOOL("smepmp", ext_smepmp, false),
|
|
MULTI_EXT_CFG_BOOL("smepmp", ext_smepmp, false),
|
|
MULTI_EXT_CFG_BOOL("smstateen", ext_smstateen, false),
|
|
MULTI_EXT_CFG_BOOL("smstateen", ext_smstateen, false),
|
|
|
|
+ MULTI_EXT_CFG_BOOL("ssaia", ext_ssaia, false),
|
|
|
|
+ MULTI_EXT_CFG_BOOL("svade", ext_svade, false),
|
|
MULTI_EXT_CFG_BOOL("svadu", ext_svadu, true),
|
|
MULTI_EXT_CFG_BOOL("svadu", ext_svadu, true),
|
|
MULTI_EXT_CFG_BOOL("svinval", ext_svinval, false),
|
|
MULTI_EXT_CFG_BOOL("svinval", ext_svinval, false),
|
|
MULTI_EXT_CFG_BOOL("svnapot", ext_svnapot, false),
|
|
MULTI_EXT_CFG_BOOL("svnapot", ext_svnapot, false),
|
|
@@ -1488,6 +1510,7 @@ const RISCVCPUMultiExtConfig riscv_cpu_extensions[] = {
|
|
MULTI_EXT_CFG_BOOL("zksed", ext_zksed, false),
|
|
MULTI_EXT_CFG_BOOL("zksed", ext_zksed, false),
|
|
MULTI_EXT_CFG_BOOL("zksh", ext_zksh, false),
|
|
MULTI_EXT_CFG_BOOL("zksh", ext_zksh, false),
|
|
MULTI_EXT_CFG_BOOL("zkt", ext_zkt, false),
|
|
MULTI_EXT_CFG_BOOL("zkt", ext_zkt, false),
|
|
|
|
+ MULTI_EXT_CFG_BOOL("ztso", ext_ztso, false),
|
|
|
|
|
|
MULTI_EXT_CFG_BOOL("zdinx", ext_zdinx, false),
|
|
MULTI_EXT_CFG_BOOL("zdinx", ext_zdinx, false),
|
|
MULTI_EXT_CFG_BOOL("zfinx", ext_zfinx, false),
|
|
MULTI_EXT_CFG_BOOL("zfinx", ext_zfinx, false),
|
|
@@ -1549,25 +1572,40 @@ const RISCVCPUMultiExtConfig riscv_cpu_vendor_exts[] = {
|
|
|
|
|
|
/* These are experimental so mark with 'x-' */
|
|
/* These are experimental so mark with 'x-' */
|
|
const RISCVCPUMultiExtConfig riscv_cpu_experimental_exts[] = {
|
|
const RISCVCPUMultiExtConfig riscv_cpu_experimental_exts[] = {
|
|
- MULTI_EXT_CFG_BOOL("x-smaia", ext_smaia, false),
|
|
|
|
- MULTI_EXT_CFG_BOOL("x-ssaia", ext_ssaia, false),
|
|
|
|
-
|
|
|
|
- MULTI_EXT_CFG_BOOL("x-zaamo", ext_zaamo, false),
|
|
|
|
- MULTI_EXT_CFG_BOOL("x-zalrsc", ext_zalrsc, false),
|
|
|
|
-
|
|
|
|
- MULTI_EXT_CFG_BOOL("x-zvfh", ext_zvfh, false),
|
|
|
|
- MULTI_EXT_CFG_BOOL("x-zvfhmin", ext_zvfhmin, false),
|
|
|
|
-
|
|
|
|
- MULTI_EXT_CFG_BOOL("x-zfbfmin", ext_zfbfmin, false),
|
|
|
|
- MULTI_EXT_CFG_BOOL("x-zvfbfmin", ext_zvfbfmin, false),
|
|
|
|
- MULTI_EXT_CFG_BOOL("x-zvfbfwma", ext_zvfbfwma, false),
|
|
|
|
-
|
|
|
|
DEFINE_PROP_END_OF_LIST(),
|
|
DEFINE_PROP_END_OF_LIST(),
|
|
};
|
|
};
|
|
|
|
|
|
|
|
+#define ALWAYS_ENABLED_FEATURE(_name) \
|
|
|
|
+ {.name = _name, \
|
|
|
|
+ .offset = CPU_CFG_OFFSET(ext_always_enabled), \
|
|
|
|
+ .enabled = true}
|
|
|
|
+
|
|
|
|
+/*
|
|
|
|
+ * 'Named features' is the name we give to extensions that we
|
|
|
|
+ * don't want to expose to users. They are either immutable
|
|
|
|
+ * (always enabled/disable) or they'll vary depending on
|
|
|
|
+ * the resulting CPU state. They have riscv,isa strings
|
|
|
|
+ * and priv_ver like regular extensions.
|
|
|
|
+ */
|
|
const RISCVCPUMultiExtConfig riscv_cpu_named_features[] = {
|
|
const RISCVCPUMultiExtConfig riscv_cpu_named_features[] = {
|
|
- MULTI_EXT_CFG_BOOL("svade", svade, true),
|
|
|
|
- MULTI_EXT_CFG_BOOL("zic64b", zic64b, true),
|
|
|
|
|
|
+ MULTI_EXT_CFG_BOOL("zic64b", ext_zic64b, true),
|
|
|
|
+
|
|
|
|
+ /*
|
|
|
|
+ * cache-related extensions that are always enabled
|
|
|
|
+ * in TCG since QEMU RISC-V does not have a cache
|
|
|
|
+ * model.
|
|
|
|
+ */
|
|
|
|
+ ALWAYS_ENABLED_FEATURE("za64rs"),
|
|
|
|
+ ALWAYS_ENABLED_FEATURE("ziccif"),
|
|
|
|
+ ALWAYS_ENABLED_FEATURE("ziccrse"),
|
|
|
|
+ ALWAYS_ENABLED_FEATURE("ziccamoa"),
|
|
|
|
+ ALWAYS_ENABLED_FEATURE("zicclsm"),
|
|
|
|
+ ALWAYS_ENABLED_FEATURE("ssccptr"),
|
|
|
|
+
|
|
|
|
+ /* Other named features that TCG always implements */
|
|
|
|
+ ALWAYS_ENABLED_FEATURE("sstvecd"),
|
|
|
|
+ ALWAYS_ENABLED_FEATURE("sstvala"),
|
|
|
|
+ ALWAYS_ENABLED_FEATURE("sscounterenw"),
|
|
|
|
|
|
DEFINE_PROP_END_OF_LIST(),
|
|
DEFINE_PROP_END_OF_LIST(),
|
|
};
|
|
};
|
|
@@ -2162,13 +2200,10 @@ static const PropertyInfo prop_marchid = {
|
|
};
|
|
};
|
|
|
|
|
|
/*
|
|
/*
|
|
- * RVA22U64 defines some 'named features' or 'synthetic extensions'
|
|
|
|
- * that are cache related: Za64rs, Zic64b, Ziccif, Ziccrse, Ziccamoa
|
|
|
|
- * and Zicclsm. We do not implement caching in QEMU so we'll consider
|
|
|
|
- * all these named features as always enabled.
|
|
|
|
- *
|
|
|
|
- * There's no riscv,isa update for them (nor for zic64b, despite it
|
|
|
|
- * having a cfg offset) at this moment.
|
|
|
|
|
|
+ * RVA22U64 defines some 'named features' that are cache
|
|
|
|
+ * related: Za64rs, Zic64b, Ziccif, Ziccrse, Ziccamoa
|
|
|
|
+ * and Zicclsm. They are always implemented in TCG and
|
|
|
|
+ * doesn't need to be manually enabled by the profile.
|
|
*/
|
|
*/
|
|
static RISCVCPUProfile RVA22U64 = {
|
|
static RISCVCPUProfile RVA22U64 = {
|
|
.parent = NULL,
|
|
.parent = NULL,
|
|
@@ -2185,7 +2220,7 @@ static RISCVCPUProfile RVA22U64 = {
|
|
CPU_CFG_OFFSET(ext_zicbop), CPU_CFG_OFFSET(ext_zicboz),
|
|
CPU_CFG_OFFSET(ext_zicbop), CPU_CFG_OFFSET(ext_zicboz),
|
|
|
|
|
|
/* mandatory named features for this profile */
|
|
/* mandatory named features for this profile */
|
|
- CPU_CFG_OFFSET(zic64b),
|
|
|
|
|
|
+ CPU_CFG_OFFSET(ext_zic64b),
|
|
|
|
|
|
RISCV_PROFILE_EXT_LIST_END
|
|
RISCV_PROFILE_EXT_LIST_END
|
|
}
|
|
}
|
|
@@ -2200,8 +2235,6 @@ static RISCVCPUProfile RVA22U64 = {
|
|
* Other named features that we already implement: Sstvecd, Sstvala,
|
|
* Other named features that we already implement: Sstvecd, Sstvala,
|
|
* Sscounterenw
|
|
* Sscounterenw
|
|
*
|
|
*
|
|
- * Named features that we need to enable: svade
|
|
|
|
- *
|
|
|
|
* The remaining features/extensions comes from RVA22U64.
|
|
* The remaining features/extensions comes from RVA22U64.
|
|
*/
|
|
*/
|
|
static RISCVCPUProfile RVA22S64 = {
|
|
static RISCVCPUProfile RVA22S64 = {
|
|
@@ -2213,10 +2246,7 @@ static RISCVCPUProfile RVA22S64 = {
|
|
.ext_offsets = {
|
|
.ext_offsets = {
|
|
/* rva22s64 exts */
|
|
/* rva22s64 exts */
|
|
CPU_CFG_OFFSET(ext_zifencei), CPU_CFG_OFFSET(ext_svpbmt),
|
|
CPU_CFG_OFFSET(ext_zifencei), CPU_CFG_OFFSET(ext_svpbmt),
|
|
- CPU_CFG_OFFSET(ext_svinval),
|
|
|
|
-
|
|
|
|
- /* rva22s64 named features */
|
|
|
|
- CPU_CFG_OFFSET(svade),
|
|
|
|
|
|
+ CPU_CFG_OFFSET(ext_svinval), CPU_CFG_OFFSET(ext_svade),
|
|
|
|
|
|
RISCV_PROFILE_EXT_LIST_END
|
|
RISCV_PROFILE_EXT_LIST_END
|
|
}
|
|
}
|