From: Cornelia Huck <cohuck@redhat.com>
To: Peter Maydell <peter.maydell@linaro.org>
Cc: eric.auger.pro@gmail.com, eric.auger@redhat.com,
qemu-devel@nongnu.org, qemu-arm@nongnu.org,
kvmarm@lists.linux.dev, richard.henderson@linaro.org,
alex.bennee@linaro.org, maz@kernel.org, oliver.upton@linux.dev,
sebott@redhat.com, shameerali.kolothum.thodi@huawei.com,
armbru@redhat.com, berrange@redhat.com, abologna@redhat.com,
jdenemar@redhat.com, agraf@csgraf.de, shahuang@redhat.com,
mark.rutland@arm.com, philmd@linaro.org, pbonzini@redhat.com
Subject: Re: [PATCH v7 12/14] arm/cpu: Add sysreg generation scripts
Date: Thu, 12 Jun 2025 17:42:58 +0200 [thread overview]
Message-ID: <877c1h9da5.fsf@redhat.com> (raw)
In-Reply-To: <CAFEAcA-xDxoRLWZCMrAEeSb3NvyyOPzYgFQbbEzGALujOOG-3g@mail.gmail.com>
On Thu, Jun 12 2025, Peter Maydell <peter.maydell@linaro.org> wrote:
> On Thu, 15 May 2025 at 16:40, Cornelia Huck <cohuck@redhat.com> wrote:
>>
>> From: Eric Auger <eric.auger@redhat.com>
>>
>> Introduce scripts that automate the generation of system register
>> definitions from a given linux source tree arch/arm64/tools/sysreg.
>>
>> Invocation of
>> ./update-aarch64-sysreg-code.sh $PATH_TO_LINUX_SOURCE_TREE
>> in scripts directory generates target/arm/cpu-sysregs.h.inc
>> containing defines for all system registers.
>>
>> [CH: update to handle current kernel sysregs structure, and to emit
>> the re-worked register structures; cpu properties will be added
>> later]
>> Reviewed-by: Sebastian Ott <sebott@redhat.com>
>> Signed-off-by: Eric Auger <eric.auger@redhat.com>
>> Signed-off-by: Cornelia Huck <cohuck@redhat.com>
>> ---
>
>> diff --git a/scripts/gen-cpu-sysregs-header.awk b/scripts/gen-cpu-sysregs-header.awk
>> new file mode 100755
>> index 000000000000..452e51035d52
>> --- /dev/null
>> +++ b/scripts/gen-cpu-sysregs-header.awk
>
> This should probably have 'arm' in the filename somewhere, unless
> it's really architecture-agnostic, which I don't think it is.
Nod.
>
>> @@ -0,0 +1,35 @@
>> +#!/bin/awk -f
>
> Does this really need to be in awk? Our standard scripting
> language is python. This isn't run at build time so there's
> no "extra dependency" issue, but we currently use awk only
> minimally and almost always for trivial stuff.
Much of this originally was inspired by the equivalent tooling in Linux
that creates definitions from the same sysreg file. (There's another,
more complicated awk script in the cpu model series that creates
definitions for the individual fields.) I can try to rewrite that in
python, but I think awk is actually not a bad tool to use here.
>
>> +# SPDX-License-Identifier: GPL-2.0-or-later
>> +# gen-cpu-sysregs-header.awk: arm64 sysreg header include generator
>> +#
>> +# Usage: awk -f gen-cpu-sysregs-header.awk $LINUX_PATH/arch/arm64/tools/sysreg
>> +
>> +BEGIN {
>> + print ""
>> +} END {
>> + print ""
>> +}
>> +
>> +# skip blank lines and comment lines
>> +/^$/ { next }
>> +/^[\t ]*#/ { next }
>> +
>> +/^Sysreg\t/ || /^Sysreg /{
>> +
>> + reg = $2
>> + op0 = $3
>> + op1 = $4
>> + crn = $5
>> + crm = $6
>> + op2 = $7
>> +
>> + if (op0 == 3 && (op1>=0 && op1<=3) && crn==0 && (crm>=0 && crm<=7) && (op2>=0 && op2<=7)) {
>> + print "DEF("reg", "op0", "op1", "crn", "crm", "op2")"
>> + }
>> + next
>> +}
>> +
>> +{
>> + /* skip all other lines */
>> + next
>> +}
>
> Generated source files should have a comment at the top
> noting that they're autogenerated and how to regenerate
> them, please.
ok
>
>> diff --git a/scripts/update-aarch64-sysreg-code.sh b/scripts/update-aarch64-sysreg-code.sh
>> new file mode 100755
>> index 000000000000..e34538887dd8
>> --- /dev/null
>> +++ b/scripts/update-aarch64-sysreg-code.sh
>> @@ -0,0 +1,26 @@
>> +#!/bin/sh -e
>> +#
>> +# SPDX-License-Identifier: GPL-2.0-or-later
>> +# Update target/arm/cpu-sysregs.h
>> +# from a linux source tree (arch/arm64/tools/sysreg)
>> +#
>> +# Copyright Red Hat, Inc. 2024
>> +#
>> +# Authors:
>> +# Eric Auger <eric.auger@redhat.com>
>> +#
>> +
>> +linux="$1"
>> +output="$PWD"
>
> We seem to set this but then not use it.
ok
>
>> +
>> +if [ -z "$linux" ] || ! [ -d "$linux" ]; then
>> + cat << EOF
>> +usage: update-aarch64-sysreg-code.sh LINUX_PATH
>> +
>> +LINUX_PATH Linux kernel directory to obtain the headers from
>> +EOF
>> + exit 1
>> +fi
>> +
>> +awk -f gen-cpu-sysregs-header.awk \
>> + $linux/arch/arm64/tools/sysreg > ../target/arm/cpu-sysregs.h.inc
>
> This looks like it is assuming that the user runs the script
> from within the scripts/ directory ?
>
> Following the same command line conventions as our existing
> scripts/update-linux-headers.sh is probably the least
> surprising thing.
Ok, will do.
next prev parent reply other threads:[~2025-06-12 15:43 UTC|newest]
Thread overview: 28+ messages / expand[flat|nested] mbox.gz Atom feed top
2025-05-15 15:38 [PATCH v7 00/14] arm: rework id register storage Cornelia Huck
2025-05-15 15:38 ` [PATCH v7 01/14] arm/cpu: Add sysreg definitions in cpu-sysregs.h Cornelia Huck
2025-05-15 15:38 ` [PATCH v7 02/14] arm/cpu: Store aa64isar0/aa64zfr0 into the idregs arrays Cornelia Huck
2025-06-12 15:04 ` Peter Maydell
2025-06-12 15:34 ` Cornelia Huck
2025-06-12 15:39 ` Peter Maydell
2025-05-15 15:38 ` [PATCH v7 03/14] arm/cpu: Store aa64isar1/2 into the idregs array Cornelia Huck
2025-05-15 15:38 ` [PATCH v7 04/14] arm/cpu: Store aa64pfr0/1 " Cornelia Huck
2025-05-15 15:38 ` [PATCH v7 05/14] arm/cpu: Store aa64mmfr0-3 " Cornelia Huck
2025-05-15 15:38 ` [PATCH v7 06/14] arm/cpu: Store aa64dfr0/1 " Cornelia Huck
2025-05-15 15:39 ` [PATCH v7 07/14] arm/cpu: Store aa64smfr0 " Cornelia Huck
2025-05-15 15:39 ` [PATCH v7 08/14] arm/cpu: Store id_isar0-7 " Cornelia Huck
2025-06-12 15:16 ` Peter Maydell
2025-06-12 15:36 ` Cornelia Huck
2025-06-12 15:39 ` Peter Maydell
2025-06-12 15:53 ` Cornelia Huck
2025-05-15 15:39 ` [PATCH v7 09/14] arm/cpu: Store id_pfr0/1/2 " Cornelia Huck
2025-05-15 15:39 ` [PATCH v7 10/14] arm/cpu: Store id_dfr0/1 " Cornelia Huck
2025-05-15 15:39 ` [PATCH v7 11/14] arm/cpu: Store id_mmfr0-5 " Cornelia Huck
2025-05-15 15:39 ` [PATCH v7 12/14] arm/cpu: Add sysreg generation scripts Cornelia Huck
2025-06-12 15:29 ` Peter Maydell
2025-06-12 15:42 ` Cornelia Huck [this message]
2025-05-15 15:39 ` [PATCH v7 13/14] arm/cpu: switch to a generated cpu-sysregs.h.inc Cornelia Huck
2025-06-12 15:35 ` Peter Maydell
2025-06-12 16:07 ` Cornelia Huck
2025-05-15 15:39 ` [PATCH v7 14/14] arm/kvm: use fd instead of fdarray[2] Cornelia Huck
2025-06-06 9:53 ` [PATCH v7 00/14] arm: rework id register storage Cornelia Huck
2025-06-12 15:36 ` Peter Maydell
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=877c1h9da5.fsf@redhat.com \
--to=cohuck@redhat.com \
--cc=abologna@redhat.com \
--cc=agraf@csgraf.de \
--cc=alex.bennee@linaro.org \
--cc=armbru@redhat.com \
--cc=berrange@redhat.com \
--cc=eric.auger.pro@gmail.com \
--cc=eric.auger@redhat.com \
--cc=jdenemar@redhat.com \
--cc=kvmarm@lists.linux.dev \
--cc=mark.rutland@arm.com \
--cc=maz@kernel.org \
--cc=oliver.upton@linux.dev \
--cc=pbonzini@redhat.com \
--cc=peter.maydell@linaro.org \
--cc=philmd@linaro.org \
--cc=qemu-arm@nongnu.org \
--cc=qemu-devel@nongnu.org \
--cc=richard.henderson@linaro.org \
--cc=sebott@redhat.com \
--cc=shahuang@redhat.com \
--cc=shameerali.kolothum.thodi@huawei.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox