1
The following changes since commit 7e7eb9f852a46b51a71ae9d82590b2e4d28827ee:
1
I don't have anything else queued up at the moment, so this is just
2
Richard's SME patches.
2
3
3
Merge remote-tracking branch 'remotes/armbru/tags/pull-qapi-2021-01-28' into staging (2021-01-28 22:43:18 +0000)
4
-- PMM
5
6
The following changes since commit 63b38f6c85acd312c2cab68554abf33adf4ee2b3:
7
8
Merge tag 'pull-target-arm-20220707' of https://git.linaro.org/people/pmaydell/qemu-arm into staging (2022-07-08 06:17:11 +0530)
4
9
5
are available in the Git repository at:
10
are available in the Git repository at:
6
11
7
https://git.linaro.org/people/pmaydell/qemu-arm.git tags/pull-target-arm-20210129
12
https://git.linaro.org/people/pmaydell/qemu-arm.git tags/pull-target-arm-20220711
8
13
9
for you to fetch changes up to 11749122e1a86866591306d43603d2795a3dea1a:
14
for you to fetch changes up to f9982ceaf26df27d15547a3a7990a95019e9e3a8:
10
15
11
hw/arm/stellaris: Remove board-creation reset of STELLARIS_SYS (2021-01-29 10:47:29 +0000)
16
linux-user/aarch64: Add SME related hwcap entries (2022-07-11 13:43:52 +0100)
12
17
13
----------------------------------------------------------------
18
----------------------------------------------------------------
14
target-arm queue:
19
target-arm:
15
* Implement ID_PFR2
20
* Implement SME emulation, for both system and linux-user
16
* Conditionalize DBGDIDR
17
* rename xlnx-zcu102.canbusN properties
18
* provide powerdown/reset mechanism for secure firmware on 'virt' board
19
* hw/misc: Fix arith overflow in NPCM7XX PWM module
20
* target/arm: Replace magic value by MMU_DATA_LOAD definition
21
* configure: fix preadv errors on Catalina macOS with new XCode
22
* Various configure and other cleanups in preparation for iOS support
23
* hvf: Add hypervisor entitlement to output binaries (needed for Big Sur)
24
* Implement pvpanic-pci device
25
* Convert the CMSDK timer devices to the Clock framework
26
21
27
----------------------------------------------------------------
22
----------------------------------------------------------------
28
Alexander Graf (1):
23
Richard Henderson (45):
29
hvf: Add hypervisor entitlement to output binaries
24
target/arm: Handle SME in aarch64_cpu_dump_state
25
target/arm: Add infrastructure for disas_sme
26
target/arm: Trap non-streaming usage when Streaming SVE is active
27
target/arm: Mark ADR as non-streaming
28
target/arm: Mark RDFFR, WRFFR, SETFFR as non-streaming
29
target/arm: Mark BDEP, BEXT, BGRP, COMPACT, FEXPA, FTSSEL as non-streaming
30
target/arm: Mark PMULL, FMMLA as non-streaming
31
target/arm: Mark FTSMUL, FTMAD, FADDA as non-streaming
32
target/arm: Mark SMMLA, UMMLA, USMMLA as non-streaming
33
target/arm: Mark string/histo/crypto as non-streaming
34
target/arm: Mark gather/scatter load/store as non-streaming
35
target/arm: Mark gather prefetch as non-streaming
36
target/arm: Mark LDFF1 and LDNF1 as non-streaming
37
target/arm: Mark LD1RO as non-streaming
38
target/arm: Add SME enablement checks
39
target/arm: Handle SME in sve_access_check
40
target/arm: Implement SME RDSVL, ADDSVL, ADDSPL
41
target/arm: Implement SME ZERO
42
target/arm: Implement SME MOVA
43
target/arm: Implement SME LD1, ST1
44
target/arm: Export unpredicated ld/st from translate-sve.c
45
target/arm: Implement SME LDR, STR
46
target/arm: Implement SME ADDHA, ADDVA
47
target/arm: Implement FMOPA, FMOPS (non-widening)
48
target/arm: Implement BFMOPA, BFMOPS
49
target/arm: Implement FMOPA, FMOPS (widening)
50
target/arm: Implement SME integer outer product
51
target/arm: Implement PSEL
52
target/arm: Implement REVD
53
target/arm: Implement SCLAMP, UCLAMP
54
target/arm: Reset streaming sve state on exception boundaries
55
target/arm: Enable SME for -cpu max
56
linux-user/aarch64: Clear tpidr2_el0 if CLONE_SETTLS
57
linux-user/aarch64: Reset PSTATE.SM on syscalls
58
linux-user/aarch64: Add SM bit to SVE signal context
59
linux-user/aarch64: Tidy target_restore_sigframe error return
60
linux-user/aarch64: Do not allow duplicate or short sve records
61
linux-user/aarch64: Verify extra record lock succeeded
62
linux-user/aarch64: Move sve record checks into restore
63
linux-user/aarch64: Implement SME signal handling
64
linux-user: Rename sve prctls
65
linux-user/aarch64: Implement PR_SME_GET_VL, PR_SME_SET_VL
66
target/arm: Only set ZEN in reset if SVE present
67
target/arm: Enable SME for user-only
68
linux-user/aarch64: Add SME related hwcap entries
30
69
31
Hao Wu (1):
70
docs/system/arm/emulation.rst | 4 +
32
hw/misc: Fix arith overflow in NPCM7XX PWM module
71
linux-user/aarch64/target_cpu.h | 5 +-
33
72
linux-user/aarch64/target_prctl.h | 62 +-
34
Joelle van Dyne (7):
73
target/arm/cpu.h | 7 +
35
configure: cross-compiling with empty cross_prefix
74
target/arm/helper-sme.h | 126 ++++
36
osdep: build with non-working system() function
75
target/arm/helper-sve.h | 4 +
37
darwin: remove redundant dependency declaration
76
target/arm/helper.h | 18 +
38
darwin: fix cross-compiling for Darwin
77
target/arm/translate-a64.h | 45 ++
39
configure: cross compile should use x86_64 cpu_family
78
target/arm/translate.h | 16 +
40
darwin: detect CoreAudio for build
79
target/arm/sme-fa64.decode | 60 ++
41
darwin: remove 64-bit build detection on 32-bit OS
80
target/arm/sme.decode | 88 +++
42
81
target/arm/sve.decode | 41 +-
43
Maxim Uvarov (3):
82
linux-user/aarch64/cpu_loop.c | 9 +
44
hw: gpio: implement gpio-pwr driver for qemu reset/poweroff
83
linux-user/aarch64/signal.c | 243 ++++++--
45
arm-virt: refactor gpios creation
84
linux-user/elfload.c | 20 +
46
arm-virt: add secure pl061 for reset/power down
85
linux-user/syscall.c | 28 +-
47
86
target/arm/cpu.c | 35 +-
48
Mihai Carabas (4):
87
target/arm/cpu64.c | 11 +
49
hw/misc/pvpanic: split-out generic and bus dependent code
88
target/arm/helper.c | 56 +-
50
hw/misc/pvpanic: add PCI interface support
89
target/arm/sme_helper.c | 1140 +++++++++++++++++++++++++++++++++++++
51
pvpanic : update pvpanic spec document
90
target/arm/sve_helper.c | 28 +
52
tests/qtest: add a test case for pvpanic-pci
91
target/arm/translate-a64.c | 103 +++-
53
92
target/arm/translate-sme.c | 373 ++++++++++++
54
Paolo Bonzini (1):
93
target/arm/translate-sve.c | 393 ++++++++++---
55
arm: rename xlnx-zcu102.canbusN properties
94
target/arm/translate-vfp.c | 12 +
56
95
target/arm/translate.c | 2 +
57
Peter Maydell (26):
96
target/arm/vec_helper.c | 24 +
58
configure: Move preadv check to meson.build
97
target/arm/meson.build | 3 +
59
ptimer: Add new ptimer_set_period_from_clock() function
98
28 files changed, 2821 insertions(+), 135 deletions(-)
60
clock: Add new clock_has_source() function
99
create mode 100644 target/arm/sme-fa64.decode
61
tests: Add a simple test of the CMSDK APB timer
100
create mode 100644 target/arm/sme.decode
62
tests: Add a simple test of the CMSDK APB watchdog
101
create mode 100644 target/arm/translate-sme.c
63
tests: Add a simple test of the CMSDK APB dual timer
64
hw/timer/cmsdk-apb-timer: Rename CMSDKAPBTIMER struct to CMSDKAPBTimer
65
hw/timer/cmsdk-apb-timer: Add Clock input
66
hw/timer/cmsdk-apb-dualtimer: Add Clock input
67
hw/watchdog/cmsdk-apb-watchdog: Add Clock input
68
hw/arm/armsse: Rename "MAINCLK" property to "MAINCLK_FRQ"
69
hw/arm/armsse: Wire up clocks
70
hw/arm/mps2: Inline CMSDK_APB_TIMER creation
71
hw/arm/mps2: Create and connect SYSCLK Clock
72
hw/arm/mps2-tz: Create and connect ARMSSE Clocks
73
hw/arm/musca: Create and connect ARMSSE Clocks
74
hw/arm/stellaris: Convert SSYS to QOM device
75
hw/arm/stellaris: Create Clock input for watchdog
76
hw/timer/cmsdk-apb-timer: Convert to use Clock input
77
hw/timer/cmsdk-apb-dualtimer: Convert to use Clock input
78
hw/watchdog/cmsdk-apb-watchdog: Convert to use Clock input
79
tests/qtest/cmsdk-apb-watchdog-test: Test clock changes
80
hw/arm/armsse: Use Clock to set system_clock_scale
81
arm: Don't set freq properties on CMSDK timer, dualtimer, watchdog, ARMSSE
82
arm: Remove frq properties on CMSDK timer, dualtimer, watchdog, ARMSSE
83
hw/arm/stellaris: Remove board-creation reset of STELLARIS_SYS
84
85
Philippe Mathieu-Daudé (1):
86
target/arm: Replace magic value by MMU_DATA_LOAD definition
87
88
Richard Henderson (2):
89
target/arm: Implement ID_PFR2
90
target/arm: Conditionalize DBGDIDR
91
92
docs/devel/clocks.rst | 16 +++
93
docs/specs/pci-ids.txt | 1 +
94
docs/specs/pvpanic.txt | 13 ++-
95
docs/system/arm/virt.rst | 2 +
96
configure | 78 ++++++++------
97
meson.build | 34 ++++++-
98
include/hw/arm/armsse.h | 14 ++-
99
include/hw/arm/virt.h | 2 +
100
include/hw/clock.h | 15 +++
101
include/hw/misc/pvpanic.h | 24 ++++-
102
include/hw/pci/pci.h | 1 +
103
include/hw/ptimer.h | 22 ++++
104
include/hw/timer/cmsdk-apb-dualtimer.h | 5 +-
105
include/hw/timer/cmsdk-apb-timer.h | 34 ++-----
106
include/hw/watchdog/cmsdk-apb-watchdog.h | 5 +-
107
include/qemu/osdep.h | 12 +++
108
include/qemu/typedefs.h | 1 +
109
target/arm/cpu.h | 1 +
110
hw/arm/armsse.c | 48 ++++++---
111
hw/arm/mps2-tz.c | 14 ++-
112
hw/arm/mps2.c | 28 ++++-
113
hw/arm/musca.c | 13 ++-
114
hw/arm/stellaris.c | 170 +++++++++++++++++++++++--------
115
hw/arm/virt.c | 111 ++++++++++++++++----
116
hw/arm/xlnx-zcu102.c | 4 +-
117
hw/core/ptimer.c | 34 +++++++
118
hw/gpio/gpio_pwr.c | 70 +++++++++++++
119
hw/misc/npcm7xx_pwm.c | 23 ++++-
120
hw/misc/pvpanic-isa.c | 94 +++++++++++++++++
121
hw/misc/pvpanic-pci.c | 94 +++++++++++++++++
122
hw/misc/pvpanic.c | 85 ++--------------
123
hw/timer/cmsdk-apb-dualtimer.c | 53 +++++++---
124
hw/timer/cmsdk-apb-timer.c | 55 +++++-----
125
hw/watchdog/cmsdk-apb-watchdog.c | 29 ++++--
126
target/arm/helper.c | 27 +++--
127
target/arm/kvm64.c | 2 +
128
tests/qtest/cmsdk-apb-dualtimer-test.c | 130 +++++++++++++++++++++++
129
tests/qtest/cmsdk-apb-timer-test.c | 75 ++++++++++++++
130
tests/qtest/cmsdk-apb-watchdog-test.c | 131 ++++++++++++++++++++++++
131
tests/qtest/npcm7xx_pwm-test.c | 4 +-
132
tests/qtest/pvpanic-pci-test.c | 94 +++++++++++++++++
133
tests/qtest/xlnx-can-test.c | 30 +++---
134
MAINTAINERS | 3 +
135
accel/hvf/entitlements.plist | 8 ++
136
hw/arm/Kconfig | 1 +
137
hw/gpio/Kconfig | 3 +
138
hw/gpio/meson.build | 1 +
139
hw/i386/Kconfig | 2 +-
140
hw/misc/Kconfig | 12 ++-
141
hw/misc/meson.build | 4 +-
142
scripts/entitlement.sh | 13 +++
143
tests/qtest/meson.build | 6 +-
144
52 files changed, 1432 insertions(+), 319 deletions(-)
145
create mode 100644 hw/gpio/gpio_pwr.c
146
create mode 100644 hw/misc/pvpanic-isa.c
147
create mode 100644 hw/misc/pvpanic-pci.c
148
create mode 100644 tests/qtest/cmsdk-apb-dualtimer-test.c
149
create mode 100644 tests/qtest/cmsdk-apb-timer-test.c
150
create mode 100644 tests/qtest/cmsdk-apb-watchdog-test.c
151
create mode 100644 tests/qtest/pvpanic-pci-test.c
152
create mode 100644 accel/hvf/entitlements.plist
153
create mode 100755 scripts/entitlement.sh
154
diff view generated by jsdifflib
1
Now that the watchdog device uses its Clock input rather than being
1
From: Richard Henderson <richard.henderson@linaro.org>
2
passed the value of system_clock_scale at creation time, we can
3
remove the hack where we reset the STELLARIS_SYS at board creation
4
time to force it to set system_clock_scale. Instead it will be reset
5
at the usual point in startup and will inform the watchdog of the
6
clock frequency at that point.
7
2
3
Dump SVCR, plus use the correct access check for Streaming Mode.
4
5
Reviewed-by: Peter Maydell <peter.maydell@linaro.org>
6
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
7
Message-id: 20220708151540.18136-2-richard.henderson@linaro.org
8
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
8
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
9
Reviewed-by: Luc Michel <luc@lmichel.fr>
10
Tested-by: Philippe Mathieu-Daudé <f4bug@amsat.org>
11
Reviewed-by: Philippe Mathieu-Daudé <f4bug@amsat.org>
12
Message-id: 20210128114145.20536-26-peter.maydell@linaro.org
13
Message-id: 20210121190622.22000-26-peter.maydell@linaro.org
14
Reviewed-by: Philippe Mathieu-Daudé <f4bug@amsat.org>
15
---
9
---
16
hw/arm/stellaris.c | 10 ----------
10
target/arm/cpu.c | 17 ++++++++++++++++-
17
1 file changed, 10 deletions(-)
11
1 file changed, 16 insertions(+), 1 deletion(-)
18
12
19
diff --git a/hw/arm/stellaris.c b/hw/arm/stellaris.c
13
diff --git a/target/arm/cpu.c b/target/arm/cpu.c
20
index XXXXXXX..XXXXXXX 100644
14
index XXXXXXX..XXXXXXX 100644
21
--- a/hw/arm/stellaris.c
15
--- a/target/arm/cpu.c
22
+++ b/hw/arm/stellaris.c
16
+++ b/target/arm/cpu.c
23
@@ -XXX,XX +XXX,XX @@ static DeviceState *stellaris_sys_init(uint32_t base, qemu_irq irq,
17
@@ -XXX,XX +XXX,XX @@ static void aarch64_cpu_dump_state(CPUState *cs, FILE *f, int flags)
24
sysbus_mmio_map(sbd, 0, base);
18
int i;
25
sysbus_connect_irq(sbd, 0, irq);
19
int el = arm_current_el(env);
26
20
const char *ns_status;
27
- /*
21
+ bool sve;
28
- * Normally we should not be resetting devices like this during
22
29
- * board creation. For the moment we need to do so, because
23
qemu_fprintf(f, " PC=%016" PRIx64 " ", env->pc);
30
- * system_clock_scale will only get set when the STELLARIS_SYS
24
for (i = 0; i < 32; i++) {
31
- * device is reset, and we need its initial value to pass to
25
@@ -XXX,XX +XXX,XX @@ static void aarch64_cpu_dump_state(CPUState *cs, FILE *f, int flags)
32
- * the watchdog device. This hack can be removed once the
26
el,
33
- * watchdog has been converted to use a Clock input instead.
27
psr & PSTATE_SP ? 'h' : 't');
34
- */
28
35
- device_cold_reset(dev);
29
+ if (cpu_isar_feature(aa64_sme, cpu)) {
36
-
30
+ qemu_fprintf(f, " SVCR=%08" PRIx64 " %c%c",
37
return dev;
31
+ env->svcr,
38
}
32
+ (FIELD_EX64(env->svcr, SVCR, ZA) ? 'Z' : '-'),
39
33
+ (FIELD_EX64(env->svcr, SVCR, SM) ? 'S' : '-'));
34
+ }
35
if (cpu_isar_feature(aa64_bti, cpu)) {
36
qemu_fprintf(f, " BTYPE=%d", (psr & PSTATE_BTYPE) >> 10);
37
}
38
@@ -XXX,XX +XXX,XX @@ static void aarch64_cpu_dump_state(CPUState *cs, FILE *f, int flags)
39
qemu_fprintf(f, " FPCR=%08x FPSR=%08x\n",
40
vfp_get_fpcr(env), vfp_get_fpsr(env));
41
42
- if (cpu_isar_feature(aa64_sve, cpu) && sve_exception_el(env, el) == 0) {
43
+ if (cpu_isar_feature(aa64_sme, cpu) && FIELD_EX64(env->svcr, SVCR, SM)) {
44
+ sve = sme_exception_el(env, el) == 0;
45
+ } else if (cpu_isar_feature(aa64_sve, cpu)) {
46
+ sve = sve_exception_el(env, el) == 0;
47
+ } else {
48
+ sve = false;
49
+ }
50
+
51
+ if (sve) {
52
int j, zcr_len = sve_vqm1_for_el(env, el);
53
54
for (i = 0; i <= FFR_PRED_NUM; i++) {
40
--
55
--
41
2.20.1
56
2.25.1
42
43
diff view generated by jsdifflib
1
Add a simple test of the CMSDK watchdog, since we're about to do some
1
From: Richard Henderson <richard.henderson@linaro.org>
2
refactoring of how it is clocked.
3
2
3
This includes the build rules for the decoder, and the
4
new file for translation, but excludes any instructions.
5
6
Reviewed-by: Peter Maydell <peter.maydell@linaro.org>
7
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
8
Message-id: 20220708151540.18136-3-richard.henderson@linaro.org
4
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
9
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
5
Reviewed-by: Luc Michel <luc@lmichel.fr>
6
Tested-by: Philippe Mathieu-Daudé <f4bug@amsat.org>
7
Reviewed-by: Philippe Mathieu-Daudé <f4bug@amsat.org>
8
Message-id: 20210128114145.20536-5-peter.maydell@linaro.org
9
Message-id: 20210121190622.22000-5-peter.maydell@linaro.org
10
Reviewed-by: Philippe Mathieu-Daudé <f4bug@amsat.org>
11
---
10
---
12
tests/qtest/cmsdk-apb-watchdog-test.c | 79 +++++++++++++++++++++++++++
11
target/arm/translate-a64.h | 1 +
13
MAINTAINERS | 1 +
12
target/arm/sme.decode | 20 ++++++++++++++++++++
14
tests/qtest/meson.build | 1 +
13
target/arm/translate-a64.c | 7 ++++++-
15
3 files changed, 81 insertions(+)
14
target/arm/translate-sme.c | 35 +++++++++++++++++++++++++++++++++++
16
create mode 100644 tests/qtest/cmsdk-apb-watchdog-test.c
15
target/arm/meson.build | 2 ++
16
5 files changed, 64 insertions(+), 1 deletion(-)
17
create mode 100644 target/arm/sme.decode
18
create mode 100644 target/arm/translate-sme.c
17
19
18
diff --git a/tests/qtest/cmsdk-apb-watchdog-test.c b/tests/qtest/cmsdk-apb-watchdog-test.c
20
diff --git a/target/arm/translate-a64.h b/target/arm/translate-a64.h
21
index XXXXXXX..XXXXXXX 100644
22
--- a/target/arm/translate-a64.h
23
+++ b/target/arm/translate-a64.h
24
@@ -XXX,XX +XXX,XX @@ static inline int pred_gvec_reg_size(DisasContext *s)
25
}
26
27
bool disas_sve(DisasContext *, uint32_t);
28
+bool disas_sme(DisasContext *, uint32_t);
29
30
void gen_gvec_rax1(unsigned vece, uint32_t rd_ofs, uint32_t rn_ofs,
31
uint32_t rm_ofs, uint32_t opr_sz, uint32_t max_sz);
32
diff --git a/target/arm/sme.decode b/target/arm/sme.decode
19
new file mode 100644
33
new file mode 100644
20
index XXXXXXX..XXXXXXX
34
index XXXXXXX..XXXXXXX
21
--- /dev/null
35
--- /dev/null
22
+++ b/tests/qtest/cmsdk-apb-watchdog-test.c
36
+++ b/target/arm/sme.decode
37
@@ -XXX,XX +XXX,XX @@
38
+# AArch64 SME instruction descriptions
39
+#
40
+# Copyright (c) 2022 Linaro, Ltd
41
+#
42
+# This library is free software; you can redistribute it and/or
43
+# modify it under the terms of the GNU Lesser General Public
44
+# License as published by the Free Software Foundation; either
45
+# version 2.1 of the License, or (at your option) any later version.
46
+#
47
+# This library is distributed in the hope that it will be useful,
48
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
49
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
50
+# Lesser General Public License for more details.
51
+#
52
+# You should have received a copy of the GNU Lesser General Public
53
+# License along with this library; if not, see <http://www.gnu.org/licenses/>.
54
+
55
+#
56
+# This file is processed by scripts/decodetree.py
57
+#
58
diff --git a/target/arm/translate-a64.c b/target/arm/translate-a64.c
59
index XXXXXXX..XXXXXXX 100644
60
--- a/target/arm/translate-a64.c
61
+++ b/target/arm/translate-a64.c
62
@@ -XXX,XX +XXX,XX @@ static void aarch64_tr_translate_insn(DisasContextBase *dcbase, CPUState *cpu)
63
}
64
65
switch (extract32(insn, 25, 4)) {
66
- case 0x0: case 0x1: case 0x3: /* UNALLOCATED */
67
+ case 0x0:
68
+ if (!extract32(insn, 31, 1) || !disas_sme(s, insn)) {
69
+ unallocated_encoding(s);
70
+ }
71
+ break;
72
+ case 0x1: case 0x3: /* UNALLOCATED */
73
unallocated_encoding(s);
74
break;
75
case 0x2:
76
diff --git a/target/arm/translate-sme.c b/target/arm/translate-sme.c
77
new file mode 100644
78
index XXXXXXX..XXXXXXX
79
--- /dev/null
80
+++ b/target/arm/translate-sme.c
23
@@ -XXX,XX +XXX,XX @@
81
@@ -XXX,XX +XXX,XX @@
24
+/*
82
+/*
25
+ * QTest testcase for the CMSDK APB watchdog device
83
+ * AArch64 SME translation
26
+ *
84
+ *
27
+ * Copyright (c) 2021 Linaro Limited
85
+ * Copyright (c) 2022 Linaro, Ltd
28
+ *
86
+ *
29
+ * This program is free software; you can redistribute it and/or modify it
87
+ * This library is free software; you can redistribute it and/or
30
+ * under the terms of the GNU General Public License as published by the
88
+ * modify it under the terms of the GNU Lesser General Public
31
+ * Free Software Foundation; either version 2 of the License, or
89
+ * License as published by the Free Software Foundation; either
32
+ * (at your option) any later version.
90
+ * version 2.1 of the License, or (at your option) any later version.
33
+ *
91
+ *
34
+ * This program is distributed in the hope that it will be useful, but WITHOUT
92
+ * This library is distributed in the hope that it will be useful,
35
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
93
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
36
+ * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
94
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
37
+ * for more details.
95
+ * Lesser General Public License for more details.
96
+ *
97
+ * You should have received a copy of the GNU Lesser General Public
98
+ * License along with this library; if not, see <http://www.gnu.org/licenses/>.
38
+ */
99
+ */
39
+
100
+
40
+#include "qemu/osdep.h"
101
+#include "qemu/osdep.h"
41
+#include "libqtest-single.h"
102
+#include "cpu.h"
103
+#include "tcg/tcg-op.h"
104
+#include "tcg/tcg-op-gvec.h"
105
+#include "tcg/tcg-gvec-desc.h"
106
+#include "translate.h"
107
+#include "exec/helper-gen.h"
108
+#include "translate-a64.h"
109
+#include "fpu/softfloat.h"
110
+
42
+
111
+
43
+/*
112
+/*
44
+ * lm3s811evb watchdog; at board startup this runs at 200MHz / 16 == 12.5MHz,
113
+ * Include the generated decoder.
45
+ * which is 80ns per tick.
46
+ */
114
+ */
47
+#define WDOG_BASE 0x40000000
48
+
115
+
49
+#define WDOGLOAD 0
116
+#include "decode-sme.c.inc"
50
+#define WDOGVALUE 4
117
diff --git a/target/arm/meson.build b/target/arm/meson.build
51
+#define WDOGCONTROL 8
52
+#define WDOGINTCLR 0xc
53
+#define WDOGRIS 0x10
54
+#define WDOGMIS 0x14
55
+#define WDOGLOCK 0xc00
56
+
57
+static void test_watchdog(void)
58
+{
59
+ g_assert_cmpuint(readl(WDOG_BASE + WDOGRIS), ==, 0);
60
+
61
+ writel(WDOG_BASE + WDOGCONTROL, 1);
62
+ writel(WDOG_BASE + WDOGLOAD, 1000);
63
+
64
+ /* Step to just past the 500th tick */
65
+ clock_step(500 * 80 + 1);
66
+ g_assert_cmpuint(readl(WDOG_BASE + WDOGRIS), ==, 0);
67
+ g_assert_cmpuint(readl(WDOG_BASE + WDOGVALUE), ==, 500);
68
+
69
+ /* Just past the 1000th tick: timer should have fired */
70
+ clock_step(500 * 80);
71
+ g_assert_cmpuint(readl(WDOG_BASE + WDOGRIS), ==, 1);
72
+ g_assert_cmpuint(readl(WDOG_BASE + WDOGVALUE), ==, 0);
73
+
74
+ /* VALUE reloads at following tick */
75
+ clock_step(80);
76
+ g_assert_cmpuint(readl(WDOG_BASE + WDOGVALUE), ==, 1000);
77
+
78
+ /* Writing any value to WDOGINTCLR clears the interrupt and reloads */
79
+ clock_step(500 * 80);
80
+ g_assert_cmpuint(readl(WDOG_BASE + WDOGVALUE), ==, 500);
81
+ g_assert_cmpuint(readl(WDOG_BASE + WDOGRIS), ==, 1);
82
+ writel(WDOG_BASE + WDOGINTCLR, 0);
83
+ g_assert_cmpuint(readl(WDOG_BASE + WDOGVALUE), ==, 1000);
84
+ g_assert_cmpuint(readl(WDOG_BASE + WDOGRIS), ==, 0);
85
+}
86
+
87
+int main(int argc, char **argv)
88
+{
89
+ int r;
90
+
91
+ g_test_init(&argc, &argv, NULL);
92
+
93
+ qtest_start("-machine lm3s811evb");
94
+
95
+ qtest_add_func("/cmsdk-apb-watchdog/watchdog", test_watchdog);
96
+
97
+ r = g_test_run();
98
+
99
+ qtest_end();
100
+
101
+ return r;
102
+}
103
diff --git a/MAINTAINERS b/MAINTAINERS
104
index XXXXXXX..XXXXXXX 100644
118
index XXXXXXX..XXXXXXX 100644
105
--- a/MAINTAINERS
119
--- a/target/arm/meson.build
106
+++ b/MAINTAINERS
120
+++ b/target/arm/meson.build
107
@@ -XXX,XX +XXX,XX @@ F: hw/char/cmsdk-apb-uart.c
121
@@ -XXX,XX +XXX,XX @@
108
F: include/hw/char/cmsdk-apb-uart.h
122
gen = [
109
F: hw/watchdog/cmsdk-apb-watchdog.c
123
decodetree.process('sve.decode', extra_args: '--decode=disas_sve'),
110
F: include/hw/watchdog/cmsdk-apb-watchdog.h
124
+ decodetree.process('sme.decode', extra_args: '--decode=disas_sme'),
111
+F: tests/qtest/cmsdk-apb-watchdog-test.c
125
decodetree.process('neon-shared.decode', extra_args: '--decode=disas_neon_shared'),
112
F: hw/misc/tz-ppc.c
126
decodetree.process('neon-dp.decode', extra_args: '--decode=disas_neon_dp'),
113
F: include/hw/misc/tz-ppc.h
127
decodetree.process('neon-ls.decode', extra_args: '--decode=disas_neon_ls'),
114
F: hw/misc/tz-mpc.c
128
@@ -XXX,XX +XXX,XX @@ arm_ss.add(when: 'TARGET_AARCH64', if_true: files(
115
diff --git a/tests/qtest/meson.build b/tests/qtest/meson.build
129
'sme_helper.c',
116
index XXXXXXX..XXXXXXX 100644
130
'translate-a64.c',
117
--- a/tests/qtest/meson.build
131
'translate-sve.c',
118
+++ b/tests/qtest/meson.build
132
+ 'translate-sme.c',
119
@@ -XXX,XX +XXX,XX @@ qtests_npcm7xx = \
133
))
120
'npcm7xx_watchdog_timer-test']
134
121
qtests_arm = \
135
arm_softmmu_ss = ss.source_set()
122
(config_all_devices.has_key('CONFIG_CMSDK_APB_TIMER') ? ['cmsdk-apb-timer-test'] : []) + \
123
+ (config_all_devices.has_key('CONFIG_CMSDK_APB_WATCHDOG') ? ['cmsdk-apb-watchdog-test'] : []) + \
124
(config_all_devices.has_key('CONFIG_PFLASH_CFI02') ? ['pflash-cfi02-test'] : []) + \
125
(config_all_devices.has_key('CONFIG_NPCM7XX') ? qtests_npcm7xx : []) + \
126
['arm-cpu-features',
127
--
136
--
128
2.20.1
137
2.25.1
129
130
diff view generated by jsdifflib
1
From: Richard Henderson <richard.henderson@linaro.org>
1
From: Richard Henderson <richard.henderson@linaro.org>
2
2
3
This was defined at some point before ARMv8.4, and will
3
This new behaviour is in the ARM pseudocode function
4
shortly be used by new processor descriptions.
4
AArch64.CheckFPAdvSIMDEnabled, which applies to AArch32
5
via AArch32.CheckAdvSIMDOrFPEnabled when the EL to which
6
the trap would be delivered is in AArch64 mode.
7
8
Given that ARMv9 drops support for AArch32 outside EL0, the trap EL
9
detection ought to be trivially true, but the pseudocode still contains
10
a number of conditions, and QEMU has not yet committed to dropping A32
11
support for EL[12] when v9 features are present.
12
13
Since the computation of SME_TRAP_NONSTREAMING is necessarily different
14
for the two modes, we might as well preserve bits within TBFLAG_ANY and
15
allocate separate bits within TBFLAG_A32 and TBFLAG_A64 instead.
16
17
Note that DDI0616A.a has typos for bits [22:21] of LD1RO in the table
18
of instructions illegal in streaming mode.
5
19
6
Reviewed-by: Peter Maydell <peter.maydell@linaro.org>
20
Reviewed-by: Peter Maydell <peter.maydell@linaro.org>
7
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
21
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
8
Message-id: 20210120204400.1056582-1-richard.henderson@linaro.org
22
Message-id: 20220708151540.18136-4-richard.henderson@linaro.org
9
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
23
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
10
---
24
---
11
target/arm/cpu.h | 1 +
25
target/arm/cpu.h | 7 +++
12
target/arm/helper.c | 4 ++--
26
target/arm/translate.h | 4 ++
13
target/arm/kvm64.c | 2 ++
27
target/arm/sme-fa64.decode | 90 ++++++++++++++++++++++++++++++++++++++
14
3 files changed, 5 insertions(+), 2 deletions(-)
28
target/arm/helper.c | 41 +++++++++++++++++
29
target/arm/translate-a64.c | 40 ++++++++++++++++-
30
target/arm/translate-vfp.c | 12 +++++
31
target/arm/translate.c | 2 +
32
target/arm/meson.build | 1 +
33
8 files changed, 195 insertions(+), 2 deletions(-)
34
create mode 100644 target/arm/sme-fa64.decode
15
35
16
diff --git a/target/arm/cpu.h b/target/arm/cpu.h
36
diff --git a/target/arm/cpu.h b/target/arm/cpu.h
17
index XXXXXXX..XXXXXXX 100644
37
index XXXXXXX..XXXXXXX 100644
18
--- a/target/arm/cpu.h
38
--- a/target/arm/cpu.h
19
+++ b/target/arm/cpu.h
39
+++ b/target/arm/cpu.h
20
@@ -XXX,XX +XXX,XX @@ struct ARMCPU {
40
@@ -XXX,XX +XXX,XX @@ FIELD(TBFLAG_A32, HSTR_ACTIVE, 9, 1)
21
uint32_t id_mmfr4;
41
* the same thing as the current security state of the processor!
22
uint32_t id_pfr0;
42
*/
23
uint32_t id_pfr1;
43
FIELD(TBFLAG_A32, NS, 10, 1)
24
+ uint32_t id_pfr2;
44
+/*
25
uint32_t mvfr0;
45
+ * Indicates that SME Streaming mode is active, and SMCR_ELx.FA64 is not.
26
uint32_t mvfr1;
46
+ * This requires an SME trap from AArch32 mode when using NEON.
27
uint32_t mvfr2;
47
+ */
48
+FIELD(TBFLAG_A32, SME_TRAP_NONSTREAMING, 11, 1)
49
50
/*
51
* Bit usage when in AArch32 state, for M-profile only.
52
@@ -XXX,XX +XXX,XX @@ FIELD(TBFLAG_A64, SMEEXC_EL, 20, 2)
53
FIELD(TBFLAG_A64, PSTATE_SM, 22, 1)
54
FIELD(TBFLAG_A64, PSTATE_ZA, 23, 1)
55
FIELD(TBFLAG_A64, SVL, 24, 4)
56
+/* Indicates that SME Streaming mode is active, and SMCR_ELx.FA64 is not. */
57
+FIELD(TBFLAG_A64, SME_TRAP_NONSTREAMING, 28, 1)
58
59
/*
60
* Helpers for using the above.
61
diff --git a/target/arm/translate.h b/target/arm/translate.h
62
index XXXXXXX..XXXXXXX 100644
63
--- a/target/arm/translate.h
64
+++ b/target/arm/translate.h
65
@@ -XXX,XX +XXX,XX @@ typedef struct DisasContext {
66
bool pstate_sm;
67
/* True if PSTATE.ZA is set. */
68
bool pstate_za;
69
+ /* True if non-streaming insns should raise an SME Streaming exception. */
70
+ bool sme_trap_nonstreaming;
71
+ /* True if the current instruction is non-streaming. */
72
+ bool is_nonstreaming;
73
/* True if MVE insns are definitely not predicated by VPR or LTPSIZE */
74
bool mve_no_pred;
75
/*
76
diff --git a/target/arm/sme-fa64.decode b/target/arm/sme-fa64.decode
77
new file mode 100644
78
index XXXXXXX..XXXXXXX
79
--- /dev/null
80
+++ b/target/arm/sme-fa64.decode
81
@@ -XXX,XX +XXX,XX @@
82
+# AArch64 SME allowed instruction decoding
83
+#
84
+# Copyright (c) 2022 Linaro, Ltd
85
+#
86
+# This library is free software; you can redistribute it and/or
87
+# modify it under the terms of the GNU Lesser General Public
88
+# License as published by the Free Software Foundation; either
89
+# version 2.1 of the License, or (at your option) any later version.
90
+#
91
+# This library is distributed in the hope that it will be useful,
92
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
93
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
94
+# Lesser General Public License for more details.
95
+#
96
+# You should have received a copy of the GNU Lesser General Public
97
+# License along with this library; if not, see <http://www.gnu.org/licenses/>.
98
+
99
+#
100
+# This file is processed by scripts/decodetree.py
101
+#
102
+
103
+# These patterns are taken from Appendix E1.1 of DDI0616 A.a,
104
+# Arm Architecture Reference Manual Supplement,
105
+# The Scalable Matrix Extension (SME), for Armv9-A
106
+
107
+{
108
+ [
109
+ OK 0-00 1110 0000 0001 0010 11-- ---- ---- # SMOV W|Xd,Vn.B[0]
110
+ OK 0-00 1110 0000 0010 0010 11-- ---- ---- # SMOV W|Xd,Vn.H[0]
111
+ OK 0100 1110 0000 0100 0010 11-- ---- ---- # SMOV Xd,Vn.S[0]
112
+ OK 0000 1110 0000 0001 0011 11-- ---- ---- # UMOV Wd,Vn.B[0]
113
+ OK 0000 1110 0000 0010 0011 11-- ---- ---- # UMOV Wd,Vn.H[0]
114
+ OK 0000 1110 0000 0100 0011 11-- ---- ---- # UMOV Wd,Vn.S[0]
115
+ OK 0100 1110 0000 1000 0011 11-- ---- ---- # UMOV Xd,Vn.D[0]
116
+ ]
117
+ FAIL 0--0 111- ---- ---- ---- ---- ---- ---- # Advanced SIMD vector operations
118
+}
119
+
120
+{
121
+ [
122
+ OK 0101 1110 --1- ---- 11-1 11-- ---- ---- # FMULX/FRECPS/FRSQRTS (scalar)
123
+ OK 0101 1110 -10- ---- 00-1 11-- ---- ---- # FMULX/FRECPS/FRSQRTS (scalar, FP16)
124
+ OK 01-1 1110 1-10 0001 11-1 10-- ---- ---- # FRECPE/FRSQRTE/FRECPX (scalar)
125
+ OK 01-1 1110 1111 1001 11-1 10-- ---- ---- # FRECPE/FRSQRTE/FRECPX (scalar, FP16)
126
+ ]
127
+ FAIL 01-1 111- ---- ---- ---- ---- ---- ---- # Advanced SIMD single-element operations
128
+}
129
+
130
+FAIL 0-00 110- ---- ---- ---- ---- ---- ---- # Advanced SIMD structure load/store
131
+FAIL 1100 1110 ---- ---- ---- ---- ---- ---- # Advanced SIMD cryptography extensions
132
+FAIL 0001 1110 0111 1110 0000 00-- ---- ---- # FJCVTZS
133
+
134
+# These are the "avoidance of doubt" final table of Illegal Advanced SIMD instructions
135
+# We don't actually need to include these, as the default is OK.
136
+# -001 111- ---- ---- ---- ---- ---- ---- # Scalar floating-point operations
137
+# --10 110- ---- ---- ---- ---- ---- ---- # Load/store pair of FP registers
138
+# --01 1100 ---- ---- ---- ---- ---- ---- # Load FP register (PC-relative literal)
139
+# --11 1100 --0- ---- ---- ---- ---- ---- # Load/store FP register (unscaled imm)
140
+# --11 1100 --1- ---- ---- ---- ---- --10 # Load/store FP register (register offset)
141
+# --11 1101 ---- ---- ---- ---- ---- ---- # Load/store FP register (scaled imm)
142
+
143
+FAIL 0000 0100 --1- ---- 1010 ---- ---- ---- # ADR
144
+FAIL 0000 0100 --1- ---- 1011 -0-- ---- ---- # FTSSEL, FEXPA
145
+FAIL 0000 0101 --10 0001 100- ---- ---- ---- # COMPACT
146
+FAIL 0010 0101 --01 100- 1111 000- ---0 ---- # RDFFR, RDFFRS
147
+FAIL 0010 0101 --10 1--- 1001 ---- ---- ---- # WRFFR, SETFFR
148
+FAIL 0100 0101 --0- ---- 1011 ---- ---- ---- # BDEP, BEXT, BGRP
149
+FAIL 0100 0101 000- ---- 0110 1--- ---- ---- # PMULLB, PMULLT (128b result)
150
+FAIL 0110 0100 --1- ---- 1110 01-- ---- ---- # FMMLA, BFMMLA
151
+FAIL 0110 0101 --0- ---- 0000 11-- ---- ---- # FTSMUL
152
+FAIL 0110 0101 --01 0--- 100- ---- ---- ---- # FTMAD
153
+FAIL 0110 0101 --01 1--- 001- ---- ---- ---- # FADDA
154
+FAIL 0100 0101 --0- ---- 1001 10-- ---- ---- # SMMLA, UMMLA, USMMLA
155
+FAIL 0100 0101 --1- ---- 1--- ---- ---- ---- # SVE2 string/histo/crypto instructions
156
+FAIL 1000 010- -00- ---- 10-- ---- ---- ---- # SVE2 32-bit gather NT load (vector+scalar)
157
+FAIL 1000 010- -00- ---- 111- ---- ---- ---- # SVE 32-bit gather prefetch (vector+imm)
158
+FAIL 1000 0100 0-1- ---- 0--- ---- ---- ---- # SVE 32-bit gather prefetch (scalar+vector)
159
+FAIL 1000 010- -01- ---- 1--- ---- ---- ---- # SVE 32-bit gather load (vector+imm)
160
+FAIL 1000 0100 0-0- ---- 0--- ---- ---- ---- # SVE 32-bit gather load byte (scalar+vector)
161
+FAIL 1000 0100 1--- ---- 0--- ---- ---- ---- # SVE 32-bit gather load half (scalar+vector)
162
+FAIL 1000 0101 0--- ---- 0--- ---- ---- ---- # SVE 32-bit gather load word (scalar+vector)
163
+FAIL 1010 010- ---- ---- 011- ---- ---- ---- # SVE contiguous FF load (scalar+scalar)
164
+FAIL 1010 010- ---1 ---- 101- ---- ---- ---- # SVE contiguous NF load (scalar+imm)
165
+FAIL 1010 010- -01- ---- 000- ---- ---- ---- # SVE load & replicate 32 bytes (scalar+scalar)
166
+FAIL 1010 010- -010 ---- 001- ---- ---- ---- # SVE load & replicate 32 bytes (scalar+imm)
167
+FAIL 1100 010- ---- ---- ---- ---- ---- ---- # SVE 64-bit gather load/prefetch
168
+FAIL 1110 010- -00- ---- 001- ---- ---- ---- # SVE2 64-bit scatter NT store (vector+scalar)
169
+FAIL 1110 010- -10- ---- 001- ---- ---- ---- # SVE2 32-bit scatter NT store (vector+scalar)
170
+FAIL 1110 010- ---- ---- 1-0- ---- ---- ---- # SVE scatter store (scalar+32-bit vector)
171
+FAIL 1110 010- ---- ---- 101- ---- ---- ---- # SVE scatter store (misc)
28
diff --git a/target/arm/helper.c b/target/arm/helper.c
172
diff --git a/target/arm/helper.c b/target/arm/helper.c
29
index XXXXXXX..XXXXXXX 100644
173
index XXXXXXX..XXXXXXX 100644
30
--- a/target/arm/helper.c
174
--- a/target/arm/helper.c
31
+++ b/target/arm/helper.c
175
+++ b/target/arm/helper.c
32
@@ -XXX,XX +XXX,XX @@ void register_cp_regs_for_features(ARMCPU *cpu)
176
@@ -XXX,XX +XXX,XX @@ int sme_exception_el(CPUARMState *env, int el)
33
.access = PL1_R, .type = ARM_CP_CONST,
177
return 0;
34
.accessfn = access_aa64_tid3,
178
}
35
.resetvalue = 0 },
179
36
- { .name = "MVFR4_EL1_RESERVED", .state = ARM_CP_STATE_AA64,
180
+/* This corresponds to the ARM pseudocode function IsFullA64Enabled(). */
37
+ { .name = "ID_PFR2", .state = ARM_CP_STATE_BOTH,
181
+static bool sme_fa64(CPUARMState *env, int el)
38
.opc0 = 3, .opc1 = 0, .crn = 0, .crm = 3, .opc2 = 4,
182
+{
39
.access = PL1_R, .type = ARM_CP_CONST,
183
+ if (!cpu_isar_feature(aa64_sme_fa64, env_archcpu(env))) {
40
.accessfn = access_aa64_tid3,
184
+ return false;
41
- .resetvalue = 0 },
185
+ }
42
+ .resetvalue = cpu->isar.id_pfr2 },
186
+
43
{ .name = "MVFR5_EL1_RESERVED", .state = ARM_CP_STATE_AA64,
187
+ if (el <= 1 && !el_is_in_host(env, el)) {
44
.opc0 = 3, .opc1 = 0, .crn = 0, .crm = 3, .opc2 = 5,
188
+ if (!FIELD_EX64(env->vfp.smcr_el[1], SMCR, FA64)) {
45
.access = PL1_R, .type = ARM_CP_CONST,
189
+ return false;
46
diff --git a/target/arm/kvm64.c b/target/arm/kvm64.c
190
+ }
47
index XXXXXXX..XXXXXXX 100644
191
+ }
48
--- a/target/arm/kvm64.c
192
+ if (el <= 2 && arm_is_el2_enabled(env)) {
49
+++ b/target/arm/kvm64.c
193
+ if (!FIELD_EX64(env->vfp.smcr_el[2], SMCR, FA64)) {
50
@@ -XXX,XX +XXX,XX @@ bool kvm_arm_get_host_cpu_features(ARMHostCPUFeatures *ahcf)
194
+ return false;
51
ARM64_SYS_REG(3, 0, 0, 1, 0));
195
+ }
52
err |= read_sys_reg32(fdarray[2], &ahcf->isar.id_pfr1,
196
+ }
53
ARM64_SYS_REG(3, 0, 0, 1, 1));
197
+ if (arm_feature(env, ARM_FEATURE_EL3)) {
54
+ err |= read_sys_reg32(fdarray[2], &ahcf->isar.id_pfr2,
198
+ if (!FIELD_EX64(env->vfp.smcr_el[3], SMCR, FA64)) {
55
+ ARM64_SYS_REG(3, 0, 0, 3, 4));
199
+ return false;
56
err |= read_sys_reg32(fdarray[2], &ahcf->isar.id_dfr0,
200
+ }
57
ARM64_SYS_REG(3, 0, 0, 1, 2));
201
+ }
58
err |= read_sys_reg32(fdarray[2], &ahcf->isar.id_mmfr0,
202
+
203
+ return true;
204
+}
205
+
206
/*
207
* Given that SVE is enabled, return the vector length for EL.
208
*/
209
@@ -XXX,XX +XXX,XX @@ static CPUARMTBFlags rebuild_hflags_a32(CPUARMState *env, int fp_el,
210
DP_TBFLAG_ANY(flags, PSTATE__IL, 1);
211
}
212
213
+ /*
214
+ * The SME exception we are testing for is raised via
215
+ * AArch64.CheckFPAdvSIMDEnabled(), as called from
216
+ * AArch32.CheckAdvSIMDOrFPEnabled().
217
+ */
218
+ if (el == 0
219
+ && FIELD_EX64(env->svcr, SVCR, SM)
220
+ && (!arm_is_el2_enabled(env)
221
+ || (arm_el_is_aa64(env, 2) && !(env->cp15.hcr_el2 & HCR_TGE)))
222
+ && arm_el_is_aa64(env, 1)
223
+ && !sme_fa64(env, el)) {
224
+ DP_TBFLAG_A32(flags, SME_TRAP_NONSTREAMING, 1);
225
+ }
226
+
227
return rebuild_hflags_common_32(env, fp_el, mmu_idx, flags);
228
}
229
230
@@ -XXX,XX +XXX,XX @@ static CPUARMTBFlags rebuild_hflags_a64(CPUARMState *env, int el, int fp_el,
231
}
232
if (FIELD_EX64(env->svcr, SVCR, SM)) {
233
DP_TBFLAG_A64(flags, PSTATE_SM, 1);
234
+ DP_TBFLAG_A64(flags, SME_TRAP_NONSTREAMING, !sme_fa64(env, el));
235
}
236
DP_TBFLAG_A64(flags, PSTATE_ZA, FIELD_EX64(env->svcr, SVCR, ZA));
237
}
238
diff --git a/target/arm/translate-a64.c b/target/arm/translate-a64.c
239
index XXXXXXX..XXXXXXX 100644
240
--- a/target/arm/translate-a64.c
241
+++ b/target/arm/translate-a64.c
242
@@ -XXX,XX +XXX,XX @@ static void do_vec_ld(DisasContext *s, int destidx, int element,
243
* unallocated-encoding checks (otherwise the syndrome information
244
* for the resulting exception will be incorrect).
245
*/
246
-static bool fp_access_check(DisasContext *s)
247
+static bool fp_access_check_only(DisasContext *s)
248
{
249
if (s->fp_excp_el) {
250
assert(!s->fp_access_checked);
251
@@ -XXX,XX +XXX,XX @@ static bool fp_access_check(DisasContext *s)
252
return true;
253
}
254
255
+static bool fp_access_check(DisasContext *s)
256
+{
257
+ if (!fp_access_check_only(s)) {
258
+ return false;
259
+ }
260
+ if (s->sme_trap_nonstreaming && s->is_nonstreaming) {
261
+ gen_exception_insn(s, s->pc_curr, EXCP_UDEF,
262
+ syn_smetrap(SME_ET_Streaming, false));
263
+ return false;
264
+ }
265
+ return true;
266
+}
267
+
268
/* Check that SVE access is enabled. If it is, return true.
269
* If not, emit code to generate an appropriate exception and return false.
270
*/
271
@@ -XXX,XX +XXX,XX @@ static void handle_sys(DisasContext *s, uint32_t insn, bool isread,
272
default:
273
g_assert_not_reached();
274
}
275
- if ((ri->type & ARM_CP_FPU) && !fp_access_check(s)) {
276
+ if ((ri->type & ARM_CP_FPU) && !fp_access_check_only(s)) {
277
return;
278
} else if ((ri->type & ARM_CP_SVE) && !sve_access_check(s)) {
279
return;
280
@@ -XXX,XX +XXX,XX @@ static void disas_data_proc_simd_fp(DisasContext *s, uint32_t insn)
281
}
282
}
283
284
+/*
285
+ * Include the generated SME FA64 decoder.
286
+ */
287
+
288
+#include "decode-sme-fa64.c.inc"
289
+
290
+static bool trans_OK(DisasContext *s, arg_OK *a)
291
+{
292
+ return true;
293
+}
294
+
295
+static bool trans_FAIL(DisasContext *s, arg_OK *a)
296
+{
297
+ s->is_nonstreaming = true;
298
+ return true;
299
+}
300
+
301
/**
302
* is_guarded_page:
303
* @env: The cpu environment
304
@@ -XXX,XX +XXX,XX @@ static void aarch64_tr_init_disas_context(DisasContextBase *dcbase,
305
dc->mte_active[1] = EX_TBFLAG_A64(tb_flags, MTE0_ACTIVE);
306
dc->pstate_sm = EX_TBFLAG_A64(tb_flags, PSTATE_SM);
307
dc->pstate_za = EX_TBFLAG_A64(tb_flags, PSTATE_ZA);
308
+ dc->sme_trap_nonstreaming = EX_TBFLAG_A64(tb_flags, SME_TRAP_NONSTREAMING);
309
dc->vec_len = 0;
310
dc->vec_stride = 0;
311
dc->cp_regs = arm_cpu->cp_regs;
312
@@ -XXX,XX +XXX,XX @@ static void aarch64_tr_translate_insn(DisasContextBase *dcbase, CPUState *cpu)
313
}
314
}
315
316
+ s->is_nonstreaming = false;
317
+ if (s->sme_trap_nonstreaming) {
318
+ disas_sme_fa64(s, insn);
319
+ }
320
+
321
switch (extract32(insn, 25, 4)) {
322
case 0x0:
323
if (!extract32(insn, 31, 1) || !disas_sme(s, insn)) {
324
diff --git a/target/arm/translate-vfp.c b/target/arm/translate-vfp.c
325
index XXXXXXX..XXXXXXX 100644
326
--- a/target/arm/translate-vfp.c
327
+++ b/target/arm/translate-vfp.c
328
@@ -XXX,XX +XXX,XX @@ static bool vfp_access_check_a(DisasContext *s, bool ignore_vfp_enabled)
329
return false;
330
}
331
332
+ /*
333
+ * Note that rebuild_hflags_a32 has already accounted for being in EL0
334
+ * and the higher EL in A64 mode, etc. Unlike A64 mode, there do not
335
+ * appear to be any insns which touch VFP which are allowed.
336
+ */
337
+ if (s->sme_trap_nonstreaming) {
338
+ gen_exception_insn(s, s->pc_curr, EXCP_UDEF,
339
+ syn_smetrap(SME_ET_Streaming,
340
+ s->base.pc_next - s->pc_curr == 2));
341
+ return false;
342
+ }
343
+
344
if (!s->vfp_enabled && !ignore_vfp_enabled) {
345
assert(!arm_dc_feature(s, ARM_FEATURE_M));
346
unallocated_encoding(s);
347
diff --git a/target/arm/translate.c b/target/arm/translate.c
348
index XXXXXXX..XXXXXXX 100644
349
--- a/target/arm/translate.c
350
+++ b/target/arm/translate.c
351
@@ -XXX,XX +XXX,XX @@ static void arm_tr_init_disas_context(DisasContextBase *dcbase, CPUState *cs)
352
dc->vec_len = EX_TBFLAG_A32(tb_flags, VECLEN);
353
dc->vec_stride = EX_TBFLAG_A32(tb_flags, VECSTRIDE);
354
}
355
+ dc->sme_trap_nonstreaming =
356
+ EX_TBFLAG_A32(tb_flags, SME_TRAP_NONSTREAMING);
357
}
358
dc->cp_regs = cpu->cp_regs;
359
dc->features = env->features;
360
diff --git a/target/arm/meson.build b/target/arm/meson.build
361
index XXXXXXX..XXXXXXX 100644
362
--- a/target/arm/meson.build
363
+++ b/target/arm/meson.build
364
@@ -XXX,XX +XXX,XX @@
365
gen = [
366
decodetree.process('sve.decode', extra_args: '--decode=disas_sve'),
367
decodetree.process('sme.decode', extra_args: '--decode=disas_sme'),
368
+ decodetree.process('sme-fa64.decode', extra_args: '--static-decode=disas_sme_fa64'),
369
decodetree.process('neon-shared.decode', extra_args: '--decode=disas_neon_shared'),
370
decodetree.process('neon-dp.decode', extra_args: '--decode=disas_neon_dp'),
371
decodetree.process('neon-ls.decode', extra_args: '--decode=disas_neon_ls'),
59
--
372
--
60
2.20.1
373
2.25.1
61
62
diff view generated by jsdifflib
1
As the first step in converting the CMSDK_APB_DUALTIMER device to the
1
From: Richard Henderson <richard.henderson@linaro.org>
2
Clock framework, add a Clock input. For the moment we do nothing
3
with this clock; we will change the behaviour from using the pclk-frq
4
property to using the Clock once all the users of this device have
5
been converted to wire up the Clock.
6
2
7
We take the opportunity to correct the name of the clock input to
3
Mark ADR as a non-streaming instruction, which should trap
8
match the hardware -- the dual timer names the clock which drives the
4
if full a64 support is not enabled in streaming mode.
9
timers TIMCLK. (It does also have a 'pclk' input, which is used only
10
for the register and APB bus logic; on the SSE-200 these clocks are
11
both connected together.)
12
5
13
This is a migration compatibility break for machines mps2-an385,
6
Removing entries from sme-fa64.decode is an easy way to see
14
mps2-an386, mps2-an500, mps2-an511, mps2-an505, mps2-an521, musca-a,
7
what remains to be done.
15
musca-b1.
16
8
9
Reviewed-by: Peter Maydell <peter.maydell@linaro.org>
10
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
11
Message-id: 20220708151540.18136-5-richard.henderson@linaro.org
17
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
12
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
18
Reviewed-by: Philippe Mathieu-Daudé <f4bug@amsat.org>
19
Reviewed-by: Luc Michel <luc@lmichel.fr>
20
Tested-by: Philippe Mathieu-Daudé <f4bug@amsat.org>
21
Message-id: 20210128114145.20536-9-peter.maydell@linaro.org
22
Message-id: 20210121190622.22000-9-peter.maydell@linaro.org
23
---
13
---
24
include/hw/timer/cmsdk-apb-dualtimer.h | 3 +++
14
target/arm/translate.h | 7 +++++++
25
hw/timer/cmsdk-apb-dualtimer.c | 7 +++++--
15
target/arm/sme-fa64.decode | 1 -
26
2 files changed, 8 insertions(+), 2 deletions(-)
16
target/arm/translate-sve.c | 8 ++++----
17
3 files changed, 11 insertions(+), 5 deletions(-)
27
18
28
diff --git a/include/hw/timer/cmsdk-apb-dualtimer.h b/include/hw/timer/cmsdk-apb-dualtimer.h
19
diff --git a/target/arm/translate.h b/target/arm/translate.h
29
index XXXXXXX..XXXXXXX 100644
20
index XXXXXXX..XXXXXXX 100644
30
--- a/include/hw/timer/cmsdk-apb-dualtimer.h
21
--- a/target/arm/translate.h
31
+++ b/include/hw/timer/cmsdk-apb-dualtimer.h
22
+++ b/target/arm/translate.h
32
@@ -XXX,XX +XXX,XX @@
23
@@ -XXX,XX +XXX,XX @@ uint64_t asimd_imm_const(uint32_t imm, int cmode, int op);
33
*
24
static bool trans_##NAME(DisasContext *s, arg_##NAME *a) \
34
* QEMU interface:
25
{ return dc_isar_feature(FEAT, s) && FUNC(s, __VA_ARGS__); }
35
* + QOM property "pclk-frq": frequency at which the timer is clocked
26
36
+ * + Clock input "TIMCLK": clock (for both timers)
27
+#define TRANS_FEAT_NONSTREAMING(NAME, FEAT, FUNC, ...) \
37
* + sysbus MMIO region 0: the register bank
28
+ static bool trans_##NAME(DisasContext *s, arg_##NAME *a) \
38
* + sysbus IRQ 0: combined timer interrupt TIMINTC
29
+ { \
39
* + sysbus IRO 1: timer block 1 interrupt TIMINT1
30
+ s->is_nonstreaming = true; \
40
@@ -XXX,XX +XXX,XX @@
31
+ return dc_isar_feature(FEAT, s) && FUNC(s, __VA_ARGS__); \
41
32
+ }
42
#include "hw/sysbus.h"
33
+
43
#include "hw/ptimer.h"
34
#endif /* TARGET_ARM_TRANSLATE_H */
44
+#include "hw/clock.h"
35
diff --git a/target/arm/sme-fa64.decode b/target/arm/sme-fa64.decode
45
#include "qom/object.h"
46
47
#define TYPE_CMSDK_APB_DUALTIMER "cmsdk-apb-dualtimer"
48
@@ -XXX,XX +XXX,XX @@ struct CMSDKAPBDualTimer {
49
MemoryRegion iomem;
50
qemu_irq timerintc;
51
uint32_t pclk_frq;
52
+ Clock *timclk;
53
54
CMSDKAPBDualTimerModule timermod[CMSDK_APB_DUALTIMER_NUM_MODULES];
55
uint32_t timeritcr;
56
diff --git a/hw/timer/cmsdk-apb-dualtimer.c b/hw/timer/cmsdk-apb-dualtimer.c
57
index XXXXXXX..XXXXXXX 100644
36
index XXXXXXX..XXXXXXX 100644
58
--- a/hw/timer/cmsdk-apb-dualtimer.c
37
--- a/target/arm/sme-fa64.decode
59
+++ b/hw/timer/cmsdk-apb-dualtimer.c
38
+++ b/target/arm/sme-fa64.decode
60
@@ -XXX,XX +XXX,XX @@
39
@@ -XXX,XX +XXX,XX @@ FAIL 0001 1110 0111 1110 0000 00-- ---- ---- # FJCVTZS
61
#include "hw/irq.h"
40
# --11 1100 --1- ---- ---- ---- ---- --10 # Load/store FP register (register offset)
62
#include "hw/qdev-properties.h"
41
# --11 1101 ---- ---- ---- ---- ---- ---- # Load/store FP register (scaled imm)
63
#include "hw/registerfields.h"
42
64
+#include "hw/qdev-clock.h"
43
-FAIL 0000 0100 --1- ---- 1010 ---- ---- ---- # ADR
65
#include "hw/timer/cmsdk-apb-dualtimer.h"
44
FAIL 0000 0100 --1- ---- 1011 -0-- ---- ---- # FTSSEL, FEXPA
66
#include "migration/vmstate.h"
45
FAIL 0000 0101 --10 0001 100- ---- ---- ---- # COMPACT
67
46
FAIL 0010 0101 --01 100- 1111 000- ---0 ---- # RDFFR, RDFFRS
68
@@ -XXX,XX +XXX,XX @@ static void cmsdk_apb_dualtimer_init(Object *obj)
47
diff --git a/target/arm/translate-sve.c b/target/arm/translate-sve.c
69
for (i = 0; i < ARRAY_SIZE(s->timermod); i++) {
48
index XXXXXXX..XXXXXXX 100644
70
sysbus_init_irq(sbd, &s->timermod[i].timerint);
49
--- a/target/arm/translate-sve.c
71
}
50
+++ b/target/arm/translate-sve.c
72
+ s->timclk = qdev_init_clock_in(DEVICE(s), "TIMCLK", NULL, NULL);
51
@@ -XXX,XX +XXX,XX @@ static bool do_adr(DisasContext *s, arg_rrri *a, gen_helper_gvec_3 *fn)
52
return gen_gvec_ool_zzz(s, fn, a->rd, a->rn, a->rm, a->imm);
73
}
53
}
74
54
75
static void cmsdk_apb_dualtimer_realize(DeviceState *dev, Error **errp)
55
-TRANS_FEAT(ADR_p32, aa64_sve, do_adr, a, gen_helper_sve_adr_p32)
76
@@ -XXX,XX +XXX,XX @@ static const VMStateDescription cmsdk_dualtimermod_vmstate = {
56
-TRANS_FEAT(ADR_p64, aa64_sve, do_adr, a, gen_helper_sve_adr_p64)
77
57
-TRANS_FEAT(ADR_s32, aa64_sve, do_adr, a, gen_helper_sve_adr_s32)
78
static const VMStateDescription cmsdk_apb_dualtimer_vmstate = {
58
-TRANS_FEAT(ADR_u32, aa64_sve, do_adr, a, gen_helper_sve_adr_u32)
79
.name = "cmsdk-apb-dualtimer",
59
+TRANS_FEAT_NONSTREAMING(ADR_p32, aa64_sve, do_adr, a, gen_helper_sve_adr_p32)
80
- .version_id = 1,
60
+TRANS_FEAT_NONSTREAMING(ADR_p64, aa64_sve, do_adr, a, gen_helper_sve_adr_p64)
81
- .minimum_version_id = 1,
61
+TRANS_FEAT_NONSTREAMING(ADR_s32, aa64_sve, do_adr, a, gen_helper_sve_adr_s32)
82
+ .version_id = 2,
62
+TRANS_FEAT_NONSTREAMING(ADR_u32, aa64_sve, do_adr, a, gen_helper_sve_adr_u32)
83
+ .minimum_version_id = 2,
63
84
.fields = (VMStateField[]) {
64
/*
85
+ VMSTATE_CLOCK(timclk, CMSDKAPBDualTimer),
65
*** SVE Integer Misc - Unpredicated Group
86
VMSTATE_STRUCT_ARRAY(timermod, CMSDKAPBDualTimer,
87
CMSDK_APB_DUALTIMER_NUM_MODULES,
88
1, cmsdk_dualtimermod_vmstate,
89
--
66
--
90
2.20.1
67
2.25.1
91
92
diff view generated by jsdifflib
1
As the first step in converting the CMSDK_APB_TIMER device to the
1
From: Richard Henderson <richard.henderson@linaro.org>
2
Clock framework, add a Clock input. For the moment we do nothing
3
with this clock; we will change the behaviour from using the pclk-frq
4
property to using the Clock once all the users of this device have
5
been converted to wire up the Clock.
6
2
7
Since the device doesn't already have a doc comment for its "QEMU
3
Mark these as a non-streaming instructions, which should trap
8
interface", we add one including the new Clock.
4
if full a64 support is not enabled in streaming mode.
9
5
10
This is a migration compatibility break for machines mps2-an505,
6
Reviewed-by: Peter Maydell <peter.maydell@linaro.org>
11
mps2-an521, musca-a, musca-b1.
7
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
8
Message-id: 20220708151540.18136-6-richard.henderson@linaro.org
9
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
10
---
11
target/arm/sme-fa64.decode | 2 --
12
target/arm/translate-sve.c | 9 ++++++---
13
2 files changed, 6 insertions(+), 5 deletions(-)
12
14
13
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
15
diff --git a/target/arm/sme-fa64.decode b/target/arm/sme-fa64.decode
14
Reviewed-by: Philippe Mathieu-Daudé <f4bug@amsat.org>
15
Reviewed-by: Luc Michel <luc@lmichel.fr>
16
Tested-by: Philippe Mathieu-Daudé <f4bug@amsat.org>
17
Message-id: 20210128114145.20536-8-peter.maydell@linaro.org
18
Message-id: 20210121190622.22000-8-peter.maydell@linaro.org
19
---
20
include/hw/timer/cmsdk-apb-timer.h | 9 +++++++++
21
hw/timer/cmsdk-apb-timer.c | 7 +++++--
22
2 files changed, 14 insertions(+), 2 deletions(-)
23
24
diff --git a/include/hw/timer/cmsdk-apb-timer.h b/include/hw/timer/cmsdk-apb-timer.h
25
index XXXXXXX..XXXXXXX 100644
16
index XXXXXXX..XXXXXXX 100644
26
--- a/include/hw/timer/cmsdk-apb-timer.h
17
--- a/target/arm/sme-fa64.decode
27
+++ b/include/hw/timer/cmsdk-apb-timer.h
18
+++ b/target/arm/sme-fa64.decode
28
@@ -XXX,XX +XXX,XX @@
19
@@ -XXX,XX +XXX,XX @@ FAIL 0001 1110 0111 1110 0000 00-- ---- ---- # FJCVTZS
29
#include "hw/qdev-properties.h"
20
30
#include "hw/sysbus.h"
21
FAIL 0000 0100 --1- ---- 1011 -0-- ---- ---- # FTSSEL, FEXPA
31
#include "hw/ptimer.h"
22
FAIL 0000 0101 --10 0001 100- ---- ---- ---- # COMPACT
32
+#include "hw/clock.h"
23
-FAIL 0010 0101 --01 100- 1111 000- ---0 ---- # RDFFR, RDFFRS
33
#include "qom/object.h"
24
-FAIL 0010 0101 --10 1--- 1001 ---- ---- ---- # WRFFR, SETFFR
34
25
FAIL 0100 0101 --0- ---- 1011 ---- ---- ---- # BDEP, BEXT, BGRP
35
#define TYPE_CMSDK_APB_TIMER "cmsdk-apb-timer"
26
FAIL 0100 0101 000- ---- 0110 1--- ---- ---- # PMULLB, PMULLT (128b result)
36
OBJECT_DECLARE_SIMPLE_TYPE(CMSDKAPBTimer, CMSDK_APB_TIMER)
27
FAIL 0110 0100 --1- ---- 1110 01-- ---- ---- # FMMLA, BFMMLA
37
28
diff --git a/target/arm/translate-sve.c b/target/arm/translate-sve.c
38
+/*
39
+ * QEMU interface:
40
+ * + QOM property "pclk-frq": frequency at which the timer is clocked
41
+ * + Clock input "pclk": clock for the timer
42
+ * + sysbus MMIO region 0: the register bank
43
+ * + sysbus IRQ 0: timer interrupt TIMERINT
44
+ */
45
struct CMSDKAPBTimer {
46
/*< private >*/
47
SysBusDevice parent_obj;
48
@@ -XXX,XX +XXX,XX @@ struct CMSDKAPBTimer {
49
qemu_irq timerint;
50
uint32_t pclk_frq;
51
struct ptimer_state *timer;
52
+ Clock *pclk;
53
54
uint32_t ctrl;
55
uint32_t value;
56
diff --git a/hw/timer/cmsdk-apb-timer.c b/hw/timer/cmsdk-apb-timer.c
57
index XXXXXXX..XXXXXXX 100644
29
index XXXXXXX..XXXXXXX 100644
58
--- a/hw/timer/cmsdk-apb-timer.c
30
--- a/target/arm/translate-sve.c
59
+++ b/hw/timer/cmsdk-apb-timer.c
31
+++ b/target/arm/translate-sve.c
60
@@ -XXX,XX +XXX,XX @@
32
@@ -XXX,XX +XXX,XX @@ static bool do_predset(DisasContext *s, int esz, int rd, int pat, bool setflag)
61
#include "hw/sysbus.h"
33
TRANS_FEAT(PTRUE, aa64_sve, do_predset, a->esz, a->rd, a->pat, a->s)
62
#include "hw/irq.h"
34
63
#include "hw/registerfields.h"
35
/* Note pat == 31 is #all, to set all elements. */
64
+#include "hw/qdev-clock.h"
36
-TRANS_FEAT(SETFFR, aa64_sve, do_predset, 0, FFR_PRED_NUM, 31, false)
65
#include "hw/timer/cmsdk-apb-timer.h"
37
+TRANS_FEAT_NONSTREAMING(SETFFR, aa64_sve,
66
#include "migration/vmstate.h"
38
+ do_predset, 0, FFR_PRED_NUM, 31, false)
67
39
68
@@ -XXX,XX +XXX,XX @@ static void cmsdk_apb_timer_init(Object *obj)
40
/* Note pat == 32 is #unimp, to set no elements. */
69
s, "cmsdk-apb-timer", 0x1000);
41
TRANS_FEAT(PFALSE, aa64_sve, do_predset, 0, a->rd, 32, false)
70
sysbus_init_mmio(sbd, &s->iomem);
42
@@ -XXX,XX +XXX,XX @@ static bool trans_RDFFR_p(DisasContext *s, arg_RDFFR_p *a)
71
sysbus_init_irq(sbd, &s->timerint);
43
.rd = a->rd, .pg = a->pg, .s = a->s,
72
+ s->pclk = qdev_init_clock_in(DEVICE(s), "pclk", NULL, NULL);
44
.rn = FFR_PRED_NUM, .rm = FFR_PRED_NUM,
45
};
46
+
47
+ s->is_nonstreaming = true;
48
return trans_AND_pppp(s, &alt_a);
73
}
49
}
74
50
75
static void cmsdk_apb_timer_realize(DeviceState *dev, Error **errp)
51
-TRANS_FEAT(RDFFR, aa64_sve, do_mov_p, a->rd, FFR_PRED_NUM)
76
@@ -XXX,XX +XXX,XX @@ static void cmsdk_apb_timer_realize(DeviceState *dev, Error **errp)
52
-TRANS_FEAT(WRFFR, aa64_sve, do_mov_p, FFR_PRED_NUM, a->rn)
77
53
+TRANS_FEAT_NONSTREAMING(RDFFR, aa64_sve, do_mov_p, a->rd, FFR_PRED_NUM)
78
static const VMStateDescription cmsdk_apb_timer_vmstate = {
54
+TRANS_FEAT_NONSTREAMING(WRFFR, aa64_sve, do_mov_p, FFR_PRED_NUM, a->rn)
79
.name = "cmsdk-apb-timer",
55
80
- .version_id = 1,
56
static bool do_pfirst_pnext(DisasContext *s, arg_rr_esz *a,
81
- .minimum_version_id = 1,
57
void (*gen_fn)(TCGv_i32, TCGv_ptr,
82
+ .version_id = 2,
83
+ .minimum_version_id = 2,
84
.fields = (VMStateField[]) {
85
VMSTATE_PTIMER(timer, CMSDKAPBTimer),
86
+ VMSTATE_CLOCK(pclk, CMSDKAPBTimer),
87
VMSTATE_UINT32(ctrl, CMSDKAPBTimer),
88
VMSTATE_UINT32(value, CMSDKAPBTimer),
89
VMSTATE_UINT32(reload, CMSDKAPBTimer),
90
--
58
--
91
2.20.1
59
2.25.1
92
93
diff view generated by jsdifflib
1
Now no users are setting the frq properties on the CMSDK timer,
1
From: Richard Henderson <richard.henderson@linaro.org>
2
dualtimer, watchdog or ARMSSE SoC devices, we can remove the
3
properties and the struct fields that back them.
4
2
3
Mark these as a non-streaming instructions, which should trap
4
if full a64 support is not enabled in streaming mode.
5
6
Reviewed-by: Peter Maydell <peter.maydell@linaro.org>
7
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
8
Message-id: 20220708151540.18136-7-richard.henderson@linaro.org
5
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
9
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
6
Reviewed-by: Philippe Mathieu-Daudé <f4bug@amsat.org>
7
Reviewed-by: Luc Michel <luc@lmichel.fr>
8
Tested-by: Philippe Mathieu-Daudé <f4bug@amsat.org>
9
Message-id: 20210128114145.20536-25-peter.maydell@linaro.org
10
Message-id: 20210121190622.22000-25-peter.maydell@linaro.org
11
---
10
---
12
include/hw/arm/armsse.h | 2 --
11
target/arm/sme-fa64.decode | 3 ---
13
include/hw/timer/cmsdk-apb-dualtimer.h | 2 --
12
target/arm/translate-sve.c | 22 ++++++++++++----------
14
include/hw/timer/cmsdk-apb-timer.h | 2 --
13
2 files changed, 12 insertions(+), 13 deletions(-)
15
include/hw/watchdog/cmsdk-apb-watchdog.h | 2 --
16
hw/arm/armsse.c | 2 --
17
hw/timer/cmsdk-apb-dualtimer.c | 6 ------
18
hw/timer/cmsdk-apb-timer.c | 6 ------
19
hw/watchdog/cmsdk-apb-watchdog.c | 6 ------
20
8 files changed, 28 deletions(-)
21
14
22
diff --git a/include/hw/arm/armsse.h b/include/hw/arm/armsse.h
15
diff --git a/target/arm/sme-fa64.decode b/target/arm/sme-fa64.decode
23
index XXXXXXX..XXXXXXX 100644
16
index XXXXXXX..XXXXXXX 100644
24
--- a/include/hw/arm/armsse.h
17
--- a/target/arm/sme-fa64.decode
25
+++ b/include/hw/arm/armsse.h
18
+++ b/target/arm/sme-fa64.decode
26
@@ -XXX,XX +XXX,XX @@
19
@@ -XXX,XX +XXX,XX @@ FAIL 0001 1110 0111 1110 0000 00-- ---- ---- # FJCVTZS
27
* + Clock input "S32KCLK": slow 32KHz clock used for a few peripherals
20
# --11 1100 --1- ---- ---- ---- ---- --10 # Load/store FP register (register offset)
28
* + QOM property "memory" is a MemoryRegion containing the devices provided
21
# --11 1101 ---- ---- ---- ---- ---- ---- # Load/store FP register (scaled imm)
29
* by the board model.
22
30
- * + QOM property "MAINCLK_FRQ" is the frequency of the main system clock
23
-FAIL 0000 0100 --1- ---- 1011 -0-- ---- ---- # FTSSEL, FEXPA
31
* + QOM property "EXP_NUMIRQ" sets the number of expansion interrupts.
24
-FAIL 0000 0101 --10 0001 100- ---- ---- ---- # COMPACT
32
* (In hardware, the SSE-200 permits the number of expansion interrupts
25
-FAIL 0100 0101 --0- ---- 1011 ---- ---- ---- # BDEP, BEXT, BGRP
33
* for the two CPUs to be configured separately, but we restrict it to
26
FAIL 0100 0101 000- ---- 0110 1--- ---- ---- # PMULLB, PMULLT (128b result)
34
@@ -XXX,XX +XXX,XX @@ struct ARMSSE {
27
FAIL 0110 0100 --1- ---- 1110 01-- ---- ---- # FMMLA, BFMMLA
35
/* Properties */
28
FAIL 0110 0101 --0- ---- 0000 11-- ---- ---- # FTSMUL
36
MemoryRegion *board_memory;
29
diff --git a/target/arm/translate-sve.c b/target/arm/translate-sve.c
37
uint32_t exp_numirq;
38
- uint32_t mainclk_frq;
39
uint32_t sram_addr_width;
40
uint32_t init_svtor;
41
bool cpu_fpu[SSE_MAX_CPUS];
42
diff --git a/include/hw/timer/cmsdk-apb-dualtimer.h b/include/hw/timer/cmsdk-apb-dualtimer.h
43
index XXXXXXX..XXXXXXX 100644
30
index XXXXXXX..XXXXXXX 100644
44
--- a/include/hw/timer/cmsdk-apb-dualtimer.h
31
--- a/target/arm/translate-sve.c
45
+++ b/include/hw/timer/cmsdk-apb-dualtimer.h
32
+++ b/target/arm/translate-sve.c
46
@@ -XXX,XX +XXX,XX @@
33
@@ -XXX,XX +XXX,XX @@ static gen_helper_gvec_2 * const fexpa_fns[4] = {
47
* https://developer.arm.com/products/system-design/system-design-kits/cortex-m-system-design-kit
34
NULL, gen_helper_sve_fexpa_h,
48
*
35
gen_helper_sve_fexpa_s, gen_helper_sve_fexpa_d,
49
* QEMU interface:
36
};
50
- * + QOM property "pclk-frq": frequency at which the timer is clocked
37
-TRANS_FEAT(FEXPA, aa64_sve, gen_gvec_ool_zz,
51
* + Clock input "TIMCLK": clock (for both timers)
38
- fexpa_fns[a->esz], a->rd, a->rn, 0)
52
* + sysbus MMIO region 0: the register bank
39
+TRANS_FEAT_NONSTREAMING(FEXPA, aa64_sve, gen_gvec_ool_zz,
53
* + sysbus IRQ 0: combined timer interrupt TIMINTC
40
+ fexpa_fns[a->esz], a->rd, a->rn, 0)
54
@@ -XXX,XX +XXX,XX @@ struct CMSDKAPBDualTimer {
41
55
/*< public >*/
42
static gen_helper_gvec_3 * const ftssel_fns[4] = {
56
MemoryRegion iomem;
43
NULL, gen_helper_sve_ftssel_h,
57
qemu_irq timerintc;
44
gen_helper_sve_ftssel_s, gen_helper_sve_ftssel_d,
58
- uint32_t pclk_frq;
45
};
59
Clock *timclk;
46
-TRANS_FEAT(FTSSEL, aa64_sve, gen_gvec_ool_arg_zzz, ftssel_fns[a->esz], a, 0)
60
47
+TRANS_FEAT_NONSTREAMING(FTSSEL, aa64_sve, gen_gvec_ool_arg_zzz,
61
CMSDKAPBDualTimerModule timermod[CMSDK_APB_DUALTIMER_NUM_MODULES];
48
+ ftssel_fns[a->esz], a, 0)
62
diff --git a/include/hw/timer/cmsdk-apb-timer.h b/include/hw/timer/cmsdk-apb-timer.h
63
index XXXXXXX..XXXXXXX 100644
64
--- a/include/hw/timer/cmsdk-apb-timer.h
65
+++ b/include/hw/timer/cmsdk-apb-timer.h
66
@@ -XXX,XX +XXX,XX @@ OBJECT_DECLARE_SIMPLE_TYPE(CMSDKAPBTimer, CMSDK_APB_TIMER)
67
49
68
/*
50
/*
69
* QEMU interface:
51
*** SVE Predicate Logical Operations Group
70
- * + QOM property "pclk-frq": frequency at which the timer is clocked
52
@@ -XXX,XX +XXX,XX @@ TRANS_FEAT(TRN2_q, aa64_sve_f64mm, gen_gvec_ool_arg_zzz,
71
* + Clock input "pclk": clock for the timer
53
static gen_helper_gvec_3 * const compact_fns[4] = {
72
* + sysbus MMIO region 0: the register bank
54
NULL, NULL, gen_helper_sve_compact_s, gen_helper_sve_compact_d
73
* + sysbus IRQ 0: timer interrupt TIMERINT
74
@@ -XXX,XX +XXX,XX @@ struct CMSDKAPBTimer {
75
/*< public >*/
76
MemoryRegion iomem;
77
qemu_irq timerint;
78
- uint32_t pclk_frq;
79
struct ptimer_state *timer;
80
Clock *pclk;
81
82
diff --git a/include/hw/watchdog/cmsdk-apb-watchdog.h b/include/hw/watchdog/cmsdk-apb-watchdog.h
83
index XXXXXXX..XXXXXXX 100644
84
--- a/include/hw/watchdog/cmsdk-apb-watchdog.h
85
+++ b/include/hw/watchdog/cmsdk-apb-watchdog.h
86
@@ -XXX,XX +XXX,XX @@
87
* https://developer.arm.com/products/system-design/system-design-kits/cortex-m-system-design-kit
88
*
89
* QEMU interface:
90
- * + QOM property "wdogclk-frq": frequency at which the watchdog is clocked
91
* + Clock input "WDOGCLK": clock for the watchdog's timer
92
* + sysbus MMIO region 0: the register bank
93
* + sysbus IRQ 0: watchdog interrupt
94
@@ -XXX,XX +XXX,XX @@ struct CMSDKAPBWatchdog {
95
/*< public >*/
96
MemoryRegion iomem;
97
qemu_irq wdogint;
98
- uint32_t wdogclk_frq;
99
bool is_luminary;
100
struct ptimer_state *timer;
101
Clock *wdogclk;
102
diff --git a/hw/arm/armsse.c b/hw/arm/armsse.c
103
index XXXXXXX..XXXXXXX 100644
104
--- a/hw/arm/armsse.c
105
+++ b/hw/arm/armsse.c
106
@@ -XXX,XX +XXX,XX @@ static Property iotkit_properties[] = {
107
DEFINE_PROP_LINK("memory", ARMSSE, board_memory, TYPE_MEMORY_REGION,
108
MemoryRegion *),
109
DEFINE_PROP_UINT32("EXP_NUMIRQ", ARMSSE, exp_numirq, 64),
110
- DEFINE_PROP_UINT32("MAINCLK_FRQ", ARMSSE, mainclk_frq, 0),
111
DEFINE_PROP_UINT32("SRAM_ADDR_WIDTH", ARMSSE, sram_addr_width, 15),
112
DEFINE_PROP_UINT32("init-svtor", ARMSSE, init_svtor, 0x10000000),
113
DEFINE_PROP_BOOL("CPU0_FPU", ARMSSE, cpu_fpu[0], true),
114
@@ -XXX,XX +XXX,XX @@ static Property armsse_properties[] = {
115
DEFINE_PROP_LINK("memory", ARMSSE, board_memory, TYPE_MEMORY_REGION,
116
MemoryRegion *),
117
DEFINE_PROP_UINT32("EXP_NUMIRQ", ARMSSE, exp_numirq, 64),
118
- DEFINE_PROP_UINT32("MAINCLK_FRQ", ARMSSE, mainclk_frq, 0),
119
DEFINE_PROP_UINT32("SRAM_ADDR_WIDTH", ARMSSE, sram_addr_width, 15),
120
DEFINE_PROP_UINT32("init-svtor", ARMSSE, init_svtor, 0x10000000),
121
DEFINE_PROP_BOOL("CPU0_FPU", ARMSSE, cpu_fpu[0], false),
122
diff --git a/hw/timer/cmsdk-apb-dualtimer.c b/hw/timer/cmsdk-apb-dualtimer.c
123
index XXXXXXX..XXXXXXX 100644
124
--- a/hw/timer/cmsdk-apb-dualtimer.c
125
+++ b/hw/timer/cmsdk-apb-dualtimer.c
126
@@ -XXX,XX +XXX,XX @@ static const VMStateDescription cmsdk_apb_dualtimer_vmstate = {
127
}
128
};
55
};
129
56
-TRANS_FEAT(COMPACT, aa64_sve, gen_gvec_ool_arg_zpz, compact_fns[a->esz], a, 0)
130
-static Property cmsdk_apb_dualtimer_properties[] = {
57
+TRANS_FEAT_NONSTREAMING(COMPACT, aa64_sve, gen_gvec_ool_arg_zpz,
131
- DEFINE_PROP_UINT32("pclk-frq", CMSDKAPBDualTimer, pclk_frq, 0),
58
+ compact_fns[a->esz], a, 0)
132
- DEFINE_PROP_END_OF_LIST(),
59
133
-};
60
/* Call the helper that computes the ARM LastActiveElement pseudocode
134
-
61
* function, scaled by the element size. This includes the not found
135
static void cmsdk_apb_dualtimer_class_init(ObjectClass *klass, void *data)
62
@@ -XXX,XX +XXX,XX @@ static gen_helper_gvec_3 * const bext_fns[4] = {
136
{
63
gen_helper_sve2_bext_b, gen_helper_sve2_bext_h,
137
DeviceClass *dc = DEVICE_CLASS(klass);
64
gen_helper_sve2_bext_s, gen_helper_sve2_bext_d,
138
@@ -XXX,XX +XXX,XX @@ static void cmsdk_apb_dualtimer_class_init(ObjectClass *klass, void *data)
139
dc->realize = cmsdk_apb_dualtimer_realize;
140
dc->vmsd = &cmsdk_apb_dualtimer_vmstate;
141
dc->reset = cmsdk_apb_dualtimer_reset;
142
- device_class_set_props(dc, cmsdk_apb_dualtimer_properties);
143
}
144
145
static const TypeInfo cmsdk_apb_dualtimer_info = {
146
diff --git a/hw/timer/cmsdk-apb-timer.c b/hw/timer/cmsdk-apb-timer.c
147
index XXXXXXX..XXXXXXX 100644
148
--- a/hw/timer/cmsdk-apb-timer.c
149
+++ b/hw/timer/cmsdk-apb-timer.c
150
@@ -XXX,XX +XXX,XX @@ static const VMStateDescription cmsdk_apb_timer_vmstate = {
151
}
152
};
65
};
153
66
-TRANS_FEAT(BEXT, aa64_sve2_bitperm, gen_gvec_ool_arg_zzz,
154
-static Property cmsdk_apb_timer_properties[] = {
67
- bext_fns[a->esz], a, 0)
155
- DEFINE_PROP_UINT32("pclk-frq", CMSDKAPBTimer, pclk_frq, 0),
68
+TRANS_FEAT_NONSTREAMING(BEXT, aa64_sve2_bitperm, gen_gvec_ool_arg_zzz,
156
- DEFINE_PROP_END_OF_LIST(),
69
+ bext_fns[a->esz], a, 0)
157
-};
70
158
-
71
static gen_helper_gvec_3 * const bdep_fns[4] = {
159
static void cmsdk_apb_timer_class_init(ObjectClass *klass, void *data)
72
gen_helper_sve2_bdep_b, gen_helper_sve2_bdep_h,
160
{
73
gen_helper_sve2_bdep_s, gen_helper_sve2_bdep_d,
161
DeviceClass *dc = DEVICE_CLASS(klass);
162
@@ -XXX,XX +XXX,XX @@ static void cmsdk_apb_timer_class_init(ObjectClass *klass, void *data)
163
dc->realize = cmsdk_apb_timer_realize;
164
dc->vmsd = &cmsdk_apb_timer_vmstate;
165
dc->reset = cmsdk_apb_timer_reset;
166
- device_class_set_props(dc, cmsdk_apb_timer_properties);
167
}
168
169
static const TypeInfo cmsdk_apb_timer_info = {
170
diff --git a/hw/watchdog/cmsdk-apb-watchdog.c b/hw/watchdog/cmsdk-apb-watchdog.c
171
index XXXXXXX..XXXXXXX 100644
172
--- a/hw/watchdog/cmsdk-apb-watchdog.c
173
+++ b/hw/watchdog/cmsdk-apb-watchdog.c
174
@@ -XXX,XX +XXX,XX @@ static const VMStateDescription cmsdk_apb_watchdog_vmstate = {
175
}
176
};
74
};
177
75
-TRANS_FEAT(BDEP, aa64_sve2_bitperm, gen_gvec_ool_arg_zzz,
178
-static Property cmsdk_apb_watchdog_properties[] = {
76
- bdep_fns[a->esz], a, 0)
179
- DEFINE_PROP_UINT32("wdogclk-frq", CMSDKAPBWatchdog, wdogclk_frq, 0),
77
+TRANS_FEAT_NONSTREAMING(BDEP, aa64_sve2_bitperm, gen_gvec_ool_arg_zzz,
180
- DEFINE_PROP_END_OF_LIST(),
78
+ bdep_fns[a->esz], a, 0)
181
-};
79
182
-
80
static gen_helper_gvec_3 * const bgrp_fns[4] = {
183
static void cmsdk_apb_watchdog_class_init(ObjectClass *klass, void *data)
81
gen_helper_sve2_bgrp_b, gen_helper_sve2_bgrp_h,
184
{
82
gen_helper_sve2_bgrp_s, gen_helper_sve2_bgrp_d,
185
DeviceClass *dc = DEVICE_CLASS(klass);
83
};
186
@@ -XXX,XX +XXX,XX @@ static void cmsdk_apb_watchdog_class_init(ObjectClass *klass, void *data)
84
-TRANS_FEAT(BGRP, aa64_sve2_bitperm, gen_gvec_ool_arg_zzz,
187
dc->realize = cmsdk_apb_watchdog_realize;
85
- bgrp_fns[a->esz], a, 0)
188
dc->vmsd = &cmsdk_apb_watchdog_vmstate;
86
+TRANS_FEAT_NONSTREAMING(BGRP, aa64_sve2_bitperm, gen_gvec_ool_arg_zzz,
189
dc->reset = cmsdk_apb_watchdog_reset;
87
+ bgrp_fns[a->esz], a, 0)
190
- device_class_set_props(dc, cmsdk_apb_watchdog_properties);
88
191
}
89
static gen_helper_gvec_3 * const cadd_fns[4] = {
192
90
gen_helper_sve2_cadd_b, gen_helper_sve2_cadd_h,
193
static const TypeInfo cmsdk_apb_watchdog_info = {
194
--
91
--
195
2.20.1
92
2.25.1
196
197
diff view generated by jsdifflib
1
Remove all the code that sets frequency properties on the CMSDK
1
From: Richard Henderson <richard.henderson@linaro.org>
2
timer, dualtimer and watchdog devices and on the ARMSSE SoC device:
3
these properties are unused now that the devices rely on their Clock
4
inputs instead.
5
2
3
Mark these as a non-streaming instructions, which should trap
4
if full a64 support is not enabled in streaming mode.
5
6
Reviewed-by: Peter Maydell <peter.maydell@linaro.org>
7
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
8
Message-id: 20220708151540.18136-8-richard.henderson@linaro.org
6
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
9
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
7
Reviewed-by: Philippe Mathieu-Daudé <f4bug@amsat.org>
8
Reviewed-by: Luc Michel <luc@lmichel.fr>
9
Tested-by: Philippe Mathieu-Daudé <f4bug@amsat.org>
10
Message-id: 20210128114145.20536-24-peter.maydell@linaro.org
11
Message-id: 20210121190622.22000-24-peter.maydell@linaro.org
12
---
10
---
13
hw/arm/armsse.c | 7 -------
11
target/arm/sme-fa64.decode | 2 --
14
hw/arm/mps2-tz.c | 1 -
12
target/arm/translate-sve.c | 24 +++++++++++++++---------
15
hw/arm/mps2.c | 3 ---
13
2 files changed, 15 insertions(+), 11 deletions(-)
16
hw/arm/musca.c | 1 -
17
hw/arm/stellaris.c | 3 ---
18
5 files changed, 15 deletions(-)
19
14
20
diff --git a/hw/arm/armsse.c b/hw/arm/armsse.c
15
diff --git a/target/arm/sme-fa64.decode b/target/arm/sme-fa64.decode
21
index XXXXXXX..XXXXXXX 100644
16
index XXXXXXX..XXXXXXX 100644
22
--- a/hw/arm/armsse.c
17
--- a/target/arm/sme-fa64.decode
23
+++ b/hw/arm/armsse.c
18
+++ b/target/arm/sme-fa64.decode
24
@@ -XXX,XX +XXX,XX @@ static void armsse_realize(DeviceState *dev, Error **errp)
19
@@ -XXX,XX +XXX,XX @@ FAIL 0001 1110 0111 1110 0000 00-- ---- ---- # FJCVTZS
25
* it to the appropriate PPC port; then we can realize the PPC and
20
# --11 1100 --1- ---- ---- ---- ---- --10 # Load/store FP register (register offset)
26
* map its upstream ends to the right place in the container.
21
# --11 1101 ---- ---- ---- ---- ---- ---- # Load/store FP register (scaled imm)
27
*/
22
28
- qdev_prop_set_uint32(DEVICE(&s->timer0), "pclk-frq", s->mainclk_frq);
23
-FAIL 0100 0101 000- ---- 0110 1--- ---- ---- # PMULLB, PMULLT (128b result)
29
qdev_connect_clock_in(DEVICE(&s->timer0), "pclk", s->mainclk);
24
-FAIL 0110 0100 --1- ---- 1110 01-- ---- ---- # FMMLA, BFMMLA
30
if (!sysbus_realize(SYS_BUS_DEVICE(&s->timer0), errp)) {
25
FAIL 0110 0101 --0- ---- 0000 11-- ---- ---- # FTSMUL
31
return;
26
FAIL 0110 0101 --01 0--- 100- ---- ---- ---- # FTMAD
32
@@ -XXX,XX +XXX,XX @@ static void armsse_realize(DeviceState *dev, Error **errp)
27
FAIL 0110 0101 --01 1--- 001- ---- ---- ---- # FADDA
33
object_property_set_link(OBJECT(&s->apb_ppc0), "port[0]", OBJECT(mr),
28
diff --git a/target/arm/translate-sve.c b/target/arm/translate-sve.c
34
&error_abort);
35
36
- qdev_prop_set_uint32(DEVICE(&s->timer1), "pclk-frq", s->mainclk_frq);
37
qdev_connect_clock_in(DEVICE(&s->timer1), "pclk", s->mainclk);
38
if (!sysbus_realize(SYS_BUS_DEVICE(&s->timer1), errp)) {
39
return;
40
@@ -XXX,XX +XXX,XX @@ static void armsse_realize(DeviceState *dev, Error **errp)
41
object_property_set_link(OBJECT(&s->apb_ppc0), "port[1]", OBJECT(mr),
42
&error_abort);
43
44
- qdev_prop_set_uint32(DEVICE(&s->dualtimer), "pclk-frq", s->mainclk_frq);
45
qdev_connect_clock_in(DEVICE(&s->dualtimer), "TIMCLK", s->mainclk);
46
if (!sysbus_realize(SYS_BUS_DEVICE(&s->dualtimer), errp)) {
47
return;
48
@@ -XXX,XX +XXX,XX @@ static void armsse_realize(DeviceState *dev, Error **errp)
49
/* Devices behind APB PPC1:
50
* 0x4002f000: S32K timer
51
*/
52
- qdev_prop_set_uint32(DEVICE(&s->s32ktimer), "pclk-frq", S32KCLK);
53
qdev_connect_clock_in(DEVICE(&s->s32ktimer), "pclk", s->s32kclk);
54
if (!sysbus_realize(SYS_BUS_DEVICE(&s->s32ktimer), errp)) {
55
return;
56
@@ -XXX,XX +XXX,XX @@ static void armsse_realize(DeviceState *dev, Error **errp)
57
qdev_connect_gpio_out(DEVICE(&s->nmi_orgate), 0,
58
qdev_get_gpio_in_named(DEVICE(&s->armv7m), "NMI", 0));
59
60
- qdev_prop_set_uint32(DEVICE(&s->s32kwatchdog), "wdogclk-frq", S32KCLK);
61
qdev_connect_clock_in(DEVICE(&s->s32kwatchdog), "WDOGCLK", s->s32kclk);
62
if (!sysbus_realize(SYS_BUS_DEVICE(&s->s32kwatchdog), errp)) {
63
return;
64
@@ -XXX,XX +XXX,XX @@ static void armsse_realize(DeviceState *dev, Error **errp)
65
66
/* 0x40080000 .. 0x4008ffff : ARMSSE second Base peripheral region */
67
68
- qdev_prop_set_uint32(DEVICE(&s->nswatchdog), "wdogclk-frq", s->mainclk_frq);
69
qdev_connect_clock_in(DEVICE(&s->nswatchdog), "WDOGCLK", s->mainclk);
70
if (!sysbus_realize(SYS_BUS_DEVICE(&s->nswatchdog), errp)) {
71
return;
72
@@ -XXX,XX +XXX,XX @@ static void armsse_realize(DeviceState *dev, Error **errp)
73
armsse_get_common_irq_in(s, 1));
74
sysbus_mmio_map(SYS_BUS_DEVICE(&s->nswatchdog), 0, 0x40081000);
75
76
- qdev_prop_set_uint32(DEVICE(&s->swatchdog), "wdogclk-frq", s->mainclk_frq);
77
qdev_connect_clock_in(DEVICE(&s->swatchdog), "WDOGCLK", s->mainclk);
78
if (!sysbus_realize(SYS_BUS_DEVICE(&s->swatchdog), errp)) {
79
return;
80
diff --git a/hw/arm/mps2-tz.c b/hw/arm/mps2-tz.c
81
index XXXXXXX..XXXXXXX 100644
29
index XXXXXXX..XXXXXXX 100644
82
--- a/hw/arm/mps2-tz.c
30
--- a/target/arm/translate-sve.c
83
+++ b/hw/arm/mps2-tz.c
31
+++ b/target/arm/translate-sve.c
84
@@ -XXX,XX +XXX,XX @@ static void mps2tz_common_init(MachineState *machine)
32
@@ -XXX,XX +XXX,XX @@ static bool do_trans_pmull(DisasContext *s, arg_rrr_esz *a, bool sel)
85
object_property_set_link(OBJECT(&mms->iotkit), "memory",
33
gen_helper_gvec_pmull_q, gen_helper_sve2_pmull_h,
86
OBJECT(system_memory), &error_abort);
34
NULL, gen_helper_sve2_pmull_d,
87
qdev_prop_set_uint32(iotkitdev, "EXP_NUMIRQ", MPS2TZ_NUMIRQ);
35
};
88
- qdev_prop_set_uint32(iotkitdev, "MAINCLK_FRQ", SYSCLK_FRQ);
36
- if (a->esz == 0
89
qdev_connect_clock_in(iotkitdev, "MAINCLK", mms->sysclk);
37
- ? !dc_isar_feature(aa64_sve2_pmull128, s)
90
qdev_connect_clock_in(iotkitdev, "S32KCLK", mms->s32kclk);
38
- : !dc_isar_feature(aa64_sve, s)) {
91
sysbus_realize(SYS_BUS_DEVICE(&mms->iotkit), &error_fatal);
39
+
92
diff --git a/hw/arm/mps2.c b/hw/arm/mps2.c
40
+ if (a->esz == 0) {
93
index XXXXXXX..XXXXXXX 100644
41
+ if (!dc_isar_feature(aa64_sve2_pmull128, s)) {
94
--- a/hw/arm/mps2.c
42
+ return false;
95
+++ b/hw/arm/mps2.c
43
+ }
96
@@ -XXX,XX +XXX,XX @@ static void mps2_common_init(MachineState *machine)
44
+ s->is_nonstreaming = true;
97
object_initialize_child(OBJECT(mms), name, &mms->timer[i],
45
+ } else if (!dc_isar_feature(aa64_sve, s)) {
98
TYPE_CMSDK_APB_TIMER);
46
return false;
99
sbd = SYS_BUS_DEVICE(&mms->timer[i]);
47
}
100
- qdev_prop_set_uint32(DEVICE(&mms->timer[i]), "pclk-frq", SYSCLK_FRQ);
48
return gen_gvec_ool_arg_zzz(s, fns[a->esz], a, sel);
101
qdev_connect_clock_in(DEVICE(&mms->timer[i]), "pclk", mms->sysclk);
49
@@ -XXX,XX +XXX,XX @@ DO_ZPZZ_FP(FMINP, aa64_sve2, sve2_fminp_zpzz)
102
sysbus_realize_and_unref(sbd, &error_fatal);
50
* SVE Integer Multiply-Add (unpredicated)
103
sysbus_mmio_map(sbd, 0, base);
51
*/
104
@@ -XXX,XX +XXX,XX @@ static void mps2_common_init(MachineState *machine)
52
105
53
-TRANS_FEAT(FMMLA_s, aa64_sve_f32mm, gen_gvec_fpst_zzzz, gen_helper_fmmla_s,
106
object_initialize_child(OBJECT(mms), "dualtimer", &mms->dualtimer,
54
- a->rd, a->rn, a->rm, a->ra, 0, FPST_FPCR)
107
TYPE_CMSDK_APB_DUALTIMER);
55
-TRANS_FEAT(FMMLA_d, aa64_sve_f64mm, gen_gvec_fpst_zzzz, gen_helper_fmmla_d,
108
- qdev_prop_set_uint32(DEVICE(&mms->dualtimer), "pclk-frq", SYSCLK_FRQ);
56
- a->rd, a->rn, a->rm, a->ra, 0, FPST_FPCR)
109
qdev_connect_clock_in(DEVICE(&mms->dualtimer), "TIMCLK", mms->sysclk);
57
+TRANS_FEAT_NONSTREAMING(FMMLA_s, aa64_sve_f32mm, gen_gvec_fpst_zzzz,
110
sysbus_realize(SYS_BUS_DEVICE(&mms->dualtimer), &error_fatal);
58
+ gen_helper_fmmla_s, a->rd, a->rn, a->rm, a->ra,
111
sysbus_connect_irq(SYS_BUS_DEVICE(&mms->dualtimer), 0,
59
+ 0, FPST_FPCR)
112
@@ -XXX,XX +XXX,XX @@ static void mps2_common_init(MachineState *machine)
60
+TRANS_FEAT_NONSTREAMING(FMMLA_d, aa64_sve_f64mm, gen_gvec_fpst_zzzz,
113
sysbus_mmio_map(SYS_BUS_DEVICE(&mms->dualtimer), 0, 0x40002000);
61
+ gen_helper_fmmla_d, a->rd, a->rn, a->rm, a->ra,
114
object_initialize_child(OBJECT(mms), "watchdog", &mms->watchdog,
62
+ 0, FPST_FPCR)
115
TYPE_CMSDK_APB_WATCHDOG);
63
116
- qdev_prop_set_uint32(DEVICE(&mms->watchdog), "wdogclk-frq", SYSCLK_FRQ);
64
static gen_helper_gvec_4 * const sqdmlal_zzzw_fns[] = {
117
qdev_connect_clock_in(DEVICE(&mms->watchdog), "WDOGCLK", mms->sysclk);
65
NULL, gen_helper_sve2_sqdmlal_zzzw_h,
118
sysbus_realize(SYS_BUS_DEVICE(&mms->watchdog), &error_fatal);
66
@@ -XXX,XX +XXX,XX @@ TRANS_FEAT(BFDOT_zzzz, aa64_sve_bf16, gen_gvec_ool_arg_zzzz,
119
sysbus_connect_irq(SYS_BUS_DEVICE(&mms->watchdog), 0,
67
TRANS_FEAT(BFDOT_zzxz, aa64_sve_bf16, gen_gvec_ool_arg_zzxz,
120
diff --git a/hw/arm/musca.c b/hw/arm/musca.c
68
gen_helper_gvec_bfdot_idx, a)
121
index XXXXXXX..XXXXXXX 100644
69
122
--- a/hw/arm/musca.c
70
-TRANS_FEAT(BFMMLA, aa64_sve_bf16, gen_gvec_ool_arg_zzzz,
123
+++ b/hw/arm/musca.c
71
- gen_helper_gvec_bfmmla, a, 0)
124
@@ -XXX,XX +XXX,XX @@ static void musca_init(MachineState *machine)
72
+TRANS_FEAT_NONSTREAMING(BFMMLA, aa64_sve_bf16, gen_gvec_ool_arg_zzzz,
125
qdev_prop_set_uint32(ssedev, "EXP_NUMIRQ", mmc->num_irqs);
73
+ gen_helper_gvec_bfmmla, a, 0)
126
qdev_prop_set_uint32(ssedev, "init-svtor", mmc->init_svtor);
74
127
qdev_prop_set_uint32(ssedev, "SRAM_ADDR_WIDTH", mmc->sram_addr_width);
75
static bool do_BFMLAL_zzzw(DisasContext *s, arg_rrrr_esz *a, bool sel)
128
- qdev_prop_set_uint32(ssedev, "MAINCLK_FRQ", SYSCLK_FRQ);
76
{
129
qdev_connect_clock_in(ssedev, "MAINCLK", mms->sysclk);
130
qdev_connect_clock_in(ssedev, "S32KCLK", mms->s32kclk);
131
/*
132
diff --git a/hw/arm/stellaris.c b/hw/arm/stellaris.c
133
index XXXXXXX..XXXXXXX 100644
134
--- a/hw/arm/stellaris.c
135
+++ b/hw/arm/stellaris.c
136
@@ -XXX,XX +XXX,XX @@ static void stellaris_init(MachineState *ms, stellaris_board_info *board)
137
if (board->dc1 & (1 << 3)) { /* watchdog present */
138
dev = qdev_new(TYPE_LUMINARY_WATCHDOG);
139
140
- /* system_clock_scale is valid now */
141
- uint32_t mainclk = NANOSECONDS_PER_SECOND / system_clock_scale;
142
- qdev_prop_set_uint32(dev, "wdogclk-frq", mainclk);
143
qdev_connect_clock_in(dev, "WDOGCLK",
144
qdev_get_clock_out(ssys_dev, "SYSCLK"));
145
146
--
77
--
147
2.20.1
78
2.25.1
148
149
diff view generated by jsdifflib
1
Create and connect the Clock input for the watchdog device on the
1
From: Richard Henderson <richard.henderson@linaro.org>
2
Stellaris boards. Because the Stellaris boards model the ability to
3
change the clock rate by programming PLL registers, we have to create
4
an output Clock on the ssys_state device and wire it up to the
5
watchdog.
6
2
7
Note that the old comment on ssys_calculate_system_clock() got the
3
Mark these as a non-streaming instructions, which should trap
8
units wrong -- system_clock_scale is in nanoseconds, not
4
if full a64 support is not enabled in streaming mode.
9
milliseconds. Improve the commentary to clarify how we are
10
calculating the period.
11
5
6
Reviewed-by: Peter Maydell <peter.maydell@linaro.org>
7
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
8
Message-id: 20220708151540.18136-9-richard.henderson@linaro.org
12
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
9
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
13
Reviewed-by: Luc Michel <luc@lmichel.fr>
14
Tested-by: Philippe Mathieu-Daudé <f4bug@amsat.org>
15
Reviewed-by: Philippe Mathieu-Daudé <f4bug@amsat.org>
16
Message-id: 20210128114145.20536-18-peter.maydell@linaro.org
17
Message-id: 20210121190622.22000-18-peter.maydell@linaro.org
18
Reviewed-by: Philippe Mathieu-Daudé <f4bug@amsat.org>
19
---
10
---
20
hw/arm/stellaris.c | 43 +++++++++++++++++++++++++++++++------------
11
target/arm/sme-fa64.decode | 3 ---
21
1 file changed, 31 insertions(+), 12 deletions(-)
12
target/arm/translate-sve.c | 15 +++++++++++----
13
2 files changed, 11 insertions(+), 7 deletions(-)
22
14
23
diff --git a/hw/arm/stellaris.c b/hw/arm/stellaris.c
15
diff --git a/target/arm/sme-fa64.decode b/target/arm/sme-fa64.decode
24
index XXXXXXX..XXXXXXX 100644
16
index XXXXXXX..XXXXXXX 100644
25
--- a/hw/arm/stellaris.c
17
--- a/target/arm/sme-fa64.decode
26
+++ b/hw/arm/stellaris.c
18
+++ b/target/arm/sme-fa64.decode
27
@@ -XXX,XX +XXX,XX @@
19
@@ -XXX,XX +XXX,XX @@ FAIL 0001 1110 0111 1110 0000 00-- ---- ---- # FJCVTZS
28
#include "hw/watchdog/cmsdk-apb-watchdog.h"
20
# --11 1100 --1- ---- ---- ---- ---- --10 # Load/store FP register (register offset)
29
#include "migration/vmstate.h"
21
# --11 1101 ---- ---- ---- ---- ---- ---- # Load/store FP register (scaled imm)
30
#include "hw/misc/unimp.h"
22
31
+#include "hw/qdev-clock.h"
23
-FAIL 0110 0101 --0- ---- 0000 11-- ---- ---- # FTSMUL
32
#include "cpu.h"
24
-FAIL 0110 0101 --01 0--- 100- ---- ---- ---- # FTMAD
33
#include "qom/object.h"
25
-FAIL 0110 0101 --01 1--- 001- ---- ---- ---- # FADDA
34
26
FAIL 0100 0101 --0- ---- 1001 10-- ---- ---- # SMMLA, UMMLA, USMMLA
35
@@ -XXX,XX +XXX,XX @@ struct ssys_state {
27
FAIL 0100 0101 --1- ---- 1--- ---- ---- ---- # SVE2 string/histo/crypto instructions
36
uint32_t clkvclr;
28
FAIL 1000 010- -00- ---- 10-- ---- ---- ---- # SVE2 32-bit gather NT load (vector+scalar)
37
uint32_t ldoarst;
29
diff --git a/target/arm/translate-sve.c b/target/arm/translate-sve.c
38
qemu_irq irq;
30
index XXXXXXX..XXXXXXX 100644
39
+ Clock *sysclk;
31
--- a/target/arm/translate-sve.c
40
/* Properties (all read-only registers) */
32
+++ b/target/arm/translate-sve.c
41
uint32_t user0;
33
@@ -XXX,XX +XXX,XX @@ static gen_helper_gvec_3_ptr * const ftmad_fns[4] = {
42
uint32_t user1;
34
NULL, gen_helper_sve_ftmad_h,
43
@@ -XXX,XX +XXX,XX @@ static bool ssys_use_rcc2(ssys_state *s)
35
gen_helper_sve_ftmad_s, gen_helper_sve_ftmad_d,
44
}
36
};
37
-TRANS_FEAT(FTMAD, aa64_sve, gen_gvec_fpst_zzz,
38
- ftmad_fns[a->esz], a->rd, a->rn, a->rm, a->imm,
39
- a->esz == MO_16 ? FPST_FPCR_F16 : FPST_FPCR)
40
+TRANS_FEAT_NONSTREAMING(FTMAD, aa64_sve, gen_gvec_fpst_zzz,
41
+ ftmad_fns[a->esz], a->rd, a->rn, a->rm, a->imm,
42
+ a->esz == MO_16 ? FPST_FPCR_F16 : FPST_FPCR)
45
43
46
/*
44
/*
47
- * Caculate the sys. clock period in ms.
45
*** SVE Floating Point Accumulating Reduction Group
48
+ * Calculate the system clock period. We only want to propagate
46
@@ -XXX,XX +XXX,XX @@ static bool trans_FADDA(DisasContext *s, arg_rprr_esz *a)
49
+ * this change to the rest of the system if we're not being called
47
if (a->esz == 0 || !dc_isar_feature(aa64_sve, s)) {
50
+ * from migration post-load.
48
return false;
49
}
50
+ s->is_nonstreaming = true;
51
if (!sve_access_check(s)) {
52
return true;
53
}
54
@@ -XXX,XX +XXX,XX @@ static bool trans_FADDA(DisasContext *s, arg_rprr_esz *a)
55
DO_FP3(FADD_zzz, fadd)
56
DO_FP3(FSUB_zzz, fsub)
57
DO_FP3(FMUL_zzz, fmul)
58
-DO_FP3(FTSMUL, ftsmul)
59
DO_FP3(FRECPS, recps)
60
DO_FP3(FRSQRTS, rsqrts)
61
62
#undef DO_FP3
63
64
+static gen_helper_gvec_3_ptr * const ftsmul_fns[4] = {
65
+ NULL, gen_helper_gvec_ftsmul_h,
66
+ gen_helper_gvec_ftsmul_s, gen_helper_gvec_ftsmul_d
67
+};
68
+TRANS_FEAT_NONSTREAMING(FTSMUL, aa64_sve, gen_gvec_fpst_arg_zzz,
69
+ ftsmul_fns[a->esz], a, 0)
70
+
71
/*
72
*** SVE Floating Point Arithmetic - Predicated Group
51
*/
73
*/
52
-static void ssys_calculate_system_clock(ssys_state *s)
53
+static void ssys_calculate_system_clock(ssys_state *s, bool propagate_clock)
54
{
55
+ /*
56
+ * SYSDIV field specifies divisor: 0 == /1, 1 == /2, etc. Input
57
+ * clock is 200MHz, which is a period of 5 ns. Dividing the clock
58
+ * frequency by X is the same as multiplying the period by X.
59
+ */
60
if (ssys_use_rcc2(s)) {
61
system_clock_scale = 5 * (((s->rcc2 >> 23) & 0x3f) + 1);
62
} else {
63
system_clock_scale = 5 * (((s->rcc >> 23) & 0xf) + 1);
64
}
65
+ clock_set_ns(s->sysclk, system_clock_scale);
66
+ if (propagate_clock) {
67
+ clock_propagate(s->sysclk);
68
+ }
69
}
70
71
static void ssys_write(void *opaque, hwaddr offset,
72
@@ -XXX,XX +XXX,XX @@ static void ssys_write(void *opaque, hwaddr offset,
73
s->int_status |= (1 << 6);
74
}
75
s->rcc = value;
76
- ssys_calculate_system_clock(s);
77
+ ssys_calculate_system_clock(s, true);
78
break;
79
case 0x070: /* RCC2 */
80
if (ssys_board_class(s) == DID0_CLASS_SANDSTORM) {
81
@@ -XXX,XX +XXX,XX @@ static void ssys_write(void *opaque, hwaddr offset,
82
s->int_status |= (1 << 6);
83
}
84
s->rcc2 = value;
85
- ssys_calculate_system_clock(s);
86
+ ssys_calculate_system_clock(s, true);
87
break;
88
case 0x100: /* RCGC0 */
89
s->rcgc[0] = value;
90
@@ -XXX,XX +XXX,XX @@ static void stellaris_sys_reset_hold(Object *obj)
91
{
92
ssys_state *s = STELLARIS_SYS(obj);
93
94
- ssys_calculate_system_clock(s);
95
+ /* OK to propagate clocks from the hold phase */
96
+ ssys_calculate_system_clock(s, true);
97
}
98
99
static void stellaris_sys_reset_exit(Object *obj)
100
@@ -XXX,XX +XXX,XX @@ static int stellaris_sys_post_load(void *opaque, int version_id)
101
{
102
ssys_state *s = opaque;
103
104
- ssys_calculate_system_clock(s);
105
+ ssys_calculate_system_clock(s, false);
106
107
return 0;
108
}
109
@@ -XXX,XX +XXX,XX @@ static const VMStateDescription vmstate_stellaris_sys = {
110
VMSTATE_UINT32_ARRAY(dcgc, ssys_state, 3),
111
VMSTATE_UINT32(clkvclr, ssys_state),
112
VMSTATE_UINT32(ldoarst, ssys_state),
113
+ /* No field for sysclk -- handled in post-load instead */
114
VMSTATE_END_OF_LIST()
115
}
116
};
117
@@ -XXX,XX +XXX,XX @@ static void stellaris_sys_instance_init(Object *obj)
118
memory_region_init_io(&s->iomem, obj, &ssys_ops, s, "ssys", 0x00001000);
119
sysbus_init_mmio(sbd, &s->iomem);
120
sysbus_init_irq(sbd, &s->irq);
121
+ s->sysclk = qdev_init_clock_out(DEVICE(s), "SYSCLK");
122
}
123
124
-static int stellaris_sys_init(uint32_t base, qemu_irq irq,
125
- stellaris_board_info * board,
126
- uint8_t *macaddr)
127
+static DeviceState *stellaris_sys_init(uint32_t base, qemu_irq irq,
128
+ stellaris_board_info *board,
129
+ uint8_t *macaddr)
130
{
131
DeviceState *dev = qdev_new(TYPE_STELLARIS_SYS);
132
SysBusDevice *sbd = SYS_BUS_DEVICE(dev);
133
@@ -XXX,XX +XXX,XX @@ static int stellaris_sys_init(uint32_t base, qemu_irq irq,
134
*/
135
device_cold_reset(dev);
136
137
- return 0;
138
+ return dev;
139
}
140
141
/* I2C controller. */
142
@@ -XXX,XX +XXX,XX @@ static void stellaris_init(MachineState *ms, stellaris_board_info *board)
143
int flash_size;
144
I2CBus *i2c;
145
DeviceState *dev;
146
+ DeviceState *ssys_dev;
147
int i;
148
int j;
149
150
@@ -XXX,XX +XXX,XX @@ static void stellaris_init(MachineState *ms, stellaris_board_info *board)
151
}
152
}
153
154
- stellaris_sys_init(0x400fe000, qdev_get_gpio_in(nvic, 28),
155
- board, nd_table[0].macaddr.a);
156
+ ssys_dev = stellaris_sys_init(0x400fe000, qdev_get_gpio_in(nvic, 28),
157
+ board, nd_table[0].macaddr.a);
158
159
160
if (board->dc1 & (1 << 3)) { /* watchdog present */
161
@@ -XXX,XX +XXX,XX @@ static void stellaris_init(MachineState *ms, stellaris_board_info *board)
162
/* system_clock_scale is valid now */
163
uint32_t mainclk = NANOSECONDS_PER_SECOND / system_clock_scale;
164
qdev_prop_set_uint32(dev, "wdogclk-frq", mainclk);
165
+ qdev_connect_clock_in(dev, "WDOGCLK",
166
+ qdev_get_clock_out(ssys_dev, "SYSCLK"));
167
168
sysbus_realize_and_unref(SYS_BUS_DEVICE(dev), &error_fatal);
169
sysbus_mmio_map(SYS_BUS_DEVICE(dev),
170
--
74
--
171
2.20.1
75
2.25.1
172
173
diff view generated by jsdifflib
1
Create and connect the two clocks needed by the ARMSSE.
1
From: Richard Henderson <richard.henderson@linaro.org>
2
2
3
Mark these as a non-streaming instructions, which should trap
4
if full a64 support is not enabled in streaming mode.
5
6
Reviewed-by: Peter Maydell <peter.maydell@linaro.org>
7
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
8
Message-id: 20220708151540.18136-10-richard.henderson@linaro.org
3
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
9
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
4
Reviewed-by: Philippe Mathieu-Daudé <f4bug@amsat.org>
5
Reviewed-by: Luc Michel <luc@lmichel.fr>
6
Tested-by: Philippe Mathieu-Daudé <f4bug@amsat.org>
7
Message-id: 20210128114145.20536-16-peter.maydell@linaro.org
8
Message-id: 20210121190622.22000-16-peter.maydell@linaro.org
9
---
10
---
10
hw/arm/musca.c | 12 ++++++++++++
11
target/arm/sme-fa64.decode | 1 -
11
1 file changed, 12 insertions(+)
12
target/arm/translate-sve.c | 12 ++++++------
13
2 files changed, 6 insertions(+), 7 deletions(-)
12
14
13
diff --git a/hw/arm/musca.c b/hw/arm/musca.c
15
diff --git a/target/arm/sme-fa64.decode b/target/arm/sme-fa64.decode
14
index XXXXXXX..XXXXXXX 100644
16
index XXXXXXX..XXXXXXX 100644
15
--- a/hw/arm/musca.c
17
--- a/target/arm/sme-fa64.decode
16
+++ b/hw/arm/musca.c
18
+++ b/target/arm/sme-fa64.decode
17
@@ -XXX,XX +XXX,XX @@
19
@@ -XXX,XX +XXX,XX @@ FAIL 0001 1110 0111 1110 0000 00-- ---- ---- # FJCVTZS
18
#include "hw/misc/tz-ppc.h"
20
# --11 1100 --1- ---- ---- ---- ---- --10 # Load/store FP register (register offset)
19
#include "hw/misc/unimp.h"
21
# --11 1101 ---- ---- ---- ---- ---- ---- # Load/store FP register (scaled imm)
20
#include "hw/rtc/pl031.h"
22
21
+#include "hw/qdev-clock.h"
23
-FAIL 0100 0101 --0- ---- 1001 10-- ---- ---- # SMMLA, UMMLA, USMMLA
22
#include "qom/object.h"
24
FAIL 0100 0101 --1- ---- 1--- ---- ---- ---- # SVE2 string/histo/crypto instructions
23
25
FAIL 1000 010- -00- ---- 10-- ---- ---- ---- # SVE2 32-bit gather NT load (vector+scalar)
24
#define MUSCA_NUMIRQ_MAX 96
26
FAIL 1000 010- -00- ---- 111- ---- ---- ---- # SVE 32-bit gather prefetch (vector+imm)
25
@@ -XXX,XX +XXX,XX @@ struct MuscaMachineState {
27
diff --git a/target/arm/translate-sve.c b/target/arm/translate-sve.c
26
UnimplementedDeviceState sdio;
28
index XXXXXXX..XXXXXXX 100644
27
UnimplementedDeviceState gpio;
29
--- a/target/arm/translate-sve.c
28
UnimplementedDeviceState cryptoisland;
30
+++ b/target/arm/translate-sve.c
29
+ Clock *sysclk;
31
@@ -XXX,XX +XXX,XX @@ TRANS_FEAT(FMLALT_zzxw, aa64_sve2, do_FMLAL_zzxw, a, false, true)
30
+ Clock *s32kclk;
32
TRANS_FEAT(FMLSLB_zzxw, aa64_sve2, do_FMLAL_zzxw, a, true, false)
31
};
33
TRANS_FEAT(FMLSLT_zzxw, aa64_sve2, do_FMLAL_zzxw, a, true, true)
32
34
33
#define TYPE_MUSCA_MACHINE "musca"
35
-TRANS_FEAT(SMMLA, aa64_sve_i8mm, gen_gvec_ool_arg_zzzz,
34
@@ -XXX,XX +XXX,XX @@ OBJECT_DECLARE_TYPE(MuscaMachineState, MuscaMachineClass, MUSCA_MACHINE)
36
- gen_helper_gvec_smmla_b, a, 0)
35
* don't model that in our SSE-200 model yet.
37
-TRANS_FEAT(USMMLA, aa64_sve_i8mm, gen_gvec_ool_arg_zzzz,
36
*/
38
- gen_helper_gvec_usmmla_b, a, 0)
37
#define SYSCLK_FRQ 40000000
39
-TRANS_FEAT(UMMLA, aa64_sve_i8mm, gen_gvec_ool_arg_zzzz,
38
+/* Slow 32Khz S32KCLK frequency in Hz */
40
- gen_helper_gvec_ummla_b, a, 0)
39
+#define S32KCLK_FRQ (32 * 1000)
41
+TRANS_FEAT_NONSTREAMING(SMMLA, aa64_sve_i8mm, gen_gvec_ool_arg_zzzz,
40
42
+ gen_helper_gvec_smmla_b, a, 0)
41
static qemu_irq get_sse_irq_in(MuscaMachineState *mms, int irqno)
43
+TRANS_FEAT_NONSTREAMING(USMMLA, aa64_sve_i8mm, gen_gvec_ool_arg_zzzz,
42
{
44
+ gen_helper_gvec_usmmla_b, a, 0)
43
@@ -XXX,XX +XXX,XX @@ static void musca_init(MachineState *machine)
45
+TRANS_FEAT_NONSTREAMING(UMMLA, aa64_sve_i8mm, gen_gvec_ool_arg_zzzz,
44
exit(1);
46
+ gen_helper_gvec_ummla_b, a, 0)
45
}
47
46
48
TRANS_FEAT(BFDOT_zzzz, aa64_sve_bf16, gen_gvec_ool_arg_zzzz,
47
+ mms->sysclk = clock_new(OBJECT(machine), "SYSCLK");
49
gen_helper_gvec_bfdot, a, 0)
48
+ clock_set_hz(mms->sysclk, SYSCLK_FRQ);
49
+ mms->s32kclk = clock_new(OBJECT(machine), "S32KCLK");
50
+ clock_set_hz(mms->s32kclk, S32KCLK_FRQ);
51
+
52
object_initialize_child(OBJECT(machine), "sse-200", &mms->sse,
53
TYPE_SSE200);
54
ssedev = DEVICE(&mms->sse);
55
@@ -XXX,XX +XXX,XX @@ static void musca_init(MachineState *machine)
56
qdev_prop_set_uint32(ssedev, "init-svtor", mmc->init_svtor);
57
qdev_prop_set_uint32(ssedev, "SRAM_ADDR_WIDTH", mmc->sram_addr_width);
58
qdev_prop_set_uint32(ssedev, "MAINCLK_FRQ", SYSCLK_FRQ);
59
+ qdev_connect_clock_in(ssedev, "MAINCLK", mms->sysclk);
60
+ qdev_connect_clock_in(ssedev, "S32KCLK", mms->s32kclk);
61
/*
62
* Musca-A takes the default SSE-200 FPU/DSP settings (ie no for
63
* CPU0 and yes for CPU1); Musca-B1 explicitly enables them for CPU0.
64
--
50
--
65
2.20.1
51
2.25.1
66
67
diff view generated by jsdifflib
1
From: Alexander Graf <agraf@csgraf.de>
1
From: Richard Henderson <richard.henderson@linaro.org>
2
2
3
In macOS 11, QEMU only gets access to Hypervisor.framework if it has the
3
Mark these as non-streaming instructions, which should trap
4
respective entitlement. Add an entitlement template and automatically self
4
if full a64 support is not enabled in streaming mode.
5
sign and apply the entitlement in the build.
6
5
7
Signed-off-by: Alexander Graf <agraf@csgraf.de>
6
Reviewed-by: Peter Maydell <peter.maydell@linaro.org>
8
Reviewed-by: Roman Bolshakov <r.bolshakov@yadro.com>
7
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
9
Tested-by: Roman Bolshakov <r.bolshakov@yadro.com>
8
Message-id: 20220708151540.18136-11-richard.henderson@linaro.org
10
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
9
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
11
---
10
---
12
meson.build | 29 +++++++++++++++++++++++++----
11
target/arm/sme-fa64.decode | 1 -
13
accel/hvf/entitlements.plist | 8 ++++++++
12
target/arm/translate-sve.c | 35 ++++++++++++++++++-----------------
14
scripts/entitlement.sh | 13 +++++++++++++
13
2 files changed, 18 insertions(+), 18 deletions(-)
15
3 files changed, 46 insertions(+), 4 deletions(-)
16
create mode 100644 accel/hvf/entitlements.plist
17
create mode 100755 scripts/entitlement.sh
18
14
19
diff --git a/meson.build b/meson.build
15
diff --git a/target/arm/sme-fa64.decode b/target/arm/sme-fa64.decode
20
index XXXXXXX..XXXXXXX 100644
16
index XXXXXXX..XXXXXXX 100644
21
--- a/meson.build
17
--- a/target/arm/sme-fa64.decode
22
+++ b/meson.build
18
+++ b/target/arm/sme-fa64.decode
23
@@ -XXX,XX +XXX,XX @@ foreach target : target_dirs
19
@@ -XXX,XX +XXX,XX @@ FAIL 0001 1110 0111 1110 0000 00-- ---- ---- # FJCVTZS
24
}]
20
# --11 1100 --1- ---- ---- ---- ---- --10 # Load/store FP register (register offset)
25
endif
21
# --11 1101 ---- ---- ---- ---- ---- ---- # Load/store FP register (scaled imm)
26
foreach exe: execs
22
27
- emulators += {exe['name']:
23
-FAIL 0100 0101 --1- ---- 1--- ---- ---- ---- # SVE2 string/histo/crypto instructions
28
- executable(exe['name'], exe['sources'],
24
FAIL 1000 010- -00- ---- 10-- ---- ---- ---- # SVE2 32-bit gather NT load (vector+scalar)
29
- install: true,
25
FAIL 1000 010- -00- ---- 111- ---- ---- ---- # SVE 32-bit gather prefetch (vector+imm)
30
+ exe_name = exe['name']
26
FAIL 1000 0100 0-1- ---- 0--- ---- ---- ---- # SVE 32-bit gather prefetch (scalar+vector)
31
+ exe_sign = 'CONFIG_HVF' in config_target
27
diff --git a/target/arm/translate-sve.c b/target/arm/translate-sve.c
32
+ if exe_sign
28
index XXXXXXX..XXXXXXX 100644
33
+ exe_name += '-unsigned'
29
--- a/target/arm/translate-sve.c
34
+ endif
30
+++ b/target/arm/translate-sve.c
35
+
31
@@ -XXX,XX +XXX,XX @@ DO_SVE2_ZZZ_NARROW(RSUBHNT, rsubhnt)
36
+ emulator = executable(exe_name, exe['sources'],
32
static gen_helper_gvec_flags_4 * const match_fns[4] = {
37
+ install: not exe_sign,
33
gen_helper_sve2_match_ppzz_b, gen_helper_sve2_match_ppzz_h, NULL, NULL
38
c_args: c_args,
34
};
39
dependencies: arch_deps + deps + exe['dependencies'],
35
-TRANS_FEAT(MATCH, aa64_sve2, do_ppzz_flags, a, match_fns[a->esz])
40
objects: lib.extract_all_objects(recursive: true),
36
+TRANS_FEAT_NONSTREAMING(MATCH, aa64_sve2, do_ppzz_flags, a, match_fns[a->esz])
41
@@ -XXX,XX +XXX,XX @@ foreach target : target_dirs
37
42
link_depends: [block_syms, qemu_syms] + exe.get('link_depends', []),
38
static gen_helper_gvec_flags_4 * const nmatch_fns[4] = {
43
link_args: link_args,
39
gen_helper_sve2_nmatch_ppzz_b, gen_helper_sve2_nmatch_ppzz_h, NULL, NULL
44
gui_app: exe['gui'])
40
};
45
- }
41
-TRANS_FEAT(NMATCH, aa64_sve2, do_ppzz_flags, a, nmatch_fns[a->esz])
46
+
42
+TRANS_FEAT_NONSTREAMING(NMATCH, aa64_sve2, do_ppzz_flags, a, nmatch_fns[a->esz])
47
+ if exe_sign
43
48
+ emulators += {exe['name'] : custom_target(exe['name'],
44
static gen_helper_gvec_4 * const histcnt_fns[4] = {
49
+ install: true,
45
NULL, NULL, gen_helper_sve2_histcnt_s, gen_helper_sve2_histcnt_d
50
+ install_dir: get_option('bindir'),
46
};
51
+ depends: emulator,
47
-TRANS_FEAT(HISTCNT, aa64_sve2, gen_gvec_ool_arg_zpzz,
52
+ output: exe['name'],
48
- histcnt_fns[a->esz], a, 0)
53
+ command: [
49
+TRANS_FEAT_NONSTREAMING(HISTCNT, aa64_sve2, gen_gvec_ool_arg_zpzz,
54
+ meson.current_source_dir() / 'scripts/entitlement.sh',
50
+ histcnt_fns[a->esz], a, 0)
55
+ meson.current_build_dir() / exe_name,
51
56
+ meson.current_build_dir() / exe['name'],
52
-TRANS_FEAT(HISTSEG, aa64_sve2, gen_gvec_ool_arg_zzz,
57
+ meson.current_source_dir() / 'accel/hvf/entitlements.plist'
53
- a->esz == 0 ? gen_helper_sve2_histseg : NULL, a, 0)
58
+ ])
54
+TRANS_FEAT_NONSTREAMING(HISTSEG, aa64_sve2, gen_gvec_ool_arg_zzz,
59
+ }
55
+ a->esz == 0 ? gen_helper_sve2_histseg : NULL, a, 0)
60
+ else
56
61
+ emulators += {exe['name']: emulator}
57
DO_ZPZZ_FP(FADDP, aa64_sve2, sve2_faddp_zpzz)
62
+ endif
58
DO_ZPZZ_FP(FMAXNMP, aa64_sve2, sve2_fmaxnmp_zpzz)
63
59
@@ -XXX,XX +XXX,XX @@ TRANS_FEAT(SQRDCMLAH_zzzz, aa64_sve2, gen_gvec_ool_zzzz,
64
if 'CONFIG_TRACE_SYSTEMTAP' in config_host
60
TRANS_FEAT(USDOT_zzzz, aa64_sve_i8mm, gen_gvec_ool_arg_zzzz,
65
foreach stp: [
61
a->esz == 2 ? gen_helper_gvec_usdot_b : NULL, a, 0)
66
diff --git a/accel/hvf/entitlements.plist b/accel/hvf/entitlements.plist
62
67
new file mode 100644
63
-TRANS_FEAT(AESMC, aa64_sve2_aes, gen_gvec_ool_zz,
68
index XXXXXXX..XXXXXXX
64
- gen_helper_crypto_aesmc, a->rd, a->rd, a->decrypt)
69
--- /dev/null
65
+TRANS_FEAT_NONSTREAMING(AESMC, aa64_sve2_aes, gen_gvec_ool_zz,
70
+++ b/accel/hvf/entitlements.plist
66
+ gen_helper_crypto_aesmc, a->rd, a->rd, a->decrypt)
71
@@ -XXX,XX +XXX,XX @@
67
72
+<?xml version="1.0" encoding="UTF-8"?>
68
-TRANS_FEAT(AESE, aa64_sve2_aes, gen_gvec_ool_arg_zzz,
73
+<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
69
- gen_helper_crypto_aese, a, false)
74
+<plist version="1.0">
70
-TRANS_FEAT(AESD, aa64_sve2_aes, gen_gvec_ool_arg_zzz,
75
+<dict>
71
- gen_helper_crypto_aese, a, true)
76
+ <key>com.apple.security.hypervisor</key>
72
+TRANS_FEAT_NONSTREAMING(AESE, aa64_sve2_aes, gen_gvec_ool_arg_zzz,
77
+ <true/>
73
+ gen_helper_crypto_aese, a, false)
78
+</dict>
74
+TRANS_FEAT_NONSTREAMING(AESD, aa64_sve2_aes, gen_gvec_ool_arg_zzz,
79
+</plist>
75
+ gen_helper_crypto_aese, a, true)
80
diff --git a/scripts/entitlement.sh b/scripts/entitlement.sh
76
81
new file mode 100755
77
-TRANS_FEAT(SM4E, aa64_sve2_sm4, gen_gvec_ool_arg_zzz,
82
index XXXXXXX..XXXXXXX
78
- gen_helper_crypto_sm4e, a, 0)
83
--- /dev/null
79
-TRANS_FEAT(SM4EKEY, aa64_sve2_sm4, gen_gvec_ool_arg_zzz,
84
+++ b/scripts/entitlement.sh
80
- gen_helper_crypto_sm4ekey, a, 0)
85
@@ -XXX,XX +XXX,XX @@
81
+TRANS_FEAT_NONSTREAMING(SM4E, aa64_sve2_sm4, gen_gvec_ool_arg_zzz,
86
+#!/bin/sh -e
82
+ gen_helper_crypto_sm4e, a, 0)
87
+#
83
+TRANS_FEAT_NONSTREAMING(SM4EKEY, aa64_sve2_sm4, gen_gvec_ool_arg_zzz,
88
+# Helper script for the build process to apply entitlements
84
+ gen_helper_crypto_sm4ekey, a, 0)
89
+
85
90
+SRC="$1"
86
-TRANS_FEAT(RAX1, aa64_sve2_sha3, gen_gvec_fn_arg_zzz, gen_gvec_rax1, a)
91
+DST="$2"
87
+TRANS_FEAT_NONSTREAMING(RAX1, aa64_sve2_sha3, gen_gvec_fn_arg_zzz,
92
+ENTITLEMENT="$3"
88
+ gen_gvec_rax1, a)
93
+
89
94
+trap 'rm "$DST.tmp"' exit
90
TRANS_FEAT(FCVTNT_sh, aa64_sve2, gen_gvec_fpst_arg_zpz,
95
+cp -af "$SRC" "$DST.tmp"
91
gen_helper_sve2_fcvtnt_sh, a, 0, FPST_FPCR)
96
+codesign --entitlements "$ENTITLEMENT" --force -s - "$DST.tmp"
97
+mv "$DST.tmp" "$DST"
98
+trap '' exit
99
--
92
--
100
2.20.1
93
2.25.1
101
102
diff view generated by jsdifflib
1
Create two input clocks on the ARMSSE devices, one for the normal
1
From: Richard Henderson <richard.henderson@linaro.org>
2
MAINCLK, and one for the 32KHz S32KCLK, and wire these up to the
3
appropriate devices. The old property-based clock frequency setting
4
will remain in place until conversion is complete.
5
2
6
This is a migration compatibility break for machines mps2-an505,
3
Mark these as a non-streaming instructions, which should trap
7
mps2-an521, musca-a, musca-b1.
4
if full a64 support is not enabled in streaming mode.
8
5
6
Reviewed-by: Peter Maydell <peter.maydell@linaro.org>
7
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
8
Message-id: 20220708151540.18136-12-richard.henderson@linaro.org
9
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
9
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
10
Reviewed-by: Philippe Mathieu-Daudé <f4bug@amsat.org>
11
Reviewed-by: Luc Michel <luc@lmichel.fr>
12
Tested-by: Philippe Mathieu-Daudé <f4bug@amsat.org>
13
Message-id: 20210128114145.20536-12-peter.maydell@linaro.org
14
Message-id: 20210121190622.22000-12-peter.maydell@linaro.org
15
---
10
---
16
include/hw/arm/armsse.h | 6 ++++++
11
target/arm/sme-fa64.decode | 9 ---------
17
hw/arm/armsse.c | 17 +++++++++++++++--
12
target/arm/translate-sve.c | 6 ++++++
18
2 files changed, 21 insertions(+), 2 deletions(-)
13
2 files changed, 6 insertions(+), 9 deletions(-)
19
14
20
diff --git a/include/hw/arm/armsse.h b/include/hw/arm/armsse.h
15
diff --git a/target/arm/sme-fa64.decode b/target/arm/sme-fa64.decode
21
index XXXXXXX..XXXXXXX 100644
16
index XXXXXXX..XXXXXXX 100644
22
--- a/include/hw/arm/armsse.h
17
--- a/target/arm/sme-fa64.decode
23
+++ b/include/hw/arm/armsse.h
18
+++ b/target/arm/sme-fa64.decode
24
@@ -XXX,XX +XXX,XX @@
19
@@ -XXX,XX +XXX,XX @@ FAIL 0001 1110 0111 1110 0000 00-- ---- ---- # FJCVTZS
25
* per-CPU identity and control register blocks
20
# --11 1100 --1- ---- ---- ---- ---- --10 # Load/store FP register (register offset)
26
*
21
# --11 1101 ---- ---- ---- ---- ---- ---- # Load/store FP register (scaled imm)
27
* QEMU interface:
22
28
+ * + Clock input "MAINCLK": clock for CPUs and most peripherals
23
-FAIL 1000 010- -00- ---- 10-- ---- ---- ---- # SVE2 32-bit gather NT load (vector+scalar)
29
+ * + Clock input "S32KCLK": slow 32KHz clock used for a few peripherals
24
FAIL 1000 010- -00- ---- 111- ---- ---- ---- # SVE 32-bit gather prefetch (vector+imm)
30
* + QOM property "memory" is a MemoryRegion containing the devices provided
25
FAIL 1000 0100 0-1- ---- 0--- ---- ---- ---- # SVE 32-bit gather prefetch (scalar+vector)
31
* by the board model.
26
-FAIL 1000 010- -01- ---- 1--- ---- ---- ---- # SVE 32-bit gather load (vector+imm)
32
* + QOM property "MAINCLK_FRQ" is the frequency of the main system clock
27
-FAIL 1000 0100 0-0- ---- 0--- ---- ---- ---- # SVE 32-bit gather load byte (scalar+vector)
33
@@ -XXX,XX +XXX,XX @@
28
-FAIL 1000 0100 1--- ---- 0--- ---- ---- ---- # SVE 32-bit gather load half (scalar+vector)
34
#include "hw/misc/armsse-mhu.h"
29
-FAIL 1000 0101 0--- ---- 0--- ---- ---- ---- # SVE 32-bit gather load word (scalar+vector)
35
#include "hw/misc/unimp.h"
30
FAIL 1010 010- ---- ---- 011- ---- ---- ---- # SVE contiguous FF load (scalar+scalar)
36
#include "hw/or-irq.h"
31
FAIL 1010 010- ---1 ---- 101- ---- ---- ---- # SVE contiguous NF load (scalar+imm)
37
+#include "hw/clock.h"
32
FAIL 1010 010- -01- ---- 000- ---- ---- ---- # SVE load & replicate 32 bytes (scalar+scalar)
38
#include "hw/core/split-irq.h"
33
FAIL 1010 010- -010 ---- 001- ---- ---- ---- # SVE load & replicate 32 bytes (scalar+imm)
39
#include "hw/cpu/cluster.h"
34
FAIL 1100 010- ---- ---- ---- ---- ---- ---- # SVE 64-bit gather load/prefetch
40
#include "qom/object.h"
35
-FAIL 1110 010- -00- ---- 001- ---- ---- ---- # SVE2 64-bit scatter NT store (vector+scalar)
41
@@ -XXX,XX +XXX,XX @@ struct ARMSSE {
36
-FAIL 1110 010- -10- ---- 001- ---- ---- ---- # SVE2 32-bit scatter NT store (vector+scalar)
42
37
-FAIL 1110 010- ---- ---- 1-0- ---- ---- ---- # SVE scatter store (scalar+32-bit vector)
43
uint32_t nsccfg;
38
-FAIL 1110 010- ---- ---- 101- ---- ---- ---- # SVE scatter store (misc)
44
39
diff --git a/target/arm/translate-sve.c b/target/arm/translate-sve.c
45
+ Clock *mainclk;
46
+ Clock *s32kclk;
47
+
48
/* Properties */
49
MemoryRegion *board_memory;
50
uint32_t exp_numirq;
51
diff --git a/hw/arm/armsse.c b/hw/arm/armsse.c
52
index XXXXXXX..XXXXXXX 100644
40
index XXXXXXX..XXXXXXX 100644
53
--- a/hw/arm/armsse.c
41
--- a/target/arm/translate-sve.c
54
+++ b/hw/arm/armsse.c
42
+++ b/target/arm/translate-sve.c
55
@@ -XXX,XX +XXX,XX @@
43
@@ -XXX,XX +XXX,XX @@ static bool trans_LD1_zprz(DisasContext *s, arg_LD1_zprz *a)
56
#include "hw/arm/armsse.h"
44
if (!dc_isar_feature(aa64_sve, s)) {
57
#include "hw/arm/boot.h"
45
return false;
58
#include "hw/irq.h"
59
+#include "hw/qdev-clock.h"
60
61
/* Format of the System Information block SYS_CONFIG register */
62
typedef enum SysConfigFormat {
63
@@ -XXX,XX +XXX,XX @@ static void armsse_init(Object *obj)
64
assert(info->sram_banks <= MAX_SRAM_BANKS);
65
assert(info->num_cpus <= SSE_MAX_CPUS);
66
67
+ s->mainclk = qdev_init_clock_in(DEVICE(s), "MAINCLK", NULL, NULL);
68
+ s->s32kclk = qdev_init_clock_in(DEVICE(s), "S32KCLK", NULL, NULL);
69
+
70
memory_region_init(&s->container, obj, "armsse-container", UINT64_MAX);
71
72
for (i = 0; i < info->num_cpus; i++) {
73
@@ -XXX,XX +XXX,XX @@ static void armsse_realize(DeviceState *dev, Error **errp)
74
* map its upstream ends to the right place in the container.
75
*/
76
qdev_prop_set_uint32(DEVICE(&s->timer0), "pclk-frq", s->mainclk_frq);
77
+ qdev_connect_clock_in(DEVICE(&s->timer0), "pclk", s->mainclk);
78
if (!sysbus_realize(SYS_BUS_DEVICE(&s->timer0), errp)) {
79
return;
80
}
46
}
81
@@ -XXX,XX +XXX,XX @@ static void armsse_realize(DeviceState *dev, Error **errp)
47
+ s->is_nonstreaming = true;
82
&error_abort);
48
if (!sve_access_check(s)) {
83
49
return true;
84
qdev_prop_set_uint32(DEVICE(&s->timer1), "pclk-frq", s->mainclk_frq);
85
+ qdev_connect_clock_in(DEVICE(&s->timer1), "pclk", s->mainclk);
86
if (!sysbus_realize(SYS_BUS_DEVICE(&s->timer1), errp)) {
87
return;
88
}
50
}
89
@@ -XXX,XX +XXX,XX @@ static void armsse_realize(DeviceState *dev, Error **errp)
51
@@ -XXX,XX +XXX,XX @@ static bool trans_LD1_zpiz(DisasContext *s, arg_LD1_zpiz *a)
90
&error_abort);
52
if (!dc_isar_feature(aa64_sve, s)) {
91
53
return false;
92
qdev_prop_set_uint32(DEVICE(&s->dualtimer), "pclk-frq", s->mainclk_frq);
93
+ qdev_connect_clock_in(DEVICE(&s->dualtimer), "TIMCLK", s->mainclk);
94
if (!sysbus_realize(SYS_BUS_DEVICE(&s->dualtimer), errp)) {
95
return;
96
}
54
}
97
@@ -XXX,XX +XXX,XX @@ static void armsse_realize(DeviceState *dev, Error **errp)
55
+ s->is_nonstreaming = true;
98
* 0x4002f000: S32K timer
56
if (!sve_access_check(s)) {
99
*/
57
return true;
100
qdev_prop_set_uint32(DEVICE(&s->s32ktimer), "pclk-frq", S32KCLK);
101
+ qdev_connect_clock_in(DEVICE(&s->s32ktimer), "pclk", s->s32kclk);
102
if (!sysbus_realize(SYS_BUS_DEVICE(&s->s32ktimer), errp)) {
103
return;
104
}
58
}
105
@@ -XXX,XX +XXX,XX @@ static void armsse_realize(DeviceState *dev, Error **errp)
59
@@ -XXX,XX +XXX,XX @@ static bool trans_LDNT1_zprz(DisasContext *s, arg_LD1_zprz *a)
106
qdev_get_gpio_in_named(DEVICE(&s->armv7m), "NMI", 0));
60
if (!dc_isar_feature(aa64_sve2, s)) {
107
61
return false;
108
qdev_prop_set_uint32(DEVICE(&s->s32kwatchdog), "wdogclk-frq", S32KCLK);
109
+ qdev_connect_clock_in(DEVICE(&s->s32kwatchdog), "WDOGCLK", s->s32kclk);
110
if (!sysbus_realize(SYS_BUS_DEVICE(&s->s32kwatchdog), errp)) {
111
return;
112
}
62
}
113
@@ -XXX,XX +XXX,XX @@ static void armsse_realize(DeviceState *dev, Error **errp)
63
+ s->is_nonstreaming = true;
114
/* 0x40080000 .. 0x4008ffff : ARMSSE second Base peripheral region */
64
if (!sve_access_check(s)) {
115
65
return true;
116
qdev_prop_set_uint32(DEVICE(&s->nswatchdog), "wdogclk-frq", s->mainclk_frq);
117
+ qdev_connect_clock_in(DEVICE(&s->nswatchdog), "WDOGCLK", s->mainclk);
118
if (!sysbus_realize(SYS_BUS_DEVICE(&s->nswatchdog), errp)) {
119
return;
120
}
66
}
121
@@ -XXX,XX +XXX,XX @@ static void armsse_realize(DeviceState *dev, Error **errp)
67
@@ -XXX,XX +XXX,XX @@ static bool trans_ST1_zprz(DisasContext *s, arg_ST1_zprz *a)
122
sysbus_mmio_map(SYS_BUS_DEVICE(&s->nswatchdog), 0, 0x40081000);
68
if (!dc_isar_feature(aa64_sve, s)) {
123
69
return false;
124
qdev_prop_set_uint32(DEVICE(&s->swatchdog), "wdogclk-frq", s->mainclk_frq);
125
+ qdev_connect_clock_in(DEVICE(&s->swatchdog), "WDOGCLK", s->mainclk);
126
if (!sysbus_realize(SYS_BUS_DEVICE(&s->swatchdog), errp)) {
127
return;
128
}
70
}
129
@@ -XXX,XX +XXX,XX @@ static void armsse_idau_check(IDAUInterface *ii, uint32_t address,
71
+ s->is_nonstreaming = true;
130
72
if (!sve_access_check(s)) {
131
static const VMStateDescription armsse_vmstate = {
73
return true;
132
.name = "iotkit",
74
}
133
- .version_id = 1,
75
@@ -XXX,XX +XXX,XX @@ static bool trans_ST1_zpiz(DisasContext *s, arg_ST1_zpiz *a)
134
- .minimum_version_id = 1,
76
if (!dc_isar_feature(aa64_sve, s)) {
135
+ .version_id = 2,
77
return false;
136
+ .minimum_version_id = 2,
78
}
137
.fields = (VMStateField[]) {
79
+ s->is_nonstreaming = true;
138
+ VMSTATE_CLOCK(mainclk, ARMSSE),
80
if (!sve_access_check(s)) {
139
+ VMSTATE_CLOCK(s32kclk, ARMSSE),
81
return true;
140
VMSTATE_UINT32(nsccfg, ARMSSE),
82
}
141
VMSTATE_END_OF_LIST()
83
@@ -XXX,XX +XXX,XX @@ static bool trans_STNT1_zprz(DisasContext *s, arg_ST1_zprz *a)
84
if (!dc_isar_feature(aa64_sve2, s)) {
85
return false;
86
}
87
+ s->is_nonstreaming = true;
88
if (!sve_access_check(s)) {
89
return true;
142
}
90
}
143
--
91
--
144
2.20.1
92
2.25.1
145
146
diff view generated by jsdifflib
1
Use the MAINCLK Clock input to set the system_clock_scale variable
1
From: Richard Henderson <richard.henderson@linaro.org>
2
rather than using the mainclk_frq property.
3
2
3
Mark these as a non-streaming instructions, which should trap if full
4
a64 support is not enabled in streaming mode. In this case, introduce
5
PRF_ns (prefetch non-streaming) to handle the checks.
6
7
Reviewed-by: Peter Maydell <peter.maydell@linaro.org>
8
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
9
Message-id: 20220708151540.18136-13-richard.henderson@linaro.org
4
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
10
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
5
Reviewed-by: Philippe Mathieu-Daudé <f4bug@amsat.org>
6
Tested-by: Philippe Mathieu-Daudé <f4bug@amsat.org>
7
Reviewed-by: Luc Michel <luc@lmichel.fr>
8
Message-id: 20210128114145.20536-23-peter.maydell@linaro.org
9
Message-id: 20210121190622.22000-23-peter.maydell@linaro.org
10
---
11
---
11
hw/arm/armsse.c | 24 +++++++++++++++++++-----
12
target/arm/sme-fa64.decode | 3 ---
12
1 file changed, 19 insertions(+), 5 deletions(-)
13
target/arm/sve.decode | 10 +++++-----
14
target/arm/translate-sve.c | 11 +++++++++++
15
3 files changed, 16 insertions(+), 8 deletions(-)
13
16
14
diff --git a/hw/arm/armsse.c b/hw/arm/armsse.c
17
diff --git a/target/arm/sme-fa64.decode b/target/arm/sme-fa64.decode
15
index XXXXXXX..XXXXXXX 100644
18
index XXXXXXX..XXXXXXX 100644
16
--- a/hw/arm/armsse.c
19
--- a/target/arm/sme-fa64.decode
17
+++ b/hw/arm/armsse.c
20
+++ b/target/arm/sme-fa64.decode
18
@@ -XXX,XX +XXX,XX @@ static void armsse_forward_sec_resp_cfg(ARMSSE *s)
21
@@ -XXX,XX +XXX,XX @@ FAIL 0001 1110 0111 1110 0000 00-- ---- ---- # FJCVTZS
19
qdev_connect_gpio_out(dev_splitter, 2, s->sec_resp_cfg_in);
22
# --11 1100 --1- ---- ---- ---- ---- --10 # Load/store FP register (register offset)
23
# --11 1101 ---- ---- ---- ---- ---- ---- # Load/store FP register (scaled imm)
24
25
-FAIL 1000 010- -00- ---- 111- ---- ---- ---- # SVE 32-bit gather prefetch (vector+imm)
26
-FAIL 1000 0100 0-1- ---- 0--- ---- ---- ---- # SVE 32-bit gather prefetch (scalar+vector)
27
FAIL 1010 010- ---- ---- 011- ---- ---- ---- # SVE contiguous FF load (scalar+scalar)
28
FAIL 1010 010- ---1 ---- 101- ---- ---- ---- # SVE contiguous NF load (scalar+imm)
29
FAIL 1010 010- -01- ---- 000- ---- ---- ---- # SVE load & replicate 32 bytes (scalar+scalar)
30
FAIL 1010 010- -010 ---- 001- ---- ---- ---- # SVE load & replicate 32 bytes (scalar+imm)
31
-FAIL 1100 010- ---- ---- ---- ---- ---- ---- # SVE 64-bit gather load/prefetch
32
diff --git a/target/arm/sve.decode b/target/arm/sve.decode
33
index XXXXXXX..XXXXXXX 100644
34
--- a/target/arm/sve.decode
35
+++ b/target/arm/sve.decode
36
@@ -XXX,XX +XXX,XX @@ LD1RO_zpri 1010010 .. 01 0.... 001 ... ..... ..... \
37
@rpri_load_msz nreg=0
38
39
# SVE 32-bit gather prefetch (scalar plus 32-bit scaled offsets)
40
-PRF 1000010 00 -1 ----- 0-- --- ----- 0 ----
41
+PRF_ns 1000010 00 -1 ----- 0-- --- ----- 0 ----
42
43
# SVE 32-bit gather prefetch (vector plus immediate)
44
-PRF 1000010 -- 00 ----- 111 --- ----- 0 ----
45
+PRF_ns 1000010 -- 00 ----- 111 --- ----- 0 ----
46
47
# SVE contiguous prefetch (scalar plus immediate)
48
PRF 1000010 11 1- ----- 0-- --- ----- 0 ----
49
@@ -XXX,XX +XXX,XX @@ LD1_zpiz 1100010 .. 01 ..... 1.. ... ..... ..... \
50
@rpri_g_load esz=3
51
52
# SVE 64-bit gather prefetch (scalar plus 64-bit scaled offsets)
53
-PRF 1100010 00 11 ----- 1-- --- ----- 0 ----
54
+PRF_ns 1100010 00 11 ----- 1-- --- ----- 0 ----
55
56
# SVE 64-bit gather prefetch (scalar plus unpacked 32-bit scaled offsets)
57
-PRF 1100010 00 -1 ----- 0-- --- ----- 0 ----
58
+PRF_ns 1100010 00 -1 ----- 0-- --- ----- 0 ----
59
60
# SVE 64-bit gather prefetch (vector plus immediate)
61
-PRF 1100010 -- 00 ----- 111 --- ----- 0 ----
62
+PRF_ns 1100010 -- 00 ----- 111 --- ----- 0 ----
63
64
### SVE Memory Store Group
65
66
diff --git a/target/arm/translate-sve.c b/target/arm/translate-sve.c
67
index XXXXXXX..XXXXXXX 100644
68
--- a/target/arm/translate-sve.c
69
+++ b/target/arm/translate-sve.c
70
@@ -XXX,XX +XXX,XX @@ static bool trans_PRF_rr(DisasContext *s, arg_PRF_rr *a)
71
return true;
20
}
72
}
21
73
22
+static void armsse_mainclk_update(void *opaque)
74
+static bool trans_PRF_ns(DisasContext *s, arg_PRF_ns *a)
23
+{
75
+{
24
+ ARMSSE *s = ARM_SSE(opaque);
76
+ if (!dc_isar_feature(aa64_sve, s)) {
25
+ /*
77
+ return false;
26
+ * Set system_clock_scale from our Clock input; this is what
78
+ }
27
+ * controls the tick rate of the CPU SysTick timer.
79
+ /* Prefetch is a nop within QEMU. */
28
+ */
80
+ s->is_nonstreaming = true;
29
+ system_clock_scale = clock_ticks_to_ns(s->mainclk, 1);
81
+ (void)sve_access_check(s);
82
+ return true;
30
+}
83
+}
31
+
84
+
32
static void armsse_init(Object *obj)
85
/*
33
{
86
* Move Prefix
34
ARMSSE *s = ARM_SSE(obj);
87
*
35
@@ -XXX,XX +XXX,XX @@ static void armsse_init(Object *obj)
36
assert(info->sram_banks <= MAX_SRAM_BANKS);
37
assert(info->num_cpus <= SSE_MAX_CPUS);
38
39
- s->mainclk = qdev_init_clock_in(DEVICE(s), "MAINCLK", NULL, NULL);
40
+ s->mainclk = qdev_init_clock_in(DEVICE(s), "MAINCLK",
41
+ armsse_mainclk_update, s);
42
s->s32kclk = qdev_init_clock_in(DEVICE(s), "S32KCLK", NULL, NULL);
43
44
memory_region_init(&s->container, obj, "armsse-container", UINT64_MAX);
45
@@ -XXX,XX +XXX,XX @@ static void armsse_realize(DeviceState *dev, Error **errp)
46
return;
47
}
48
49
- if (!s->mainclk_frq) {
50
- error_setg(errp, "MAINCLK_FRQ property was not set");
51
- return;
52
+ if (!clock_has_source(s->mainclk)) {
53
+ error_setg(errp, "MAINCLK clock was not connected");
54
+ }
55
+ if (!clock_has_source(s->s32kclk)) {
56
+ error_setg(errp, "S32KCLK clock was not connected");
57
}
58
59
assert(info->num_cpus <= SSE_MAX_CPUS);
60
@@ -XXX,XX +XXX,XX @@ static void armsse_realize(DeviceState *dev, Error **errp)
61
*/
62
sysbus_init_mmio(SYS_BUS_DEVICE(s), &s->container);
63
64
- system_clock_scale = NANOSECONDS_PER_SECOND / s->mainclk_frq;
65
+ /* Set initial system_clock_scale from MAINCLK */
66
+ armsse_mainclk_update(s);
67
}
68
69
static void armsse_idau_check(IDAUInterface *ii, uint32_t address,
70
--
88
--
71
2.20.1
89
2.25.1
72
73
diff view generated by jsdifflib
1
From: Joelle van Dyne <j@getutm.app>
1
From: Richard Henderson <richard.henderson@linaro.org>
2
2
3
A workaround added in early days of 64-bit OSX forced x86_64 if the
3
Mark these as a non-streaming instructions, which should trap
4
host machine had 64-bit support. This creates issues when cross-
4
if full a64 support is not enabled in streaming mode.
5
compiling for ARM64. Additionally, the user can always use --cpu=* to
6
manually set the host CPU and therefore this workaround should be
7
removed.
8
5
9
Reviewed-by: Peter Maydell <peter.maydell@linaro.org>
6
Reviewed-by: Peter Maydell <peter.maydell@linaro.org>
10
Signed-off-by: Joelle van Dyne <j@getutm.app>
7
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
11
Message-id: 20210126012457.39046-12-j@getutm.app
8
Message-id: 20220708151540.18136-14-richard.henderson@linaro.org
12
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
9
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
13
---
10
---
14
configure | 11 -----------
11
target/arm/sme-fa64.decode | 2 --
15
1 file changed, 11 deletions(-)
12
target/arm/translate-sve.c | 2 ++
13
2 files changed, 2 insertions(+), 2 deletions(-)
16
14
17
diff --git a/configure b/configure
15
diff --git a/target/arm/sme-fa64.decode b/target/arm/sme-fa64.decode
18
index XXXXXXX..XXXXXXX 100755
16
index XXXXXXX..XXXXXXX 100644
19
--- a/configure
17
--- a/target/arm/sme-fa64.decode
20
+++ b/configure
18
+++ b/target/arm/sme-fa64.decode
21
@@ -XXX,XX +XXX,XX @@ fi
19
@@ -XXX,XX +XXX,XX @@ FAIL 0001 1110 0111 1110 0000 00-- ---- ---- # FJCVTZS
22
# the correct CPU with the --cpu option.
20
# --11 1100 --1- ---- ---- ---- ---- --10 # Load/store FP register (register offset)
23
case $targetos in
21
# --11 1101 ---- ---- ---- ---- ---- ---- # Load/store FP register (scaled imm)
24
Darwin)
22
25
- # on Leopard most of the system is 32-bit, so we have to ask the kernel if we can
23
-FAIL 1010 010- ---- ---- 011- ---- ---- ---- # SVE contiguous FF load (scalar+scalar)
26
- # run 64-bit userspace code.
24
-FAIL 1010 010- ---1 ---- 101- ---- ---- ---- # SVE contiguous NF load (scalar+imm)
27
- # If the user didn't specify a CPU explicitly and the kernel says this is
25
FAIL 1010 010- -01- ---- 000- ---- ---- ---- # SVE load & replicate 32 bytes (scalar+scalar)
28
- # 64 bit hw, then assume x86_64. Otherwise fall through to the usual detection code.
26
FAIL 1010 010- -010 ---- 001- ---- ---- ---- # SVE load & replicate 32 bytes (scalar+imm)
29
- if test -z "$cpu" && test "$(sysctl -n hw.optional.x86_64)" = "1"; then
27
diff --git a/target/arm/translate-sve.c b/target/arm/translate-sve.c
30
- cpu="x86_64"
28
index XXXXXXX..XXXXXXX 100644
31
- fi
29
--- a/target/arm/translate-sve.c
32
HOST_DSOSUF=".dylib"
30
+++ b/target/arm/translate-sve.c
33
;;
31
@@ -XXX,XX +XXX,XX @@ static bool trans_LDFF1_zprr(DisasContext *s, arg_rprr_load *a)
34
SunOS)
32
if (!dc_isar_feature(aa64_sve, s)) {
35
@@ -XXX,XX +XXX,XX @@ OpenBSD)
33
return false;
36
Darwin)
34
}
37
bsd="yes"
35
+ s->is_nonstreaming = true;
38
darwin="yes"
36
if (sve_access_check(s)) {
39
- if [ "$cpu" = "x86_64" ] ; then
37
TCGv_i64 addr = new_tmp_a64(s);
40
- QEMU_CFLAGS="-arch x86_64 $QEMU_CFLAGS"
38
tcg_gen_shli_i64(addr, cpu_reg(s, a->rm), dtype_msz(a->dtype));
41
- QEMU_LDFLAGS="-arch x86_64 $QEMU_LDFLAGS"
39
@@ -XXX,XX +XXX,XX @@ static bool trans_LDNF1_zpri(DisasContext *s, arg_rpri_load *a)
42
- fi
40
if (!dc_isar_feature(aa64_sve, s)) {
43
audio_drv_list="try-coreaudio try-sdl"
41
return false;
44
audio_possible_drivers="coreaudio sdl"
42
}
45
# Disable attempts to use ObjectiveC features in os/object.h since they
43
+ s->is_nonstreaming = true;
44
if (sve_access_check(s)) {
45
int vsz = vec_full_reg_size(s);
46
int elements = vsz >> dtype_esz[a->dtype];
46
--
47
--
47
2.20.1
48
2.25.1
48
49
diff view generated by jsdifflib
1
From: Joelle van Dyne <j@getutm.app>
1
From: Richard Henderson <richard.henderson@linaro.org>
2
2
3
On iOS there is no CoreAudio, so we should not assume Darwin always
3
Mark these as a non-streaming instructions, which should trap
4
has it.
4
if full a64 support is not enabled in streaming mode.
5
5
6
Signed-off-by: Joelle van Dyne <j@getutm.app>
6
Reviewed-by: Peter Maydell <peter.maydell@linaro.org>
7
Reviewed-by: Philippe Mathieu-Daudé <f4bug@amsat.org>
7
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
8
Message-id: 20210126012457.39046-11-j@getutm.app
8
Message-id: 20220708151540.18136-15-richard.henderson@linaro.org
9
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
9
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
10
---
10
---
11
configure | 35 +++++++++++++++++++++++++++++++++--
11
target/arm/sme-fa64.decode | 3 ---
12
1 file changed, 33 insertions(+), 2 deletions(-)
12
target/arm/translate-sve.c | 2 ++
13
2 files changed, 2 insertions(+), 3 deletions(-)
13
14
14
diff --git a/configure b/configure
15
diff --git a/target/arm/sme-fa64.decode b/target/arm/sme-fa64.decode
15
index XXXXXXX..XXXXXXX 100755
16
index XXXXXXX..XXXXXXX 100644
16
--- a/configure
17
--- a/target/arm/sme-fa64.decode
17
+++ b/configure
18
+++ b/target/arm/sme-fa64.decode
18
@@ -XXX,XX +XXX,XX @@ fdt="auto"
19
@@ -XXX,XX +XXX,XX @@ FAIL 0001 1110 0111 1110 0000 00-- ---- ---- # FJCVTZS
19
netmap="no"
20
# --11 1100 --0- ---- ---- ---- ---- ---- # Load/store FP register (unscaled imm)
20
sdl="auto"
21
# --11 1100 --1- ---- ---- ---- ---- --10 # Load/store FP register (register offset)
21
sdl_image="auto"
22
# --11 1101 ---- ---- ---- ---- ---- ---- # Load/store FP register (scaled imm)
22
+coreaudio="auto"
23
-
23
virtiofsd="auto"
24
-FAIL 1010 010- -01- ---- 000- ---- ---- ---- # SVE load & replicate 32 bytes (scalar+scalar)
24
virtfs="auto"
25
-FAIL 1010 010- -010 ---- 001- ---- ---- ---- # SVE load & replicate 32 bytes (scalar+imm)
25
libudev="auto"
26
diff --git a/target/arm/translate-sve.c b/target/arm/translate-sve.c
26
@@ -XXX,XX +XXX,XX @@ Darwin)
27
index XXXXXXX..XXXXXXX 100644
27
QEMU_CFLAGS="-arch x86_64 $QEMU_CFLAGS"
28
--- a/target/arm/translate-sve.c
28
QEMU_LDFLAGS="-arch x86_64 $QEMU_LDFLAGS"
29
+++ b/target/arm/translate-sve.c
29
fi
30
@@ -XXX,XX +XXX,XX @@ static bool trans_LD1RO_zprr(DisasContext *s, arg_rprr_load *a)
30
- audio_drv_list="coreaudio try-sdl"
31
if (a->rm == 31) {
31
+ audio_drv_list="try-coreaudio try-sdl"
32
return false;
32
audio_possible_drivers="coreaudio sdl"
33
}
33
# Disable attempts to use ObjectiveC features in os/object.h since they
34
+ s->is_nonstreaming = true;
34
# won't work when we're compiling with gcc as a C compiler.
35
if (sve_access_check(s)) {
35
@@ -XXX,XX +XXX,XX @@ EOF
36
TCGv_i64 addr = new_tmp_a64(s);
36
fi
37
tcg_gen_shli_i64(addr, cpu_reg(s, a->rm), dtype_msz(a->dtype));
37
fi
38
@@ -XXX,XX +XXX,XX @@ static bool trans_LD1RO_zpri(DisasContext *s, arg_rpri_load *a)
38
39
if (!dc_isar_feature(aa64_sve_f64mm, s)) {
39
+##########################################
40
return false;
40
+# detect CoreAudio
41
}
41
+if test "$coreaudio" != "no" ; then
42
+ s->is_nonstreaming = true;
42
+ coreaudio_libs="-framework CoreAudio"
43
if (sve_access_check(s)) {
43
+ cat > $TMPC << EOF
44
TCGv_i64 addr = new_tmp_a64(s);
44
+#include <CoreAudio/CoreAudio.h>
45
tcg_gen_addi_i64(addr, cpu_reg_sp(s, a->rn), a->imm * 32);
45
+int main(void)
46
+{
47
+ return (int)AudioGetCurrentHostTime();
48
+}
49
+EOF
50
+ if compile_prog "" "$coreaudio_libs" ; then
51
+ coreaudio=yes
52
+ else
53
+ coreaudio=no
54
+ fi
55
+fi
56
+
57
##########################################
58
# Sound support libraries probe
59
60
@@ -XXX,XX +XXX,XX @@ for drv in $audio_drv_list; do
61
fi
62
;;
63
64
- coreaudio)
65
+ coreaudio | try-coreaudio)
66
+ if test "$coreaudio" = "no"; then
67
+ if test "$drv" = "try-coreaudio"; then
68
+ audio_drv_list=$(echo "$audio_drv_list" | sed -e 's/try-coreaudio//')
69
+ else
70
+ error_exit "$drv check failed" \
71
+ "Make sure to have the $drv is available."
72
+ fi
73
+ else
74
coreaudio_libs="-framework CoreAudio"
75
+ if test "$drv" = "try-coreaudio"; then
76
+ audio_drv_list=$(echo "$audio_drv_list" | sed -e 's/try-coreaudio/coreaudio/')
77
+ fi
78
+ fi
79
;;
80
81
dsound)
82
--
46
--
83
2.20.1
47
2.25.1
84
85
diff view generated by jsdifflib
1
From: Mihai Carabas <mihai.carabas@oracle.com>
1
From: Richard Henderson <richard.henderson@linaro.org>
2
2
3
Add a test case for pvpanic-pci device. The scenario is the same as pvpanic
3
These functions will be used to verify that the cpu
4
ISA device, but is using the PCI bus.
4
is in the correct state for a given instruction.
5
5
6
Signed-off-by: Mihai Carabas <mihai.carabas@oracle.com>
7
Acked-by: Thomas Huth <thuth@redhat.com>
8
Reviewed-by: Peter Maydell <peter.maydell@linaro.org>
6
Reviewed-by: Peter Maydell <peter.maydell@linaro.org>
9
Signed-off-by: Mihai Carabas <mihai.carabas@oracle.com>
7
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
8
Message-id: 20220708151540.18136-16-richard.henderson@linaro.org
10
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
9
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
11
---
10
---
12
tests/qtest/pvpanic-pci-test.c | 94 ++++++++++++++++++++++++++++++++++
11
target/arm/translate-a64.h | 21 +++++++++++++++++++++
13
tests/qtest/meson.build | 1 +
12
target/arm/translate-a64.c | 34 ++++++++++++++++++++++++++++++++++
14
2 files changed, 95 insertions(+)
13
2 files changed, 55 insertions(+)
15
create mode 100644 tests/qtest/pvpanic-pci-test.c
16
14
17
diff --git a/tests/qtest/pvpanic-pci-test.c b/tests/qtest/pvpanic-pci-test.c
15
diff --git a/target/arm/translate-a64.h b/target/arm/translate-a64.h
18
new file mode 100644
16
index XXXXXXX..XXXXXXX 100644
19
index XXXXXXX..XXXXXXX
17
--- a/target/arm/translate-a64.h
20
--- /dev/null
18
+++ b/target/arm/translate-a64.h
21
+++ b/tests/qtest/pvpanic-pci-test.c
19
@@ -XXX,XX +XXX,XX @@ void write_fp_dreg(DisasContext *s, int reg, TCGv_i64 v);
22
@@ -XXX,XX +XXX,XX @@
20
bool logic_imm_decode_wmask(uint64_t *result, unsigned int immn,
23
+/*
21
unsigned int imms, unsigned int immr);
24
+ * QTest testcase for PV Panic PCI device
22
bool sve_access_check(DisasContext *s);
25
+ *
23
+bool sme_enabled_check(DisasContext *s);
26
+ * Copyright (C) 2020 Oracle
24
+bool sme_enabled_check_with_svcr(DisasContext *s, unsigned);
27
+ *
28
+ * Authors:
29
+ * Mihai Carabas <mihai.carabas@oracle.com>
30
+ *
31
+ * This work is licensed under the terms of the GNU GPL, version 2 or later.
32
+ * See the COPYING file in the top-level directory.
33
+ *
34
+ */
35
+
25
+
36
+#include "qemu/osdep.h"
26
+/* This function corresponds to CheckStreamingSVEEnabled. */
37
+#include "libqos/libqtest.h"
27
+static inline bool sme_sm_enabled_check(DisasContext *s)
38
+#include "qapi/qmp/qdict.h"
39
+#include "libqos/pci.h"
40
+#include "libqos/pci-pc.h"
41
+#include "hw/pci/pci_regs.h"
42
+
43
+static void test_panic_nopause(void)
44
+{
28
+{
45
+ uint8_t val;
29
+ return sme_enabled_check_with_svcr(s, R_SVCR_SM_MASK);
46
+ QDict *response, *data;
47
+ QTestState *qts;
48
+ QPCIBus *pcibus;
49
+ QPCIDevice *dev;
50
+ QPCIBar bar;
51
+
52
+ qts = qtest_init("-device pvpanic-pci,addr=04.0 -action panic=none");
53
+ pcibus = qpci_new_pc(qts, NULL);
54
+ dev = qpci_device_find(pcibus, QPCI_DEVFN(0x4, 0x0));
55
+ qpci_device_enable(dev);
56
+ bar = qpci_iomap(dev, 0, NULL);
57
+
58
+ qpci_memread(dev, bar, 0, &val, sizeof(val));
59
+ g_assert_cmpuint(val, ==, 3);
60
+
61
+ val = 1;
62
+ qpci_memwrite(dev, bar, 0, &val, sizeof(val));
63
+
64
+ response = qtest_qmp_eventwait_ref(qts, "GUEST_PANICKED");
65
+ g_assert(qdict_haskey(response, "data"));
66
+ data = qdict_get_qdict(response, "data");
67
+ g_assert(qdict_haskey(data, "action"));
68
+ g_assert_cmpstr(qdict_get_str(data, "action"), ==, "run");
69
+ qobject_unref(response);
70
+
71
+ qtest_quit(qts);
72
+}
30
+}
73
+
31
+
74
+static void test_panic(void)
32
+/* This function corresponds to CheckSMEAndZAEnabled. */
33
+static inline bool sme_za_enabled_check(DisasContext *s)
75
+{
34
+{
76
+ uint8_t val;
35
+ return sme_enabled_check_with_svcr(s, R_SVCR_ZA_MASK);
77
+ QDict *response, *data;
78
+ QTestState *qts;
79
+ QPCIBus *pcibus;
80
+ QPCIDevice *dev;
81
+ QPCIBar bar;
82
+
83
+ qts = qtest_init("-device pvpanic-pci,addr=04.0 -action panic=pause");
84
+ pcibus = qpci_new_pc(qts, NULL);
85
+ dev = qpci_device_find(pcibus, QPCI_DEVFN(0x4, 0x0));
86
+ qpci_device_enable(dev);
87
+ bar = qpci_iomap(dev, 0, NULL);
88
+
89
+ qpci_memread(dev, bar, 0, &val, sizeof(val));
90
+ g_assert_cmpuint(val, ==, 3);
91
+
92
+ val = 1;
93
+ qpci_memwrite(dev, bar, 0, &val, sizeof(val));
94
+
95
+ response = qtest_qmp_eventwait_ref(qts, "GUEST_PANICKED");
96
+ g_assert(qdict_haskey(response, "data"));
97
+ data = qdict_get_qdict(response, "data");
98
+ g_assert(qdict_haskey(data, "action"));
99
+ g_assert_cmpstr(qdict_get_str(data, "action"), ==, "pause");
100
+ qobject_unref(response);
101
+
102
+ qtest_quit(qts);
103
+}
36
+}
104
+
37
+
105
+int main(int argc, char **argv)
38
+/* Note that this function corresponds to CheckStreamingSVEAndZAEnabled. */
39
+static inline bool sme_smza_enabled_check(DisasContext *s)
106
+{
40
+{
107
+ int ret;
41
+ return sme_enabled_check_with_svcr(s, R_SVCR_SM_MASK | R_SVCR_ZA_MASK);
42
+}
108
+
43
+
109
+ g_test_init(&argc, &argv, NULL);
44
TCGv_i64 clean_data_tbi(DisasContext *s, TCGv_i64 addr);
110
+ qtest_add_func("/pvpanic-pci/panic", test_panic);
45
TCGv_i64 gen_mte_check1(DisasContext *s, TCGv_i64 addr, bool is_write,
111
+ qtest_add_func("/pvpanic-pci/panic-nopause", test_panic_nopause);
46
bool tag_checked, int log2_size);
47
diff --git a/target/arm/translate-a64.c b/target/arm/translate-a64.c
48
index XXXXXXX..XXXXXXX 100644
49
--- a/target/arm/translate-a64.c
50
+++ b/target/arm/translate-a64.c
51
@@ -XXX,XX +XXX,XX @@ static bool sme_access_check(DisasContext *s)
52
return true;
53
}
54
55
+/* This function corresponds to CheckSMEEnabled. */
56
+bool sme_enabled_check(DisasContext *s)
57
+{
58
+ /*
59
+ * Note that unlike sve_excp_el, we have not constrained sme_excp_el
60
+ * to be zero when fp_excp_el has priority. This is because we need
61
+ * sme_excp_el by itself for cpregs access checks.
62
+ */
63
+ if (!s->fp_excp_el || s->sme_excp_el < s->fp_excp_el) {
64
+ s->fp_access_checked = true;
65
+ return sme_access_check(s);
66
+ }
67
+ return fp_access_check_only(s);
68
+}
112
+
69
+
113
+ ret = g_test_run();
70
+/* Common subroutine for CheckSMEAnd*Enabled. */
71
+bool sme_enabled_check_with_svcr(DisasContext *s, unsigned req)
72
+{
73
+ if (!sme_enabled_check(s)) {
74
+ return false;
75
+ }
76
+ if (FIELD_EX64(req, SVCR, SM) && !s->pstate_sm) {
77
+ gen_exception_insn(s, s->pc_curr, EXCP_UDEF,
78
+ syn_smetrap(SME_ET_NotStreaming, false));
79
+ return false;
80
+ }
81
+ if (FIELD_EX64(req, SVCR, ZA) && !s->pstate_za) {
82
+ gen_exception_insn(s, s->pc_curr, EXCP_UDEF,
83
+ syn_smetrap(SME_ET_InactiveZA, false));
84
+ return false;
85
+ }
86
+ return true;
87
+}
114
+
88
+
115
+ return ret;
89
/*
116
+}
90
* This utility function is for doing register extension with an
117
diff --git a/tests/qtest/meson.build b/tests/qtest/meson.build
91
* optional shift. You will likely want to pass a temporary for the
118
index XXXXXXX..XXXXXXX 100644
119
--- a/tests/qtest/meson.build
120
+++ b/tests/qtest/meson.build
121
@@ -XXX,XX +XXX,XX @@ qtests_i386 = \
122
config_all_devices.has_key('CONFIG_ISA_IPMI_BT') ? ['ipmi-bt-test'] : []) + \
123
(config_all_devices.has_key('CONFIG_WDT_IB700') ? ['wdt_ib700-test'] : []) + \
124
(config_all_devices.has_key('CONFIG_PVPANIC_ISA') ? ['pvpanic-test'] : []) + \
125
+ (config_all_devices.has_key('CONFIG_PVPANIC_PCI') ? ['pvpanic-pci-test'] : []) + \
126
(config_all_devices.has_key('CONFIG_HDA') ? ['intel-hda-test'] : []) + \
127
(config_all_devices.has_key('CONFIG_I82801B11') ? ['i82801b11-test'] : []) + \
128
(config_all_devices.has_key('CONFIG_IOH3420') ? ['ioh3420-test'] : []) + \
129
--
92
--
130
2.20.1
93
2.25.1
131
132
diff view generated by jsdifflib
1
From: Maxim Uvarov <maxim.uvarov@linaro.org>
1
From: Richard Henderson <richard.henderson@linaro.org>
2
2
3
Add secure pl061 for reset/power down machine from
3
The pseudocode for CheckSVEEnabled gains a check for Streaming
4
the secure world (Arm Trusted Firmware). Connect it
4
SVE mode, and for SME present but SVE absent.
5
with gpio-pwr driver.
6
5
7
Signed-off-by: Maxim Uvarov <maxim.uvarov@linaro.org>
6
Reviewed-by: Peter Maydell <peter.maydell@linaro.org>
8
Reviewed-by: Andrew Jones <drjones@redhat.com>
7
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
9
[PMM: Added mention of the new device to the documentation]
8
Message-id: 20220708151540.18136-17-richard.henderson@linaro.org
10
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
9
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
11
---
10
---
12
docs/system/arm/virt.rst | 2 ++
11
target/arm/translate-a64.c | 22 ++++++++++++++++------
13
include/hw/arm/virt.h | 2 ++
12
1 file changed, 16 insertions(+), 6 deletions(-)
14
hw/arm/virt.c | 56 +++++++++++++++++++++++++++++++++++++++-
15
hw/arm/Kconfig | 1 +
16
4 files changed, 60 insertions(+), 1 deletion(-)
17
13
18
diff --git a/docs/system/arm/virt.rst b/docs/system/arm/virt.rst
14
diff --git a/target/arm/translate-a64.c b/target/arm/translate-a64.c
19
index XXXXXXX..XXXXXXX 100644
15
index XXXXXXX..XXXXXXX 100644
20
--- a/docs/system/arm/virt.rst
16
--- a/target/arm/translate-a64.c
21
+++ b/docs/system/arm/virt.rst
17
+++ b/target/arm/translate-a64.c
22
@@ -XXX,XX +XXX,XX @@ The virt board supports:
18
@@ -XXX,XX +XXX,XX @@ static bool fp_access_check(DisasContext *s)
23
- Secure-World-only devices if the CPU has TrustZone:
19
return true;
24
25
- A second PL011 UART
26
+ - A second PL061 GPIO controller, with GPIO lines for triggering
27
+ a system reset or system poweroff
28
- A secure flash memory
29
- 16MB of secure RAM
30
31
diff --git a/include/hw/arm/virt.h b/include/hw/arm/virt.h
32
index XXXXXXX..XXXXXXX 100644
33
--- a/include/hw/arm/virt.h
34
+++ b/include/hw/arm/virt.h
35
@@ -XXX,XX +XXX,XX @@ enum {
36
VIRT_GPIO,
37
VIRT_SECURE_UART,
38
VIRT_SECURE_MEM,
39
+ VIRT_SECURE_GPIO,
40
VIRT_PCDIMM_ACPI,
41
VIRT_ACPI_GED,
42
VIRT_NVDIMM_ACPI,
43
@@ -XXX,XX +XXX,XX @@ struct VirtMachineClass {
44
bool kvm_no_adjvtime;
45
bool no_kvm_steal_time;
46
bool acpi_expose_flash;
47
+ bool no_secure_gpio;
48
};
49
50
struct VirtMachineState {
51
diff --git a/hw/arm/virt.c b/hw/arm/virt.c
52
index XXXXXXX..XXXXXXX 100644
53
--- a/hw/arm/virt.c
54
+++ b/hw/arm/virt.c
55
@@ -XXX,XX +XXX,XX @@ static const MemMapEntry base_memmap[] = {
56
[VIRT_ACPI_GED] = { 0x09080000, ACPI_GED_EVT_SEL_LEN },
57
[VIRT_NVDIMM_ACPI] = { 0x09090000, NVDIMM_ACPI_IO_LEN},
58
[VIRT_PVTIME] = { 0x090a0000, 0x00010000 },
59
+ [VIRT_SECURE_GPIO] = { 0x090b0000, 0x00001000 },
60
[VIRT_MMIO] = { 0x0a000000, 0x00000200 },
61
/* ...repeating for a total of NUM_VIRTIO_TRANSPORTS, each of that size */
62
[VIRT_PLATFORM_BUS] = { 0x0c000000, 0x02000000 },
63
@@ -XXX,XX +XXX,XX @@ static void create_gpio_keys(const VirtMachineState *vms,
64
"gpios", phandle, 3, 0);
65
}
20
}
66
21
67
+#define SECURE_GPIO_POWEROFF 0
22
-/* Check that SVE access is enabled. If it is, return true.
68
+#define SECURE_GPIO_RESET 1
23
+/*
24
+ * Check that SVE access is enabled. If it is, return true.
25
* If not, emit code to generate an appropriate exception and return false.
26
+ * This function corresponds to CheckSVEEnabled().
27
*/
28
bool sve_access_check(DisasContext *s)
29
{
30
- if (s->sve_excp_el) {
31
- assert(!s->sve_access_checked);
32
- s->sve_access_checked = true;
33
-
34
+ if (s->pstate_sm || !dc_isar_feature(aa64_sve, s)) {
35
+ assert(dc_isar_feature(aa64_sme, s));
36
+ if (!sme_sm_enabled_check(s)) {
37
+ goto fail_exit;
38
+ }
39
+ } else if (s->sve_excp_el) {
40
gen_exception_insn_el(s, s->pc_curr, EXCP_UDEF,
41
syn_sve_access_trap(), s->sve_excp_el);
42
- return false;
43
+ goto fail_exit;
44
}
45
s->sve_access_checked = true;
46
return fp_access_check(s);
69
+
47
+
70
+static void create_secure_gpio_pwr(const VirtMachineState *vms,
48
+ fail_exit:
71
+ DeviceState *pl061_dev,
49
+ /* Assert that we only raise one exception per instruction. */
72
+ uint32_t phandle)
50
+ assert(!s->sve_access_checked);
73
+{
51
+ s->sve_access_checked = true;
74
+ DeviceState *gpio_pwr_dev;
52
+ return false;
75
+
76
+ /* gpio-pwr */
77
+ gpio_pwr_dev = sysbus_create_simple("gpio-pwr", -1, NULL);
78
+
79
+ /* connect secure pl061 to gpio-pwr */
80
+ qdev_connect_gpio_out(pl061_dev, SECURE_GPIO_RESET,
81
+ qdev_get_gpio_in_named(gpio_pwr_dev, "reset", 0));
82
+ qdev_connect_gpio_out(pl061_dev, SECURE_GPIO_POWEROFF,
83
+ qdev_get_gpio_in_named(gpio_pwr_dev, "shutdown", 0));
84
+
85
+ qemu_fdt_add_subnode(vms->fdt, "/gpio-poweroff");
86
+ qemu_fdt_setprop_string(vms->fdt, "/gpio-poweroff", "compatible",
87
+ "gpio-poweroff");
88
+ qemu_fdt_setprop_cells(vms->fdt, "/gpio-poweroff",
89
+ "gpios", phandle, SECURE_GPIO_POWEROFF, 0);
90
+ qemu_fdt_setprop_string(vms->fdt, "/gpio-poweroff", "status", "disabled");
91
+ qemu_fdt_setprop_string(vms->fdt, "/gpio-poweroff", "secure-status",
92
+ "okay");
93
+
94
+ qemu_fdt_add_subnode(vms->fdt, "/gpio-restart");
95
+ qemu_fdt_setprop_string(vms->fdt, "/gpio-restart", "compatible",
96
+ "gpio-restart");
97
+ qemu_fdt_setprop_cells(vms->fdt, "/gpio-restart",
98
+ "gpios", phandle, SECURE_GPIO_RESET, 0);
99
+ qemu_fdt_setprop_string(vms->fdt, "/gpio-restart", "status", "disabled");
100
+ qemu_fdt_setprop_string(vms->fdt, "/gpio-restart", "secure-status",
101
+ "okay");
102
+}
103
+
104
static void create_gpio_devices(const VirtMachineState *vms, int gpio,
105
MemoryRegion *mem)
106
{
107
@@ -XXX,XX +XXX,XX @@ static void create_gpio_devices(const VirtMachineState *vms, int gpio,
108
qemu_fdt_setprop_string(vms->fdt, nodename, "clock-names", "apb_pclk");
109
qemu_fdt_setprop_cell(vms->fdt, nodename, "phandle", phandle);
110
111
+ if (gpio != VIRT_GPIO) {
112
+ /* Mark as not usable by the normal world */
113
+ qemu_fdt_setprop_string(vms->fdt, nodename, "status", "disabled");
114
+ qemu_fdt_setprop_string(vms->fdt, nodename, "secure-status", "okay");
115
+ }
116
g_free(nodename);
117
118
/* Child gpio devices */
119
- create_gpio_keys(vms, pl061_dev, phandle);
120
+ if (gpio == VIRT_GPIO) {
121
+ create_gpio_keys(vms, pl061_dev, phandle);
122
+ } else {
123
+ create_secure_gpio_pwr(vms, pl061_dev, phandle);
124
+ }
125
}
53
}
126
54
127
static void create_virtio_devices(const VirtMachineState *vms)
55
/*
128
@@ -XXX,XX +XXX,XX @@ static void machvirt_init(MachineState *machine)
129
create_gpio_devices(vms, VIRT_GPIO, sysmem);
130
}
131
132
+ if (vms->secure && !vmc->no_secure_gpio) {
133
+ create_gpio_devices(vms, VIRT_SECURE_GPIO, secure_sysmem);
134
+ }
135
+
136
/* connect powerdown request */
137
vms->powerdown_notifier.notify = virt_powerdown_req;
138
qemu_register_powerdown_notifier(&vms->powerdown_notifier);
139
@@ -XXX,XX +XXX,XX @@ DEFINE_VIRT_MACHINE_AS_LATEST(6, 0)
140
141
static void virt_machine_5_2_options(MachineClass *mc)
142
{
143
+ VirtMachineClass *vmc = VIRT_MACHINE_CLASS(OBJECT_CLASS(mc));
144
+
145
virt_machine_6_0_options(mc);
146
compat_props_add(mc->compat_props, hw_compat_5_2, hw_compat_5_2_len);
147
+ vmc->no_secure_gpio = true;
148
}
149
DEFINE_VIRT_MACHINE(5, 2)
150
151
diff --git a/hw/arm/Kconfig b/hw/arm/Kconfig
152
index XXXXXXX..XXXXXXX 100644
153
--- a/hw/arm/Kconfig
154
+++ b/hw/arm/Kconfig
155
@@ -XXX,XX +XXX,XX @@ config ARM_VIRT
156
select PL011 # UART
157
select PL031 # RTC
158
select PL061 # GPIO
159
+ select GPIO_PWR
160
select PLATFORM_BUS
161
select SMBIOS
162
select VIRTIO_MMIO
163
--
56
--
164
2.20.1
57
2.25.1
165
166
diff view generated by jsdifflib
1
Convert the SSYS code in the Stellaris boards (which encapsulates the
1
From: Richard Henderson <richard.henderson@linaro.org>
2
system registers) to a proper QOM device. This will provide us with
3
somewhere to put the output Clock whose frequency depends on the
4
setting of the PLL configuration registers.
5
2
6
This is a migration compatibility break for lm3s811evb, lm3s6965evb.
3
These SME instructions are nominally within the SVE decode space,
4
so we add them to sve.decode and translate-sve.c.
7
5
8
We use 3-phase reset here because the Clock will need to propagate
6
Reviewed-by: Peter Maydell <peter.maydell@linaro.org>
9
its value in the hold phase.
7
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
8
Message-id: 20220708151540.18136-18-richard.henderson@linaro.org
9
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
10
---
11
target/arm/translate-a64.h | 12 ++++++++++++
12
target/arm/sve.decode | 5 ++++-
13
target/arm/translate-sve.c | 38 ++++++++++++++++++++++++++++++++++++++
14
3 files changed, 54 insertions(+), 1 deletion(-)
10
15
11
For the moment we reset the device during the board creation so that
16
diff --git a/target/arm/translate-a64.h b/target/arm/translate-a64.h
12
the system_clock_scale global gets set; this will be removed in a
13
subsequent commit.
14
15
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
16
Reviewed-by: Luc Michel <luc@lmichel.fr>
17
Tested-by: Philippe Mathieu-Daudé <f4bug@amsat.org>
18
Reviewed-by: Philippe Mathieu-Daudé <f4bug@amsat.org>
19
Message-id: 20210128114145.20536-17-peter.maydell@linaro.org
20
Message-id: 20210121190622.22000-17-peter.maydell@linaro.org
21
Reviewed-by: Philippe Mathieu-Daudé <f4bug@amsat.org>
22
---
23
hw/arm/stellaris.c | 132 ++++++++++++++++++++++++++++++++++++---------
24
1 file changed, 107 insertions(+), 25 deletions(-)
25
26
diff --git a/hw/arm/stellaris.c b/hw/arm/stellaris.c
27
index XXXXXXX..XXXXXXX 100644
17
index XXXXXXX..XXXXXXX 100644
28
--- a/hw/arm/stellaris.c
18
--- a/target/arm/translate-a64.h
29
+++ b/hw/arm/stellaris.c
19
+++ b/target/arm/translate-a64.h
30
@@ -XXX,XX +XXX,XX @@ static void stellaris_gptm_realize(DeviceState *dev, Error **errp)
20
@@ -XXX,XX +XXX,XX @@ static inline int vec_full_reg_size(DisasContext *s)
31
21
return s->vl;
32
/* System controller. */
22
}
33
23
34
-typedef struct {
24
+/* Return the byte size of the vector register, SVL / 8. */
35
+#define TYPE_STELLARIS_SYS "stellaris-sys"
25
+static inline int streaming_vec_reg_size(DisasContext *s)
36
+OBJECT_DECLARE_SIMPLE_TYPE(ssys_state, STELLARIS_SYS)
26
+{
37
+
27
+ return s->svl;
38
+struct ssys_state {
39
+ SysBusDevice parent_obj;
40
+
41
MemoryRegion iomem;
42
uint32_t pborctl;
43
uint32_t ldopctl;
44
@@ -XXX,XX +XXX,XX @@ typedef struct {
45
uint32_t dcgc[3];
46
uint32_t clkvclr;
47
uint32_t ldoarst;
48
+ qemu_irq irq;
49
+ /* Properties (all read-only registers) */
50
uint32_t user0;
51
uint32_t user1;
52
- qemu_irq irq;
53
- stellaris_board_info *board;
54
-} ssys_state;
55
+ uint32_t did0;
56
+ uint32_t did1;
57
+ uint32_t dc0;
58
+ uint32_t dc1;
59
+ uint32_t dc2;
60
+ uint32_t dc3;
61
+ uint32_t dc4;
62
+};
63
64
static void ssys_update(ssys_state *s)
65
{
66
@@ -XXX,XX +XXX,XX @@ static uint32_t pllcfg_fury[16] = {
67
68
static int ssys_board_class(const ssys_state *s)
69
{
70
- uint32_t did0 = s->board->did0;
71
+ uint32_t did0 = s->did0;
72
switch (did0 & DID0_VER_MASK) {
73
case DID0_VER_0:
74
return DID0_CLASS_SANDSTORM;
75
@@ -XXX,XX +XXX,XX @@ static uint64_t ssys_read(void *opaque, hwaddr offset,
76
77
switch (offset) {
78
case 0x000: /* DID0 */
79
- return s->board->did0;
80
+ return s->did0;
81
case 0x004: /* DID1 */
82
- return s->board->did1;
83
+ return s->did1;
84
case 0x008: /* DC0 */
85
- return s->board->dc0;
86
+ return s->dc0;
87
case 0x010: /* DC1 */
88
- return s->board->dc1;
89
+ return s->dc1;
90
case 0x014: /* DC2 */
91
- return s->board->dc2;
92
+ return s->dc2;
93
case 0x018: /* DC3 */
94
- return s->board->dc3;
95
+ return s->dc3;
96
case 0x01c: /* DC4 */
97
- return s->board->dc4;
98
+ return s->dc4;
99
case 0x030: /* PBORCTL */
100
return s->pborctl;
101
case 0x034: /* LDOPCTL */
102
@@ -XXX,XX +XXX,XX @@ static const MemoryRegionOps ssys_ops = {
103
.endianness = DEVICE_NATIVE_ENDIAN,
104
};
105
106
-static void ssys_reset(void *opaque)
107
+static void stellaris_sys_reset_enter(Object *obj, ResetType type)
108
{
109
- ssys_state *s = (ssys_state *)opaque;
110
+ ssys_state *s = STELLARIS_SYS(obj);
111
112
s->pborctl = 0x7ffd;
113
s->rcc = 0x078e3ac0;
114
@@ -XXX,XX +XXX,XX @@ static void ssys_reset(void *opaque)
115
s->rcgc[0] = 1;
116
s->scgc[0] = 1;
117
s->dcgc[0] = 1;
118
+}
28
+}
119
+
29
+
120
+static void stellaris_sys_reset_hold(Object *obj)
30
/*
31
* Return the offset info CPUARMState of the predicate vector register Pn.
32
* Note for this purpose, FFR is P16.
33
@@ -XXX,XX +XXX,XX @@ static inline int pred_full_reg_size(DisasContext *s)
34
return s->vl >> 3;
35
}
36
37
+/* Return the byte size of the predicate register, SVL / 64. */
38
+static inline int streaming_pred_reg_size(DisasContext *s)
121
+{
39
+{
122
+ ssys_state *s = STELLARIS_SYS(obj);
40
+ return s->svl >> 3;
123
+
124
ssys_calculate_system_clock(s);
125
}
126
127
+static void stellaris_sys_reset_exit(Object *obj)
128
+{
129
+}
41
+}
130
+
42
+
131
static int stellaris_sys_post_load(void *opaque, int version_id)
43
/*
132
{
44
* Round up the size of a register to a size allowed by
133
ssys_state *s = opaque;
45
* the tcg vector infrastructure. Any operation which uses this
134
@@ -XXX,XX +XXX,XX @@ static const VMStateDescription vmstate_stellaris_sys = {
46
diff --git a/target/arm/sve.decode b/target/arm/sve.decode
135
}
47
index XXXXXXX..XXXXXXX 100644
136
};
48
--- a/target/arm/sve.decode
137
49
+++ b/target/arm/sve.decode
138
+static Property stellaris_sys_properties[] = {
50
@@ -XXX,XX +XXX,XX @@ INDEX_ri 00000100 esz:2 1 imm:s5 010001 rn:5 rd:5
139
+ DEFINE_PROP_UINT32("user0", ssys_state, user0, 0),
51
# SVE index generation (register start, register increment)
140
+ DEFINE_PROP_UINT32("user1", ssys_state, user1, 0),
52
INDEX_rr 00000100 .. 1 ..... 010011 ..... ..... @rd_rn_rm
141
+ DEFINE_PROP_UINT32("did0", ssys_state, did0, 0),
53
142
+ DEFINE_PROP_UINT32("did1", ssys_state, did1, 0),
54
-### SVE Stack Allocation Group
143
+ DEFINE_PROP_UINT32("dc0", ssys_state, dc0, 0),
55
+### SVE / Streaming SVE Stack Allocation Group
144
+ DEFINE_PROP_UINT32("dc1", ssys_state, dc1, 0),
56
145
+ DEFINE_PROP_UINT32("dc2", ssys_state, dc2, 0),
57
# SVE stack frame adjustment
146
+ DEFINE_PROP_UINT32("dc3", ssys_state, dc3, 0),
58
ADDVL 00000100 001 ..... 01010 ...... ..... @rd_rn_i6
147
+ DEFINE_PROP_UINT32("dc4", ssys_state, dc4, 0),
59
+ADDSVL 00000100 001 ..... 01011 ...... ..... @rd_rn_i6
148
+ DEFINE_PROP_END_OF_LIST()
60
ADDPL 00000100 011 ..... 01010 ...... ..... @rd_rn_i6
149
+};
61
+ADDSPL 00000100 011 ..... 01011 ...... ..... @rd_rn_i6
150
+
62
151
+static void stellaris_sys_instance_init(Object *obj)
63
# SVE stack frame size
64
RDVL 00000100 101 11111 01010 imm:s6 rd:5
65
+RDSVL 00000100 101 11111 01011 imm:s6 rd:5
66
67
### SVE Bitwise Shift - Unpredicated Group
68
69
diff --git a/target/arm/translate-sve.c b/target/arm/translate-sve.c
70
index XXXXXXX..XXXXXXX 100644
71
--- a/target/arm/translate-sve.c
72
+++ b/target/arm/translate-sve.c
73
@@ -XXX,XX +XXX,XX @@ static bool trans_ADDVL(DisasContext *s, arg_ADDVL *a)
74
return true;
75
}
76
77
+static bool trans_ADDSVL(DisasContext *s, arg_ADDSVL *a)
152
+{
78
+{
153
+ ssys_state *s = STELLARIS_SYS(obj);
79
+ if (!dc_isar_feature(aa64_sme, s)) {
154
+ SysBusDevice *sbd = SYS_BUS_DEVICE(s);
80
+ return false;
155
+
81
+ }
156
+ memory_region_init_io(&s->iomem, obj, &ssys_ops, s, "ssys", 0x00001000);
82
+ if (sme_enabled_check(s)) {
157
+ sysbus_init_mmio(sbd, &s->iomem);
83
+ TCGv_i64 rd = cpu_reg_sp(s, a->rd);
158
+ sysbus_init_irq(sbd, &s->irq);
84
+ TCGv_i64 rn = cpu_reg_sp(s, a->rn);
85
+ tcg_gen_addi_i64(rd, rn, a->imm * streaming_vec_reg_size(s));
86
+ }
87
+ return true;
159
+}
88
+}
160
+
89
+
161
static int stellaris_sys_init(uint32_t base, qemu_irq irq,
90
static bool trans_ADDPL(DisasContext *s, arg_ADDPL *a)
162
stellaris_board_info * board,
163
uint8_t *macaddr)
164
{
91
{
165
- ssys_state *s;
92
if (!dc_isar_feature(aa64_sve, s)) {
166
+ DeviceState *dev = qdev_new(TYPE_STELLARIS_SYS);
93
@@ -XXX,XX +XXX,XX @@ static bool trans_ADDPL(DisasContext *s, arg_ADDPL *a)
167
+ SysBusDevice *sbd = SYS_BUS_DEVICE(dev);
94
return true;
168
169
- s = g_new0(ssys_state, 1);
170
- s->irq = irq;
171
- s->board = board;
172
/* Most devices come preprogrammed with a MAC address in the user data. */
173
- s->user0 = macaddr[0] | (macaddr[1] << 8) | (macaddr[2] << 16);
174
- s->user1 = macaddr[3] | (macaddr[4] << 8) | (macaddr[5] << 16);
175
+ qdev_prop_set_uint32(dev, "user0",
176
+ macaddr[0] | (macaddr[1] << 8) | (macaddr[2] << 16));
177
+ qdev_prop_set_uint32(dev, "user1",
178
+ macaddr[3] | (macaddr[4] << 8) | (macaddr[5] << 16));
179
+ qdev_prop_set_uint32(dev, "did0", board->did0);
180
+ qdev_prop_set_uint32(dev, "did1", board->did1);
181
+ qdev_prop_set_uint32(dev, "dc0", board->dc0);
182
+ qdev_prop_set_uint32(dev, "dc1", board->dc1);
183
+ qdev_prop_set_uint32(dev, "dc2", board->dc2);
184
+ qdev_prop_set_uint32(dev, "dc3", board->dc3);
185
+ qdev_prop_set_uint32(dev, "dc4", board->dc4);
186
+
187
+ sysbus_realize_and_unref(sbd, &error_fatal);
188
+ sysbus_mmio_map(sbd, 0, base);
189
+ sysbus_connect_irq(sbd, 0, irq);
190
+
191
+ /*
192
+ * Normally we should not be resetting devices like this during
193
+ * board creation. For the moment we need to do so, because
194
+ * system_clock_scale will only get set when the STELLARIS_SYS
195
+ * device is reset, and we need its initial value to pass to
196
+ * the watchdog device. This hack can be removed once the
197
+ * watchdog has been converted to use a Clock input instead.
198
+ */
199
+ device_cold_reset(dev);
200
201
- memory_region_init_io(&s->iomem, NULL, &ssys_ops, s, "ssys", 0x00001000);
202
- memory_region_add_subregion(get_system_memory(), base, &s->iomem);
203
- ssys_reset(s);
204
- vmstate_register(NULL, VMSTATE_INSTANCE_ID_ANY, &vmstate_stellaris_sys, s);
205
return 0;
206
}
95
}
207
96
208
-
97
+static bool trans_ADDSPL(DisasContext *s, arg_ADDSPL *a)
209
/* I2C controller. */
210
211
#define TYPE_STELLARIS_I2C "stellaris-i2c"
212
@@ -XXX,XX +XXX,XX @@ static const TypeInfo stellaris_adc_info = {
213
.class_init = stellaris_adc_class_init,
214
};
215
216
+static void stellaris_sys_class_init(ObjectClass *klass, void *data)
217
+{
98
+{
218
+ DeviceClass *dc = DEVICE_CLASS(klass);
99
+ if (!dc_isar_feature(aa64_sme, s)) {
219
+ ResettableClass *rc = RESETTABLE_CLASS(klass);
100
+ return false;
220
+
101
+ }
221
+ dc->vmsd = &vmstate_stellaris_sys;
102
+ if (sme_enabled_check(s)) {
222
+ rc->phases.enter = stellaris_sys_reset_enter;
103
+ TCGv_i64 rd = cpu_reg_sp(s, a->rd);
223
+ rc->phases.hold = stellaris_sys_reset_hold;
104
+ TCGv_i64 rn = cpu_reg_sp(s, a->rn);
224
+ rc->phases.exit = stellaris_sys_reset_exit;
105
+ tcg_gen_addi_i64(rd, rn, a->imm * streaming_pred_reg_size(s));
225
+ device_class_set_props(dc, stellaris_sys_properties);
106
+ }
107
+ return true;
226
+}
108
+}
227
+
109
+
228
+static const TypeInfo stellaris_sys_info = {
110
static bool trans_RDVL(DisasContext *s, arg_RDVL *a)
229
+ .name = TYPE_STELLARIS_SYS,
111
{
230
+ .parent = TYPE_SYS_BUS_DEVICE,
112
if (!dc_isar_feature(aa64_sve, s)) {
231
+ .instance_size = sizeof(ssys_state),
113
@@ -XXX,XX +XXX,XX @@ static bool trans_RDVL(DisasContext *s, arg_RDVL *a)
232
+ .instance_init = stellaris_sys_instance_init,
114
return true;
233
+ .class_init = stellaris_sys_class_init,
115
}
234
+};
116
117
+static bool trans_RDSVL(DisasContext *s, arg_RDSVL *a)
118
+{
119
+ if (!dc_isar_feature(aa64_sme, s)) {
120
+ return false;
121
+ }
122
+ if (sme_enabled_check(s)) {
123
+ TCGv_i64 reg = cpu_reg(s, a->rd);
124
+ tcg_gen_movi_i64(reg, a->imm * streaming_vec_reg_size(s));
125
+ }
126
+ return true;
127
+}
235
+
128
+
236
static void stellaris_register_types(void)
129
/*
237
{
130
*** SVE Compute Vector Address Group
238
type_register_static(&stellaris_i2c_info);
131
*/
239
type_register_static(&stellaris_gptm_info);
240
type_register_static(&stellaris_adc_info);
241
+ type_register_static(&stellaris_sys_info);
242
}
243
244
type_init(stellaris_register_types)
245
--
132
--
246
2.20.1
133
2.25.1
247
248
diff view generated by jsdifflib
1
Now that the CMSDK APB watchdog uses its Clock input, it will
1
From: Richard Henderson <richard.henderson@linaro.org>
2
correctly respond when the system clock frequency is changed using
3
the RCC register on in the Stellaris board system registers. Test
4
that when the RCC register is written it causes the watchdog timer to
5
change speed.
6
2
3
Reviewed-by: Peter Maydell <peter.maydell@linaro.org>
4
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
5
Message-id: 20220708151540.18136-19-richard.henderson@linaro.org
7
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
6
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
8
Reviewed-by: Philippe Mathieu-Daudé <f4bug@amsat.org>
9
Reviewed-by: Luc Michel <luc@lmichel.fr>
10
Tested-by: Philippe Mathieu-Daudé <f4bug@amsat.org>
11
Message-id: 20210128114145.20536-22-peter.maydell@linaro.org
12
Message-id: 20210121190622.22000-22-peter.maydell@linaro.org
13
---
7
---
14
tests/qtest/cmsdk-apb-watchdog-test.c | 52 +++++++++++++++++++++++++++
8
target/arm/helper-sme.h | 2 ++
15
1 file changed, 52 insertions(+)
9
target/arm/sme.decode | 4 ++++
10
target/arm/sme_helper.c | 25 +++++++++++++++++++++++++
11
target/arm/translate-sme.c | 13 +++++++++++++
12
4 files changed, 44 insertions(+)
16
13
17
diff --git a/tests/qtest/cmsdk-apb-watchdog-test.c b/tests/qtest/cmsdk-apb-watchdog-test.c
14
diff --git a/target/arm/helper-sme.h b/target/arm/helper-sme.h
18
index XXXXXXX..XXXXXXX 100644
15
index XXXXXXX..XXXXXXX 100644
19
--- a/tests/qtest/cmsdk-apb-watchdog-test.c
16
--- a/target/arm/helper-sme.h
20
+++ b/tests/qtest/cmsdk-apb-watchdog-test.c
17
+++ b/target/arm/helper-sme.h
18
@@ -XXX,XX +XXX,XX @@
19
20
DEF_HELPER_FLAGS_2(set_pstate_sm, TCG_CALL_NO_RWG, void, env, i32)
21
DEF_HELPER_FLAGS_2(set_pstate_za, TCG_CALL_NO_RWG, void, env, i32)
22
+
23
+DEF_HELPER_FLAGS_3(sme_zero, TCG_CALL_NO_RWG, void, env, i32, i32)
24
diff --git a/target/arm/sme.decode b/target/arm/sme.decode
25
index XXXXXXX..XXXXXXX 100644
26
--- a/target/arm/sme.decode
27
+++ b/target/arm/sme.decode
28
@@ -XXX,XX +XXX,XX @@
29
#
30
# This file is processed by scripts/decodetree.py
31
#
32
+
33
+### SME Misc
34
+
35
+ZERO 11000000 00 001 00000000000 imm:8
36
diff --git a/target/arm/sme_helper.c b/target/arm/sme_helper.c
37
index XXXXXXX..XXXXXXX 100644
38
--- a/target/arm/sme_helper.c
39
+++ b/target/arm/sme_helper.c
40
@@ -XXX,XX +XXX,XX @@ void helper_set_pstate_za(CPUARMState *env, uint32_t i)
41
memset(env->zarray, 0, sizeof(env->zarray));
42
}
43
}
44
+
45
+void helper_sme_zero(CPUARMState *env, uint32_t imm, uint32_t svl)
46
+{
47
+ uint32_t i;
48
+
49
+ /*
50
+ * Special case clearing the entire ZA space.
51
+ * This falls into the CONSTRAINED UNPREDICTABLE zeroing of any
52
+ * parts of the ZA storage outside of SVL.
53
+ */
54
+ if (imm == 0xff) {
55
+ memset(env->zarray, 0, sizeof(env->zarray));
56
+ return;
57
+ }
58
+
59
+ /*
60
+ * Recall that ZAnH.D[m] is spread across ZA[n+8*m],
61
+ * so each row is discontiguous within ZA[].
62
+ */
63
+ for (i = 0; i < svl; i++) {
64
+ if (imm & (1 << (i % 8))) {
65
+ memset(&env->zarray[i], 0, svl);
66
+ }
67
+ }
68
+}
69
diff --git a/target/arm/translate-sme.c b/target/arm/translate-sme.c
70
index XXXXXXX..XXXXXXX 100644
71
--- a/target/arm/translate-sme.c
72
+++ b/target/arm/translate-sme.c
21
@@ -XXX,XX +XXX,XX @@
73
@@ -XXX,XX +XXX,XX @@
22
*/
74
*/
23
75
24
#include "qemu/osdep.h"
76
#include "decode-sme.c.inc"
25
+#include "qemu/bitops.h"
26
#include "libqtest-single.h"
27
28
/*
29
@@ -XXX,XX +XXX,XX @@
30
#define WDOGMIS 0x14
31
#define WDOGLOCK 0xc00
32
33
+#define SSYS_BASE 0x400fe000
34
+#define RCC 0x60
35
+#define SYSDIV_SHIFT 23
36
+#define SYSDIV_LENGTH 4
37
+
77
+
38
static void test_watchdog(void)
78
+
39
{
79
+static bool trans_ZERO(DisasContext *s, arg_ZERO *a)
40
g_assert_cmpuint(readl(WDOG_BASE + WDOGRIS), ==, 0);
41
@@ -XXX,XX +XXX,XX @@ static void test_watchdog(void)
42
g_assert_cmpuint(readl(WDOG_BASE + WDOGRIS), ==, 0);
43
}
44
45
+static void test_clock_change(void)
46
+{
80
+{
47
+ uint32_t rcc;
81
+ if (!dc_isar_feature(aa64_sme, s)) {
48
+
82
+ return false;
49
+ /*
83
+ }
50
+ * Test that writing to the stellaris board's RCC register to
84
+ if (sme_za_enabled_check(s)) {
51
+ * change the system clock frequency causes the watchdog
85
+ gen_helper_sme_zero(cpu_env, tcg_constant_i32(a->imm),
52
+ * to change the speed it counts at.
86
+ tcg_constant_i32(streaming_vec_reg_size(s)));
53
+ */
87
+ }
54
+ g_assert_cmpuint(readl(WDOG_BASE + WDOGRIS), ==, 0);
88
+ return true;
55
+
56
+ writel(WDOG_BASE + WDOGCONTROL, 1);
57
+ writel(WDOG_BASE + WDOGLOAD, 1000);
58
+
59
+ /* Step to just past the 500th tick */
60
+ clock_step(80 * 500 + 1);
61
+ g_assert_cmpuint(readl(WDOG_BASE + WDOGRIS), ==, 0);
62
+ g_assert_cmpuint(readl(WDOG_BASE + WDOGVALUE), ==, 500);
63
+
64
+ /* Rewrite RCC.SYSDIV from 16 to 8, so the clock is now 40ns per tick */
65
+ rcc = readl(SSYS_BASE + RCC);
66
+ g_assert_cmpuint(extract32(rcc, SYSDIV_SHIFT, SYSDIV_LENGTH), ==, 0xf);
67
+ rcc = deposit32(rcc, SYSDIV_SHIFT, SYSDIV_LENGTH, 7);
68
+ writel(SSYS_BASE + RCC, rcc);
69
+
70
+ /* Just past the 1000th tick: timer should have fired */
71
+ clock_step(40 * 500);
72
+ g_assert_cmpuint(readl(WDOG_BASE + WDOGRIS), ==, 1);
73
+
74
+ g_assert_cmpuint(readl(WDOG_BASE + WDOGVALUE), ==, 0);
75
+
76
+ /* VALUE reloads at following tick */
77
+ clock_step(41);
78
+ g_assert_cmpuint(readl(WDOG_BASE + WDOGVALUE), ==, 1000);
79
+
80
+ /* Writing any value to WDOGINTCLR clears the interrupt and reloads */
81
+ clock_step(40 * 500);
82
+ g_assert_cmpuint(readl(WDOG_BASE + WDOGVALUE), ==, 500);
83
+ g_assert_cmpuint(readl(WDOG_BASE + WDOGRIS), ==, 1);
84
+ writel(WDOG_BASE + WDOGINTCLR, 0);
85
+ g_assert_cmpuint(readl(WDOG_BASE + WDOGVALUE), ==, 1000);
86
+ g_assert_cmpuint(readl(WDOG_BASE + WDOGRIS), ==, 0);
87
+}
89
+}
88
+
89
int main(int argc, char **argv)
90
{
91
int r;
92
@@ -XXX,XX +XXX,XX @@ int main(int argc, char **argv)
93
qtest_start("-machine lm3s811evb");
94
95
qtest_add_func("/cmsdk-apb-watchdog/watchdog", test_watchdog);
96
+ qtest_add_func("/cmsdk-apb-watchdog/watchdog_clock_change",
97
+ test_clock_change);
98
99
r = g_test_run();
100
101
--
90
--
102
2.20.1
91
2.25.1
103
104
diff view generated by jsdifflib
1
As the first step in converting the CMSDK_APB_TIMER device to the
1
From: Richard Henderson <richard.henderson@linaro.org>
2
Clock framework, add a Clock input. For the moment we do nothing
3
with this clock; we will change the behaviour from using the
4
wdogclk-frq property to using the Clock once all the users of this
5
device have been converted to wire up the Clock.
6
2
7
This is a migration compatibility break for machines mps2-an385,
3
We can reuse the SVE functions for implementing moves to/from
8
mps2-an386, mps2-an500, mps2-an511, mps2-an505, mps2-an521, musca-a,
4
horizontal tile slices, but we need new ones for moves to/from
9
musca-b1, lm3s811evb, lm3s6965evb.
5
vertical tile slices.
10
6
7
Reviewed-by: Peter Maydell <peter.maydell@linaro.org>
8
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
9
Message-id: 20220708151540.18136-20-richard.henderson@linaro.org
11
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
10
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
12
Reviewed-by: Philippe Mathieu-Daudé <f4bug@amsat.org>
13
Reviewed-by: Luc Michel <luc@lmichel.fr>
14
Tested-by: Philippe Mathieu-Daudé <f4bug@amsat.org>
15
Message-id: 20210128114145.20536-10-peter.maydell@linaro.org
16
Message-id: 20210121190622.22000-10-peter.maydell@linaro.org
17
---
11
---
18
include/hw/watchdog/cmsdk-apb-watchdog.h | 3 +++
12
target/arm/helper-sme.h | 12 +++
19
hw/watchdog/cmsdk-apb-watchdog.c | 7 +++++--
13
target/arm/helper-sve.h | 2 +
20
2 files changed, 8 insertions(+), 2 deletions(-)
14
target/arm/translate-a64.h | 8 ++
15
target/arm/translate.h | 5 ++
16
target/arm/sme.decode | 15 ++++
17
target/arm/sme_helper.c | 151 ++++++++++++++++++++++++++++++++++++-
18
target/arm/sve_helper.c | 12 +++
19
target/arm/translate-sme.c | 127 +++++++++++++++++++++++++++++++
20
8 files changed, 331 insertions(+), 1 deletion(-)
21
21
22
diff --git a/include/hw/watchdog/cmsdk-apb-watchdog.h b/include/hw/watchdog/cmsdk-apb-watchdog.h
22
diff --git a/target/arm/helper-sme.h b/target/arm/helper-sme.h
23
index XXXXXXX..XXXXXXX 100644
23
index XXXXXXX..XXXXXXX 100644
24
--- a/include/hw/watchdog/cmsdk-apb-watchdog.h
24
--- a/target/arm/helper-sme.h
25
+++ b/include/hw/watchdog/cmsdk-apb-watchdog.h
25
+++ b/target/arm/helper-sme.h
26
@@ -XXX,XX +XXX,XX @@ DEF_HELPER_FLAGS_2(set_pstate_sm, TCG_CALL_NO_RWG, void, env, i32)
27
DEF_HELPER_FLAGS_2(set_pstate_za, TCG_CALL_NO_RWG, void, env, i32)
28
29
DEF_HELPER_FLAGS_3(sme_zero, TCG_CALL_NO_RWG, void, env, i32, i32)
30
+
31
+/* Move to/from vertical array slices, i.e. columns, so 'c'. */
32
+DEF_HELPER_FLAGS_4(sme_mova_cz_b, TCG_CALL_NO_RWG, void, ptr, ptr, ptr, i32)
33
+DEF_HELPER_FLAGS_4(sme_mova_zc_b, TCG_CALL_NO_RWG, void, ptr, ptr, ptr, i32)
34
+DEF_HELPER_FLAGS_4(sme_mova_cz_h, TCG_CALL_NO_RWG, void, ptr, ptr, ptr, i32)
35
+DEF_HELPER_FLAGS_4(sme_mova_zc_h, TCG_CALL_NO_RWG, void, ptr, ptr, ptr, i32)
36
+DEF_HELPER_FLAGS_4(sme_mova_cz_s, TCG_CALL_NO_RWG, void, ptr, ptr, ptr, i32)
37
+DEF_HELPER_FLAGS_4(sme_mova_zc_s, TCG_CALL_NO_RWG, void, ptr, ptr, ptr, i32)
38
+DEF_HELPER_FLAGS_4(sme_mova_cz_d, TCG_CALL_NO_RWG, void, ptr, ptr, ptr, i32)
39
+DEF_HELPER_FLAGS_4(sme_mova_zc_d, TCG_CALL_NO_RWG, void, ptr, ptr, ptr, i32)
40
+DEF_HELPER_FLAGS_4(sme_mova_cz_q, TCG_CALL_NO_RWG, void, ptr, ptr, ptr, i32)
41
+DEF_HELPER_FLAGS_4(sme_mova_zc_q, TCG_CALL_NO_RWG, void, ptr, ptr, ptr, i32)
42
diff --git a/target/arm/helper-sve.h b/target/arm/helper-sve.h
43
index XXXXXXX..XXXXXXX 100644
44
--- a/target/arm/helper-sve.h
45
+++ b/target/arm/helper-sve.h
46
@@ -XXX,XX +XXX,XX @@ DEF_HELPER_FLAGS_5(sve_sel_zpzz_s, TCG_CALL_NO_RWG,
47
void, ptr, ptr, ptr, ptr, i32)
48
DEF_HELPER_FLAGS_5(sve_sel_zpzz_d, TCG_CALL_NO_RWG,
49
void, ptr, ptr, ptr, ptr, i32)
50
+DEF_HELPER_FLAGS_5(sve_sel_zpzz_q, TCG_CALL_NO_RWG,
51
+ void, ptr, ptr, ptr, ptr, i32)
52
53
DEF_HELPER_FLAGS_5(sve2_addp_zpzz_b, TCG_CALL_NO_RWG,
54
void, ptr, ptr, ptr, ptr, i32)
55
diff --git a/target/arm/translate-a64.h b/target/arm/translate-a64.h
56
index XXXXXXX..XXXXXXX 100644
57
--- a/target/arm/translate-a64.h
58
+++ b/target/arm/translate-a64.h
59
@@ -XXX,XX +XXX,XX @@ static inline int pred_gvec_reg_size(DisasContext *s)
60
return size_for_gvec(pred_full_reg_size(s));
61
}
62
63
+/* Return a newly allocated pointer to the predicate register. */
64
+static inline TCGv_ptr pred_full_reg_ptr(DisasContext *s, int regno)
65
+{
66
+ TCGv_ptr ret = tcg_temp_new_ptr();
67
+ tcg_gen_addi_ptr(ret, cpu_env, pred_full_reg_offset(s, regno));
68
+ return ret;
69
+}
70
+
71
bool disas_sve(DisasContext *, uint32_t);
72
bool disas_sme(DisasContext *, uint32_t);
73
74
diff --git a/target/arm/translate.h b/target/arm/translate.h
75
index XXXXXXX..XXXXXXX 100644
76
--- a/target/arm/translate.h
77
+++ b/target/arm/translate.h
78
@@ -XXX,XX +XXX,XX @@ static inline int plus_2(DisasContext *s, int x)
79
return x + 2;
80
}
81
82
+static inline int plus_12(DisasContext *s, int x)
83
+{
84
+ return x + 12;
85
+}
86
+
87
static inline int times_2(DisasContext *s, int x)
88
{
89
return x * 2;
90
diff --git a/target/arm/sme.decode b/target/arm/sme.decode
91
index XXXXXXX..XXXXXXX 100644
92
--- a/target/arm/sme.decode
93
+++ b/target/arm/sme.decode
26
@@ -XXX,XX +XXX,XX @@
94
@@ -XXX,XX +XXX,XX @@
27
*
95
### SME Misc
28
* QEMU interface:
96
29
* + QOM property "wdogclk-frq": frequency at which the watchdog is clocked
97
ZERO 11000000 00 001 00000000000 imm:8
30
+ * + Clock input "WDOGCLK": clock for the watchdog's timer
98
+
31
* + sysbus MMIO region 0: the register bank
99
+### SME Move into/from Array
32
* + sysbus IRQ 0: watchdog interrupt
100
+
33
*
101
+%mova_rs 13:2 !function=plus_12
102
+&mova esz rs pg zr za_imm v:bool to_vec:bool
103
+
104
+MOVA 11000000 esz:2 00000 0 v:1 .. pg:3 zr:5 0 za_imm:4 \
105
+ &mova to_vec=0 rs=%mova_rs
106
+MOVA 11000000 11 00000 1 v:1 .. pg:3 zr:5 0 za_imm:4 \
107
+ &mova to_vec=0 rs=%mova_rs esz=4
108
+
109
+MOVA 11000000 esz:2 00001 0 v:1 .. pg:3 0 za_imm:4 zr:5 \
110
+ &mova to_vec=1 rs=%mova_rs
111
+MOVA 11000000 11 00001 1 v:1 .. pg:3 0 za_imm:4 zr:5 \
112
+ &mova to_vec=1 rs=%mova_rs esz=4
113
diff --git a/target/arm/sme_helper.c b/target/arm/sme_helper.c
114
index XXXXXXX..XXXXXXX 100644
115
--- a/target/arm/sme_helper.c
116
+++ b/target/arm/sme_helper.c
34
@@ -XXX,XX +XXX,XX @@
117
@@ -XXX,XX +XXX,XX @@
35
118
36
#include "hw/sysbus.h"
119
#include "qemu/osdep.h"
37
#include "hw/ptimer.h"
120
#include "cpu.h"
38
+#include "hw/clock.h"
121
-#include "internals.h"
39
#include "qom/object.h"
122
+#include "tcg/tcg-gvec-desc.h"
40
123
#include "exec/helper-proto.h"
41
#define TYPE_CMSDK_APB_WATCHDOG "cmsdk-apb-watchdog"
124
+#include "qemu/int128.h"
42
@@ -XXX,XX +XXX,XX @@ struct CMSDKAPBWatchdog {
125
+#include "vec_internal.h"
43
uint32_t wdogclk_frq;
126
44
bool is_luminary;
127
/* ResetSVEState */
45
struct ptimer_state *timer;
128
void arm_reset_sve_state(CPUARMState *env)
46
+ Clock *wdogclk;
129
@@ -XXX,XX +XXX,XX @@ void helper_sme_zero(CPUARMState *env, uint32_t imm, uint32_t svl)
47
130
}
48
uint32_t control;
131
}
49
uint32_t intstatus;
132
}
50
diff --git a/hw/watchdog/cmsdk-apb-watchdog.c b/hw/watchdog/cmsdk-apb-watchdog.c
133
+
51
index XXXXXXX..XXXXXXX 100644
134
+
52
--- a/hw/watchdog/cmsdk-apb-watchdog.c
135
+/*
53
+++ b/hw/watchdog/cmsdk-apb-watchdog.c
136
+ * When considering the ZA storage as an array of elements of
137
+ * type T, the index within that array of the Nth element of
138
+ * a vertical slice of a tile can be calculated like this,
139
+ * regardless of the size of type T. This is because the tiles
140
+ * are interleaved, so if type T is size N bytes then row 1 of
141
+ * the tile is N rows away from row 0. The division by N to
142
+ * convert a byte offset into an array index and the multiplication
143
+ * by N to convert from vslice-index-within-the-tile to
144
+ * the index within the ZA storage cancel out.
145
+ */
146
+#define tile_vslice_index(i) ((i) * sizeof(ARMVectorReg))
147
+
148
+/*
149
+ * When doing byte arithmetic on the ZA storage, the element
150
+ * byteoff bytes away in a tile vertical slice is always this
151
+ * many bytes away in the ZA storage, regardless of the
152
+ * size of the tile element, assuming that byteoff is a multiple
153
+ * of the element size. Again this is because of the interleaving
154
+ * of the tiles. For instance if we have 1 byte per element then
155
+ * each row of the ZA storage has one byte of the vslice data,
156
+ * and (counting from 0) byte 8 goes in row 8 of the storage
157
+ * at offset (8 * row-size-in-bytes).
158
+ * If we have 8 bytes per element then each row of the ZA storage
159
+ * has 8 bytes of the data, but there are 8 interleaved tiles and
160
+ * so byte 8 of the data goes into row 1 of the tile,
161
+ * which is again row 8 of the storage, so the offset is still
162
+ * (8 * row-size-in-bytes). Similarly for other element sizes.
163
+ */
164
+#define tile_vslice_offset(byteoff) ((byteoff) * sizeof(ARMVectorReg))
165
+
166
+
167
+/*
168
+ * Move Zreg vector to ZArray column.
169
+ */
170
+#define DO_MOVA_C(NAME, TYPE, H) \
171
+void HELPER(NAME)(void *za, void *vn, void *vg, uint32_t desc) \
172
+{ \
173
+ int i, oprsz = simd_oprsz(desc); \
174
+ for (i = 0; i < oprsz; ) { \
175
+ uint16_t pg = *(uint16_t *)(vg + H1_2(i >> 3)); \
176
+ do { \
177
+ if (pg & 1) { \
178
+ *(TYPE *)(za + tile_vslice_offset(i)) = *(TYPE *)(vn + H(i)); \
179
+ } \
180
+ i += sizeof(TYPE); \
181
+ pg >>= sizeof(TYPE); \
182
+ } while (i & 15); \
183
+ } \
184
+}
185
+
186
+DO_MOVA_C(sme_mova_cz_b, uint8_t, H1)
187
+DO_MOVA_C(sme_mova_cz_h, uint16_t, H1_2)
188
+DO_MOVA_C(sme_mova_cz_s, uint32_t, H1_4)
189
+
190
+void HELPER(sme_mova_cz_d)(void *za, void *vn, void *vg, uint32_t desc)
191
+{
192
+ int i, oprsz = simd_oprsz(desc) / 8;
193
+ uint8_t *pg = vg;
194
+ uint64_t *n = vn;
195
+ uint64_t *a = za;
196
+
197
+ for (i = 0; i < oprsz; i++) {
198
+ if (pg[H1(i)] & 1) {
199
+ a[tile_vslice_index(i)] = n[i];
200
+ }
201
+ }
202
+}
203
+
204
+void HELPER(sme_mova_cz_q)(void *za, void *vn, void *vg, uint32_t desc)
205
+{
206
+ int i, oprsz = simd_oprsz(desc) / 16;
207
+ uint16_t *pg = vg;
208
+ Int128 *n = vn;
209
+ Int128 *a = za;
210
+
211
+ /*
212
+ * Int128 is used here simply to copy 16 bytes, and to simplify
213
+ * the address arithmetic.
214
+ */
215
+ for (i = 0; i < oprsz; i++) {
216
+ if (pg[H2(i)] & 1) {
217
+ a[tile_vslice_index(i)] = n[i];
218
+ }
219
+ }
220
+}
221
+
222
+#undef DO_MOVA_C
223
+
224
+/*
225
+ * Move ZArray column to Zreg vector.
226
+ */
227
+#define DO_MOVA_Z(NAME, TYPE, H) \
228
+void HELPER(NAME)(void *vd, void *za, void *vg, uint32_t desc) \
229
+{ \
230
+ int i, oprsz = simd_oprsz(desc); \
231
+ for (i = 0; i < oprsz; ) { \
232
+ uint16_t pg = *(uint16_t *)(vg + H1_2(i >> 3)); \
233
+ do { \
234
+ if (pg & 1) { \
235
+ *(TYPE *)(vd + H(i)) = *(TYPE *)(za + tile_vslice_offset(i)); \
236
+ } \
237
+ i += sizeof(TYPE); \
238
+ pg >>= sizeof(TYPE); \
239
+ } while (i & 15); \
240
+ } \
241
+}
242
+
243
+DO_MOVA_Z(sme_mova_zc_b, uint8_t, H1)
244
+DO_MOVA_Z(sme_mova_zc_h, uint16_t, H1_2)
245
+DO_MOVA_Z(sme_mova_zc_s, uint32_t, H1_4)
246
+
247
+void HELPER(sme_mova_zc_d)(void *vd, void *za, void *vg, uint32_t desc)
248
+{
249
+ int i, oprsz = simd_oprsz(desc) / 8;
250
+ uint8_t *pg = vg;
251
+ uint64_t *d = vd;
252
+ uint64_t *a = za;
253
+
254
+ for (i = 0; i < oprsz; i++) {
255
+ if (pg[H1(i)] & 1) {
256
+ d[i] = a[tile_vslice_index(i)];
257
+ }
258
+ }
259
+}
260
+
261
+void HELPER(sme_mova_zc_q)(void *vd, void *za, void *vg, uint32_t desc)
262
+{
263
+ int i, oprsz = simd_oprsz(desc) / 16;
264
+ uint16_t *pg = vg;
265
+ Int128 *d = vd;
266
+ Int128 *a = za;
267
+
268
+ /*
269
+ * Int128 is used here simply to copy 16 bytes, and to simplify
270
+ * the address arithmetic.
271
+ */
272
+ for (i = 0; i < oprsz; i++, za += sizeof(ARMVectorReg)) {
273
+ if (pg[H2(i)] & 1) {
274
+ d[i] = a[tile_vslice_index(i)];
275
+ }
276
+ }
277
+}
278
+
279
+#undef DO_MOVA_Z
280
diff --git a/target/arm/sve_helper.c b/target/arm/sve_helper.c
281
index XXXXXXX..XXXXXXX 100644
282
--- a/target/arm/sve_helper.c
283
+++ b/target/arm/sve_helper.c
284
@@ -XXX,XX +XXX,XX @@ void HELPER(sve_sel_zpzz_d)(void *vd, void *vn, void *vm,
285
}
286
}
287
288
+void HELPER(sve_sel_zpzz_q)(void *vd, void *vn, void *vm,
289
+ void *vg, uint32_t desc)
290
+{
291
+ intptr_t i, opr_sz = simd_oprsz(desc) / 16;
292
+ Int128 *d = vd, *n = vn, *m = vm;
293
+ uint16_t *pg = vg;
294
+
295
+ for (i = 0; i < opr_sz; i += 1) {
296
+ d[i] = (pg[H2(i)] & 1 ? n : m)[i];
297
+ }
298
+}
299
+
300
/* Two operand comparison controlled by a predicate.
301
* ??? It is very tempting to want to be able to expand this inline
302
* with x86 instructions, e.g.
303
diff --git a/target/arm/translate-sme.c b/target/arm/translate-sme.c
304
index XXXXXXX..XXXXXXX 100644
305
--- a/target/arm/translate-sme.c
306
+++ b/target/arm/translate-sme.c
54
@@ -XXX,XX +XXX,XX @@
307
@@ -XXX,XX +XXX,XX @@
55
#include "hw/irq.h"
308
#include "decode-sme.c.inc"
56
#include "hw/qdev-properties.h"
309
57
#include "hw/registerfields.h"
310
58
+#include "hw/qdev-clock.h"
311
+/*
59
#include "hw/watchdog/cmsdk-apb-watchdog.h"
312
+ * Resolve tile.size[index] to a host pointer, where tile and index
60
#include "migration/vmstate.h"
313
+ * are always decoded together, dependent on the element size.
61
314
+ */
62
@@ -XXX,XX +XXX,XX @@ static void cmsdk_apb_watchdog_init(Object *obj)
315
+static TCGv_ptr get_tile_rowcol(DisasContext *s, int esz, int rs,
63
s, "cmsdk-apb-watchdog", 0x1000);
316
+ int tile_index, bool vertical)
64
sysbus_init_mmio(sbd, &s->iomem);
317
+{
65
sysbus_init_irq(sbd, &s->wdogint);
318
+ int tile = tile_index >> (4 - esz);
66
+ s->wdogclk = qdev_init_clock_in(DEVICE(s), "WDOGCLK", NULL, NULL);
319
+ int index = esz == MO_128 ? 0 : extract32(tile_index, 0, 4 - esz);
67
320
+ int pos, len, offset;
68
s->is_luminary = false;
321
+ TCGv_i32 tmp;
69
s->id = cmsdk_apb_watchdog_id;
322
+ TCGv_ptr addr;
70
@@ -XXX,XX +XXX,XX @@ static void cmsdk_apb_watchdog_realize(DeviceState *dev, Error **errp)
323
+
71
324
+ /* Compute the final index, which is Rs+imm. */
72
static const VMStateDescription cmsdk_apb_watchdog_vmstate = {
325
+ tmp = tcg_temp_new_i32();
73
.name = "cmsdk-apb-watchdog",
326
+ tcg_gen_trunc_tl_i32(tmp, cpu_reg(s, rs));
74
- .version_id = 1,
327
+ tcg_gen_addi_i32(tmp, tmp, index);
75
- .minimum_version_id = 1,
328
+
76
+ .version_id = 2,
329
+ /* Prepare a power-of-two modulo via extraction of @len bits. */
77
+ .minimum_version_id = 2,
330
+ len = ctz32(streaming_vec_reg_size(s)) - esz;
78
.fields = (VMStateField[]) {
331
+
79
+ VMSTATE_CLOCK(wdogclk, CMSDKAPBWatchdog),
332
+ if (vertical) {
80
VMSTATE_PTIMER(timer, CMSDKAPBWatchdog),
333
+ /*
81
VMSTATE_UINT32(control, CMSDKAPBWatchdog),
334
+ * Compute the byte offset of the index within the tile:
82
VMSTATE_UINT32(intstatus, CMSDKAPBWatchdog),
335
+ * (index % (svl / size)) * size
336
+ * = (index % (svl >> esz)) << esz
337
+ * Perform the power-of-two modulo via extraction of the low @len bits.
338
+ * Perform the multiply by shifting left by @pos bits.
339
+ * Perform these operations simultaneously via deposit into zero.
340
+ */
341
+ pos = esz;
342
+ tcg_gen_deposit_z_i32(tmp, tmp, pos, len);
343
+
344
+ /*
345
+ * For big-endian, adjust the indexed column byte offset within
346
+ * the uint64_t host words that make up env->zarray[].
347
+ */
348
+ if (HOST_BIG_ENDIAN && esz < MO_64) {
349
+ tcg_gen_xori_i32(tmp, tmp, 8 - (1 << esz));
350
+ }
351
+ } else {
352
+ /*
353
+ * Compute the byte offset of the index within the tile:
354
+ * (index % (svl / size)) * (size * sizeof(row))
355
+ * = (index % (svl >> esz)) << (esz + log2(sizeof(row)))
356
+ */
357
+ pos = esz + ctz32(sizeof(ARMVectorReg));
358
+ tcg_gen_deposit_z_i32(tmp, tmp, pos, len);
359
+
360
+ /* Row slices are always aligned and need no endian adjustment. */
361
+ }
362
+
363
+ /* The tile byte offset within env->zarray is the row. */
364
+ offset = tile * sizeof(ARMVectorReg);
365
+
366
+ /* Include the byte offset of zarray to make this relative to env. */
367
+ offset += offsetof(CPUARMState, zarray);
368
+ tcg_gen_addi_i32(tmp, tmp, offset);
369
+
370
+ /* Add the byte offset to env to produce the final pointer. */
371
+ addr = tcg_temp_new_ptr();
372
+ tcg_gen_ext_i32_ptr(addr, tmp);
373
+ tcg_temp_free_i32(tmp);
374
+ tcg_gen_add_ptr(addr, addr, cpu_env);
375
+
376
+ return addr;
377
+}
378
+
379
static bool trans_ZERO(DisasContext *s, arg_ZERO *a)
380
{
381
if (!dc_isar_feature(aa64_sme, s)) {
382
@@ -XXX,XX +XXX,XX @@ static bool trans_ZERO(DisasContext *s, arg_ZERO *a)
383
}
384
return true;
385
}
386
+
387
+static bool trans_MOVA(DisasContext *s, arg_MOVA *a)
388
+{
389
+ static gen_helper_gvec_4 * const h_fns[5] = {
390
+ gen_helper_sve_sel_zpzz_b, gen_helper_sve_sel_zpzz_h,
391
+ gen_helper_sve_sel_zpzz_s, gen_helper_sve_sel_zpzz_d,
392
+ gen_helper_sve_sel_zpzz_q
393
+ };
394
+ static gen_helper_gvec_3 * const cz_fns[5] = {
395
+ gen_helper_sme_mova_cz_b, gen_helper_sme_mova_cz_h,
396
+ gen_helper_sme_mova_cz_s, gen_helper_sme_mova_cz_d,
397
+ gen_helper_sme_mova_cz_q,
398
+ };
399
+ static gen_helper_gvec_3 * const zc_fns[5] = {
400
+ gen_helper_sme_mova_zc_b, gen_helper_sme_mova_zc_h,
401
+ gen_helper_sme_mova_zc_s, gen_helper_sme_mova_zc_d,
402
+ gen_helper_sme_mova_zc_q,
403
+ };
404
+
405
+ TCGv_ptr t_za, t_zr, t_pg;
406
+ TCGv_i32 t_desc;
407
+ int svl;
408
+
409
+ if (!dc_isar_feature(aa64_sme, s)) {
410
+ return false;
411
+ }
412
+ if (!sme_smza_enabled_check(s)) {
413
+ return true;
414
+ }
415
+
416
+ t_za = get_tile_rowcol(s, a->esz, a->rs, a->za_imm, a->v);
417
+ t_zr = vec_full_reg_ptr(s, a->zr);
418
+ t_pg = pred_full_reg_ptr(s, a->pg);
419
+
420
+ svl = streaming_vec_reg_size(s);
421
+ t_desc = tcg_constant_i32(simd_desc(svl, svl, 0));
422
+
423
+ if (a->v) {
424
+ /* Vertical slice -- use sme mova helpers. */
425
+ if (a->to_vec) {
426
+ zc_fns[a->esz](t_zr, t_za, t_pg, t_desc);
427
+ } else {
428
+ cz_fns[a->esz](t_za, t_zr, t_pg, t_desc);
429
+ }
430
+ } else {
431
+ /* Horizontal slice -- reuse sve sel helpers. */
432
+ if (a->to_vec) {
433
+ h_fns[a->esz](t_zr, t_za, t_zr, t_pg, t_desc);
434
+ } else {
435
+ h_fns[a->esz](t_za, t_zr, t_za, t_pg, t_desc);
436
+ }
437
+ }
438
+
439
+ tcg_temp_free_ptr(t_za);
440
+ tcg_temp_free_ptr(t_zr);
441
+ tcg_temp_free_ptr(t_pg);
442
+
443
+ return true;
444
+}
83
--
445
--
84
2.20.1
446
2.25.1
85
86
diff view generated by jsdifflib
1
From: Mihai Carabas <mihai.carabas@oracle.com>
1
From: Richard Henderson <richard.henderson@linaro.org>
2
2
3
To ease the PCI device addition in next patches, split the code as follows:
3
We cannot reuse the SVE functions for LD[1-4] and ST[1-4],
4
- generic code (read/write/setup) is being kept in pvpanic.c
4
because those functions accept only a Zreg register number.
5
- ISA dependent code moved to pvpanic-isa.c
5
For SME, we want to pass a pointer into ZA storage.
6
6
7
Also, rename:
8
- ISA_PVPANIC_DEVICE -> PVPANIC_ISA_DEVICE.
9
- TYPE_PVPANIC -> TYPE_PVPANIC_ISA.
10
- MemoryRegion io -> mr.
11
- pvpanic_ioport_* in pvpanic_*.
12
13
Update the build system with the new files and config structure.
14
15
Signed-off-by: Mihai Carabas <mihai.carabas@oracle.com>
16
Reviewed-by: Peter Maydell <peter.maydell@linaro.org>
7
Reviewed-by: Peter Maydell <peter.maydell@linaro.org>
8
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
9
Message-id: 20220708151540.18136-21-richard.henderson@linaro.org
17
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
10
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
18
---
11
---
19
include/hw/misc/pvpanic.h | 23 +++++++++-
12
target/arm/helper-sme.h | 82 +++++
20
hw/misc/pvpanic-isa.c | 94 +++++++++++++++++++++++++++++++++++++++
13
target/arm/sme.decode | 9 +
21
hw/misc/pvpanic.c | 85 +++--------------------------------
14
target/arm/sme_helper.c | 595 +++++++++++++++++++++++++++++++++++++
22
hw/i386/Kconfig | 2 +-
15
target/arm/translate-sme.c | 70 +++++
23
hw/misc/Kconfig | 6 ++-
16
4 files changed, 756 insertions(+)
24
hw/misc/meson.build | 3 +-
25
tests/qtest/meson.build | 2 +-
26
7 files changed, 130 insertions(+), 85 deletions(-)
27
create mode 100644 hw/misc/pvpanic-isa.c
28
17
29
diff --git a/include/hw/misc/pvpanic.h b/include/hw/misc/pvpanic.h
18
diff --git a/target/arm/helper-sme.h b/target/arm/helper-sme.h
30
index XXXXXXX..XXXXXXX 100644
19
index XXXXXXX..XXXXXXX 100644
31
--- a/include/hw/misc/pvpanic.h
20
--- a/target/arm/helper-sme.h
32
+++ b/include/hw/misc/pvpanic.h
21
+++ b/target/arm/helper-sme.h
22
@@ -XXX,XX +XXX,XX @@ DEF_HELPER_FLAGS_4(sme_mova_cz_d, TCG_CALL_NO_RWG, void, ptr, ptr, ptr, i32)
23
DEF_HELPER_FLAGS_4(sme_mova_zc_d, TCG_CALL_NO_RWG, void, ptr, ptr, ptr, i32)
24
DEF_HELPER_FLAGS_4(sme_mova_cz_q, TCG_CALL_NO_RWG, void, ptr, ptr, ptr, i32)
25
DEF_HELPER_FLAGS_4(sme_mova_zc_q, TCG_CALL_NO_RWG, void, ptr, ptr, ptr, i32)
26
+
27
+DEF_HELPER_FLAGS_5(sme_ld1b_h, TCG_CALL_NO_WG, void, env, ptr, ptr, tl, i32)
28
+DEF_HELPER_FLAGS_5(sme_ld1b_v, TCG_CALL_NO_WG, void, env, ptr, ptr, tl, i32)
29
+DEF_HELPER_FLAGS_5(sme_ld1b_h_mte, TCG_CALL_NO_WG, void, env, ptr, ptr, tl, i32)
30
+DEF_HELPER_FLAGS_5(sme_ld1b_v_mte, TCG_CALL_NO_WG, void, env, ptr, ptr, tl, i32)
31
+
32
+DEF_HELPER_FLAGS_5(sme_ld1h_be_h, TCG_CALL_NO_WG, void, env, ptr, ptr, tl, i32)
33
+DEF_HELPER_FLAGS_5(sme_ld1h_le_h, TCG_CALL_NO_WG, void, env, ptr, ptr, tl, i32)
34
+DEF_HELPER_FLAGS_5(sme_ld1h_be_v, TCG_CALL_NO_WG, void, env, ptr, ptr, tl, i32)
35
+DEF_HELPER_FLAGS_5(sme_ld1h_le_v, TCG_CALL_NO_WG, void, env, ptr, ptr, tl, i32)
36
+DEF_HELPER_FLAGS_5(sme_ld1h_be_h_mte, TCG_CALL_NO_WG, void, env, ptr, ptr, tl, i32)
37
+DEF_HELPER_FLAGS_5(sme_ld1h_le_h_mte, TCG_CALL_NO_WG, void, env, ptr, ptr, tl, i32)
38
+DEF_HELPER_FLAGS_5(sme_ld1h_be_v_mte, TCG_CALL_NO_WG, void, env, ptr, ptr, tl, i32)
39
+DEF_HELPER_FLAGS_5(sme_ld1h_le_v_mte, TCG_CALL_NO_WG, void, env, ptr, ptr, tl, i32)
40
+
41
+DEF_HELPER_FLAGS_5(sme_ld1s_be_h, TCG_CALL_NO_WG, void, env, ptr, ptr, tl, i32)
42
+DEF_HELPER_FLAGS_5(sme_ld1s_le_h, TCG_CALL_NO_WG, void, env, ptr, ptr, tl, i32)
43
+DEF_HELPER_FLAGS_5(sme_ld1s_be_v, TCG_CALL_NO_WG, void, env, ptr, ptr, tl, i32)
44
+DEF_HELPER_FLAGS_5(sme_ld1s_le_v, TCG_CALL_NO_WG, void, env, ptr, ptr, tl, i32)
45
+DEF_HELPER_FLAGS_5(sme_ld1s_be_h_mte, TCG_CALL_NO_WG, void, env, ptr, ptr, tl, i32)
46
+DEF_HELPER_FLAGS_5(sme_ld1s_le_h_mte, TCG_CALL_NO_WG, void, env, ptr, ptr, tl, i32)
47
+DEF_HELPER_FLAGS_5(sme_ld1s_be_v_mte, TCG_CALL_NO_WG, void, env, ptr, ptr, tl, i32)
48
+DEF_HELPER_FLAGS_5(sme_ld1s_le_v_mte, TCG_CALL_NO_WG, void, env, ptr, ptr, tl, i32)
49
+
50
+DEF_HELPER_FLAGS_5(sme_ld1d_be_h, TCG_CALL_NO_WG, void, env, ptr, ptr, tl, i32)
51
+DEF_HELPER_FLAGS_5(sme_ld1d_le_h, TCG_CALL_NO_WG, void, env, ptr, ptr, tl, i32)
52
+DEF_HELPER_FLAGS_5(sme_ld1d_be_v, TCG_CALL_NO_WG, void, env, ptr, ptr, tl, i32)
53
+DEF_HELPER_FLAGS_5(sme_ld1d_le_v, TCG_CALL_NO_WG, void, env, ptr, ptr, tl, i32)
54
+DEF_HELPER_FLAGS_5(sme_ld1d_be_h_mte, TCG_CALL_NO_WG, void, env, ptr, ptr, tl, i32)
55
+DEF_HELPER_FLAGS_5(sme_ld1d_le_h_mte, TCG_CALL_NO_WG, void, env, ptr, ptr, tl, i32)
56
+DEF_HELPER_FLAGS_5(sme_ld1d_be_v_mte, TCG_CALL_NO_WG, void, env, ptr, ptr, tl, i32)
57
+DEF_HELPER_FLAGS_5(sme_ld1d_le_v_mte, TCG_CALL_NO_WG, void, env, ptr, ptr, tl, i32)
58
+
59
+DEF_HELPER_FLAGS_5(sme_ld1q_be_h, TCG_CALL_NO_WG, void, env, ptr, ptr, tl, i32)
60
+DEF_HELPER_FLAGS_5(sme_ld1q_le_h, TCG_CALL_NO_WG, void, env, ptr, ptr, tl, i32)
61
+DEF_HELPER_FLAGS_5(sme_ld1q_be_v, TCG_CALL_NO_WG, void, env, ptr, ptr, tl, i32)
62
+DEF_HELPER_FLAGS_5(sme_ld1q_le_v, TCG_CALL_NO_WG, void, env, ptr, ptr, tl, i32)
63
+DEF_HELPER_FLAGS_5(sme_ld1q_be_h_mte, TCG_CALL_NO_WG, void, env, ptr, ptr, tl, i32)
64
+DEF_HELPER_FLAGS_5(sme_ld1q_le_h_mte, TCG_CALL_NO_WG, void, env, ptr, ptr, tl, i32)
65
+DEF_HELPER_FLAGS_5(sme_ld1q_be_v_mte, TCG_CALL_NO_WG, void, env, ptr, ptr, tl, i32)
66
+DEF_HELPER_FLAGS_5(sme_ld1q_le_v_mte, TCG_CALL_NO_WG, void, env, ptr, ptr, tl, i32)
67
+
68
+DEF_HELPER_FLAGS_5(sme_st1b_h, TCG_CALL_NO_WG, void, env, ptr, ptr, tl, i32)
69
+DEF_HELPER_FLAGS_5(sme_st1b_v, TCG_CALL_NO_WG, void, env, ptr, ptr, tl, i32)
70
+DEF_HELPER_FLAGS_5(sme_st1b_h_mte, TCG_CALL_NO_WG, void, env, ptr, ptr, tl, i32)
71
+DEF_HELPER_FLAGS_5(sme_st1b_v_mte, TCG_CALL_NO_WG, void, env, ptr, ptr, tl, i32)
72
+
73
+DEF_HELPER_FLAGS_5(sme_st1h_be_h, TCG_CALL_NO_WG, void, env, ptr, ptr, tl, i32)
74
+DEF_HELPER_FLAGS_5(sme_st1h_le_h, TCG_CALL_NO_WG, void, env, ptr, ptr, tl, i32)
75
+DEF_HELPER_FLAGS_5(sme_st1h_be_v, TCG_CALL_NO_WG, void, env, ptr, ptr, tl, i32)
76
+DEF_HELPER_FLAGS_5(sme_st1h_le_v, TCG_CALL_NO_WG, void, env, ptr, ptr, tl, i32)
77
+DEF_HELPER_FLAGS_5(sme_st1h_be_h_mte, TCG_CALL_NO_WG, void, env, ptr, ptr, tl, i32)
78
+DEF_HELPER_FLAGS_5(sme_st1h_le_h_mte, TCG_CALL_NO_WG, void, env, ptr, ptr, tl, i32)
79
+DEF_HELPER_FLAGS_5(sme_st1h_be_v_mte, TCG_CALL_NO_WG, void, env, ptr, ptr, tl, i32)
80
+DEF_HELPER_FLAGS_5(sme_st1h_le_v_mte, TCG_CALL_NO_WG, void, env, ptr, ptr, tl, i32)
81
+
82
+DEF_HELPER_FLAGS_5(sme_st1s_be_h, TCG_CALL_NO_WG, void, env, ptr, ptr, tl, i32)
83
+DEF_HELPER_FLAGS_5(sme_st1s_le_h, TCG_CALL_NO_WG, void, env, ptr, ptr, tl, i32)
84
+DEF_HELPER_FLAGS_5(sme_st1s_be_v, TCG_CALL_NO_WG, void, env, ptr, ptr, tl, i32)
85
+DEF_HELPER_FLAGS_5(sme_st1s_le_v, TCG_CALL_NO_WG, void, env, ptr, ptr, tl, i32)
86
+DEF_HELPER_FLAGS_5(sme_st1s_be_h_mte, TCG_CALL_NO_WG, void, env, ptr, ptr, tl, i32)
87
+DEF_HELPER_FLAGS_5(sme_st1s_le_h_mte, TCG_CALL_NO_WG, void, env, ptr, ptr, tl, i32)
88
+DEF_HELPER_FLAGS_5(sme_st1s_be_v_mte, TCG_CALL_NO_WG, void, env, ptr, ptr, tl, i32)
89
+DEF_HELPER_FLAGS_5(sme_st1s_le_v_mte, TCG_CALL_NO_WG, void, env, ptr, ptr, tl, i32)
90
+
91
+DEF_HELPER_FLAGS_5(sme_st1d_be_h, TCG_CALL_NO_WG, void, env, ptr, ptr, tl, i32)
92
+DEF_HELPER_FLAGS_5(sme_st1d_le_h, TCG_CALL_NO_WG, void, env, ptr, ptr, tl, i32)
93
+DEF_HELPER_FLAGS_5(sme_st1d_be_v, TCG_CALL_NO_WG, void, env, ptr, ptr, tl, i32)
94
+DEF_HELPER_FLAGS_5(sme_st1d_le_v, TCG_CALL_NO_WG, void, env, ptr, ptr, tl, i32)
95
+DEF_HELPER_FLAGS_5(sme_st1d_be_h_mte, TCG_CALL_NO_WG, void, env, ptr, ptr, tl, i32)
96
+DEF_HELPER_FLAGS_5(sme_st1d_le_h_mte, TCG_CALL_NO_WG, void, env, ptr, ptr, tl, i32)
97
+DEF_HELPER_FLAGS_5(sme_st1d_be_v_mte, TCG_CALL_NO_WG, void, env, ptr, ptr, tl, i32)
98
+DEF_HELPER_FLAGS_5(sme_st1d_le_v_mte, TCG_CALL_NO_WG, void, env, ptr, ptr, tl, i32)
99
+
100
+DEF_HELPER_FLAGS_5(sme_st1q_be_h, TCG_CALL_NO_WG, void, env, ptr, ptr, tl, i32)
101
+DEF_HELPER_FLAGS_5(sme_st1q_le_h, TCG_CALL_NO_WG, void, env, ptr, ptr, tl, i32)
102
+DEF_HELPER_FLAGS_5(sme_st1q_be_v, TCG_CALL_NO_WG, void, env, ptr, ptr, tl, i32)
103
+DEF_HELPER_FLAGS_5(sme_st1q_le_v, TCG_CALL_NO_WG, void, env, ptr, ptr, tl, i32)
104
+DEF_HELPER_FLAGS_5(sme_st1q_be_h_mte, TCG_CALL_NO_WG, void, env, ptr, ptr, tl, i32)
105
+DEF_HELPER_FLAGS_5(sme_st1q_le_h_mte, TCG_CALL_NO_WG, void, env, ptr, ptr, tl, i32)
106
+DEF_HELPER_FLAGS_5(sme_st1q_be_v_mte, TCG_CALL_NO_WG, void, env, ptr, ptr, tl, i32)
107
+DEF_HELPER_FLAGS_5(sme_st1q_le_v_mte, TCG_CALL_NO_WG, void, env, ptr, ptr, tl, i32)
108
diff --git a/target/arm/sme.decode b/target/arm/sme.decode
109
index XXXXXXX..XXXXXXX 100644
110
--- a/target/arm/sme.decode
111
+++ b/target/arm/sme.decode
112
@@ -XXX,XX +XXX,XX @@ MOVA 11000000 esz:2 00001 0 v:1 .. pg:3 0 za_imm:4 zr:5 \
113
&mova to_vec=1 rs=%mova_rs
114
MOVA 11000000 11 00001 1 v:1 .. pg:3 0 za_imm:4 zr:5 \
115
&mova to_vec=1 rs=%mova_rs esz=4
116
+
117
+### SME Memory
118
+
119
+&ldst esz rs pg rn rm za_imm v:bool st:bool
120
+
121
+LDST1 1110000 0 esz:2 st:1 rm:5 v:1 .. pg:3 rn:5 0 za_imm:4 \
122
+ &ldst rs=%mova_rs
123
+LDST1 1110000 111 st:1 rm:5 v:1 .. pg:3 rn:5 0 za_imm:4 \
124
+ &ldst esz=4 rs=%mova_rs
125
diff --git a/target/arm/sme_helper.c b/target/arm/sme_helper.c
126
index XXXXXXX..XXXXXXX 100644
127
--- a/target/arm/sme_helper.c
128
+++ b/target/arm/sme_helper.c
33
@@ -XXX,XX +XXX,XX @@
129
@@ -XXX,XX +XXX,XX @@
34
130
35
#include "qom/object.h"
131
#include "qemu/osdep.h"
36
132
#include "cpu.h"
37
-#define TYPE_PVPANIC "pvpanic"
133
+#include "internals.h"
38
+#define TYPE_PVPANIC_ISA_DEVICE "pvpanic"
134
#include "tcg/tcg-gvec-desc.h"
39
135
#include "exec/helper-proto.h"
40
#define PVPANIC_IOPORT_PROP "ioport"
136
+#include "exec/cpu_ldst.h"
41
137
+#include "exec/exec-all.h"
42
+/* The bit of supported pv event, TODO: include uapi header and remove this */
138
#include "qemu/int128.h"
43
+#define PVPANIC_F_PANICKED 0
139
#include "vec_internal.h"
44
+#define PVPANIC_F_CRASHLOADED 1
140
+#include "sve_ldst_internal.h"
45
+
141
46
+/* The pv event value */
142
/* ResetSVEState */
47
+#define PVPANIC_PANICKED (1 << PVPANIC_F_PANICKED)
143
void arm_reset_sve_state(CPUARMState *env)
48
+#define PVPANIC_CRASHLOADED (1 << PVPANIC_F_CRASHLOADED)
144
@@ -XXX,XX +XXX,XX @@ void HELPER(sme_mova_zc_q)(void *vd, void *za, void *vg, uint32_t desc)
145
}
146
147
#undef DO_MOVA_Z
49
+
148
+
50
+/*
149
+/*
51
+ * PVPanicState for any device type
150
+ * Clear elements in a tile slice comprising len bytes.
52
+ */
151
+ */
53
+typedef struct PVPanicState PVPanicState;
152
+
54
+struct PVPanicState {
153
+typedef void ClearFn(void *ptr, size_t off, size_t len);
55
+ MemoryRegion mr;
154
+
56
+ uint8_t events;
155
+static void clear_horizontal(void *ptr, size_t off, size_t len)
57
+};
156
+{
58
+
157
+ memset(ptr + off, 0, len);
59
+void pvpanic_setup_io(PVPanicState *s, DeviceState *dev, unsigned size);
158
+}
60
+
159
+
61
static inline uint16_t pvpanic_port(void)
160
+static void clear_vertical_b(void *vptr, size_t off, size_t len)
62
{
161
+{
63
- Object *o = object_resolve_path_type("", TYPE_PVPANIC, NULL);
162
+ for (size_t i = 0; i < len; ++i) {
64
+ Object *o = object_resolve_path_type("", TYPE_PVPANIC_ISA_DEVICE, NULL);
163
+ *(uint8_t *)(vptr + tile_vslice_offset(i + off)) = 0;
65
if (!o) {
164
+ }
66
return 0;
165
+}
67
}
166
+
68
diff --git a/hw/misc/pvpanic-isa.c b/hw/misc/pvpanic-isa.c
167
+static void clear_vertical_h(void *vptr, size_t off, size_t len)
69
new file mode 100644
168
+{
70
index XXXXXXX..XXXXXXX
169
+ for (size_t i = 0; i < len; i += 2) {
71
--- /dev/null
170
+ *(uint16_t *)(vptr + tile_vslice_offset(i + off)) = 0;
72
+++ b/hw/misc/pvpanic-isa.c
171
+ }
73
@@ -XXX,XX +XXX,XX @@
172
+}
173
+
174
+static void clear_vertical_s(void *vptr, size_t off, size_t len)
175
+{
176
+ for (size_t i = 0; i < len; i += 4) {
177
+ *(uint32_t *)(vptr + tile_vslice_offset(i + off)) = 0;
178
+ }
179
+}
180
+
181
+static void clear_vertical_d(void *vptr, size_t off, size_t len)
182
+{
183
+ for (size_t i = 0; i < len; i += 8) {
184
+ *(uint64_t *)(vptr + tile_vslice_offset(i + off)) = 0;
185
+ }
186
+}
187
+
188
+static void clear_vertical_q(void *vptr, size_t off, size_t len)
189
+{
190
+ for (size_t i = 0; i < len; i += 16) {
191
+ memset(vptr + tile_vslice_offset(i + off), 0, 16);
192
+ }
193
+}
194
+
74
+/*
195
+/*
75
+ * QEMU simulated pvpanic device.
196
+ * Copy elements from an array into a tile slice comprising len bytes.
76
+ *
77
+ * Copyright Fujitsu, Corp. 2013
78
+ *
79
+ * Authors:
80
+ * Wen Congyang <wency@cn.fujitsu.com>
81
+ * Hu Tao <hutao@cn.fujitsu.com>
82
+ *
83
+ * This work is licensed under the terms of the GNU GPL, version 2 or later.
84
+ * See the COPYING file in the top-level directory.
85
+ *
86
+ */
197
+ */
87
+
198
+
88
+#include "qemu/osdep.h"
199
+typedef void CopyFn(void *dst, const void *src, size_t len);
89
+#include "qemu/log.h"
200
+
90
+#include "qemu/module.h"
201
+static void copy_horizontal(void *dst, const void *src, size_t len)
91
+#include "sysemu/runstate.h"
202
+{
92
+
203
+ memcpy(dst, src, len);
93
+#include "hw/nvram/fw_cfg.h"
204
+}
94
+#include "hw/qdev-properties.h"
205
+
95
+#include "hw/misc/pvpanic.h"
206
+static void copy_vertical_b(void *vdst, const void *vsrc, size_t len)
96
+#include "qom/object.h"
207
+{
97
+#include "hw/isa/isa.h"
208
+ const uint8_t *src = vsrc;
98
+
209
+ uint8_t *dst = vdst;
99
+OBJECT_DECLARE_SIMPLE_TYPE(PVPanicISAState, PVPANIC_ISA_DEVICE)
210
+ size_t i;
211
+
212
+ for (i = 0; i < len; ++i) {
213
+ dst[tile_vslice_index(i)] = src[i];
214
+ }
215
+}
216
+
217
+static void copy_vertical_h(void *vdst, const void *vsrc, size_t len)
218
+{
219
+ const uint16_t *src = vsrc;
220
+ uint16_t *dst = vdst;
221
+ size_t i;
222
+
223
+ for (i = 0; i < len / 2; ++i) {
224
+ dst[tile_vslice_index(i)] = src[i];
225
+ }
226
+}
227
+
228
+static void copy_vertical_s(void *vdst, const void *vsrc, size_t len)
229
+{
230
+ const uint32_t *src = vsrc;
231
+ uint32_t *dst = vdst;
232
+ size_t i;
233
+
234
+ for (i = 0; i < len / 4; ++i) {
235
+ dst[tile_vslice_index(i)] = src[i];
236
+ }
237
+}
238
+
239
+static void copy_vertical_d(void *vdst, const void *vsrc, size_t len)
240
+{
241
+ const uint64_t *src = vsrc;
242
+ uint64_t *dst = vdst;
243
+ size_t i;
244
+
245
+ for (i = 0; i < len / 8; ++i) {
246
+ dst[tile_vslice_index(i)] = src[i];
247
+ }
248
+}
249
+
250
+static void copy_vertical_q(void *vdst, const void *vsrc, size_t len)
251
+{
252
+ for (size_t i = 0; i < len; i += 16) {
253
+ memcpy(vdst + tile_vslice_offset(i), vsrc + i, 16);
254
+ }
255
+}
100
+
256
+
101
+/*
257
+/*
102
+ * PVPanicISAState for ISA device and
258
+ * Host and TLB primitives for vertical tile slice addressing.
103
+ * use ioport.
104
+ */
259
+ */
105
+struct PVPanicISAState {
260
+
106
+ ISADevice parent_obj;
261
+#define DO_LD(NAME, TYPE, HOST, TLB) \
107
+
262
+static inline void sme_##NAME##_v_host(void *za, intptr_t off, void *host) \
108
+ uint16_t ioport;
263
+{ \
109
+ PVPanicState pvpanic;
264
+ TYPE val = HOST(host); \
110
+};
265
+ *(TYPE *)(za + tile_vslice_offset(off)) = val; \
111
+
266
+} \
112
+static void pvpanic_isa_initfn(Object *obj)
267
+static inline void sme_##NAME##_v_tlb(CPUARMState *env, void *za, \
113
+{
268
+ intptr_t off, target_ulong addr, uintptr_t ra) \
114
+ PVPanicISAState *s = PVPANIC_ISA_DEVICE(obj);
269
+{ \
115
+
270
+ TYPE val = TLB(env, useronly_clean_ptr(addr), ra); \
116
+ pvpanic_setup_io(&s->pvpanic, DEVICE(s), 1);
271
+ *(TYPE *)(za + tile_vslice_offset(off)) = val; \
117
+}
272
+}
118
+
273
+
119
+static void pvpanic_isa_realizefn(DeviceState *dev, Error **errp)
274
+#define DO_ST(NAME, TYPE, HOST, TLB) \
120
+{
275
+static inline void sme_##NAME##_v_host(void *za, intptr_t off, void *host) \
121
+ ISADevice *d = ISA_DEVICE(dev);
276
+{ \
122
+ PVPanicISAState *s = PVPANIC_ISA_DEVICE(dev);
277
+ TYPE val = *(TYPE *)(za + tile_vslice_offset(off)); \
123
+ PVPanicState *ps = &s->pvpanic;
278
+ HOST(host, val); \
124
+ FWCfgState *fw_cfg = fw_cfg_find();
279
+} \
125
+ uint16_t *pvpanic_port;
280
+static inline void sme_##NAME##_v_tlb(CPUARMState *env, void *za, \
126
+
281
+ intptr_t off, target_ulong addr, uintptr_t ra) \
127
+ if (!fw_cfg) {
282
+{ \
283
+ TYPE val = *(TYPE *)(za + tile_vslice_offset(off)); \
284
+ TLB(env, useronly_clean_ptr(addr), val, ra); \
285
+}
286
+
287
+/*
288
+ * The ARMVectorReg elements are stored in host-endian 64-bit units.
289
+ * For 128-bit quantities, the sequence defined by the Elem[] pseudocode
290
+ * corresponds to storing the two 64-bit pieces in little-endian order.
291
+ */
292
+#define DO_LDQ(HNAME, VNAME, BE, HOST, TLB) \
293
+static inline void HNAME##_host(void *za, intptr_t off, void *host) \
294
+{ \
295
+ uint64_t val0 = HOST(host), val1 = HOST(host + 8); \
296
+ uint64_t *ptr = za + off; \
297
+ ptr[0] = BE ? val1 : val0, ptr[1] = BE ? val0 : val1; \
298
+} \
299
+static inline void VNAME##_v_host(void *za, intptr_t off, void *host) \
300
+{ \
301
+ HNAME##_host(za, tile_vslice_offset(off), host); \
302
+} \
303
+static inline void HNAME##_tlb(CPUARMState *env, void *za, intptr_t off, \
304
+ target_ulong addr, uintptr_t ra) \
305
+{ \
306
+ uint64_t val0 = TLB(env, useronly_clean_ptr(addr), ra); \
307
+ uint64_t val1 = TLB(env, useronly_clean_ptr(addr + 8), ra); \
308
+ uint64_t *ptr = za + off; \
309
+ ptr[0] = BE ? val1 : val0, ptr[1] = BE ? val0 : val1; \
310
+} \
311
+static inline void VNAME##_v_tlb(CPUARMState *env, void *za, intptr_t off, \
312
+ target_ulong addr, uintptr_t ra) \
313
+{ \
314
+ HNAME##_tlb(env, za, tile_vslice_offset(off), addr, ra); \
315
+}
316
+
317
+#define DO_STQ(HNAME, VNAME, BE, HOST, TLB) \
318
+static inline void HNAME##_host(void *za, intptr_t off, void *host) \
319
+{ \
320
+ uint64_t *ptr = za + off; \
321
+ HOST(host, ptr[BE]); \
322
+ HOST(host + 1, ptr[!BE]); \
323
+} \
324
+static inline void VNAME##_v_host(void *za, intptr_t off, void *host) \
325
+{ \
326
+ HNAME##_host(za, tile_vslice_offset(off), host); \
327
+} \
328
+static inline void HNAME##_tlb(CPUARMState *env, void *za, intptr_t off, \
329
+ target_ulong addr, uintptr_t ra) \
330
+{ \
331
+ uint64_t *ptr = za + off; \
332
+ TLB(env, useronly_clean_ptr(addr), ptr[BE], ra); \
333
+ TLB(env, useronly_clean_ptr(addr + 8), ptr[!BE], ra); \
334
+} \
335
+static inline void VNAME##_v_tlb(CPUARMState *env, void *za, intptr_t off, \
336
+ target_ulong addr, uintptr_t ra) \
337
+{ \
338
+ HNAME##_tlb(env, za, tile_vslice_offset(off), addr, ra); \
339
+}
340
+
341
+DO_LD(ld1b, uint8_t, ldub_p, cpu_ldub_data_ra)
342
+DO_LD(ld1h_be, uint16_t, lduw_be_p, cpu_lduw_be_data_ra)
343
+DO_LD(ld1h_le, uint16_t, lduw_le_p, cpu_lduw_le_data_ra)
344
+DO_LD(ld1s_be, uint32_t, ldl_be_p, cpu_ldl_be_data_ra)
345
+DO_LD(ld1s_le, uint32_t, ldl_le_p, cpu_ldl_le_data_ra)
346
+DO_LD(ld1d_be, uint64_t, ldq_be_p, cpu_ldq_be_data_ra)
347
+DO_LD(ld1d_le, uint64_t, ldq_le_p, cpu_ldq_le_data_ra)
348
+
349
+DO_LDQ(sve_ld1qq_be, sme_ld1q_be, 1, ldq_be_p, cpu_ldq_be_data_ra)
350
+DO_LDQ(sve_ld1qq_le, sme_ld1q_le, 0, ldq_le_p, cpu_ldq_le_data_ra)
351
+
352
+DO_ST(st1b, uint8_t, stb_p, cpu_stb_data_ra)
353
+DO_ST(st1h_be, uint16_t, stw_be_p, cpu_stw_be_data_ra)
354
+DO_ST(st1h_le, uint16_t, stw_le_p, cpu_stw_le_data_ra)
355
+DO_ST(st1s_be, uint32_t, stl_be_p, cpu_stl_be_data_ra)
356
+DO_ST(st1s_le, uint32_t, stl_le_p, cpu_stl_le_data_ra)
357
+DO_ST(st1d_be, uint64_t, stq_be_p, cpu_stq_be_data_ra)
358
+DO_ST(st1d_le, uint64_t, stq_le_p, cpu_stq_le_data_ra)
359
+
360
+DO_STQ(sve_st1qq_be, sme_st1q_be, 1, stq_be_p, cpu_stq_be_data_ra)
361
+DO_STQ(sve_st1qq_le, sme_st1q_le, 0, stq_le_p, cpu_stq_le_data_ra)
362
+
363
+#undef DO_LD
364
+#undef DO_ST
365
+#undef DO_LDQ
366
+#undef DO_STQ
367
+
368
+/*
369
+ * Common helper for all contiguous predicated loads.
370
+ */
371
+
372
+static inline QEMU_ALWAYS_INLINE
373
+void sme_ld1(CPUARMState *env, void *za, uint64_t *vg,
374
+ const target_ulong addr, uint32_t desc, const uintptr_t ra,
375
+ const int esz, uint32_t mtedesc, bool vertical,
376
+ sve_ldst1_host_fn *host_fn,
377
+ sve_ldst1_tlb_fn *tlb_fn,
378
+ ClearFn *clr_fn,
379
+ CopyFn *cpy_fn)
380
+{
381
+ const intptr_t reg_max = simd_oprsz(desc);
382
+ const intptr_t esize = 1 << esz;
383
+ intptr_t reg_off, reg_last;
384
+ SVEContLdSt info;
385
+ void *host;
386
+ int flags;
387
+
388
+ /* Find the active elements. */
389
+ if (!sve_cont_ldst_elements(&info, addr, vg, reg_max, esz, esize)) {
390
+ /* The entire predicate was false; no load occurs. */
391
+ clr_fn(za, 0, reg_max);
128
+ return;
392
+ return;
129
+ }
393
+ }
130
+
394
+
131
+ pvpanic_port = g_malloc(sizeof(*pvpanic_port));
395
+ /* Probe the page(s). Exit with exception for any invalid page. */
132
+ *pvpanic_port = cpu_to_le16(s->ioport);
396
+ sve_cont_ldst_pages(&info, FAULT_ALL, env, addr, MMU_DATA_LOAD, ra);
133
+ fw_cfg_add_file(fw_cfg, "etc/pvpanic-port", pvpanic_port,
397
+
134
+ sizeof(*pvpanic_port));
398
+ /* Handle watchpoints for all active elements. */
135
+
399
+ sve_cont_ldst_watchpoints(&info, env, vg, addr, esize, esize,
136
+ isa_register_ioport(d, &ps->mr, s->ioport);
400
+ BP_MEM_READ, ra);
137
+}
401
+
138
+
402
+ /*
139
+static Property pvpanic_isa_properties[] = {
403
+ * Handle mte checks for all active elements.
140
+ DEFINE_PROP_UINT16(PVPANIC_IOPORT_PROP, PVPanicISAState, ioport, 0x505),
404
+ * Since TBI must be set for MTE, !mtedesc => !mte_active.
141
+ DEFINE_PROP_UINT8("events", PVPanicISAState, pvpanic.events, PVPANIC_PANICKED | PVPANIC_CRASHLOADED),
405
+ */
142
+ DEFINE_PROP_END_OF_LIST(),
406
+ if (mtedesc) {
143
+};
407
+ sve_cont_ldst_mte_check(&info, env, vg, addr, esize, esize,
144
+
408
+ mtedesc, ra);
145
+static void pvpanic_isa_class_init(ObjectClass *klass, void *data)
409
+ }
146
+{
410
+
147
+ DeviceClass *dc = DEVICE_CLASS(klass);
411
+ flags = info.page[0].flags | info.page[1].flags;
148
+
412
+ if (unlikely(flags != 0)) {
149
+ dc->realize = pvpanic_isa_realizefn;
413
+#ifdef CONFIG_USER_ONLY
150
+ device_class_set_props(dc, pvpanic_isa_properties);
414
+ g_assert_not_reached();
151
+ set_bit(DEVICE_CATEGORY_MISC, dc->categories);
415
+#else
152
+}
416
+ /*
153
+
417
+ * At least one page includes MMIO.
154
+static TypeInfo pvpanic_isa_info = {
418
+ * Any bus operation can fail with cpu_transaction_failed,
155
+ .name = TYPE_PVPANIC_ISA_DEVICE,
419
+ * which for ARM will raise SyncExternal. Perform the load
156
+ .parent = TYPE_ISA_DEVICE,
420
+ * into scratch memory to preserve register state until the end.
157
+ .instance_size = sizeof(PVPanicISAState),
421
+ */
158
+ .instance_init = pvpanic_isa_initfn,
422
+ ARMVectorReg scratch = { };
159
+ .class_init = pvpanic_isa_class_init,
423
+
160
+};
424
+ reg_off = info.reg_off_first[0];
161
+
425
+ reg_last = info.reg_off_last[1];
162
+static void pvpanic_register_types(void)
426
+ if (reg_last < 0) {
163
+{
427
+ reg_last = info.reg_off_split;
164
+ type_register_static(&pvpanic_isa_info);
428
+ if (reg_last < 0) {
165
+}
429
+ reg_last = info.reg_off_last[0];
166
+
430
+ }
167
+type_init(pvpanic_register_types)
431
+ }
168
diff --git a/hw/misc/pvpanic.c b/hw/misc/pvpanic.c
432
+
433
+ do {
434
+ uint64_t pg = vg[reg_off >> 6];
435
+ do {
436
+ if ((pg >> (reg_off & 63)) & 1) {
437
+ tlb_fn(env, &scratch, reg_off, addr + reg_off, ra);
438
+ }
439
+ reg_off += esize;
440
+ } while (reg_off & 63);
441
+ } while (reg_off <= reg_last);
442
+
443
+ cpy_fn(za, &scratch, reg_max);
444
+ return;
445
+#endif
446
+ }
447
+
448
+ /* The entire operation is in RAM, on valid pages. */
449
+
450
+ reg_off = info.reg_off_first[0];
451
+ reg_last = info.reg_off_last[0];
452
+ host = info.page[0].host;
453
+
454
+ if (!vertical) {
455
+ memset(za, 0, reg_max);
456
+ } else if (reg_off) {
457
+ clr_fn(za, 0, reg_off);
458
+ }
459
+
460
+ while (reg_off <= reg_last) {
461
+ uint64_t pg = vg[reg_off >> 6];
462
+ do {
463
+ if ((pg >> (reg_off & 63)) & 1) {
464
+ host_fn(za, reg_off, host + reg_off);
465
+ } else if (vertical) {
466
+ clr_fn(za, reg_off, esize);
467
+ }
468
+ reg_off += esize;
469
+ } while (reg_off <= reg_last && (reg_off & 63));
470
+ }
471
+
472
+ /*
473
+ * Use the slow path to manage the cross-page misalignment.
474
+ * But we know this is RAM and cannot trap.
475
+ */
476
+ reg_off = info.reg_off_split;
477
+ if (unlikely(reg_off >= 0)) {
478
+ tlb_fn(env, za, reg_off, addr + reg_off, ra);
479
+ }
480
+
481
+ reg_off = info.reg_off_first[1];
482
+ if (unlikely(reg_off >= 0)) {
483
+ reg_last = info.reg_off_last[1];
484
+ host = info.page[1].host;
485
+
486
+ do {
487
+ uint64_t pg = vg[reg_off >> 6];
488
+ do {
489
+ if ((pg >> (reg_off & 63)) & 1) {
490
+ host_fn(za, reg_off, host + reg_off);
491
+ } else if (vertical) {
492
+ clr_fn(za, reg_off, esize);
493
+ }
494
+ reg_off += esize;
495
+ } while (reg_off & 63);
496
+ } while (reg_off <= reg_last);
497
+ }
498
+}
499
+
500
+static inline QEMU_ALWAYS_INLINE
501
+void sme_ld1_mte(CPUARMState *env, void *za, uint64_t *vg,
502
+ target_ulong addr, uint32_t desc, uintptr_t ra,
503
+ const int esz, bool vertical,
504
+ sve_ldst1_host_fn *host_fn,
505
+ sve_ldst1_tlb_fn *tlb_fn,
506
+ ClearFn *clr_fn,
507
+ CopyFn *cpy_fn)
508
+{
509
+ uint32_t mtedesc = desc >> (SIMD_DATA_SHIFT + SVE_MTEDESC_SHIFT);
510
+ int bit55 = extract64(addr, 55, 1);
511
+
512
+ /* Remove mtedesc from the normal sve descriptor. */
513
+ desc = extract32(desc, 0, SIMD_DATA_SHIFT + SVE_MTEDESC_SHIFT);
514
+
515
+ /* Perform gross MTE suppression early. */
516
+ if (!tbi_check(desc, bit55) ||
517
+ tcma_check(desc, bit55, allocation_tag_from_addr(addr))) {
518
+ mtedesc = 0;
519
+ }
520
+
521
+ sme_ld1(env, za, vg, addr, desc, ra, esz, mtedesc, vertical,
522
+ host_fn, tlb_fn, clr_fn, cpy_fn);
523
+}
524
+
525
+#define DO_LD(L, END, ESZ) \
526
+void HELPER(sme_ld1##L##END##_h)(CPUARMState *env, void *za, void *vg, \
527
+ target_ulong addr, uint32_t desc) \
528
+{ \
529
+ sme_ld1(env, za, vg, addr, desc, GETPC(), ESZ, 0, false, \
530
+ sve_ld1##L##L##END##_host, sve_ld1##L##L##END##_tlb, \
531
+ clear_horizontal, copy_horizontal); \
532
+} \
533
+void HELPER(sme_ld1##L##END##_v)(CPUARMState *env, void *za, void *vg, \
534
+ target_ulong addr, uint32_t desc) \
535
+{ \
536
+ sme_ld1(env, za, vg, addr, desc, GETPC(), ESZ, 0, true, \
537
+ sme_ld1##L##END##_v_host, sme_ld1##L##END##_v_tlb, \
538
+ clear_vertical_##L, copy_vertical_##L); \
539
+} \
540
+void HELPER(sme_ld1##L##END##_h_mte)(CPUARMState *env, void *za, void *vg, \
541
+ target_ulong addr, uint32_t desc) \
542
+{ \
543
+ sme_ld1_mte(env, za, vg, addr, desc, GETPC(), ESZ, false, \
544
+ sve_ld1##L##L##END##_host, sve_ld1##L##L##END##_tlb, \
545
+ clear_horizontal, copy_horizontal); \
546
+} \
547
+void HELPER(sme_ld1##L##END##_v_mte)(CPUARMState *env, void *za, void *vg, \
548
+ target_ulong addr, uint32_t desc) \
549
+{ \
550
+ sme_ld1_mte(env, za, vg, addr, desc, GETPC(), ESZ, true, \
551
+ sme_ld1##L##END##_v_host, sme_ld1##L##END##_v_tlb, \
552
+ clear_vertical_##L, copy_vertical_##L); \
553
+}
554
+
555
+DO_LD(b, , MO_8)
556
+DO_LD(h, _be, MO_16)
557
+DO_LD(h, _le, MO_16)
558
+DO_LD(s, _be, MO_32)
559
+DO_LD(s, _le, MO_32)
560
+DO_LD(d, _be, MO_64)
561
+DO_LD(d, _le, MO_64)
562
+DO_LD(q, _be, MO_128)
563
+DO_LD(q, _le, MO_128)
564
+
565
+#undef DO_LD
566
+
567
+/*
568
+ * Common helper for all contiguous predicated stores.
569
+ */
570
+
571
+static inline QEMU_ALWAYS_INLINE
572
+void sme_st1(CPUARMState *env, void *za, uint64_t *vg,
573
+ const target_ulong addr, uint32_t desc, const uintptr_t ra,
574
+ const int esz, uint32_t mtedesc, bool vertical,
575
+ sve_ldst1_host_fn *host_fn,
576
+ sve_ldst1_tlb_fn *tlb_fn)
577
+{
578
+ const intptr_t reg_max = simd_oprsz(desc);
579
+ const intptr_t esize = 1 << esz;
580
+ intptr_t reg_off, reg_last;
581
+ SVEContLdSt info;
582
+ void *host;
583
+ int flags;
584
+
585
+ /* Find the active elements. */
586
+ if (!sve_cont_ldst_elements(&info, addr, vg, reg_max, esz, esize)) {
587
+ /* The entire predicate was false; no store occurs. */
588
+ return;
589
+ }
590
+
591
+ /* Probe the page(s). Exit with exception for any invalid page. */
592
+ sve_cont_ldst_pages(&info, FAULT_ALL, env, addr, MMU_DATA_STORE, ra);
593
+
594
+ /* Handle watchpoints for all active elements. */
595
+ sve_cont_ldst_watchpoints(&info, env, vg, addr, esize, esize,
596
+ BP_MEM_WRITE, ra);
597
+
598
+ /*
599
+ * Handle mte checks for all active elements.
600
+ * Since TBI must be set for MTE, !mtedesc => !mte_active.
601
+ */
602
+ if (mtedesc) {
603
+ sve_cont_ldst_mte_check(&info, env, vg, addr, esize, esize,
604
+ mtedesc, ra);
605
+ }
606
+
607
+ flags = info.page[0].flags | info.page[1].flags;
608
+ if (unlikely(flags != 0)) {
609
+#ifdef CONFIG_USER_ONLY
610
+ g_assert_not_reached();
611
+#else
612
+ /*
613
+ * At least one page includes MMIO.
614
+ * Any bus operation can fail with cpu_transaction_failed,
615
+ * which for ARM will raise SyncExternal. We cannot avoid
616
+ * this fault and will leave with the store incomplete.
617
+ */
618
+ reg_off = info.reg_off_first[0];
619
+ reg_last = info.reg_off_last[1];
620
+ if (reg_last < 0) {
621
+ reg_last = info.reg_off_split;
622
+ if (reg_last < 0) {
623
+ reg_last = info.reg_off_last[0];
624
+ }
625
+ }
626
+
627
+ do {
628
+ uint64_t pg = vg[reg_off >> 6];
629
+ do {
630
+ if ((pg >> (reg_off & 63)) & 1) {
631
+ tlb_fn(env, za, reg_off, addr + reg_off, ra);
632
+ }
633
+ reg_off += esize;
634
+ } while (reg_off & 63);
635
+ } while (reg_off <= reg_last);
636
+ return;
637
+#endif
638
+ }
639
+
640
+ reg_off = info.reg_off_first[0];
641
+ reg_last = info.reg_off_last[0];
642
+ host = info.page[0].host;
643
+
644
+ while (reg_off <= reg_last) {
645
+ uint64_t pg = vg[reg_off >> 6];
646
+ do {
647
+ if ((pg >> (reg_off & 63)) & 1) {
648
+ host_fn(za, reg_off, host + reg_off);
649
+ }
650
+ reg_off += 1 << esz;
651
+ } while (reg_off <= reg_last && (reg_off & 63));
652
+ }
653
+
654
+ /*
655
+ * Use the slow path to manage the cross-page misalignment.
656
+ * But we know this is RAM and cannot trap.
657
+ */
658
+ reg_off = info.reg_off_split;
659
+ if (unlikely(reg_off >= 0)) {
660
+ tlb_fn(env, za, reg_off, addr + reg_off, ra);
661
+ }
662
+
663
+ reg_off = info.reg_off_first[1];
664
+ if (unlikely(reg_off >= 0)) {
665
+ reg_last = info.reg_off_last[1];
666
+ host = info.page[1].host;
667
+
668
+ do {
669
+ uint64_t pg = vg[reg_off >> 6];
670
+ do {
671
+ if ((pg >> (reg_off & 63)) & 1) {
672
+ host_fn(za, reg_off, host + reg_off);
673
+ }
674
+ reg_off += 1 << esz;
675
+ } while (reg_off & 63);
676
+ } while (reg_off <= reg_last);
677
+ }
678
+}
679
+
680
+static inline QEMU_ALWAYS_INLINE
681
+void sme_st1_mte(CPUARMState *env, void *za, uint64_t *vg, target_ulong addr,
682
+ uint32_t desc, uintptr_t ra, int esz, bool vertical,
683
+ sve_ldst1_host_fn *host_fn,
684
+ sve_ldst1_tlb_fn *tlb_fn)
685
+{
686
+ uint32_t mtedesc = desc >> (SIMD_DATA_SHIFT + SVE_MTEDESC_SHIFT);
687
+ int bit55 = extract64(addr, 55, 1);
688
+
689
+ /* Remove mtedesc from the normal sve descriptor. */
690
+ desc = extract32(desc, 0, SIMD_DATA_SHIFT + SVE_MTEDESC_SHIFT);
691
+
692
+ /* Perform gross MTE suppression early. */
693
+ if (!tbi_check(desc, bit55) ||
694
+ tcma_check(desc, bit55, allocation_tag_from_addr(addr))) {
695
+ mtedesc = 0;
696
+ }
697
+
698
+ sme_st1(env, za, vg, addr, desc, ra, esz, mtedesc,
699
+ vertical, host_fn, tlb_fn);
700
+}
701
+
702
+#define DO_ST(L, END, ESZ) \
703
+void HELPER(sme_st1##L##END##_h)(CPUARMState *env, void *za, void *vg, \
704
+ target_ulong addr, uint32_t desc) \
705
+{ \
706
+ sme_st1(env, za, vg, addr, desc, GETPC(), ESZ, 0, false, \
707
+ sve_st1##L##L##END##_host, sve_st1##L##L##END##_tlb); \
708
+} \
709
+void HELPER(sme_st1##L##END##_v)(CPUARMState *env, void *za, void *vg, \
710
+ target_ulong addr, uint32_t desc) \
711
+{ \
712
+ sme_st1(env, za, vg, addr, desc, GETPC(), ESZ, 0, true, \
713
+ sme_st1##L##END##_v_host, sme_st1##L##END##_v_tlb); \
714
+} \
715
+void HELPER(sme_st1##L##END##_h_mte)(CPUARMState *env, void *za, void *vg, \
716
+ target_ulong addr, uint32_t desc) \
717
+{ \
718
+ sme_st1_mte(env, za, vg, addr, desc, GETPC(), ESZ, false, \
719
+ sve_st1##L##L##END##_host, sve_st1##L##L##END##_tlb); \
720
+} \
721
+void HELPER(sme_st1##L##END##_v_mte)(CPUARMState *env, void *za, void *vg, \
722
+ target_ulong addr, uint32_t desc) \
723
+{ \
724
+ sme_st1_mte(env, za, vg, addr, desc, GETPC(), ESZ, true, \
725
+ sme_st1##L##END##_v_host, sme_st1##L##END##_v_tlb); \
726
+}
727
+
728
+DO_ST(b, , MO_8)
729
+DO_ST(h, _be, MO_16)
730
+DO_ST(h, _le, MO_16)
731
+DO_ST(s, _be, MO_32)
732
+DO_ST(s, _le, MO_32)
733
+DO_ST(d, _be, MO_64)
734
+DO_ST(d, _le, MO_64)
735
+DO_ST(q, _be, MO_128)
736
+DO_ST(q, _le, MO_128)
737
+
738
+#undef DO_ST
739
diff --git a/target/arm/translate-sme.c b/target/arm/translate-sme.c
169
index XXXXXXX..XXXXXXX 100644
740
index XXXXXXX..XXXXXXX 100644
170
--- a/hw/misc/pvpanic.c
741
--- a/target/arm/translate-sme.c
171
+++ b/hw/misc/pvpanic.c
742
+++ b/target/arm/translate-sme.c
172
@@ -XXX,XX +XXX,XX @@
743
@@ -XXX,XX +XXX,XX @@ static bool trans_MOVA(DisasContext *s, arg_MOVA *a)
173
#include "hw/misc/pvpanic.h"
744
174
#include "qom/object.h"
745
return true;
175
176
-/* The bit of supported pv event, TODO: include uapi header and remove this */
177
-#define PVPANIC_F_PANICKED 0
178
-#define PVPANIC_F_CRASHLOADED 1
179
-
180
-/* The pv event value */
181
-#define PVPANIC_PANICKED (1 << PVPANIC_F_PANICKED)
182
-#define PVPANIC_CRASHLOADED (1 << PVPANIC_F_CRASHLOADED)
183
-
184
-typedef struct PVPanicState PVPanicState;
185
-DECLARE_INSTANCE_CHECKER(PVPanicState, ISA_PVPANIC_DEVICE,
186
- TYPE_PVPANIC)
187
-
188
static void handle_event(int event)
189
{
190
static bool logged;
191
@@ -XXX,XX +XXX,XX @@ static void handle_event(int event)
192
}
193
}
746
}
194
747
+
195
-#include "hw/isa/isa.h"
748
+static bool trans_LDST1(DisasContext *s, arg_LDST1 *a)
196
-
749
+{
197
-struct PVPanicState {
750
+ typedef void GenLdSt1(TCGv_env, TCGv_ptr, TCGv_ptr, TCGv, TCGv_i32);
198
- ISADevice parent_obj;
751
+
199
-
752
+ /*
200
- MemoryRegion io;
753
+ * Indexed by [esz][be][v][mte][st], which is (except for load/store)
201
- uint16_t ioport;
754
+ * also the order in which the elements appear in the function names,
202
- uint8_t events;
755
+ * and so how we must concatenate the pieces.
203
-};
756
+ */
204
-
757
+
205
/* return supported events on read */
758
+#define FN_LS(F) { gen_helper_sme_ld1##F, gen_helper_sme_st1##F }
206
-static uint64_t pvpanic_ioport_read(void *opaque, hwaddr addr, unsigned size)
759
+#define FN_MTE(F) { FN_LS(F), FN_LS(F##_mte) }
207
+static uint64_t pvpanic_read(void *opaque, hwaddr addr, unsigned size)
760
+#define FN_HV(F) { FN_MTE(F##_h), FN_MTE(F##_v) }
208
{
761
+#define FN_END(L, B) { FN_HV(L), FN_HV(B) }
209
PVPanicState *pvp = opaque;
762
+
210
return pvp->events;
763
+ static GenLdSt1 * const fns[5][2][2][2][2] = {
211
}
764
+ FN_END(b, b),
212
765
+ FN_END(h_le, h_be),
213
-static void pvpanic_ioport_write(void *opaque, hwaddr addr, uint64_t val,
766
+ FN_END(s_le, s_be),
214
+static void pvpanic_write(void *opaque, hwaddr addr, uint64_t val,
767
+ FN_END(d_le, d_be),
215
unsigned size)
768
+ FN_END(q_le, q_be),
216
{
769
+ };
217
handle_event(val);
770
+
218
}
771
+#undef FN_LS
219
772
+#undef FN_MTE
220
static const MemoryRegionOps pvpanic_ops = {
773
+#undef FN_HV
221
- .read = pvpanic_ioport_read,
774
+#undef FN_END
222
- .write = pvpanic_ioport_write,
775
+
223
+ .read = pvpanic_read,
776
+ TCGv_ptr t_za, t_pg;
224
+ .write = pvpanic_write,
777
+ TCGv_i64 addr;
225
.impl = {
778
+ int svl, desc = 0;
226
.min_access_size = 1,
779
+ bool be = s->be_data == MO_BE;
227
.max_access_size = 1,
780
+ bool mte = s->mte_active[0];
228
},
781
+
229
};
782
+ if (!dc_isar_feature(aa64_sme, s)) {
230
783
+ return false;
231
-static void pvpanic_isa_initfn(Object *obj)
784
+ }
232
+void pvpanic_setup_io(PVPanicState *s, DeviceState *dev, unsigned size)
785
+ if (!sme_smza_enabled_check(s)) {
233
{
786
+ return true;
234
- PVPanicState *s = ISA_PVPANIC_DEVICE(obj);
787
+ }
235
-
788
+
236
- memory_region_init_io(&s->io, OBJECT(s), &pvpanic_ops, s, "pvpanic", 1);
789
+ t_za = get_tile_rowcol(s, a->esz, a->rs, a->za_imm, a->v);
237
+ memory_region_init_io(&s->mr, OBJECT(dev), &pvpanic_ops, s, "pvpanic", size);
790
+ t_pg = pred_full_reg_ptr(s, a->pg);
238
}
791
+ addr = tcg_temp_new_i64();
239
-
792
+
240
-static void pvpanic_isa_realizefn(DeviceState *dev, Error **errp)
793
+ tcg_gen_shli_i64(addr, cpu_reg(s, a->rm), a->esz);
241
-{
794
+ tcg_gen_add_i64(addr, addr, cpu_reg_sp(s, a->rn));
242
- ISADevice *d = ISA_DEVICE(dev);
795
+
243
- PVPanicState *s = ISA_PVPANIC_DEVICE(dev);
796
+ if (mte) {
244
- FWCfgState *fw_cfg = fw_cfg_find();
797
+ desc = FIELD_DP32(desc, MTEDESC, MIDX, get_mem_index(s));
245
- uint16_t *pvpanic_port;
798
+ desc = FIELD_DP32(desc, MTEDESC, TBI, s->tbid);
246
-
799
+ desc = FIELD_DP32(desc, MTEDESC, TCMA, s->tcma);
247
- if (!fw_cfg) {
800
+ desc = FIELD_DP32(desc, MTEDESC, WRITE, a->st);
248
- return;
801
+ desc = FIELD_DP32(desc, MTEDESC, SIZEM1, (1 << a->esz) - 1);
249
- }
802
+ desc <<= SVE_MTEDESC_SHIFT;
250
-
803
+ } else {
251
- pvpanic_port = g_malloc(sizeof(*pvpanic_port));
804
+ addr = clean_data_tbi(s, addr);
252
- *pvpanic_port = cpu_to_le16(s->ioport);
805
+ }
253
- fw_cfg_add_file(fw_cfg, "etc/pvpanic-port", pvpanic_port,
806
+ svl = streaming_vec_reg_size(s);
254
- sizeof(*pvpanic_port));
807
+ desc = simd_desc(svl, svl, desc);
255
-
808
+
256
- isa_register_ioport(d, &s->io, s->ioport);
809
+ fns[a->esz][be][a->v][mte][a->st](cpu_env, t_za, t_pg, addr,
257
-}
810
+ tcg_constant_i32(desc));
258
-
811
+
259
-static Property pvpanic_isa_properties[] = {
812
+ tcg_temp_free_ptr(t_za);
260
- DEFINE_PROP_UINT16(PVPANIC_IOPORT_PROP, PVPanicState, ioport, 0x505),
813
+ tcg_temp_free_ptr(t_pg);
261
- DEFINE_PROP_UINT8("events", PVPanicState, events, PVPANIC_PANICKED | PVPANIC_CRASHLOADED),
814
+ tcg_temp_free_i64(addr);
262
- DEFINE_PROP_END_OF_LIST(),
815
+ return true;
263
-};
816
+}
264
-
265
-static void pvpanic_isa_class_init(ObjectClass *klass, void *data)
266
-{
267
- DeviceClass *dc = DEVICE_CLASS(klass);
268
-
269
- dc->realize = pvpanic_isa_realizefn;
270
- device_class_set_props(dc, pvpanic_isa_properties);
271
- set_bit(DEVICE_CATEGORY_MISC, dc->categories);
272
-}
273
-
274
-static TypeInfo pvpanic_isa_info = {
275
- .name = TYPE_PVPANIC,
276
- .parent = TYPE_ISA_DEVICE,
277
- .instance_size = sizeof(PVPanicState),
278
- .instance_init = pvpanic_isa_initfn,
279
- .class_init = pvpanic_isa_class_init,
280
-};
281
-
282
-static void pvpanic_register_types(void)
283
-{
284
- type_register_static(&pvpanic_isa_info);
285
-}
286
-
287
-type_init(pvpanic_register_types)
288
diff --git a/hw/i386/Kconfig b/hw/i386/Kconfig
289
index XXXXXXX..XXXXXXX 100644
290
--- a/hw/i386/Kconfig
291
+++ b/hw/i386/Kconfig
292
@@ -XXX,XX +XXX,XX @@ config PC
293
imply ISA_DEBUG
294
imply PARALLEL
295
imply PCI_DEVICES
296
- imply PVPANIC
297
+ imply PVPANIC_ISA
298
imply QXL
299
imply SEV
300
imply SGA
301
diff --git a/hw/misc/Kconfig b/hw/misc/Kconfig
302
index XXXXXXX..XXXXXXX 100644
303
--- a/hw/misc/Kconfig
304
+++ b/hw/misc/Kconfig
305
@@ -XXX,XX +XXX,XX @@ config IOTKIT_SYSCTL
306
config IOTKIT_SYSINFO
307
bool
308
309
-config PVPANIC
310
+config PVPANIC_COMMON
311
+ bool
312
+
313
+config PVPANIC_ISA
314
bool
315
depends on ISA_BUS
316
+ select PVPANIC_COMMON
317
318
config AUX
319
bool
320
diff --git a/hw/misc/meson.build b/hw/misc/meson.build
321
index XXXXXXX..XXXXXXX 100644
322
--- a/hw/misc/meson.build
323
+++ b/hw/misc/meson.build
324
@@ -XXX,XX +XXX,XX @@ softmmu_ss.add(when: 'CONFIG_EMC141X', if_true: files('emc141x.c'))
325
softmmu_ss.add(when: 'CONFIG_UNIMP', if_true: files('unimp.c'))
326
softmmu_ss.add(when: 'CONFIG_EMPTY_SLOT', if_true: files('empty_slot.c'))
327
softmmu_ss.add(when: 'CONFIG_LED', if_true: files('led.c'))
328
+softmmu_ss.add(when: 'CONFIG_PVPANIC_COMMON', if_true: files('pvpanic.c'))
329
330
# ARM devices
331
softmmu_ss.add(when: 'CONFIG_PL310', if_true: files('arm_l2x0.c'))
332
@@ -XXX,XX +XXX,XX @@ softmmu_ss.add(when: 'CONFIG_IOTKIT_SYSINFO', if_true: files('iotkit-sysinfo.c')
333
softmmu_ss.add(when: 'CONFIG_ARMSSE_CPUID', if_true: files('armsse-cpuid.c'))
334
softmmu_ss.add(when: 'CONFIG_ARMSSE_MHU', if_true: files('armsse-mhu.c'))
335
336
-softmmu_ss.add(when: 'CONFIG_PVPANIC', if_true: files('pvpanic.c'))
337
+softmmu_ss.add(when: 'CONFIG_PVPANIC_ISA', if_true: files('pvpanic-isa.c'))
338
softmmu_ss.add(when: 'CONFIG_AUX', if_true: files('auxbus.c'))
339
softmmu_ss.add(when: 'CONFIG_ASPEED_SOC', if_true: files('aspeed_scu.c', 'aspeed_sdmc.c', 'aspeed_xdma.c'))
340
softmmu_ss.add(when: 'CONFIG_MSF2', if_true: files('msf2-sysreg.c'))
341
diff --git a/tests/qtest/meson.build b/tests/qtest/meson.build
342
index XXXXXXX..XXXXXXX 100644
343
--- a/tests/qtest/meson.build
344
+++ b/tests/qtest/meson.build
345
@@ -XXX,XX +XXX,XX @@ qtests_i386 = \
346
(config_host.has_key('CONFIG_LINUX') and \
347
config_all_devices.has_key('CONFIG_ISA_IPMI_BT') ? ['ipmi-bt-test'] : []) + \
348
(config_all_devices.has_key('CONFIG_WDT_IB700') ? ['wdt_ib700-test'] : []) + \
349
- (config_all_devices.has_key('CONFIG_PVPANIC') ? ['pvpanic-test'] : []) + \
350
+ (config_all_devices.has_key('CONFIG_PVPANIC_ISA') ? ['pvpanic-test'] : []) + \
351
(config_all_devices.has_key('CONFIG_HDA') ? ['intel-hda-test'] : []) + \
352
(config_all_devices.has_key('CONFIG_I82801B11') ? ['i82801b11-test'] : []) + \
353
(config_all_devices.has_key('CONFIG_IOH3420') ? ['ioh3420-test'] : []) + \
354
--
817
--
355
2.20.1
818
2.25.1
356
357
diff view generated by jsdifflib
1
Switch the CMSDK APB watchdog device over to using its Clock input;
1
From: Richard Henderson <richard.henderson@linaro.org>
2
the wdogclk_frq property is now ignored.
3
2
3
Add a TCGv_ptr base argument, which will be cpu_env for SVE.
4
We will reuse this for SME save and restore array insns.
5
6
Reviewed-by: Peter Maydell <peter.maydell@linaro.org>
7
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
8
Message-id: 20220708151540.18136-22-richard.henderson@linaro.org
4
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
9
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
5
Reviewed-by: Philippe Mathieu-Daudé <f4bug@amsat.org>
6
Reviewed-by: Luc Michel <luc@lmichel.fr>
7
Tested-by: Philippe Mathieu-Daudé <f4bug@amsat.org>
8
Message-id: 20210128114145.20536-21-peter.maydell@linaro.org
9
Message-id: 20210121190622.22000-21-peter.maydell@linaro.org
10
---
10
---
11
hw/watchdog/cmsdk-apb-watchdog.c | 18 ++++++++++++++----
11
target/arm/translate-a64.h | 3 +++
12
1 file changed, 14 insertions(+), 4 deletions(-)
12
target/arm/translate-sve.c | 48 ++++++++++++++++++++++++++++----------
13
2 files changed, 39 insertions(+), 12 deletions(-)
13
14
14
diff --git a/hw/watchdog/cmsdk-apb-watchdog.c b/hw/watchdog/cmsdk-apb-watchdog.c
15
diff --git a/target/arm/translate-a64.h b/target/arm/translate-a64.h
15
index XXXXXXX..XXXXXXX 100644
16
index XXXXXXX..XXXXXXX 100644
16
--- a/hw/watchdog/cmsdk-apb-watchdog.c
17
--- a/target/arm/translate-a64.h
17
+++ b/hw/watchdog/cmsdk-apb-watchdog.c
18
+++ b/target/arm/translate-a64.h
18
@@ -XXX,XX +XXX,XX @@ static void cmsdk_apb_watchdog_reset(DeviceState *dev)
19
@@ -XXX,XX +XXX,XX @@ void gen_gvec_xar(unsigned vece, uint32_t rd_ofs, uint32_t rn_ofs,
19
ptimer_transaction_commit(s->timer);
20
uint32_t rm_ofs, int64_t shift,
21
uint32_t opr_sz, uint32_t max_sz);
22
23
+void gen_sve_ldr(DisasContext *s, TCGv_ptr, int vofs, int len, int rn, int imm);
24
+void gen_sve_str(DisasContext *s, TCGv_ptr, int vofs, int len, int rn, int imm);
25
+
26
#endif /* TARGET_ARM_TRANSLATE_A64_H */
27
diff --git a/target/arm/translate-sve.c b/target/arm/translate-sve.c
28
index XXXXXXX..XXXXXXX 100644
29
--- a/target/arm/translate-sve.c
30
+++ b/target/arm/translate-sve.c
31
@@ -XXX,XX +XXX,XX @@ TRANS_FEAT(UCVTF_dd, aa64_sve, gen_gvec_fpst_arg_zpz,
32
* The load should begin at the address Rn + IMM.
33
*/
34
35
-static void do_ldr(DisasContext *s, uint32_t vofs, int len, int rn, int imm)
36
+void gen_sve_ldr(DisasContext *s, TCGv_ptr base, int vofs,
37
+ int len, int rn, int imm)
38
{
39
int len_align = QEMU_ALIGN_DOWN(len, 8);
40
int len_remain = len % 8;
41
@@ -XXX,XX +XXX,XX @@ static void do_ldr(DisasContext *s, uint32_t vofs, int len, int rn, int imm)
42
t0 = tcg_temp_new_i64();
43
for (i = 0; i < len_align; i += 8) {
44
tcg_gen_qemu_ld_i64(t0, clean_addr, midx, MO_LEUQ);
45
- tcg_gen_st_i64(t0, cpu_env, vofs + i);
46
+ tcg_gen_st_i64(t0, base, vofs + i);
47
tcg_gen_addi_i64(clean_addr, clean_addr, 8);
48
}
49
tcg_temp_free_i64(t0);
50
@@ -XXX,XX +XXX,XX @@ static void do_ldr(DisasContext *s, uint32_t vofs, int len, int rn, int imm)
51
clean_addr = new_tmp_a64_local(s);
52
tcg_gen_mov_i64(clean_addr, t0);
53
54
+ if (base != cpu_env) {
55
+ TCGv_ptr b = tcg_temp_local_new_ptr();
56
+ tcg_gen_mov_ptr(b, base);
57
+ base = b;
58
+ }
59
+
60
gen_set_label(loop);
61
62
t0 = tcg_temp_new_i64();
63
@@ -XXX,XX +XXX,XX @@ static void do_ldr(DisasContext *s, uint32_t vofs, int len, int rn, int imm)
64
tcg_gen_addi_i64(clean_addr, clean_addr, 8);
65
66
tp = tcg_temp_new_ptr();
67
- tcg_gen_add_ptr(tp, cpu_env, i);
68
+ tcg_gen_add_ptr(tp, base, i);
69
tcg_gen_addi_ptr(i, i, 8);
70
tcg_gen_st_i64(t0, tp, vofs);
71
tcg_temp_free_ptr(tp);
72
@@ -XXX,XX +XXX,XX @@ static void do_ldr(DisasContext *s, uint32_t vofs, int len, int rn, int imm)
73
74
tcg_gen_brcondi_ptr(TCG_COND_LTU, i, len_align, loop);
75
tcg_temp_free_ptr(i);
76
+
77
+ if (base != cpu_env) {
78
+ tcg_temp_free_ptr(base);
79
+ assert(len_remain == 0);
80
+ }
81
}
82
83
/*
84
@@ -XXX,XX +XXX,XX @@ static void do_ldr(DisasContext *s, uint32_t vofs, int len, int rn, int imm)
85
default:
86
g_assert_not_reached();
87
}
88
- tcg_gen_st_i64(t0, cpu_env, vofs + len_align);
89
+ tcg_gen_st_i64(t0, base, vofs + len_align);
90
tcg_temp_free_i64(t0);
91
}
20
}
92
}
21
93
22
+static void cmsdk_apb_watchdog_clk_update(void *opaque)
94
/* Similarly for stores. */
23
+{
95
-static void do_str(DisasContext *s, uint32_t vofs, int len, int rn, int imm)
24
+ CMSDKAPBWatchdog *s = CMSDK_APB_WATCHDOG(opaque);
96
+void gen_sve_str(DisasContext *s, TCGv_ptr base, int vofs,
97
+ int len, int rn, int imm)
98
{
99
int len_align = QEMU_ALIGN_DOWN(len, 8);
100
int len_remain = len % 8;
101
@@ -XXX,XX +XXX,XX @@ static void do_str(DisasContext *s, uint32_t vofs, int len, int rn, int imm)
102
103
t0 = tcg_temp_new_i64();
104
for (i = 0; i < len_align; i += 8) {
105
- tcg_gen_ld_i64(t0, cpu_env, vofs + i);
106
+ tcg_gen_ld_i64(t0, base, vofs + i);
107
tcg_gen_qemu_st_i64(t0, clean_addr, midx, MO_LEUQ);
108
tcg_gen_addi_i64(clean_addr, clean_addr, 8);
109
}
110
@@ -XXX,XX +XXX,XX @@ static void do_str(DisasContext *s, uint32_t vofs, int len, int rn, int imm)
111
clean_addr = new_tmp_a64_local(s);
112
tcg_gen_mov_i64(clean_addr, t0);
113
114
+ if (base != cpu_env) {
115
+ TCGv_ptr b = tcg_temp_local_new_ptr();
116
+ tcg_gen_mov_ptr(b, base);
117
+ base = b;
118
+ }
25
+
119
+
26
+ ptimer_transaction_begin(s->timer);
120
gen_set_label(loop);
27
+ ptimer_set_period_from_clock(s->timer, s->wdogclk, 1);
121
28
+ ptimer_transaction_commit(s->timer);
122
t0 = tcg_temp_new_i64();
29
+}
123
tp = tcg_temp_new_ptr();
124
- tcg_gen_add_ptr(tp, cpu_env, i);
125
+ tcg_gen_add_ptr(tp, base, i);
126
tcg_gen_ld_i64(t0, tp, vofs);
127
tcg_gen_addi_ptr(i, i, 8);
128
tcg_temp_free_ptr(tp);
129
@@ -XXX,XX +XXX,XX @@ static void do_str(DisasContext *s, uint32_t vofs, int len, int rn, int imm)
130
131
tcg_gen_brcondi_ptr(TCG_COND_LTU, i, len_align, loop);
132
tcg_temp_free_ptr(i);
30
+
133
+
31
static void cmsdk_apb_watchdog_init(Object *obj)
134
+ if (base != cpu_env) {
32
{
135
+ tcg_temp_free_ptr(base);
33
SysBusDevice *sbd = SYS_BUS_DEVICE(obj);
136
+ assert(len_remain == 0);
34
@@ -XXX,XX +XXX,XX @@ static void cmsdk_apb_watchdog_init(Object *obj)
137
+ }
35
s, "cmsdk-apb-watchdog", 0x1000);
36
sysbus_init_mmio(sbd, &s->iomem);
37
sysbus_init_irq(sbd, &s->wdogint);
38
- s->wdogclk = qdev_init_clock_in(DEVICE(s), "WDOGCLK", NULL, NULL);
39
+ s->wdogclk = qdev_init_clock_in(DEVICE(s), "WDOGCLK",
40
+ cmsdk_apb_watchdog_clk_update, s);
41
42
s->is_luminary = false;
43
s->id = cmsdk_apb_watchdog_id;
44
@@ -XXX,XX +XXX,XX @@ static void cmsdk_apb_watchdog_realize(DeviceState *dev, Error **errp)
45
{
46
CMSDKAPBWatchdog *s = CMSDK_APB_WATCHDOG(dev);
47
48
- if (s->wdogclk_frq == 0) {
49
+ if (!clock_has_source(s->wdogclk)) {
50
error_setg(errp,
51
- "CMSDK APB watchdog: wdogclk-frq property must be set");
52
+ "CMSDK APB watchdog: WDOGCLK clock must be connected");
53
return;
54
}
138
}
55
139
56
@@ -XXX,XX +XXX,XX @@ static void cmsdk_apb_watchdog_realize(DeviceState *dev, Error **errp)
140
/* Predicate register stores can be any multiple of 2. */
57
PTIMER_POLICY_NO_COUNTER_ROUND_DOWN);
141
if (len_remain) {
58
142
t0 = tcg_temp_new_i64();
59
ptimer_transaction_begin(s->timer);
143
- tcg_gen_ld_i64(t0, cpu_env, vofs + len_align);
60
- ptimer_set_freq(s->timer, s->wdogclk_frq);
144
+ tcg_gen_ld_i64(t0, base, vofs + len_align);
61
+ ptimer_set_period_from_clock(s->timer, s->wdogclk, 1);
145
62
ptimer_transaction_commit(s->timer);
146
switch (len_remain) {
147
case 2:
148
@@ -XXX,XX +XXX,XX @@ static bool trans_LDR_zri(DisasContext *s, arg_rri *a)
149
if (sve_access_check(s)) {
150
int size = vec_full_reg_size(s);
151
int off = vec_full_reg_offset(s, a->rd);
152
- do_ldr(s, off, size, a->rn, a->imm * size);
153
+ gen_sve_ldr(s, cpu_env, off, size, a->rn, a->imm * size);
154
}
155
return true;
63
}
156
}
64
157
@@ -XXX,XX +XXX,XX @@ static bool trans_LDR_pri(DisasContext *s, arg_rri *a)
158
if (sve_access_check(s)) {
159
int size = pred_full_reg_size(s);
160
int off = pred_full_reg_offset(s, a->rd);
161
- do_ldr(s, off, size, a->rn, a->imm * size);
162
+ gen_sve_ldr(s, cpu_env, off, size, a->rn, a->imm * size);
163
}
164
return true;
165
}
166
@@ -XXX,XX +XXX,XX @@ static bool trans_STR_zri(DisasContext *s, arg_rri *a)
167
if (sve_access_check(s)) {
168
int size = vec_full_reg_size(s);
169
int off = vec_full_reg_offset(s, a->rd);
170
- do_str(s, off, size, a->rn, a->imm * size);
171
+ gen_sve_str(s, cpu_env, off, size, a->rn, a->imm * size);
172
}
173
return true;
174
}
175
@@ -XXX,XX +XXX,XX @@ static bool trans_STR_pri(DisasContext *s, arg_rri *a)
176
if (sve_access_check(s)) {
177
int size = pred_full_reg_size(s);
178
int off = pred_full_reg_offset(s, a->rd);
179
- do_str(s, off, size, a->rn, a->imm * size);
180
+ gen_sve_str(s, cpu_env, off, size, a->rn, a->imm * size);
181
}
182
return true;
183
}
65
--
184
--
66
2.20.1
185
2.25.1
67
68
diff view generated by jsdifflib
1
Add a function for checking whether a clock has a source. This is
1
From: Richard Henderson <richard.henderson@linaro.org>
2
useful for devices which have input clocks that must be wired up by
3
the board as it allows them to fail in realize rather than ploughing
4
on with a zero-period clock.
5
2
3
We can reuse the SVE functions for LDR and STR, passing in the
4
base of the ZA vector and a zero offset.
5
6
Reviewed-by: Peter Maydell <peter.maydell@linaro.org>
7
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
8
Message-id: 20220708151540.18136-23-richard.henderson@linaro.org
6
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
9
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
7
Reviewed-by: Luc Michel <luc@lmichel.fr>
8
Reviewed-by: Philippe Mathieu-Daudé <f4bug@amsat.org>
9
Tested-by: Philippe Mathieu-Daudé <f4bug@amsat.org>
10
Message-id: 20210128114145.20536-3-peter.maydell@linaro.org
11
Message-id: 20210121190622.22000-3-peter.maydell@linaro.org
12
---
10
---
13
docs/devel/clocks.rst | 16 ++++++++++++++++
11
target/arm/sme.decode | 7 +++++++
14
include/hw/clock.h | 15 +++++++++++++++
12
target/arm/translate-sme.c | 24 ++++++++++++++++++++++++
15
2 files changed, 31 insertions(+)
13
2 files changed, 31 insertions(+)
16
14
17
diff --git a/docs/devel/clocks.rst b/docs/devel/clocks.rst
15
diff --git a/target/arm/sme.decode b/target/arm/sme.decode
18
index XXXXXXX..XXXXXXX 100644
16
index XXXXXXX..XXXXXXX 100644
19
--- a/docs/devel/clocks.rst
17
--- a/target/arm/sme.decode
20
+++ b/docs/devel/clocks.rst
18
+++ b/target/arm/sme.decode
21
@@ -XXX,XX +XXX,XX @@ object during device instance init. For example:
19
@@ -XXX,XX +XXX,XX @@ LDST1 1110000 0 esz:2 st:1 rm:5 v:1 .. pg:3 rn:5 0 za_imm:4 \
22
/* set initial value to 10ns / 100MHz */
20
&ldst rs=%mova_rs
23
clock_set_ns(clk, 10);
21
LDST1 1110000 111 st:1 rm:5 v:1 .. pg:3 rn:5 0 za_imm:4 \
24
22
&ldst esz=4 rs=%mova_rs
25
+To enforce that the clock is wired up by the board code, you can
26
+call ``clock_has_source()`` in your device's realize method:
27
+
23
+
28
+.. code-block:: c
24
+&ldstr rv rn imm
25
+@ldstr ....... ... . ...... .. ... rn:5 . imm:4 \
26
+ &ldstr rv=%mova_rs
29
+
27
+
30
+ if (!clock_has_source(s->clk)) {
28
+LDR 1110000 100 0 000000 .. 000 ..... 0 .... @ldstr
31
+ error_setg(errp, "MyDevice: clk input must be connected");
29
+STR 1110000 100 1 000000 .. 000 ..... 0 .... @ldstr
32
+ return;
30
diff --git a/target/arm/translate-sme.c b/target/arm/translate-sme.c
33
+ }
31
index XXXXXXX..XXXXXXX 100644
32
--- a/target/arm/translate-sme.c
33
+++ b/target/arm/translate-sme.c
34
@@ -XXX,XX +XXX,XX @@ static bool trans_LDST1(DisasContext *s, arg_LDST1 *a)
35
tcg_temp_free_i64(addr);
36
return true;
37
}
34
+
38
+
35
+Note that this only checks that the clock has been wired up; it is
39
+typedef void GenLdStR(DisasContext *, TCGv_ptr, int, int, int, int);
36
+still possible that the output clock connected to it is disabled
37
+or has not yet been configured, in which case the period will be
38
+zero. You should use the clock callback to find out when the clock
39
+period changes.
40
+
40
+
41
Fetching clock frequency/period
41
+static bool do_ldst_r(DisasContext *s, arg_ldstr *a, GenLdStR *fn)
42
-------------------------------
43
44
diff --git a/include/hw/clock.h b/include/hw/clock.h
45
index XXXXXXX..XXXXXXX 100644
46
--- a/include/hw/clock.h
47
+++ b/include/hw/clock.h
48
@@ -XXX,XX +XXX,XX @@ void clock_clear_callback(Clock *clk);
49
*/
50
void clock_set_source(Clock *clk, Clock *src);
51
52
+/**
53
+ * clock_has_source:
54
+ * @clk: the clock
55
+ *
56
+ * Returns true if the clock has a source clock connected to it.
57
+ * This is useful for devices which have input clocks which must
58
+ * be connected by the board/SoC code which creates them. The
59
+ * device code can use this to check in its realize method that
60
+ * the clock has been connected.
61
+ */
62
+static inline bool clock_has_source(const Clock *clk)
63
+{
42
+{
64
+ return clk->source != NULL;
43
+ int svl = streaming_vec_reg_size(s);
44
+ int imm = a->imm;
45
+ TCGv_ptr base;
46
+
47
+ if (!sme_za_enabled_check(s)) {
48
+ return true;
49
+ }
50
+
51
+ /* ZA[n] equates to ZA0H.B[n]. */
52
+ base = get_tile_rowcol(s, MO_8, a->rv, imm, false);
53
+
54
+ fn(s, base, 0, svl, a->rn, imm * svl);
55
+
56
+ tcg_temp_free_ptr(base);
57
+ return true;
65
+}
58
+}
66
+
59
+
67
/**
60
+TRANS_FEAT(LDR, aa64_sme, do_ldst_r, a, gen_sve_ldr)
68
* clock_set:
61
+TRANS_FEAT(STR, aa64_sme, do_ldst_r, a, gen_sve_str)
69
* @clk: the clock to initialize.
70
--
62
--
71
2.20.1
63
2.25.1
72
73
diff view generated by jsdifflib
1
From: Maxim Uvarov <maxim.uvarov@linaro.org>
1
From: Richard Henderson <richard.henderson@linaro.org>
2
2
3
Implement gpio-pwr driver to allow reboot and poweroff machine.
4
This is simple driver with just 2 gpios lines. Current use case
5
is to reboot and poweroff virt machine in secure mode. Secure
6
pl066 gpio chip is needed for that.
7
8
Signed-off-by: Maxim Uvarov <maxim.uvarov@linaro.org>
9
Reviewed-by: Hao Wu <wuhaotsh@google.com>
10
Reviewed-by: Peter Maydell <peter.maydell@linaro.org>
3
Reviewed-by: Peter Maydell <peter.maydell@linaro.org>
4
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
5
Message-id: 20220708151540.18136-24-richard.henderson@linaro.org
11
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
6
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
12
---
7
---
13
hw/gpio/gpio_pwr.c | 70 +++++++++++++++++++++++++++++++++++++++++++++
8
target/arm/helper-sme.h | 5 +++
14
hw/gpio/Kconfig | 3 ++
9
target/arm/sme.decode | 11 +++++
15
hw/gpio/meson.build | 1 +
10
target/arm/sme_helper.c | 90 ++++++++++++++++++++++++++++++++++++++
16
3 files changed, 74 insertions(+)
11
target/arm/translate-sme.c | 31 +++++++++++++
17
create mode 100644 hw/gpio/gpio_pwr.c
12
4 files changed, 137 insertions(+)
18
13
19
diff --git a/hw/gpio/gpio_pwr.c b/hw/gpio/gpio_pwr.c
14
diff --git a/target/arm/helper-sme.h b/target/arm/helper-sme.h
20
new file mode 100644
15
index XXXXXXX..XXXXXXX 100644
21
index XXXXXXX..XXXXXXX
16
--- a/target/arm/helper-sme.h
22
--- /dev/null
17
+++ b/target/arm/helper-sme.h
23
+++ b/hw/gpio/gpio_pwr.c
18
@@ -XXX,XX +XXX,XX @@ DEF_HELPER_FLAGS_5(sme_st1q_be_h_mte, TCG_CALL_NO_WG, void, env, ptr, ptr, tl, i
24
@@ -XXX,XX +XXX,XX @@
19
DEF_HELPER_FLAGS_5(sme_st1q_le_h_mte, TCG_CALL_NO_WG, void, env, ptr, ptr, tl, i32)
25
+/*
20
DEF_HELPER_FLAGS_5(sme_st1q_be_v_mte, TCG_CALL_NO_WG, void, env, ptr, ptr, tl, i32)
26
+ * GPIO qemu power controller
21
DEF_HELPER_FLAGS_5(sme_st1q_le_v_mte, TCG_CALL_NO_WG, void, env, ptr, ptr, tl, i32)
27
+ *
28
+ * Copyright (c) 2020 Linaro Limited
29
+ *
30
+ * Author: Maxim Uvarov <maxim.uvarov@linaro.org>
31
+ *
32
+ * Virtual gpio driver which can be used on top of pl061
33
+ * to reboot and shutdown qemu virtual machine. One of use
34
+ * case is gpio driver for secure world application (ARM
35
+ * Trusted Firmware.).
36
+ *
37
+ * This work is licensed under the terms of the GNU GPL, version 2 or later.
38
+ * See the COPYING file in the top-level directory.
39
+ * SPDX-License-Identifier: GPL-2.0-or-later
40
+ */
41
+
22
+
42
+/*
23
+DEF_HELPER_FLAGS_5(sme_addha_s, TCG_CALL_NO_RWG, void, ptr, ptr, ptr, ptr, i32)
43
+ * QEMU interface:
24
+DEF_HELPER_FLAGS_5(sme_addva_s, TCG_CALL_NO_RWG, void, ptr, ptr, ptr, ptr, i32)
44
+ * two named input GPIO lines:
25
+DEF_HELPER_FLAGS_5(sme_addha_d, TCG_CALL_NO_RWG, void, ptr, ptr, ptr, ptr, i32)
45
+ * 'reset' : when asserted, trigger system reset
26
+DEF_HELPER_FLAGS_5(sme_addva_d, TCG_CALL_NO_RWG, void, ptr, ptr, ptr, ptr, i32)
46
+ * 'shutdown' : when asserted, trigger system shutdown
27
diff --git a/target/arm/sme.decode b/target/arm/sme.decode
47
+ */
28
index XXXXXXX..XXXXXXX 100644
29
--- a/target/arm/sme.decode
30
+++ b/target/arm/sme.decode
31
@@ -XXX,XX +XXX,XX @@ LDST1 1110000 111 st:1 rm:5 v:1 .. pg:3 rn:5 0 za_imm:4 \
32
33
LDR 1110000 100 0 000000 .. 000 ..... 0 .... @ldstr
34
STR 1110000 100 1 000000 .. 000 ..... 0 .... @ldstr
48
+
35
+
49
+#include "qemu/osdep.h"
36
+### SME Add Vector to Array
50
+#include "hw/sysbus.h"
51
+#include "sysemu/runstate.h"
52
+
37
+
53
+#define TYPE_GPIOPWR "gpio-pwr"
38
+&adda zad zn pm pn
54
+OBJECT_DECLARE_SIMPLE_TYPE(GPIO_PWR_State, GPIOPWR)
39
+@adda_32 ........ .. ..... . pm:3 pn:3 zn:5 ... zad:2 &adda
40
+@adda_64 ........ .. ..... . pm:3 pn:3 zn:5 .. zad:3 &adda
55
+
41
+
56
+struct GPIO_PWR_State {
42
+ADDHA_s 11000000 10 01000 0 ... ... ..... 000 .. @adda_32
57
+ SysBusDevice parent_obj;
43
+ADDVA_s 11000000 10 01000 1 ... ... ..... 000 .. @adda_32
58
+};
44
+ADDHA_d 11000000 11 01000 0 ... ... ..... 00 ... @adda_64
45
+ADDVA_d 11000000 11 01000 1 ... ... ..... 00 ... @adda_64
46
diff --git a/target/arm/sme_helper.c b/target/arm/sme_helper.c
47
index XXXXXXX..XXXXXXX 100644
48
--- a/target/arm/sme_helper.c
49
+++ b/target/arm/sme_helper.c
50
@@ -XXX,XX +XXX,XX @@ DO_ST(q, _be, MO_128)
51
DO_ST(q, _le, MO_128)
52
53
#undef DO_ST
59
+
54
+
60
+static void gpio_pwr_reset(void *opaque, int n, int level)
55
+void HELPER(sme_addha_s)(void *vzda, void *vzn, void *vpn,
56
+ void *vpm, uint32_t desc)
61
+{
57
+{
62
+ if (level) {
58
+ intptr_t row, col, oprsz = simd_oprsz(desc) / 4;
63
+ qemu_system_reset_request(SHUTDOWN_CAUSE_GUEST_RESET);
59
+ uint64_t *pn = vpn, *pm = vpm;
60
+ uint32_t *zda = vzda, *zn = vzn;
61
+
62
+ for (row = 0; row < oprsz; ) {
63
+ uint64_t pa = pn[row >> 4];
64
+ do {
65
+ if (pa & 1) {
66
+ for (col = 0; col < oprsz; ) {
67
+ uint64_t pb = pm[col >> 4];
68
+ do {
69
+ if (pb & 1) {
70
+ zda[tile_vslice_index(row) + H4(col)] += zn[H4(col)];
71
+ }
72
+ pb >>= 4;
73
+ } while (++col & 15);
74
+ }
75
+ }
76
+ pa >>= 4;
77
+ } while (++row & 15);
64
+ }
78
+ }
65
+}
79
+}
66
+
80
+
67
+static void gpio_pwr_shutdown(void *opaque, int n, int level)
81
+void HELPER(sme_addha_d)(void *vzda, void *vzn, void *vpn,
82
+ void *vpm, uint32_t desc)
68
+{
83
+{
69
+ if (level) {
84
+ intptr_t row, col, oprsz = simd_oprsz(desc) / 8;
70
+ qemu_system_reset_request(SHUTDOWN_CAUSE_GUEST_SHUTDOWN);
85
+ uint8_t *pn = vpn, *pm = vpm;
86
+ uint64_t *zda = vzda, *zn = vzn;
87
+
88
+ for (row = 0; row < oprsz; ++row) {
89
+ if (pn[H1(row)] & 1) {
90
+ for (col = 0; col < oprsz; ++col) {
91
+ if (pm[H1(col)] & 1) {
92
+ zda[tile_vslice_index(row) + col] += zn[col];
93
+ }
94
+ }
95
+ }
71
+ }
96
+ }
72
+}
97
+}
73
+
98
+
74
+static void gpio_pwr_init(Object *obj)
99
+void HELPER(sme_addva_s)(void *vzda, void *vzn, void *vpn,
100
+ void *vpm, uint32_t desc)
75
+{
101
+{
76
+ DeviceState *dev = DEVICE(obj);
102
+ intptr_t row, col, oprsz = simd_oprsz(desc) / 4;
103
+ uint64_t *pn = vpn, *pm = vpm;
104
+ uint32_t *zda = vzda, *zn = vzn;
77
+
105
+
78
+ qdev_init_gpio_in_named(dev, gpio_pwr_reset, "reset", 1);
106
+ for (row = 0; row < oprsz; ) {
79
+ qdev_init_gpio_in_named(dev, gpio_pwr_shutdown, "shutdown", 1);
107
+ uint64_t pa = pn[row >> 4];
108
+ do {
109
+ if (pa & 1) {
110
+ uint32_t zn_row = zn[H4(row)];
111
+ for (col = 0; col < oprsz; ) {
112
+ uint64_t pb = pm[col >> 4];
113
+ do {
114
+ if (pb & 1) {
115
+ zda[tile_vslice_index(row) + H4(col)] += zn_row;
116
+ }
117
+ pb >>= 4;
118
+ } while (++col & 15);
119
+ }
120
+ }
121
+ pa >>= 4;
122
+ } while (++row & 15);
123
+ }
80
+}
124
+}
81
+
125
+
82
+static const TypeInfo gpio_pwr_info = {
126
+void HELPER(sme_addva_d)(void *vzda, void *vzn, void *vpn,
83
+ .name = TYPE_GPIOPWR,
127
+ void *vpm, uint32_t desc)
84
+ .parent = TYPE_SYS_BUS_DEVICE,
128
+{
85
+ .instance_size = sizeof(GPIO_PWR_State),
129
+ intptr_t row, col, oprsz = simd_oprsz(desc) / 8;
86
+ .instance_init = gpio_pwr_init,
130
+ uint8_t *pn = vpn, *pm = vpm;
87
+};
131
+ uint64_t *zda = vzda, *zn = vzn;
88
+
132
+
89
+static void gpio_pwr_register_types(void)
133
+ for (row = 0; row < oprsz; ++row) {
134
+ if (pn[H1(row)] & 1) {
135
+ uint64_t zn_row = zn[row];
136
+ for (col = 0; col < oprsz; ++col) {
137
+ if (pm[H1(col)] & 1) {
138
+ zda[tile_vslice_index(row) + col] += zn_row;
139
+ }
140
+ }
141
+ }
142
+ }
143
+}
144
diff --git a/target/arm/translate-sme.c b/target/arm/translate-sme.c
145
index XXXXXXX..XXXXXXX 100644
146
--- a/target/arm/translate-sme.c
147
+++ b/target/arm/translate-sme.c
148
@@ -XXX,XX +XXX,XX @@ static bool do_ldst_r(DisasContext *s, arg_ldstr *a, GenLdStR *fn)
149
150
TRANS_FEAT(LDR, aa64_sme, do_ldst_r, a, gen_sve_ldr)
151
TRANS_FEAT(STR, aa64_sme, do_ldst_r, a, gen_sve_str)
152
+
153
+static bool do_adda(DisasContext *s, arg_adda *a, MemOp esz,
154
+ gen_helper_gvec_4 *fn)
90
+{
155
+{
91
+ type_register_static(&gpio_pwr_info);
156
+ int svl = streaming_vec_reg_size(s);
157
+ uint32_t desc = simd_desc(svl, svl, 0);
158
+ TCGv_ptr za, zn, pn, pm;
159
+
160
+ if (!sme_smza_enabled_check(s)) {
161
+ return true;
162
+ }
163
+
164
+ /* Sum XZR+zad to find ZAd. */
165
+ za = get_tile_rowcol(s, esz, 31, a->zad, false);
166
+ zn = vec_full_reg_ptr(s, a->zn);
167
+ pn = pred_full_reg_ptr(s, a->pn);
168
+ pm = pred_full_reg_ptr(s, a->pm);
169
+
170
+ fn(za, zn, pn, pm, tcg_constant_i32(desc));
171
+
172
+ tcg_temp_free_ptr(za);
173
+ tcg_temp_free_ptr(zn);
174
+ tcg_temp_free_ptr(pn);
175
+ tcg_temp_free_ptr(pm);
176
+ return true;
92
+}
177
+}
93
+
178
+
94
+type_init(gpio_pwr_register_types)
179
+TRANS_FEAT(ADDHA_s, aa64_sme, do_adda, a, MO_32, gen_helper_sme_addha_s)
95
diff --git a/hw/gpio/Kconfig b/hw/gpio/Kconfig
180
+TRANS_FEAT(ADDVA_s, aa64_sme, do_adda, a, MO_32, gen_helper_sme_addva_s)
96
index XXXXXXX..XXXXXXX 100644
181
+TRANS_FEAT(ADDHA_d, aa64_sme_i16i64, do_adda, a, MO_64, gen_helper_sme_addha_d)
97
--- a/hw/gpio/Kconfig
182
+TRANS_FEAT(ADDVA_d, aa64_sme_i16i64, do_adda, a, MO_64, gen_helper_sme_addva_d)
98
+++ b/hw/gpio/Kconfig
99
@@ -XXX,XX +XXX,XX @@ config PL061
100
config GPIO_KEY
101
bool
102
103
+config GPIO_PWR
104
+ bool
105
+
106
config SIFIVE_GPIO
107
bool
108
diff --git a/hw/gpio/meson.build b/hw/gpio/meson.build
109
index XXXXXXX..XXXXXXX 100644
110
--- a/hw/gpio/meson.build
111
+++ b/hw/gpio/meson.build
112
@@ -XXX,XX +XXX,XX @@
113
softmmu_ss.add(when: 'CONFIG_E500', if_true: files('mpc8xxx.c'))
114
softmmu_ss.add(when: 'CONFIG_GPIO_KEY', if_true: files('gpio_key.c'))
115
+softmmu_ss.add(when: 'CONFIG_GPIO_PWR', if_true: files('gpio_pwr.c'))
116
softmmu_ss.add(when: 'CONFIG_MAX7310', if_true: files('max7310.c'))
117
softmmu_ss.add(when: 'CONFIG_PL061', if_true: files('pl061.c'))
118
softmmu_ss.add(when: 'CONFIG_PUV3', if_true: files('puv3_gpio.c'))
119
--
183
--
120
2.20.1
184
2.25.1
121
122
diff view generated by jsdifflib
1
Add a simple test of the CMSDK dual timer, since we're about to do
1
From: Richard Henderson <richard.henderson@linaro.org>
2
some refactoring of how it is clocked.
3
2
3
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
4
Message-id: 20220708151540.18136-25-richard.henderson@linaro.org
4
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
5
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
5
Tested-by: Philippe Mathieu-Daudé <f4bug@amsat.org>
6
Reviewed-by: Peter Maydell <peter.maydell@linaro.org>
6
Reviewed-by: Philippe Mathieu-Daudé <f4bug@amsat.org>
7
Reviewed-by: Luc Michel <luc@lmichel.fr>
8
Message-id: 20210128114145.20536-6-peter.maydell@linaro.org
9
Message-id: 20210121190622.22000-6-peter.maydell@linaro.org
10
---
7
---
11
tests/qtest/cmsdk-apb-dualtimer-test.c | 130 +++++++++++++++++++++++++
8
target/arm/helper-sme.h | 5 +++
12
MAINTAINERS | 1 +
9
target/arm/sme.decode | 9 +++++
13
tests/qtest/meson.build | 1 +
10
target/arm/sme_helper.c | 69 ++++++++++++++++++++++++++++++++++++++
14
3 files changed, 132 insertions(+)
11
target/arm/translate-sme.c | 32 ++++++++++++++++++
15
create mode 100644 tests/qtest/cmsdk-apb-dualtimer-test.c
12
4 files changed, 115 insertions(+)
16
13
17
diff --git a/tests/qtest/cmsdk-apb-dualtimer-test.c b/tests/qtest/cmsdk-apb-dualtimer-test.c
14
diff --git a/target/arm/helper-sme.h b/target/arm/helper-sme.h
18
new file mode 100644
15
index XXXXXXX..XXXXXXX 100644
19
index XXXXXXX..XXXXXXX
16
--- a/target/arm/helper-sme.h
20
--- /dev/null
17
+++ b/target/arm/helper-sme.h
21
+++ b/tests/qtest/cmsdk-apb-dualtimer-test.c
18
@@ -XXX,XX +XXX,XX @@ DEF_HELPER_FLAGS_5(sme_addha_s, TCG_CALL_NO_RWG, void, ptr, ptr, ptr, ptr, i32)
19
DEF_HELPER_FLAGS_5(sme_addva_s, TCG_CALL_NO_RWG, void, ptr, ptr, ptr, ptr, i32)
20
DEF_HELPER_FLAGS_5(sme_addha_d, TCG_CALL_NO_RWG, void, ptr, ptr, ptr, ptr, i32)
21
DEF_HELPER_FLAGS_5(sme_addva_d, TCG_CALL_NO_RWG, void, ptr, ptr, ptr, ptr, i32)
22
+
23
+DEF_HELPER_FLAGS_7(sme_fmopa_s, TCG_CALL_NO_RWG,
24
+ void, ptr, ptr, ptr, ptr, ptr, ptr, i32)
25
+DEF_HELPER_FLAGS_7(sme_fmopa_d, TCG_CALL_NO_RWG,
26
+ void, ptr, ptr, ptr, ptr, ptr, ptr, i32)
27
diff --git a/target/arm/sme.decode b/target/arm/sme.decode
28
index XXXXXXX..XXXXXXX 100644
29
--- a/target/arm/sme.decode
30
+++ b/target/arm/sme.decode
31
@@ -XXX,XX +XXX,XX @@ ADDHA_s 11000000 10 01000 0 ... ... ..... 000 .. @adda_32
32
ADDVA_s 11000000 10 01000 1 ... ... ..... 000 .. @adda_32
33
ADDHA_d 11000000 11 01000 0 ... ... ..... 00 ... @adda_64
34
ADDVA_d 11000000 11 01000 1 ... ... ..... 00 ... @adda_64
35
+
36
+### SME Outer Product
37
+
38
+&op zad zn zm pm pn sub:bool
39
+@op_32 ........ ... zm:5 pm:3 pn:3 zn:5 sub:1 .. zad:2 &op
40
+@op_64 ........ ... zm:5 pm:3 pn:3 zn:5 sub:1 . zad:3 &op
41
+
42
+FMOPA_s 10000000 100 ..... ... ... ..... . 00 .. @op_32
43
+FMOPA_d 10000000 110 ..... ... ... ..... . 0 ... @op_64
44
diff --git a/target/arm/sme_helper.c b/target/arm/sme_helper.c
45
index XXXXXXX..XXXXXXX 100644
46
--- a/target/arm/sme_helper.c
47
+++ b/target/arm/sme_helper.c
22
@@ -XXX,XX +XXX,XX @@
48
@@ -XXX,XX +XXX,XX @@
23
+/*
49
#include "exec/cpu_ldst.h"
24
+ * QTest testcase for the CMSDK APB dualtimer device
50
#include "exec/exec-all.h"
25
+ *
51
#include "qemu/int128.h"
26
+ * Copyright (c) 2021 Linaro Limited
52
+#include "fpu/softfloat.h"
27
+ *
53
#include "vec_internal.h"
28
+ * This program is free software; you can redistribute it and/or modify it
54
#include "sve_ldst_internal.h"
29
+ * under the terms of the GNU General Public License as published by the
55
30
+ * Free Software Foundation; either version 2 of the License, or
56
@@ -XXX,XX +XXX,XX @@ void HELPER(sme_addva_d)(void *vzda, void *vzn, void *vpn,
31
+ * (at your option) any later version.
57
}
32
+ *
58
}
33
+ * This program is distributed in the hope that it will be useful, but WITHOUT
59
}
34
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
35
+ * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
36
+ * for more details.
37
+ */
38
+
60
+
39
+#include "qemu/osdep.h"
61
+void HELPER(sme_fmopa_s)(void *vza, void *vzn, void *vzm, void *vpn,
40
+#include "libqtest-single.h"
62
+ void *vpm, void *vst, uint32_t desc)
41
+
42
+/* IoTKit/ARMSSE dualtimer; driven at 25MHz in mps2-an385, so 40ns per tick */
43
+#define TIMER_BASE 0x40002000
44
+
45
+#define TIMER1LOAD 0
46
+#define TIMER1VALUE 4
47
+#define TIMER1CONTROL 8
48
+#define TIMER1INTCLR 0xc
49
+#define TIMER1RIS 0x10
50
+#define TIMER1MIS 0x14
51
+#define TIMER1BGLOAD 0x18
52
+
53
+#define TIMER2LOAD 0x20
54
+#define TIMER2VALUE 0x24
55
+#define TIMER2CONTROL 0x28
56
+#define TIMER2INTCLR 0x2c
57
+#define TIMER2RIS 0x30
58
+#define TIMER2MIS 0x34
59
+#define TIMER2BGLOAD 0x38
60
+
61
+#define CTRL_ENABLE (1 << 7)
62
+#define CTRL_PERIODIC (1 << 6)
63
+#define CTRL_INTEN (1 << 5)
64
+#define CTRL_PRESCALE_1 (0 << 2)
65
+#define CTRL_PRESCALE_16 (1 << 2)
66
+#define CTRL_PRESCALE_256 (2 << 2)
67
+#define CTRL_32BIT (1 << 1)
68
+#define CTRL_ONESHOT (1 << 0)
69
+
70
+static void test_dualtimer(void)
71
+{
63
+{
72
+ g_assert_true(readl(TIMER_BASE + TIMER1RIS) == 0);
64
+ intptr_t row, col, oprsz = simd_maxsz(desc);
73
+
65
+ uint32_t neg = simd_data(desc) << 31;
74
+ /* Start timer: will fire after 40000 ns */
66
+ uint16_t *pn = vpn, *pm = vpm;
75
+ writel(TIMER_BASE + TIMER1LOAD, 1000);
67
+ float_status fpst;
76
+ /* enable in free-running, wrapping, interrupt mode */
77
+ writel(TIMER_BASE + TIMER1CONTROL, CTRL_ENABLE | CTRL_INTEN);
78
+
79
+ /* Step to just past the 500th tick and check VALUE */
80
+ clock_step(500 * 40 + 1);
81
+ g_assert_cmpuint(readl(TIMER_BASE + TIMER1RIS), ==, 0);
82
+ g_assert_cmpuint(readl(TIMER_BASE + TIMER1VALUE), ==, 500);
83
+
84
+ /* Just past the 1000th tick: timer should have fired */
85
+ clock_step(500 * 40);
86
+ g_assert_cmpuint(readl(TIMER_BASE + TIMER1RIS), ==, 1);
87
+ g_assert_cmpuint(readl(TIMER_BASE + TIMER1VALUE), ==, 0);
88
+
68
+
89
+ /*
69
+ /*
90
+ * We are in free-running wrapping 16-bit mode, so on the following
70
+ * Make a copy of float_status because this operation does not
91
+ * tick VALUE should have wrapped round to 0xffff.
71
+ * update the cumulative fp exception status. It also produces
72
+ * default nans.
92
+ */
73
+ */
93
+ clock_step(40);
74
+ fpst = *(float_status *)vst;
94
+ g_assert_cmpuint(readl(TIMER_BASE + TIMER1VALUE), ==, 0xffff);
75
+ set_default_nan_mode(true, &fpst);
95
+
76
+
96
+ /* Check that any write to INTCLR clears interrupt */
77
+ for (row = 0; row < oprsz; ) {
97
+ writel(TIMER_BASE + TIMER1INTCLR, 1);
78
+ uint16_t pa = pn[H2(row >> 4)];
98
+ g_assert_cmpuint(readl(TIMER_BASE + TIMER1RIS), ==, 0);
79
+ do {
80
+ if (pa & 1) {
81
+ void *vza_row = vza + tile_vslice_offset(row);
82
+ uint32_t n = *(uint32_t *)(vzn + H1_4(row)) ^ neg;
99
+
83
+
100
+ /* Turn off the timer */
84
+ for (col = 0; col < oprsz; ) {
101
+ writel(TIMER_BASE + TIMER1CONTROL, 0);
85
+ uint16_t pb = pm[H2(col >> 4)];
86
+ do {
87
+ if (pb & 1) {
88
+ uint32_t *a = vza_row + H1_4(col);
89
+ uint32_t *m = vzm + H1_4(col);
90
+ *a = float32_muladd(n, *m, *a, 0, vst);
91
+ }
92
+ col += 4;
93
+ pb >>= 4;
94
+ } while (col & 15);
95
+ }
96
+ }
97
+ row += 4;
98
+ pa >>= 4;
99
+ } while (row & 15);
100
+ }
102
+}
101
+}
103
+
102
+
104
+static void test_prescale(void)
103
+void HELPER(sme_fmopa_d)(void *vza, void *vzn, void *vzm, void *vpn,
104
+ void *vpm, void *vst, uint32_t desc)
105
+{
105
+{
106
+ g_assert_true(readl(TIMER_BASE + TIMER2RIS) == 0);
106
+ intptr_t row, col, oprsz = simd_oprsz(desc) / 8;
107
+ uint64_t neg = (uint64_t)simd_data(desc) << 63;
108
+ uint64_t *za = vza, *zn = vzn, *zm = vzm;
109
+ uint8_t *pn = vpn, *pm = vpm;
110
+ float_status fpst = *(float_status *)vst;
107
+
111
+
108
+ /* Start timer: will fire after 40 * 256 * 1000 == 1024000 ns */
112
+ set_default_nan_mode(true, &fpst);
109
+ writel(TIMER_BASE + TIMER2LOAD, 1000);
110
+ /* enable in periodic, wrapping, interrupt mode, prescale 256 */
111
+ writel(TIMER_BASE + TIMER2CONTROL,
112
+ CTRL_ENABLE | CTRL_INTEN | CTRL_PERIODIC | CTRL_PRESCALE_256);
113
+
113
+
114
+ /* Step to just past the 500th tick and check VALUE */
114
+ for (row = 0; row < oprsz; ++row) {
115
+ clock_step(40 * 256 * 501);
115
+ if (pn[H1(row)] & 1) {
116
+ g_assert_cmpuint(readl(TIMER_BASE + TIMER2RIS), ==, 0);
116
+ uint64_t *za_row = &za[tile_vslice_index(row)];
117
+ g_assert_cmpuint(readl(TIMER_BASE + TIMER2VALUE), ==, 500);
117
+ uint64_t n = zn[row] ^ neg;
118
+
118
+
119
+ /* Just past the 1000th tick: timer should have fired */
119
+ for (col = 0; col < oprsz; ++col) {
120
+ clock_step(40 * 256 * 500);
120
+ if (pm[H1(col)] & 1) {
121
+ g_assert_cmpuint(readl(TIMER_BASE + TIMER2RIS), ==, 1);
121
+ uint64_t *a = &za_row[col];
122
+ g_assert_cmpuint(readl(TIMER_BASE + TIMER2VALUE), ==, 0);
122
+ *a = float64_muladd(n, zm[col], *a, 0, &fpst);
123
+ }
124
+ }
125
+ }
126
+ }
127
+}
128
diff --git a/target/arm/translate-sme.c b/target/arm/translate-sme.c
129
index XXXXXXX..XXXXXXX 100644
130
--- a/target/arm/translate-sme.c
131
+++ b/target/arm/translate-sme.c
132
@@ -XXX,XX +XXX,XX @@ TRANS_FEAT(ADDHA_s, aa64_sme, do_adda, a, MO_32, gen_helper_sme_addha_s)
133
TRANS_FEAT(ADDVA_s, aa64_sme, do_adda, a, MO_32, gen_helper_sme_addva_s)
134
TRANS_FEAT(ADDHA_d, aa64_sme_i16i64, do_adda, a, MO_64, gen_helper_sme_addha_d)
135
TRANS_FEAT(ADDVA_d, aa64_sme_i16i64, do_adda, a, MO_64, gen_helper_sme_addva_d)
123
+
136
+
124
+ /* In periodic mode the tick VALUE now reloads */
137
+static bool do_outprod_fpst(DisasContext *s, arg_op *a, MemOp esz,
125
+ clock_step(40 * 256);
138
+ gen_helper_gvec_5_ptr *fn)
126
+ g_assert_cmpuint(readl(TIMER_BASE + TIMER2VALUE), ==, 1000);
139
+{
140
+ int svl = streaming_vec_reg_size(s);
141
+ uint32_t desc = simd_desc(svl, svl, a->sub);
142
+ TCGv_ptr za, zn, zm, pn, pm, fpst;
127
+
143
+
128
+ /* Check that any write to INTCLR clears interrupt */
144
+ if (!sme_smza_enabled_check(s)) {
129
+ writel(TIMER_BASE + TIMER2INTCLR, 1);
145
+ return true;
130
+ g_assert_cmpuint(readl(TIMER_BASE + TIMER2RIS), ==, 0);
146
+ }
131
+
147
+
132
+ /* Turn off the timer */
148
+ /* Sum XZR+zad to find ZAd. */
133
+ writel(TIMER_BASE + TIMER2CONTROL, 0);
149
+ za = get_tile_rowcol(s, esz, 31, a->zad, false);
150
+ zn = vec_full_reg_ptr(s, a->zn);
151
+ zm = vec_full_reg_ptr(s, a->zm);
152
+ pn = pred_full_reg_ptr(s, a->pn);
153
+ pm = pred_full_reg_ptr(s, a->pm);
154
+ fpst = fpstatus_ptr(FPST_FPCR);
155
+
156
+ fn(za, zn, zm, pn, pm, fpst, tcg_constant_i32(desc));
157
+
158
+ tcg_temp_free_ptr(za);
159
+ tcg_temp_free_ptr(zn);
160
+ tcg_temp_free_ptr(pn);
161
+ tcg_temp_free_ptr(pm);
162
+ tcg_temp_free_ptr(fpst);
163
+ return true;
134
+}
164
+}
135
+
165
+
136
+int main(int argc, char **argv)
166
+TRANS_FEAT(FMOPA_s, aa64_sme, do_outprod_fpst, a, MO_32, gen_helper_sme_fmopa_s)
137
+{
167
+TRANS_FEAT(FMOPA_d, aa64_sme_f64f64, do_outprod_fpst, a, MO_64, gen_helper_sme_fmopa_d)
138
+ int r;
139
+
140
+ g_test_init(&argc, &argv, NULL);
141
+
142
+ qtest_start("-machine mps2-an385");
143
+
144
+ qtest_add_func("/cmsdk-apb-dualtimer/dualtimer", test_dualtimer);
145
+ qtest_add_func("/cmsdk-apb-dualtimer/prescale", test_prescale);
146
+
147
+ r = g_test_run();
148
+
149
+ qtest_end();
150
+
151
+ return r;
152
+}
153
diff --git a/MAINTAINERS b/MAINTAINERS
154
index XXXXXXX..XXXXXXX 100644
155
--- a/MAINTAINERS
156
+++ b/MAINTAINERS
157
@@ -XXX,XX +XXX,XX @@ F: include/hw/timer/cmsdk-apb-timer.h
158
F: tests/qtest/cmsdk-apb-timer-test.c
159
F: hw/timer/cmsdk-apb-dualtimer.c
160
F: include/hw/timer/cmsdk-apb-dualtimer.h
161
+F: tests/qtest/cmsdk-apb-dualtimer-test.c
162
F: hw/char/cmsdk-apb-uart.c
163
F: include/hw/char/cmsdk-apb-uart.h
164
F: hw/watchdog/cmsdk-apb-watchdog.c
165
diff --git a/tests/qtest/meson.build b/tests/qtest/meson.build
166
index XXXXXXX..XXXXXXX 100644
167
--- a/tests/qtest/meson.build
168
+++ b/tests/qtest/meson.build
169
@@ -XXX,XX +XXX,XX @@ qtests_npcm7xx = \
170
'npcm7xx_timer-test',
171
'npcm7xx_watchdog_timer-test']
172
qtests_arm = \
173
+ (config_all_devices.has_key('CONFIG_CMSDK_APB_DUALTIMER') ? ['cmsdk-apb-dualtimer-test'] : []) + \
174
(config_all_devices.has_key('CONFIG_CMSDK_APB_TIMER') ? ['cmsdk-apb-timer-test'] : []) + \
175
(config_all_devices.has_key('CONFIG_CMSDK_APB_WATCHDOG') ? ['cmsdk-apb-watchdog-test'] : []) + \
176
(config_all_devices.has_key('CONFIG_PFLASH_CFI02') ? ['pflash-cfi02-test'] : []) + \
177
--
168
--
178
2.20.1
169
2.25.1
179
180
diff view generated by jsdifflib
1
The ptimer API currently provides two methods for setting the period:
1
From: Richard Henderson <richard.henderson@linaro.org>
2
ptimer_set_period(), which takes a period in nanoseconds, and
3
ptimer_set_freq(), which takes a frequency in Hz. Neither of these
4
lines up nicely with the Clock API, because although both the Clock
5
and the ptimer track the frequency using a representation of whole
6
and fractional nanoseconds, conversion via either period-in-ns or
7
frequency-in-Hz will introduce a rounding error.
8
2
9
Add a new function ptimer_set_period_from_clock() which takes the
3
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
10
Clock object directly to avoid the rounding issues. This includes a
4
Message-id: 20220708151540.18136-26-richard.henderson@linaro.org
11
facility for the user to specify that there is a frequency divider
5
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
12
between the Clock proper and the timer, as some timer devices like
6
Reviewed-by: Peter Maydell <peter.maydell@linaro.org>
13
the CMSDK APB dualtimer need this.
7
---
8
target/arm/helper-sme.h | 2 ++
9
target/arm/sme.decode | 2 ++
10
target/arm/sme_helper.c | 56 ++++++++++++++++++++++++++++++++++++++
11
target/arm/translate-sme.c | 30 ++++++++++++++++++++
12
4 files changed, 90 insertions(+)
14
13
15
To avoid having to drag in clock.h from ptimer.h we add the Clock
14
diff --git a/target/arm/helper-sme.h b/target/arm/helper-sme.h
16
type to typedefs.h.
17
18
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
19
Reviewed-by: Luc Michel <luc@lmichel.fr>
20
Tested-by: Philippe Mathieu-Daudé <f4bug@amsat.org>
21
Reviewed-by: Philippe Mathieu-Daudé <f4bug@amsat.org>
22
Message-id: 20210128114145.20536-2-peter.maydell@linaro.org
23
Message-id: 20210121190622.22000-2-peter.maydell@linaro.org
24
---
25
include/hw/ptimer.h | 22 ++++++++++++++++++++++
26
include/qemu/typedefs.h | 1 +
27
hw/core/ptimer.c | 34 ++++++++++++++++++++++++++++++++++
28
3 files changed, 57 insertions(+)
29
30
diff --git a/include/hw/ptimer.h b/include/hw/ptimer.h
31
index XXXXXXX..XXXXXXX 100644
15
index XXXXXXX..XXXXXXX 100644
32
--- a/include/hw/ptimer.h
16
--- a/target/arm/helper-sme.h
33
+++ b/include/hw/ptimer.h
17
+++ b/target/arm/helper-sme.h
34
@@ -XXX,XX +XXX,XX @@ void ptimer_transaction_commit(ptimer_state *s);
18
@@ -XXX,XX +XXX,XX @@ DEF_HELPER_FLAGS_7(sme_fmopa_s, TCG_CALL_NO_RWG,
35
*/
19
void, ptr, ptr, ptr, ptr, ptr, ptr, i32)
36
void ptimer_set_period(ptimer_state *s, int64_t period);
20
DEF_HELPER_FLAGS_7(sme_fmopa_d, TCG_CALL_NO_RWG,
37
21
void, ptr, ptr, ptr, ptr, ptr, ptr, i32)
38
+/**
22
+DEF_HELPER_FLAGS_6(sme_bfmopa, TCG_CALL_NO_RWG,
39
+ * ptimer_set_period_from_clock - Set counter increment from a Clock
23
+ void, ptr, ptr, ptr, ptr, ptr, i32)
40
+ * @s: ptimer to configure
24
diff --git a/target/arm/sme.decode b/target/arm/sme.decode
41
+ * @clk: pointer to Clock object to take period from
25
index XXXXXXX..XXXXXXX 100644
42
+ * @divisor: value to scale the clock frequency down by
26
--- a/target/arm/sme.decode
43
+ *
27
+++ b/target/arm/sme.decode
44
+ * If the ptimer is being driven from a Clock, this is the preferred
28
@@ -XXX,XX +XXX,XX @@ ADDVA_d 11000000 11 01000 1 ... ... ..... 00 ... @adda_64
45
+ * way to tell the ptimer about the period, because it avoids any
29
46
+ * possible rounding errors that might happen if the internal
30
FMOPA_s 10000000 100 ..... ... ... ..... . 00 .. @op_32
47
+ * representation of the Clock period was converted to either a period
31
FMOPA_d 10000000 110 ..... ... ... ..... . 0 ... @op_64
48
+ * in ns or a frequency in Hz.
49
+ *
50
+ * If the ptimer should run at the same frequency as the clock,
51
+ * pass 1 as the @divisor; if the ptimer should run at half the
52
+ * frequency, pass 2, and so on.
53
+ *
54
+ * This function will assert if it is called outside a
55
+ * ptimer_transaction_begin/commit block.
56
+ */
57
+void ptimer_set_period_from_clock(ptimer_state *s, const Clock *clock,
58
+ unsigned int divisor);
59
+
32
+
60
/**
33
+BFMOPA 10000001 100 ..... ... ... ..... . 00 .. @op_32
61
* ptimer_set_freq - Set counter frequency in Hz
34
diff --git a/target/arm/sme_helper.c b/target/arm/sme_helper.c
62
* @s: ptimer to configure
63
diff --git a/include/qemu/typedefs.h b/include/qemu/typedefs.h
64
index XXXXXXX..XXXXXXX 100644
35
index XXXXXXX..XXXXXXX 100644
65
--- a/include/qemu/typedefs.h
36
--- a/target/arm/sme_helper.c
66
+++ b/include/qemu/typedefs.h
37
+++ b/target/arm/sme_helper.c
67
@@ -XXX,XX +XXX,XX @@ typedef struct BlockDriverState BlockDriverState;
38
@@ -XXX,XX +XXX,XX @@ void HELPER(sme_fmopa_d)(void *vza, void *vzn, void *vzm, void *vpn,
68
typedef struct BusClass BusClass;
39
}
69
typedef struct BusState BusState;
70
typedef struct Chardev Chardev;
71
+typedef struct Clock Clock;
72
typedef struct CompatProperty CompatProperty;
73
typedef struct CoMutex CoMutex;
74
typedef struct CPUAddressSpace CPUAddressSpace;
75
diff --git a/hw/core/ptimer.c b/hw/core/ptimer.c
76
index XXXXXXX..XXXXXXX 100644
77
--- a/hw/core/ptimer.c
78
+++ b/hw/core/ptimer.c
79
@@ -XXX,XX +XXX,XX @@
80
#include "sysemu/qtest.h"
81
#include "block/aio.h"
82
#include "sysemu/cpus.h"
83
+#include "hw/clock.h"
84
85
#define DELTA_ADJUST 1
86
#define DELTA_NO_ADJUST -1
87
@@ -XXX,XX +XXX,XX @@ void ptimer_set_period(ptimer_state *s, int64_t period)
88
}
40
}
89
}
41
}
90
42
+
91
+/* Set counter increment interval from a Clock */
43
+/*
92
+void ptimer_set_period_from_clock(ptimer_state *s, const Clock *clk,
44
+ * Alter PAIR as needed for controlling predicates being false,
93
+ unsigned int divisor)
45
+ * and for NEG on an enabled row element.
46
+ */
47
+static inline uint32_t f16mop_adj_pair(uint32_t pair, uint32_t pg, uint32_t neg)
94
+{
48
+{
95
+ /*
49
+ /*
96
+ * The raw clock period is a 64-bit value in units of 2^-32 ns;
50
+ * The pseudocode uses a conditional negate after the conditional zero.
97
+ * put another way it's a 32.32 fixed-point ns value. Our internal
51
+ * It is simpler here to unconditionally negate before conditional zero.
98
+ * representation of the period is 64.32 fixed point ns, so
99
+ * the conversion is simple.
100
+ */
52
+ */
101
+ uint64_t raw_period = clock_get(clk);
53
+ pair ^= neg;
102
+ uint64_t period_frac;
54
+ if (!(pg & 1)) {
55
+ pair &= 0xffff0000u;
56
+ }
57
+ if (!(pg & 4)) {
58
+ pair &= 0x0000ffffu;
59
+ }
60
+ return pair;
61
+}
103
+
62
+
104
+ assert(s->in_transaction);
63
+void HELPER(sme_bfmopa)(void *vza, void *vzn, void *vzm, void *vpn,
105
+ s->delta = ptimer_get_count(s);
64
+ void *vpm, uint32_t desc)
106
+ s->period = extract64(raw_period, 32, 32);
65
+{
107
+ period_frac = extract64(raw_period, 0, 32);
66
+ intptr_t row, col, oprsz = simd_maxsz(desc);
108
+ /*
67
+ uint32_t neg = simd_data(desc) * 0x80008000u;
109
+ * divisor specifies a possible frequency divisor between the
68
+ uint16_t *pn = vpn, *pm = vpm;
110
+ * clock and the timer, so it is a multiplier on the period.
111
+ * We do the multiply after splitting the raw period out into
112
+ * period and frac to avoid having to do a 32*64->96 multiply.
113
+ */
114
+ s->period *= divisor;
115
+ period_frac *= divisor;
116
+ s->period += extract64(period_frac, 32, 32);
117
+ s->period_frac = (uint32_t)period_frac;
118
+
69
+
119
+ if (s->enabled) {
70
+ for (row = 0; row < oprsz; ) {
120
+ s->need_reload = true;
71
+ uint16_t prow = pn[H2(row >> 4)];
72
+ do {
73
+ void *vza_row = vza + tile_vslice_offset(row);
74
+ uint32_t n = *(uint32_t *)(vzn + H1_4(row));
75
+
76
+ n = f16mop_adj_pair(n, prow, neg);
77
+
78
+ for (col = 0; col < oprsz; ) {
79
+ uint16_t pcol = pm[H2(col >> 4)];
80
+ do {
81
+ if (prow & pcol & 0b0101) {
82
+ uint32_t *a = vza_row + H1_4(col);
83
+ uint32_t m = *(uint32_t *)(vzm + H1_4(col));
84
+
85
+ m = f16mop_adj_pair(m, pcol, 0);
86
+ *a = bfdotadd(*a, n, m);
87
+
88
+ col += 4;
89
+ pcol >>= 4;
90
+ }
91
+ } while (col & 15);
92
+ }
93
+ row += 4;
94
+ prow >>= 4;
95
+ } while (row & 15);
121
+ }
96
+ }
122
+}
97
+}
98
diff --git a/target/arm/translate-sme.c b/target/arm/translate-sme.c
99
index XXXXXXX..XXXXXXX 100644
100
--- a/target/arm/translate-sme.c
101
+++ b/target/arm/translate-sme.c
102
@@ -XXX,XX +XXX,XX @@ TRANS_FEAT(ADDVA_s, aa64_sme, do_adda, a, MO_32, gen_helper_sme_addva_s)
103
TRANS_FEAT(ADDHA_d, aa64_sme_i16i64, do_adda, a, MO_64, gen_helper_sme_addha_d)
104
TRANS_FEAT(ADDVA_d, aa64_sme_i16i64, do_adda, a, MO_64, gen_helper_sme_addva_d)
105
106
+static bool do_outprod(DisasContext *s, arg_op *a, MemOp esz,
107
+ gen_helper_gvec_5 *fn)
108
+{
109
+ int svl = streaming_vec_reg_size(s);
110
+ uint32_t desc = simd_desc(svl, svl, a->sub);
111
+ TCGv_ptr za, zn, zm, pn, pm;
123
+
112
+
124
/* Set counter frequency in Hz. */
113
+ if (!sme_smza_enabled_check(s)) {
125
void ptimer_set_freq(ptimer_state *s, uint32_t freq)
114
+ return true;
115
+ }
116
+
117
+ /* Sum XZR+zad to find ZAd. */
118
+ za = get_tile_rowcol(s, esz, 31, a->zad, false);
119
+ zn = vec_full_reg_ptr(s, a->zn);
120
+ zm = vec_full_reg_ptr(s, a->zm);
121
+ pn = pred_full_reg_ptr(s, a->pn);
122
+ pm = pred_full_reg_ptr(s, a->pm);
123
+
124
+ fn(za, zn, zm, pn, pm, tcg_constant_i32(desc));
125
+
126
+ tcg_temp_free_ptr(za);
127
+ tcg_temp_free_ptr(zn);
128
+ tcg_temp_free_ptr(pn);
129
+ tcg_temp_free_ptr(pm);
130
+ return true;
131
+}
132
+
133
static bool do_outprod_fpst(DisasContext *s, arg_op *a, MemOp esz,
134
gen_helper_gvec_5_ptr *fn)
126
{
135
{
136
@@ -XXX,XX +XXX,XX @@ static bool do_outprod_fpst(DisasContext *s, arg_op *a, MemOp esz,
137
138
TRANS_FEAT(FMOPA_s, aa64_sme, do_outprod_fpst, a, MO_32, gen_helper_sme_fmopa_s)
139
TRANS_FEAT(FMOPA_d, aa64_sme_f64f64, do_outprod_fpst, a, MO_64, gen_helper_sme_fmopa_d)
140
+
141
+/* TODO: FEAT_EBF16 */
142
+TRANS_FEAT(BFMOPA, aa64_sme, do_outprod, a, MO_32, gen_helper_sme_bfmopa)
127
--
143
--
128
2.20.1
144
2.25.1
129
130
diff view generated by jsdifflib
1
Switch the CMSDK APB timer device over to using its Clock input; the
1
From: Richard Henderson <richard.henderson@linaro.org>
2
pclk-frq property is now ignored.
3
2
3
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
4
Message-id: 20220708151540.18136-27-richard.henderson@linaro.org
4
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
5
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
5
Reviewed-by: Philippe Mathieu-Daudé <f4bug@amsat.org>
6
Reviewed-by: Peter Maydell <peter.maydell@linaro.org>
6
Reviewed-by: Luc Michel <luc@lmichel.fr>
7
Tested-by: Philippe Mathieu-Daudé <f4bug@amsat.org>
8
Message-id: 20210128114145.20536-19-peter.maydell@linaro.org
9
Message-id: 20210121190622.22000-19-peter.maydell@linaro.org
10
---
7
---
11
hw/timer/cmsdk-apb-timer.c | 18 ++++++++++++++----
8
target/arm/helper-sme.h | 2 ++
12
1 file changed, 14 insertions(+), 4 deletions(-)
9
target/arm/sme.decode | 1 +
10
target/arm/sme_helper.c | 74 ++++++++++++++++++++++++++++++++++++++
11
target/arm/translate-sme.c | 1 +
12
4 files changed, 78 insertions(+)
13
13
14
diff --git a/hw/timer/cmsdk-apb-timer.c b/hw/timer/cmsdk-apb-timer.c
14
diff --git a/target/arm/helper-sme.h b/target/arm/helper-sme.h
15
index XXXXXXX..XXXXXXX 100644
15
index XXXXXXX..XXXXXXX 100644
16
--- a/hw/timer/cmsdk-apb-timer.c
16
--- a/target/arm/helper-sme.h
17
+++ b/hw/timer/cmsdk-apb-timer.c
17
+++ b/target/arm/helper-sme.h
18
@@ -XXX,XX +XXX,XX @@ static void cmsdk_apb_timer_reset(DeviceState *dev)
18
@@ -XXX,XX +XXX,XX @@ DEF_HELPER_FLAGS_5(sme_addva_s, TCG_CALL_NO_RWG, void, ptr, ptr, ptr, ptr, i32)
19
ptimer_transaction_commit(s->timer);
19
DEF_HELPER_FLAGS_5(sme_addha_d, TCG_CALL_NO_RWG, void, ptr, ptr, ptr, ptr, i32)
20
DEF_HELPER_FLAGS_5(sme_addva_d, TCG_CALL_NO_RWG, void, ptr, ptr, ptr, ptr, i32)
21
22
+DEF_HELPER_FLAGS_7(sme_fmopa_h, TCG_CALL_NO_RWG,
23
+ void, ptr, ptr, ptr, ptr, ptr, ptr, i32)
24
DEF_HELPER_FLAGS_7(sme_fmopa_s, TCG_CALL_NO_RWG,
25
void, ptr, ptr, ptr, ptr, ptr, ptr, i32)
26
DEF_HELPER_FLAGS_7(sme_fmopa_d, TCG_CALL_NO_RWG,
27
diff --git a/target/arm/sme.decode b/target/arm/sme.decode
28
index XXXXXXX..XXXXXXX 100644
29
--- a/target/arm/sme.decode
30
+++ b/target/arm/sme.decode
31
@@ -XXX,XX +XXX,XX @@ FMOPA_s 10000000 100 ..... ... ... ..... . 00 .. @op_32
32
FMOPA_d 10000000 110 ..... ... ... ..... . 0 ... @op_64
33
34
BFMOPA 10000001 100 ..... ... ... ..... . 00 .. @op_32
35
+FMOPA_h 10000001 101 ..... ... ... ..... . 00 .. @op_32
36
diff --git a/target/arm/sme_helper.c b/target/arm/sme_helper.c
37
index XXXXXXX..XXXXXXX 100644
38
--- a/target/arm/sme_helper.c
39
+++ b/target/arm/sme_helper.c
40
@@ -XXX,XX +XXX,XX @@ static inline uint32_t f16mop_adj_pair(uint32_t pair, uint32_t pg, uint32_t neg)
41
return pair;
20
}
42
}
21
43
22
+static void cmsdk_apb_timer_clk_update(void *opaque)
44
+static float32 f16_dotadd(float32 sum, uint32_t e1, uint32_t e2,
45
+ float_status *s_std, float_status *s_odd)
23
+{
46
+{
24
+ CMSDKAPBTimer *s = CMSDK_APB_TIMER(opaque);
47
+ float64 e1r = float16_to_float64(e1 & 0xffff, true, s_std);
48
+ float64 e1c = float16_to_float64(e1 >> 16, true, s_std);
49
+ float64 e2r = float16_to_float64(e2 & 0xffff, true, s_std);
50
+ float64 e2c = float16_to_float64(e2 >> 16, true, s_std);
51
+ float64 t64;
52
+ float32 t32;
25
+
53
+
26
+ ptimer_transaction_begin(s->timer);
54
+ /*
27
+ ptimer_set_period_from_clock(s->timer, s->pclk, 1);
55
+ * The ARM pseudocode function FPDot performs both multiplies
28
+ ptimer_transaction_commit(s->timer);
56
+ * and the add with a single rounding operation. Emulate this
57
+ * by performing the first multiply in round-to-odd, then doing
58
+ * the second multiply as fused multiply-add, and rounding to
59
+ * float32 all in one step.
60
+ */
61
+ t64 = float64_mul(e1r, e2r, s_odd);
62
+ t64 = float64r32_muladd(e1c, e2c, t64, 0, s_std);
63
+
64
+ /* This conversion is exact, because we've already rounded. */
65
+ t32 = float64_to_float32(t64, s_std);
66
+
67
+ /* The final accumulation step is not fused. */
68
+ return float32_add(sum, t32, s_std);
29
+}
69
+}
30
+
70
+
31
static void cmsdk_apb_timer_init(Object *obj)
71
+void HELPER(sme_fmopa_h)(void *vza, void *vzn, void *vzm, void *vpn,
72
+ void *vpm, void *vst, uint32_t desc)
73
+{
74
+ intptr_t row, col, oprsz = simd_maxsz(desc);
75
+ uint32_t neg = simd_data(desc) * 0x80008000u;
76
+ uint16_t *pn = vpn, *pm = vpm;
77
+ float_status fpst_odd, fpst_std;
78
+
79
+ /*
80
+ * Make a copy of float_status because this operation does not
81
+ * update the cumulative fp exception status. It also produces
82
+ * default nans. Make a second copy with round-to-odd -- see above.
83
+ */
84
+ fpst_std = *(float_status *)vst;
85
+ set_default_nan_mode(true, &fpst_std);
86
+ fpst_odd = fpst_std;
87
+ set_float_rounding_mode(float_round_to_odd, &fpst_odd);
88
+
89
+ for (row = 0; row < oprsz; ) {
90
+ uint16_t prow = pn[H2(row >> 4)];
91
+ do {
92
+ void *vza_row = vza + tile_vslice_offset(row);
93
+ uint32_t n = *(uint32_t *)(vzn + H1_4(row));
94
+
95
+ n = f16mop_adj_pair(n, prow, neg);
96
+
97
+ for (col = 0; col < oprsz; ) {
98
+ uint16_t pcol = pm[H2(col >> 4)];
99
+ do {
100
+ if (prow & pcol & 0b0101) {
101
+ uint32_t *a = vza_row + H1_4(col);
102
+ uint32_t m = *(uint32_t *)(vzm + H1_4(col));
103
+
104
+ m = f16mop_adj_pair(m, pcol, 0);
105
+ *a = f16_dotadd(*a, n, m, &fpst_std, &fpst_odd);
106
+
107
+ col += 4;
108
+ pcol >>= 4;
109
+ }
110
+ } while (col & 15);
111
+ }
112
+ row += 4;
113
+ prow >>= 4;
114
+ } while (row & 15);
115
+ }
116
+}
117
+
118
void HELPER(sme_bfmopa)(void *vza, void *vzn, void *vzm, void *vpn,
119
void *vpm, uint32_t desc)
32
{
120
{
33
SysBusDevice *sbd = SYS_BUS_DEVICE(obj);
121
diff --git a/target/arm/translate-sme.c b/target/arm/translate-sme.c
34
@@ -XXX,XX +XXX,XX @@ static void cmsdk_apb_timer_init(Object *obj)
122
index XXXXXXX..XXXXXXX 100644
35
s, "cmsdk-apb-timer", 0x1000);
123
--- a/target/arm/translate-sme.c
36
sysbus_init_mmio(sbd, &s->iomem);
124
+++ b/target/arm/translate-sme.c
37
sysbus_init_irq(sbd, &s->timerint);
125
@@ -XXX,XX +XXX,XX @@ static bool do_outprod_fpst(DisasContext *s, arg_op *a, MemOp esz,
38
- s->pclk = qdev_init_clock_in(DEVICE(s), "pclk", NULL, NULL);
126
return true;
39
+ s->pclk = qdev_init_clock_in(DEVICE(s), "pclk",
40
+ cmsdk_apb_timer_clk_update, s);
41
}
127
}
42
128
43
static void cmsdk_apb_timer_realize(DeviceState *dev, Error **errp)
129
+TRANS_FEAT(FMOPA_h, aa64_sme, do_outprod_fpst, a, MO_32, gen_helper_sme_fmopa_h)
44
{
130
TRANS_FEAT(FMOPA_s, aa64_sme, do_outprod_fpst, a, MO_32, gen_helper_sme_fmopa_s)
45
CMSDKAPBTimer *s = CMSDK_APB_TIMER(dev);
131
TRANS_FEAT(FMOPA_d, aa64_sme_f64f64, do_outprod_fpst, a, MO_64, gen_helper_sme_fmopa_d)
46
47
- if (s->pclk_frq == 0) {
48
- error_setg(errp, "CMSDK APB timer: pclk-frq property must be set");
49
+ if (!clock_has_source(s->pclk)) {
50
+ error_setg(errp, "CMSDK APB timer: pclk clock must be connected");
51
return;
52
}
53
54
@@ -XXX,XX +XXX,XX @@ static void cmsdk_apb_timer_realize(DeviceState *dev, Error **errp)
55
PTIMER_POLICY_NO_COUNTER_ROUND_DOWN);
56
57
ptimer_transaction_begin(s->timer);
58
- ptimer_set_freq(s->timer, s->pclk_frq);
59
+ ptimer_set_period_from_clock(s->timer, s->pclk, 1);
60
ptimer_transaction_commit(s->timer);
61
}
62
132
63
--
133
--
64
2.20.1
134
2.25.1
65
66
diff view generated by jsdifflib
1
From: Mihai Carabas <mihai.carabas@oracle.com>
1
From: Richard Henderson <richard.henderson@linaro.org>
2
2
3
Add PCI interface support for PVPANIC device. Create a new file pvpanic-pci.c
3
This is SMOPA, SUMOPA, USMOPA_s, UMOPA, for both Int8 and Int16.
4
where the PCI specific routines reside and update the build system with the new
5
files and config structure.
6
4
7
Signed-off-by: Mihai Carabas <mihai.carabas@oracle.com>
8
Reviewed-by: Gerd Hoffmann <kraxel@redhat.com>
9
Reviewed-by: Peter Maydell <peter.maydell@linaro.org>
5
Reviewed-by: Peter Maydell <peter.maydell@linaro.org>
10
Signed-off-by: Mihai Carabas <mihai.carabas@oracle.com>
6
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
7
Message-id: 20220708151540.18136-28-richard.henderson@linaro.org
11
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
8
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
12
---
9
---
13
docs/specs/pci-ids.txt | 1 +
10
target/arm/helper-sme.h | 16 ++++++++
14
include/hw/misc/pvpanic.h | 1 +
11
target/arm/sme.decode | 10 +++++
15
include/hw/pci/pci.h | 1 +
12
target/arm/sme_helper.c | 82 ++++++++++++++++++++++++++++++++++++++
16
hw/misc/pvpanic-pci.c | 94 +++++++++++++++++++++++++++++++++++++++
13
target/arm/translate-sme.c | 10 +++++
17
hw/misc/Kconfig | 6 +++
14
4 files changed, 118 insertions(+)
18
hw/misc/meson.build | 1 +
19
6 files changed, 104 insertions(+)
20
create mode 100644 hw/misc/pvpanic-pci.c
21
15
22
diff --git a/docs/specs/pci-ids.txt b/docs/specs/pci-ids.txt
16
diff --git a/target/arm/helper-sme.h b/target/arm/helper-sme.h
23
index XXXXXXX..XXXXXXX 100644
17
index XXXXXXX..XXXXXXX 100644
24
--- a/docs/specs/pci-ids.txt
18
--- a/target/arm/helper-sme.h
25
+++ b/docs/specs/pci-ids.txt
19
+++ b/target/arm/helper-sme.h
26
@@ -XXX,XX +XXX,XX @@ PCI devices (other than virtio):
20
@@ -XXX,XX +XXX,XX @@ DEF_HELPER_FLAGS_7(sme_fmopa_d, TCG_CALL_NO_RWG,
27
1b36:000d PCI xhci usb host adapter
21
void, ptr, ptr, ptr, ptr, ptr, ptr, i32)
28
1b36:000f mdpy (mdev sample device), linux/samples/vfio-mdev/mdpy.c
22
DEF_HELPER_FLAGS_6(sme_bfmopa, TCG_CALL_NO_RWG,
29
1b36:0010 PCIe NVMe device (-device nvme)
23
void, ptr, ptr, ptr, ptr, ptr, i32)
30
+1b36:0011 PCI PVPanic device (-device pvpanic-pci)
24
+DEF_HELPER_FLAGS_6(sme_smopa_s, TCG_CALL_NO_RWG,
31
25
+ void, ptr, ptr, ptr, ptr, ptr, i32)
32
All these devices are documented in docs/specs.
26
+DEF_HELPER_FLAGS_6(sme_umopa_s, TCG_CALL_NO_RWG,
33
27
+ void, ptr, ptr, ptr, ptr, ptr, i32)
34
diff --git a/include/hw/misc/pvpanic.h b/include/hw/misc/pvpanic.h
28
+DEF_HELPER_FLAGS_6(sme_sumopa_s, TCG_CALL_NO_RWG,
29
+ void, ptr, ptr, ptr, ptr, ptr, i32)
30
+DEF_HELPER_FLAGS_6(sme_usmopa_s, TCG_CALL_NO_RWG,
31
+ void, ptr, ptr, ptr, ptr, ptr, i32)
32
+DEF_HELPER_FLAGS_6(sme_smopa_d, TCG_CALL_NO_RWG,
33
+ void, ptr, ptr, ptr, ptr, ptr, i32)
34
+DEF_HELPER_FLAGS_6(sme_umopa_d, TCG_CALL_NO_RWG,
35
+ void, ptr, ptr, ptr, ptr, ptr, i32)
36
+DEF_HELPER_FLAGS_6(sme_sumopa_d, TCG_CALL_NO_RWG,
37
+ void, ptr, ptr, ptr, ptr, ptr, i32)
38
+DEF_HELPER_FLAGS_6(sme_usmopa_d, TCG_CALL_NO_RWG,
39
+ void, ptr, ptr, ptr, ptr, ptr, i32)
40
diff --git a/target/arm/sme.decode b/target/arm/sme.decode
35
index XXXXXXX..XXXXXXX 100644
41
index XXXXXXX..XXXXXXX 100644
36
--- a/include/hw/misc/pvpanic.h
42
--- a/target/arm/sme.decode
37
+++ b/include/hw/misc/pvpanic.h
43
+++ b/target/arm/sme.decode
38
@@ -XXX,XX +XXX,XX @@
44
@@ -XXX,XX +XXX,XX @@ FMOPA_d 10000000 110 ..... ... ... ..... . 0 ... @op_64
39
#include "qom/object.h"
45
40
46
BFMOPA 10000001 100 ..... ... ... ..... . 00 .. @op_32
41
#define TYPE_PVPANIC_ISA_DEVICE "pvpanic"
47
FMOPA_h 10000001 101 ..... ... ... ..... . 00 .. @op_32
42
+#define TYPE_PVPANIC_PCI_DEVICE "pvpanic-pci"
48
+
43
49
+SMOPA_s 1010000 0 10 0 ..... ... ... ..... . 00 .. @op_32
44
#define PVPANIC_IOPORT_PROP "ioport"
50
+SUMOPA_s 1010000 0 10 1 ..... ... ... ..... . 00 .. @op_32
45
51
+USMOPA_s 1010000 1 10 0 ..... ... ... ..... . 00 .. @op_32
46
diff --git a/include/hw/pci/pci.h b/include/hw/pci/pci.h
52
+UMOPA_s 1010000 1 10 1 ..... ... ... ..... . 00 .. @op_32
53
+
54
+SMOPA_d 1010000 0 11 0 ..... ... ... ..... . 0 ... @op_64
55
+SUMOPA_d 1010000 0 11 1 ..... ... ... ..... . 0 ... @op_64
56
+USMOPA_d 1010000 1 11 0 ..... ... ... ..... . 0 ... @op_64
57
+UMOPA_d 1010000 1 11 1 ..... ... ... ..... . 0 ... @op_64
58
diff --git a/target/arm/sme_helper.c b/target/arm/sme_helper.c
47
index XXXXXXX..XXXXXXX 100644
59
index XXXXXXX..XXXXXXX 100644
48
--- a/include/hw/pci/pci.h
60
--- a/target/arm/sme_helper.c
49
+++ b/include/hw/pci/pci.h
61
+++ b/target/arm/sme_helper.c
50
@@ -XXX,XX +XXX,XX @@ extern bool pci_available;
62
@@ -XXX,XX +XXX,XX @@ void HELPER(sme_bfmopa)(void *vza, void *vzn, void *vzm, void *vpn,
51
#define PCI_DEVICE_ID_REDHAT_PCIE_BRIDGE 0x000e
63
} while (row & 15);
52
#define PCI_DEVICE_ID_REDHAT_MDPY 0x000f
64
}
53
#define PCI_DEVICE_ID_REDHAT_NVME 0x0010
65
}
54
+#define PCI_DEVICE_ID_REDHAT_PVPANIC 0x0011
55
#define PCI_DEVICE_ID_REDHAT_QXL 0x0100
56
57
#define FMT_PCIBUS PRIx64
58
diff --git a/hw/misc/pvpanic-pci.c b/hw/misc/pvpanic-pci.c
59
new file mode 100644
60
index XXXXXXX..XXXXXXX
61
--- /dev/null
62
+++ b/hw/misc/pvpanic-pci.c
63
@@ -XXX,XX +XXX,XX @@
64
+/*
65
+ * QEMU simulated PCI pvpanic device.
66
+ *
67
+ * Copyright (C) 2020 Oracle
68
+ *
69
+ * Authors:
70
+ * Mihai Carabas <mihai.carabas@oracle.com>
71
+ *
72
+ * This work is licensed under the terms of the GNU GPL, version 2 or later.
73
+ * See the COPYING file in the top-level directory.
74
+ *
75
+ */
76
+
66
+
77
+#include "qemu/osdep.h"
67
+typedef uint64_t IMOPFn(uint64_t, uint64_t, uint64_t, uint8_t, bool);
78
+#include "qemu/log.h"
79
+#include "qemu/module.h"
80
+#include "sysemu/runstate.h"
81
+
68
+
82
+#include "hw/nvram/fw_cfg.h"
69
+static inline void do_imopa(uint64_t *za, uint64_t *zn, uint64_t *zm,
83
+#include "hw/qdev-properties.h"
70
+ uint8_t *pn, uint8_t *pm,
84
+#include "migration/vmstate.h"
71
+ uint32_t desc, IMOPFn *fn)
85
+#include "hw/misc/pvpanic.h"
72
+{
86
+#include "qom/object.h"
73
+ intptr_t row, col, oprsz = simd_oprsz(desc) / 8;
87
+#include "hw/pci/pci.h"
74
+ bool neg = simd_data(desc);
88
+
75
+
89
+OBJECT_DECLARE_SIMPLE_TYPE(PVPanicPCIState, PVPANIC_PCI_DEVICE)
76
+ for (row = 0; row < oprsz; ++row) {
77
+ uint8_t pa = pn[H1(row)];
78
+ uint64_t *za_row = &za[tile_vslice_index(row)];
79
+ uint64_t n = zn[row];
90
+
80
+
91
+/*
81
+ for (col = 0; col < oprsz; ++col) {
92
+ * PVPanicPCIState for PCI device
82
+ uint8_t pb = pm[H1(col)];
93
+ */
83
+ uint64_t *a = &za_row[col];
94
+typedef struct PVPanicPCIState {
95
+ PCIDevice dev;
96
+ PVPanicState pvpanic;
97
+} PVPanicPCIState;
98
+
84
+
99
+static const VMStateDescription vmstate_pvpanic_pci = {
85
+ *a = fn(n, zm[col], *a, pa & pb, neg);
100
+ .name = "pvpanic-pci",
86
+ }
101
+ .version_id = 1,
102
+ .minimum_version_id = 1,
103
+ .fields = (VMStateField[]) {
104
+ VMSTATE_PCI_DEVICE(dev, PVPanicPCIState),
105
+ VMSTATE_END_OF_LIST()
106
+ }
87
+ }
107
+};
108
+
109
+static void pvpanic_pci_realizefn(PCIDevice *dev, Error **errp)
110
+{
111
+ PVPanicPCIState *s = PVPANIC_PCI_DEVICE(dev);
112
+ PVPanicState *ps = &s->pvpanic;
113
+
114
+ pvpanic_setup_io(&s->pvpanic, DEVICE(s), 2);
115
+
116
+ pci_register_bar(dev, 0, PCI_BASE_ADDRESS_SPACE_MEMORY, &ps->mr);
117
+}
88
+}
118
+
89
+
119
+static Property pvpanic_pci_properties[] = {
90
+#define DEF_IMOP_32(NAME, NTYPE, MTYPE) \
120
+ DEFINE_PROP_UINT8("events", PVPanicPCIState, pvpanic.events, PVPANIC_PANICKED | PVPANIC_CRASHLOADED),
91
+static uint64_t NAME(uint64_t n, uint64_t m, uint64_t a, uint8_t p, bool neg) \
121
+ DEFINE_PROP_END_OF_LIST(),
92
+{ \
122
+};
93
+ uint32_t sum0 = 0, sum1 = 0; \
123
+
94
+ /* Apply P to N as a mask, making the inactive elements 0. */ \
124
+static void pvpanic_pci_class_init(ObjectClass *klass, void *data)
95
+ n &= expand_pred_b(p); \
125
+{
96
+ sum0 += (NTYPE)(n >> 0) * (MTYPE)(m >> 0); \
126
+ DeviceClass *dc = DEVICE_CLASS(klass);
97
+ sum0 += (NTYPE)(n >> 8) * (MTYPE)(m >> 8); \
127
+ PCIDeviceClass *pc = PCI_DEVICE_CLASS(klass);
98
+ sum0 += (NTYPE)(n >> 16) * (MTYPE)(m >> 16); \
128
+
99
+ sum0 += (NTYPE)(n >> 24) * (MTYPE)(m >> 24); \
129
+ device_class_set_props(dc, pvpanic_pci_properties);
100
+ sum1 += (NTYPE)(n >> 32) * (MTYPE)(m >> 32); \
130
+
101
+ sum1 += (NTYPE)(n >> 40) * (MTYPE)(m >> 40); \
131
+ pc->realize = pvpanic_pci_realizefn;
102
+ sum1 += (NTYPE)(n >> 48) * (MTYPE)(m >> 48); \
132
+ pc->vendor_id = PCI_VENDOR_ID_REDHAT;
103
+ sum1 += (NTYPE)(n >> 56) * (MTYPE)(m >> 56); \
133
+ pc->device_id = PCI_DEVICE_ID_REDHAT_PVPANIC;
104
+ if (neg) { \
134
+ pc->revision = 1;
105
+ sum0 = (uint32_t)a - sum0, sum1 = (uint32_t)(a >> 32) - sum1; \
135
+ pc->class_id = PCI_CLASS_SYSTEM_OTHER;
106
+ } else { \
136
+ dc->vmsd = &vmstate_pvpanic_pci;
107
+ sum0 = (uint32_t)a + sum0, sum1 = (uint32_t)(a >> 32) + sum1; \
137
+
108
+ } \
138
+ set_bit(DEVICE_CATEGORY_MISC, dc->categories);
109
+ return ((uint64_t)sum1 << 32) | sum0; \
139
+}
110
+}
140
+
111
+
141
+static TypeInfo pvpanic_pci_info = {
112
+#define DEF_IMOP_64(NAME, NTYPE, MTYPE) \
142
+ .name = TYPE_PVPANIC_PCI_DEVICE,
113
+static uint64_t NAME(uint64_t n, uint64_t m, uint64_t a, uint8_t p, bool neg) \
143
+ .parent = TYPE_PCI_DEVICE,
114
+{ \
144
+ .instance_size = sizeof(PVPanicPCIState),
115
+ uint64_t sum = 0; \
145
+ .class_init = pvpanic_pci_class_init,
116
+ /* Apply P to N as a mask, making the inactive elements 0. */ \
146
+ .interfaces = (InterfaceInfo[]) {
117
+ n &= expand_pred_h(p); \
147
+ { INTERFACE_CONVENTIONAL_PCI_DEVICE },
118
+ sum += (NTYPE)(n >> 0) * (MTYPE)(m >> 0); \
148
+ { }
119
+ sum += (NTYPE)(n >> 16) * (MTYPE)(m >> 16); \
149
+ }
120
+ sum += (NTYPE)(n >> 32) * (MTYPE)(m >> 32); \
150
+};
121
+ sum += (NTYPE)(n >> 48) * (MTYPE)(m >> 48); \
151
+
122
+ return neg ? a - sum : a + sum; \
152
+static void pvpanic_register_types(void)
153
+{
154
+ type_register_static(&pvpanic_pci_info);
155
+}
123
+}
156
+
124
+
157
+type_init(pvpanic_register_types);
125
+DEF_IMOP_32(smopa_s, int8_t, int8_t)
158
diff --git a/hw/misc/Kconfig b/hw/misc/Kconfig
126
+DEF_IMOP_32(umopa_s, uint8_t, uint8_t)
127
+DEF_IMOP_32(sumopa_s, int8_t, uint8_t)
128
+DEF_IMOP_32(usmopa_s, uint8_t, int8_t)
129
+
130
+DEF_IMOP_64(smopa_d, int16_t, int16_t)
131
+DEF_IMOP_64(umopa_d, uint16_t, uint16_t)
132
+DEF_IMOP_64(sumopa_d, int16_t, uint16_t)
133
+DEF_IMOP_64(usmopa_d, uint16_t, int16_t)
134
+
135
+#define DEF_IMOPH(NAME) \
136
+ void HELPER(sme_##NAME)(void *vza, void *vzn, void *vzm, void *vpn, \
137
+ void *vpm, uint32_t desc) \
138
+ { do_imopa(vza, vzn, vzm, vpn, vpm, desc, NAME); }
139
+
140
+DEF_IMOPH(smopa_s)
141
+DEF_IMOPH(umopa_s)
142
+DEF_IMOPH(sumopa_s)
143
+DEF_IMOPH(usmopa_s)
144
+DEF_IMOPH(smopa_d)
145
+DEF_IMOPH(umopa_d)
146
+DEF_IMOPH(sumopa_d)
147
+DEF_IMOPH(usmopa_d)
148
diff --git a/target/arm/translate-sme.c b/target/arm/translate-sme.c
159
index XXXXXXX..XXXXXXX 100644
149
index XXXXXXX..XXXXXXX 100644
160
--- a/hw/misc/Kconfig
150
--- a/target/arm/translate-sme.c
161
+++ b/hw/misc/Kconfig
151
+++ b/target/arm/translate-sme.c
162
@@ -XXX,XX +XXX,XX @@ config IOTKIT_SYSINFO
152
@@ -XXX,XX +XXX,XX @@ TRANS_FEAT(FMOPA_d, aa64_sme_f64f64, do_outprod_fpst, a, MO_64, gen_helper_sme_f
163
config PVPANIC_COMMON
153
164
bool
154
/* TODO: FEAT_EBF16 */
165
155
TRANS_FEAT(BFMOPA, aa64_sme, do_outprod, a, MO_32, gen_helper_sme_bfmopa)
166
+config PVPANIC_PCI
167
+ bool
168
+ default y if PCI_DEVICES
169
+ depends on PCI
170
+ select PVPANIC_COMMON
171
+
156
+
172
config PVPANIC_ISA
157
+TRANS_FEAT(SMOPA_s, aa64_sme, do_outprod, a, MO_32, gen_helper_sme_smopa_s)
173
bool
158
+TRANS_FEAT(UMOPA_s, aa64_sme, do_outprod, a, MO_32, gen_helper_sme_umopa_s)
174
depends on ISA_BUS
159
+TRANS_FEAT(SUMOPA_s, aa64_sme, do_outprod, a, MO_32, gen_helper_sme_sumopa_s)
175
diff --git a/hw/misc/meson.build b/hw/misc/meson.build
160
+TRANS_FEAT(USMOPA_s, aa64_sme, do_outprod, a, MO_32, gen_helper_sme_usmopa_s)
176
index XXXXXXX..XXXXXXX 100644
161
+
177
--- a/hw/misc/meson.build
162
+TRANS_FEAT(SMOPA_d, aa64_sme_i16i64, do_outprod, a, MO_64, gen_helper_sme_smopa_d)
178
+++ b/hw/misc/meson.build
163
+TRANS_FEAT(UMOPA_d, aa64_sme_i16i64, do_outprod, a, MO_64, gen_helper_sme_umopa_d)
179
@@ -XXX,XX +XXX,XX @@ softmmu_ss.add(when: 'CONFIG_ARMSSE_CPUID', if_true: files('armsse-cpuid.c'))
164
+TRANS_FEAT(SUMOPA_d, aa64_sme_i16i64, do_outprod, a, MO_64, gen_helper_sme_sumopa_d)
180
softmmu_ss.add(when: 'CONFIG_ARMSSE_MHU', if_true: files('armsse-mhu.c'))
165
+TRANS_FEAT(USMOPA_d, aa64_sme_i16i64, do_outprod, a, MO_64, gen_helper_sme_usmopa_d)
181
182
softmmu_ss.add(when: 'CONFIG_PVPANIC_ISA', if_true: files('pvpanic-isa.c'))
183
+softmmu_ss.add(when: 'CONFIG_PVPANIC_PCI', if_true: files('pvpanic-pci.c'))
184
softmmu_ss.add(when: 'CONFIG_AUX', if_true: files('auxbus.c'))
185
softmmu_ss.add(when: 'CONFIG_ASPEED_SOC', if_true: files('aspeed_scu.c', 'aspeed_sdmc.c', 'aspeed_xdma.c'))
186
softmmu_ss.add(when: 'CONFIG_MSF2', if_true: files('msf2-sysreg.c'))
187
--
166
--
188
2.20.1
167
2.25.1
189
190
diff view generated by jsdifflib
1
The old-style convenience function cmsdk_apb_timer_create() for
1
From: Richard Henderson <richard.henderson@linaro.org>
2
creating CMSDK_APB_TIMER objects is used in only two places in
3
mps2.c. Most of the rest of the code in that file uses the new
4
"initialize in place" coding style.
5
2
6
We want to connect up a Clock object which should be done between the
3
This is an SVE instruction that operates using the SVE vector
7
object creation and realization; rather than adding a Clock* argument
4
length but that it is present only if SME is implemented.
8
to the convenience function, convert the timer creation code in
9
mps2.c to the same style as is used already for the watchdog,
10
dualtimer and other devices, and delete the now-unused convenience
11
function.
12
5
6
Reviewed-by: Peter Maydell <peter.maydell@linaro.org>
7
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
8
Message-id: 20220708151540.18136-29-richard.henderson@linaro.org
13
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
9
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
14
Reviewed-by: Philippe Mathieu-Daudé <f4bug@amsat.org>
15
Reviewed-by: Luc Michel <luc@lmichel.fr>
16
Tested-by: Philippe Mathieu-Daudé <f4bug@amsat.org>
17
Message-id: 20210128114145.20536-13-peter.maydell@linaro.org
18
Message-id: 20210121190622.22000-13-peter.maydell@linaro.org
19
---
10
---
20
include/hw/timer/cmsdk-apb-timer.h | 21 ---------------------
11
target/arm/sve.decode | 20 +++++++++++++
21
hw/arm/mps2.c | 18 ++++++++++++++++--
12
target/arm/translate-sve.c | 57 ++++++++++++++++++++++++++++++++++++++
22
2 files changed, 16 insertions(+), 23 deletions(-)
13
2 files changed, 77 insertions(+)
23
14
24
diff --git a/include/hw/timer/cmsdk-apb-timer.h b/include/hw/timer/cmsdk-apb-timer.h
15
diff --git a/target/arm/sve.decode b/target/arm/sve.decode
25
index XXXXXXX..XXXXXXX 100644
16
index XXXXXXX..XXXXXXX 100644
26
--- a/include/hw/timer/cmsdk-apb-timer.h
17
--- a/target/arm/sve.decode
27
+++ b/include/hw/timer/cmsdk-apb-timer.h
18
+++ b/target/arm/sve.decode
28
@@ -XXX,XX +XXX,XX @@ struct CMSDKAPBTimer {
19
@@ -XXX,XX +XXX,XX @@ BFMLALT_zzxw 01100100 11 1 ..... 0100.1 ..... ..... @rrxr_3a esz=2
29
uint32_t intstatus;
20
30
};
21
### SVE2 floating-point bfloat16 dot-product (indexed)
31
22
BFDOT_zzxz 01100100 01 1 ..... 010000 ..... ..... @rrxr_2 esz=2
32
-/**
23
+
33
- * cmsdk_apb_timer_create - convenience function to create TYPE_CMSDK_APB_TIMER
24
+### SVE broadcast predicate element
34
- * @addr: location in system memory to map registers
25
+
35
- * @pclk_frq: frequency in Hz of the PCLK clock (used for calculating baud rate)
26
+&psel esz pd pn pm rv imm
36
- */
27
+%psel_rv 16:2 !function=plus_12
37
-static inline DeviceState *cmsdk_apb_timer_create(hwaddr addr,
28
+%psel_imm_b 22:2 19:2
38
- qemu_irq timerint,
29
+%psel_imm_h 22:2 20:1
39
- uint32_t pclk_frq)
30
+%psel_imm_s 22:2
40
-{
31
+%psel_imm_d 23:1
41
- DeviceState *dev;
32
+@psel ........ .. . ... .. .. pn:4 . pm:4 . pd:4 \
42
- SysBusDevice *s;
33
+ &psel rv=%psel_rv
43
-
34
+
44
- dev = qdev_new(TYPE_CMSDK_APB_TIMER);
35
+PSEL 00100101 .. 1 ..1 .. 01 .... 0 .... 0 .... \
45
- s = SYS_BUS_DEVICE(dev);
36
+ @psel esz=0 imm=%psel_imm_b
46
- qdev_prop_set_uint32(dev, "pclk-frq", pclk_frq);
37
+PSEL 00100101 .. 1 .10 .. 01 .... 0 .... 0 .... \
47
- sysbus_realize_and_unref(s, &error_fatal);
38
+ @psel esz=1 imm=%psel_imm_h
48
- sysbus_mmio_map(s, 0, addr);
39
+PSEL 00100101 .. 1 100 .. 01 .... 0 .... 0 .... \
49
- sysbus_connect_irq(s, 0, timerint);
40
+ @psel esz=2 imm=%psel_imm_s
50
- return dev;
41
+PSEL 00100101 .1 1 000 .. 01 .... 0 .... 0 .... \
51
-}
42
+ @psel esz=3 imm=%psel_imm_d
52
-
43
diff --git a/target/arm/translate-sve.c b/target/arm/translate-sve.c
53
#endif
54
diff --git a/hw/arm/mps2.c b/hw/arm/mps2.c
55
index XXXXXXX..XXXXXXX 100644
44
index XXXXXXX..XXXXXXX 100644
56
--- a/hw/arm/mps2.c
45
--- a/target/arm/translate-sve.c
57
+++ b/hw/arm/mps2.c
46
+++ b/target/arm/translate-sve.c
58
@@ -XXX,XX +XXX,XX @@ struct MPS2MachineState {
47
@@ -XXX,XX +XXX,XX @@ static bool do_BFMLAL_zzxw(DisasContext *s, arg_rrxr_esz *a, bool sel)
59
/* CMSDK APB subsystem */
48
60
CMSDKAPBDualTimer dualtimer;
49
TRANS_FEAT(BFMLALB_zzxw, aa64_sve_bf16, do_BFMLAL_zzxw, a, false)
61
CMSDKAPBWatchdog watchdog;
50
TRANS_FEAT(BFMLALT_zzxw, aa64_sve_bf16, do_BFMLAL_zzxw, a, true)
62
+ CMSDKAPBTimer timer[2];
63
};
64
65
#define TYPE_MPS2_MACHINE "mps2"
66
@@ -XXX,XX +XXX,XX @@ static void mps2_common_init(MachineState *machine)
67
}
68
69
/* CMSDK APB subsystem */
70
- cmsdk_apb_timer_create(0x40000000, qdev_get_gpio_in(armv7m, 8), SYSCLK_FRQ);
71
- cmsdk_apb_timer_create(0x40001000, qdev_get_gpio_in(armv7m, 9), SYSCLK_FRQ);
72
+ for (i = 0; i < ARRAY_SIZE(mms->timer); i++) {
73
+ g_autofree char *name = g_strdup_printf("timer%d", i);
74
+ hwaddr base = 0x40000000 + i * 0x1000;
75
+ int irqno = 8 + i;
76
+ SysBusDevice *sbd;
77
+
51
+
78
+ object_initialize_child(OBJECT(mms), name, &mms->timer[i],
52
+static bool trans_PSEL(DisasContext *s, arg_psel *a)
79
+ TYPE_CMSDK_APB_TIMER);
53
+{
80
+ sbd = SYS_BUS_DEVICE(&mms->timer[i]);
54
+ int vl = vec_full_reg_size(s);
81
+ qdev_prop_set_uint32(DEVICE(&mms->timer[i]), "pclk-frq", SYSCLK_FRQ);
55
+ int pl = pred_gvec_reg_size(s);
82
+ sysbus_realize_and_unref(sbd, &error_fatal);
56
+ int elements = vl >> a->esz;
83
+ sysbus_mmio_map(sbd, 0, base);
57
+ TCGv_i64 tmp, didx, dbit;
84
+ sysbus_connect_irq(sbd, 0, qdev_get_gpio_in(armv7m, irqno));
58
+ TCGv_ptr ptr;
59
+
60
+ if (!dc_isar_feature(aa64_sme, s)) {
61
+ return false;
62
+ }
63
+ if (!sve_access_check(s)) {
64
+ return true;
85
+ }
65
+ }
86
+
66
+
87
object_initialize_child(OBJECT(mms), "dualtimer", &mms->dualtimer,
67
+ tmp = tcg_temp_new_i64();
88
TYPE_CMSDK_APB_DUALTIMER);
68
+ dbit = tcg_temp_new_i64();
89
qdev_prop_set_uint32(DEVICE(&mms->dualtimer), "pclk-frq", SYSCLK_FRQ);
69
+ didx = tcg_temp_new_i64();
70
+ ptr = tcg_temp_new_ptr();
71
+
72
+ /* Compute the predicate element. */
73
+ tcg_gen_addi_i64(tmp, cpu_reg(s, a->rv), a->imm);
74
+ if (is_power_of_2(elements)) {
75
+ tcg_gen_andi_i64(tmp, tmp, elements - 1);
76
+ } else {
77
+ tcg_gen_remu_i64(tmp, tmp, tcg_constant_i64(elements));
78
+ }
79
+
80
+ /* Extract the predicate byte and bit indices. */
81
+ tcg_gen_shli_i64(tmp, tmp, a->esz);
82
+ tcg_gen_andi_i64(dbit, tmp, 7);
83
+ tcg_gen_shri_i64(didx, tmp, 3);
84
+ if (HOST_BIG_ENDIAN) {
85
+ tcg_gen_xori_i64(didx, didx, 7);
86
+ }
87
+
88
+ /* Load the predicate word. */
89
+ tcg_gen_trunc_i64_ptr(ptr, didx);
90
+ tcg_gen_add_ptr(ptr, ptr, cpu_env);
91
+ tcg_gen_ld8u_i64(tmp, ptr, pred_full_reg_offset(s, a->pm));
92
+
93
+ /* Extract the predicate bit and replicate to MO_64. */
94
+ tcg_gen_shr_i64(tmp, tmp, dbit);
95
+ tcg_gen_andi_i64(tmp, tmp, 1);
96
+ tcg_gen_neg_i64(tmp, tmp);
97
+
98
+ /* Apply to either copy the source, or write zeros. */
99
+ tcg_gen_gvec_ands(MO_64, pred_full_reg_offset(s, a->pd),
100
+ pred_full_reg_offset(s, a->pn), tmp, pl, pl);
101
+
102
+ tcg_temp_free_i64(tmp);
103
+ tcg_temp_free_i64(dbit);
104
+ tcg_temp_free_i64(didx);
105
+ tcg_temp_free_ptr(ptr);
106
+ return true;
107
+}
90
--
108
--
91
2.20.1
109
2.25.1
92
93
diff view generated by jsdifflib
1
Add a simple test of the CMSDK APB timer, since we're about to do
1
From: Richard Henderson <richard.henderson@linaro.org>
2
some refactoring of how it is clocked.
3
2
3
This is an SVE instruction that operates using the SVE vector
4
length but that it is present only if SME is implemented.
5
6
Reviewed-by: Peter Maydell <peter.maydell@linaro.org>
7
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
8
Message-id: 20220708151540.18136-30-richard.henderson@linaro.org
4
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
9
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
5
Reviewed-by: Philippe Mathieu-Daudé <f4bug@amsat.org>
6
Reviewed-by: Luc Michel <luc@lmichel.fr>
7
Tested-by: Philippe Mathieu-Daudé <f4bug@amsat.org>
8
Message-id: 20210128114145.20536-4-peter.maydell@linaro.org
9
Message-id: 20210121190622.22000-4-peter.maydell@linaro.org
10
---
10
---
11
tests/qtest/cmsdk-apb-timer-test.c | 75 ++++++++++++++++++++++++++++++
11
target/arm/helper-sve.h | 2 ++
12
MAINTAINERS | 1 +
12
target/arm/sve.decode | 1 +
13
tests/qtest/meson.build | 1 +
13
target/arm/sve_helper.c | 16 ++++++++++++++++
14
3 files changed, 77 insertions(+)
14
target/arm/translate-sve.c | 2 ++
15
create mode 100644 tests/qtest/cmsdk-apb-timer-test.c
15
4 files changed, 21 insertions(+)
16
16
17
diff --git a/tests/qtest/cmsdk-apb-timer-test.c b/tests/qtest/cmsdk-apb-timer-test.c
17
diff --git a/target/arm/helper-sve.h b/target/arm/helper-sve.h
18
new file mode 100644
18
index XXXXXXX..XXXXXXX 100644
19
index XXXXXXX..XXXXXXX
19
--- a/target/arm/helper-sve.h
20
--- /dev/null
20
+++ b/target/arm/helper-sve.h
21
+++ b/tests/qtest/cmsdk-apb-timer-test.c
21
@@ -XXX,XX +XXX,XX @@ DEF_HELPER_FLAGS_4(sve_revh_d, TCG_CALL_NO_RWG, void, ptr, ptr, ptr, i32)
22
@@ -XXX,XX +XXX,XX @@
22
23
+/*
23
DEF_HELPER_FLAGS_4(sve_revw_d, TCG_CALL_NO_RWG, void, ptr, ptr, ptr, i32)
24
+ * QTest testcase for the CMSDK APB timer device
24
25
+ *
25
+DEF_HELPER_FLAGS_4(sme_revd_q, TCG_CALL_NO_RWG, void, ptr, ptr, ptr, i32)
26
+ * Copyright (c) 2021 Linaro Limited
27
+ *
28
+ * This program is free software; you can redistribute it and/or modify it
29
+ * under the terms of the GNU General Public License as published by the
30
+ * Free Software Foundation; either version 2 of the License, or
31
+ * (at your option) any later version.
32
+ *
33
+ * This program is distributed in the hope that it will be useful, but WITHOUT
34
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
35
+ * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
36
+ * for more details.
37
+ */
38
+
26
+
39
+#include "qemu/osdep.h"
27
DEF_HELPER_FLAGS_4(sve_rbit_b, TCG_CALL_NO_RWG, void, ptr, ptr, ptr, i32)
40
+#include "libqtest-single.h"
28
DEF_HELPER_FLAGS_4(sve_rbit_h, TCG_CALL_NO_RWG, void, ptr, ptr, ptr, i32)
29
DEF_HELPER_FLAGS_4(sve_rbit_s, TCG_CALL_NO_RWG, void, ptr, ptr, ptr, i32)
30
diff --git a/target/arm/sve.decode b/target/arm/sve.decode
31
index XXXXXXX..XXXXXXX 100644
32
--- a/target/arm/sve.decode
33
+++ b/target/arm/sve.decode
34
@@ -XXX,XX +XXX,XX @@ REVB 00000101 .. 1001 00 100 ... ..... ..... @rd_pg_rn
35
REVH 00000101 .. 1001 01 100 ... ..... ..... @rd_pg_rn
36
REVW 00000101 .. 1001 10 100 ... ..... ..... @rd_pg_rn
37
RBIT 00000101 .. 1001 11 100 ... ..... ..... @rd_pg_rn
38
+REVD 00000101 00 1011 10 100 ... ..... ..... @rd_pg_rn_e0
39
40
# SVE vector splice (predicated, destructive)
41
SPLICE 00000101 .. 101 100 100 ... ..... ..... @rdn_pg_rm
42
diff --git a/target/arm/sve_helper.c b/target/arm/sve_helper.c
43
index XXXXXXX..XXXXXXX 100644
44
--- a/target/arm/sve_helper.c
45
+++ b/target/arm/sve_helper.c
46
@@ -XXX,XX +XXX,XX @@ DO_ZPZ_D(sve_revh_d, uint64_t, hswap64)
47
48
DO_ZPZ_D(sve_revw_d, uint64_t, wswap64)
49
50
+void HELPER(sme_revd_q)(void *vd, void *vn, void *vg, uint32_t desc)
51
+{
52
+ intptr_t i, opr_sz = simd_oprsz(desc) / 8;
53
+ uint64_t *d = vd, *n = vn;
54
+ uint8_t *pg = vg;
41
+
55
+
42
+/* IoTKit/ARMSSE-200 timer0; driven at 25MHz in mps2-an385, so 40ns per tick */
56
+ for (i = 0; i < opr_sz; i += 2) {
43
+#define TIMER_BASE 0x40000000
57
+ if (pg[H1(i)] & 1) {
44
+
58
+ uint64_t n0 = n[i + 0];
45
+#define CTRL 0
59
+ uint64_t n1 = n[i + 1];
46
+#define VALUE 4
60
+ d[i + 0] = n1;
47
+#define RELOAD 8
61
+ d[i + 1] = n0;
48
+#define INTSTATUS 0xc
62
+ }
49
+
63
+ }
50
+static void test_timer(void)
51
+{
52
+ g_assert_true(readl(TIMER_BASE + INTSTATUS) == 0);
53
+
54
+ /* Start timer: will fire after 40 * 1000 == 40000 ns */
55
+ writel(TIMER_BASE + RELOAD, 1000);
56
+ writel(TIMER_BASE + CTRL, 9);
57
+
58
+ /* Step to just past the 500th tick and check VALUE */
59
+ clock_step(40 * 500 + 1);
60
+ g_assert_cmpuint(readl(TIMER_BASE + INTSTATUS), ==, 0);
61
+ g_assert_cmpuint(readl(TIMER_BASE + VALUE), ==, 500);
62
+
63
+ /* Just past the 1000th tick: timer should have fired */
64
+ clock_step(40 * 500);
65
+ g_assert_cmpuint(readl(TIMER_BASE + INTSTATUS), ==, 1);
66
+ g_assert_cmpuint(readl(TIMER_BASE + VALUE), ==, 0);
67
+
68
+ /* VALUE reloads at the following tick */
69
+ clock_step(40);
70
+ g_assert_cmpuint(readl(TIMER_BASE + VALUE), ==, 1000);
71
+
72
+ /* Check write-1-to-clear behaviour of INTSTATUS */
73
+ writel(TIMER_BASE + INTSTATUS, 0);
74
+ g_assert_cmpuint(readl(TIMER_BASE + INTSTATUS), ==, 1);
75
+ writel(TIMER_BASE + INTSTATUS, 1);
76
+ g_assert_cmpuint(readl(TIMER_BASE + INTSTATUS), ==, 0);
77
+
78
+ /* Turn off the timer */
79
+ writel(TIMER_BASE + CTRL, 0);
80
+}
64
+}
81
+
65
+
82
+int main(int argc, char **argv)
66
DO_ZPZ(sve_rbit_b, uint8_t, H1, revbit8)
83
+{
67
DO_ZPZ(sve_rbit_h, uint16_t, H1_2, revbit16)
84
+ int r;
68
DO_ZPZ(sve_rbit_s, uint32_t, H1_4, revbit32)
69
diff --git a/target/arm/translate-sve.c b/target/arm/translate-sve.c
70
index XXXXXXX..XXXXXXX 100644
71
--- a/target/arm/translate-sve.c
72
+++ b/target/arm/translate-sve.c
73
@@ -XXX,XX +XXX,XX @@ TRANS_FEAT(REVH, aa64_sve, gen_gvec_ool_arg_zpz, revh_fns[a->esz], a, 0)
74
TRANS_FEAT(REVW, aa64_sve, gen_gvec_ool_arg_zpz,
75
a->esz == 3 ? gen_helper_sve_revw_d : NULL, a, 0)
76
77
+TRANS_FEAT(REVD, aa64_sme, gen_gvec_ool_arg_zpz, gen_helper_sme_revd_q, a, 0)
85
+
78
+
86
+ g_test_init(&argc, &argv, NULL);
79
TRANS_FEAT(SPLICE, aa64_sve, gen_gvec_ool_arg_zpzz,
87
+
80
gen_helper_sve_splice, a, a->esz)
88
+ qtest_start("-machine mps2-an385");
81
89
+
90
+ qtest_add_func("/cmsdk-apb-timer/timer", test_timer);
91
+
92
+ r = g_test_run();
93
+
94
+ qtest_end();
95
+
96
+ return r;
97
+}
98
diff --git a/MAINTAINERS b/MAINTAINERS
99
index XXXXXXX..XXXXXXX 100644
100
--- a/MAINTAINERS
101
+++ b/MAINTAINERS
102
@@ -XXX,XX +XXX,XX @@ F: include/hw/rtc/pl031.h
103
F: include/hw/arm/primecell.h
104
F: hw/timer/cmsdk-apb-timer.c
105
F: include/hw/timer/cmsdk-apb-timer.h
106
+F: tests/qtest/cmsdk-apb-timer-test.c
107
F: hw/timer/cmsdk-apb-dualtimer.c
108
F: include/hw/timer/cmsdk-apb-dualtimer.h
109
F: hw/char/cmsdk-apb-uart.c
110
diff --git a/tests/qtest/meson.build b/tests/qtest/meson.build
111
index XXXXXXX..XXXXXXX 100644
112
--- a/tests/qtest/meson.build
113
+++ b/tests/qtest/meson.build
114
@@ -XXX,XX +XXX,XX @@ qtests_npcm7xx = \
115
'npcm7xx_timer-test',
116
'npcm7xx_watchdog_timer-test']
117
qtests_arm = \
118
+ (config_all_devices.has_key('CONFIG_CMSDK_APB_TIMER') ? ['cmsdk-apb-timer-test'] : []) + \
119
(config_all_devices.has_key('CONFIG_PFLASH_CFI02') ? ['pflash-cfi02-test'] : []) + \
120
(config_all_devices.has_key('CONFIG_NPCM7XX') ? qtests_npcm7xx : []) + \
121
['arm-cpu-features',
122
--
82
--
123
2.20.1
83
2.25.1
124
125
diff view generated by jsdifflib
1
From: Joelle van Dyne <j@getutm.app>
1
From: Richard Henderson <richard.henderson@linaro.org>
2
2
3
Build without error on hosts without a working system(). If system()
3
This is an SVE instruction that operates using the SVE vector
4
is called, return -1 with ENOSYS.
4
length but that it is present only if SME is implemented.
5
5
6
Signed-off-by: Joelle van Dyne <j@getutm.app>
7
Message-id: 20210126012457.39046-6-j@getutm.app
8
Reviewed-by: Peter Maydell <peter.maydell@linaro.org>
6
Reviewed-by: Peter Maydell <peter.maydell@linaro.org>
7
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
8
Message-id: 20220708151540.18136-31-richard.henderson@linaro.org
9
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
9
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
10
---
10
---
11
meson.build | 1 +
11
target/arm/helper.h | 18 +++++++
12
include/qemu/osdep.h | 12 ++++++++++++
12
target/arm/sve.decode | 5 ++
13
2 files changed, 13 insertions(+)
13
target/arm/translate-sve.c | 102 +++++++++++++++++++++++++++++++++++++
14
target/arm/vec_helper.c | 24 +++++++++
15
4 files changed, 149 insertions(+)
14
16
15
diff --git a/meson.build b/meson.build
17
diff --git a/target/arm/helper.h b/target/arm/helper.h
16
index XXXXXXX..XXXXXXX 100644
18
index XXXXXXX..XXXXXXX 100644
17
--- a/meson.build
19
--- a/target/arm/helper.h
18
+++ b/meson.build
20
+++ b/target/arm/helper.h
19
@@ -XXX,XX +XXX,XX @@ config_host_data.set('HAVE_DRM_H', cc.has_header('libdrm/drm.h'))
21
@@ -XXX,XX +XXX,XX @@ DEF_HELPER_FLAGS_6(gvec_bfmlal, TCG_CALL_NO_RWG,
20
config_host_data.set('HAVE_PTY_H', cc.has_header('pty.h'))
22
DEF_HELPER_FLAGS_6(gvec_bfmlal_idx, TCG_CALL_NO_RWG,
21
config_host_data.set('HAVE_SYS_IOCCOM_H', cc.has_header('sys/ioccom.h'))
23
void, ptr, ptr, ptr, ptr, ptr, i32)
22
config_host_data.set('HAVE_SYS_KCOV_H', cc.has_header('sys/kcov.h'))
24
23
+config_host_data.set('HAVE_SYSTEM_FUNCTION', cc.has_function('system', prefix: '#include <stdlib.h>'))
25
+DEF_HELPER_FLAGS_5(gvec_sclamp_b, TCG_CALL_NO_RWG,
24
26
+ void, ptr, ptr, ptr, ptr, i32)
25
config_host_data.set('CONFIG_PREADV', cc.has_function('preadv', prefix: '#include <sys/uio.h>'))
27
+DEF_HELPER_FLAGS_5(gvec_sclamp_h, TCG_CALL_NO_RWG,
26
28
+ void, ptr, ptr, ptr, ptr, i32)
27
diff --git a/include/qemu/osdep.h b/include/qemu/osdep.h
29
+DEF_HELPER_FLAGS_5(gvec_sclamp_s, TCG_CALL_NO_RWG,
28
index XXXXXXX..XXXXXXX 100644
30
+ void, ptr, ptr, ptr, ptr, i32)
29
--- a/include/qemu/osdep.h
31
+DEF_HELPER_FLAGS_5(gvec_sclamp_d, TCG_CALL_NO_RWG,
30
+++ b/include/qemu/osdep.h
32
+ void, ptr, ptr, ptr, ptr, i32)
31
@@ -XXX,XX +XXX,XX @@ static inline void qemu_thread_jit_write(void) {}
33
+
32
static inline void qemu_thread_jit_execute(void) {}
34
+DEF_HELPER_FLAGS_5(gvec_uclamp_b, TCG_CALL_NO_RWG,
33
#endif
35
+ void, ptr, ptr, ptr, ptr, i32)
34
36
+DEF_HELPER_FLAGS_5(gvec_uclamp_h, TCG_CALL_NO_RWG,
35
+/**
37
+ void, ptr, ptr, ptr, ptr, i32)
36
+ * Platforms which do not support system() return ENOSYS
38
+DEF_HELPER_FLAGS_5(gvec_uclamp_s, TCG_CALL_NO_RWG,
37
+ */
39
+ void, ptr, ptr, ptr, ptr, i32)
38
+#ifndef HAVE_SYSTEM_FUNCTION
40
+DEF_HELPER_FLAGS_5(gvec_uclamp_d, TCG_CALL_NO_RWG,
39
+#define system platform_does_not_support_system
41
+ void, ptr, ptr, ptr, ptr, i32)
40
+static inline int platform_does_not_support_system(const char *command)
42
+
41
+{
43
#ifdef TARGET_AARCH64
42
+ errno = ENOSYS;
44
#include "helper-a64.h"
43
+ return -1;
45
#include "helper-sve.h"
44
+}
46
diff --git a/target/arm/sve.decode b/target/arm/sve.decode
45
+#endif /* !HAVE_SYSTEM_FUNCTION */
47
index XXXXXXX..XXXXXXX 100644
46
+
48
--- a/target/arm/sve.decode
47
#endif
49
+++ b/target/arm/sve.decode
50
@@ -XXX,XX +XXX,XX @@ PSEL 00100101 .. 1 100 .. 01 .... 0 .... 0 .... \
51
@psel esz=2 imm=%psel_imm_s
52
PSEL 00100101 .1 1 000 .. 01 .... 0 .... 0 .... \
53
@psel esz=3 imm=%psel_imm_d
54
+
55
+### SVE clamp
56
+
57
+SCLAMP 01000100 .. 0 ..... 110000 ..... ..... @rda_rn_rm
58
+UCLAMP 01000100 .. 0 ..... 110001 ..... ..... @rda_rn_rm
59
diff --git a/target/arm/translate-sve.c b/target/arm/translate-sve.c
60
index XXXXXXX..XXXXXXX 100644
61
--- a/target/arm/translate-sve.c
62
+++ b/target/arm/translate-sve.c
63
@@ -XXX,XX +XXX,XX @@ static bool trans_PSEL(DisasContext *s, arg_psel *a)
64
tcg_temp_free_ptr(ptr);
65
return true;
66
}
67
+
68
+static void gen_sclamp_i32(TCGv_i32 d, TCGv_i32 n, TCGv_i32 m, TCGv_i32 a)
69
+{
70
+ tcg_gen_smax_i32(d, a, n);
71
+ tcg_gen_smin_i32(d, d, m);
72
+}
73
+
74
+static void gen_sclamp_i64(TCGv_i64 d, TCGv_i64 n, TCGv_i64 m, TCGv_i64 a)
75
+{
76
+ tcg_gen_smax_i64(d, a, n);
77
+ tcg_gen_smin_i64(d, d, m);
78
+}
79
+
80
+static void gen_sclamp_vec(unsigned vece, TCGv_vec d, TCGv_vec n,
81
+ TCGv_vec m, TCGv_vec a)
82
+{
83
+ tcg_gen_smax_vec(vece, d, a, n);
84
+ tcg_gen_smin_vec(vece, d, d, m);
85
+}
86
+
87
+static void gen_sclamp(unsigned vece, uint32_t d, uint32_t n, uint32_t m,
88
+ uint32_t a, uint32_t oprsz, uint32_t maxsz)
89
+{
90
+ static const TCGOpcode vecop[] = {
91
+ INDEX_op_smin_vec, INDEX_op_smax_vec, 0
92
+ };
93
+ static const GVecGen4 ops[4] = {
94
+ { .fniv = gen_sclamp_vec,
95
+ .fno = gen_helper_gvec_sclamp_b,
96
+ .opt_opc = vecop,
97
+ .vece = MO_8 },
98
+ { .fniv = gen_sclamp_vec,
99
+ .fno = gen_helper_gvec_sclamp_h,
100
+ .opt_opc = vecop,
101
+ .vece = MO_16 },
102
+ { .fni4 = gen_sclamp_i32,
103
+ .fniv = gen_sclamp_vec,
104
+ .fno = gen_helper_gvec_sclamp_s,
105
+ .opt_opc = vecop,
106
+ .vece = MO_32 },
107
+ { .fni8 = gen_sclamp_i64,
108
+ .fniv = gen_sclamp_vec,
109
+ .fno = gen_helper_gvec_sclamp_d,
110
+ .opt_opc = vecop,
111
+ .vece = MO_64,
112
+ .prefer_i64 = TCG_TARGET_REG_BITS == 64 }
113
+ };
114
+ tcg_gen_gvec_4(d, n, m, a, oprsz, maxsz, &ops[vece]);
115
+}
116
+
117
+TRANS_FEAT(SCLAMP, aa64_sme, gen_gvec_fn_arg_zzzz, gen_sclamp, a)
118
+
119
+static void gen_uclamp_i32(TCGv_i32 d, TCGv_i32 n, TCGv_i32 m, TCGv_i32 a)
120
+{
121
+ tcg_gen_umax_i32(d, a, n);
122
+ tcg_gen_umin_i32(d, d, m);
123
+}
124
+
125
+static void gen_uclamp_i64(TCGv_i64 d, TCGv_i64 n, TCGv_i64 m, TCGv_i64 a)
126
+{
127
+ tcg_gen_umax_i64(d, a, n);
128
+ tcg_gen_umin_i64(d, d, m);
129
+}
130
+
131
+static void gen_uclamp_vec(unsigned vece, TCGv_vec d, TCGv_vec n,
132
+ TCGv_vec m, TCGv_vec a)
133
+{
134
+ tcg_gen_umax_vec(vece, d, a, n);
135
+ tcg_gen_umin_vec(vece, d, d, m);
136
+}
137
+
138
+static void gen_uclamp(unsigned vece, uint32_t d, uint32_t n, uint32_t m,
139
+ uint32_t a, uint32_t oprsz, uint32_t maxsz)
140
+{
141
+ static const TCGOpcode vecop[] = {
142
+ INDEX_op_umin_vec, INDEX_op_umax_vec, 0
143
+ };
144
+ static const GVecGen4 ops[4] = {
145
+ { .fniv = gen_uclamp_vec,
146
+ .fno = gen_helper_gvec_uclamp_b,
147
+ .opt_opc = vecop,
148
+ .vece = MO_8 },
149
+ { .fniv = gen_uclamp_vec,
150
+ .fno = gen_helper_gvec_uclamp_h,
151
+ .opt_opc = vecop,
152
+ .vece = MO_16 },
153
+ { .fni4 = gen_uclamp_i32,
154
+ .fniv = gen_uclamp_vec,
155
+ .fno = gen_helper_gvec_uclamp_s,
156
+ .opt_opc = vecop,
157
+ .vece = MO_32 },
158
+ { .fni8 = gen_uclamp_i64,
159
+ .fniv = gen_uclamp_vec,
160
+ .fno = gen_helper_gvec_uclamp_d,
161
+ .opt_opc = vecop,
162
+ .vece = MO_64,
163
+ .prefer_i64 = TCG_TARGET_REG_BITS == 64 }
164
+ };
165
+ tcg_gen_gvec_4(d, n, m, a, oprsz, maxsz, &ops[vece]);
166
+}
167
+
168
+TRANS_FEAT(UCLAMP, aa64_sme, gen_gvec_fn_arg_zzzz, gen_uclamp, a)
169
diff --git a/target/arm/vec_helper.c b/target/arm/vec_helper.c
170
index XXXXXXX..XXXXXXX 100644
171
--- a/target/arm/vec_helper.c
172
+++ b/target/arm/vec_helper.c
173
@@ -XXX,XX +XXX,XX @@ void HELPER(gvec_bfmlal_idx)(void *vd, void *vn, void *vm,
174
}
175
clear_tail(d, opr_sz, simd_maxsz(desc));
176
}
177
+
178
+#define DO_CLAMP(NAME, TYPE) \
179
+void HELPER(NAME)(void *d, void *n, void *m, void *a, uint32_t desc) \
180
+{ \
181
+ intptr_t i, opr_sz = simd_oprsz(desc); \
182
+ for (i = 0; i < opr_sz; i += sizeof(TYPE)) { \
183
+ TYPE aa = *(TYPE *)(a + i); \
184
+ TYPE nn = *(TYPE *)(n + i); \
185
+ TYPE mm = *(TYPE *)(m + i); \
186
+ TYPE dd = MIN(MAX(aa, nn), mm); \
187
+ *(TYPE *)(d + i) = dd; \
188
+ } \
189
+ clear_tail(d, opr_sz, simd_maxsz(desc)); \
190
+}
191
+
192
+DO_CLAMP(gvec_sclamp_b, int8_t)
193
+DO_CLAMP(gvec_sclamp_h, int16_t)
194
+DO_CLAMP(gvec_sclamp_s, int32_t)
195
+DO_CLAMP(gvec_sclamp_d, int64_t)
196
+
197
+DO_CLAMP(gvec_uclamp_b, uint8_t)
198
+DO_CLAMP(gvec_uclamp_h, uint16_t)
199
+DO_CLAMP(gvec_uclamp_s, uint32_t)
200
+DO_CLAMP(gvec_uclamp_d, uint64_t)
48
--
201
--
49
2.20.1
202
2.25.1
50
51
diff view generated by jsdifflib
1
From: Richard Henderson <richard.henderson@linaro.org>
1
From: Richard Henderson <richard.henderson@linaro.org>
2
2
3
Only define the register if it exists for the cpu.
3
We can handle both exception entry and exception return by
4
hooking into aarch64_sve_change_el.
4
5
6
Reviewed-by: Peter Maydell <peter.maydell@linaro.org>
5
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
7
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
6
Message-id: 20210120031656.737646-1-richard.henderson@linaro.org
8
Message-id: 20220708151540.18136-32-richard.henderson@linaro.org
7
Reviewed-by: Peter Maydell <peter.maydell@linaro.org>
8
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
9
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
9
---
10
---
10
target/arm/helper.c | 21 +++++++++++++++------
11
target/arm/helper.c | 15 +++++++++++++--
11
1 file changed, 15 insertions(+), 6 deletions(-)
12
1 file changed, 13 insertions(+), 2 deletions(-)
12
13
13
diff --git a/target/arm/helper.c b/target/arm/helper.c
14
diff --git a/target/arm/helper.c b/target/arm/helper.c
14
index XXXXXXX..XXXXXXX 100644
15
index XXXXXXX..XXXXXXX 100644
15
--- a/target/arm/helper.c
16
--- a/target/arm/helper.c
16
+++ b/target/arm/helper.c
17
+++ b/target/arm/helper.c
17
@@ -XXX,XX +XXX,XX @@ static void define_debug_regs(ARMCPU *cpu)
18
@@ -XXX,XX +XXX,XX @@ void aarch64_sve_change_el(CPUARMState *env, int old_el,
18
*/
19
return;
19
int i;
20
}
20
int wrps, brps, ctx_cmps;
21
21
- ARMCPRegInfo dbgdidr = {
22
+ old_a64 = old_el ? arm_el_is_aa64(env, old_el) : el0_a64;
22
- .name = "DBGDIDR", .cp = 14, .crn = 0, .crm = 0, .opc1 = 0, .opc2 = 0,
23
+ new_a64 = new_el ? arm_el_is_aa64(env, new_el) : el0_a64;
23
- .access = PL0_R, .accessfn = access_tda,
24
- .type = ARM_CP_CONST, .resetvalue = cpu->isar.dbgdidr,
25
- };
26
+
24
+
27
+ /*
25
+ /*
28
+ * The Arm ARM says DBGDIDR is optional and deprecated if EL1 cannot
26
+ * Both AArch64.TakeException and AArch64.ExceptionReturn
29
+ * use AArch32. Given that bit 15 is RES1, if the value is 0 then
27
+ * invoke ResetSVEState when taking an exception from, or
30
+ * the register must not exist for this cpu.
28
+ * returning to, AArch32 state when PSTATE.SM is enabled.
31
+ */
29
+ */
32
+ if (cpu->isar.dbgdidr != 0) {
30
+ if (old_a64 != new_a64 && FIELD_EX64(env->svcr, SVCR, SM)) {
33
+ ARMCPRegInfo dbgdidr = {
31
+ arm_reset_sve_state(env);
34
+ .name = "DBGDIDR", .cp = 14, .crn = 0, .crm = 0,
32
+ return;
35
+ .opc1 = 0, .opc2 = 0,
36
+ .access = PL0_R, .accessfn = access_tda,
37
+ .type = ARM_CP_CONST, .resetvalue = cpu->isar.dbgdidr,
38
+ };
39
+ define_one_arm_cp_reg(cpu, &dbgdidr);
40
+ }
33
+ }
41
34
+
42
/* Note that all these register fields hold "number of Xs minus 1". */
35
/*
43
brps = arm_num_brps(cpu);
36
* DDI0584A.d sec 3.2: "If SVE instructions are disabled or trapped
44
@@ -XXX,XX +XXX,XX @@ static void define_debug_regs(ARMCPU *cpu)
37
* at ELx, or not available because the EL is in AArch32 state, then
45
38
@@ -XXX,XX +XXX,XX @@ void aarch64_sve_change_el(CPUARMState *env, int old_el,
46
assert(ctx_cmps <= brps);
39
* we already have the correct register contents when encountering the
47
40
* vq0->vq0 transition between EL0->EL1.
48
- define_one_arm_cp_reg(cpu, &dbgdidr);
41
*/
49
define_arm_cp_regs(cpu, debug_cp_reginfo);
42
- old_a64 = old_el ? arm_el_is_aa64(env, old_el) : el0_a64;
50
43
old_len = (old_a64 && !sve_exception_el(env, old_el)
51
if (arm_feature(&cpu->env, ARM_FEATURE_LPAE)) {
44
? sve_vqm1_for_el(env, old_el) : 0);
45
- new_a64 = new_el ? arm_el_is_aa64(env, new_el) : el0_a64;
46
new_len = (new_a64 && !sve_exception_el(env, new_el)
47
? sve_vqm1_for_el(env, new_el) : 0);
48
52
--
49
--
53
2.20.1
50
2.25.1
54
55
diff view generated by jsdifflib
1
From: Mihai Carabas <mihai.carabas@oracle.com>
1
From: Richard Henderson <richard.henderson@linaro.org>
2
2
3
Add pvpanic PCI device support details in docs/specs/pvpanic.txt.
3
Note that SME remains effectively disabled for user-only,
4
because we do not yet set CPACR_EL1.SMEN. This needs to
5
wait until the kernel ABI is implemented.
4
6
5
Signed-off-by: Mihai Carabas <mihai.carabas@oracle.com>
6
Reviewed-by: Peter Maydell <peter.maydell@linaro.org>
7
Reviewed-by: Peter Maydell <peter.maydell@linaro.org>
8
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
9
Message-id: 20220708151540.18136-33-richard.henderson@linaro.org
7
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
10
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
8
---
11
---
9
docs/specs/pvpanic.txt | 13 ++++++++++++-
12
docs/system/arm/emulation.rst | 4 ++++
10
1 file changed, 12 insertions(+), 1 deletion(-)
13
target/arm/cpu64.c | 11 +++++++++++
14
2 files changed, 15 insertions(+)
11
15
12
diff --git a/docs/specs/pvpanic.txt b/docs/specs/pvpanic.txt
16
diff --git a/docs/system/arm/emulation.rst b/docs/system/arm/emulation.rst
13
index XXXXXXX..XXXXXXX 100644
17
index XXXXXXX..XXXXXXX 100644
14
--- a/docs/specs/pvpanic.txt
18
--- a/docs/system/arm/emulation.rst
15
+++ b/docs/specs/pvpanic.txt
19
+++ b/docs/system/arm/emulation.rst
16
@@ -XXX,XX +XXX,XX @@
20
@@ -XXX,XX +XXX,XX @@ the following architecture extensions:
17
PVPANIC DEVICE
21
- FEAT_SHA512 (Advanced SIMD SHA512 instructions)
18
==============
22
- FEAT_SM3 (Advanced SIMD SM3 instructions)
19
23
- FEAT_SM4 (Advanced SIMD SM4 instructions)
20
-pvpanic device is a simulated ISA device, through which a guest panic
24
+- FEAT_SME (Scalable Matrix Extension)
21
+pvpanic device is a simulated device, through which a guest panic
25
+- FEAT_SME_FA64 (Full A64 instruction set in Streaming SVE mode)
22
event is sent to qemu, and a QMP event is generated. This allows
26
+- FEAT_SME_F64F64 (Double-precision floating-point outer product instructions)
23
management apps (e.g. libvirt) to be notified and respond to the event.
27
+- FEAT_SME_I16I64 (16-bit to 64-bit integer widening outer product instructions)
24
28
- FEAT_SPECRES (Speculation restriction instructions)
25
@@ -XXX,XX +XXX,XX @@ The management app has the option of waiting for GUEST_PANICKED events,
29
- FEAT_SSBS (Speculative Store Bypass Safe)
26
and/or polling for guest-panicked RunState, to learn when the pvpanic
30
- FEAT_TLBIOS (TLB invalidate instructions in Outer Shareable domain)
27
device has fired a panic event.
31
diff --git a/target/arm/cpu64.c b/target/arm/cpu64.c
28
32
index XXXXXXX..XXXXXXX 100644
29
+The pvpanic device can be implemented as an ISA device (using IOPORT) or as a
33
--- a/target/arm/cpu64.c
30
+PCI device.
34
+++ b/target/arm/cpu64.c
35
@@ -XXX,XX +XXX,XX @@ static void aarch64_max_initfn(Object *obj)
36
*/
37
t = FIELD_DP64(t, ID_AA64PFR1, MTE, 3); /* FEAT_MTE3 */
38
t = FIELD_DP64(t, ID_AA64PFR1, RAS_FRAC, 0); /* FEAT_RASv1p1 + FEAT_DoubleFault */
39
+ t = FIELD_DP64(t, ID_AA64PFR1, SME, 1); /* FEAT_SME */
40
t = FIELD_DP64(t, ID_AA64PFR1, CSV2_FRAC, 0); /* FEAT_CSV2_2 */
41
cpu->isar.id_aa64pfr1 = t;
42
43
@@ -XXX,XX +XXX,XX @@ static void aarch64_max_initfn(Object *obj)
44
t = FIELD_DP64(t, ID_AA64DFR0, PMUVER, 5); /* FEAT_PMUv3p4 */
45
cpu->isar.id_aa64dfr0 = t;
46
47
+ t = cpu->isar.id_aa64smfr0;
48
+ t = FIELD_DP64(t, ID_AA64SMFR0, F32F32, 1); /* FEAT_SME */
49
+ t = FIELD_DP64(t, ID_AA64SMFR0, B16F32, 1); /* FEAT_SME */
50
+ t = FIELD_DP64(t, ID_AA64SMFR0, F16F32, 1); /* FEAT_SME */
51
+ t = FIELD_DP64(t, ID_AA64SMFR0, I8I32, 0xf); /* FEAT_SME */
52
+ t = FIELD_DP64(t, ID_AA64SMFR0, F64F64, 1); /* FEAT_SME_F64F64 */
53
+ t = FIELD_DP64(t, ID_AA64SMFR0, I16I64, 0xf); /* FEAT_SME_I16I64 */
54
+ t = FIELD_DP64(t, ID_AA64SMFR0, FA64, 1); /* FEAT_SME_FA64 */
55
+ cpu->isar.id_aa64smfr0 = t;
31
+
56
+
32
ISA Interface
57
/* Replicate the same data to the 32-bit id registers. */
33
-------------
58
aa32_max_features(cpu);
34
35
@@ -XXX,XX +XXX,XX @@ bit 1: a guest panic has happened and will be handled by the guest;
36
the host should record it or report it, but should not affect
37
the execution of the guest.
38
39
+PCI Interface
40
+-------------
41
+
42
+The PCI interface is similar to the ISA interface except that it uses an MMIO
43
+address space provided by its BAR0, 1 byte long. Any machine with a PCI bus
44
+can enable a pvpanic device by adding '-device pvpanic-pci' to the command
45
+line.
46
+
47
ACPI Interface
48
--------------
49
59
50
--
60
--
51
2.20.1
61
2.25.1
52
53
diff view generated by jsdifflib
1
The state struct for the CMSDK APB timer device doesn't follow our
1
From: Richard Henderson <richard.henderson@linaro.org>
2
usual naming convention of camelcase -- "CMSDK" and "APB" are both
3
acronyms, but "TIMER" is not so should not be all-uppercase.
4
Globally rename the struct to "CMSDKAPBTimer" (bringing it into line
5
with CMSDKAPBWatchdog and CMSDKAPBDualTimer; CMSDKAPBUART remains
6
as-is because "UART" is an acronym).
7
2
8
Commit created with:
3
Reviewed-by: Peter Maydell <peter.maydell@linaro.org>
9
perl -p -i -e 's/CMSDKAPBTIMER/CMSDKAPBTimer/g' hw/timer/cmsdk-apb-timer.c include/hw/arm/armsse.h include/hw/timer/cmsdk-apb-timer.h
4
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
5
Message-id: 20220708151540.18136-34-richard.henderson@linaro.org
6
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
7
---
8
linux-user/aarch64/target_cpu.h | 5 ++++-
9
1 file changed, 4 insertions(+), 1 deletion(-)
10
10
11
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
11
diff --git a/linux-user/aarch64/target_cpu.h b/linux-user/aarch64/target_cpu.h
12
Reviewed-by: Philippe Mathieu-Daudé <f4bug@amsat.org>
13
Reviewed-by: Luc Michel <luc@lmichel.fr>
14
Tested-by: Philippe Mathieu-Daudé <f4bug@amsat.org>
15
Message-id: 20210128114145.20536-7-peter.maydell@linaro.org
16
Message-id: 20210121190622.22000-7-peter.maydell@linaro.org
17
---
18
include/hw/arm/armsse.h | 6 +++---
19
include/hw/timer/cmsdk-apb-timer.h | 4 ++--
20
hw/timer/cmsdk-apb-timer.c | 28 ++++++++++++++--------------
21
3 files changed, 19 insertions(+), 19 deletions(-)
22
23
diff --git a/include/hw/arm/armsse.h b/include/hw/arm/armsse.h
24
index XXXXXXX..XXXXXXX 100644
12
index XXXXXXX..XXXXXXX 100644
25
--- a/include/hw/arm/armsse.h
13
--- a/linux-user/aarch64/target_cpu.h
26
+++ b/include/hw/arm/armsse.h
14
+++ b/linux-user/aarch64/target_cpu.h
27
@@ -XXX,XX +XXX,XX @@ struct ARMSSE {
15
@@ -XXX,XX +XXX,XX @@ static inline void cpu_clone_regs_parent(CPUARMState *env, unsigned flags)
28
TZPPC apb_ppc0;
16
29
TZPPC apb_ppc1;
17
static inline void cpu_set_tls(CPUARMState *env, target_ulong newtls)
30
TZMPC mpc[IOTS_NUM_MPC];
31
- CMSDKAPBTIMER timer0;
32
- CMSDKAPBTIMER timer1;
33
- CMSDKAPBTIMER s32ktimer;
34
+ CMSDKAPBTimer timer0;
35
+ CMSDKAPBTimer timer1;
36
+ CMSDKAPBTimer s32ktimer;
37
qemu_or_irq ppc_irq_orgate;
38
SplitIRQ sec_resp_splitter;
39
SplitIRQ ppc_irq_splitter[NUM_PPCS];
40
diff --git a/include/hw/timer/cmsdk-apb-timer.h b/include/hw/timer/cmsdk-apb-timer.h
41
index XXXXXXX..XXXXXXX 100644
42
--- a/include/hw/timer/cmsdk-apb-timer.h
43
+++ b/include/hw/timer/cmsdk-apb-timer.h
44
@@ -XXX,XX +XXX,XX @@
45
#include "qom/object.h"
46
47
#define TYPE_CMSDK_APB_TIMER "cmsdk-apb-timer"
48
-OBJECT_DECLARE_SIMPLE_TYPE(CMSDKAPBTIMER, CMSDK_APB_TIMER)
49
+OBJECT_DECLARE_SIMPLE_TYPE(CMSDKAPBTimer, CMSDK_APB_TIMER)
50
51
-struct CMSDKAPBTIMER {
52
+struct CMSDKAPBTimer {
53
/*< private >*/
54
SysBusDevice parent_obj;
55
56
diff --git a/hw/timer/cmsdk-apb-timer.c b/hw/timer/cmsdk-apb-timer.c
57
index XXXXXXX..XXXXXXX 100644
58
--- a/hw/timer/cmsdk-apb-timer.c
59
+++ b/hw/timer/cmsdk-apb-timer.c
60
@@ -XXX,XX +XXX,XX @@ static const int timer_id[] = {
61
0x0d, 0xf0, 0x05, 0xb1, /* CID0..CID3 */
62
};
63
64
-static void cmsdk_apb_timer_update(CMSDKAPBTIMER *s)
65
+static void cmsdk_apb_timer_update(CMSDKAPBTimer *s)
66
{
18
{
67
qemu_set_irq(s->timerint, !!(s->intstatus & R_INTSTATUS_IRQ_MASK));
19
- /* Note that AArch64 Linux keeps the TLS pointer in TPIDR; this is
20
+ /*
21
+ * Note that AArch64 Linux keeps the TLS pointer in TPIDR; this is
22
* different from AArch32 Linux, which uses TPIDRRO.
23
*/
24
env->cp15.tpidr_el[0] = newtls;
25
+ /* TPIDR2_EL0 is cleared with CLONE_SETTLS. */
26
+ env->cp15.tpidr2_el0 = 0;
68
}
27
}
69
28
70
static uint64_t cmsdk_apb_timer_read(void *opaque, hwaddr offset, unsigned size)
29
static inline abi_ulong get_sp_from_cpustate(CPUARMState *state)
71
{
72
- CMSDKAPBTIMER *s = CMSDK_APB_TIMER(opaque);
73
+ CMSDKAPBTimer *s = CMSDK_APB_TIMER(opaque);
74
uint64_t r;
75
76
switch (offset) {
77
@@ -XXX,XX +XXX,XX @@ static uint64_t cmsdk_apb_timer_read(void *opaque, hwaddr offset, unsigned size)
78
static void cmsdk_apb_timer_write(void *opaque, hwaddr offset, uint64_t value,
79
unsigned size)
80
{
81
- CMSDKAPBTIMER *s = CMSDK_APB_TIMER(opaque);
82
+ CMSDKAPBTimer *s = CMSDK_APB_TIMER(opaque);
83
84
trace_cmsdk_apb_timer_write(offset, value, size);
85
86
@@ -XXX,XX +XXX,XX @@ static const MemoryRegionOps cmsdk_apb_timer_ops = {
87
88
static void cmsdk_apb_timer_tick(void *opaque)
89
{
90
- CMSDKAPBTIMER *s = CMSDK_APB_TIMER(opaque);
91
+ CMSDKAPBTimer *s = CMSDK_APB_TIMER(opaque);
92
93
if (s->ctrl & R_CTRL_IRQEN_MASK) {
94
s->intstatus |= R_INTSTATUS_IRQ_MASK;
95
@@ -XXX,XX +XXX,XX @@ static void cmsdk_apb_timer_tick(void *opaque)
96
97
static void cmsdk_apb_timer_reset(DeviceState *dev)
98
{
99
- CMSDKAPBTIMER *s = CMSDK_APB_TIMER(dev);
100
+ CMSDKAPBTimer *s = CMSDK_APB_TIMER(dev);
101
102
trace_cmsdk_apb_timer_reset();
103
s->ctrl = 0;
104
@@ -XXX,XX +XXX,XX @@ static void cmsdk_apb_timer_reset(DeviceState *dev)
105
static void cmsdk_apb_timer_init(Object *obj)
106
{
107
SysBusDevice *sbd = SYS_BUS_DEVICE(obj);
108
- CMSDKAPBTIMER *s = CMSDK_APB_TIMER(obj);
109
+ CMSDKAPBTimer *s = CMSDK_APB_TIMER(obj);
110
111
memory_region_init_io(&s->iomem, obj, &cmsdk_apb_timer_ops,
112
s, "cmsdk-apb-timer", 0x1000);
113
@@ -XXX,XX +XXX,XX @@ static void cmsdk_apb_timer_init(Object *obj)
114
115
static void cmsdk_apb_timer_realize(DeviceState *dev, Error **errp)
116
{
117
- CMSDKAPBTIMER *s = CMSDK_APB_TIMER(dev);
118
+ CMSDKAPBTimer *s = CMSDK_APB_TIMER(dev);
119
120
if (s->pclk_frq == 0) {
121
error_setg(errp, "CMSDK APB timer: pclk-frq property must be set");
122
@@ -XXX,XX +XXX,XX @@ static const VMStateDescription cmsdk_apb_timer_vmstate = {
123
.version_id = 1,
124
.minimum_version_id = 1,
125
.fields = (VMStateField[]) {
126
- VMSTATE_PTIMER(timer, CMSDKAPBTIMER),
127
- VMSTATE_UINT32(ctrl, CMSDKAPBTIMER),
128
- VMSTATE_UINT32(value, CMSDKAPBTIMER),
129
- VMSTATE_UINT32(reload, CMSDKAPBTIMER),
130
- VMSTATE_UINT32(intstatus, CMSDKAPBTIMER),
131
+ VMSTATE_PTIMER(timer, CMSDKAPBTimer),
132
+ VMSTATE_UINT32(ctrl, CMSDKAPBTimer),
133
+ VMSTATE_UINT32(value, CMSDKAPBTimer),
134
+ VMSTATE_UINT32(reload, CMSDKAPBTimer),
135
+ VMSTATE_UINT32(intstatus, CMSDKAPBTimer),
136
VMSTATE_END_OF_LIST()
137
}
138
};
139
140
static Property cmsdk_apb_timer_properties[] = {
141
- DEFINE_PROP_UINT32("pclk-frq", CMSDKAPBTIMER, pclk_frq, 0),
142
+ DEFINE_PROP_UINT32("pclk-frq", CMSDKAPBTimer, pclk_frq, 0),
143
DEFINE_PROP_END_OF_LIST(),
144
};
145
146
@@ -XXX,XX +XXX,XX @@ static void cmsdk_apb_timer_class_init(ObjectClass *klass, void *data)
147
static const TypeInfo cmsdk_apb_timer_info = {
148
.name = TYPE_CMSDK_APB_TIMER,
149
.parent = TYPE_SYS_BUS_DEVICE,
150
- .instance_size = sizeof(CMSDKAPBTIMER),
151
+ .instance_size = sizeof(CMSDKAPBTimer),
152
.instance_init = cmsdk_apb_timer_init,
153
.class_init = cmsdk_apb_timer_class_init,
154
};
155
--
30
--
156
2.20.1
31
2.25.1
157
158
diff view generated by jsdifflib
1
Create a fixed-frequency Clock object to be the SYSCLK, and wire it
1
From: Richard Henderson <richard.henderson@linaro.org>
2
up to the devices that require it.
3
2
3
Reviewed-by: Peter Maydell <peter.maydell@linaro.org>
4
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
5
Message-id: 20220708151540.18136-35-richard.henderson@linaro.org
4
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
6
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
5
Reviewed-by: Philippe Mathieu-Daudé <f4bug@amsat.org>
6
Reviewed-by: Luc Michel <luc@lmichel.fr>
7
Tested-by: Philippe Mathieu-Daudé <f4bug@amsat.org>
8
Message-id: 20210128114145.20536-14-peter.maydell@linaro.org
9
Message-id: 20210121190622.22000-14-peter.maydell@linaro.org
10
---
7
---
11
hw/arm/mps2.c | 9 +++++++++
8
linux-user/aarch64/cpu_loop.c | 9 +++++++++
12
1 file changed, 9 insertions(+)
9
1 file changed, 9 insertions(+)
13
10
14
diff --git a/hw/arm/mps2.c b/hw/arm/mps2.c
11
diff --git a/linux-user/aarch64/cpu_loop.c b/linux-user/aarch64/cpu_loop.c
15
index XXXXXXX..XXXXXXX 100644
12
index XXXXXXX..XXXXXXX 100644
16
--- a/hw/arm/mps2.c
13
--- a/linux-user/aarch64/cpu_loop.c
17
+++ b/hw/arm/mps2.c
14
+++ b/linux-user/aarch64/cpu_loop.c
18
@@ -XXX,XX +XXX,XX @@
15
@@ -XXX,XX +XXX,XX @@ void cpu_loop(CPUARMState *env)
19
#include "hw/net/lan9118.h"
16
20
#include "net/net.h"
17
switch (trapnr) {
21
#include "hw/watchdog/cmsdk-apb-watchdog.h"
18
case EXCP_SWI:
22
+#include "hw/qdev-clock.h"
19
+ /*
23
#include "qom/object.h"
20
+ * On syscall, PSTATE.ZA is preserved, along with the ZA matrix.
24
21
+ * PSTATE.SM is cleared, per SMSTOP, which does ResetSVEState.
25
typedef enum MPS2FPGAType {
22
+ */
26
@@ -XXX,XX +XXX,XX @@ struct MPS2MachineState {
23
+ if (FIELD_EX64(env->svcr, SVCR, SM)) {
27
CMSDKAPBDualTimer dualtimer;
24
+ env->svcr = FIELD_DP64(env->svcr, SVCR, SM, 0);
28
CMSDKAPBWatchdog watchdog;
25
+ arm_rebuild_hflags(env);
29
CMSDKAPBTimer timer[2];
26
+ arm_reset_sve_state(env);
30
+ Clock *sysclk;
27
+ }
31
};
28
ret = do_syscall(env,
32
29
env->xregs[8],
33
#define TYPE_MPS2_MACHINE "mps2"
30
env->xregs[0],
34
@@ -XXX,XX +XXX,XX @@ static void mps2_common_init(MachineState *machine)
35
exit(EXIT_FAILURE);
36
}
37
38
+ /* This clock doesn't need migration because it is fixed-frequency */
39
+ mms->sysclk = clock_new(OBJECT(machine), "SYSCLK");
40
+ clock_set_hz(mms->sysclk, SYSCLK_FRQ);
41
+
42
/* The FPGA images have an odd combination of different RAMs,
43
* because in hardware they are different implementations and
44
* connected to different buses, giving varying performance/size
45
@@ -XXX,XX +XXX,XX @@ static void mps2_common_init(MachineState *machine)
46
TYPE_CMSDK_APB_TIMER);
47
sbd = SYS_BUS_DEVICE(&mms->timer[i]);
48
qdev_prop_set_uint32(DEVICE(&mms->timer[i]), "pclk-frq", SYSCLK_FRQ);
49
+ qdev_connect_clock_in(DEVICE(&mms->timer[i]), "pclk", mms->sysclk);
50
sysbus_realize_and_unref(sbd, &error_fatal);
51
sysbus_mmio_map(sbd, 0, base);
52
sysbus_connect_irq(sbd, 0, qdev_get_gpio_in(armv7m, irqno));
53
@@ -XXX,XX +XXX,XX @@ static void mps2_common_init(MachineState *machine)
54
object_initialize_child(OBJECT(mms), "dualtimer", &mms->dualtimer,
55
TYPE_CMSDK_APB_DUALTIMER);
56
qdev_prop_set_uint32(DEVICE(&mms->dualtimer), "pclk-frq", SYSCLK_FRQ);
57
+ qdev_connect_clock_in(DEVICE(&mms->dualtimer), "TIMCLK", mms->sysclk);
58
sysbus_realize(SYS_BUS_DEVICE(&mms->dualtimer), &error_fatal);
59
sysbus_connect_irq(SYS_BUS_DEVICE(&mms->dualtimer), 0,
60
qdev_get_gpio_in(armv7m, 10));
61
@@ -XXX,XX +XXX,XX @@ static void mps2_common_init(MachineState *machine)
62
object_initialize_child(OBJECT(mms), "watchdog", &mms->watchdog,
63
TYPE_CMSDK_APB_WATCHDOG);
64
qdev_prop_set_uint32(DEVICE(&mms->watchdog), "wdogclk-frq", SYSCLK_FRQ);
65
+ qdev_connect_clock_in(DEVICE(&mms->watchdog), "WDOGCLK", mms->sysclk);
66
sysbus_realize(SYS_BUS_DEVICE(&mms->watchdog), &error_fatal);
67
sysbus_connect_irq(SYS_BUS_DEVICE(&mms->watchdog), 0,
68
qdev_get_gpio_in_named(armv7m, "NMI", 0));
69
--
31
--
70
2.20.1
32
2.25.1
71
72
diff view generated by jsdifflib
1
From: Joelle van Dyne <j@getutm.app>
1
From: Richard Henderson <richard.henderson@linaro.org>
2
2
3
The iOS toolchain does not use the host prefix naming convention. So we
3
Make sure to zero the currently reserved fields.
4
need to enable cross-compile options while allowing the PREFIX to be
5
blank.
6
4
7
Reviewed-by: Philippe Mathieu-Daudé <f4bug@amsat.org>
5
Reviewed-by: Peter Maydell <peter.maydell@linaro.org>
8
Signed-off-by: Joelle van Dyne <j@getutm.app>
6
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
9
Message-id: 20210126012457.39046-3-j@getutm.app
7
Message-id: 20220708151540.18136-36-richard.henderson@linaro.org
10
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
8
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
11
---
9
---
12
configure | 6 ++++--
10
linux-user/aarch64/signal.c | 9 ++++++++-
13
1 file changed, 4 insertions(+), 2 deletions(-)
11
1 file changed, 8 insertions(+), 1 deletion(-)
14
12
15
diff --git a/configure b/configure
13
diff --git a/linux-user/aarch64/signal.c b/linux-user/aarch64/signal.c
16
index XXXXXXX..XXXXXXX 100755
14
index XXXXXXX..XXXXXXX 100644
17
--- a/configure
15
--- a/linux-user/aarch64/signal.c
18
+++ b/configure
16
+++ b/linux-user/aarch64/signal.c
19
@@ -XXX,XX +XXX,XX @@ cpu=""
17
@@ -XXX,XX +XXX,XX @@ struct target_extra_context {
20
iasl="iasl"
18
struct target_sve_context {
21
interp_prefix="/usr/gnemul/qemu-%M"
19
struct target_aarch64_ctx head;
22
static="no"
20
uint16_t vl;
23
+cross_compile="no"
21
- uint16_t reserved[3];
24
cross_prefix=""
22
+ uint16_t flags;
25
audio_drv_list=""
23
+ uint16_t reserved[2];
26
block_drv_rw_whitelist=""
24
/* The actual SVE data immediately follows. It is laid out
27
@@ -XXX,XX +XXX,XX @@ for opt do
25
* according to TARGET_SVE_SIG_{Z,P}REG_OFFSET, based off of
28
optarg=$(expr "x$opt" : 'x[^=]*=\(.*\)')
26
* the original struct pointer.
29
case "$opt" in
27
@@ -XXX,XX +XXX,XX @@ struct target_sve_context {
30
--cross-prefix=*) cross_prefix="$optarg"
28
#define TARGET_SVE_SIG_CONTEXT_SIZE(VQ) \
31
+ cross_compile="yes"
29
(TARGET_SVE_SIG_PREG_OFFSET(VQ, 17))
32
;;
30
33
--cc=*) CC="$optarg"
31
+#define TARGET_SVE_SIG_FLAG_SM 1
34
;;
32
+
35
@@ -XXX,XX +XXX,XX @@ $(echo Deprecated targets: $deprecated_targets_list | \
33
struct target_rt_sigframe {
36
--target-list-exclude=LIST exclude a set of targets from the default target-list
34
struct target_siginfo info;
37
35
struct target_ucontext uc;
38
Advanced options (experts only):
36
@@ -XXX,XX +XXX,XX @@ static void target_setup_sve_record(struct target_sve_context *sve,
39
- --cross-prefix=PREFIX use PREFIX for compile tools [$cross_prefix]
37
{
40
+ --cross-prefix=PREFIX use PREFIX for compile tools, PREFIX can be blank [$cross_prefix]
38
int i, j;
41
--cc=CC use C compiler CC [$cc]
39
42
--iasl=IASL use ACPI compiler IASL [$iasl]
40
+ memset(sve, 0, sizeof(*sve));
43
--host-cc=CC use C compiler CC [$host_cc] for code run at
41
__put_user(TARGET_SVE_MAGIC, &sve->head.magic);
44
@@ -XXX,XX +XXX,XX @@ if has $sdl2_config; then
42
__put_user(size, &sve->head.size);
45
fi
43
__put_user(vq * TARGET_SVE_VQ_BYTES, &sve->vl);
46
echo "strip = [$(meson_quote $strip)]" >> $cross
44
+ if (FIELD_EX64(env->svcr, SVCR, SM)) {
47
echo "windres = [$(meson_quote $windres)]" >> $cross
45
+ __put_user(TARGET_SVE_SIG_FLAG_SM, &sve->flags);
48
-if test -n "$cross_prefix"; then
46
+ }
49
+if test "$cross_compile" = "yes"; then
47
50
cross_arg="--cross-file config-meson.cross"
48
/* Note that SVE regs are stored as a byte stream, with each byte element
51
echo "[host_machine]" >> $cross
49
* at a subsequent address. This corresponds to a little-endian store
52
if test "$mingw32" = "yes" ; then
53
--
50
--
54
2.20.1
51
2.25.1
55
56
diff view generated by jsdifflib
1
While we transition the ARMSSE code from integer properties
1
From: Richard Henderson <richard.henderson@linaro.org>
2
specifying clock frequencies to Clock objects, we want to have the
3
device provide both at once. We want the final name of the main
4
input Clock to be "MAINCLK", following the hardware name.
5
Unfortunately creating an input Clock with a name X creates an
6
under-the-hood QOM property X; for "MAINCLK" this clashes with the
7
existing UINT32 property of that name.
8
2
9
Rename the UINT32 property to MAINCLK_FRQ so it can coexist with the
3
Fold the return value setting into the goto, so each
10
MAINCLK Clock; once the transition is complete MAINCLK_FRQ will be
4
point of failure need not do both.
11
deleted.
12
5
13
Commit created with:
6
Reviewed-by: Peter Maydell <peter.maydell@linaro.org>
14
perl -p -i -e 's/MAINCLK/MAINCLK_FRQ/g' hw/arm/{armsse,mps2-tz,musca}.c include/hw/arm/armsse.h
7
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
8
Message-id: 20220708151540.18136-37-richard.henderson@linaro.org
9
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
10
---
11
linux-user/aarch64/signal.c | 26 +++++++++++---------------
12
1 file changed, 11 insertions(+), 15 deletions(-)
15
13
16
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
14
diff --git a/linux-user/aarch64/signal.c b/linux-user/aarch64/signal.c
17
Reviewed-by: Philippe Mathieu-Daudé <f4bug@amsat.org>
18
Reviewed-by: Luc Michel <luc@lmichel.fr>
19
Tested-by: Philippe Mathieu-Daudé <f4bug@amsat.org>
20
Message-id: 20210128114145.20536-11-peter.maydell@linaro.org
21
Message-id: 20210121190622.22000-11-peter.maydell@linaro.org
22
---
23
include/hw/arm/armsse.h | 2 +-
24
hw/arm/armsse.c | 6 +++---
25
hw/arm/mps2-tz.c | 2 +-
26
hw/arm/musca.c | 2 +-
27
4 files changed, 6 insertions(+), 6 deletions(-)
28
29
diff --git a/include/hw/arm/armsse.h b/include/hw/arm/armsse.h
30
index XXXXXXX..XXXXXXX 100644
15
index XXXXXXX..XXXXXXX 100644
31
--- a/include/hw/arm/armsse.h
16
--- a/linux-user/aarch64/signal.c
32
+++ b/include/hw/arm/armsse.h
17
+++ b/linux-user/aarch64/signal.c
33
@@ -XXX,XX +XXX,XX @@
18
@@ -XXX,XX +XXX,XX @@ static int target_restore_sigframe(CPUARMState *env,
34
* QEMU interface:
19
struct target_sve_context *sve = NULL;
35
* + QOM property "memory" is a MemoryRegion containing the devices provided
20
uint64_t extra_datap = 0;
36
* by the board model.
21
bool used_extra = false;
37
- * + QOM property "MAINCLK" is the frequency of the main system clock
22
- bool err = false;
38
+ * + QOM property "MAINCLK_FRQ" is the frequency of the main system clock
23
int vq = 0, sve_size = 0;
39
* + QOM property "EXP_NUMIRQ" sets the number of expansion interrupts.
24
40
* (In hardware, the SSE-200 permits the number of expansion interrupts
25
target_restore_general_frame(env, sf);
41
* for the two CPUs to be configured separately, but we restrict it to
26
@@ -XXX,XX +XXX,XX @@ static int target_restore_sigframe(CPUARMState *env,
42
diff --git a/hw/arm/armsse.c b/hw/arm/armsse.c
27
switch (magic) {
43
index XXXXXXX..XXXXXXX 100644
28
case 0:
44
--- a/hw/arm/armsse.c
29
if (size != 0) {
45
+++ b/hw/arm/armsse.c
30
- err = true;
46
@@ -XXX,XX +XXX,XX @@ static Property iotkit_properties[] = {
31
- goto exit;
47
DEFINE_PROP_LINK("memory", ARMSSE, board_memory, TYPE_MEMORY_REGION,
32
+ goto err;
48
MemoryRegion *),
33
}
49
DEFINE_PROP_UINT32("EXP_NUMIRQ", ARMSSE, exp_numirq, 64),
34
if (used_extra) {
50
- DEFINE_PROP_UINT32("MAINCLK", ARMSSE, mainclk_frq, 0),
35
ctx = NULL;
51
+ DEFINE_PROP_UINT32("MAINCLK_FRQ", ARMSSE, mainclk_frq, 0),
36
@@ -XXX,XX +XXX,XX @@ static int target_restore_sigframe(CPUARMState *env,
52
DEFINE_PROP_UINT32("SRAM_ADDR_WIDTH", ARMSSE, sram_addr_width, 15),
37
53
DEFINE_PROP_UINT32("init-svtor", ARMSSE, init_svtor, 0x10000000),
38
case TARGET_FPSIMD_MAGIC:
54
DEFINE_PROP_BOOL("CPU0_FPU", ARMSSE, cpu_fpu[0], true),
39
if (fpsimd || size != sizeof(struct target_fpsimd_context)) {
55
@@ -XXX,XX +XXX,XX @@ static Property armsse_properties[] = {
40
- err = true;
56
DEFINE_PROP_LINK("memory", ARMSSE, board_memory, TYPE_MEMORY_REGION,
41
- goto exit;
57
MemoryRegion *),
42
+ goto err;
58
DEFINE_PROP_UINT32("EXP_NUMIRQ", ARMSSE, exp_numirq, 64),
43
}
59
- DEFINE_PROP_UINT32("MAINCLK", ARMSSE, mainclk_frq, 0),
44
fpsimd = (struct target_fpsimd_context *)ctx;
60
+ DEFINE_PROP_UINT32("MAINCLK_FRQ", ARMSSE, mainclk_frq, 0),
45
break;
61
DEFINE_PROP_UINT32("SRAM_ADDR_WIDTH", ARMSSE, sram_addr_width, 15),
46
@@ -XXX,XX +XXX,XX @@ static int target_restore_sigframe(CPUARMState *env,
62
DEFINE_PROP_UINT32("init-svtor", ARMSSE, init_svtor, 0x10000000),
47
break;
63
DEFINE_PROP_BOOL("CPU0_FPU", ARMSSE, cpu_fpu[0], false),
48
}
64
@@ -XXX,XX +XXX,XX @@ static void armsse_realize(DeviceState *dev, Error **errp)
49
}
50
- err = true;
51
- goto exit;
52
+ goto err;
53
54
case TARGET_EXTRA_MAGIC:
55
if (extra || size != sizeof(struct target_extra_context)) {
56
- err = true;
57
- goto exit;
58
+ goto err;
59
}
60
__get_user(extra_datap,
61
&((struct target_extra_context *)ctx)->datap);
62
@@ -XXX,XX +XXX,XX @@ static int target_restore_sigframe(CPUARMState *env,
63
/* Unknown record -- we certainly didn't generate it.
64
* Did we in fact get out of sync?
65
*/
66
- err = true;
67
- goto exit;
68
+ goto err;
69
}
70
ctx = (void *)ctx + size;
65
}
71
}
66
72
@@ -XXX,XX +XXX,XX @@ static int target_restore_sigframe(CPUARMState *env,
67
if (!s->mainclk_frq) {
73
if (fpsimd) {
68
- error_setg(errp, "MAINCLK property was not set");
74
target_restore_fpsimd_record(env, fpsimd);
69
+ error_setg(errp, "MAINCLK_FRQ property was not set");
75
} else {
70
return;
76
- err = true;
77
+ goto err;
71
}
78
}
72
79
73
diff --git a/hw/arm/mps2-tz.c b/hw/arm/mps2-tz.c
80
/* SVE data, if present, overwrites FPSIMD data. */
74
index XXXXXXX..XXXXXXX 100644
81
if (sve) {
75
--- a/hw/arm/mps2-tz.c
82
target_restore_sve_record(env, sve, vq);
76
+++ b/hw/arm/mps2-tz.c
83
}
77
@@ -XXX,XX +XXX,XX @@ static void mps2tz_common_init(MachineState *machine)
84
-
78
object_property_set_link(OBJECT(&mms->iotkit), "memory",
85
- exit:
79
OBJECT(system_memory), &error_abort);
86
unlock_user(extra, extra_datap, 0);
80
qdev_prop_set_uint32(iotkitdev, "EXP_NUMIRQ", MPS2TZ_NUMIRQ);
87
- return err;
81
- qdev_prop_set_uint32(iotkitdev, "MAINCLK", SYSCLK_FRQ);
88
+ return 0;
82
+ qdev_prop_set_uint32(iotkitdev, "MAINCLK_FRQ", SYSCLK_FRQ);
89
+
83
sysbus_realize(SYS_BUS_DEVICE(&mms->iotkit), &error_fatal);
90
+ err:
84
91
+ unlock_user(extra, extra_datap, 0);
85
/*
92
+ return 1;
86
diff --git a/hw/arm/musca.c b/hw/arm/musca.c
93
}
87
index XXXXXXX..XXXXXXX 100644
94
88
--- a/hw/arm/musca.c
95
static abi_ulong get_sigframe(struct target_sigaction *ka,
89
+++ b/hw/arm/musca.c
90
@@ -XXX,XX +XXX,XX @@ static void musca_init(MachineState *machine)
91
qdev_prop_set_uint32(ssedev, "EXP_NUMIRQ", mmc->num_irqs);
92
qdev_prop_set_uint32(ssedev, "init-svtor", mmc->init_svtor);
93
qdev_prop_set_uint32(ssedev, "SRAM_ADDR_WIDTH", mmc->sram_addr_width);
94
- qdev_prop_set_uint32(ssedev, "MAINCLK", SYSCLK_FRQ);
95
+ qdev_prop_set_uint32(ssedev, "MAINCLK_FRQ", SYSCLK_FRQ);
96
/*
97
* Musca-A takes the default SSE-200 FPU/DSP settings (ie no for
98
* CPU0 and yes for CPU1); Musca-B1 explicitly enables them for CPU0.
99
--
96
--
100
2.20.1
97
2.25.1
101
102
diff view generated by jsdifflib
1
From: Joelle van Dyne <j@getutm.app>
1
From: Richard Henderson <richard.henderson@linaro.org>
2
2
3
Reviewed-by: Philippe Mathieu-Daudé <philmd@redhat.com>
3
In parse_user_sigframe, the kernel rejects duplicate sve records,
4
Signed-off-by: Joelle van Dyne <j@getutm.app>
4
or records that are smaller than the header. We were silently
5
Message-id: 20210126012457.39046-9-j@getutm.app
5
allowing these cases to pass, dropping the record.
6
7
Reviewed-by: Peter Maydell <peter.maydell@linaro.org>
8
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
9
Message-id: 20220708151540.18136-38-richard.henderson@linaro.org
6
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
10
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
7
---
11
---
8
configure | 5 ++++-
12
linux-user/aarch64/signal.c | 5 ++++-
9
1 file changed, 4 insertions(+), 1 deletion(-)
13
1 file changed, 4 insertions(+), 1 deletion(-)
10
14
11
diff --git a/configure b/configure
15
diff --git a/linux-user/aarch64/signal.c b/linux-user/aarch64/signal.c
12
index XXXXXXX..XXXXXXX 100755
16
index XXXXXXX..XXXXXXX 100644
13
--- a/configure
17
--- a/linux-user/aarch64/signal.c
14
+++ b/configure
18
+++ b/linux-user/aarch64/signal.c
15
@@ -XXX,XX +XXX,XX @@ if test "$cross_compile" = "yes"; then
19
@@ -XXX,XX +XXX,XX @@ static int target_restore_sigframe(CPUARMState *env,
16
echo "system = 'darwin'" >> $cross
20
break;
17
fi
21
18
case "$ARCH" in
22
case TARGET_SVE_MAGIC:
19
- i386|x86_64)
23
+ if (sve || size < sizeof(struct target_sve_context)) {
20
+ i386)
24
+ goto err;
21
echo "cpu_family = 'x86'" >> $cross
25
+ }
22
;;
26
if (cpu_isar_feature(aa64_sve, env_archcpu(env))) {
23
+ x86_64)
27
vq = sve_vq(env);
24
+ echo "cpu_family = 'x86_64'" >> $cross
28
sve_size = QEMU_ALIGN_UP(TARGET_SVE_SIG_CONTEXT_SIZE(vq), 16);
25
+ ;;
29
- if (!sve && size == sve_size) {
26
ppc64le)
30
+ if (size == sve_size) {
27
echo "cpu_family = 'ppc64'" >> $cross
31
sve = (struct target_sve_context *)ctx;
28
;;
32
break;
33
}
29
--
34
--
30
2.20.1
35
2.25.1
31
32
diff view generated by jsdifflib
1
From: Joelle van Dyne <j@getutm.app>
1
From: Richard Henderson <richard.henderson@linaro.org>
2
3
Add objc to the Meson cross file as well as detection of Darwin.
4
2
5
Reviewed-by: Peter Maydell <peter.maydell@linaro.org>
3
Reviewed-by: Peter Maydell <peter.maydell@linaro.org>
6
Signed-off-by: Joelle van Dyne <j@getutm.app>
4
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
7
Reviewed-by: Philippe Mathieu-Daudé <f4bug@amsat.org>
5
Message-id: 20220708151540.18136-39-richard.henderson@linaro.org
8
Message-id: 20210126012457.39046-8-j@getutm.app
9
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
6
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
10
---
7
---
11
configure | 4 ++++
8
linux-user/aarch64/signal.c | 3 +++
12
1 file changed, 4 insertions(+)
9
1 file changed, 3 insertions(+)
13
10
14
diff --git a/configure b/configure
11
diff --git a/linux-user/aarch64/signal.c b/linux-user/aarch64/signal.c
15
index XXXXXXX..XXXXXXX 100755
12
index XXXXXXX..XXXXXXX 100644
16
--- a/configure
13
--- a/linux-user/aarch64/signal.c
17
+++ b/configure
14
+++ b/linux-user/aarch64/signal.c
18
@@ -XXX,XX +XXX,XX @@ echo "cpp_link_args = [${LDFLAGS:+$(meson_quote $LDFLAGS)}]" >> $cross
15
@@ -XXX,XX +XXX,XX @@ static int target_restore_sigframe(CPUARMState *env,
19
echo "[binaries]" >> $cross
16
__get_user(extra_size,
20
echo "c = [$(meson_quote $cc)]" >> $cross
17
&((struct target_extra_context *)ctx)->size);
21
test -n "$cxx" && echo "cpp = [$(meson_quote $cxx)]" >> $cross
18
extra = lock_user(VERIFY_READ, extra_datap, extra_size, 0);
22
+test -n "$objcc" && echo "objc = [$(meson_quote $objcc)]" >> $cross
19
+ if (!extra) {
23
echo "ar = [$(meson_quote $ar)]" >> $cross
20
+ return 1;
24
echo "nm = [$(meson_quote $nm)]" >> $cross
21
+ }
25
echo "pkgconfig = [$(meson_quote $pkg_config_exe)]" >> $cross
22
break;
26
@@ -XXX,XX +XXX,XX @@ if test "$cross_compile" = "yes"; then
23
27
if test "$linux" = "yes" ; then
24
default:
28
echo "system = 'linux'" >> $cross
29
fi
30
+ if test "$darwin" = "yes" ; then
31
+ echo "system = 'darwin'" >> $cross
32
+ fi
33
case "$ARCH" in
34
i386|x86_64)
35
echo "cpu_family = 'x86'" >> $cross
36
--
25
--
37
2.20.1
26
2.25.1
38
39
diff view generated by jsdifflib
1
From: Maxim Uvarov <maxim.uvarov@linaro.org>
1
From: Richard Henderson <richard.henderson@linaro.org>
2
2
3
No functional change. Just refactor code to better
3
Move the checks out of the parsing loop and into the
4
support secure and normal world gpios.
4
restore function. This more closely mirrors the code
5
structure in the kernel, and is slightly clearer.
5
6
6
Signed-off-by: Maxim Uvarov <maxim.uvarov@linaro.org>
7
Reject rather than silently skip incorrect VL and SVE record sizes,
7
Reviewed-by: Andrew Jones <drjones@redhat.com>
8
bringing our checks in to line with those the kernel does.
9
10
Reviewed-by: Peter Maydell <peter.maydell@linaro.org>
11
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
12
Message-id: 20220708151540.18136-40-richard.henderson@linaro.org
8
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
13
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
9
---
14
---
10
hw/arm/virt.c | 57 ++++++++++++++++++++++++++++++++-------------------
15
linux-user/aarch64/signal.c | 51 +++++++++++++++++++++++++------------
11
1 file changed, 36 insertions(+), 21 deletions(-)
16
1 file changed, 35 insertions(+), 16 deletions(-)
12
17
13
diff --git a/hw/arm/virt.c b/hw/arm/virt.c
18
diff --git a/linux-user/aarch64/signal.c b/linux-user/aarch64/signal.c
14
index XXXXXXX..XXXXXXX 100644
19
index XXXXXXX..XXXXXXX 100644
15
--- a/hw/arm/virt.c
20
--- a/linux-user/aarch64/signal.c
16
+++ b/hw/arm/virt.c
21
+++ b/linux-user/aarch64/signal.c
17
@@ -XXX,XX +XXX,XX @@ static void virt_powerdown_req(Notifier *n, void *opaque)
22
@@ -XXX,XX +XXX,XX @@ static void target_restore_fpsimd_record(CPUARMState *env,
18
}
23
}
19
}
24
}
20
25
21
-static void create_gpio(const VirtMachineState *vms)
26
-static void target_restore_sve_record(CPUARMState *env,
22
+static void create_gpio_keys(const VirtMachineState *vms,
27
- struct target_sve_context *sve, int vq)
23
+ DeviceState *pl061_dev,
28
+static bool target_restore_sve_record(CPUARMState *env,
24
+ uint32_t phandle)
29
+ struct target_sve_context *sve,
25
+{
30
+ int size)
26
+ gpio_key_dev = sysbus_create_simple("gpio-key", -1,
31
{
27
+ qdev_get_gpio_in(pl061_dev, 3));
32
- int i, j;
33
+ int i, j, vl, vq;
34
35
- /* Note that SVE regs are stored as a byte stream, with each byte element
36
+ if (!cpu_isar_feature(aa64_sve, env_archcpu(env))) {
37
+ return false;
38
+ }
28
+
39
+
29
+ qemu_fdt_add_subnode(vms->fdt, "/gpio-keys");
40
+ __get_user(vl, &sve->vl);
30
+ qemu_fdt_setprop_string(vms->fdt, "/gpio-keys", "compatible", "gpio-keys");
41
+ vq = sve_vq(env);
31
+ qemu_fdt_setprop_cell(vms->fdt, "/gpio-keys", "#size-cells", 0);
32
+ qemu_fdt_setprop_cell(vms->fdt, "/gpio-keys", "#address-cells", 1);
33
+
42
+
34
+ qemu_fdt_add_subnode(vms->fdt, "/gpio-keys/poweroff");
43
+ /* Reject mismatched VL. */
35
+ qemu_fdt_setprop_string(vms->fdt, "/gpio-keys/poweroff",
44
+ if (vl != vq * TARGET_SVE_VQ_BYTES) {
36
+ "label", "GPIO Key Poweroff");
45
+ return false;
37
+ qemu_fdt_setprop_cell(vms->fdt, "/gpio-keys/poweroff", "linux,code",
46
+ }
38
+ KEY_POWER);
39
+ qemu_fdt_setprop_cells(vms->fdt, "/gpio-keys/poweroff",
40
+ "gpios", phandle, 3, 0);
41
+}
42
+
47
+
43
+static void create_gpio_devices(const VirtMachineState *vms, int gpio,
48
+ /* Accept empty record -- used to clear PSTATE.SM. */
44
+ MemoryRegion *mem)
49
+ if (size <= sizeof(*sve)) {
45
{
50
+ return true;
46
char *nodename;
51
+ }
47
DeviceState *pl061_dev;
48
- hwaddr base = vms->memmap[VIRT_GPIO].base;
49
- hwaddr size = vms->memmap[VIRT_GPIO].size;
50
- int irq = vms->irqmap[VIRT_GPIO];
51
+ hwaddr base = vms->memmap[gpio].base;
52
+ hwaddr size = vms->memmap[gpio].size;
53
+ int irq = vms->irqmap[gpio];
54
const char compat[] = "arm,pl061\0arm,primecell";
55
+ SysBusDevice *s;
56
57
- pl061_dev = sysbus_create_simple("pl061", base,
58
- qdev_get_gpio_in(vms->gic, irq));
59
+ pl061_dev = qdev_new("pl061");
60
+ s = SYS_BUS_DEVICE(pl061_dev);
61
+ sysbus_realize_and_unref(s, &error_fatal);
62
+ memory_region_add_subregion(mem, base, sysbus_mmio_get_region(s, 0));
63
+ sysbus_connect_irq(s, 0, qdev_get_gpio_in(vms->gic, irq));
64
65
uint32_t phandle = qemu_fdt_alloc_phandle(vms->fdt);
66
nodename = g_strdup_printf("/pl061@%" PRIx64, base);
67
@@ -XXX,XX +XXX,XX @@ static void create_gpio(const VirtMachineState *vms)
68
qemu_fdt_setprop_string(vms->fdt, nodename, "clock-names", "apb_pclk");
69
qemu_fdt_setprop_cell(vms->fdt, nodename, "phandle", phandle);
70
71
- gpio_key_dev = sysbus_create_simple("gpio-key", -1,
72
- qdev_get_gpio_in(pl061_dev, 3));
73
- qemu_fdt_add_subnode(vms->fdt, "/gpio-keys");
74
- qemu_fdt_setprop_string(vms->fdt, "/gpio-keys", "compatible", "gpio-keys");
75
- qemu_fdt_setprop_cell(vms->fdt, "/gpio-keys", "#size-cells", 0);
76
- qemu_fdt_setprop_cell(vms->fdt, "/gpio-keys", "#address-cells", 1);
77
-
78
- qemu_fdt_add_subnode(vms->fdt, "/gpio-keys/poweroff");
79
- qemu_fdt_setprop_string(vms->fdt, "/gpio-keys/poweroff",
80
- "label", "GPIO Key Poweroff");
81
- qemu_fdt_setprop_cell(vms->fdt, "/gpio-keys/poweroff", "linux,code",
82
- KEY_POWER);
83
- qemu_fdt_setprop_cells(vms->fdt, "/gpio-keys/poweroff",
84
- "gpios", phandle, 3, 0);
85
g_free(nodename);
86
+
52
+
87
+ /* Child gpio devices */
53
+ /* Reject non-empty but incomplete record. */
88
+ create_gpio_keys(vms, pl061_dev, phandle);
54
+ if (size < TARGET_SVE_SIG_CONTEXT_SIZE(vq)) {
55
+ return false;
56
+ }
57
+
58
+ /*
59
+ * Note that SVE regs are stored as a byte stream, with each byte element
60
* at a subsequent address. This corresponds to a little-endian load
61
* of our 64-bit hunks.
62
*/
63
@@ -XXX,XX +XXX,XX @@ static void target_restore_sve_record(CPUARMState *env,
64
}
65
}
66
}
67
+ return true;
89
}
68
}
90
69
91
static void create_virtio_devices(const VirtMachineState *vms)
70
static int target_restore_sigframe(CPUARMState *env,
92
@@ -XXX,XX +XXX,XX @@ static void machvirt_init(MachineState *machine)
71
@@ -XXX,XX +XXX,XX @@ static int target_restore_sigframe(CPUARMState *env,
93
if (has_ged && aarch64 && firmware_loaded && virt_is_acpi_enabled(vms)) {
72
struct target_sve_context *sve = NULL;
94
vms->acpi_dev = create_acpi_ged(vms);
73
uint64_t extra_datap = 0;
95
} else {
74
bool used_extra = false;
96
- create_gpio(vms);
75
- int vq = 0, sve_size = 0;
97
+ create_gpio_devices(vms, VIRT_GPIO, sysmem);
76
+ int sve_size = 0;
77
78
target_restore_general_frame(env, sf);
79
80
@@ -XXX,XX +XXX,XX @@ static int target_restore_sigframe(CPUARMState *env,
81
if (sve || size < sizeof(struct target_sve_context)) {
82
goto err;
83
}
84
- if (cpu_isar_feature(aa64_sve, env_archcpu(env))) {
85
- vq = sve_vq(env);
86
- sve_size = QEMU_ALIGN_UP(TARGET_SVE_SIG_CONTEXT_SIZE(vq), 16);
87
- if (size == sve_size) {
88
- sve = (struct target_sve_context *)ctx;
89
- break;
90
- }
91
- }
92
- goto err;
93
+ sve = (struct target_sve_context *)ctx;
94
+ sve_size = size;
95
+ break;
96
97
case TARGET_EXTRA_MAGIC:
98
if (extra || size != sizeof(struct target_extra_context)) {
99
@@ -XXX,XX +XXX,XX @@ static int target_restore_sigframe(CPUARMState *env,
98
}
100
}
99
101
100
/* connect powerdown request */
102
/* SVE data, if present, overwrites FPSIMD data. */
103
- if (sve) {
104
- target_restore_sve_record(env, sve, vq);
105
+ if (sve && !target_restore_sve_record(env, sve, sve_size)) {
106
+ goto err;
107
}
108
unlock_user(extra, extra_datap, 0);
109
return 0;
101
--
110
--
102
2.20.1
111
2.25.1
103
104
diff view generated by jsdifflib
1
Switch the CMSDK APB dualtimer device over to using its Clock input;
1
From: Richard Henderson <richard.henderson@linaro.org>
2
the pclk-frq property is now ignored.
3
2
3
Set the SM bit in the SVE record on signal delivery, create the ZA record.
4
Restore SM and ZA state according to the records present on return.
5
6
Reviewed-by: Peter Maydell <peter.maydell@linaro.org>
7
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
8
Message-id: 20220708151540.18136-41-richard.henderson@linaro.org
4
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
9
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
5
Reviewed-by: Luc Michel <luc@lmichel.fr>
6
Tested-by: Philippe Mathieu-Daudé <f4bug@amsat.org>
7
Reviewed-by: Philippe Mathieu-Daudé <f4bug@amsat.org>
8
Message-id: 20210128114145.20536-20-peter.maydell@linaro.org
9
Message-id: 20210121190622.22000-20-peter.maydell@linaro.org
10
Reviewed-by: Philippe Mathieu-Daudé <f4bug@amsat.org>
11
---
10
---
12
hw/timer/cmsdk-apb-dualtimer.c | 42 ++++++++++++++++++++++++++++++----
11
linux-user/aarch64/signal.c | 167 +++++++++++++++++++++++++++++++++---
13
1 file changed, 37 insertions(+), 5 deletions(-)
12
1 file changed, 154 insertions(+), 13 deletions(-)
14
13
15
diff --git a/hw/timer/cmsdk-apb-dualtimer.c b/hw/timer/cmsdk-apb-dualtimer.c
14
diff --git a/linux-user/aarch64/signal.c b/linux-user/aarch64/signal.c
16
index XXXXXXX..XXXXXXX 100644
15
index XXXXXXX..XXXXXXX 100644
17
--- a/hw/timer/cmsdk-apb-dualtimer.c
16
--- a/linux-user/aarch64/signal.c
18
+++ b/hw/timer/cmsdk-apb-dualtimer.c
17
+++ b/linux-user/aarch64/signal.c
19
@@ -XXX,XX +XXX,XX @@ static void cmsdk_apb_dualtimer_update(CMSDKAPBDualTimer *s)
18
@@ -XXX,XX +XXX,XX @@ struct target_sve_context {
20
qemu_set_irq(s->timerintc, timintc);
19
20
#define TARGET_SVE_SIG_FLAG_SM 1
21
22
+#define TARGET_ZA_MAGIC 0x54366345
23
+
24
+struct target_za_context {
25
+ struct target_aarch64_ctx head;
26
+ uint16_t vl;
27
+ uint16_t reserved[3];
28
+ /* The actual ZA data immediately follows. */
29
+};
30
+
31
+#define TARGET_ZA_SIG_REGS_OFFSET \
32
+ QEMU_ALIGN_UP(sizeof(struct target_za_context), TARGET_SVE_VQ_BYTES)
33
+#define TARGET_ZA_SIG_ZAV_OFFSET(VQ, N) \
34
+ (TARGET_ZA_SIG_REGS_OFFSET + (VQ) * TARGET_SVE_VQ_BYTES * (N))
35
+#define TARGET_ZA_SIG_CONTEXT_SIZE(VQ) \
36
+ TARGET_ZA_SIG_ZAV_OFFSET(VQ, VQ * TARGET_SVE_VQ_BYTES)
37
+
38
struct target_rt_sigframe {
39
struct target_siginfo info;
40
struct target_ucontext uc;
41
@@ -XXX,XX +XXX,XX @@ static void target_setup_end_record(struct target_aarch64_ctx *end)
21
}
42
}
22
43
23
+static int cmsdk_dualtimermod_divisor(CMSDKAPBDualTimerModule *m)
44
static void target_setup_sve_record(struct target_sve_context *sve,
45
- CPUARMState *env, int vq, int size)
46
+ CPUARMState *env, int size)
47
{
48
- int i, j;
49
+ int i, j, vq = sve_vq(env);
50
51
memset(sve, 0, sizeof(*sve));
52
__put_user(TARGET_SVE_MAGIC, &sve->head.magic);
53
@@ -XXX,XX +XXX,XX @@ static void target_setup_sve_record(struct target_sve_context *sve,
54
}
55
}
56
57
+static void target_setup_za_record(struct target_za_context *za,
58
+ CPUARMState *env, int size)
24
+{
59
+{
25
+ /* Return the divisor set by the current CONTROL.PRESCALE value */
60
+ int vq = sme_vq(env);
26
+ switch (FIELD_EX32(m->control, CONTROL, PRESCALE)) {
61
+ int vl = vq * TARGET_SVE_VQ_BYTES;
27
+ case 0:
62
+ int i, j;
28
+ return 1;
63
+
29
+ case 1:
64
+ memset(za, 0, sizeof(*za));
30
+ return 16;
65
+ __put_user(TARGET_ZA_MAGIC, &za->head.magic);
31
+ case 2:
66
+ __put_user(size, &za->head.size);
32
+ case 3: /* UNDEFINED, we treat like 2 (and complained when it was set) */
67
+ __put_user(vl, &za->vl);
33
+ return 256;
68
+
34
+ default:
69
+ if (size == TARGET_ZA_SIG_CONTEXT_SIZE(0)) {
35
+ g_assert_not_reached();
70
+ return;
71
+ }
72
+ assert(size == TARGET_ZA_SIG_CONTEXT_SIZE(vq));
73
+
74
+ /*
75
+ * Note that ZA vectors are stored as a byte stream,
76
+ * with each byte element at a subsequent address.
77
+ */
78
+ for (i = 0; i < vl; ++i) {
79
+ uint64_t *z = (void *)za + TARGET_ZA_SIG_ZAV_OFFSET(vq, i);
80
+ for (j = 0; j < vq * 2; ++j) {
81
+ __put_user_e(env->zarray[i].d[j], z + j, le);
82
+ }
36
+ }
83
+ }
37
+}
84
+}
38
+
85
+
39
static void cmsdk_dualtimermod_write_control(CMSDKAPBDualTimerModule *m,
86
static void target_restore_general_frame(CPUARMState *env,
40
uint32_t newctrl)
87
struct target_rt_sigframe *sf)
41
{
88
{
42
@@ -XXX,XX +XXX,XX @@ static void cmsdk_dualtimermod_write_control(CMSDKAPBDualTimerModule *m,
89
@@ -XXX,XX +XXX,XX @@ static void target_restore_fpsimd_record(CPUARMState *env,
43
default:
90
44
g_assert_not_reached();
91
static bool target_restore_sve_record(CPUARMState *env,
45
}
92
struct target_sve_context *sve,
46
- ptimer_set_freq(m->timer, m->parent->pclk_frq / divisor);
93
- int size)
47
+ ptimer_set_period_from_clock(m->timer, m->parent->timclk, divisor);
94
+ int size, int *svcr)
48
}
95
{
49
96
- int i, j, vl, vq;
50
if (changed & R_CONTROL_MODE_MASK) {
97
+ int i, j, vl, vq, flags;
51
@@ -XXX,XX +XXX,XX @@ static void cmsdk_dualtimermod_reset(CMSDKAPBDualTimerModule *m)
98
+ bool sm;
52
* limit must both be set to 0xffff, so we wrap at 16 bits.
99
53
*/
100
- if (!cpu_isar_feature(aa64_sve, env_archcpu(env))) {
54
ptimer_set_limit(m->timer, 0xffff, 1);
101
+ __get_user(vl, &sve->vl);
55
- ptimer_set_freq(m->timer, m->parent->pclk_frq);
102
+ __get_user(flags, &sve->flags);
56
+ ptimer_set_period_from_clock(m->timer, m->parent->timclk,
103
+
57
+ cmsdk_dualtimermod_divisor(m));
104
+ sm = flags & TARGET_SVE_SIG_FLAG_SM;
58
ptimer_transaction_commit(m->timer);
105
+
106
+ /* The cpu must support Streaming or Non-streaming SVE. */
107
+ if (sm
108
+ ? !cpu_isar_feature(aa64_sme, env_archcpu(env))
109
+ : !cpu_isar_feature(aa64_sve, env_archcpu(env))) {
110
return false;
111
}
112
113
- __get_user(vl, &sve->vl);
114
- vq = sve_vq(env);
115
+ /*
116
+ * Note that we cannot use sve_vq() because that depends on the
117
+ * current setting of PSTATE.SM, not the state to be restored.
118
+ */
119
+ vq = sve_vqm1_for_el_sm(env, 0, sm) + 1;
120
121
/* Reject mismatched VL. */
122
if (vl != vq * TARGET_SVE_VQ_BYTES) {
123
@@ -XXX,XX +XXX,XX @@ static bool target_restore_sve_record(CPUARMState *env,
124
return false;
125
}
126
127
+ *svcr = FIELD_DP64(*svcr, SVCR, SM, sm);
128
+
129
/*
130
* Note that SVE regs are stored as a byte stream, with each byte element
131
* at a subsequent address. This corresponds to a little-endian load
132
@@ -XXX,XX +XXX,XX @@ static bool target_restore_sve_record(CPUARMState *env,
133
return true;
59
}
134
}
60
135
61
@@ -XXX,XX +XXX,XX @@ static void cmsdk_apb_dualtimer_reset(DeviceState *dev)
136
+static bool target_restore_za_record(CPUARMState *env,
62
s->timeritop = 0;
137
+ struct target_za_context *za,
63
}
138
+ int size, int *svcr)
64
65
+static void cmsdk_apb_dualtimer_clk_update(void *opaque)
66
+{
139
+{
67
+ CMSDKAPBDualTimer *s = CMSDK_APB_DUALTIMER(opaque);
140
+ int i, j, vl, vq;
68
+ int i;
141
+
69
+
142
+ if (!cpu_isar_feature(aa64_sme, env_archcpu(env))) {
70
+ for (i = 0; i < ARRAY_SIZE(s->timermod); i++) {
143
+ return false;
71
+ CMSDKAPBDualTimerModule *m = &s->timermod[i];
144
+ }
72
+ ptimer_transaction_begin(m->timer);
145
+
73
+ ptimer_set_period_from_clock(m->timer, m->parent->timclk,
146
+ __get_user(vl, &za->vl);
74
+ cmsdk_dualtimermod_divisor(m));
147
+ vq = sme_vq(env);
75
+ ptimer_transaction_commit(m->timer);
148
+
76
+ }
149
+ /* Reject mismatched VL. */
150
+ if (vl != vq * TARGET_SVE_VQ_BYTES) {
151
+ return false;
152
+ }
153
+
154
+ /* Accept empty record -- used to clear PSTATE.ZA. */
155
+ if (size <= TARGET_ZA_SIG_CONTEXT_SIZE(0)) {
156
+ return true;
157
+ }
158
+
159
+ /* Reject non-empty but incomplete record. */
160
+ if (size < TARGET_ZA_SIG_CONTEXT_SIZE(vq)) {
161
+ return false;
162
+ }
163
+
164
+ *svcr = FIELD_DP64(*svcr, SVCR, ZA, 1);
165
+
166
+ for (i = 0; i < vl; ++i) {
167
+ uint64_t *z = (void *)za + TARGET_ZA_SIG_ZAV_OFFSET(vq, i);
168
+ for (j = 0; j < vq * 2; ++j) {
169
+ __get_user_e(env->zarray[i].d[j], z + j, le);
170
+ }
171
+ }
172
+ return true;
77
+}
173
+}
78
+
174
+
79
static void cmsdk_apb_dualtimer_init(Object *obj)
175
static int target_restore_sigframe(CPUARMState *env,
80
{
176
struct target_rt_sigframe *sf)
81
SysBusDevice *sbd = SYS_BUS_DEVICE(obj);
177
{
82
@@ -XXX,XX +XXX,XX @@ static void cmsdk_apb_dualtimer_init(Object *obj)
178
struct target_aarch64_ctx *ctx, *extra = NULL;
83
for (i = 0; i < ARRAY_SIZE(s->timermod); i++) {
179
struct target_fpsimd_context *fpsimd = NULL;
84
sysbus_init_irq(sbd, &s->timermod[i].timerint);
180
struct target_sve_context *sve = NULL;
85
}
181
+ struct target_za_context *za = NULL;
86
- s->timclk = qdev_init_clock_in(DEVICE(s), "TIMCLK", NULL, NULL);
182
uint64_t extra_datap = 0;
87
+ s->timclk = qdev_init_clock_in(DEVICE(s), "TIMCLK",
183
bool used_extra = false;
88
+ cmsdk_apb_dualtimer_clk_update, s);
184
int sve_size = 0;
89
}
185
+ int za_size = 0;
90
186
+ int svcr = 0;
91
static void cmsdk_apb_dualtimer_realize(DeviceState *dev, Error **errp)
187
92
@@ -XXX,XX +XXX,XX @@ static void cmsdk_apb_dualtimer_realize(DeviceState *dev, Error **errp)
188
target_restore_general_frame(env, sf);
93
CMSDKAPBDualTimer *s = CMSDK_APB_DUALTIMER(dev);
189
94
int i;
190
@@ -XXX,XX +XXX,XX @@ static int target_restore_sigframe(CPUARMState *env,
95
191
sve_size = size;
96
- if (s->pclk_frq == 0) {
192
break;
97
- error_setg(errp, "CMSDK APB timer: pclk-frq property must be set");
193
98
+ if (!clock_has_source(s->timclk)) {
194
+ case TARGET_ZA_MAGIC:
99
+ error_setg(errp, "CMSDK APB dualtimer: TIMCLK clock must be connected");
195
+ if (za || size < sizeof(struct target_za_context)) {
100
return;
196
+ goto err;
101
}
197
+ }
102
198
+ za = (struct target_za_context *)ctx;
199
+ za_size = size;
200
+ break;
201
+
202
case TARGET_EXTRA_MAGIC:
203
if (extra || size != sizeof(struct target_extra_context)) {
204
goto err;
205
@@ -XXX,XX +XXX,XX @@ static int target_restore_sigframe(CPUARMState *env,
206
}
207
208
/* SVE data, if present, overwrites FPSIMD data. */
209
- if (sve && !target_restore_sve_record(env, sve, sve_size)) {
210
+ if (sve && !target_restore_sve_record(env, sve, sve_size, &svcr)) {
211
goto err;
212
}
213
+ if (za && !target_restore_za_record(env, za, za_size, &svcr)) {
214
+ goto err;
215
+ }
216
+ if (env->svcr != svcr) {
217
+ env->svcr = svcr;
218
+ arm_rebuild_hflags(env);
219
+ }
220
unlock_user(extra, extra_datap, 0);
221
return 0;
222
223
@@ -XXX,XX +XXX,XX @@ static void target_setup_frame(int usig, struct target_sigaction *ka,
224
.total_size = offsetof(struct target_rt_sigframe,
225
uc.tuc_mcontext.__reserved),
226
};
227
- int fpsimd_ofs, fr_ofs, sve_ofs = 0, vq = 0, sve_size = 0;
228
+ int fpsimd_ofs, fr_ofs, sve_ofs = 0, za_ofs = 0;
229
+ int sve_size = 0, za_size = 0;
230
struct target_rt_sigframe *frame;
231
struct target_rt_frame_record *fr;
232
abi_ulong frame_addr, return_addr;
233
@@ -XXX,XX +XXX,XX @@ static void target_setup_frame(int usig, struct target_sigaction *ka,
234
&layout);
235
236
/* SVE state needs saving only if it exists. */
237
- if (cpu_isar_feature(aa64_sve, env_archcpu(env))) {
238
- vq = sve_vq(env);
239
- sve_size = QEMU_ALIGN_UP(TARGET_SVE_SIG_CONTEXT_SIZE(vq), 16);
240
+ if (cpu_isar_feature(aa64_sve, env_archcpu(env)) ||
241
+ cpu_isar_feature(aa64_sme, env_archcpu(env))) {
242
+ sve_size = QEMU_ALIGN_UP(TARGET_SVE_SIG_CONTEXT_SIZE(sve_vq(env)), 16);
243
sve_ofs = alloc_sigframe_space(sve_size, &layout);
244
}
245
+ if (cpu_isar_feature(aa64_sme, env_archcpu(env))) {
246
+ /* ZA state needs saving only if it is enabled. */
247
+ if (FIELD_EX64(env->svcr, SVCR, ZA)) {
248
+ za_size = TARGET_ZA_SIG_CONTEXT_SIZE(sme_vq(env));
249
+ } else {
250
+ za_size = TARGET_ZA_SIG_CONTEXT_SIZE(0);
251
+ }
252
+ za_ofs = alloc_sigframe_space(za_size, &layout);
253
+ }
254
255
if (layout.extra_ofs) {
256
/* Reserve space for the extra end marker. The standard end marker
257
@@ -XXX,XX +XXX,XX @@ static void target_setup_frame(int usig, struct target_sigaction *ka,
258
target_setup_end_record((void *)frame + layout.extra_end_ofs);
259
}
260
if (sve_ofs) {
261
- target_setup_sve_record((void *)frame + sve_ofs, env, vq, sve_size);
262
+ target_setup_sve_record((void *)frame + sve_ofs, env, sve_size);
263
+ }
264
+ if (za_ofs) {
265
+ target_setup_za_record((void *)frame + za_ofs, env, za_size);
266
}
267
268
/* Set up the stack frame for unwinding. */
269
@@ -XXX,XX +XXX,XX @@ static void target_setup_frame(int usig, struct target_sigaction *ka,
270
env->btype = 2;
271
}
272
273
+ /*
274
+ * Invoke the signal handler with both SM and ZA disabled.
275
+ * When clearing SM, ResetSVEState, per SMSTOP.
276
+ */
277
+ if (FIELD_EX64(env->svcr, SVCR, SM)) {
278
+ arm_reset_sve_state(env);
279
+ }
280
+ if (env->svcr) {
281
+ env->svcr = 0;
282
+ arm_rebuild_hflags(env);
283
+ }
284
+
285
if (info) {
286
tswap_siginfo(&frame->info, info);
287
env->xregs[1] = frame_addr + offsetof(struct target_rt_sigframe, info);
103
--
288
--
104
2.20.1
289
2.25.1
105
106
diff view generated by jsdifflib
1
From: Philippe Mathieu-Daudé <f4bug@amsat.org>
1
From: Richard Henderson <richard.henderson@linaro.org>
2
2
3
cpu_get_phys_page_debug() uses 'DATA LOAD' MMU access type.
3
Add "sve" to the sve prctl functions, to distinguish
4
them from the coming "sme" prctls with similar names.
4
5
5
Signed-off-by: Philippe Mathieu-Daudé <f4bug@amsat.org>
6
Message-id: 20210127232822.3530782-1-f4bug@amsat.org
7
Reviewed-by: Peter Maydell <peter.maydell@linaro.org>
6
Reviewed-by: Peter Maydell <peter.maydell@linaro.org>
7
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
8
Message-id: 20220708151540.18136-42-richard.henderson@linaro.org
8
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
9
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
9
---
10
---
10
target/arm/helper.c | 2 +-
11
linux-user/aarch64/target_prctl.h | 8 ++++----
11
1 file changed, 1 insertion(+), 1 deletion(-)
12
linux-user/syscall.c | 12 ++++++------
13
2 files changed, 10 insertions(+), 10 deletions(-)
12
14
13
diff --git a/target/arm/helper.c b/target/arm/helper.c
15
diff --git a/linux-user/aarch64/target_prctl.h b/linux-user/aarch64/target_prctl.h
14
index XXXXXXX..XXXXXXX 100644
16
index XXXXXXX..XXXXXXX 100644
15
--- a/target/arm/helper.c
17
--- a/linux-user/aarch64/target_prctl.h
16
+++ b/target/arm/helper.c
18
+++ b/linux-user/aarch64/target_prctl.h
17
@@ -XXX,XX +XXX,XX @@ hwaddr arm_cpu_get_phys_page_attrs_debug(CPUState *cs, vaddr addr,
19
@@ -XXX,XX +XXX,XX @@
18
20
#ifndef AARCH64_TARGET_PRCTL_H
19
*attrs = (MemTxAttrs) {};
21
#define AARCH64_TARGET_PRCTL_H
20
22
21
- ret = get_phys_addr(env, addr, 0, mmu_idx, &phys_addr,
23
-static abi_long do_prctl_get_vl(CPUArchState *env)
22
+ ret = get_phys_addr(env, addr, MMU_DATA_LOAD, mmu_idx, &phys_addr,
24
+static abi_long do_prctl_sve_get_vl(CPUArchState *env)
23
attrs, &prot, &page_size, &fi, &cacheattrs);
25
{
24
26
ARMCPU *cpu = env_archcpu(env);
25
if (ret) {
27
if (cpu_isar_feature(aa64_sve, cpu)) {
28
@@ -XXX,XX +XXX,XX @@ static abi_long do_prctl_get_vl(CPUArchState *env)
29
}
30
return -TARGET_EINVAL;
31
}
32
-#define do_prctl_get_vl do_prctl_get_vl
33
+#define do_prctl_sve_get_vl do_prctl_sve_get_vl
34
35
-static abi_long do_prctl_set_vl(CPUArchState *env, abi_long arg2)
36
+static abi_long do_prctl_sve_set_vl(CPUArchState *env, abi_long arg2)
37
{
38
/*
39
* We cannot support either PR_SVE_SET_VL_ONEXEC or PR_SVE_VL_INHERIT.
40
@@ -XXX,XX +XXX,XX @@ static abi_long do_prctl_set_vl(CPUArchState *env, abi_long arg2)
41
}
42
return -TARGET_EINVAL;
43
}
44
-#define do_prctl_set_vl do_prctl_set_vl
45
+#define do_prctl_sve_set_vl do_prctl_sve_set_vl
46
47
static abi_long do_prctl_reset_keys(CPUArchState *env, abi_long arg2)
48
{
49
diff --git a/linux-user/syscall.c b/linux-user/syscall.c
50
index XXXXXXX..XXXXXXX 100644
51
--- a/linux-user/syscall.c
52
+++ b/linux-user/syscall.c
53
@@ -XXX,XX +XXX,XX @@ static abi_long do_prctl_inval1(CPUArchState *env, abi_long arg2)
54
#ifndef do_prctl_set_fp_mode
55
#define do_prctl_set_fp_mode do_prctl_inval1
56
#endif
57
-#ifndef do_prctl_get_vl
58
-#define do_prctl_get_vl do_prctl_inval0
59
+#ifndef do_prctl_sve_get_vl
60
+#define do_prctl_sve_get_vl do_prctl_inval0
61
#endif
62
-#ifndef do_prctl_set_vl
63
-#define do_prctl_set_vl do_prctl_inval1
64
+#ifndef do_prctl_sve_set_vl
65
+#define do_prctl_sve_set_vl do_prctl_inval1
66
#endif
67
#ifndef do_prctl_reset_keys
68
#define do_prctl_reset_keys do_prctl_inval1
69
@@ -XXX,XX +XXX,XX @@ static abi_long do_prctl(CPUArchState *env, abi_long option, abi_long arg2,
70
case PR_SET_FP_MODE:
71
return do_prctl_set_fp_mode(env, arg2);
72
case PR_SVE_GET_VL:
73
- return do_prctl_get_vl(env);
74
+ return do_prctl_sve_get_vl(env);
75
case PR_SVE_SET_VL:
76
- return do_prctl_set_vl(env, arg2);
77
+ return do_prctl_sve_set_vl(env, arg2);
78
case PR_PAC_RESET_KEYS:
79
if (arg3 || arg4 || arg5) {
80
return -TARGET_EINVAL;
26
--
81
--
27
2.20.1
82
2.25.1
28
29
diff view generated by jsdifflib
1
From: Hao Wu <wuhaotsh@google.com>
1
From: Richard Henderson <richard.henderson@linaro.org>
2
2
3
Fix potential overflow problem when calculating pwm_duty.
3
These prctl set the Streaming SVE vector length, which may
4
1. Ensure p->cmr and p->cnr to be from [0,65535], according to the
4
be completely different from the Normal SVE vector length.
5
hardware specification.
6
2. Changed duty to uint32_t. However, since MAX_DUTY * (p->cmr+1)
7
can excceed UINT32_MAX, we convert them to uint64_t in computation
8
and converted them back to uint32_t.
9
(duty is guaranteed to be <= MAX_DUTY so it won't overflow.)
10
5
11
Fixes: CID 1442342
12
Suggested-by: Peter Maydell <peter.maydell@linaro.org>
13
Reviewed-by: Doug Evans <dje@google.com>
14
Signed-off-by: Hao Wu <wuhaotsh@google.com>
15
Message-id: 20210127011142.2122790-1-wuhaotsh@google.com
16
Reviewed-by: Peter Maydell <peter.maydell@linaro.org>
6
Reviewed-by: Peter Maydell <peter.maydell@linaro.org>
7
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
8
Message-id: 20220708151540.18136-43-richard.henderson@linaro.org
17
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
9
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
18
---
10
---
19
hw/misc/npcm7xx_pwm.c | 23 +++++++++++++++++++----
11
linux-user/aarch64/target_prctl.h | 54 +++++++++++++++++++++++++++++++
20
tests/qtest/npcm7xx_pwm-test.c | 4 ++--
12
linux-user/syscall.c | 16 +++++++++
21
2 files changed, 21 insertions(+), 6 deletions(-)
13
2 files changed, 70 insertions(+)
22
14
23
diff --git a/hw/misc/npcm7xx_pwm.c b/hw/misc/npcm7xx_pwm.c
15
diff --git a/linux-user/aarch64/target_prctl.h b/linux-user/aarch64/target_prctl.h
24
index XXXXXXX..XXXXXXX 100644
16
index XXXXXXX..XXXXXXX 100644
25
--- a/hw/misc/npcm7xx_pwm.c
17
--- a/linux-user/aarch64/target_prctl.h
26
+++ b/hw/misc/npcm7xx_pwm.c
18
+++ b/linux-user/aarch64/target_prctl.h
27
@@ -XXX,XX +XXX,XX @@ REG32(NPCM7XX_PWM_PWDR3, 0x50);
19
@@ -XXX,XX +XXX,XX @@ static abi_long do_prctl_sve_get_vl(CPUArchState *env)
28
#define NPCM7XX_CH_INV BIT(2)
20
{
29
#define NPCM7XX_CH_MOD BIT(3)
21
ARMCPU *cpu = env_archcpu(env);
30
22
if (cpu_isar_feature(aa64_sve, cpu)) {
31
+#define NPCM7XX_MAX_CMR 65535
23
+ /* PSTATE.SM is always unset on syscall entry. */
32
+#define NPCM7XX_MAX_CNR 65535
24
return sve_vq(env) * 16;
25
}
26
return -TARGET_EINVAL;
27
@@ -XXX,XX +XXX,XX @@ static abi_long do_prctl_sve_set_vl(CPUArchState *env, abi_long arg2)
28
&& arg2 >= 0 && arg2 <= 512 * 16 && !(arg2 & 15)) {
29
uint32_t vq, old_vq;
30
31
+ /* PSTATE.SM is always unset on syscall entry. */
32
old_vq = sve_vq(env);
33
34
/*
35
@@ -XXX,XX +XXX,XX @@ static abi_long do_prctl_sve_set_vl(CPUArchState *env, abi_long arg2)
36
}
37
#define do_prctl_sve_set_vl do_prctl_sve_set_vl
38
39
+static abi_long do_prctl_sme_get_vl(CPUArchState *env)
40
+{
41
+ ARMCPU *cpu = env_archcpu(env);
42
+ if (cpu_isar_feature(aa64_sme, cpu)) {
43
+ return sme_vq(env) * 16;
44
+ }
45
+ return -TARGET_EINVAL;
46
+}
47
+#define do_prctl_sme_get_vl do_prctl_sme_get_vl
33
+
48
+
34
/* Offset of each PWM channel's prescaler in the PPR register. */
49
+static abi_long do_prctl_sme_set_vl(CPUArchState *env, abi_long arg2)
35
static const int npcm7xx_ppr_base[] = { 0, 0, 8, 8 };
50
+{
36
/* Offset of each PWM channel's clock selector in the CSR register. */
51
+ /*
37
@@ -XXX,XX +XXX,XX @@ static uint32_t npcm7xx_pwm_calculate_freq(NPCM7xxPWM *p)
52
+ * We cannot support either PR_SME_SET_VL_ONEXEC or PR_SME_VL_INHERIT.
38
53
+ * Note the kernel definition of sve_vl_valid allows for VQ=512,
39
static uint32_t npcm7xx_pwm_calculate_duty(NPCM7xxPWM *p)
54
+ * i.e. VL=8192, even though the architectural maximum is VQ=16.
55
+ */
56
+ if (cpu_isar_feature(aa64_sme, env_archcpu(env))
57
+ && arg2 >= 0 && arg2 <= 512 * 16 && !(arg2 & 15)) {
58
+ int vq, old_vq;
59
+
60
+ old_vq = sme_vq(env);
61
+
62
+ /*
63
+ * Bound the value of vq, so that we know that it fits into
64
+ * the 4-bit field in SMCR_EL1. Because PSTATE.SM is cleared
65
+ * on syscall entry, we are not modifying the current SVE
66
+ * vector length.
67
+ */
68
+ vq = MAX(arg2 / 16, 1);
69
+ vq = MIN(vq, 16);
70
+ env->vfp.smcr_el[1] =
71
+ FIELD_DP64(env->vfp.smcr_el[1], SMCR, LEN, vq - 1);
72
+
73
+ /* Delay rebuilding hflags until we know if ZA must change. */
74
+ vq = sve_vqm1_for_el_sm(env, 0, true) + 1;
75
+
76
+ if (vq != old_vq) {
77
+ /*
78
+ * PSTATE.ZA state is cleared on any change to SVL.
79
+ * We need not call arm_rebuild_hflags because PSTATE.SM was
80
+ * cleared on syscall entry, so this hasn't changed VL.
81
+ */
82
+ env->svcr = FIELD_DP64(env->svcr, SVCR, ZA, 0);
83
+ arm_rebuild_hflags(env);
84
+ }
85
+ return vq * 16;
86
+ }
87
+ return -TARGET_EINVAL;
88
+}
89
+#define do_prctl_sme_set_vl do_prctl_sme_set_vl
90
+
91
static abi_long do_prctl_reset_keys(CPUArchState *env, abi_long arg2)
40
{
92
{
41
- uint64_t duty;
93
ARMCPU *cpu = env_archcpu(env);
42
+ uint32_t duty;
94
diff --git a/linux-user/syscall.c b/linux-user/syscall.c
43
44
if (p->running) {
45
if (p->cnr == 0) {
46
@@ -XXX,XX +XXX,XX @@ static uint32_t npcm7xx_pwm_calculate_duty(NPCM7xxPWM *p)
47
} else if (p->cmr >= p->cnr) {
48
duty = NPCM7XX_PWM_MAX_DUTY;
49
} else {
50
- duty = NPCM7XX_PWM_MAX_DUTY * (p->cmr + 1) / (p->cnr + 1);
51
+ duty = (uint64_t)NPCM7XX_PWM_MAX_DUTY * (p->cmr + 1) / (p->cnr + 1);
52
}
53
} else {
54
duty = 0;
55
@@ -XXX,XX +XXX,XX @@ static void npcm7xx_pwm_write(void *opaque, hwaddr offset,
56
case A_NPCM7XX_PWM_CNR2:
57
case A_NPCM7XX_PWM_CNR3:
58
p = &s->pwm[npcm7xx_cnr_index(offset)];
59
- p->cnr = value;
60
+ if (value > NPCM7XX_MAX_CNR) {
61
+ qemu_log_mask(LOG_GUEST_ERROR,
62
+ "%s: invalid cnr value: %u", __func__, value);
63
+ p->cnr = NPCM7XX_MAX_CNR;
64
+ } else {
65
+ p->cnr = value;
66
+ }
67
npcm7xx_pwm_update_output(p);
68
break;
69
70
@@ -XXX,XX +XXX,XX @@ static void npcm7xx_pwm_write(void *opaque, hwaddr offset,
71
case A_NPCM7XX_PWM_CMR2:
72
case A_NPCM7XX_PWM_CMR3:
73
p = &s->pwm[npcm7xx_cmr_index(offset)];
74
- p->cmr = value;
75
+ if (value > NPCM7XX_MAX_CMR) {
76
+ qemu_log_mask(LOG_GUEST_ERROR,
77
+ "%s: invalid cmr value: %u", __func__, value);
78
+ p->cmr = NPCM7XX_MAX_CMR;
79
+ } else {
80
+ p->cmr = value;
81
+ }
82
npcm7xx_pwm_update_output(p);
83
break;
84
85
diff --git a/tests/qtest/npcm7xx_pwm-test.c b/tests/qtest/npcm7xx_pwm-test.c
86
index XXXXXXX..XXXXXXX 100644
95
index XXXXXXX..XXXXXXX 100644
87
--- a/tests/qtest/npcm7xx_pwm-test.c
96
--- a/linux-user/syscall.c
88
+++ b/tests/qtest/npcm7xx_pwm-test.c
97
+++ b/linux-user/syscall.c
89
@@ -XXX,XX +XXX,XX @@ static uint64_t pwm_compute_freq(QTestState *qts, uint32_t ppr, uint32_t csr,
98
@@ -XXX,XX +XXX,XX @@ abi_long do_arch_prctl(CPUX86State *env, int code, abi_ulong addr)
90
99
#ifndef PR_SET_SYSCALL_USER_DISPATCH
91
static uint64_t pwm_compute_duty(uint32_t cnr, uint32_t cmr, bool inverted)
100
# define PR_SET_SYSCALL_USER_DISPATCH 59
92
{
101
#endif
93
- uint64_t duty;
102
+#ifndef PR_SME_SET_VL
94
+ uint32_t duty;
103
+# define PR_SME_SET_VL 63
95
104
+# define PR_SME_GET_VL 64
96
if (cnr == 0) {
105
+# define PR_SME_VL_LEN_MASK 0xffff
97
/* PWM is stopped. */
106
+# define PR_SME_VL_INHERIT (1 << 17)
98
@@ -XXX,XX +XXX,XX @@ static uint64_t pwm_compute_duty(uint32_t cnr, uint32_t cmr, bool inverted)
107
+#endif
99
} else if (cmr >= cnr) {
108
100
duty = MAX_DUTY;
109
#include "target_prctl.h"
101
} else {
110
102
- duty = MAX_DUTY * (cmr + 1) / (cnr + 1);
111
@@ -XXX,XX +XXX,XX @@ static abi_long do_prctl_inval1(CPUArchState *env, abi_long arg2)
103
+ duty = (uint64_t)MAX_DUTY * (cmr + 1) / (cnr + 1);
112
#ifndef do_prctl_set_unalign
104
}
113
#define do_prctl_set_unalign do_prctl_inval1
105
114
#endif
106
if (inverted) {
115
+#ifndef do_prctl_sme_get_vl
116
+#define do_prctl_sme_get_vl do_prctl_inval0
117
+#endif
118
+#ifndef do_prctl_sme_set_vl
119
+#define do_prctl_sme_set_vl do_prctl_inval1
120
+#endif
121
122
static abi_long do_prctl(CPUArchState *env, abi_long option, abi_long arg2,
123
abi_long arg3, abi_long arg4, abi_long arg5)
124
@@ -XXX,XX +XXX,XX @@ static abi_long do_prctl(CPUArchState *env, abi_long option, abi_long arg2,
125
return do_prctl_sve_get_vl(env);
126
case PR_SVE_SET_VL:
127
return do_prctl_sve_set_vl(env, arg2);
128
+ case PR_SME_GET_VL:
129
+ return do_prctl_sme_get_vl(env);
130
+ case PR_SME_SET_VL:
131
+ return do_prctl_sme_set_vl(env, arg2);
132
case PR_PAC_RESET_KEYS:
133
if (arg3 || arg4 || arg5) {
134
return -TARGET_EINVAL;
107
--
135
--
108
2.20.1
136
2.25.1
109
110
diff view generated by jsdifflib
1
From: Joelle van Dyne <j@getutm.app>
1
From: Richard Henderson <richard.henderson@linaro.org>
2
2
3
Meson will find CoreFoundation, IOKit, and Cocoa as needed.
3
There's no reason to set CPACR_EL1.ZEN if SVE disabled.
4
4
5
Reviewed-by: Peter Maydell <peter.maydell@linaro.org>
5
Reviewed-by: Peter Maydell <peter.maydell@linaro.org>
6
Signed-off-by: Joelle van Dyne <j@getutm.app>
6
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
7
Message-id: 20210126012457.39046-7-j@getutm.app
7
Message-id: 20220708151540.18136-44-richard.henderson@linaro.org
8
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
8
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
9
---
9
---
10
configure | 1 -
10
target/arm/cpu.c | 7 +++----
11
1 file changed, 1 deletion(-)
11
1 file changed, 3 insertions(+), 4 deletions(-)
12
12
13
diff --git a/configure b/configure
13
diff --git a/target/arm/cpu.c b/target/arm/cpu.c
14
index XXXXXXX..XXXXXXX 100755
14
index XXXXXXX..XXXXXXX 100644
15
--- a/configure
15
--- a/target/arm/cpu.c
16
+++ b/configure
16
+++ b/target/arm/cpu.c
17
@@ -XXX,XX +XXX,XX @@ Darwin)
17
@@ -XXX,XX +XXX,XX @@ static void arm_cpu_reset(DeviceState *dev)
18
fi
18
/* and to the FP/Neon instructions */
19
audio_drv_list="coreaudio try-sdl"
19
env->cp15.cpacr_el1 = FIELD_DP64(env->cp15.cpacr_el1,
20
audio_possible_drivers="coreaudio sdl"
20
CPACR_EL1, FPEN, 3);
21
- QEMU_LDFLAGS="-framework CoreFoundation -framework IOKit $QEMU_LDFLAGS"
21
- /* and to the SVE instructions */
22
# Disable attempts to use ObjectiveC features in os/object.h since they
22
- env->cp15.cpacr_el1 = FIELD_DP64(env->cp15.cpacr_el1,
23
# won't work when we're compiling with gcc as a C compiler.
23
- CPACR_EL1, ZEN, 3);
24
QEMU_CFLAGS="-DOS_OBJECT_USE_OBJC=0 $QEMU_CFLAGS"
24
- /* with reasonable vector length */
25
+ /* and to the SVE instructions, with default vector length */
26
if (cpu_isar_feature(aa64_sve, cpu)) {
27
+ env->cp15.cpacr_el1 = FIELD_DP64(env->cp15.cpacr_el1,
28
+ CPACR_EL1, ZEN, 3);
29
env->vfp.zcr_el[1] = cpu->sve_default_vq - 1;
30
}
31
/*
25
--
32
--
26
2.20.1
33
2.25.1
27
28
diff view generated by jsdifflib
1
From: Paolo Bonzini <pbonzini@redhat.com>
1
From: Richard Henderson <richard.henderson@linaro.org>
2
2
3
The properties to attach a CANBUS object to the xlnx-zcu102 machine have
3
Enable SME, TPIDR2_EL0, and FA64 if supported by the cpu.
4
a period in them. We want to use periods in properties for compound QAPI types,
5
and besides the "xlnx-zcu102." prefix is both unnecessary and different
6
from any other machine property name. Remove it.
7
4
8
Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
5
Reviewed-by: Peter Maydell <peter.maydell@linaro.org>
9
Message-id: 20210118162537.779542-1-pbonzini@redhat.com
6
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
10
Reviewed-by: Vikram Garhwal <fnu.vikram@xilinx.com>
7
Message-id: 20220708151540.18136-45-richard.henderson@linaro.org
11
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
8
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
12
---
9
---
13
hw/arm/xlnx-zcu102.c | 4 ++--
10
target/arm/cpu.c | 11 +++++++++++
14
tests/qtest/xlnx-can-test.c | 30 +++++++++++++++---------------
11
1 file changed, 11 insertions(+)
15
2 files changed, 17 insertions(+), 17 deletions(-)
16
12
17
diff --git a/hw/arm/xlnx-zcu102.c b/hw/arm/xlnx-zcu102.c
13
diff --git a/target/arm/cpu.c b/target/arm/cpu.c
18
index XXXXXXX..XXXXXXX 100644
14
index XXXXXXX..XXXXXXX 100644
19
--- a/hw/arm/xlnx-zcu102.c
15
--- a/target/arm/cpu.c
20
+++ b/hw/arm/xlnx-zcu102.c
16
+++ b/target/arm/cpu.c
21
@@ -XXX,XX +XXX,XX @@ static void xlnx_zcu102_machine_instance_init(Object *obj)
17
@@ -XXX,XX +XXX,XX @@ static void arm_cpu_reset(DeviceState *dev)
22
s->secure = false;
18
CPACR_EL1, ZEN, 3);
23
/* Default to virt (EL2) being disabled */
19
env->vfp.zcr_el[1] = cpu->sve_default_vq - 1;
24
s->virt = false;
20
}
25
- object_property_add_link(obj, "xlnx-zcu102.canbus0", TYPE_CAN_BUS,
21
+ /* and for SME instructions, with default vector length, and TPIDR2 */
26
+ object_property_add_link(obj, "canbus0", TYPE_CAN_BUS,
22
+ if (cpu_isar_feature(aa64_sme, cpu)) {
27
(Object **)&s->canbus[0],
23
+ env->cp15.sctlr_el[1] |= SCTLR_EnTP2;
28
object_property_allow_set_link,
24
+ env->cp15.cpacr_el1 = FIELD_DP64(env->cp15.cpacr_el1,
29
0);
25
+ CPACR_EL1, SMEN, 3);
30
26
+ env->vfp.smcr_el[1] = cpu->sme_default_vq - 1;
31
- object_property_add_link(obj, "xlnx-zcu102.canbus1", TYPE_CAN_BUS,
27
+ if (cpu_isar_feature(aa64_sme_fa64, cpu)) {
32
+ object_property_add_link(obj, "canbus1", TYPE_CAN_BUS,
28
+ env->vfp.smcr_el[1] = FIELD_DP64(env->vfp.smcr_el[1],
33
(Object **)&s->canbus[1],
29
+ SMCR, FA64, 1);
34
object_property_allow_set_link,
30
+ }
35
0);
31
+ }
36
diff --git a/tests/qtest/xlnx-can-test.c b/tests/qtest/xlnx-can-test.c
32
/*
37
index XXXXXXX..XXXXXXX 100644
33
* Enable 48-bit address space (TODO: take reserved_va into account).
38
--- a/tests/qtest/xlnx-can-test.c
34
* Enable TBI0 but not TBI1.
39
+++ b/tests/qtest/xlnx-can-test.c
40
@@ -XXX,XX +XXX,XX @@ static void test_can_bus(void)
41
uint8_t can_timestamp = 1;
42
43
QTestState *qts = qtest_init("-machine xlnx-zcu102"
44
- " -object can-bus,id=canbus0"
45
- " -machine xlnx-zcu102.canbus0=canbus0"
46
- " -machine xlnx-zcu102.canbus1=canbus0"
47
+ " -object can-bus,id=canbus"
48
+ " -machine canbus0=canbus"
49
+ " -machine canbus1=canbus"
50
);
51
52
/* Configure the CAN0 and CAN1. */
53
@@ -XXX,XX +XXX,XX @@ static void test_can_loopback(void)
54
uint32_t status = 0;
55
56
QTestState *qts = qtest_init("-machine xlnx-zcu102"
57
- " -object can-bus,id=canbus0"
58
- " -machine xlnx-zcu102.canbus0=canbus0"
59
- " -machine xlnx-zcu102.canbus1=canbus0"
60
+ " -object can-bus,id=canbus"
61
+ " -machine canbus0=canbus"
62
+ " -machine canbus1=canbus"
63
);
64
65
/* Configure the CAN0 in loopback mode. */
66
@@ -XXX,XX +XXX,XX @@ static void test_can_filter(void)
67
uint8_t can_timestamp = 1;
68
69
QTestState *qts = qtest_init("-machine xlnx-zcu102"
70
- " -object can-bus,id=canbus0"
71
- " -machine xlnx-zcu102.canbus0=canbus0"
72
- " -machine xlnx-zcu102.canbus1=canbus0"
73
+ " -object can-bus,id=canbus"
74
+ " -machine canbus0=canbus"
75
+ " -machine canbus1=canbus"
76
);
77
78
/* Configure the CAN0 and CAN1. */
79
@@ -XXX,XX +XXX,XX @@ static void test_can_sleepmode(void)
80
uint8_t can_timestamp = 1;
81
82
QTestState *qts = qtest_init("-machine xlnx-zcu102"
83
- " -object can-bus,id=canbus0"
84
- " -machine xlnx-zcu102.canbus0=canbus0"
85
- " -machine xlnx-zcu102.canbus1=canbus0"
86
+ " -object can-bus,id=canbus"
87
+ " -machine canbus0=canbus"
88
+ " -machine canbus1=canbus"
89
);
90
91
/* Configure the CAN0. */
92
@@ -XXX,XX +XXX,XX @@ static void test_can_snoopmode(void)
93
uint8_t can_timestamp = 1;
94
95
QTestState *qts = qtest_init("-machine xlnx-zcu102"
96
- " -object can-bus,id=canbus0"
97
- " -machine xlnx-zcu102.canbus0=canbus0"
98
- " -machine xlnx-zcu102.canbus1=canbus0"
99
+ " -object can-bus,id=canbus"
100
+ " -machine canbus0=canbus"
101
+ " -machine canbus1=canbus"
102
);
103
104
/* Configure the CAN0. */
105
--
35
--
106
2.20.1
36
2.25.1
107
108
diff view generated by jsdifflib
Deleted patch
1
Move the preadv availability check to meson.build. This is what we
2
want to be doing for host-OS-feature-checks anyway, but it also fixes
3
a problem with building for macOS with the most recent XCode SDK on a
4
Catalina host.
5
1
6
On that configuration, 'preadv()' is provided as a weak symbol, so
7
that programs can be built with optional support for it and make a
8
runtime availability check to see whether the preadv() they have is a
9
working one or one which they must not call because it will
10
runtime-assert. QEMU's configure test passes (unless you're building
11
with --enable-werror) because the test program using preadv()
12
compiles, but then QEMU crashes at runtime when preadv() is called,
13
with errors like:
14
15
dyld: lazy symbol binding failed: Symbol not found: _preadv
16
Referenced from: /Users/pm215/src/qemu/./build/x86/tests/test-replication
17
Expected in: /usr/lib/libSystem.B.dylib
18
19
dyld: Symbol not found: _preadv
20
Referenced from: /Users/pm215/src/qemu/./build/x86/tests/test-replication
21
Expected in: /usr/lib/libSystem.B.dylib
22
23
Meson's own function availability check has a special case for macOS
24
which adds '-Wl,-no_weak_imports' to the compiler flags, which forces
25
the test to require the real function, not the macOS-version-too-old
26
stub.
27
28
So this commit fixes the bug where macOS builds on Catalina currently
29
require --disable-werror.
30
31
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
32
Acked-by: Paolo Bonzini <pbonzini@redhat.com>
33
Reviewed-by: Philippe Mathieu-Daudé <philmd@redhat.com>
34
Message-id: 20210126155846.17109-1-peter.maydell@linaro.org
35
---
36
configure | 16 ----------------
37
meson.build | 4 +++-
38
2 files changed, 3 insertions(+), 17 deletions(-)
39
40
diff --git a/configure b/configure
41
index XXXXXXX..XXXXXXX 100755
42
--- a/configure
43
+++ b/configure
44
@@ -XXX,XX +XXX,XX @@ if compile_prog "" "" ; then
45
iovec=yes
46
fi
47
48
-##########################################
49
-# preadv probe
50
-cat > $TMPC <<EOF
51
-#include <sys/types.h>
52
-#include <sys/uio.h>
53
-#include <unistd.h>
54
-int main(void) { return preadv(0, 0, 0, 0); }
55
-EOF
56
-preadv=no
57
-if compile_prog "" "" ; then
58
- preadv=yes
59
-fi
60
-
61
##########################################
62
# fdt probe
63
64
@@ -XXX,XX +XXX,XX @@ fi
65
if test "$iovec" = "yes" ; then
66
echo "CONFIG_IOVEC=y" >> $config_host_mak
67
fi
68
-if test "$preadv" = "yes" ; then
69
- echo "CONFIG_PREADV=y" >> $config_host_mak
70
-fi
71
if test "$membarrier" = "yes" ; then
72
echo "CONFIG_MEMBARRIER=y" >> $config_host_mak
73
fi
74
diff --git a/meson.build b/meson.build
75
index XXXXXXX..XXXXXXX 100644
76
--- a/meson.build
77
+++ b/meson.build
78
@@ -XXX,XX +XXX,XX @@ config_host_data.set('HAVE_PTY_H', cc.has_header('pty.h'))
79
config_host_data.set('HAVE_SYS_IOCCOM_H', cc.has_header('sys/ioccom.h'))
80
config_host_data.set('HAVE_SYS_KCOV_H', cc.has_header('sys/kcov.h'))
81
82
+config_host_data.set('CONFIG_PREADV', cc.has_function('preadv', prefix: '#include <sys/uio.h>'))
83
+
84
ignored = ['CONFIG_QEMU_INTERP_PREFIX'] # actually per-target
85
arrays = ['CONFIG_AUDIO_DRIVERS', 'CONFIG_BDRV_RW_WHITELIST', 'CONFIG_BDRV_RO_WHITELIST']
86
strings = ['HOST_DSOSUF', 'CONFIG_IASL']
87
@@ -XXX,XX +XXX,XX @@ summary_info += {'PIE': get_option('b_pie')}
88
summary_info += {'static build': config_host.has_key('CONFIG_STATIC')}
89
summary_info += {'malloc trim support': has_malloc_trim}
90
summary_info += {'membarrier': config_host.has_key('CONFIG_MEMBARRIER')}
91
-summary_info += {'preadv support': config_host.has_key('CONFIG_PREADV')}
92
+summary_info += {'preadv support': config_host_data.get('CONFIG_PREADV')}
93
summary_info += {'fdatasync': config_host.has_key('CONFIG_FDATASYNC')}
94
summary_info += {'madvise': config_host.has_key('CONFIG_MADVISE')}
95
summary_info += {'posix_madvise': config_host.has_key('CONFIG_POSIX_MADVISE')}
96
--
97
2.20.1
98
99
diff view generated by jsdifflib
1
Create and connect the two clocks needed by the ARMSSE.
1
From: Richard Henderson <richard.henderson@linaro.org>
2
2
3
Reviewed-by: Peter Maydell <peter.maydell@linaro.org>
4
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
5
Message-id: 20220708151540.18136-46-richard.henderson@linaro.org
3
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
6
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
4
Reviewed-by: Philippe Mathieu-Daudé <f4bug@amsat.org>
5
Reviewed-by: Luc Michel <luc@lmichel.fr>
6
Tested-by: Philippe Mathieu-Daudé <f4bug@amsat.org>
7
Message-id: 20210128114145.20536-15-peter.maydell@linaro.org
8
Message-id: 20210121190622.22000-15-peter.maydell@linaro.org
9
---
7
---
10
hw/arm/mps2-tz.c | 13 +++++++++++++
8
linux-user/elfload.c | 20 ++++++++++++++++++++
11
1 file changed, 13 insertions(+)
9
1 file changed, 20 insertions(+)
12
10
13
diff --git a/hw/arm/mps2-tz.c b/hw/arm/mps2-tz.c
11
diff --git a/linux-user/elfload.c b/linux-user/elfload.c
14
index XXXXXXX..XXXXXXX 100644
12
index XXXXXXX..XXXXXXX 100644
15
--- a/hw/arm/mps2-tz.c
13
--- a/linux-user/elfload.c
16
+++ b/hw/arm/mps2-tz.c
14
+++ b/linux-user/elfload.c
17
@@ -XXX,XX +XXX,XX @@
15
@@ -XXX,XX +XXX,XX @@ enum {
18
#include "hw/net/lan9118.h"
16
ARM_HWCAP2_A64_RNG = 1 << 16,
19
#include "net/net.h"
17
ARM_HWCAP2_A64_BTI = 1 << 17,
20
#include "hw/core/split-irq.h"
18
ARM_HWCAP2_A64_MTE = 1 << 18,
21
+#include "hw/qdev-clock.h"
19
+ ARM_HWCAP2_A64_ECV = 1 << 19,
22
#include "qom/object.h"
20
+ ARM_HWCAP2_A64_AFP = 1 << 20,
23
21
+ ARM_HWCAP2_A64_RPRES = 1 << 21,
24
#define MPS2TZ_NUMIRQ 92
22
+ ARM_HWCAP2_A64_MTE3 = 1 << 22,
25
@@ -XXX,XX +XXX,XX @@ struct MPS2TZMachineState {
23
+ ARM_HWCAP2_A64_SME = 1 << 23,
26
qemu_or_irq uart_irq_orgate;
24
+ ARM_HWCAP2_A64_SME_I16I64 = 1 << 24,
27
DeviceState *lan9118;
25
+ ARM_HWCAP2_A64_SME_F64F64 = 1 << 25,
28
SplitIRQ cpu_irq_splitter[MPS2TZ_NUMIRQ];
26
+ ARM_HWCAP2_A64_SME_I8I32 = 1 << 26,
29
+ Clock *sysclk;
27
+ ARM_HWCAP2_A64_SME_F16F32 = 1 << 27,
30
+ Clock *s32kclk;
28
+ ARM_HWCAP2_A64_SME_B16F32 = 1 << 28,
29
+ ARM_HWCAP2_A64_SME_F32F32 = 1 << 29,
30
+ ARM_HWCAP2_A64_SME_FA64 = 1 << 30,
31
};
31
};
32
32
33
#define TYPE_MPS2TZ_MACHINE "mps2tz"
33
#define ELF_HWCAP get_elf_hwcap()
34
@@ -XXX,XX +XXX,XX @@ OBJECT_DECLARE_TYPE(MPS2TZMachineState, MPS2TZMachineClass, MPS2TZ_MACHINE)
34
@@ -XXX,XX +XXX,XX @@ static uint32_t get_elf_hwcap2(void)
35
35
GET_FEATURE_ID(aa64_rndr, ARM_HWCAP2_A64_RNG);
36
/* Main SYSCLK frequency in Hz */
36
GET_FEATURE_ID(aa64_bti, ARM_HWCAP2_A64_BTI);
37
#define SYSCLK_FRQ 20000000
37
GET_FEATURE_ID(aa64_mte, ARM_HWCAP2_A64_MTE);
38
+/* Slow 32Khz S32KCLK frequency in Hz */
38
+ GET_FEATURE_ID(aa64_sme, (ARM_HWCAP2_A64_SME |
39
+#define S32KCLK_FRQ (32 * 1000)
39
+ ARM_HWCAP2_A64_SME_F32F32 |
40
40
+ ARM_HWCAP2_A64_SME_B16F32 |
41
/* Create an alias of an entire original MemoryRegion @orig
41
+ ARM_HWCAP2_A64_SME_F16F32 |
42
* located at @base in the memory map.
42
+ ARM_HWCAP2_A64_SME_I8I32));
43
@@ -XXX,XX +XXX,XX @@ static void mps2tz_common_init(MachineState *machine)
43
+ GET_FEATURE_ID(aa64_sme_f64f64, ARM_HWCAP2_A64_SME_F64F64);
44
exit(EXIT_FAILURE);
44
+ GET_FEATURE_ID(aa64_sme_i16i64, ARM_HWCAP2_A64_SME_I16I64);
45
}
45
+ GET_FEATURE_ID(aa64_sme_fa64, ARM_HWCAP2_A64_SME_FA64);
46
46
47
+ /* These clocks don't need migration because they are fixed-frequency */
47
return hwcaps;
48
+ mms->sysclk = clock_new(OBJECT(machine), "SYSCLK");
48
}
49
+ clock_set_hz(mms->sysclk, SYSCLK_FRQ);
50
+ mms->s32kclk = clock_new(OBJECT(machine), "S32KCLK");
51
+ clock_set_hz(mms->s32kclk, S32KCLK_FRQ);
52
+
53
object_initialize_child(OBJECT(machine), TYPE_IOTKIT, &mms->iotkit,
54
mmc->armsse_type);
55
iotkitdev = DEVICE(&mms->iotkit);
56
@@ -XXX,XX +XXX,XX @@ static void mps2tz_common_init(MachineState *machine)
57
OBJECT(system_memory), &error_abort);
58
qdev_prop_set_uint32(iotkitdev, "EXP_NUMIRQ", MPS2TZ_NUMIRQ);
59
qdev_prop_set_uint32(iotkitdev, "MAINCLK_FRQ", SYSCLK_FRQ);
60
+ qdev_connect_clock_in(iotkitdev, "MAINCLK", mms->sysclk);
61
+ qdev_connect_clock_in(iotkitdev, "S32KCLK", mms->s32kclk);
62
sysbus_realize(SYS_BUS_DEVICE(&mms->iotkit), &error_fatal);
63
64
/*
65
--
49
--
66
2.20.1
50
2.25.1
67
68
diff view generated by jsdifflib