diff options
| author | Marc Zyngier <maz@kernel.org> | 2023-01-12 11:38:46 +0900 | 
|---|---|---|
| committer | Oliver Upton <oliver.upton@linux.dev> | 2023-01-12 21:07:43 +0000 | 
| commit | e2c0b51f1c9dacc68292ce9ebffbfd4204d1ca58 (patch) | |
| tree | bf6566fea3cd957b06ca4c5667b0f0329e0adb50 | |
| parent | b7bfaa761d760e72a969d116517eaa12e404c262 (diff) | |
arm64: Allow the definition of UNKNOWN system register fields
The CCSIDR_EL1 register contains an UNKNOWN field (which replaces
fields that were actually defined in previous revisions of the
architecture).
Define an 'Unkn' field type modeled after the Res0/Res1 types
to allow such description. This allows the generation of
  #define CCSIDR_EL1_UNKN     (UL(0) | GENMASK_ULL(31, 28))
which may have its use one day. Hopefully the architecture doesn't
add too many of those in the future.
Signed-off-by: Marc Zyngier <maz@kernel.org>
Signed-off-by: Akihiko Odaki <akihiko.odaki@gmail.com>
Reviewed-by: Mark Brown <broonie@kernel.org>
Link: https://lore.kernel.org/r/20230112023852.42012-2-akihiko.odaki@daynix.com
Signed-off-by: Oliver Upton <oliver.upton@linux.dev>
| -rwxr-xr-x | arch/arm64/tools/gen-sysreg.awk | 20 | ||||
| -rw-r--r-- | arch/arm64/tools/sysreg | 2 | 
2 files changed, 21 insertions, 1 deletions
diff --git a/arch/arm64/tools/gen-sysreg.awk b/arch/arm64/tools/gen-sysreg.awk index c350164a3955..e1df4b956596 100755 --- a/arch/arm64/tools/gen-sysreg.awk +++ b/arch/arm64/tools/gen-sysreg.awk @@ -98,6 +98,7 @@ END {  	res0 = "UL(0)"  	res1 = "UL(0)" +	unkn = "UL(0)"  	next_bit = 63 @@ -112,11 +113,13 @@ END {  	define(reg "_RES0", "(" res0 ")")  	define(reg "_RES1", "(" res1 ")") +	define(reg "_UNKN", "(" unkn ")")  	print ""  	reg = null  	res0 = null  	res1 = null +	unkn = null  	next  } @@ -134,6 +137,7 @@ END {  	res0 = "UL(0)"  	res1 = "UL(0)" +	unkn = "UL(0)"  	define("REG_" reg, "S" op0 "_" op1 "_C" crn "_C" crm "_" op2)  	define("SYS_" reg, "sys_reg(" op0 ", " op1 ", " crn ", " crm ", " op2 ")") @@ -161,7 +165,9 @@ END {  		define(reg "_RES0", "(" res0 ")")  	if (res1 != null)  		define(reg "_RES1", "(" res1 ")") -	if (res0 != null || res1 != null) +	if (unkn != null) +		define(reg "_UNKN", "(" unkn ")") +	if (res0 != null || res1 != null || unkn != null)  		print ""  	reg = null @@ -172,6 +178,7 @@ END {  	op2 = null  	res0 = null  	res1 = null +	unkn = null  	next  } @@ -190,6 +197,7 @@ END {          next_bit = 0  	res0 = null  	res1 = null +	unkn = null  	next  } @@ -215,6 +223,16 @@ END {  	next  } +/^Unkn/ && (block == "Sysreg" || block == "SysregFields") { +	expect_fields(2) +	parse_bitdef(reg, "UNKN", $2) +	field = "UNKN_" msb "_" lsb + +	unkn = unkn " | GENMASK_ULL(" msb ", " lsb ")" + +	next +} +  /^Field/ && (block == "Sysreg" || block == "SysregFields") {  	expect_fields(3)  	field = $3 diff --git a/arch/arm64/tools/sysreg b/arch/arm64/tools/sysreg index 184e58fd5631..f754265aec5f 100644 --- a/arch/arm64/tools/sysreg +++ b/arch/arm64/tools/sysreg @@ -15,6 +15,8 @@  # Res1	<msb>[:<lsb>] +# Unkn	<msb>[:<lsb>] +  # Field	<msb>[:<lsb>]	<name>  # Enum	<msb>[:<lsb>]	<name>  | 
