> On 16 Jun 2026, at 6:47 PM, Eric Auger <[email protected]> wrote:
> 
> !-------------------------------------------------------------------|
>  CAUTION: External Email
> 
> |-------------------------------------------------------------------!
> 
> Extract reserved fields: RES0, RES1, RAZ, ...
> 
> Signed-off-by: Eric Auger <[email protected]>
Suggested-by: Khushit Shah <[email protected]>

> ---
> target/arm/cpu-idregs.h.inc                   | 69 ++++++++++++++-
> .../update-aarch64-cpu-sysreg-properties.py   | 83 +++++++++++++++----
> 2 files changed, 136 insertions(+), 16 deletions(-)
> 
> diff --git a/target/arm/cpu-idregs.h.inc b/target/arm/cpu-idregs.h.inc
> index 1c8b26133b..5fdc84237c 100644
> --- a/target/arm/cpu-idregs.h.inc
> +++ b/target/arm/cpu-idregs.h.inc
> @@ -15,16 +15,20 @@ IDREG_START(AIDR_EL1)
> IDREG_END(AIDR_EL1)
> 
> IDREG_START(CCSIDR2_EL1)
> +    IDREG_FIELD(CCSIDR2_EL1, RES0, 24, 40)
>     IDREG_FIELD(CCSIDR2_EL1, NumSets, 0, 24)
> IDREG_END(CCSIDR2_EL1)
> 
> IDREG_START(CCSIDR_EL1)
> +    IDREG_FIELD(CCSIDR_EL1, RES0, 56, 8)
>     IDREG_FIELD(CCSIDR_EL1, NumSets, 32, 24)
> +    IDREG_FIELD(CCSIDR_EL1, RES0, 24, 8)
>     IDREG_FIELD(CCSIDR_EL1, Associativity, 3, 21)
>     IDREG_FIELD(CCSIDR_EL1, LineSize, 0, 3)
> IDREG_END(CCSIDR_EL1)
> 
> IDREG_START(CLIDR_EL1)
> +    IDREG_FIELD(CLIDR_EL1, RES0, 47, 17)
>     IDREG_FIELD(CLIDR_EL1, Ttype7, 45, 2)
>     IDREG_FIELD(CLIDR_EL1, Ttype6, 43, 2)
>     IDREG_FIELD(CLIDR_EL1, Ttype5, 41, 2)
> @@ -55,7 +59,10 @@ IDREG_START(CLIDR_EL1)
> IDREG_END(CLIDR_EL1)
> 
> IDREG_START(CTR_EL0)
> +    IDREG_FIELD(CTR_EL0, RES0, 38, 26)
>     IDREG_FIELD(CTR_EL0, TminLine, 32, 6)
> +    IDREG_FIELD(CTR_EL0, RES1, 31, 1)
> +    IDREG_FIELD(CTR_EL0, RES0, 30, 1)
>     IDREG_FIELD_START(CTR_EL0, DIC, 29, 1)
>         IDREG_FIELD_ARCH_VAL(0)
>         IDREG_FIELD_ARCH_VAL(1)
> @@ -73,23 +80,28 @@ IDREG_START(CTR_EL0)
>         IDREG_FIELD_ARCH_VAL(2)
>         IDREG_FIELD_ARCH_VAL(3)
>     IDREG_FIELD_END(CTR_EL0, L1Ip)
> +    IDREG_FIELD(CTR_EL0, RES0, 4, 10)
>     IDREG_FIELD(CTR_EL0, IminLine, 0, 4)
> IDREG_END(CTR_EL0)
> 
> IDREG_START(DCZID_EL0)
> +    IDREG_FIELD(DCZID_EL0, RES0, 9, 55)
>     IDREG_FIELD(DCZID_EL0, TBS, 5, 4)
>     IDREG_FIELD(DCZID_EL0, DZP, 4, 1)
>     IDREG_FIELD(DCZID_EL0, BS, 0, 4)
> IDREG_END(DCZID_EL0)
> 
> IDREG_START(GMID_EL1)
> +    IDREG_FIELD(GMID_EL1, RES0, 4, 60)
>     IDREG_FIELD(GMID_EL1, BS, 0, 4)
> IDREG_END(GMID_EL1)
> 
> IDREG_START(ID_AA64AFR0_EL1)
> +    IDREG_FIELD(ID_AA64AFR0_EL1, RES0, 32, 32)
> IDREG_END(ID_AA64AFR0_EL1)
> 
> IDREG_START(ID_AA64AFR1_EL1)
> +    IDREG_FIELD(ID_AA64AFR1_EL1, RES0, 0, 64)
> IDREG_END(ID_AA64AFR1_EL1)
> 
> IDREG_START(ID_AA64DFR0_EL1)
> @@ -136,6 +148,7 @@ IDREG_START(ID_AA64DFR0_EL1)
>     IDREG_FIELD_START(ID_AA64DFR0_EL1, CTX_CMPs, 28, 4)
>         IDREG_FIELD_ARCH_VAL(15)
>     IDREG_FIELD_END(ID_AA64DFR0_EL1, CTX_CMPs)
> +    IDREG_FIELD(ID_AA64DFR0_EL1, RES0, 24, 4)
>     IDREG_FIELD(ID_AA64DFR0_EL1, WRPs, 20, 4)
>     IDREG_FIELD_START(ID_AA64DFR0_EL1, PMSS, 16, 4)
>         IDREG_FIELD_ARCH_VAL(0)
> @@ -209,6 +222,7 @@ IDREG_START(ID_AA64DFR1_EL1)
> IDREG_END(ID_AA64DFR1_EL1)
> 
> IDREG_START(ID_AA64DFR2_EL1)
> +    IDREG_FIELD(ID_AA64DFR2_EL1, RES0, 28, 36)
>     IDREG_FIELD_START(ID_AA64DFR2_EL1, TRBE_EXC, 24, 4)
>         IDREG_FIELD_ARCH_VAL(0)
>         IDREG_FIELD_ARCH_VAL(1)
> @@ -221,6 +235,7 @@ IDREG_START(ID_AA64DFR2_EL1)
>         IDREG_FIELD_ARCH_VAL(0)
>         IDREG_FIELD_ARCH_VAL(1)
>     IDREG_FIELD_END(ID_AA64DFR2_EL1, SPE_EXC)
> +    IDREG_FIELD(ID_AA64DFR2_EL1, RES0, 8, 8)
>     IDREG_FIELD_START(ID_AA64DFR2_EL1, BWE, 4, 4)
>         IDREG_FIELD_ARCH_VAL(0)
>         IDREG_FIELD_ARCH_VAL(1)
> @@ -233,6 +248,7 @@ IDREG_START(ID_AA64DFR2_EL1)
> IDREG_END(ID_AA64DFR2_EL1)
> 
> IDREG_START(ID_AA64FPFR0_EL1)
> +    IDREG_FIELD(ID_AA64FPFR0_EL1, RES0, 32, 32)
>     IDREG_FIELD_START(ID_AA64FPFR0_EL1, F8CVT, 31, 1)
>         IDREG_FIELD_ARCH_VAL(0)
>         IDREG_FIELD_ARCH_VAL(1)
> @@ -257,10 +273,13 @@ IDREG_START(ID_AA64FPFR0_EL1)
>         IDREG_FIELD_ARCH_VAL(0)
>         IDREG_FIELD_ARCH_VAL(1)
>     IDREG_FIELD_END(ID_AA64FPFR0_EL1, F8MM4)
> +    IDREG_FIELD(ID_AA64FPFR0_EL1, RES0, 16, 10)
>     IDREG_FIELD_START(ID_AA64FPFR0_EL1, F16MM2, 15, 1)
>         IDREG_FIELD_ARCH_VAL(0)
>         IDREG_FIELD_ARCH_VAL(1)
>     IDREG_FIELD_END(ID_AA64FPFR0_EL1, F16MM2)
> +    IDREG_FIELD(ID_AA64FPFR0_EL1, RES0, 8, 7)
> +    IDREG_FIELD(ID_AA64FPFR0_EL1, RAZ, 2, 6)
>     IDREG_FIELD_START(ID_AA64FPFR0_EL1, F8E4M3, 1, 1)
>         IDREG_FIELD_ARCH_VAL(0)
>         IDREG_FIELD_ARCH_VAL(1)
> @@ -312,6 +331,7 @@ IDREG_START(ID_AA64ISAR0_EL1)
>         IDREG_FIELD_ARCH_VAL(0)
>         IDREG_FIELD_ARCH_VAL(1)
>     IDREG_FIELD_END(ID_AA64ISAR0_EL1, RDM)
> +    IDREG_FIELD(ID_AA64ISAR0_EL1, RES0, 24, 4)
>     IDREG_FIELD_START(ID_AA64ISAR0_EL1, Atomic, 20, 4)
>         IDREG_FIELD_ARCH_VAL(0)
>         IDREG_FIELD_ARCH_VAL(2)
> @@ -335,6 +355,7 @@ IDREG_START(ID_AA64ISAR0_EL1)
>         IDREG_FIELD_ARCH_VAL(1)
>         IDREG_FIELD_ARCH_VAL(2)
>     IDREG_FIELD_END(ID_AA64ISAR0_EL1, AES)
> +    IDREG_FIELD(ID_AA64ISAR0_EL1, RES0, 0, 4)
> IDREG_END(ID_AA64ISAR0_EL1)
> 
> IDREG_START(ID_AA64ISAR1_EL1)
> @@ -498,6 +519,7 @@ IDREG_START(ID_AA64ISAR2_EL1)
> IDREG_END(ID_AA64ISAR2_EL1)
> 
> IDREG_START(ID_AA64ISAR3_EL1)
> +    IDREG_FIELD(ID_AA64ISAR3_EL1, RES0, 48, 16)
>     IDREG_FIELD_START(ID_AA64ISAR3_EL1, LSCP, 44, 4)
>         IDREG_FIELD_ARCH_VAL(0)
>         IDREG_FIELD_ARCH_VAL(1)
> @@ -561,6 +583,7 @@ IDREG_START(ID_AA64MMFR0_EL1)
>         IDREG_FIELD_ARCH_VAL(1)
>         IDREG_FIELD_ARCH_VAL(2)
>     IDREG_FIELD_END(ID_AA64MMFR0_EL1, FGT)
> +    IDREG_FIELD(ID_AA64MMFR0_EL1, RES0, 48, 8)
>     IDREG_FIELD_START(ID_AA64MMFR0_EL1, ExS, 44, 4)
>         IDREG_FIELD_ARCH_VAL(0)
>         IDREG_FIELD_ARCH_VAL(1)
> @@ -713,6 +736,7 @@ IDREG_START(ID_AA64MMFR2_EL1)
>         IDREG_FIELD_ARCH_VAL(0)
>         IDREG_FIELD_ARCH_VAL(1)
>     IDREG_FIELD_END(ID_AA64MMFR2_EL1, TTL)
> +    IDREG_FIELD(ID_AA64MMFR2_EL1, RES0, 44, 4)
>     IDREG_FIELD_START(ID_AA64MMFR2_EL1, FWB, 40, 4)
>         IDREG_FIELD_ARCH_VAL(0)
>         IDREG_FIELD_ARCH_VAL(1)
> @@ -778,6 +802,7 @@ IDREG_START(ID_AA64MMFR3_EL1)
>         IDREG_FIELD_ARCH_VAL(2)
>         IDREG_FIELD_ARCH_VAL(3)
>     IDREG_FIELD_END(ID_AA64MMFR3_EL1, SDERR)
> +    IDREG_FIELD(ID_AA64MMFR3_EL1, RES0, 48, 4)
>     IDREG_FIELD_START(ID_AA64MMFR3_EL1, ANERR, 44, 4)
>         IDREG_FIELD_ARCH_VAL(0)
>         IDREG_FIELD_ARCH_VAL(1)
> @@ -1031,6 +1056,7 @@ IDREG_START(ID_AA64PFR1_EL1)
>         IDREG_FIELD_ARCH_VAL(1)
>         IDREG_FIELD_ARCH_VAL(2)
>     IDREG_FIELD_END(ID_AA64PFR1_EL1, SME)
> +    IDREG_FIELD(ID_AA64PFR1_EL1, RES0, 20, 4)
>     IDREG_FIELD_START(ID_AA64PFR1_EL1, MPAM_frac, 16, 4)
>         IDREG_FIELD_ARCH_VAL(0)
>         IDREG_FIELD_ARCH_VAL(1)
> @@ -1058,6 +1084,7 @@ IDREG_START(ID_AA64PFR1_EL1)
> IDREG_END(ID_AA64PFR1_EL1)
> 
> IDREG_START(ID_AA64PFR2_EL1)
> +    IDREG_FIELD(ID_AA64PFR2_EL1, RES0, 48, 16)
>     IDREG_FIELD_START(ID_AA64PFR2_EL1, VMTETCL, 44, 4)
>         IDREG_FIELD_ARCH_VAL(0)
>         IDREG_FIELD_ARCH_VAL(1)
> @@ -1117,6 +1144,7 @@ IDREG_START(ID_AA64SMFR0_EL1)
>         IDREG_FIELD_ARCH_VAL(0)
>         IDREG_FIELD_ARCH_VAL(1)
>     IDREG_FIELD_END(ID_AA64SMFR0_EL1, FA64)
> +    IDREG_FIELD(ID_AA64SMFR0_EL1, RES0, 62, 1)
>     IDREG_FIELD_START(ID_AA64SMFR0_EL1, LUT6, 61, 1)
>         IDREG_FIELD_ARCH_VAL(0)
>         IDREG_FIELD_ARCH_VAL(1)
> @@ -1136,6 +1164,7 @@ IDREG_START(ID_AA64SMFR0_EL1)
>         IDREG_FIELD_ARCH_VAL(0)
>         IDREG_FIELD_ARCH_VAL(15)
>     IDREG_FIELD_END(ID_AA64SMFR0_EL1, I16I64)
> +    IDREG_FIELD(ID_AA64SMFR0_EL1, RES0, 49, 3)
>     IDREG_FIELD_START(ID_AA64SMFR0_EL1, F64F64, 48, 1)
>         IDREG_FIELD_ARCH_VAL(0)
>         IDREG_FIELD_ARCH_VAL(1)
> @@ -1180,6 +1209,7 @@ IDREG_START(ID_AA64SMFR0_EL1)
>         IDREG_FIELD_ARCH_VAL(0)
>         IDREG_FIELD_ARCH_VAL(1)
>     IDREG_FIELD_END(ID_AA64SMFR0_EL1, F32F32)
> +    IDREG_FIELD(ID_AA64SMFR0_EL1, RES0, 31, 1)
>     IDREG_FIELD_START(ID_AA64SMFR0_EL1, SF8FMA, 30, 1)
>         IDREG_FIELD_ARCH_VAL(0)
>         IDREG_FIELD_ARCH_VAL(1)
> @@ -1192,6 +1222,7 @@ IDREG_START(ID_AA64SMFR0_EL1)
>         IDREG_FIELD_ARCH_VAL(0)
>         IDREG_FIELD_ARCH_VAL(1)
>     IDREG_FIELD_END(ID_AA64SMFR0_EL1, SF8DP2)
> +    IDREG_FIELD(ID_AA64SMFR0_EL1, RES0, 26, 2)
>     IDREG_FIELD_START(ID_AA64SMFR0_EL1, SBitPerm, 25, 1)
>         IDREG_FIELD_ARCH_VAL(0)
>         IDREG_FIELD_ARCH_VAL(1)
> @@ -1204,10 +1235,12 @@ IDREG_START(ID_AA64SMFR0_EL1)
>         IDREG_FIELD_ARCH_VAL(0)
>         IDREG_FIELD_ARCH_VAL(1)
>     IDREG_FIELD_END(ID_AA64SMFR0_EL1, SFEXPA)
> +    IDREG_FIELD(ID_AA64SMFR0_EL1, RES0, 17, 6)
>     IDREG_FIELD_START(ID_AA64SMFR0_EL1, STMOP, 16, 1)
>         IDREG_FIELD_ARCH_VAL(0)
>         IDREG_FIELD_ARCH_VAL(1)
>     IDREG_FIELD_END(ID_AA64SMFR0_EL1, STMOP)
> +    IDREG_FIELD(ID_AA64SMFR0_EL1, RES0, 1, 15)
>     IDREG_FIELD_START(ID_AA64SMFR0_EL1, SMOP4, 0, 1)
>         IDREG_FIELD_ARCH_VAL(0)
>         IDREG_FIELD_ARCH_VAL(1)
> @@ -1215,6 +1248,7 @@ IDREG_START(ID_AA64SMFR0_EL1)
> IDREG_END(ID_AA64SMFR0_EL1)
> 
> IDREG_START(ID_AA64ZFR0_EL1)
> +    IDREG_FIELD(ID_AA64ZFR0_EL1, RES0, 60, 4)
>     IDREG_FIELD_START(ID_AA64ZFR0_EL1, F64MM, 56, 4)
>         IDREG_FIELD_ARCH_VAL(0)
>         IDREG_FIELD_ARCH_VAL(1)
> @@ -1235,10 +1269,12 @@ IDREG_START(ID_AA64ZFR0_EL1)
>         IDREG_FIELD_ARCH_VAL(0)
>         IDREG_FIELD_ARCH_VAL(1)
>     IDREG_FIELD_END(ID_AA64ZFR0_EL1, SM4)
> +    IDREG_FIELD(ID_AA64ZFR0_EL1, RES0, 36, 4)
>     IDREG_FIELD_START(ID_AA64ZFR0_EL1, SHA3, 32, 4)
>         IDREG_FIELD_ARCH_VAL(0)
>         IDREG_FIELD_ARCH_VAL(1)
>     IDREG_FIELD_END(ID_AA64ZFR0_EL1, SHA3)
> +    IDREG_FIELD(ID_AA64ZFR0_EL1, RES0, 28, 4)
>     IDREG_FIELD_START(ID_AA64ZFR0_EL1, B16B16, 24, 4)
>         IDREG_FIELD_ARCH_VAL(0)
>         IDREG_FIELD_ARCH_VAL(1)
> @@ -1258,6 +1294,7 @@ IDREG_START(ID_AA64ZFR0_EL1)
>         IDREG_FIELD_ARCH_VAL(0)
>         IDREG_FIELD_ARCH_VAL(1)
>     IDREG_FIELD_END(ID_AA64ZFR0_EL1, EltPerm)
> +    IDREG_FIELD(ID_AA64ZFR0_EL1, RES0, 8, 4)
>     IDREG_FIELD_START(ID_AA64ZFR0_EL1, AES, 4, 4)
>         IDREG_FIELD_ARCH_VAL(0)
>         IDREG_FIELD_ARCH_VAL(1)
> @@ -1274,9 +1311,11 @@ IDREG_START(ID_AA64ZFR0_EL1)
> IDREG_END(ID_AA64ZFR0_EL1)
> 
> IDREG_START(ID_AFR0_EL1)
> +    IDREG_FIELD(ID_AFR0_EL1, RES0, 0, 64)
> IDREG_END(ID_AFR0_EL1)
> 
> IDREG_START(ID_DFR0_EL1)
> +    IDREG_FIELD(ID_DFR0_EL1, RES0, 32, 32)
>     IDREG_FIELD_START(ID_DFR0_EL1, TraceFilt, 28, 4)
>         IDREG_FIELD_ARCH_VAL(0)
>         IDREG_FIELD_ARCH_VAL(1)
> @@ -1328,6 +1367,7 @@ IDREG_START(ID_DFR0_EL1)
> IDREG_END(ID_DFR0_EL1)
> 
> IDREG_START(ID_DFR1_EL1)
> +    IDREG_FIELD(ID_DFR1_EL1, RES0, 8, 56)
>     IDREG_FIELD_START(ID_DFR1_EL1, HPMN0, 4, 4)
>         IDREG_FIELD_ARCH_VAL(0)
>         IDREG_FIELD_ARCH_VAL(1)
> @@ -1340,6 +1380,7 @@ IDREG_START(ID_DFR1_EL1)
> IDREG_END(ID_DFR1_EL1)
> 
> IDREG_START(ID_ISAR0_EL1)
> +    IDREG_FIELD(ID_ISAR0_EL1, RES0, 28, 36)
>     IDREG_FIELD_START(ID_ISAR0_EL1, Divide, 24, 4)
>         IDREG_FIELD_ARCH_VAL(0)
>         IDREG_FIELD_ARCH_VAL(1)
> @@ -1375,6 +1416,7 @@ IDREG_START(ID_ISAR0_EL1)
> IDREG_END(ID_ISAR0_EL1)
> 
> IDREG_START(ID_ISAR1_EL1)
> +    IDREG_FIELD(ID_ISAR1_EL1, RES0, 32, 32)
>     IDREG_FIELD_START(ID_ISAR1_EL1, Jazelle, 28, 4)
>         IDREG_FIELD_ARCH_VAL(0)
>         IDREG_FIELD_ARCH_VAL(1)
> @@ -1413,6 +1455,7 @@ IDREG_START(ID_ISAR1_EL1)
> IDREG_END(ID_ISAR1_EL1)
> 
> IDREG_START(ID_ISAR2_EL1)
> +    IDREG_FIELD(ID_ISAR2_EL1, RES0, 32, 32)
>     IDREG_FIELD_START(ID_ISAR2_EL1, Reversal, 28, 4)
>         IDREG_FIELD_ARCH_VAL(0)
>         IDREG_FIELD_ARCH_VAL(1)
> @@ -1458,6 +1501,7 @@ IDREG_START(ID_ISAR2_EL1)
> IDREG_END(ID_ISAR2_EL1)
> 
> IDREG_START(ID_ISAR3_EL1)
> +    IDREG_FIELD(ID_ISAR3_EL1, RES0, 32, 32)
>     IDREG_FIELD_START(ID_ISAR3_EL1, T32EE, 28, 4)
>         IDREG_FIELD_ARCH_VAL(0)
>         IDREG_FIELD_ARCH_VAL(1)
> @@ -1495,6 +1539,7 @@ IDREG_START(ID_ISAR3_EL1)
> IDREG_END(ID_ISAR3_EL1)
> 
> IDREG_START(ID_ISAR4_EL1)
> +    IDREG_FIELD(ID_ISAR4_EL1, RES0, 32, 32)
>     IDREG_FIELD_START(ID_ISAR4_EL1, SWP_frac, 28, 4)
>         IDREG_FIELD_ARCH_VAL(0)
>         IDREG_FIELD_ARCH_VAL(1)
> @@ -1519,12 +1564,12 @@ IDREG_START(ID_ISAR4_EL1)
>         IDREG_FIELD_ARCH_VAL(0)
>         IDREG_FIELD_ARCH_VAL(1)
>     IDREG_FIELD_END(ID_ISAR4_EL1, Writeback)
> -    IDREG_FIELD_START(ID_ISAR4_EL1, WithShifts, 4, 4)
> +    IDREG_FIELD_START(ID_ISAR4_EL1, WI, 4, 4)
>         IDREG_FIELD_ARCH_VAL(0)
>         IDREG_FIELD_ARCH_VAL(1)
>         IDREG_FIELD_ARCH_VAL(3)
>         IDREG_FIELD_ARCH_VAL(4)
> -    IDREG_FIELD_END(ID_ISAR4_EL1, WithShifts)
> +    IDREG_FIELD_END(ID_ISAR4_EL1, WI)
>     IDREG_FIELD_START(ID_ISAR4_EL1, Unpriv, 0, 4)
>         IDREG_FIELD_ARCH_VAL(0)
>         IDREG_FIELD_ARCH_VAL(1)
> @@ -1533,6 +1578,7 @@ IDREG_START(ID_ISAR4_EL1)
> IDREG_END(ID_ISAR4_EL1)
> 
> IDREG_START(ID_ISAR5_EL1)
> +    IDREG_FIELD(ID_ISAR5_EL1, RES0, 32, 32)
>     IDREG_FIELD_START(ID_ISAR5_EL1, VCMA, 28, 4)
>         IDREG_FIELD_ARCH_VAL(0)
>         IDREG_FIELD_ARCH_VAL(1)
> @@ -1541,6 +1587,7 @@ IDREG_START(ID_ISAR5_EL1)
>         IDREG_FIELD_ARCH_VAL(0)
>         IDREG_FIELD_ARCH_VAL(1)
>     IDREG_FIELD_END(ID_ISAR5_EL1, RDM)
> +    IDREG_FIELD(ID_ISAR5_EL1, RES0, 20, 4)
>     IDREG_FIELD_START(ID_ISAR5_EL1, CRC32, 16, 4)
>         IDREG_FIELD_ARCH_VAL(0)
>         IDREG_FIELD_ARCH_VAL(1)
> @@ -1565,6 +1612,7 @@ IDREG_START(ID_ISAR5_EL1)
> IDREG_END(ID_ISAR5_EL1)
> 
> IDREG_START(ID_ISAR6_EL1)
> +    IDREG_FIELD(ID_ISAR6_EL1, RES0, 32, 32)
>     IDREG_FIELD_START(ID_ISAR6_EL1, CLRBHB, 28, 4)
>         IDREG_FIELD_ARCH_VAL(0)
>         IDREG_FIELD_ARCH_VAL(1)
> @@ -1601,6 +1649,7 @@ IDREG_START(ID_ISAR6_EL1)
> IDREG_END(ID_ISAR6_EL1)
> 
> IDREG_START(ID_MMFR0_EL1)
> +    IDREG_FIELD(ID_MMFR0_EL1, RES0, 32, 32)
>     IDREG_FIELD_START(ID_MMFR0_EL1, InnerShr, 28, 4)
>         IDREG_FIELD_ARCH_VAL(0)
>         IDREG_FIELD_ARCH_VAL(1)
> @@ -1647,6 +1696,7 @@ IDREG_START(ID_MMFR0_EL1)
> IDREG_END(ID_MMFR0_EL1)
> 
> IDREG_START(ID_MMFR1_EL1)
> +    IDREG_FIELD(ID_MMFR1_EL1, RES0, 32, 32)
>     IDREG_FIELD_START(ID_MMFR1_EL1, BPred, 28, 4)
>         IDREG_FIELD_ARCH_VAL(0)
>         IDREG_FIELD_ARCH_VAL(1)
> @@ -1695,6 +1745,7 @@ IDREG_START(ID_MMFR1_EL1)
> IDREG_END(ID_MMFR1_EL1)
> 
> IDREG_START(ID_MMFR2_EL1)
> +    IDREG_FIELD(ID_MMFR2_EL1, RES0, 32, 32)
>     IDREG_FIELD_START(ID_MMFR2_EL1, HWAccFlg, 28, 4)
>         IDREG_FIELD_ARCH_VAL(0)
>         IDREG_FIELD_ARCH_VAL(1)
> @@ -1733,6 +1784,7 @@ IDREG_START(ID_MMFR2_EL1)
> IDREG_END(ID_MMFR2_EL1)
> 
> IDREG_START(ID_MMFR3_EL1)
> +    IDREG_FIELD(ID_MMFR3_EL1, RES0, 32, 32)
>     IDREG_FIELD_START(ID_MMFR3_EL1, Supersec, 28, 4)
>         IDREG_FIELD_ARCH_VAL(0)
>         IDREG_FIELD_ARCH_VAL(15)
> @@ -1772,6 +1824,7 @@ IDREG_START(ID_MMFR3_EL1)
> IDREG_END(ID_MMFR3_EL1)
> 
> IDREG_START(ID_MMFR4_EL1)
> +    IDREG_FIELD(ID_MMFR4_EL1, RES0, 32, 32)
>     IDREG_FIELD_START(ID_MMFR4_EL1, EVT, 28, 4)
>         IDREG_FIELD_ARCH_VAL(0)
>         IDREG_FIELD_ARCH_VAL(1)
> @@ -1809,6 +1862,7 @@ IDREG_START(ID_MMFR4_EL1)
> IDREG_END(ID_MMFR4_EL1)
> 
> IDREG_START(ID_MMFR5_EL1)
> +    IDREG_FIELD(ID_MMFR5_EL1, RES0, 8, 56)
>     IDREG_FIELD_START(ID_MMFR5_EL1, nTLBPA, 4, 4)
>         IDREG_FIELD_ARCH_VAL(0)
>         IDREG_FIELD_ARCH_VAL(1)
> @@ -1822,6 +1876,7 @@ IDREG_START(ID_MMFR5_EL1)
> IDREG_END(ID_MMFR5_EL1)
> 
> IDREG_START(ID_PFR0_EL1)
> +    IDREG_FIELD(ID_PFR0_EL1, RES0, 32, 32)
>     IDREG_FIELD_START(ID_PFR0_EL1, RAS, 28, 4)
>         IDREG_FIELD_ARCH_VAL(0)
>         IDREG_FIELD_ARCH_VAL(1)
> @@ -1863,6 +1918,7 @@ IDREG_START(ID_PFR0_EL1)
> IDREG_END(ID_PFR0_EL1)
> 
> IDREG_START(ID_PFR1_EL1)
> +    IDREG_FIELD(ID_PFR1_EL1, RES0, 32, 32)
>     IDREG_FIELD_START(ID_PFR1_EL1, GIC, 28, 4)
>         IDREG_FIELD_ARCH_VAL(0)
>         IDREG_FIELD_ARCH_VAL(1)
> @@ -1902,6 +1958,7 @@ IDREG_START(ID_PFR1_EL1)
> IDREG_END(ID_PFR1_EL1)
> 
> IDREG_START(ID_PFR2_EL1)
> +    IDREG_FIELD(ID_PFR2_EL1, RES0, 12, 52)
>     IDREG_FIELD_START(ID_PFR2_EL1, RAS_frac, 8, 4)
>         IDREG_FIELD_ARCH_VAL(0)
>         IDREG_FIELD_ARCH_VAL(1)
> @@ -1949,11 +2006,14 @@ IDREG_START(MIDR_EL1)
> IDREG_END(MIDR_EL1)
> 
> IDREG_START(MPIDR_EL1)
> +    IDREG_FIELD(MPIDR_EL1, RES0, 40, 24)
>     IDREG_FIELD(MPIDR_EL1, Aff3, 32, 8)
> +    IDREG_FIELD(MPIDR_EL1, RES1, 31, 1)
>     IDREG_FIELD_START(MPIDR_EL1, U, 30, 1)
>         IDREG_FIELD_ARCH_VAL(0)
>         IDREG_FIELD_ARCH_VAL(1)
>     IDREG_FIELD_END(MPIDR_EL1, U)
> +    IDREG_FIELD(MPIDR_EL1, RES0, 25, 5)
>     IDREG_FIELD_START(MPIDR_EL1, MT, 24, 1)
>         IDREG_FIELD_ARCH_VAL(0)
>         IDREG_FIELD_ARCH_VAL(1)
> @@ -1964,6 +2024,7 @@ IDREG_START(MPIDR_EL1)
> IDREG_END(MPIDR_EL1)
> 
> IDREG_START(MVFR0_EL1)
> +    IDREG_FIELD(MVFR0_EL1, RES0, 32, 32)
>     IDREG_FIELD_START(MVFR0_EL1, FPRound, 28, 4)
>         IDREG_FIELD_ARCH_VAL(0)
>         IDREG_FIELD_ARCH_VAL(1)
> @@ -2002,6 +2063,7 @@ IDREG_START(MVFR0_EL1)
> IDREG_END(MVFR0_EL1)
> 
> IDREG_START(MVFR1_EL1)
> +    IDREG_FIELD(MVFR1_EL1, RES0, 32, 32)
>     IDREG_FIELD_START(MVFR1_EL1, SIMDFMAC, 28, 4)
>         IDREG_FIELD_ARCH_VAL(0)
>         IDREG_FIELD_ARCH_VAL(1)
> @@ -2040,6 +2102,7 @@ IDREG_START(MVFR1_EL1)
> IDREG_END(MVFR1_EL1)
> 
> IDREG_START(MVFR2_EL1)
> +    IDREG_FIELD(MVFR2_EL1, RES0, 8, 56)
>     IDREG_FIELD_START(MVFR2_EL1, FPMisc, 4, 4)
>         IDREG_FIELD_ARCH_VAL(0)
>         IDREG_FIELD_ARCH_VAL(1)
> @@ -2059,6 +2122,7 @@ IDREG_START(REVIDR_EL1)
> IDREG_END(REVIDR_EL1)
> 
> IDREG_START(SMIDR_EL1)
> +    IDREG_FIELD(SMIDR_EL1, RES0, 60, 4)
>     IDREG_FIELD_START(SMIDR_EL1, NSMC, 56, 4)
>         IDREG_FIELD_ARCH_VAL(0)
>         IDREG_FIELD_ARCH_VAL(15)
> @@ -2094,6 +2158,7 @@ IDREG_START(SMIDR_EL1)
>         IDREG_FIELD_ARCH_VAL(2)
>         IDREG_FIELD_ARCH_VAL(3)
>     IDREG_FIELD_END(SMIDR_EL1, SH)
> +    IDREG_FIELD(SMIDR_EL1, RES0, 12, 1)
>     IDREG_FIELD(SMIDR_EL1, Affinity, 0, 12)
> IDREG_END(SMIDR_EL1)
> 
> diff --git a/scripts/update-aarch64-cpu-sysreg-properties.py 
> b/scripts/update-aarch64-cpu-sysreg-properties.py
> index e1d6c4afef..9e829fda2e 100644
> --- a/scripts/update-aarch64-cpu-sysreg-properties.py
> +++ b/scripts/update-aarch64-cpu-sysreg-properties.py
> @@ -81,9 +81,13 @@ def collect_fields(item, bit_offset=0):
> 
>     # Normal Field Types
>     leaf_types = ['Fields.Field', 'Fields.ConstantField',
> -                  'Fields.EnumeratedField', 'Fields.Bitfield']
> +                  'Fields.EnumeratedField', 'Fields.Bitfield', 
> 'Fields.Reserved']
>     if _type in leaf_types:
>         field_copy = item.copy()
> +
> +        if _type == 'Fields.Reserved' and not field_copy.get('name'):
> +            field_copy['name'] = item.get('value', 'RES0')
> +
>         if field_copy.get('rangeset'):
>             new_ranges = []
>             for r in field_copy['rangeset']:
> @@ -96,7 +100,7 @@ def collect_fields(item, bit_offset=0):
>         return fields
> 
>     # Traverse the hierarchy for other cases
> -    for key in ['fields', 'values', 'fieldsets']:
> +    for key in ['fields', 'values', 'fieldsets', 'constants']:
>         for nested in item.get(key, []):
>             fields.extend(collect_fields(nested, bit_offset))
> 
> @@ -163,44 +167,95 @@ def 
> generate_sysreg_properties_from_registers_json(id_reg_names, raw_json_path):
> 
>         final_output += f"IDREG_START({reg_name})\n"
> 
> -        unique_fields = {}
> +        fieldset_variants = []
> +
>         for fieldset in register.get('fieldsets', []):
> +            current_fieldset_fields = {}
>             candidates = collect_fields(fieldset)
> +
>             for val in candidates:
> -                name = (val.get('name') or val.get('label', '')).strip()
> -                if not name or "RESERVED" in name.upper():
> +                raw_name = val.get('name') or val.get('label') or 
> val.get('value') or ''
> +                name = raw_name.strip()
> +                if not name:
>                     continue
> +
> +                name_upper = name.upper()
> +
> +                # Check for architectural target states, including UNKNOWN 
> remapping
> +                base_reserved = None
> +                for r_type in ["RES0", "RES1", "RAZ", "RAO", "WI", 
> "UNKNOWN"]:
> +                    if r_type in name_upper:
> +                        base_reserved = "RES0" if r_type == "UNKNOWN" else 
> r_type
> +                        break
> +
> +                is_valid_reserved = base_reserved is not None
> +                if "RESERVED" in name_upper and not is_valid_reserved:
> +                    continue
> +
> +                # Force naming uniformity across padding blocks
> +                if is_valid_reserved:
> +                    name = base_reserved
> +
>                 for r in val.get('rangeset', []):
>                     lsb = int(r.get('start'))
>                     width = r.get('width')
>                     msb = lsb + int(width) - 1
> 
> -                    # Only keep the fields with the highest MSB
> -                    # needed fir CCSIDR_EL1
> -                    if name not in unique_fields or msb > 
> unique_fields[name]['msb']:
> -                        # extract enum values if any
> +                    if is_valid_reserved:
> +                        unique_key = f"{name}_{lsb}"
> +                    else:
> +                        unique_key = name
> +
> +                    if unique_key not in current_fieldset_fields or \
> +                       msb > current_fieldset_fields[unique_key]['msb']:
>                         enums = extract_field_enums(val)
> -                        unique_fields[name] = {'lsb': lsb, 'msb': msb, 
> 'width': width, 'enums': enums}
> +                        current_fieldset_fields[unique_key] = {
> +                            'raw_name': name,
> +                            'lsb': lsb,
> +                            'msb': msb,
> +                            'width': width,
> +                            'enums': enums
> +                        }
> +
> +            if current_fieldset_fields:
> +                fieldset_variants.append(current_fieldset_fields)
> +
> +        best_fieldset = {}
> +        max_total_width = -1
> +
> +        for variant in fieldset_variants:
> +            total_width = sum(f['width'] for f in variant.values())
> +            # prioritize layout variants with the highest MSB coverage
> +            max_msb = max(f['msb'] for f in variant.values()) if variant 
> else 0
> +
> +            # Combine width and max_msb into a fitness score tuple
> +            if (total_width, max_msb) > (max_total_width, max_total_width):
> +                max_total_width = total_width
> +                best_fieldset = variant
> +
> +        unique_fields = best_fieldset
> 
>         # Sort decreasing lsbs
>         sorted_fields = sorted(unique_fields.items(),
>                                key=lambda x: x[1]['lsb'], reverse=True)
> 
> -        for name, bits in sorted_fields:
> +        for unique_key, bits in sorted_fields:
>             enums_list = bits.get('enums', [])
> 
> +            clean_name = bits.get('raw_name', unique_key)
> +
>             if enums_list:
>                line = (f"    IDREG_FIELD_START({reg_name}, "
> -                       f"{name}, {bits['lsb']}, {bits['width']})\n")
> +                       f"{clean_name}, {bits['lsb']}, {bits['width']})\n")
>             else:
>                line = (f"    IDREG_FIELD({reg_name}, "
> -                       f"{name}, {bits['lsb']}, {bits['width']})\n")
> +                       f"{clean_name}, {bits['lsb']}, {bits['width']})\n")
>             final_output += line
>             # add the enum value definition if any
>             for enum_item in enums_list:
>                 final_output += (f"        
> IDREG_FIELD_ARCH_VAL({enum_item['value']})\n")
>             if enums_list:
> -               line = (f"    IDREG_FIELD_END({reg_name}, {name})\n")
> +               line = (f"    IDREG_FIELD_END({reg_name}, {clean_name})\n")
>                final_output += line
> 
>         final_output += f"IDREG_END({reg_name})\n"
> -- 
> 2.53.0
> 

Reply via email to