mirror of
https://github.com/Motorhead1991/qemu.git
synced 2025-08-03 07:43:54 -06:00
target/arm: Add ID_AA64SMFR0_EL1
This register is allocated from the existing block of id registers, so it is already RES0 for cpus that do not implement SME. Reviewed-by: Peter Maydell <peter.maydell@linaro.org> Signed-off-by: Richard Henderson <richard.henderson@linaro.org> Message-id: 20220607203306.657998-21-richard.henderson@linaro.org Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
This commit is contained in:
parent
f305bf9436
commit
414c54d515
3 changed files with 34 additions and 6 deletions
|
@ -966,6 +966,7 @@ struct ArchCPU {
|
|||
uint64_t id_aa64dfr0;
|
||||
uint64_t id_aa64dfr1;
|
||||
uint64_t id_aa64zfr0;
|
||||
uint64_t id_aa64smfr0;
|
||||
uint64_t reset_pmcr_el0;
|
||||
} isar;
|
||||
uint64_t midr;
|
||||
|
@ -2190,6 +2191,15 @@ FIELD(ID_AA64ZFR0, I8MM, 44, 4)
|
|||
FIELD(ID_AA64ZFR0, F32MM, 52, 4)
|
||||
FIELD(ID_AA64ZFR0, F64MM, 56, 4)
|
||||
|
||||
FIELD(ID_AA64SMFR0, F32F32, 32, 1)
|
||||
FIELD(ID_AA64SMFR0, B16F32, 34, 1)
|
||||
FIELD(ID_AA64SMFR0, F16F32, 35, 1)
|
||||
FIELD(ID_AA64SMFR0, I8I32, 36, 4)
|
||||
FIELD(ID_AA64SMFR0, F64F64, 48, 1)
|
||||
FIELD(ID_AA64SMFR0, I16I64, 52, 4)
|
||||
FIELD(ID_AA64SMFR0, SMEVER, 56, 4)
|
||||
FIELD(ID_AA64SMFR0, FA64, 63, 1)
|
||||
|
||||
FIELD(ID_DFR0, COPDBG, 0, 4)
|
||||
FIELD(ID_DFR0, COPSDBG, 4, 4)
|
||||
FIELD(ID_DFR0, MMAPDBG, 8, 4)
|
||||
|
@ -4195,6 +4205,21 @@ static inline bool isar_feature_aa64_sve_f64mm(const ARMISARegisters *id)
|
|||
return FIELD_EX64(id->id_aa64zfr0, ID_AA64ZFR0, F64MM) != 0;
|
||||
}
|
||||
|
||||
static inline bool isar_feature_aa64_sme_f64f64(const ARMISARegisters *id)
|
||||
{
|
||||
return FIELD_EX64(id->id_aa64smfr0, ID_AA64SMFR0, F64F64);
|
||||
}
|
||||
|
||||
static inline bool isar_feature_aa64_sme_i16i64(const ARMISARegisters *id)
|
||||
{
|
||||
return FIELD_EX64(id->id_aa64smfr0, ID_AA64SMFR0, I16I64) == 0xf;
|
||||
}
|
||||
|
||||
static inline bool isar_feature_aa64_sme_fa64(const ARMISARegisters *id)
|
||||
{
|
||||
return FIELD_EX64(id->id_aa64smfr0, ID_AA64SMFR0, FA64);
|
||||
}
|
||||
|
||||
/*
|
||||
* Feature tests for "does this exist in either 32-bit or 64-bit?"
|
||||
*/
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue