docs/system/arm/cpu-features.rst | 104 +++- scripts/gen-cpu-sysreg-properties.awk | 325 ++++++++++++ scripts/update-aarch64-sysreg-code.sh | 5 +- target/arm/arm-qmp-cmds.c | 19 + target/arm/cpu-custom.h | 60 +++ target/arm/cpu-sysreg-properties.c | 713 ++++++++++++++++++++++++++ target/arm/cpu-sysregs.h | 2 + target/arm/cpu.c | 12 + target/arm/cpu.h | 47 ++ target/arm/cpu64.c | 24 +- target/arm/kvm.c | 289 ++++++++++- target/arm/kvm_arm.h | 26 +- target/arm/meson.build | 1 + target/arm/trace-events | 6 + 14 files changed, 1617 insertions(+), 16 deletions(-) create mode 100755 scripts/gen-cpu-sysreg-properties.awk create mode 100644 target/arm/cpu-custom.h create mode 100644 target/arm/cpu-sysreg-properties.c
[This is on top of v5 of the ID register storage rework: https://lore.kernel.org/qemu-devel/20250409144304.912325-1-cohuck@redhat.com/T/#t] It's been a while, but here's finally a respin of the series to make ID registers configurable directly via the command line. Major changes from v2 include: - split out the rework of ID register storage (see above) and rebased on top of that - hopefully improved the documentation - fixed some bugs along the way (including output of the cpu model expansion command, and compilation with HVF on) Decided against zeroing unknown registers; it's mostly a "dammed if you do, dammed if you don't" situation as one case or the other will not quite work as desired, even disregarding fields like AA64PFR1_EL1.MTE_frac where 0 might indicate things we do not support. You'll need to be careful when doing kernel updates and be explicit with configuring fields. The current cpu properties stay as they are; we can work on converting them to compatibility props once we have support for configuring the ID register fields on the command line for the other accelerators (this is still KVM only.) The FEAT_xxx features only support a subset of what we need to configure in real life; for example, different AltraMax machines differ in CTR_EL0, which is not covered by any FEAT_. It might make sense to provide them as syntactic sugar on top. We still have to deal with MIDR/REVIDR/AIDR differences by exploiting https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git/commit?id=d300b0168ea8fd5022a1413bd37ab63f4e5a7d4d (in a different series.) I have not ignored the issue of named models on Arm, I just wanted to get the base infrastructure into place first :) Real world example (migration Graviton 3 -> 4, thx to Sebastian): -cpu host,pauth=off,SYSREG_ID_AA64PFR0_EL1_SEL2=0,SYSREG_ID_AA64PFR0_EL1_EL0=1, SYSREG_ID_AA64ISAR0_EL1_TLB=0,SYSREG_ID_AA64ISAR0_EL1_TS=0, SYSREG_ID_AA64ISAR0_EL1_SM4=0,SYSREG_ID_AA64ISAR0_EL1_SM3=0, SYSREG_ID_AA64ISAR1_EL1_SPECRES=0,SYSREG_ID_AA64ISAR1_EL1_SB=0, SYSREG_ID_AA64ISAR1_EL1_FRINTTS=0,SYSREG_ID_AA64MMFR0_EL1_TGRAN4_2=1, SYSREG_ID_AA64MMFR0_EL1_TGRAN16_2=1,SYSREG_ID_AA64MMFR0_EL1_TGRAN64_2=1 (not including handling MIDR differences, which is out of scope for this series) Code also available at https://gitlab.com/cohuck/qemu/-/tree/arm-cpu-model-rfcv3?ref_type=heads Cornelia Huck (5): arm/cpu: Add generated sysreg properties kvm: kvm_get_writable_id_regs arm/cpu: accessors for writable id registers arm-qmp-cmds: introspection for ID register props arm/cpu-features: document ID reg properties Eric Auger (5): arm/cpu: Add infra to handle generated ID register definitions arm/cpu: Add sysreg properties generation arm/kvm: Allow reading all the writable ID registers arm/kvm: write back modified ID regs to KVM arm/cpu: more customization for the kvm host cpu model docs/system/arm/cpu-features.rst | 104 +++- scripts/gen-cpu-sysreg-properties.awk | 325 ++++++++++++ scripts/update-aarch64-sysreg-code.sh | 5 +- target/arm/arm-qmp-cmds.c | 19 + target/arm/cpu-custom.h | 60 +++ target/arm/cpu-sysreg-properties.c | 713 ++++++++++++++++++++++++++ target/arm/cpu-sysregs.h | 2 + target/arm/cpu.c | 12 + target/arm/cpu.h | 47 ++ target/arm/cpu64.c | 24 +- target/arm/kvm.c | 289 ++++++++++- target/arm/kvm_arm.h | 26 +- target/arm/meson.build | 1 + target/arm/trace-events | 6 + 14 files changed, 1617 insertions(+), 16 deletions(-) create mode 100755 scripts/gen-cpu-sysreg-properties.awk create mode 100644 target/arm/cpu-custom.h create mode 100644 target/arm/cpu-sysreg-properties.c -- 2.49.0
Hi, > -----Original Message----- > From: Cornelia Huck <cohuck@redhat.com> > Sent: Monday, April 14, 2025 5:39 PM > To: eric.auger.pro@gmail.com; eric.auger@redhat.com; qemu- > devel@nongnu.org; qemu-arm@nongnu.org; kvmarm@lists.linux.dev; > peter.maydell@linaro.org; richard.henderson@linaro.org; > alex.bennee@linaro.org; maz@kernel.org; oliver.upton@linux.dev; > sebott@redhat.com; Shameerali Kolothum Thodi > <shameerali.kolothum.thodi@huawei.com>; armbru@redhat.com; > berrange@redhat.com; abologna@redhat.com; jdenemar@redhat.com > Cc: agraf@csgraf.de; shahuang@redhat.com; mark.rutland@arm.com; > philmd@linaro.org; pbonzini@redhat.com; Cornelia Huck > <cohuck@redhat.com> > Subject: [PATCH v3 00/10] kvm/arm: Introduce a customizable aarch64 KVM > host model [..] ) > > Code also available at > https://gitlab.com/cohuck/qemu/-/tree/arm-cpu-model- > rfcv3?ref_type=heads I had a spin with the above branch, but Qemu boot fails, ERROR:../target/arm/cpu64.c:57:get_sysreg_idx: code should not be reached Bail out! ERROR:../target/arm/cpu64.c:57:get_sysreg_idx: code should not be reached From a quick debug, it looks like the below path results in an invalid ID idx. kvm_arm_expose_idreg_properties() kvm_idx_to_idregs_idx(0) get_sysreg_idx(0xc000) --> id_register seems to start at 0xc008 Haven't debugged further. I am running against a 6.15-rc1 kernel after updating the Qemu branch by, ./update-aarch64-sysreg-code.sh path_to_6.15-rc1 Not sure I am missing anything. Please check and let me know. Thanks, Shameer
On Fri, May 23 2025, Shameerali Kolothum Thodi <shameerali.kolothum.thodi@huawei.com> wrote: > Hi, > >> -----Original Message----- >> From: Cornelia Huck <cohuck@redhat.com> >> Sent: Monday, April 14, 2025 5:39 PM >> To: eric.auger.pro@gmail.com; eric.auger@redhat.com; qemu- >> devel@nongnu.org; qemu-arm@nongnu.org; kvmarm@lists.linux.dev; >> peter.maydell@linaro.org; richard.henderson@linaro.org; >> alex.bennee@linaro.org; maz@kernel.org; oliver.upton@linux.dev; >> sebott@redhat.com; Shameerali Kolothum Thodi >> <shameerali.kolothum.thodi@huawei.com>; armbru@redhat.com; >> berrange@redhat.com; abologna@redhat.com; jdenemar@redhat.com >> Cc: agraf@csgraf.de; shahuang@redhat.com; mark.rutland@arm.com; >> philmd@linaro.org; pbonzini@redhat.com; Cornelia Huck >> <cohuck@redhat.com> >> Subject: [PATCH v3 00/10] kvm/arm: Introduce a customizable aarch64 KVM >> host model > > [..] > > ) >> >> Code also available at >> https://gitlab.com/cohuck/qemu/-/tree/arm-cpu-model- >> rfcv3?ref_type=heads > > I had a spin with the above branch, but Qemu boot fails, > > ERROR:../target/arm/cpu64.c:57:get_sysreg_idx: code should not be reached > Bail out! ERROR:../target/arm/cpu64.c:57:get_sysreg_idx: code should not be reached > > From a quick debug, it looks like the below path results in an invalid ID idx. > > kvm_arm_expose_idreg_properties() > kvm_idx_to_idregs_idx(0) > get_sysreg_idx(0xc000) --> id_register seems to start at 0xc008 > > Haven't debugged further. > > I am running against a 6.15-rc1 kernel after updating the Qemu branch by, > ./update-aarch64-sysreg-code.sh path_to_6.15-rc1 > > Not sure I am missing anything. Please check and let me know. Thanks for trying this out; I'll try to re-create this here. (I think I've messed up those conversion functions often enough...)
On Mon, May 26 2025, Cornelia Huck <cohuck@redhat.com> wrote: > On Fri, May 23 2025, Shameerali Kolothum Thodi <shameerali.kolothum.thodi@huawei.com> wrote: > >> Hi, >> >>> -----Original Message----- >>> From: Cornelia Huck <cohuck@redhat.com> >>> Sent: Monday, April 14, 2025 5:39 PM >>> To: eric.auger.pro@gmail.com; eric.auger@redhat.com; qemu- >>> devel@nongnu.org; qemu-arm@nongnu.org; kvmarm@lists.linux.dev; >>> peter.maydell@linaro.org; richard.henderson@linaro.org; >>> alex.bennee@linaro.org; maz@kernel.org; oliver.upton@linux.dev; >>> sebott@redhat.com; Shameerali Kolothum Thodi >>> <shameerali.kolothum.thodi@huawei.com>; armbru@redhat.com; >>> berrange@redhat.com; abologna@redhat.com; jdenemar@redhat.com >>> Cc: agraf@csgraf.de; shahuang@redhat.com; mark.rutland@arm.com; >>> philmd@linaro.org; pbonzini@redhat.com; Cornelia Huck >>> <cohuck@redhat.com> >>> Subject: [PATCH v3 00/10] kvm/arm: Introduce a customizable aarch64 KVM >>> host model >> >> [..] >> >> ) >>> >>> Code also available at >>> https://gitlab.com/cohuck/qemu/-/tree/arm-cpu-model- >>> rfcv3?ref_type=heads >> >> I had a spin with the above branch, but Qemu boot fails, >> >> ERROR:../target/arm/cpu64.c:57:get_sysreg_idx: code should not be reached >> Bail out! ERROR:../target/arm/cpu64.c:57:get_sysreg_idx: code should not be reached >> >> From a quick debug, it looks like the below path results in an invalid ID idx. >> >> kvm_arm_expose_idreg_properties() >> kvm_idx_to_idregs_idx(0) >> get_sysreg_idx(0xc000) --> id_register seems to start at 0xc008 >> >> Haven't debugged further. >> >> I am running against a 6.15-rc1 kernel after updating the Qemu branch by, >> ./update-aarch64-sysreg-code.sh path_to_6.15-rc1 >> >> Not sure I am missing anything. Please check and let me know. > > Thanks for trying this out; I'll try to re-create this here. > (I think I've messed up those conversion functions often enough...) The conversion functions are not at fault here, but we're missing registers. If we have MIDR and friends writable, they show up in the masks returned by the kernel, but they are not present in the kernel's sysreg file where we generate our definitions from, and kvm_idx_to_idregs_idx() asserts instead of returning an error, which is kind of suboptimal... So I see two possible ways to fix this: - add MIDR and friends to the kernel's sysreg file - add MIDR and friends in QEMU's cpu-sysregs.h.inc file, and only append generated definitions there First option means one more round trip, second options has more potential for messing things up if we keep stuff local to QEMU.
On Tue, May 27 2025, Cornelia Huck <cohuck@redhat.com> wrote:
> On Mon, May 26 2025, Cornelia Huck <cohuck@redhat.com> wrote:
>
>> On Fri, May 23 2025, Shameerali Kolothum Thodi <shameerali.kolothum.thodi@huawei.com> wrote:
>>
>>> Hi,
>>>
>>>> -----Original Message-----
>>>> From: Cornelia Huck <cohuck@redhat.com>
>>>> Sent: Monday, April 14, 2025 5:39 PM
>>>> To: eric.auger.pro@gmail.com; eric.auger@redhat.com; qemu-
>>>> devel@nongnu.org; qemu-arm@nongnu.org; kvmarm@lists.linux.dev;
>>>> peter.maydell@linaro.org; richard.henderson@linaro.org;
>>>> alex.bennee@linaro.org; maz@kernel.org; oliver.upton@linux.dev;
>>>> sebott@redhat.com; Shameerali Kolothum Thodi
>>>> <shameerali.kolothum.thodi@huawei.com>; armbru@redhat.com;
>>>> berrange@redhat.com; abologna@redhat.com; jdenemar@redhat.com
>>>> Cc: agraf@csgraf.de; shahuang@redhat.com; mark.rutland@arm.com;
>>>> philmd@linaro.org; pbonzini@redhat.com; Cornelia Huck
>>>> <cohuck@redhat.com>
>>>> Subject: [PATCH v3 00/10] kvm/arm: Introduce a customizable aarch64 KVM
>>>> host model
>>>
>>> [..]
>>>
>>> )
>>>>
>>>> Code also available at
>>>> https://gitlab.com/cohuck/qemu/-/tree/arm-cpu-model-
>>>> rfcv3?ref_type=heads
>>>
>>> I had a spin with the above branch, but Qemu boot fails,
>>>
>>> ERROR:../target/arm/cpu64.c:57:get_sysreg_idx: code should not be reached
>>> Bail out! ERROR:../target/arm/cpu64.c:57:get_sysreg_idx: code should not be reached
>>>
>>> From a quick debug, it looks like the below path results in an invalid ID idx.
>>>
>>> kvm_arm_expose_idreg_properties()
>>> kvm_idx_to_idregs_idx(0)
>>> get_sysreg_idx(0xc000) --> id_register seems to start at 0xc008
>>>
>>> Haven't debugged further.
>>>
>>> I am running against a 6.15-rc1 kernel after updating the Qemu branch by,
>>> ./update-aarch64-sysreg-code.sh path_to_6.15-rc1
>>>
>>> Not sure I am missing anything. Please check and let me know.
>>
>> Thanks for trying this out; I'll try to re-create this here.
>> (I think I've messed up those conversion functions often enough...)
>
> The conversion functions are not at fault here, but we're missing
> registers. If we have MIDR and friends writable, they show up in the
> masks returned by the kernel, but they are not present in the kernel's
> sysreg file where we generate our definitions from, and
> kvm_idx_to_idregs_idx() asserts instead of returning an error, which is
> kind of suboptimal...
>
> So I see two possible ways to fix this:
> - add MIDR and friends to the kernel's sysreg file
> - add MIDR and friends in QEMU's cpu-sysregs.h.inc file, and only append
> generated definitions there
>
> First option means one more round trip, second options has more
> potential for messing things up if we keep stuff local to QEMU.
With the patch below, things work for me with a 6.15+ kernel. It's a bit
messy, though, and raises questions (how do we want to handle those regs
across accelerators, for example, or how we can make sure that the code
is more robust when registers are added.)
My biggest question, however, is how this interacts with the framework
to provide lists of MIDR/REVIDR/AIDR for errata management. The hack
below adds properties to configure those regs, I guess we'd want to
suppress adding the props in order to avoid conflicts.
WDYT?
diff --git a/scripts/gen-cpu-sysreg-properties.awk b/scripts/gen-cpu-sysreg-properties.awk
index 6740e814f733..7afd9afd2650 100755
--- a/scripts/gen-cpu-sysreg-properties.awk
+++ b/scripts/gen-cpu-sysreg-properties.awk
@@ -109,6 +109,27 @@ END {
if (__current_block_depth != 0)
fatal("Missing terminator for " block_current() " block")
+ # Manually add MIDR/REVIDR/AIDR
+ print ""
+ print " /* MIDR_EL1 */"
+ print " ARM64SysReg *MIDR_EL1 = arm64_sysreg_get(MIDR_EL1_IDX);"
+ print " MIDR_EL1->name = \"MIDR_EL1\";"
+ print " arm64_sysreg_add_field(MIDR_EL1, \"Implementer\", 24, 31);"
+ print " arm64_sysreg_add_field(MIDR_EL1, \"Variant\", 20, 23);"
+ print " arm64_sysreg_add_field(MIDR_EL1, \"Architecture\", 16, 19);"
+ print " arm64_sysreg_add_field(MIDR_EL1, \"PartNum\", 4, 15);"
+ print " arm64_sysreg_add_field(MIDR_EL1, \"Revision\", 0, 3);"
+ print ""
+ print " /* REVIDR_EL1 */"
+ print " ARM64SysReg *REVIDR_EL1 = arm64_sysreg_get(REVIDR_EL1_IDX);"
+ print " REVIDR_EL1->name = \"REVIDR_EL1\";"
+ print " arm64_sysreg_add_field(REVIDR_EL1, \"IMPDEF\", 0, 63);"
+ print ""
+ print " /* AIDR_EL1 */"
+ print " ARM64SysReg *AIDR_EL1 = arm64_sysreg_get(AIDR_EL1_IDX);"
+ print " AIDR_EL1->name = \"AIDR_EL1\";"
+ print " arm64_sysreg_add_field(AIDR_EL1, \"IMPDEF\", 0, 63);"
+ print ""
print "}"
}
diff --git a/scripts/gen-cpu-sysregs-header.awk b/scripts/gen-cpu-sysregs-header.awk
index 452e51035d52..2eb561b693dc 100755
--- a/scripts/gen-cpu-sysregs-header.awk
+++ b/scripts/gen-cpu-sysregs-header.awk
@@ -7,7 +7,10 @@
BEGIN {
print ""
} END {
- print ""
+ /* add MIDR, REVIDR, and AIDR */
+ print "DEF(MIDR_EL1, 3, 0, 0, 0, 0)"
+ print "DEF(REVIDR_EL1, 3, 0, 0, 0, 6)"
+ print "DEF(AIDR_EL1, 3, 1, 0, 0, 7)"
}
# skip blank lines and comment lines
diff --git a/target/arm/cpu-sysreg-properties.c b/target/arm/cpu-sysreg-properties.c
index 29c4c8ada115..bc1ae5e1a224 100644
--- a/target/arm/cpu-sysreg-properties.c
+++ b/target/arm/cpu-sysreg-properties.c
@@ -715,4 +715,24 @@ void initialize_cpu_sysreg_properties(void)
/* For S2PIR_EL2 fields see PIRx_ELx */
+
+ /* MIDR_EL1 */
+ ARM64SysReg *MIDR_EL1 = arm64_sysreg_get(MIDR_EL1_IDX);
+ MIDR_EL1->name = "MIDR_EL1";
+ arm64_sysreg_add_field(MIDR_EL1, "Implementer", 24, 31);
+ arm64_sysreg_add_field(MIDR_EL1, "Variant", 20, 23);
+ arm64_sysreg_add_field(MIDR_EL1, "Architecture", 16, 19);
+ arm64_sysreg_add_field(MIDR_EL1, "PartNum", 4, 15);
+ arm64_sysreg_add_field(MIDR_EL1, "Revision", 0, 3);
+
+ /* REVIDR_EL1 */
+ ARM64SysReg *REVIDR_EL1 = arm64_sysreg_get(REVIDR_EL1_IDX);
+ REVIDR_EL1->name = "REVIDR_EL1";
+ arm64_sysreg_add_field(REVIDR_EL1, "IMPDEF", 0, 63);
+
+ /* AIDR_EL1 */
+ ARM64SysReg *AIDR_EL1 = arm64_sysreg_get(AIDR_EL1_IDX);
+ AIDR_EL1->name = "AIDR_EL1";
+ arm64_sysreg_add_field(AIDR_EL1, "IMPDEF", 0, 63);
+
}
diff --git a/target/arm/cpu-sysregs.h.inc b/target/arm/cpu-sysregs.h.inc
index 02aae133eb67..8f0927ce0422 100644
--- a/target/arm/cpu-sysregs.h.inc
+++ b/target/arm/cpu-sysregs.h.inc
@@ -49,4 +49,6 @@ DEF(SMIDR_EL1, 3, 1, 0, 0, 6)
DEF(CSSELR_EL1, 3, 2, 0, 0, 0)
DEF(CTR_EL0, 3, 3, 0, 0, 1)
DEF(DCZID_EL0, 3, 3, 0, 0, 7)
-
+DEF(MIDR_EL1, 3, 0, 0, 0, 0)
+DEF(REVIDR_EL1, 3, 0, 0, 0, 6)
+DEF(AIDR_EL1, 3, 1, 0, 0, 7)
diff --git a/target/arm/cpu64.c b/target/arm/cpu64.c
index 95bb728a77f1..7454f329157c 100644
--- a/target/arm/cpu64.c
+++ b/target/arm/cpu64.c
@@ -54,7 +54,7 @@ int get_sysreg_idx(ARMSysRegs sysreg)
switch (sysreg) {
#include "cpu-sysregs.h.inc"
}
- g_assert_not_reached();
+ return -1;
}
#undef DEF
Hi, On 4/14/25 6:38 PM, Cornelia Huck wrote: > [This is on top of v5 of the ID register storage rework: > https://lore.kernel.org/qemu-devel/20250409144304.912325-1-cohuck@redhat.com/T/#t] > > It's been a while, but here's finally a respin of the series to make ID > registers configurable directly via the command line. > > Major changes from v2 include: > - split out the rework of ID register storage (see above) and rebased on top > of that > - hopefully improved the documentation > - fixed some bugs along the way (including output of the cpu model expansion > command, and compilation with HVF on) > > Decided against zeroing unknown registers; it's mostly a "dammed if you do, > dammed if you don't" situation as one case or the other will not quite work > as desired, even disregarding fields like AA64PFR1_EL1.MTE_frac where 0 > might indicate things we do not support. You'll need to be careful when > doing kernel updates and be explicit with configuring fields. This is not totally clear to me. Is it possible to come with examples and also derive some guidelines to avoid pitfalls? I guess this kind of aknowledgement can be scary. > > The current cpu properties stay as they are; we can work on converting them > to compatibility props once we have support for configuring the ID register > fields on the command line for the other accelerators (this is still KVM only.) At least what can we do to make sure they are not inconsistent and work well together. Looks like a must have before being non RFC. > > The FEAT_xxx features only support a subset of what we need to configure in > real life; for example, different AltraMax machines differ in CTR_EL0, which > is not covered by any FEAT_. It might make sense to provide them as syntactic > sugar on top. I agree that anyway we will need an ID reg field granularity for some real life cases. On top of that we shall try to build higher level props matching to features as requested by an overwhelming majority in earlier comments. > > We still have to deal with MIDR/REVIDR/AIDR differences by exploiting > https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git/commit?id=d300b0168ea8fd5022a1413bd37ab63f4e5a7d4d > (in a different series.) Shameer, do you plan to contribute the qemu integration of this feature you developped on kernel side; or do you allow us to integrate it in this series? Thanks Eric > > I have not ignored the issue of named models on Arm, I just wanted to get the > base infrastructure into place first :) > > Real world example (migration Graviton 3 -> 4, thx to Sebastian): > > -cpu host,pauth=off,SYSREG_ID_AA64PFR0_EL1_SEL2=0,SYSREG_ID_AA64PFR0_EL1_EL0=1, > SYSREG_ID_AA64ISAR0_EL1_TLB=0,SYSREG_ID_AA64ISAR0_EL1_TS=0, > SYSREG_ID_AA64ISAR0_EL1_SM4=0,SYSREG_ID_AA64ISAR0_EL1_SM3=0, > SYSREG_ID_AA64ISAR1_EL1_SPECRES=0,SYSREG_ID_AA64ISAR1_EL1_SB=0, > SYSREG_ID_AA64ISAR1_EL1_FRINTTS=0,SYSREG_ID_AA64MMFR0_EL1_TGRAN4_2=1, > SYSREG_ID_AA64MMFR0_EL1_TGRAN16_2=1,SYSREG_ID_AA64MMFR0_EL1_TGRAN64_2=1 > > (not including handling MIDR differences, which is out of scope for this series) > > Code also available at > https://gitlab.com/cohuck/qemu/-/tree/arm-cpu-model-rfcv3?ref_type=heads > > > Cornelia Huck (5): > arm/cpu: Add generated sysreg properties > kvm: kvm_get_writable_id_regs > arm/cpu: accessors for writable id registers > arm-qmp-cmds: introspection for ID register props > arm/cpu-features: document ID reg properties > > Eric Auger (5): > arm/cpu: Add infra to handle generated ID register definitions > arm/cpu: Add sysreg properties generation > arm/kvm: Allow reading all the writable ID registers > arm/kvm: write back modified ID regs to KVM > arm/cpu: more customization for the kvm host cpu model > > docs/system/arm/cpu-features.rst | 104 +++- > scripts/gen-cpu-sysreg-properties.awk | 325 ++++++++++++ > scripts/update-aarch64-sysreg-code.sh | 5 +- > target/arm/arm-qmp-cmds.c | 19 + > target/arm/cpu-custom.h | 60 +++ > target/arm/cpu-sysreg-properties.c | 713 ++++++++++++++++++++++++++ > target/arm/cpu-sysregs.h | 2 + > target/arm/cpu.c | 12 + > target/arm/cpu.h | 47 ++ > target/arm/cpu64.c | 24 +- > target/arm/kvm.c | 289 ++++++++++- > target/arm/kvm_arm.h | 26 +- > target/arm/meson.build | 1 + > target/arm/trace-events | 6 + > 14 files changed, 1617 insertions(+), 16 deletions(-) > create mode 100755 scripts/gen-cpu-sysreg-properties.awk > create mode 100644 target/arm/cpu-custom.h > create mode 100644 target/arm/cpu-sysreg-properties.c >
> -----Original Message----- > From: Eric Auger <eric.auger@redhat.com> > Sent: Tuesday, May 13, 2025 4:30 PM > To: Cornelia Huck <cohuck@redhat.com>; eric.auger.pro@gmail.com; qemu- > devel@nongnu.org; qemu-arm@nongnu.org; kvmarm@lists.linux.dev; > peter.maydell@linaro.org; richard.henderson@linaro.org; > alex.bennee@linaro.org; maz@kernel.org; oliver.upton@linux.dev; > sebott@redhat.com; Shameerali Kolothum Thodi > <shameerali.kolothum.thodi@huawei.com>; armbru@redhat.com; > berrange@redhat.com; abologna@redhat.com; jdenemar@redhat.com > Cc: agraf@csgraf.de; shahuang@redhat.com; mark.rutland@arm.com; > philmd@linaro.org; pbonzini@redhat.com > Subject: Re: [PATCH v3 00/10] kvm/arm: Introduce a customizable aarch64 > KVM host model [...] > > We still have to deal with MIDR/REVIDR/AIDR differences by exploiting > > > https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git/commit?i > d=d300b0168ea8fd5022a1413bd37ab63f4e5a7d4d > > (in a different series.) > Shameer, do you plan to contribute the qemu integration of this feature > you developped on kernel side; or do you allow us to integrate it in > this series? Yes, it's on my ToDo list. I'll first go through this series and then work on adding the above support on top of it. Thanks, Shameer
On 5/14/25 3:47 PM, Shameerali Kolothum Thodi wrote: > >> -----Original Message----- >> From: Eric Auger <eric.auger@redhat.com> >> Sent: Tuesday, May 13, 2025 4:30 PM >> To: Cornelia Huck <cohuck@redhat.com>; eric.auger.pro@gmail.com; qemu- >> devel@nongnu.org; qemu-arm@nongnu.org; kvmarm@lists.linux.dev; >> peter.maydell@linaro.org; richard.henderson@linaro.org; >> alex.bennee@linaro.org; maz@kernel.org; oliver.upton@linux.dev; >> sebott@redhat.com; Shameerali Kolothum Thodi >> <shameerali.kolothum.thodi@huawei.com>; armbru@redhat.com; >> berrange@redhat.com; abologna@redhat.com; jdenemar@redhat.com >> Cc: agraf@csgraf.de; shahuang@redhat.com; mark.rutland@arm.com; >> philmd@linaro.org; pbonzini@redhat.com >> Subject: Re: [PATCH v3 00/10] kvm/arm: Introduce a customizable aarch64 >> KVM host model > [...] > >>> We still have to deal with MIDR/REVIDR/AIDR differences by exploiting >>> >> https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git/commit?i >> d=d300b0168ea8fd5022a1413bd37ab63f4e5a7d4d >>> (in a different series.) >> Shameer, do you plan to contribute the qemu integration of this feature >> you developped on kernel side; or do you allow us to integrate it in >> this series? > Yes, it's on my ToDo list. I'll first go through this series and then work on > adding the above support on top of it. OK. Thank you for your reply! Cheers Eric > > Thanks, > Shameer >
© 2016 - 2026 Red Hat, Inc.