1
Most of this is the Neon decodetree patches, followed by Edgar's versal cleanups.
1
The following changes since commit 7e7eb9f852a46b51a71ae9d82590b2e4d28827ee:
2
2
3
thanks
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
7
The following changes since commit 2ef486e76d64436be90f7359a3071fb2a56ce835:
8
9
Merge remote-tracking branch 'remotes/marcel/tags/rdma-pull-request' into staging (2020-05-03 14:12:56 +0100)
10
4
11
are available in the Git repository at:
5
are available in the Git repository at:
12
6
13
https://git.linaro.org/people/pmaydell/qemu-arm.git tags/pull-target-arm-20200504
7
https://git.linaro.org/people/pmaydell/qemu-arm.git tags/pull-target-arm-20210129
14
8
15
for you to fetch changes up to 9aefc6cf9b73f66062d2f914a0136756e7a28211:
9
for you to fetch changes up to 11749122e1a86866591306d43603d2795a3dea1a:
16
10
17
target/arm: Move gen_ function typedefs to translate.h (2020-05-04 12:59:26 +0100)
11
hw/arm/stellaris: Remove board-creation reset of STELLARIS_SYS (2021-01-29 10:47:29 +0000)
18
12
19
----------------------------------------------------------------
13
----------------------------------------------------------------
20
target-arm queue:
14
target-arm queue:
21
* Start of conversion of Neon insns to decodetree
15
* Implement ID_PFR2
22
* versal board: support SD and RTC
16
* Conditionalize DBGDIDR
23
* Implement ARMv8.2-TTS2UXN
17
* rename xlnx-zcu102.canbusN properties
24
* Make VQDMULL undefined when U=1
18
* provide powerdown/reset mechanism for secure firmware on 'virt' board
25
* Some minor code cleanups
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
26
27
----------------------------------------------------------------
27
----------------------------------------------------------------
28
Edgar E. Iglesias (11):
28
Alexander Graf (1):
29
hw/arm: versal: Remove inclusion of arm_gicv3_common.h
29
hvf: Add hypervisor entitlement to output binaries
30
hw/arm: versal: Move misplaced comment
31
hw/arm: versal-virt: Fix typo xlnx-ve -> xlnx-versal
32
hw/arm: versal: Embed the UARTs into the SoC type
33
hw/arm: versal: Embed the GEMs into the SoC type
34
hw/arm: versal: Embed the ADMAs into the SoC type
35
hw/arm: versal: Embed the APUs into the SoC type
36
hw/arm: versal: Add support for SD
37
hw/arm: versal: Add support for the RTC
38
hw/arm: versal-virt: Add support for SD
39
hw/arm: versal-virt: Add support for the RTC
40
30
41
Fredrik Strupe (1):
31
Hao Wu (1):
42
target/arm: Make VQDMULL undefined when U=1
32
hw/misc: Fix arith overflow in NPCM7XX PWM module
43
33
44
Peter Maydell (25):
34
Joelle van Dyne (7):
45
target/arm: Don't use a TLB for ARMMMUIdx_Stage2
35
configure: cross-compiling with empty cross_prefix
46
target/arm: Use enum constant in get_phys_addr_lpae() call
36
osdep: build with non-working system() function
47
target/arm: Add new 's1_is_el0' argument to get_phys_addr_lpae()
37
darwin: remove redundant dependency declaration
48
target/arm: Implement ARMv8.2-TTS2UXN
38
darwin: fix cross-compiling for Darwin
49
target/arm: Use correct variable for setting 'max' cpu's ID_AA64DFR0
39
configure: cross compile should use x86_64 cpu_family
50
target/arm/translate-vfp.inc.c: Remove duplicate simd_r32 check
40
darwin: detect CoreAudio for build
51
target/arm: Don't allow Thumb Neon insns without FEATURE_NEON
41
darwin: remove 64-bit build detection on 32-bit OS
52
target/arm: Add stubs for AArch32 Neon decodetree
53
target/arm: Convert VCMLA (vector) to decodetree
54
target/arm: Convert VCADD (vector) to decodetree
55
target/arm: Convert V[US]DOT (vector) to decodetree
56
target/arm: Convert VFM[AS]L (vector) to decodetree
57
target/arm: Convert VCMLA (scalar) to decodetree
58
target/arm: Convert V[US]DOT (scalar) to decodetree
59
target/arm: Convert VFM[AS]L (scalar) to decodetree
60
target/arm: Convert Neon load/store multiple structures to decodetree
61
target/arm: Convert Neon 'load single structure to all lanes' to decodetree
62
target/arm: Convert Neon 'load/store single structure' to decodetree
63
target/arm: Convert Neon 3-reg-same VADD/VSUB to decodetree
64
target/arm: Convert Neon 3-reg-same logic ops to decodetree
65
target/arm: Convert Neon 3-reg-same VMAX/VMIN to decodetree
66
target/arm: Convert Neon 3-reg-same comparisons to decodetree
67
target/arm: Convert Neon 3-reg-same VQADD/VQSUB to decodetree
68
target/arm: Convert Neon 3-reg-same VMUL, VMLA, VMLS, VSHL to decodetree
69
target/arm: Move gen_ function typedefs to translate.h
70
42
71
Philippe Mathieu-Daudé (2):
43
Maxim Uvarov (3):
72
hw/arm/mps2-tz: Use TYPE_IOTKIT instead of hardcoded string
44
hw: gpio: implement gpio-pwr driver for qemu reset/poweroff
73
target/arm: Use uint64_t for midr field in CPU state struct
45
arm-virt: refactor gpios creation
46
arm-virt: add secure pl061 for reset/power down
74
47
75
include/hw/arm/xlnx-versal.h | 31 +-
48
Mihai Carabas (4):
76
target/arm/cpu-param.h | 2 +-
49
hw/misc/pvpanic: split-out generic and bus dependent code
77
target/arm/cpu.h | 38 ++-
50
hw/misc/pvpanic: add PCI interface support
78
target/arm/translate-a64.h | 9 -
51
pvpanic : update pvpanic spec document
79
target/arm/translate.h | 26 ++
52
tests/qtest: add a test case for pvpanic-pci
80
target/arm/neon-dp.decode | 86 +++++
81
target/arm/neon-ls.decode | 52 +++
82
target/arm/neon-shared.decode | 66 ++++
83
hw/arm/mps2-tz.c | 2 +-
84
hw/arm/xlnx-versal-virt.c | 74 ++++-
85
hw/arm/xlnx-versal.c | 115 +++++--
86
target/arm/cpu.c | 3 +-
87
target/arm/cpu64.c | 8 +-
88
target/arm/helper.c | 183 ++++------
89
target/arm/translate-a64.c | 17 -
90
target/arm/translate-neon.inc.c | 714 +++++++++++++++++++++++++++++++++++++++
91
target/arm/translate-vfp.inc.c | 6 -
92
target/arm/translate.c | 716 +++-------------------------------------
93
target/arm/Makefile.objs | 18 +
94
19 files changed, 1302 insertions(+), 864 deletions(-)
95
create mode 100644 target/arm/neon-dp.decode
96
create mode 100644 target/arm/neon-ls.decode
97
create mode 100644 target/arm/neon-shared.decode
98
create mode 100644 target/arm/translate-neon.inc.c
99
53
54
Paolo Bonzini (1):
55
arm: rename xlnx-zcu102.canbusN properties
56
57
Peter Maydell (26):
58
configure: Move preadv check to meson.build
59
ptimer: Add new ptimer_set_period_from_clock() function
60
clock: Add new clock_has_source() function
61
tests: Add a simple test of the CMSDK APB timer
62
tests: Add a simple test of the CMSDK APB watchdog
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
From: Philippe Mathieu-Daudé <f4bug@amsat.org>
1
From: Richard Henderson <richard.henderson@linaro.org>
2
2
3
MIDR_EL1 is a 64-bit system register with the top 32-bit being RES0.
3
This was defined at some point before ARMv8.4, and will
4
Represent it in QEMU's ARMCPU struct with a uint64_t, not a
4
shortly be used by new processor descriptions.
5
uint32_t.
6
5
7
This fixes an error when compiling with -Werror=conversion
8
because we were manipulating the register value using a
9
local uint64_t variable:
10
11
target/arm/cpu64.c: In function ‘aarch64_max_initfn’:
12
target/arm/cpu64.c:628:21: error: conversion from ‘uint64_t’ {aka ‘long unsigned int’} to ‘uint32_t’ {aka ‘unsigned int’} may change value [-Werror=conversion]
13
628 | cpu->midr = t;
14
| ^
15
16
and future-proofs us against a possible future architecture
17
change using some of the top 32 bits.
18
19
Suggested-by: Laurent Desnogues <laurent.desnogues@gmail.com>
20
Suggested-by: Peter Maydell <peter.maydell@linaro.org>
21
Signed-off-by: Philippe Mathieu-Daudé <f4bug@amsat.org>
22
Reviewed-by: Laurent Desnogues <laurent.desnogues@gmail.com>
23
Message-id: 20200428172634.29707-1-f4bug@amsat.org
24
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: 20210120204400.1056582-1-richard.henderson@linaro.org
25
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
9
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
26
---
10
---
27
target/arm/cpu.h | 2 +-
11
target/arm/cpu.h | 1 +
28
target/arm/cpu.c | 2 +-
12
target/arm/helper.c | 4 ++--
29
2 files changed, 2 insertions(+), 2 deletions(-)
13
target/arm/kvm64.c | 2 ++
14
3 files changed, 5 insertions(+), 2 deletions(-)
30
15
31
diff --git a/target/arm/cpu.h b/target/arm/cpu.h
16
diff --git a/target/arm/cpu.h b/target/arm/cpu.h
32
index XXXXXXX..XXXXXXX 100644
17
index XXXXXXX..XXXXXXX 100644
33
--- a/target/arm/cpu.h
18
--- a/target/arm/cpu.h
34
+++ b/target/arm/cpu.h
19
+++ b/target/arm/cpu.h
35
@@ -XXX,XX +XXX,XX @@ struct ARMCPU {
20
@@ -XXX,XX +XXX,XX @@ struct ARMCPU {
36
uint64_t id_aa64dfr0;
21
uint32_t id_mmfr4;
37
uint64_t id_aa64dfr1;
22
uint32_t id_pfr0;
38
} isar;
23
uint32_t id_pfr1;
39
- uint32_t midr;
24
+ uint32_t id_pfr2;
40
+ uint64_t midr;
25
uint32_t mvfr0;
41
uint32_t revidr;
26
uint32_t mvfr1;
42
uint32_t reset_fpsid;
27
uint32_t mvfr2;
43
uint32_t ctr;
28
diff --git a/target/arm/helper.c b/target/arm/helper.c
44
diff --git a/target/arm/cpu.c b/target/arm/cpu.c
45
index XXXXXXX..XXXXXXX 100644
29
index XXXXXXX..XXXXXXX 100644
46
--- a/target/arm/cpu.c
30
--- a/target/arm/helper.c
47
+++ b/target/arm/cpu.c
31
+++ b/target/arm/helper.c
48
@@ -XXX,XX +XXX,XX @@ static const ARMCPUInfo arm_cpus[] = {
32
@@ -XXX,XX +XXX,XX @@ void register_cp_regs_for_features(ARMCPU *cpu)
49
static Property arm_cpu_properties[] = {
33
.access = PL1_R, .type = ARM_CP_CONST,
50
DEFINE_PROP_BOOL("start-powered-off", ARMCPU, start_powered_off, false),
34
.accessfn = access_aa64_tid3,
51
DEFINE_PROP_UINT32("psci-conduit", ARMCPU, psci_conduit, 0),
35
.resetvalue = 0 },
52
- DEFINE_PROP_UINT32("midr", ARMCPU, midr, 0),
36
- { .name = "MVFR4_EL1_RESERVED", .state = ARM_CP_STATE_AA64,
53
+ DEFINE_PROP_UINT64("midr", ARMCPU, midr, 0),
37
+ { .name = "ID_PFR2", .state = ARM_CP_STATE_BOTH,
54
DEFINE_PROP_UINT64("mp-affinity", ARMCPU,
38
.opc0 = 3, .opc1 = 0, .crn = 0, .crm = 3, .opc2 = 4,
55
mp_affinity, ARM64_AFFINITY_INVALID),
39
.access = PL1_R, .type = ARM_CP_CONST,
56
DEFINE_PROP_INT32("node-id", ARMCPU, node_id, CPU_UNSET_NUMA_NODE_ID),
40
.accessfn = access_aa64_tid3,
41
- .resetvalue = 0 },
42
+ .resetvalue = cpu->isar.id_pfr2 },
43
{ .name = "MVFR5_EL1_RESERVED", .state = ARM_CP_STATE_AA64,
44
.opc0 = 3, .opc1 = 0, .crn = 0, .crm = 3, .opc2 = 5,
45
.access = PL1_R, .type = ARM_CP_CONST,
46
diff --git a/target/arm/kvm64.c b/target/arm/kvm64.c
47
index XXXXXXX..XXXXXXX 100644
48
--- a/target/arm/kvm64.c
49
+++ b/target/arm/kvm64.c
50
@@ -XXX,XX +XXX,XX @@ bool kvm_arm_get_host_cpu_features(ARMHostCPUFeatures *ahcf)
51
ARM64_SYS_REG(3, 0, 0, 1, 0));
52
err |= read_sys_reg32(fdarray[2], &ahcf->isar.id_pfr1,
53
ARM64_SYS_REG(3, 0, 0, 1, 1));
54
+ err |= read_sys_reg32(fdarray[2], &ahcf->isar.id_pfr2,
55
+ ARM64_SYS_REG(3, 0, 0, 3, 4));
56
err |= read_sys_reg32(fdarray[2], &ahcf->isar.id_dfr0,
57
ARM64_SYS_REG(3, 0, 0, 1, 2));
58
err |= read_sys_reg32(fdarray[2], &ahcf->isar.id_mmfr0,
57
--
59
--
58
2.20.1
60
2.20.1
59
61
60
62
diff view generated by jsdifflib
1
The access_type argument to get_phys_addr_lpae() is an MMUAccessType;
1
From: Richard Henderson <richard.henderson@linaro.org>
2
use the enum constant MMU_DATA_LOAD rather than a literal 0 when we
3
call it in S1_ptw_translate().
4
2
3
Only define the register if it exists for the cpu.
4
5
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
6
Message-id: 20210120031656.737646-1-richard.henderson@linaro.org
7
Reviewed-by: Peter Maydell <peter.maydell@linaro.org>
5
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
8
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
6
Reviewed-by: Edgar E. Iglesias <edgar.iglesias@xilinx.com>
7
Reviewed-by: Richard Henderson <richard.henderson@linaro.org>
8
Message-id: 20200330210400.11724-3-peter.maydell@linaro.org
9
---
9
---
10
target/arm/helper.c | 5 +++--
10
target/arm/helper.c | 21 +++++++++++++++------
11
1 file changed, 3 insertions(+), 2 deletions(-)
11
1 file changed, 15 insertions(+), 6 deletions(-)
12
12
13
diff --git a/target/arm/helper.c b/target/arm/helper.c
13
diff --git a/target/arm/helper.c b/target/arm/helper.c
14
index XXXXXXX..XXXXXXX 100644
14
index XXXXXXX..XXXXXXX 100644
15
--- a/target/arm/helper.c
15
--- a/target/arm/helper.c
16
+++ b/target/arm/helper.c
16
+++ b/target/arm/helper.c
17
@@ -XXX,XX +XXX,XX @@ static hwaddr S1_ptw_translate(CPUARMState *env, ARMMMUIdx mmu_idx,
17
@@ -XXX,XX +XXX,XX @@ static void define_debug_regs(ARMCPU *cpu)
18
pcacheattrs = &cacheattrs;
18
*/
19
}
19
int i;
20
20
int wrps, brps, ctx_cmps;
21
- ret = get_phys_addr_lpae(env, addr, 0, ARMMMUIdx_Stage2, &s2pa,
21
- ARMCPRegInfo dbgdidr = {
22
- &txattrs, &s2prot, &s2size, fi, pcacheattrs);
22
- .name = "DBGDIDR", .cp = 14, .crn = 0, .crm = 0, .opc1 = 0, .opc2 = 0,
23
+ ret = get_phys_addr_lpae(env, addr, MMU_DATA_LOAD, ARMMMUIdx_Stage2,
23
- .access = PL0_R, .accessfn = access_tda,
24
+ &s2pa, &txattrs, &s2prot, &s2size, fi,
24
- .type = ARM_CP_CONST, .resetvalue = cpu->isar.dbgdidr,
25
+ pcacheattrs);
25
- };
26
if (ret) {
26
+
27
assert(fi->type != ARMFault_None);
27
+ /*
28
fi->s2addr = addr;
28
+ * The Arm ARM says DBGDIDR is optional and deprecated if EL1 cannot
29
+ * use AArch32. Given that bit 15 is RES1, if the value is 0 then
30
+ * the register must not exist for this cpu.
31
+ */
32
+ if (cpu->isar.dbgdidr != 0) {
33
+ ARMCPRegInfo dbgdidr = {
34
+ .name = "DBGDIDR", .cp = 14, .crn = 0, .crm = 0,
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
+ }
41
42
/* Note that all these register fields hold "number of Xs minus 1". */
43
brps = arm_num_brps(cpu);
44
@@ -XXX,XX +XXX,XX @@ static void define_debug_regs(ARMCPU *cpu)
45
46
assert(ctx_cmps <= brps);
47
48
- define_one_arm_cp_reg(cpu, &dbgdidr);
49
define_arm_cp_regs(cpu, debug_cp_reginfo);
50
51
if (arm_feature(&cpu->env, ARM_FEATURE_LPAE)) {
29
--
52
--
30
2.20.1
53
2.20.1
31
54
32
55
diff view generated by jsdifflib
New patch
1
From: Paolo Bonzini <pbonzini@redhat.com>
1
2
3
The properties to attach a CANBUS object to the xlnx-zcu102 machine have
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
8
Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
9
Message-id: 20210118162537.779542-1-pbonzini@redhat.com
10
Reviewed-by: Vikram Garhwal <fnu.vikram@xilinx.com>
11
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
12
---
13
hw/arm/xlnx-zcu102.c | 4 ++--
14
tests/qtest/xlnx-can-test.c | 30 +++++++++++++++---------------
15
2 files changed, 17 insertions(+), 17 deletions(-)
16
17
diff --git a/hw/arm/xlnx-zcu102.c b/hw/arm/xlnx-zcu102.c
18
index XXXXXXX..XXXXXXX 100644
19
--- a/hw/arm/xlnx-zcu102.c
20
+++ b/hw/arm/xlnx-zcu102.c
21
@@ -XXX,XX +XXX,XX @@ static void xlnx_zcu102_machine_instance_init(Object *obj)
22
s->secure = false;
23
/* Default to virt (EL2) being disabled */
24
s->virt = false;
25
- object_property_add_link(obj, "xlnx-zcu102.canbus0", TYPE_CAN_BUS,
26
+ object_property_add_link(obj, "canbus0", TYPE_CAN_BUS,
27
(Object **)&s->canbus[0],
28
object_property_allow_set_link,
29
0);
30
31
- object_property_add_link(obj, "xlnx-zcu102.canbus1", TYPE_CAN_BUS,
32
+ object_property_add_link(obj, "canbus1", TYPE_CAN_BUS,
33
(Object **)&s->canbus[1],
34
object_property_allow_set_link,
35
0);
36
diff --git a/tests/qtest/xlnx-can-test.c b/tests/qtest/xlnx-can-test.c
37
index XXXXXXX..XXXXXXX 100644
38
--- a/tests/qtest/xlnx-can-test.c
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
--
106
2.20.1
107
108
diff view generated by jsdifflib
1
Add the infrastructure for building and invoking a decodetree decoder
1
From: Maxim Uvarov <maxim.uvarov@linaro.org>
2
for the AArch32 Neon encodings. At the moment the new decoder covers
3
nothing, so we always fall back to the existing hand-written decode.
4
2
5
We follow the same pattern we did for the VFP decodetree conversion
3
Implement gpio-pwr driver to allow reboot and poweroff machine.
6
(commit 78e138bc1f672c145ef6ace74617d and following): code that deals
4
This is simple driver with just 2 gpios lines. Current use case
7
with Neon will be moving gradually out to translate-neon.vfp.inc,
5
is to reboot and poweroff virt machine in secure mode. Secure
8
which we #include into translate.c.
6
pl066 gpio chip is needed for that.
9
7
10
In order to share the decode files between A32 and T32, we
8
Signed-off-by: Maxim Uvarov <maxim.uvarov@linaro.org>
11
split Neon into 3 parts:
9
Reviewed-by: Hao Wu <wuhaotsh@google.com>
12
* data-processing
10
Reviewed-by: Peter Maydell <peter.maydell@linaro.org>
13
* load-store
11
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
14
* 'shared' encodings
12
---
13
hw/gpio/gpio_pwr.c | 70 +++++++++++++++++++++++++++++++++++++++++++++
14
hw/gpio/Kconfig | 3 ++
15
hw/gpio/meson.build | 1 +
16
3 files changed, 74 insertions(+)
17
create mode 100644 hw/gpio/gpio_pwr.c
15
18
16
The first two groups of instructions have similar but not identical
19
diff --git a/hw/gpio/gpio_pwr.c b/hw/gpio/gpio_pwr.c
17
A32 and T32 encodings, so we need to manually transform the T32
18
encoding into the A32 one before calling the decoder; the third group
19
covers the Neon instructions which are identical in A32 and T32.
20
21
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
22
Reviewed-by: Richard Henderson <richard.henderson@linaro.org>
23
Message-id: 20200430181003.21682-4-peter.maydell@linaro.org
24
---
25
target/arm/neon-dp.decode | 29 ++++++++++++++++++++++++++
26
target/arm/neon-ls.decode | 29 ++++++++++++++++++++++++++
27
target/arm/neon-shared.decode | 27 +++++++++++++++++++++++++
28
target/arm/translate-neon.inc.c | 32 +++++++++++++++++++++++++++++
29
target/arm/translate.c | 36 +++++++++++++++++++++++++++++++--
30
target/arm/Makefile.objs | 18 +++++++++++++++++
31
6 files changed, 169 insertions(+), 2 deletions(-)
32
create mode 100644 target/arm/neon-dp.decode
33
create mode 100644 target/arm/neon-ls.decode
34
create mode 100644 target/arm/neon-shared.decode
35
create mode 100644 target/arm/translate-neon.inc.c
36
37
diff --git a/target/arm/neon-dp.decode b/target/arm/neon-dp.decode
38
new file mode 100644
20
new file mode 100644
39
index XXXXXXX..XXXXXXX
21
index XXXXXXX..XXXXXXX
40
--- /dev/null
22
--- /dev/null
41
+++ b/target/arm/neon-dp.decode
23
+++ b/hw/gpio/gpio_pwr.c
42
@@ -XXX,XX +XXX,XX @@
43
+# AArch32 Neon data-processing instruction descriptions
44
+#
45
+# Copyright (c) 2020 Linaro, Ltd
46
+#
47
+# This library is free software; you can redistribute it and/or
48
+# modify it under the terms of the GNU Lesser General Public
49
+# License as published by the Free Software Foundation; either
50
+# version 2 of the License, or (at your option) any later version.
51
+#
52
+# This library is distributed in the hope that it will be useful,
53
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
54
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
55
+# Lesser General Public License for more details.
56
+#
57
+# You should have received a copy of the GNU Lesser General Public
58
+# License along with this library; if not, see <http://www.gnu.org/licenses/>.
59
+
60
+#
61
+# This file is processed by scripts/decodetree.py
62
+#
63
+
64
+# Encodings for Neon data processing instructions where the T32 encoding
65
+# is a simple transformation of the A32 encoding.
66
+# More specifically, this file covers instructions where the A32 encoding is
67
+# 0b1111_001p_qqqq_qqqq_qqqq_qqqq_qqqq_qqqq
68
+# and the T32 encoding is
69
+# 0b111p_1111_qqqq_qqqq_qqqq_qqqq_qqqq_qqqq
70
+# This file works on the A32 encoding only; calling code for T32 has to
71
+# transform the insn into the A32 version first.
72
diff --git a/target/arm/neon-ls.decode b/target/arm/neon-ls.decode
73
new file mode 100644
74
index XXXXXXX..XXXXXXX
75
--- /dev/null
76
+++ b/target/arm/neon-ls.decode
77
@@ -XXX,XX +XXX,XX @@
78
+# AArch32 Neon load/store instruction descriptions
79
+#
80
+# Copyright (c) 2020 Linaro, Ltd
81
+#
82
+# This library is free software; you can redistribute it and/or
83
+# modify it under the terms of the GNU Lesser General Public
84
+# License as published by the Free Software Foundation; either
85
+# version 2 of the License, or (at your option) any later version.
86
+#
87
+# This library is distributed in the hope that it will be useful,
88
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
89
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
90
+# Lesser General Public License for more details.
91
+#
92
+# You should have received a copy of the GNU Lesser General Public
93
+# License along with this library; if not, see <http://www.gnu.org/licenses/>.
94
+
95
+#
96
+# This file is processed by scripts/decodetree.py
97
+#
98
+
99
+# Encodings for Neon load/store instructions where the T32 encoding
100
+# is a simple transformation of the A32 encoding.
101
+# More specifically, this file covers instructions where the A32 encoding is
102
+# 0b1111_0100_xxx0_xxxx_xxxx_xxxx_xxxx_xxxx
103
+# and the T32 encoding is
104
+# 0b1111_1001_xxx0_xxxx_xxxx_xxxx_xxxx_xxxx
105
+# This file works on the A32 encoding only; calling code for T32 has to
106
+# transform the insn into the A32 version first.
107
diff --git a/target/arm/neon-shared.decode b/target/arm/neon-shared.decode
108
new file mode 100644
109
index XXXXXXX..XXXXXXX
110
--- /dev/null
111
+++ b/target/arm/neon-shared.decode
112
@@ -XXX,XX +XXX,XX @@
113
+# AArch32 Neon instruction descriptions
114
+#
115
+# Copyright (c) 2020 Linaro, Ltd
116
+#
117
+# This library is free software; you can redistribute it and/or
118
+# modify it under the terms of the GNU Lesser General Public
119
+# License as published by the Free Software Foundation; either
120
+# version 2 of the License, or (at your option) any later version.
121
+#
122
+# This library is distributed in the hope that it will be useful,
123
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
124
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
125
+# Lesser General Public License for more details.
126
+#
127
+# You should have received a copy of the GNU Lesser General Public
128
+# License along with this library; if not, see <http://www.gnu.org/licenses/>.
129
+
130
+#
131
+# This file is processed by scripts/decodetree.py
132
+#
133
+
134
+# Encodings for Neon instructions whose encoding is the same for
135
+# both A32 and T32.
136
+
137
+# More specifically, this covers:
138
+# 2reg scalar ext: 0b1111_1110_xxxx_xxxx_xxxx_1x0x_xxxx_xxxx
139
+# 3same ext: 0b1111_110x_xxxx_xxxx_xxxx_1x0x_xxxx_xxxx
140
diff --git a/target/arm/translate-neon.inc.c b/target/arm/translate-neon.inc.c
141
new file mode 100644
142
index XXXXXXX..XXXXXXX
143
--- /dev/null
144
+++ b/target/arm/translate-neon.inc.c
145
@@ -XXX,XX +XXX,XX @@
24
@@ -XXX,XX +XXX,XX @@
146
+/*
25
+/*
147
+ * ARM translation: AArch32 Neon instructions
26
+ * GPIO qemu power controller
148
+ *
27
+ *
149
+ * Copyright (c) 2003 Fabrice Bellard
28
+ * Copyright (c) 2020 Linaro Limited
150
+ * Copyright (c) 2005-2007 CodeSourcery
151
+ * Copyright (c) 2007 OpenedHand, Ltd.
152
+ * Copyright (c) 2020 Linaro, Ltd.
153
+ *
29
+ *
154
+ * This library is free software; you can redistribute it and/or
30
+ * Author: Maxim Uvarov <maxim.uvarov@linaro.org>
155
+ * modify it under the terms of the GNU Lesser General Public
156
+ * License as published by the Free Software Foundation; either
157
+ * version 2 of the License, or (at your option) any later version.
158
+ *
31
+ *
159
+ * This library is distributed in the hope that it will be useful,
32
+ * Virtual gpio driver which can be used on top of pl061
160
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
33
+ * to reboot and shutdown qemu virtual machine. One of use
161
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
34
+ * case is gpio driver for secure world application (ARM
162
+ * Lesser General Public License for more details.
35
+ * Trusted Firmware.).
163
+ *
36
+ *
164
+ * You should have received a copy of the GNU Lesser General Public
37
+ * This work is licensed under the terms of the GNU GPL, version 2 or later.
165
+ * License along with this library; if not, see <http://www.gnu.org/licenses/>.
38
+ * See the COPYING file in the top-level directory.
39
+ * SPDX-License-Identifier: GPL-2.0-or-later
166
+ */
40
+ */
167
+
41
+
168
+/*
42
+/*
169
+ * This file is intended to be included from translate.c; it uses
43
+ * QEMU interface:
170
+ * some macros and definitions provided by that file.
44
+ * two named input GPIO lines:
171
+ * It might be possible to convert it to a standalone .c file eventually.
45
+ * 'reset' : when asserted, trigger system reset
46
+ * 'shutdown' : when asserted, trigger system shutdown
172
+ */
47
+ */
173
+
48
+
174
+/* Include the generated Neon decoder */
49
+#include "qemu/osdep.h"
175
+#include "decode-neon-dp.inc.c"
50
+#include "hw/sysbus.h"
176
+#include "decode-neon-ls.inc.c"
51
+#include "sysemu/runstate.h"
177
+#include "decode-neon-shared.inc.c"
52
+
178
diff --git a/target/arm/translate.c b/target/arm/translate.c
53
+#define TYPE_GPIOPWR "gpio-pwr"
54
+OBJECT_DECLARE_SIMPLE_TYPE(GPIO_PWR_State, GPIOPWR)
55
+
56
+struct GPIO_PWR_State {
57
+ SysBusDevice parent_obj;
58
+};
59
+
60
+static void gpio_pwr_reset(void *opaque, int n, int level)
61
+{
62
+ if (level) {
63
+ qemu_system_reset_request(SHUTDOWN_CAUSE_GUEST_RESET);
64
+ }
65
+}
66
+
67
+static void gpio_pwr_shutdown(void *opaque, int n, int level)
68
+{
69
+ if (level) {
70
+ qemu_system_reset_request(SHUTDOWN_CAUSE_GUEST_SHUTDOWN);
71
+ }
72
+}
73
+
74
+static void gpio_pwr_init(Object *obj)
75
+{
76
+ DeviceState *dev = DEVICE(obj);
77
+
78
+ qdev_init_gpio_in_named(dev, gpio_pwr_reset, "reset", 1);
79
+ qdev_init_gpio_in_named(dev, gpio_pwr_shutdown, "shutdown", 1);
80
+}
81
+
82
+static const TypeInfo gpio_pwr_info = {
83
+ .name = TYPE_GPIOPWR,
84
+ .parent = TYPE_SYS_BUS_DEVICE,
85
+ .instance_size = sizeof(GPIO_PWR_State),
86
+ .instance_init = gpio_pwr_init,
87
+};
88
+
89
+static void gpio_pwr_register_types(void)
90
+{
91
+ type_register_static(&gpio_pwr_info);
92
+}
93
+
94
+type_init(gpio_pwr_register_types)
95
diff --git a/hw/gpio/Kconfig b/hw/gpio/Kconfig
179
index XXXXXXX..XXXXXXX 100644
96
index XXXXXXX..XXXXXXX 100644
180
--- a/target/arm/translate.c
97
--- a/hw/gpio/Kconfig
181
+++ b/target/arm/translate.c
98
+++ b/hw/gpio/Kconfig
182
@@ -XXX,XX +XXX,XX @@ static TCGv_ptr vfp_reg_ptr(bool dp, int reg)
99
@@ -XXX,XX +XXX,XX @@ config PL061
183
100
config GPIO_KEY
184
#define ARM_CP_RW_BIT (1 << 20)
101
bool
185
102
186
-/* Include the VFP decoder */
103
+config GPIO_PWR
187
+/* Include the VFP and Neon decoders */
104
+ bool
188
#include "translate-vfp.inc.c"
189
+#include "translate-neon.inc.c"
190
191
static inline void iwmmxt_load_reg(TCGv_i64 var, int reg)
192
{
193
@@ -XXX,XX +XXX,XX @@ static void disas_arm_insn(DisasContext *s, unsigned int insn)
194
/* Unconditional instructions. */
195
/* TODO: Perhaps merge these into one decodetree output file. */
196
if (disas_a32_uncond(s, insn) ||
197
- disas_vfp_uncond(s, insn)) {
198
+ disas_vfp_uncond(s, insn) ||
199
+ disas_neon_dp(s, insn) ||
200
+ disas_neon_ls(s, insn) ||
201
+ disas_neon_shared(s, insn)) {
202
return;
203
}
204
/* fall back to legacy decoder */
205
@@ -XXX,XX +XXX,XX @@ static void disas_thumb2_insn(DisasContext *s, uint32_t insn)
206
ARCH(6T2);
207
}
208
209
+ if ((insn & 0xef000000) == 0xef000000) {
210
+ /*
211
+ * T32 encodings 0b111p_1111_qqqq_qqqq_qqqq_qqqq_qqqq_qqqq
212
+ * transform into
213
+ * A32 encodings 0b1111_001p_qqqq_qqqq_qqqq_qqqq_qqqq_qqqq
214
+ */
215
+ uint32_t a32_insn = (insn & 0xe2ffffff) |
216
+ ((insn & (1 << 28)) >> 4) | (1 << 28);
217
+
105
+
218
+ if (disas_neon_dp(s, a32_insn)) {
106
config SIFIVE_GPIO
219
+ return;
107
bool
220
+ }
108
diff --git a/hw/gpio/meson.build b/hw/gpio/meson.build
221
+ }
222
+
223
+ if ((insn & 0xff100000) == 0xf9000000) {
224
+ /*
225
+ * T32 encodings 0b1111_1001_ppp0_qqqq_qqqq_qqqq_qqqq_qqqq
226
+ * transform into
227
+ * A32 encodings 0b1111_0100_ppp0_qqqq_qqqq_qqqq_qqqq_qqqq
228
+ */
229
+ uint32_t a32_insn = (insn & 0x00ffffff) | 0xf4000000;
230
+
231
+ if (disas_neon_ls(s, a32_insn)) {
232
+ return;
233
+ }
234
+ }
235
+
236
/*
237
* TODO: Perhaps merge these into one decodetree output file.
238
* Note disas_vfp is written for a32 with cond field in the
239
@@ -XXX,XX +XXX,XX @@ static void disas_thumb2_insn(DisasContext *s, uint32_t insn)
240
*/
241
if (disas_t32(s, insn) ||
242
disas_vfp_uncond(s, insn) ||
243
+ disas_neon_shared(s, insn) ||
244
((insn >> 28) == 0xe && disas_vfp(s, insn))) {
245
return;
246
}
247
diff --git a/target/arm/Makefile.objs b/target/arm/Makefile.objs
248
index XXXXXXX..XXXXXXX 100644
109
index XXXXXXX..XXXXXXX 100644
249
--- a/target/arm/Makefile.objs
110
--- a/hw/gpio/meson.build
250
+++ b/target/arm/Makefile.objs
111
+++ b/hw/gpio/meson.build
251
@@ -XXX,XX +XXX,XX @@ target/arm/decode-sve.inc.c: $(SRC_PATH)/target/arm/sve.decode $(DECODETREE)
112
@@ -XXX,XX +XXX,XX @@
252
     $(PYTHON) $(DECODETREE) --decode disas_sve -o $@ $<,\
113
softmmu_ss.add(when: 'CONFIG_E500', if_true: files('mpc8xxx.c'))
253
     "GEN", $(TARGET_DIR)$@)
114
softmmu_ss.add(when: 'CONFIG_GPIO_KEY', if_true: files('gpio_key.c'))
254
115
+softmmu_ss.add(when: 'CONFIG_GPIO_PWR', if_true: files('gpio_pwr.c'))
255
+target/arm/decode-neon-shared.inc.c: $(SRC_PATH)/target/arm/neon-shared.decode $(DECODETREE)
116
softmmu_ss.add(when: 'CONFIG_MAX7310', if_true: files('max7310.c'))
256
+    $(call quiet-command,\
117
softmmu_ss.add(when: 'CONFIG_PL061', if_true: files('pl061.c'))
257
+     $(PYTHON) $(DECODETREE) --static-decode disas_neon_shared -o $@ $<,\
118
softmmu_ss.add(when: 'CONFIG_PUV3', if_true: files('puv3_gpio.c'))
258
+     "GEN", $(TARGET_DIR)$@)
259
+
260
+target/arm/decode-neon-dp.inc.c: $(SRC_PATH)/target/arm/neon-dp.decode $(DECODETREE)
261
+    $(call quiet-command,\
262
+     $(PYTHON) $(DECODETREE) --static-decode disas_neon_dp -o $@ $<,\
263
+     "GEN", $(TARGET_DIR)$@)
264
+
265
+target/arm/decode-neon-ls.inc.c: $(SRC_PATH)/target/arm/neon-ls.decode $(DECODETREE)
266
+    $(call quiet-command,\
267
+     $(PYTHON) $(DECODETREE) --static-decode disas_neon_ls -o $@ $<,\
268
+     "GEN", $(TARGET_DIR)$@)
269
+
270
target/arm/decode-vfp.inc.c: $(SRC_PATH)/target/arm/vfp.decode $(DECODETREE)
271
    $(call quiet-command,\
272
     $(PYTHON) $(DECODETREE) --static-decode disas_vfp -o $@ $<,\
273
@@ -XXX,XX +XXX,XX @@ target/arm/decode-t16.inc.c: $(SRC_PATH)/target/arm/t16.decode $(DECODETREE)
274
     "GEN", $(TARGET_DIR)$@)
275
276
target/arm/translate-sve.o: target/arm/decode-sve.inc.c
277
+target/arm/translate.o: target/arm/decode-neon-shared.inc.c
278
+target/arm/translate.o: target/arm/decode-neon-dp.inc.c
279
+target/arm/translate.o: target/arm/decode-neon-ls.inc.c
280
target/arm/translate.o: target/arm/decode-vfp.inc.c
281
target/arm/translate.o: target/arm/decode-vfp-uncond.inc.c
282
target/arm/translate.o: target/arm/decode-a32.inc.c
283
--
119
--
284
2.20.1
120
2.20.1
285
121
286
122
diff view generated by jsdifflib
1
From: "Edgar E. Iglesias" <edgar.iglesias@xilinx.com>
1
From: Maxim Uvarov <maxim.uvarov@linaro.org>
2
2
3
Embed the APUs into the SoC type.
3
No functional change. Just refactor code to better
4
support secure and normal world gpios.
4
5
5
Suggested-by: Peter Maydell <peter.maydell@linaro.org>
6
Signed-off-by: Maxim Uvarov <maxim.uvarov@linaro.org>
6
Signed-off-by: Edgar E. Iglesias <edgar.iglesias@xilinx.com>
7
Reviewed-by: Andrew Jones <drjones@redhat.com>
7
Reviewed-by: Alistair Francis <alistair.francis@wdc.com>
8
Reviewed-by: Philippe Mathieu-Daudé <f4bug@amsat.org>
9
Reviewed-by: Luc Michel <luc.michel@greensocs.com>
10
Message-id: 20200427181649.26851-8-edgar.iglesias@gmail.com
11
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
8
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
12
---
9
---
13
include/hw/arm/xlnx-versal.h | 2 +-
10
hw/arm/virt.c | 57 ++++++++++++++++++++++++++++++++-------------------
14
hw/arm/xlnx-versal-virt.c | 4 ++--
11
1 file changed, 36 insertions(+), 21 deletions(-)
15
hw/arm/xlnx-versal.c | 19 +++++--------------
16
3 files changed, 8 insertions(+), 17 deletions(-)
17
12
18
diff --git a/include/hw/arm/xlnx-versal.h b/include/hw/arm/xlnx-versal.h
13
diff --git a/hw/arm/virt.c b/hw/arm/virt.c
19
index XXXXXXX..XXXXXXX 100644
14
index XXXXXXX..XXXXXXX 100644
20
--- a/include/hw/arm/xlnx-versal.h
15
--- a/hw/arm/virt.c
21
+++ b/include/hw/arm/xlnx-versal.h
16
+++ b/hw/arm/virt.c
22
@@ -XXX,XX +XXX,XX @@ typedef struct Versal {
17
@@ -XXX,XX +XXX,XX @@ static void virt_powerdown_req(Notifier *n, void *opaque)
23
struct {
24
struct {
25
MemoryRegion mr;
26
- ARMCPU *cpu[XLNX_VERSAL_NR_ACPUS];
27
+ ARMCPU cpu[XLNX_VERSAL_NR_ACPUS];
28
GICv3State gic;
29
} apu;
30
} fpd;
31
diff --git a/hw/arm/xlnx-versal-virt.c b/hw/arm/xlnx-versal-virt.c
32
index XXXXXXX..XXXXXXX 100644
33
--- a/hw/arm/xlnx-versal-virt.c
34
+++ b/hw/arm/xlnx-versal-virt.c
35
@@ -XXX,XX +XXX,XX @@ static void versal_virt_init(MachineState *machine)
36
s->binfo.get_dtb = versal_virt_get_dtb;
37
s->binfo.modify_dtb = versal_virt_modify_dtb;
38
if (machine->kernel_filename) {
39
- arm_load_kernel(s->soc.fpd.apu.cpu[0], machine, &s->binfo);
40
+ arm_load_kernel(&s->soc.fpd.apu.cpu[0], machine, &s->binfo);
41
} else {
42
- AddressSpace *as = arm_boot_address_space(s->soc.fpd.apu.cpu[0],
43
+ AddressSpace *as = arm_boot_address_space(&s->soc.fpd.apu.cpu[0],
44
&s->binfo);
45
/* Some boot-loaders (e.g u-boot) don't like blobs at address 0 (NULL).
46
* Offset things by 4K. */
47
diff --git a/hw/arm/xlnx-versal.c b/hw/arm/xlnx-versal.c
48
index XXXXXXX..XXXXXXX 100644
49
--- a/hw/arm/xlnx-versal.c
50
+++ b/hw/arm/xlnx-versal.c
51
@@ -XXX,XX +XXX,XX @@ static void versal_create_apu_cpus(Versal *s)
52
53
for (i = 0; i < ARRAY_SIZE(s->fpd.apu.cpu); i++) {
54
Object *obj;
55
- char *name;
56
-
57
- obj = object_new(XLNX_VERSAL_ACPU_TYPE);
58
- if (!obj) {
59
- error_report("Unable to create apu.cpu[%d] of type %s",
60
- i, XLNX_VERSAL_ACPU_TYPE);
61
- exit(EXIT_FAILURE);
62
- }
63
-
64
- name = g_strdup_printf("apu-cpu[%d]", i);
65
- object_property_add_child(OBJECT(s), name, obj, &error_fatal);
66
- g_free(name);
67
68
+ object_initialize_child(OBJECT(s), "apu-cpu[*]",
69
+ &s->fpd.apu.cpu[i], sizeof(s->fpd.apu.cpu[i]),
70
+ XLNX_VERSAL_ACPU_TYPE, &error_abort, NULL);
71
+ obj = OBJECT(&s->fpd.apu.cpu[i]);
72
object_property_set_int(obj, s->cfg.psci_conduit,
73
"psci-conduit", &error_abort);
74
if (i) {
75
@@ -XXX,XX +XXX,XX @@ static void versal_create_apu_cpus(Versal *s)
76
object_property_set_link(obj, OBJECT(&s->fpd.apu.mr), "memory",
77
&error_abort);
78
object_property_set_bool(obj, true, "realized", &error_fatal);
79
- s->fpd.apu.cpu[i] = ARM_CPU(obj);
80
}
18
}
81
}
19
}
82
20
83
@@ -XXX,XX +XXX,XX @@ static void versal_create_apu_gic(Versal *s, qemu_irq *pic)
21
-static void create_gpio(const VirtMachineState *vms)
22
+static void create_gpio_keys(const VirtMachineState *vms,
23
+ DeviceState *pl061_dev,
24
+ uint32_t phandle)
25
+{
26
+ gpio_key_dev = sysbus_create_simple("gpio-key", -1,
27
+ qdev_get_gpio_in(pl061_dev, 3));
28
+
29
+ qemu_fdt_add_subnode(vms->fdt, "/gpio-keys");
30
+ qemu_fdt_setprop_string(vms->fdt, "/gpio-keys", "compatible", "gpio-keys");
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
+
34
+ qemu_fdt_add_subnode(vms->fdt, "/gpio-keys/poweroff");
35
+ qemu_fdt_setprop_string(vms->fdt, "/gpio-keys/poweroff",
36
+ "label", "GPIO Key Poweroff");
37
+ qemu_fdt_setprop_cell(vms->fdt, "/gpio-keys/poweroff", "linux,code",
38
+ KEY_POWER);
39
+ qemu_fdt_setprop_cells(vms->fdt, "/gpio-keys/poweroff",
40
+ "gpios", phandle, 3, 0);
41
+}
42
+
43
+static void create_gpio_devices(const VirtMachineState *vms, int gpio,
44
+ MemoryRegion *mem)
45
{
46
char *nodename;
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
+
87
+ /* Child gpio devices */
88
+ create_gpio_keys(vms, pl061_dev, phandle);
89
}
90
91
static void create_virtio_devices(const VirtMachineState *vms)
92
@@ -XXX,XX +XXX,XX @@ static void machvirt_init(MachineState *machine)
93
if (has_ged && aarch64 && firmware_loaded && virt_is_acpi_enabled(vms)) {
94
vms->acpi_dev = create_acpi_ged(vms);
95
} else {
96
- create_gpio(vms);
97
+ create_gpio_devices(vms, VIRT_GPIO, sysmem);
84
}
98
}
85
99
86
for (i = 0; i < nr_apu_cpus; i++) {
100
/* connect powerdown request */
87
- DeviceState *cpudev = DEVICE(s->fpd.apu.cpu[i]);
88
+ DeviceState *cpudev = DEVICE(&s->fpd.apu.cpu[i]);
89
int ppibase = XLNX_VERSAL_NR_IRQS + i * GIC_INTERNAL + GIC_NR_SGIS;
90
qemu_irq maint_irq;
91
int ti;
92
--
101
--
93
2.20.1
102
2.20.1
94
103
95
104
diff view generated by jsdifflib
1
From: "Edgar E. Iglesias" <edgar.iglesias@xilinx.com>
1
From: Maxim Uvarov <maxim.uvarov@linaro.org>
2
2
3
Add support for the RTC.
3
Add secure pl061 for reset/power down machine from
4
the secure world (Arm Trusted Firmware). Connect it
5
with gpio-pwr driver.
4
6
5
Signed-off-by: Edgar E. Iglesias <edgar.iglesias@xilinx.com>
7
Signed-off-by: Maxim Uvarov <maxim.uvarov@linaro.org>
6
Reviewed-by: Alistair Francis <alistair.francis@wdc.com>
8
Reviewed-by: Andrew Jones <drjones@redhat.com>
7
Reviewed-by: Luc Michel <luc.michel@greensocs.com>
9
[PMM: Added mention of the new device to the documentation]
8
Message-id: 20200427181649.26851-12-edgar.iglesias@gmail.com
9
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
10
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
10
---
11
---
11
hw/arm/xlnx-versal-virt.c | 22 ++++++++++++++++++++++
12
docs/system/arm/virt.rst | 2 ++
12
1 file changed, 22 insertions(+)
13
include/hw/arm/virt.h | 2 ++
14
hw/arm/virt.c | 56 +++++++++++++++++++++++++++++++++++++++-
15
hw/arm/Kconfig | 1 +
16
4 files changed, 60 insertions(+), 1 deletion(-)
13
17
14
diff --git a/hw/arm/xlnx-versal-virt.c b/hw/arm/xlnx-versal-virt.c
18
diff --git a/docs/system/arm/virt.rst b/docs/system/arm/virt.rst
15
index XXXXXXX..XXXXXXX 100644
19
index XXXXXXX..XXXXXXX 100644
16
--- a/hw/arm/xlnx-versal-virt.c
20
--- a/docs/system/arm/virt.rst
17
+++ b/hw/arm/xlnx-versal-virt.c
21
+++ b/docs/system/arm/virt.rst
18
@@ -XXX,XX +XXX,XX @@ static void fdt_add_sd_nodes(VersalVirt *s)
22
@@ -XXX,XX +XXX,XX @@ The virt board supports:
19
}
23
- Secure-World-only devices if the CPU has TrustZone:
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);
20
}
65
}
21
66
22
+static void fdt_add_rtc_node(VersalVirt *s)
67
+#define SECURE_GPIO_POWEROFF 0
68
+#define SECURE_GPIO_RESET 1
69
+
70
+static void create_secure_gpio_pwr(const VirtMachineState *vms,
71
+ DeviceState *pl061_dev,
72
+ uint32_t phandle)
23
+{
73
+{
24
+ const char compat[] = "xlnx,zynqmp-rtc";
74
+ DeviceState *gpio_pwr_dev;
25
+ const char interrupt_names[] = "alarm\0sec";
26
+ char *name = g_strdup_printf("/rtc@%x", MM_PMC_RTC);
27
+
75
+
28
+ qemu_fdt_add_subnode(s->fdt, name);
76
+ /* gpio-pwr */
77
+ gpio_pwr_dev = sysbus_create_simple("gpio-pwr", -1, NULL);
29
+
78
+
30
+ qemu_fdt_setprop_cells(s->fdt, name, "interrupts",
79
+ /* connect secure pl061 to gpio-pwr */
31
+ GIC_FDT_IRQ_TYPE_SPI, VERSAL_RTC_ALARM_IRQ,
80
+ qdev_connect_gpio_out(pl061_dev, SECURE_GPIO_RESET,
32
+ GIC_FDT_IRQ_FLAGS_LEVEL_HI,
81
+ qdev_get_gpio_in_named(gpio_pwr_dev, "reset", 0));
33
+ GIC_FDT_IRQ_TYPE_SPI, VERSAL_RTC_SECONDS_IRQ,
82
+ qdev_connect_gpio_out(pl061_dev, SECURE_GPIO_POWEROFF,
34
+ GIC_FDT_IRQ_FLAGS_LEVEL_HI);
83
+ qdev_get_gpio_in_named(gpio_pwr_dev, "shutdown", 0));
35
+ qemu_fdt_setprop(s->fdt, name, "interrupt-names",
84
+
36
+ interrupt_names, sizeof(interrupt_names));
85
+ qemu_fdt_add_subnode(vms->fdt, "/gpio-poweroff");
37
+ qemu_fdt_setprop_sized_cells(s->fdt, name, "reg",
86
+ qemu_fdt_setprop_string(vms->fdt, "/gpio-poweroff", "compatible",
38
+ 2, MM_PMC_RTC, 2, MM_PMC_RTC_SIZE);
87
+ "gpio-poweroff");
39
+ qemu_fdt_setprop(s->fdt, name, "compatible", compat, sizeof(compat));
88
+ qemu_fdt_setprop_cells(vms->fdt, "/gpio-poweroff",
40
+ g_free(name);
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");
41
+}
102
+}
42
+
103
+
43
static void fdt_nop_memory_nodes(void *fdt, Error **errp)
104
static void create_gpio_devices(const VirtMachineState *vms, int gpio,
105
MemoryRegion *mem)
44
{
106
{
45
Error *err = NULL;
107
@@ -XXX,XX +XXX,XX @@ static void create_gpio_devices(const VirtMachineState *vms, int gpio,
46
@@ -XXX,XX +XXX,XX @@ static void versal_virt_init(MachineState *machine)
108
qemu_fdt_setprop_string(vms->fdt, nodename, "clock-names", "apb_pclk");
47
fdt_add_timer_nodes(s);
109
qemu_fdt_setprop_cell(vms->fdt, nodename, "phandle", phandle);
48
fdt_add_zdma_nodes(s);
110
49
fdt_add_sd_nodes(s);
111
+ if (gpio != VIRT_GPIO) {
50
+ fdt_add_rtc_node(s);
112
+ /* Mark as not usable by the normal world */
51
fdt_add_cpu_nodes(s, psci_conduit);
113
+ qemu_fdt_setprop_string(vms->fdt, nodename, "status", "disabled");
52
fdt_add_clk_node(s, "/clk125", 125000000, s->phandle.clk_125Mhz);
114
+ qemu_fdt_setprop_string(vms->fdt, nodename, "secure-status", "okay");
53
fdt_add_clk_node(s, "/clk25", 25000000, s->phandle.clk_25Mhz);
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
}
126
127
static void create_virtio_devices(const VirtMachineState *vms)
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
54
--
163
--
55
2.20.1
164
2.20.1
56
165
57
166
diff view generated by jsdifflib
1
From: "Edgar E. Iglesias" <edgar.iglesias@xilinx.com>
1
From: Hao Wu <wuhaotsh@google.com>
2
2
3
Fix typo xlnx-ve -> xlnx-versal.
3
Fix potential overflow problem when calculating pwm_duty.
4
1. Ensure p->cmr and p->cnr to be from [0,65535], according to the
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.)
4
10
5
Signed-off-by: Edgar E. Iglesias <edgar.iglesias@xilinx.com>
11
Fixes: CID 1442342
6
Reviewed-by: Alistair Francis <alistair.francis@wdc.com>
12
Suggested-by: Peter Maydell <peter.maydell@linaro.org>
7
Reviewed-by: Philippe Mathieu-Daudé <f4bug@amsat.org>
13
Reviewed-by: Doug Evans <dje@google.com>
8
Reviewed-by: Luc Michel <luc.michel@greensocs.com>
14
Signed-off-by: Hao Wu <wuhaotsh@google.com>
9
Message-id: 20200427181649.26851-4-edgar.iglesias@gmail.com
15
Message-id: 20210127011142.2122790-1-wuhaotsh@google.com
16
Reviewed-by: Peter Maydell <peter.maydell@linaro.org>
10
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
17
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
11
---
18
---
12
hw/arm/xlnx-versal-virt.c | 2 +-
19
hw/misc/npcm7xx_pwm.c | 23 +++++++++++++++++++----
13
1 file changed, 1 insertion(+), 1 deletion(-)
20
tests/qtest/npcm7xx_pwm-test.c | 4 ++--
21
2 files changed, 21 insertions(+), 6 deletions(-)
14
22
15
diff --git a/hw/arm/xlnx-versal-virt.c b/hw/arm/xlnx-versal-virt.c
23
diff --git a/hw/misc/npcm7xx_pwm.c b/hw/misc/npcm7xx_pwm.c
16
index XXXXXXX..XXXXXXX 100644
24
index XXXXXXX..XXXXXXX 100644
17
--- a/hw/arm/xlnx-versal-virt.c
25
--- a/hw/misc/npcm7xx_pwm.c
18
+++ b/hw/arm/xlnx-versal-virt.c
26
+++ b/hw/misc/npcm7xx_pwm.c
19
@@ -XXX,XX +XXX,XX @@ static void versal_virt_init(MachineState *machine)
27
@@ -XXX,XX +XXX,XX @@ REG32(NPCM7XX_PWM_PWDR3, 0x50);
20
psci_conduit = QEMU_PSCI_CONDUIT_SMC;
28
#define NPCM7XX_CH_INV BIT(2)
29
#define NPCM7XX_CH_MOD BIT(3)
30
31
+#define NPCM7XX_MAX_CMR 65535
32
+#define NPCM7XX_MAX_CNR 65535
33
+
34
/* Offset of each PWM channel's prescaler in the PPR register. */
35
static const int npcm7xx_ppr_base[] = { 0, 0, 8, 8 };
36
/* Offset of each PWM channel's clock selector in the CSR register. */
37
@@ -XXX,XX +XXX,XX @@ static uint32_t npcm7xx_pwm_calculate_freq(NPCM7xxPWM *p)
38
39
static uint32_t npcm7xx_pwm_calculate_duty(NPCM7xxPWM *p)
40
{
41
- uint64_t duty;
42
+ uint32_t duty;
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
87
--- a/tests/qtest/npcm7xx_pwm-test.c
88
+++ b/tests/qtest/npcm7xx_pwm-test.c
89
@@ -XXX,XX +XXX,XX @@ static uint64_t pwm_compute_freq(QTestState *qts, uint32_t ppr, uint32_t csr,
90
91
static uint64_t pwm_compute_duty(uint32_t cnr, uint32_t cmr, bool inverted)
92
{
93
- uint64_t duty;
94
+ uint32_t duty;
95
96
if (cnr == 0) {
97
/* PWM is stopped. */
98
@@ -XXX,XX +XXX,XX @@ static uint64_t pwm_compute_duty(uint32_t cnr, uint32_t cmr, bool inverted)
99
} else if (cmr >= cnr) {
100
duty = MAX_DUTY;
101
} else {
102
- duty = MAX_DUTY * (cmr + 1) / (cnr + 1);
103
+ duty = (uint64_t)MAX_DUTY * (cmr + 1) / (cnr + 1);
21
}
104
}
22
105
23
- sysbus_init_child_obj(OBJECT(machine), "xlnx-ve", &s->soc,
106
if (inverted) {
24
+ sysbus_init_child_obj(OBJECT(machine), "xlnx-versal", &s->soc,
25
sizeof(s->soc), TYPE_XLNX_VERSAL);
26
object_property_set_link(OBJECT(&s->soc), OBJECT(machine->ram),
27
"ddr", &error_abort);
28
--
107
--
29
2.20.1
108
2.20.1
30
109
31
110
diff view generated by jsdifflib
1
From: "Edgar E. Iglesias" <edgar.iglesias@xilinx.com>
1
From: Philippe Mathieu-Daudé <f4bug@amsat.org>
2
2
3
Move misplaced comment.
3
cpu_get_phys_page_debug() uses 'DATA LOAD' MMU access type.
4
4
5
Signed-off-by: Edgar E. Iglesias <edgar.iglesias@xilinx.com>
5
Signed-off-by: Philippe Mathieu-Daudé <f4bug@amsat.org>
6
Reviewed-by: Alistair Francis <alistair.francis@wdc.com>
6
Message-id: 20210127232822.3530782-1-f4bug@amsat.org
7
Reviewed-by: Philippe Mathieu-Daudé <f4bug@amsat.org>
7
Reviewed-by: Peter Maydell <peter.maydell@linaro.org>
8
Reviewed-by: Luc Michel <luc.michel@greensocs.com>
9
Message-id: 20200427181649.26851-3-edgar.iglesias@gmail.com
10
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
8
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
11
---
9
---
12
hw/arm/xlnx-versal.c | 2 +-
10
target/arm/helper.c | 2 +-
13
1 file changed, 1 insertion(+), 1 deletion(-)
11
1 file changed, 1 insertion(+), 1 deletion(-)
14
12
15
diff --git a/hw/arm/xlnx-versal.c b/hw/arm/xlnx-versal.c
13
diff --git a/target/arm/helper.c b/target/arm/helper.c
16
index XXXXXXX..XXXXXXX 100644
14
index XXXXXXX..XXXXXXX 100644
17
--- a/hw/arm/xlnx-versal.c
15
--- a/target/arm/helper.c
18
+++ b/hw/arm/xlnx-versal.c
16
+++ b/target/arm/helper.c
19
@@ -XXX,XX +XXX,XX @@ static void versal_create_apu_cpus(Versal *s)
17
@@ -XXX,XX +XXX,XX @@ hwaddr arm_cpu_get_phys_page_attrs_debug(CPUState *cs, vaddr addr,
20
18
21
obj = object_new(XLNX_VERSAL_ACPU_TYPE);
19
*attrs = (MemTxAttrs) {};
22
if (!obj) {
20
23
- /* Secondary CPUs start in PSCI powered-down state */
21
- ret = get_phys_addr(env, addr, 0, mmu_idx, &phys_addr,
24
error_report("Unable to create apu.cpu[%d] of type %s",
22
+ ret = get_phys_addr(env, addr, MMU_DATA_LOAD, mmu_idx, &phys_addr,
25
i, XLNX_VERSAL_ACPU_TYPE);
23
attrs, &prot, &page_size, &fi, &cacheattrs);
26
exit(EXIT_FAILURE);
24
27
@@ -XXX,XX +XXX,XX @@ static void versal_create_apu_cpus(Versal *s)
25
if (ret) {
28
object_property_set_int(obj, s->cfg.psci_conduit,
29
"psci-conduit", &error_abort);
30
if (i) {
31
+ /* Secondary CPUs start in PSCI powered-down state */
32
object_property_set_bool(obj, true,
33
"start-powered-off", &error_abort);
34
}
35
--
26
--
36
2.20.1
27
2.20.1
37
28
38
29
diff view generated by jsdifflib
New 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.
1
5
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
New patch
1
From: Joelle van Dyne <j@getutm.app>
1
2
3
The iOS toolchain does not use the host prefix naming convention. So we
4
need to enable cross-compile options while allowing the PREFIX to be
5
blank.
6
7
Reviewed-by: Philippe Mathieu-Daudé <f4bug@amsat.org>
8
Signed-off-by: Joelle van Dyne <j@getutm.app>
9
Message-id: 20210126012457.39046-3-j@getutm.app
10
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
11
---
12
configure | 6 ++++--
13
1 file changed, 4 insertions(+), 2 deletions(-)
14
15
diff --git a/configure b/configure
16
index XXXXXXX..XXXXXXX 100755
17
--- a/configure
18
+++ b/configure
19
@@ -XXX,XX +XXX,XX @@ cpu=""
20
iasl="iasl"
21
interp_prefix="/usr/gnemul/qemu-%M"
22
static="no"
23
+cross_compile="no"
24
cross_prefix=""
25
audio_drv_list=""
26
block_drv_rw_whitelist=""
27
@@ -XXX,XX +XXX,XX @@ for opt do
28
optarg=$(expr "x$opt" : 'x[^=]*=\(.*\)')
29
case "$opt" in
30
--cross-prefix=*) cross_prefix="$optarg"
31
+ cross_compile="yes"
32
;;
33
--cc=*) CC="$optarg"
34
;;
35
@@ -XXX,XX +XXX,XX @@ $(echo Deprecated targets: $deprecated_targets_list | \
36
--target-list-exclude=LIST exclude a set of targets from the default target-list
37
38
Advanced options (experts only):
39
- --cross-prefix=PREFIX use PREFIX for compile tools [$cross_prefix]
40
+ --cross-prefix=PREFIX use PREFIX for compile tools, PREFIX can be blank [$cross_prefix]
41
--cc=CC use C compiler CC [$cc]
42
--iasl=IASL use ACPI compiler IASL [$iasl]
43
--host-cc=CC use C compiler CC [$host_cc] for code run at
44
@@ -XXX,XX +XXX,XX @@ if has $sdl2_config; then
45
fi
46
echo "strip = [$(meson_quote $strip)]" >> $cross
47
echo "windres = [$(meson_quote $windres)]" >> $cross
48
-if test -n "$cross_prefix"; then
49
+if test "$cross_compile" = "yes"; then
50
cross_arg="--cross-file config-meson.cross"
51
echo "[host_machine]" >> $cross
52
if test "$mingw32" = "yes" ; then
53
--
54
2.20.1
55
56
diff view generated by jsdifflib
1
From: Fredrik Strupe <fredrik@strupe.net>
1
From: Joelle van Dyne <j@getutm.app>
2
2
3
According to Arm ARM, VQDMULL is only valid when U=0, while having
3
Build without error on hosts without a working system(). If system()
4
U=1 is unallocated.
4
is called, return -1 with ENOSYS.
5
5
6
Signed-off-by: Fredrik Strupe <fredrik@strupe.net>
6
Signed-off-by: Joelle van Dyne <j@getutm.app>
7
Fixes: 695272dcb976 ("target-arm: Handle UNDEF cases for Neon 3-regs-different-widths")
7
Message-id: 20210126012457.39046-6-j@getutm.app
8
Reviewed-by: Peter Maydell <peter.maydell@linaro.org>
8
Reviewed-by: Peter Maydell <peter.maydell@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
target/arm/translate.c | 2 +-
11
meson.build | 1 +
12
1 file changed, 1 insertion(+), 1 deletion(-)
12
include/qemu/osdep.h | 12 ++++++++++++
13
2 files changed, 13 insertions(+)
13
14
14
diff --git a/target/arm/translate.c b/target/arm/translate.c
15
diff --git a/meson.build b/meson.build
15
index XXXXXXX..XXXXXXX 100644
16
index XXXXXXX..XXXXXXX 100644
16
--- a/target/arm/translate.c
17
--- a/meson.build
17
+++ b/target/arm/translate.c
18
+++ b/meson.build
18
@@ -XXX,XX +XXX,XX @@ static int disas_neon_data_insn(DisasContext *s, uint32_t insn)
19
@@ -XXX,XX +XXX,XX @@ config_host_data.set('HAVE_DRM_H', cc.has_header('libdrm/drm.h'))
19
{0, 0, 0, 0}, /* VMLSL */
20
config_host_data.set('HAVE_PTY_H', cc.has_header('pty.h'))
20
{0, 0, 0, 9}, /* VQDMLSL */
21
config_host_data.set('HAVE_SYS_IOCCOM_H', cc.has_header('sys/ioccom.h'))
21
{0, 0, 0, 0}, /* Integer VMULL */
22
config_host_data.set('HAVE_SYS_KCOV_H', cc.has_header('sys/kcov.h'))
22
- {0, 0, 0, 1}, /* VQDMULL */
23
+config_host_data.set('HAVE_SYSTEM_FUNCTION', cc.has_function('system', prefix: '#include <stdlib.h>'))
23
+ {0, 0, 0, 9}, /* VQDMULL */
24
24
{0, 0, 0, 0xa}, /* Polynomial VMULL */
25
config_host_data.set('CONFIG_PREADV', cc.has_function('preadv', prefix: '#include <sys/uio.h>'))
25
{0, 0, 0, 7}, /* Reserved: always UNDEF */
26
26
};
27
diff --git a/include/qemu/osdep.h b/include/qemu/osdep.h
28
index XXXXXXX..XXXXXXX 100644
29
--- a/include/qemu/osdep.h
30
+++ b/include/qemu/osdep.h
31
@@ -XXX,XX +XXX,XX @@ static inline void qemu_thread_jit_write(void) {}
32
static inline void qemu_thread_jit_execute(void) {}
33
#endif
34
35
+/**
36
+ * Platforms which do not support system() return ENOSYS
37
+ */
38
+#ifndef HAVE_SYSTEM_FUNCTION
39
+#define system platform_does_not_support_system
40
+static inline int platform_does_not_support_system(const char *command)
41
+{
42
+ errno = ENOSYS;
43
+ return -1;
44
+}
45
+#endif /* !HAVE_SYSTEM_FUNCTION */
46
+
47
#endif
27
--
48
--
28
2.20.1
49
2.20.1
29
50
30
51
diff view generated by jsdifflib
New patch
1
From: Joelle van Dyne <j@getutm.app>
1
2
3
Meson will find CoreFoundation, IOKit, and Cocoa as needed.
4
5
Reviewed-by: Peter Maydell <peter.maydell@linaro.org>
6
Signed-off-by: Joelle van Dyne <j@getutm.app>
7
Message-id: 20210126012457.39046-7-j@getutm.app
8
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
9
---
10
configure | 1 -
11
1 file changed, 1 deletion(-)
12
13
diff --git a/configure b/configure
14
index XXXXXXX..XXXXXXX 100755
15
--- a/configure
16
+++ b/configure
17
@@ -XXX,XX +XXX,XX @@ Darwin)
18
fi
19
audio_drv_list="coreaudio try-sdl"
20
audio_possible_drivers="coreaudio sdl"
21
- QEMU_LDFLAGS="-framework CoreFoundation -framework IOKit $QEMU_LDFLAGS"
22
# Disable attempts to use ObjectiveC features in os/object.h since they
23
# won't work when we're compiling with gcc as a C compiler.
24
QEMU_CFLAGS="-DOS_OBJECT_USE_OBJC=0 $QEMU_CFLAGS"
25
--
26
2.20.1
27
28
diff view generated by jsdifflib
New patch
1
From: Joelle van Dyne <j@getutm.app>
1
2
3
Add objc to the Meson cross file as well as detection of Darwin.
4
5
Reviewed-by: Peter Maydell <peter.maydell@linaro.org>
6
Signed-off-by: Joelle van Dyne <j@getutm.app>
7
Reviewed-by: Philippe Mathieu-Daudé <f4bug@amsat.org>
8
Message-id: 20210126012457.39046-8-j@getutm.app
9
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
10
---
11
configure | 4 ++++
12
1 file changed, 4 insertions(+)
13
14
diff --git a/configure b/configure
15
index XXXXXXX..XXXXXXX 100755
16
--- a/configure
17
+++ b/configure
18
@@ -XXX,XX +XXX,XX @@ echo "cpp_link_args = [${LDFLAGS:+$(meson_quote $LDFLAGS)}]" >> $cross
19
echo "[binaries]" >> $cross
20
echo "c = [$(meson_quote $cc)]" >> $cross
21
test -n "$cxx" && echo "cpp = [$(meson_quote $cxx)]" >> $cross
22
+test -n "$objcc" && echo "objc = [$(meson_quote $objcc)]" >> $cross
23
echo "ar = [$(meson_quote $ar)]" >> $cross
24
echo "nm = [$(meson_quote $nm)]" >> $cross
25
echo "pkgconfig = [$(meson_quote $pkg_config_exe)]" >> $cross
26
@@ -XXX,XX +XXX,XX @@ if test "$cross_compile" = "yes"; then
27
if test "$linux" = "yes" ; then
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
--
37
2.20.1
38
39
diff view generated by jsdifflib
New patch
1
From: Joelle van Dyne <j@getutm.app>
1
2
3
Reviewed-by: Philippe Mathieu-Daudé <philmd@redhat.com>
4
Signed-off-by: Joelle van Dyne <j@getutm.app>
5
Message-id: 20210126012457.39046-9-j@getutm.app
6
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
7
---
8
configure | 5 ++++-
9
1 file changed, 4 insertions(+), 1 deletion(-)
10
11
diff --git a/configure b/configure
12
index XXXXXXX..XXXXXXX 100755
13
--- a/configure
14
+++ b/configure
15
@@ -XXX,XX +XXX,XX @@ if test "$cross_compile" = "yes"; then
16
echo "system = 'darwin'" >> $cross
17
fi
18
case "$ARCH" in
19
- i386|x86_64)
20
+ i386)
21
echo "cpu_family = 'x86'" >> $cross
22
;;
23
+ x86_64)
24
+ echo "cpu_family = 'x86_64'" >> $cross
25
+ ;;
26
ppc64le)
27
echo "cpu_family = 'ppc64'" >> $cross
28
;;
29
--
30
2.20.1
31
32
diff view generated by jsdifflib
New patch
1
From: Joelle van Dyne <j@getutm.app>
1
2
3
On iOS there is no CoreAudio, so we should not assume Darwin always
4
has it.
5
6
Signed-off-by: Joelle van Dyne <j@getutm.app>
7
Reviewed-by: Philippe Mathieu-Daudé <f4bug@amsat.org>
8
Message-id: 20210126012457.39046-11-j@getutm.app
9
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
10
---
11
configure | 35 +++++++++++++++++++++++++++++++++--
12
1 file changed, 33 insertions(+), 2 deletions(-)
13
14
diff --git a/configure b/configure
15
index XXXXXXX..XXXXXXX 100755
16
--- a/configure
17
+++ b/configure
18
@@ -XXX,XX +XXX,XX @@ fdt="auto"
19
netmap="no"
20
sdl="auto"
21
sdl_image="auto"
22
+coreaudio="auto"
23
virtiofsd="auto"
24
virtfs="auto"
25
libudev="auto"
26
@@ -XXX,XX +XXX,XX @@ Darwin)
27
QEMU_CFLAGS="-arch x86_64 $QEMU_CFLAGS"
28
QEMU_LDFLAGS="-arch x86_64 $QEMU_LDFLAGS"
29
fi
30
- audio_drv_list="coreaudio try-sdl"
31
+ audio_drv_list="try-coreaudio try-sdl"
32
audio_possible_drivers="coreaudio sdl"
33
# Disable attempts to use ObjectiveC features in os/object.h since they
34
# won't work when we're compiling with gcc as a C compiler.
35
@@ -XXX,XX +XXX,XX @@ EOF
36
fi
37
fi
38
39
+##########################################
40
+# detect CoreAudio
41
+if test "$coreaudio" != "no" ; then
42
+ coreaudio_libs="-framework CoreAudio"
43
+ cat > $TMPC << EOF
44
+#include <CoreAudio/CoreAudio.h>
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
--
83
2.20.1
84
85
diff view generated by jsdifflib
1
From: "Edgar E. Iglesias" <edgar.iglesias@xilinx.com>
1
From: Joelle van Dyne <j@getutm.app>
2
2
3
Embed the ADMAs into the SoC type.
3
A workaround added in early days of 64-bit OSX forced x86_64 if the
4
host machine had 64-bit support. This creates issues when cross-
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.
4
8
5
Suggested-by: Peter Maydell <peter.maydell@linaro.org>
9
Reviewed-by: Peter Maydell <peter.maydell@linaro.org>
6
Signed-off-by: Edgar E. Iglesias <edgar.iglesias@xilinx.com>
10
Signed-off-by: Joelle van Dyne <j@getutm.app>
7
Reviewed-by: Alistair Francis <alistair.francis@wdc.com>
11
Message-id: 20210126012457.39046-12-j@getutm.app
8
Reviewed-by: Philippe Mathieu-Daudé <f4bug@amsat.org>
9
Reviewed-by: Luc Michel <luc.michel@greensocs.com>
10
Message-id: 20200427181649.26851-7-edgar.iglesias@gmail.com
11
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
12
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
12
---
13
---
13
include/hw/arm/xlnx-versal.h | 3 ++-
14
configure | 11 -----------
14
hw/arm/xlnx-versal.c | 14 +++++++-------
15
1 file changed, 11 deletions(-)
15
2 files changed, 9 insertions(+), 8 deletions(-)
16
16
17
diff --git a/include/hw/arm/xlnx-versal.h b/include/hw/arm/xlnx-versal.h
17
diff --git a/configure b/configure
18
index XXXXXXX..XXXXXXX 100644
18
index XXXXXXX..XXXXXXX 100755
19
--- a/include/hw/arm/xlnx-versal.h
19
--- a/configure
20
+++ b/include/hw/arm/xlnx-versal.h
20
+++ b/configure
21
@@ -XXX,XX +XXX,XX @@
21
@@ -XXX,XX +XXX,XX @@ fi
22
#include "hw/arm/boot.h"
22
# the correct CPU with the --cpu option.
23
#include "hw/intc/arm_gicv3.h"
23
case $targetos in
24
#include "hw/char/pl011.h"
24
Darwin)
25
+#include "hw/dma/xlnx-zdma.h"
25
- # on Leopard most of the system is 32-bit, so we have to ask the kernel if we can
26
#include "hw/net/cadence_gem.h"
26
- # run 64-bit userspace code.
27
27
- # If the user didn't specify a CPU explicitly and the kernel says this is
28
#define TYPE_XLNX_VERSAL "xlnx-versal"
28
- # 64 bit hw, then assume x86_64. Otherwise fall through to the usual detection code.
29
@@ -XXX,XX +XXX,XX @@ typedef struct Versal {
29
- if test -z "$cpu" && test "$(sysctl -n hw.optional.x86_64)" = "1"; then
30
struct {
30
- cpu="x86_64"
31
PL011State uart[XLNX_VERSAL_NR_UARTS];
31
- fi
32
CadenceGEMState gem[XLNX_VERSAL_NR_GEMS];
32
HOST_DSOSUF=".dylib"
33
- SysBusDevice *adma[XLNX_VERSAL_NR_ADMAS];
33
;;
34
+ XlnxZDMA adma[XLNX_VERSAL_NR_ADMAS];
34
SunOS)
35
} iou;
35
@@ -XXX,XX +XXX,XX @@ OpenBSD)
36
} lpd;
36
Darwin)
37
37
bsd="yes"
38
diff --git a/hw/arm/xlnx-versal.c b/hw/arm/xlnx-versal.c
38
darwin="yes"
39
index XXXXXXX..XXXXXXX 100644
39
- if [ "$cpu" = "x86_64" ] ; then
40
--- a/hw/arm/xlnx-versal.c
40
- QEMU_CFLAGS="-arch x86_64 $QEMU_CFLAGS"
41
+++ b/hw/arm/xlnx-versal.c
41
- QEMU_LDFLAGS="-arch x86_64 $QEMU_LDFLAGS"
42
@@ -XXX,XX +XXX,XX @@ static void versal_create_admas(Versal *s, qemu_irq *pic)
42
- fi
43
DeviceState *dev;
43
audio_drv_list="try-coreaudio try-sdl"
44
MemoryRegion *mr;
44
audio_possible_drivers="coreaudio sdl"
45
45
# Disable attempts to use ObjectiveC features in os/object.h since they
46
- dev = qdev_create(NULL, "xlnx.zdma");
47
- s->lpd.iou.adma[i] = SYS_BUS_DEVICE(dev);
48
- object_property_set_int(OBJECT(s->lpd.iou.adma[i]), 128, "bus-width",
49
- &error_abort);
50
- object_property_add_child(OBJECT(s), name, OBJECT(dev), &error_fatal);
51
+ sysbus_init_child_obj(OBJECT(s), name,
52
+ &s->lpd.iou.adma[i], sizeof(s->lpd.iou.adma[i]),
53
+ TYPE_XLNX_ZDMA);
54
+ dev = DEVICE(&s->lpd.iou.adma[i]);
55
+ object_property_set_int(OBJECT(dev), 128, "bus-width", &error_abort);
56
qdev_init_nofail(dev);
57
58
- mr = sysbus_mmio_get_region(s->lpd.iou.adma[i], 0);
59
+ mr = sysbus_mmio_get_region(SYS_BUS_DEVICE(dev), 0);
60
memory_region_add_subregion(&s->mr_ps,
61
MM_ADMA_CH0 + i * MM_ADMA_CH0_SIZE, mr);
62
63
- sysbus_connect_irq(s->lpd.iou.adma[i], 0, pic[VERSAL_ADMA_IRQ_0 + i]);
64
+ sysbus_connect_irq(SYS_BUS_DEVICE(dev), 0, pic[VERSAL_ADMA_IRQ_0 + i]);
65
g_free(name);
66
}
67
}
68
--
46
--
69
2.20.1
47
2.20.1
70
48
71
49
diff view generated by jsdifflib
1
From: "Edgar E. Iglesias" <edgar.iglesias@xilinx.com>
1
From: Alexander Graf <agraf@csgraf.de>
2
2
3
Embed the GEMs into the SoC type.
3
In macOS 11, QEMU only gets access to Hypervisor.framework if it has the
4
respective entitlement. Add an entitlement template and automatically self
5
sign and apply the entitlement in the build.
4
6
5
Suggested-by: Peter Maydell <peter.maydell@linaro.org>
7
Signed-off-by: Alexander Graf <agraf@csgraf.de>
6
Signed-off-by: Edgar E. Iglesias <edgar.iglesias@xilinx.com>
8
Reviewed-by: Roman Bolshakov <r.bolshakov@yadro.com>
7
Reviewed-by: Alistair Francis <alistair.francis@wdc.com>
9
Tested-by: Roman Bolshakov <r.bolshakov@yadro.com>
8
Reviewed-by: Philippe Mathieu-Daudé <f4bug@amsat.org>
9
Reviewed-by: Luc Michel <luc.michel@greensocs.com>
10
Message-id: 20200427181649.26851-6-edgar.iglesias@gmail.com
11
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
10
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
12
---
11
---
13
include/hw/arm/xlnx-versal.h | 3 ++-
12
meson.build | 29 +++++++++++++++++++++++++----
14
hw/arm/xlnx-versal.c | 15 ++++++++-------
13
accel/hvf/entitlements.plist | 8 ++++++++
15
2 files changed, 10 insertions(+), 8 deletions(-)
14
scripts/entitlement.sh | 13 +++++++++++++
15
3 files changed, 46 insertions(+), 4 deletions(-)
16
create mode 100644 accel/hvf/entitlements.plist
17
create mode 100755 scripts/entitlement.sh
16
18
17
diff --git a/include/hw/arm/xlnx-versal.h b/include/hw/arm/xlnx-versal.h
19
diff --git a/meson.build b/meson.build
18
index XXXXXXX..XXXXXXX 100644
20
index XXXXXXX..XXXXXXX 100644
19
--- a/include/hw/arm/xlnx-versal.h
21
--- a/meson.build
20
+++ b/include/hw/arm/xlnx-versal.h
22
+++ b/meson.build
23
@@ -XXX,XX +XXX,XX @@ foreach target : target_dirs
24
}]
25
endif
26
foreach exe: execs
27
- emulators += {exe['name']:
28
- executable(exe['name'], exe['sources'],
29
- install: true,
30
+ exe_name = exe['name']
31
+ exe_sign = 'CONFIG_HVF' in config_target
32
+ if exe_sign
33
+ exe_name += '-unsigned'
34
+ endif
35
+
36
+ emulator = executable(exe_name, exe['sources'],
37
+ install: not exe_sign,
38
c_args: c_args,
39
dependencies: arch_deps + deps + exe['dependencies'],
40
objects: lib.extract_all_objects(recursive: true),
41
@@ -XXX,XX +XXX,XX @@ foreach target : target_dirs
42
link_depends: [block_syms, qemu_syms] + exe.get('link_depends', []),
43
link_args: link_args,
44
gui_app: exe['gui'])
45
- }
46
+
47
+ if exe_sign
48
+ emulators += {exe['name'] : custom_target(exe['name'],
49
+ install: true,
50
+ install_dir: get_option('bindir'),
51
+ depends: emulator,
52
+ output: exe['name'],
53
+ command: [
54
+ meson.current_source_dir() / 'scripts/entitlement.sh',
55
+ meson.current_build_dir() / exe_name,
56
+ meson.current_build_dir() / exe['name'],
57
+ meson.current_source_dir() / 'accel/hvf/entitlements.plist'
58
+ ])
59
+ }
60
+ else
61
+ emulators += {exe['name']: emulator}
62
+ endif
63
64
if 'CONFIG_TRACE_SYSTEMTAP' in config_host
65
foreach stp: [
66
diff --git a/accel/hvf/entitlements.plist b/accel/hvf/entitlements.plist
67
new file mode 100644
68
index XXXXXXX..XXXXXXX
69
--- /dev/null
70
+++ b/accel/hvf/entitlements.plist
21
@@ -XXX,XX +XXX,XX @@
71
@@ -XXX,XX +XXX,XX @@
22
#include "hw/arm/boot.h"
72
+<?xml version="1.0" encoding="UTF-8"?>
23
#include "hw/intc/arm_gicv3.h"
73
+<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
24
#include "hw/char/pl011.h"
74
+<plist version="1.0">
25
+#include "hw/net/cadence_gem.h"
75
+<dict>
26
76
+ <key>com.apple.security.hypervisor</key>
27
#define TYPE_XLNX_VERSAL "xlnx-versal"
77
+ <true/>
28
#define XLNX_VERSAL(obj) OBJECT_CHECK(Versal, (obj), TYPE_XLNX_VERSAL)
78
+</dict>
29
@@ -XXX,XX +XXX,XX @@ typedef struct Versal {
79
+</plist>
30
80
diff --git a/scripts/entitlement.sh b/scripts/entitlement.sh
31
struct {
81
new file mode 100755
32
PL011State uart[XLNX_VERSAL_NR_UARTS];
82
index XXXXXXX..XXXXXXX
33
- SysBusDevice *gem[XLNX_VERSAL_NR_GEMS];
83
--- /dev/null
34
+ CadenceGEMState gem[XLNX_VERSAL_NR_GEMS];
84
+++ b/scripts/entitlement.sh
35
SysBusDevice *adma[XLNX_VERSAL_NR_ADMAS];
85
@@ -XXX,XX +XXX,XX @@
36
} iou;
86
+#!/bin/sh -e
37
} lpd;
87
+#
38
diff --git a/hw/arm/xlnx-versal.c b/hw/arm/xlnx-versal.c
88
+# Helper script for the build process to apply entitlements
39
index XXXXXXX..XXXXXXX 100644
89
+
40
--- a/hw/arm/xlnx-versal.c
90
+SRC="$1"
41
+++ b/hw/arm/xlnx-versal.c
91
+DST="$2"
42
@@ -XXX,XX +XXX,XX @@ static void versal_create_gems(Versal *s, qemu_irq *pic)
92
+ENTITLEMENT="$3"
43
DeviceState *dev;
93
+
44
MemoryRegion *mr;
94
+trap 'rm "$DST.tmp"' exit
45
95
+cp -af "$SRC" "$DST.tmp"
46
- dev = qdev_create(NULL, "cadence_gem");
96
+codesign --entitlements "$ENTITLEMENT" --force -s - "$DST.tmp"
47
- s->lpd.iou.gem[i] = SYS_BUS_DEVICE(dev);
97
+mv "$DST.tmp" "$DST"
48
- object_property_add_child(OBJECT(s), name, OBJECT(dev), &error_fatal);
98
+trap '' exit
49
+ sysbus_init_child_obj(OBJECT(s), name,
50
+ &s->lpd.iou.gem[i], sizeof(s->lpd.iou.gem[i]),
51
+ TYPE_CADENCE_GEM);
52
+ dev = DEVICE(&s->lpd.iou.gem[i]);
53
if (nd->used) {
54
qemu_check_nic_model(nd, "cadence_gem");
55
qdev_set_nic_properties(dev, nd);
56
}
57
- object_property_set_int(OBJECT(s->lpd.iou.gem[i]),
58
+ object_property_set_int(OBJECT(dev),
59
2, "num-priority-queues",
60
&error_abort);
61
- object_property_set_link(OBJECT(s->lpd.iou.gem[i]),
62
+ object_property_set_link(OBJECT(dev),
63
OBJECT(&s->mr_ps), "dma",
64
&error_abort);
65
qdev_init_nofail(dev);
66
67
- mr = sysbus_mmio_get_region(s->lpd.iou.gem[i], 0);
68
+ mr = sysbus_mmio_get_region(SYS_BUS_DEVICE(dev), 0);
69
memory_region_add_subregion(&s->mr_ps, addrs[i], mr);
70
71
- sysbus_connect_irq(s->lpd.iou.gem[i], 0, pic[irqs[i]]);
72
+ sysbus_connect_irq(SYS_BUS_DEVICE(dev), 0, pic[irqs[i]]);
73
g_free(name);
74
}
75
}
76
--
99
--
77
2.20.1
100
2.20.1
78
101
79
102
diff view generated by jsdifflib
1
We define ARMMMUIdx_Stage2 as being an MMU index which uses a QEMU
1
From: Mihai Carabas <mihai.carabas@oracle.com>
2
TLB. However we never actually use the TLB -- all stage 2 lookups
2
3
are done by direct calls to get_phys_addr_lpae() followed by a
3
To ease the PCI device addition in next patches, split the code as follows:
4
physical address load via address_space_ld*().
4
- generic code (read/write/setup) is being kept in pvpanic.c
5
5
- ISA dependent code moved to pvpanic-isa.c
6
Remove Stage2 from the list of ARM MMU indexes which correspond to
6
7
real core MMU indexes, and instead put it in the set of "NOTLB" ARM
7
Also, rename:
8
MMU indexes.
8
- ISA_PVPANIC_DEVICE -> PVPANIC_ISA_DEVICE.
9
9
- TYPE_PVPANIC -> TYPE_PVPANIC_ISA.
10
This allows us to drop NB_MMU_MODES to 11. It also means we can
10
- MemoryRegion io -> mr.
11
safely add support for the ARMv8.3-TTS2UXN extension, which adds
11
- pvpanic_ioport_* in pvpanic_*.
12
permission bits to the stage 2 descriptors which define execute
12
13
permission separatel for EL0 and EL1; supporting that while keeping
13
Update the build system with the new files and config structure.
14
Stage2 in a QEMU TLB would require us to use separate TLBs for
14
15
"Stage2 for an EL0 access" and "Stage2 for an EL1 access", which is a
15
Signed-off-by: Mihai Carabas <mihai.carabas@oracle.com>
16
lot of extra complication given we aren't even using the QEMU TLB.
16
Reviewed-by: Peter Maydell <peter.maydell@linaro.org>
17
18
In the process of updating the comment on our MMU index use,
19
fix a couple of other minor errors:
20
* NS EL2 EL2&0 was missing from the list in the comment
21
* some text hadn't been updated from when we bumped NB_MMU_MODES
22
above 8
23
24
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
17
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
25
Reviewed-by: Edgar E. Iglesias <edgar.iglesias@xilinx.com>
26
Reviewed-by: Richard Henderson <richard.henderson@linaro.org>
27
Message-id: 20200330210400.11724-2-peter.maydell@linaro.org
28
---
18
---
29
target/arm/cpu-param.h | 2 +-
19
include/hw/misc/pvpanic.h | 23 +++++++++-
30
target/arm/cpu.h | 21 +++++---
20
hw/misc/pvpanic-isa.c | 94 +++++++++++++++++++++++++++++++++++++++
31
target/arm/helper.c | 112 ++++-------------------------------------
21
hw/misc/pvpanic.c | 85 +++--------------------------------
32
3 files changed, 27 insertions(+), 108 deletions(-)
22
hw/i386/Kconfig | 2 +-
33
23
hw/misc/Kconfig | 6 ++-
34
diff --git a/target/arm/cpu-param.h b/target/arm/cpu-param.h
24
hw/misc/meson.build | 3 +-
35
index XXXXXXX..XXXXXXX 100644
25
tests/qtest/meson.build | 2 +-
36
--- a/target/arm/cpu-param.h
26
7 files changed, 130 insertions(+), 85 deletions(-)
37
+++ b/target/arm/cpu-param.h
27
create mode 100644 hw/misc/pvpanic-isa.c
28
29
diff --git a/include/hw/misc/pvpanic.h b/include/hw/misc/pvpanic.h
30
index XXXXXXX..XXXXXXX 100644
31
--- a/include/hw/misc/pvpanic.h
32
+++ b/include/hw/misc/pvpanic.h
38
@@ -XXX,XX +XXX,XX @@
33
@@ -XXX,XX +XXX,XX @@
39
# define TARGET_PAGE_BITS_MIN 10
34
40
#endif
35
#include "qom/object.h"
41
36
42
-#define NB_MMU_MODES 12
37
-#define TYPE_PVPANIC "pvpanic"
43
+#define NB_MMU_MODES 11
38
+#define TYPE_PVPANIC_ISA_DEVICE "pvpanic"
44
39
45
#endif
40
#define PVPANIC_IOPORT_PROP "ioport"
46
diff --git a/target/arm/cpu.h b/target/arm/cpu.h
41
47
index XXXXXXX..XXXXXXX 100644
42
+/* The bit of supported pv event, TODO: include uapi header and remove this */
48
--- a/target/arm/cpu.h
43
+#define PVPANIC_F_PANICKED 0
49
+++ b/target/arm/cpu.h
44
+#define PVPANIC_F_CRASHLOADED 1
50
@@ -XXX,XX +XXX,XX @@ bool write_cpustate_to_list(ARMCPU *cpu, bool kvm_sync);
45
+
51
* handling via the TLB. The only way to do a stage 1 translation without
46
+/* The pv event value */
52
* the immediate stage 2 translation is via the ATS or AT system insns,
47
+#define PVPANIC_PANICKED (1 << PVPANIC_F_PANICKED)
53
* which can be slow-pathed and always do a page table walk.
48
+#define PVPANIC_CRASHLOADED (1 << PVPANIC_F_CRASHLOADED)
54
+ * The only use of stage 2 translations is either as part of an s1+2
49
+
55
+ * lookup or when loading the descriptors during a stage 1 page table walk,
50
+/*
56
+ * and in both those cases we don't use the TLB.
51
+ * PVPanicState for any device type
57
* 4. we can also safely fold together the "32 bit EL3" and "64 bit EL3"
52
+ */
58
* translation regimes, because they map reasonably well to each other
53
+typedef struct PVPanicState PVPanicState;
59
* and they can't both be active at the same time.
54
+struct PVPanicState {
60
@@ -XXX,XX +XXX,XX @@ bool write_cpustate_to_list(ARMCPU *cpu, bool kvm_sync);
55
+ MemoryRegion mr;
61
* NS EL1 EL1&0 stage 1+2 (aka NS PL1)
56
+ uint8_t events;
62
* NS EL1 EL1&0 stage 1+2 +PAN
57
+};
63
* NS EL0 EL2&0
58
+
64
+ * NS EL2 EL2&0
59
+void pvpanic_setup_io(PVPanicState *s, DeviceState *dev, unsigned size);
65
* NS EL2 EL2&0 +PAN
60
+
66
* NS EL2 (aka NS PL2)
61
static inline uint16_t pvpanic_port(void)
67
* S EL0 EL1&0 (aka S PL0)
62
{
68
* S EL1 EL1&0 (not used if EL3 is 32 bit)
63
- Object *o = object_resolve_path_type("", TYPE_PVPANIC, NULL);
69
* S EL1 EL1&0 +PAN
64
+ Object *o = object_resolve_path_type("", TYPE_PVPANIC_ISA_DEVICE, NULL);
70
* S EL3 (aka S PL1)
65
if (!o) {
71
- * NS EL1&0 stage 2
66
return 0;
72
*
67
}
73
- * for a total of 12 different mmu_idx.
68
diff --git a/hw/misc/pvpanic-isa.c b/hw/misc/pvpanic-isa.c
74
+ * for a total of 11 different mmu_idx.
69
new file mode 100644
75
*
70
index XXXXXXX..XXXXXXX
76
* R profile CPUs have an MPU, but can use the same set of MMU indexes
71
--- /dev/null
77
* as A profile. They only need to distinguish NS EL0 and NS EL1 (and
72
+++ b/hw/misc/pvpanic-isa.c
78
@@ -XXX,XX +XXX,XX @@ bool write_cpustate_to_list(ARMCPU *cpu, bool kvm_sync);
73
@@ -XXX,XX +XXX,XX @@
79
* are not quite the same -- different CPU types (most notably M profile
74
+/*
80
* vs A/R profile) would like to use MMU indexes with different semantics,
75
+ * QEMU simulated pvpanic device.
81
* but since we don't ever need to use all of those in a single CPU we
76
+ *
82
- * can avoid setting NB_MMU_MODES to more than 8. The lower bits of
77
+ * Copyright Fujitsu, Corp. 2013
83
+ * can avoid having to set NB_MMU_MODES to "total number of A profile MMU
78
+ *
84
+ * modes + total number of M profile MMU modes". The lower bits of
79
+ * Authors:
85
* ARMMMUIdx are the core TLB mmu index, and the higher bits are always
80
+ * Wen Congyang <wency@cn.fujitsu.com>
86
* the same for any particular CPU.
81
+ * Hu Tao <hutao@cn.fujitsu.com>
87
* Variables of type ARMMUIdx are always full values, and the core
82
+ *
88
@@ -XXX,XX +XXX,XX @@ typedef enum ARMMMUIdx {
83
+ * This work is licensed under the terms of the GNU GPL, version 2 or later.
89
ARMMMUIdx_SE10_1_PAN = 9 | ARM_MMU_IDX_A,
84
+ * See the COPYING file in the top-level directory.
90
ARMMMUIdx_SE3 = 10 | ARM_MMU_IDX_A,
85
+ *
91
86
+ */
92
- ARMMMUIdx_Stage2 = 11 | ARM_MMU_IDX_A,
87
+
93
-
88
+#include "qemu/osdep.h"
94
/*
89
+#include "qemu/log.h"
95
* These are not allocated TLBs and are used only for AT system
90
+#include "qemu/module.h"
96
* instructions or for the first stage of an S12 page table walk.
91
+#include "sysemu/runstate.h"
97
@@ -XXX,XX +XXX,XX @@ typedef enum ARMMMUIdx {
92
+
98
ARMMMUIdx_Stage1_E0 = 0 | ARM_MMU_IDX_NOTLB,
93
+#include "hw/nvram/fw_cfg.h"
99
ARMMMUIdx_Stage1_E1 = 1 | ARM_MMU_IDX_NOTLB,
94
+#include "hw/qdev-properties.h"
100
ARMMMUIdx_Stage1_E1_PAN = 2 | ARM_MMU_IDX_NOTLB,
95
+#include "hw/misc/pvpanic.h"
101
+ /*
96
+#include "qom/object.h"
102
+ * Not allocated a TLB: used only for second stage of an S12 page
97
+#include "hw/isa/isa.h"
103
+ * table walk, or for descriptor loads during first stage of an S1
98
+
104
+ * page table walk. Note that if we ever want to have a TLB for this
99
+OBJECT_DECLARE_SIMPLE_TYPE(PVPanicISAState, PVPANIC_ISA_DEVICE)
105
+ * then various TLB flush insns which currently are no-ops or flush
100
+
106
+ * only stage 1 MMU indexes will need to change to flush stage 2.
101
+/*
107
+ */
102
+ * PVPanicISAState for ISA device and
108
+ ARMMMUIdx_Stage2 = 3 | ARM_MMU_IDX_NOTLB,
103
+ * use ioport.
109
104
+ */
110
/*
105
+struct PVPanicISAState {
111
* M-profile.
106
+ ISADevice parent_obj;
112
@@ -XXX,XX +XXX,XX @@ typedef enum ARMMMUIdxBit {
107
+
113
TO_CORE_BIT(SE10_1),
108
+ uint16_t ioport;
114
TO_CORE_BIT(SE10_1_PAN),
109
+ PVPanicState pvpanic;
115
TO_CORE_BIT(SE3),
110
+};
116
- TO_CORE_BIT(Stage2),
111
+
117
112
+static void pvpanic_isa_initfn(Object *obj)
118
TO_CORE_BIT(MUser),
113
+{
119
TO_CORE_BIT(MPriv),
114
+ PVPanicISAState *s = PVPANIC_ISA_DEVICE(obj);
120
diff --git a/target/arm/helper.c b/target/arm/helper.c
115
+
121
index XXXXXXX..XXXXXXX 100644
116
+ pvpanic_setup_io(&s->pvpanic, DEVICE(s), 1);
122
--- a/target/arm/helper.c
117
+}
123
+++ b/target/arm/helper.c
118
+
124
@@ -XXX,XX +XXX,XX @@ static void tlbiall_nsnh_write(CPUARMState *env, const ARMCPRegInfo *ri,
119
+static void pvpanic_isa_realizefn(DeviceState *dev, Error **errp)
125
tlb_flush_by_mmuidx(cs,
120
+{
126
ARMMMUIdxBit_E10_1 |
121
+ ISADevice *d = ISA_DEVICE(dev);
127
ARMMMUIdxBit_E10_1_PAN |
122
+ PVPanicISAState *s = PVPANIC_ISA_DEVICE(dev);
128
- ARMMMUIdxBit_E10_0 |
123
+ PVPanicState *ps = &s->pvpanic;
129
- ARMMMUIdxBit_Stage2);
124
+ FWCfgState *fw_cfg = fw_cfg_find();
130
+ ARMMMUIdxBit_E10_0);
125
+ uint16_t *pvpanic_port;
126
+
127
+ if (!fw_cfg) {
128
+ return;
129
+ }
130
+
131
+ pvpanic_port = g_malloc(sizeof(*pvpanic_port));
132
+ *pvpanic_port = cpu_to_le16(s->ioport);
133
+ fw_cfg_add_file(fw_cfg, "etc/pvpanic-port", pvpanic_port,
134
+ sizeof(*pvpanic_port));
135
+
136
+ isa_register_ioport(d, &ps->mr, s->ioport);
137
+}
138
+
139
+static Property pvpanic_isa_properties[] = {
140
+ DEFINE_PROP_UINT16(PVPANIC_IOPORT_PROP, PVPanicISAState, ioport, 0x505),
141
+ DEFINE_PROP_UINT8("events", PVPanicISAState, pvpanic.events, PVPANIC_PANICKED | PVPANIC_CRASHLOADED),
142
+ DEFINE_PROP_END_OF_LIST(),
143
+};
144
+
145
+static void pvpanic_isa_class_init(ObjectClass *klass, void *data)
146
+{
147
+ DeviceClass *dc = DEVICE_CLASS(klass);
148
+
149
+ dc->realize = pvpanic_isa_realizefn;
150
+ device_class_set_props(dc, pvpanic_isa_properties);
151
+ set_bit(DEVICE_CATEGORY_MISC, dc->categories);
152
+}
153
+
154
+static TypeInfo pvpanic_isa_info = {
155
+ .name = TYPE_PVPANIC_ISA_DEVICE,
156
+ .parent = TYPE_ISA_DEVICE,
157
+ .instance_size = sizeof(PVPanicISAState),
158
+ .instance_init = pvpanic_isa_initfn,
159
+ .class_init = pvpanic_isa_class_init,
160
+};
161
+
162
+static void pvpanic_register_types(void)
163
+{
164
+ type_register_static(&pvpanic_isa_info);
165
+}
166
+
167
+type_init(pvpanic_register_types)
168
diff --git a/hw/misc/pvpanic.c b/hw/misc/pvpanic.c
169
index XXXXXXX..XXXXXXX 100644
170
--- a/hw/misc/pvpanic.c
171
+++ b/hw/misc/pvpanic.c
172
@@ -XXX,XX +XXX,XX @@
173
#include "hw/misc/pvpanic.h"
174
#include "qom/object.h"
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
}
131
}
193
}
132
194
133
static void tlbiall_nsnh_is_write(CPUARMState *env, const ARMCPRegInfo *ri,
195
-#include "hw/isa/isa.h"
134
@@ -XXX,XX +XXX,XX @@ static void tlbiall_nsnh_is_write(CPUARMState *env, const ARMCPRegInfo *ri,
196
-
135
tlb_flush_by_mmuidx_all_cpus_synced(cs,
197
-struct PVPanicState {
136
ARMMMUIdxBit_E10_1 |
198
- ISADevice parent_obj;
137
ARMMMUIdxBit_E10_1_PAN |
199
-
138
- ARMMMUIdxBit_E10_0 |
200
- MemoryRegion io;
139
- ARMMMUIdxBit_Stage2);
201
- uint16_t ioport;
140
+ ARMMMUIdxBit_E10_0);
202
- uint8_t events;
203
-};
204
-
205
/* return supported events on read */
206
-static uint64_t pvpanic_ioport_read(void *opaque, hwaddr addr, unsigned size)
207
+static uint64_t pvpanic_read(void *opaque, hwaddr addr, unsigned size)
208
{
209
PVPanicState *pvp = opaque;
210
return pvp->events;
141
}
211
}
142
212
143
-static void tlbiipas2_write(CPUARMState *env, const ARMCPRegInfo *ri,
213
-static void pvpanic_ioport_write(void *opaque, hwaddr addr, uint64_t val,
144
- uint64_t value)
214
+static void pvpanic_write(void *opaque, hwaddr addr, uint64_t val,
215
unsigned size)
216
{
217
handle_event(val);
218
}
219
220
static const MemoryRegionOps pvpanic_ops = {
221
- .read = pvpanic_ioport_read,
222
- .write = pvpanic_ioport_write,
223
+ .read = pvpanic_read,
224
+ .write = pvpanic_write,
225
.impl = {
226
.min_access_size = 1,
227
.max_access_size = 1,
228
},
229
};
230
231
-static void pvpanic_isa_initfn(Object *obj)
232
+void pvpanic_setup_io(PVPanicState *s, DeviceState *dev, unsigned size)
233
{
234
- PVPanicState *s = ISA_PVPANIC_DEVICE(obj);
235
-
236
- memory_region_init_io(&s->io, OBJECT(s), &pvpanic_ops, s, "pvpanic", 1);
237
+ memory_region_init_io(&s->mr, OBJECT(dev), &pvpanic_ops, s, "pvpanic", size);
238
}
239
-
240
-static void pvpanic_isa_realizefn(DeviceState *dev, Error **errp)
145
-{
241
-{
146
- /* Invalidate by IPA. This has to invalidate any structures that
242
- ISADevice *d = ISA_DEVICE(dev);
147
- * contain only stage 2 translation information, but does not need
243
- PVPanicState *s = ISA_PVPANIC_DEVICE(dev);
148
- * to apply to structures that contain combined stage 1 and stage 2
244
- FWCfgState *fw_cfg = fw_cfg_find();
149
- * translation information.
245
- uint16_t *pvpanic_port;
150
- * This must NOP if EL2 isn't implemented or SCR_EL3.NS is zero.
246
-
151
- */
247
- if (!fw_cfg) {
152
- CPUState *cs = env_cpu(env);
153
- uint64_t pageaddr;
154
-
155
- if (!arm_feature(env, ARM_FEATURE_EL2) || !(env->cp15.scr_el3 & SCR_NS)) {
156
- return;
248
- return;
157
- }
249
- }
158
-
250
-
159
- pageaddr = sextract64(value << 12, 0, 40);
251
- pvpanic_port = g_malloc(sizeof(*pvpanic_port));
160
-
252
- *pvpanic_port = cpu_to_le16(s->ioport);
161
- tlb_flush_page_by_mmuidx(cs, pageaddr, ARMMMUIdxBit_Stage2);
253
- fw_cfg_add_file(fw_cfg, "etc/pvpanic-port", pvpanic_port,
254
- sizeof(*pvpanic_port));
255
-
256
- isa_register_ioport(d, &s->io, s->ioport);
162
-}
257
-}
163
-
258
-
164
-static void tlbiipas2_is_write(CPUARMState *env, const ARMCPRegInfo *ri,
259
-static Property pvpanic_isa_properties[] = {
165
- uint64_t value)
260
- DEFINE_PROP_UINT16(PVPANIC_IOPORT_PROP, PVPanicState, ioport, 0x505),
261
- DEFINE_PROP_UINT8("events", PVPanicState, events, PVPANIC_PANICKED | PVPANIC_CRASHLOADED),
262
- DEFINE_PROP_END_OF_LIST(),
263
-};
264
-
265
-static void pvpanic_isa_class_init(ObjectClass *klass, void *data)
166
-{
266
-{
167
- CPUState *cs = env_cpu(env);
267
- DeviceClass *dc = DEVICE_CLASS(klass);
168
- uint64_t pageaddr;
268
-
169
-
269
- dc->realize = pvpanic_isa_realizefn;
170
- if (!arm_feature(env, ARM_FEATURE_EL2) || !(env->cp15.scr_el3 & SCR_NS)) {
270
- device_class_set_props(dc, pvpanic_isa_properties);
171
- return;
271
- set_bit(DEVICE_CATEGORY_MISC, dc->categories);
172
- }
173
-
174
- pageaddr = sextract64(value << 12, 0, 40);
175
-
176
- tlb_flush_page_by_mmuidx_all_cpus_synced(cs, pageaddr,
177
- ARMMMUIdxBit_Stage2);
178
-}
272
-}
179
273
-
180
static void tlbiall_hyp_write(CPUARMState *env, const ARMCPRegInfo *ri,
274
-static TypeInfo pvpanic_isa_info = {
181
uint64_t value)
275
- .name = TYPE_PVPANIC,
182
@@ -XXX,XX +XXX,XX @@ static void vttbr_write(CPUARMState *env, const ARMCPRegInfo *ri,
276
- .parent = TYPE_ISA_DEVICE,
183
tlb_flush_by_mmuidx(cs,
277
- .instance_size = sizeof(PVPanicState),
184
ARMMMUIdxBit_E10_1 |
278
- .instance_init = pvpanic_isa_initfn,
185
ARMMMUIdxBit_E10_1_PAN |
279
- .class_init = pvpanic_isa_class_init,
186
- ARMMMUIdxBit_E10_0 |
280
-};
187
- ARMMMUIdxBit_Stage2);
281
-
188
+ ARMMMUIdxBit_E10_0);
282
-static void pvpanic_register_types(void)
189
raw_write(env, ri, value);
190
}
191
}
192
@@ -XXX,XX +XXX,XX @@ static int alle1_tlbmask(CPUARMState *env)
193
return ARMMMUIdxBit_SE10_1 |
194
ARMMMUIdxBit_SE10_1_PAN |
195
ARMMMUIdxBit_SE10_0;
196
- } else if (arm_feature(env, ARM_FEATURE_EL2)) {
197
- return ARMMMUIdxBit_E10_1 |
198
- ARMMMUIdxBit_E10_1_PAN |
199
- ARMMMUIdxBit_E10_0 |
200
- ARMMMUIdxBit_Stage2;
201
} else {
202
return ARMMMUIdxBit_E10_1 |
203
ARMMMUIdxBit_E10_1_PAN |
204
@@ -XXX,XX +XXX,XX @@ static void tlbi_aa64_vae3is_write(CPUARMState *env, const ARMCPRegInfo *ri,
205
ARMMMUIdxBit_SE3);
206
}
207
208
-static void tlbi_aa64_ipas2e1_write(CPUARMState *env, const ARMCPRegInfo *ri,
209
- uint64_t value)
210
-{
283
-{
211
- /* Invalidate by IPA. This has to invalidate any structures that
284
- type_register_static(&pvpanic_isa_info);
212
- * contain only stage 2 translation information, but does not need
213
- * to apply to structures that contain combined stage 1 and stage 2
214
- * translation information.
215
- * This must NOP if EL2 isn't implemented or SCR_EL3.NS is zero.
216
- */
217
- ARMCPU *cpu = env_archcpu(env);
218
- CPUState *cs = CPU(cpu);
219
- uint64_t pageaddr;
220
-
221
- if (!arm_feature(env, ARM_FEATURE_EL2) || !(env->cp15.scr_el3 & SCR_NS)) {
222
- return;
223
- }
224
-
225
- pageaddr = sextract64(value << 12, 0, 48);
226
-
227
- tlb_flush_page_by_mmuidx(cs, pageaddr, ARMMMUIdxBit_Stage2);
228
-}
285
-}
229
-
286
-
230
-static void tlbi_aa64_ipas2e1is_write(CPUARMState *env, const ARMCPRegInfo *ri,
287
-type_init(pvpanic_register_types)
231
- uint64_t value)
288
diff --git a/hw/i386/Kconfig b/hw/i386/Kconfig
232
-{
289
index XXXXXXX..XXXXXXX 100644
233
- CPUState *cs = env_cpu(env);
290
--- a/hw/i386/Kconfig
234
- uint64_t pageaddr;
291
+++ b/hw/i386/Kconfig
235
-
292
@@ -XXX,XX +XXX,XX @@ config PC
236
- if (!arm_feature(env, ARM_FEATURE_EL2) || !(env->cp15.scr_el3 & SCR_NS)) {
293
imply ISA_DEBUG
237
- return;
294
imply PARALLEL
238
- }
295
imply PCI_DEVICES
239
-
296
- imply PVPANIC
240
- pageaddr = sextract64(value << 12, 0, 48);
297
+ imply PVPANIC_ISA
241
-
298
imply QXL
242
- tlb_flush_page_by_mmuidx_all_cpus_synced(cs, pageaddr,
299
imply SEV
243
- ARMMMUIdxBit_Stage2);
300
imply SGA
244
-}
301
diff --git a/hw/misc/Kconfig b/hw/misc/Kconfig
245
-
302
index XXXXXXX..XXXXXXX 100644
246
static CPAccessResult aa64_zva_access(CPUARMState *env, const ARMCPRegInfo *ri,
303
--- a/hw/misc/Kconfig
247
bool isread)
304
+++ b/hw/misc/Kconfig
248
{
305
@@ -XXX,XX +XXX,XX @@ config IOTKIT_SYSCTL
249
@@ -XXX,XX +XXX,XX @@ static const ARMCPRegInfo v8_cp_reginfo[] = {
306
config IOTKIT_SYSINFO
250
.writefn = tlbi_aa64_vae1_write },
307
bool
251
{ .name = "TLBI_IPAS2E1IS", .state = ARM_CP_STATE_AA64,
308
252
.opc0 = 1, .opc1 = 4, .crn = 8, .crm = 0, .opc2 = 1,
309
-config PVPANIC
253
- .access = PL2_W, .type = ARM_CP_NO_RAW,
310
+config PVPANIC_COMMON
254
- .writefn = tlbi_aa64_ipas2e1is_write },
311
+ bool
255
+ .access = PL2_W, .type = ARM_CP_NOP },
312
+
256
{ .name = "TLBI_IPAS2LE1IS", .state = ARM_CP_STATE_AA64,
313
+config PVPANIC_ISA
257
.opc0 = 1, .opc1 = 4, .crn = 8, .crm = 0, .opc2 = 5,
314
bool
258
- .access = PL2_W, .type = ARM_CP_NO_RAW,
315
depends on ISA_BUS
259
- .writefn = tlbi_aa64_ipas2e1is_write },
316
+ select PVPANIC_COMMON
260
+ .access = PL2_W, .type = ARM_CP_NOP },
317
261
{ .name = "TLBI_ALLE1IS", .state = ARM_CP_STATE_AA64,
318
config AUX
262
.opc0 = 1, .opc1 = 4, .crn = 8, .crm = 3, .opc2 = 4,
319
bool
263
.access = PL2_W, .type = ARM_CP_NO_RAW,
320
diff --git a/hw/misc/meson.build b/hw/misc/meson.build
264
@@ -XXX,XX +XXX,XX @@ static const ARMCPRegInfo v8_cp_reginfo[] = {
321
index XXXXXXX..XXXXXXX 100644
265
.writefn = tlbi_aa64_alle1is_write },
322
--- a/hw/misc/meson.build
266
{ .name = "TLBI_IPAS2E1", .state = ARM_CP_STATE_AA64,
323
+++ b/hw/misc/meson.build
267
.opc0 = 1, .opc1 = 4, .crn = 8, .crm = 4, .opc2 = 1,
324
@@ -XXX,XX +XXX,XX @@ softmmu_ss.add(when: 'CONFIG_EMC141X', if_true: files('emc141x.c'))
268
- .access = PL2_W, .type = ARM_CP_NO_RAW,
325
softmmu_ss.add(when: 'CONFIG_UNIMP', if_true: files('unimp.c'))
269
- .writefn = tlbi_aa64_ipas2e1_write },
326
softmmu_ss.add(when: 'CONFIG_EMPTY_SLOT', if_true: files('empty_slot.c'))
270
+ .access = PL2_W, .type = ARM_CP_NOP },
327
softmmu_ss.add(when: 'CONFIG_LED', if_true: files('led.c'))
271
{ .name = "TLBI_IPAS2LE1", .state = ARM_CP_STATE_AA64,
328
+softmmu_ss.add(when: 'CONFIG_PVPANIC_COMMON', if_true: files('pvpanic.c'))
272
.opc0 = 1, .opc1 = 4, .crn = 8, .crm = 4, .opc2 = 5,
329
273
- .access = PL2_W, .type = ARM_CP_NO_RAW,
330
# ARM devices
274
- .writefn = tlbi_aa64_ipas2e1_write },
331
softmmu_ss.add(when: 'CONFIG_PL310', if_true: files('arm_l2x0.c'))
275
+ .access = PL2_W, .type = ARM_CP_NOP },
332
@@ -XXX,XX +XXX,XX @@ softmmu_ss.add(when: 'CONFIG_IOTKIT_SYSINFO', if_true: files('iotkit-sysinfo.c')
276
{ .name = "TLBI_ALLE1", .state = ARM_CP_STATE_AA64,
333
softmmu_ss.add(when: 'CONFIG_ARMSSE_CPUID', if_true: files('armsse-cpuid.c'))
277
.opc0 = 1, .opc1 = 4, .crn = 8, .crm = 7, .opc2 = 4,
334
softmmu_ss.add(when: 'CONFIG_ARMSSE_MHU', if_true: files('armsse-mhu.c'))
278
.access = PL2_W, .type = ARM_CP_NO_RAW,
335
279
@@ -XXX,XX +XXX,XX @@ static const ARMCPRegInfo v8_cp_reginfo[] = {
336
-softmmu_ss.add(when: 'CONFIG_PVPANIC', if_true: files('pvpanic.c'))
280
.writefn = tlbimva_hyp_is_write },
337
+softmmu_ss.add(when: 'CONFIG_PVPANIC_ISA', if_true: files('pvpanic-isa.c'))
281
{ .name = "TLBIIPAS2",
338
softmmu_ss.add(when: 'CONFIG_AUX', if_true: files('auxbus.c'))
282
.cp = 15, .opc1 = 4, .crn = 8, .crm = 4, .opc2 = 1,
339
softmmu_ss.add(when: 'CONFIG_ASPEED_SOC', if_true: files('aspeed_scu.c', 'aspeed_sdmc.c', 'aspeed_xdma.c'))
283
- .type = ARM_CP_NO_RAW, .access = PL2_W,
340
softmmu_ss.add(when: 'CONFIG_MSF2', if_true: files('msf2-sysreg.c'))
284
- .writefn = tlbiipas2_write },
341
diff --git a/tests/qtest/meson.build b/tests/qtest/meson.build
285
+ .type = ARM_CP_NOP, .access = PL2_W },
342
index XXXXXXX..XXXXXXX 100644
286
{ .name = "TLBIIPAS2IS",
343
--- a/tests/qtest/meson.build
287
.cp = 15, .opc1 = 4, .crn = 8, .crm = 0, .opc2 = 1,
344
+++ b/tests/qtest/meson.build
288
- .type = ARM_CP_NO_RAW, .access = PL2_W,
345
@@ -XXX,XX +XXX,XX @@ qtests_i386 = \
289
- .writefn = tlbiipas2_is_write },
346
(config_host.has_key('CONFIG_LINUX') and \
290
+ .type = ARM_CP_NOP, .access = PL2_W },
347
config_all_devices.has_key('CONFIG_ISA_IPMI_BT') ? ['ipmi-bt-test'] : []) + \
291
{ .name = "TLBIIPAS2L",
348
(config_all_devices.has_key('CONFIG_WDT_IB700') ? ['wdt_ib700-test'] : []) + \
292
.cp = 15, .opc1 = 4, .crn = 8, .crm = 4, .opc2 = 5,
349
- (config_all_devices.has_key('CONFIG_PVPANIC') ? ['pvpanic-test'] : []) + \
293
- .type = ARM_CP_NO_RAW, .access = PL2_W,
350
+ (config_all_devices.has_key('CONFIG_PVPANIC_ISA') ? ['pvpanic-test'] : []) + \
294
- .writefn = tlbiipas2_write },
351
(config_all_devices.has_key('CONFIG_HDA') ? ['intel-hda-test'] : []) + \
295
+ .type = ARM_CP_NOP, .access = PL2_W },
352
(config_all_devices.has_key('CONFIG_I82801B11') ? ['i82801b11-test'] : []) + \
296
{ .name = "TLBIIPAS2LIS",
353
(config_all_devices.has_key('CONFIG_IOH3420') ? ['ioh3420-test'] : []) + \
297
.cp = 15, .opc1 = 4, .crn = 8, .crm = 0, .opc2 = 5,
298
- .type = ARM_CP_NO_RAW, .access = PL2_W,
299
- .writefn = tlbiipas2_is_write },
300
+ .type = ARM_CP_NOP, .access = PL2_W },
301
/* 32 bit cache operations */
302
{ .name = "ICIALLUIS", .cp = 15, .opc1 = 0, .crn = 7, .crm = 1, .opc2 = 0,
303
.type = ARM_CP_NOP, .access = PL1_W, .accessfn = aa64_cacheop_pou_access },
304
--
354
--
305
2.20.1
355
2.20.1
306
356
307
357
diff view generated by jsdifflib
1
From: "Edgar E. Iglesias" <edgar.iglesias@xilinx.com>
1
From: Mihai Carabas <mihai.carabas@oracle.com>
2
2
3
Embed the UARTs into the SoC type.
3
Add PCI interface support for PVPANIC device. Create a new file pvpanic-pci.c
4
where the PCI specific routines reside and update the build system with the new
5
files and config structure.
4
6
5
Suggested-by: Peter Maydell <peter.maydell@linaro.org>
7
Signed-off-by: Mihai Carabas <mihai.carabas@oracle.com>
6
Signed-off-by: Edgar E. Iglesias <edgar.iglesias@xilinx.com>
8
Reviewed-by: Gerd Hoffmann <kraxel@redhat.com>
7
Reviewed-by: Alistair Francis <alistair.francis@wdc.com>
9
Reviewed-by: Peter Maydell <peter.maydell@linaro.org>
8
Reviewed-by: Philippe Mathieu-Daudé <f4bug@amsat.org>
10
Signed-off-by: Mihai Carabas <mihai.carabas@oracle.com>
9
Reviewed-by: Luc Michel <luc.michel@greensocs.com>
10
Message-id: 20200427181649.26851-5-edgar.iglesias@gmail.com
11
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
11
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
12
---
12
---
13
include/hw/arm/xlnx-versal.h | 3 ++-
13
docs/specs/pci-ids.txt | 1 +
14
hw/arm/xlnx-versal.c | 12 ++++++------
14
include/hw/misc/pvpanic.h | 1 +
15
2 files changed, 8 insertions(+), 7 deletions(-)
15
include/hw/pci/pci.h | 1 +
16
hw/misc/pvpanic-pci.c | 94 +++++++++++++++++++++++++++++++++++++++
17
hw/misc/Kconfig | 6 +++
18
hw/misc/meson.build | 1 +
19
6 files changed, 104 insertions(+)
20
create mode 100644 hw/misc/pvpanic-pci.c
16
21
17
diff --git a/include/hw/arm/xlnx-versal.h b/include/hw/arm/xlnx-versal.h
22
diff --git a/docs/specs/pci-ids.txt b/docs/specs/pci-ids.txt
18
index XXXXXXX..XXXXXXX 100644
23
index XXXXXXX..XXXXXXX 100644
19
--- a/include/hw/arm/xlnx-versal.h
24
--- a/docs/specs/pci-ids.txt
20
+++ b/include/hw/arm/xlnx-versal.h
25
+++ b/docs/specs/pci-ids.txt
26
@@ -XXX,XX +XXX,XX @@ PCI devices (other than virtio):
27
1b36:000d PCI xhci usb host adapter
28
1b36:000f mdpy (mdev sample device), linux/samples/vfio-mdev/mdpy.c
29
1b36:0010 PCIe NVMe device (-device nvme)
30
+1b36:0011 PCI PVPanic device (-device pvpanic-pci)
31
32
All these devices are documented in docs/specs.
33
34
diff --git a/include/hw/misc/pvpanic.h b/include/hw/misc/pvpanic.h
35
index XXXXXXX..XXXXXXX 100644
36
--- a/include/hw/misc/pvpanic.h
37
+++ b/include/hw/misc/pvpanic.h
21
@@ -XXX,XX +XXX,XX @@
38
@@ -XXX,XX +XXX,XX @@
22
#include "hw/sysbus.h"
39
#include "qom/object.h"
23
#include "hw/arm/boot.h"
40
24
#include "hw/intc/arm_gicv3.h"
41
#define TYPE_PVPANIC_ISA_DEVICE "pvpanic"
25
+#include "hw/char/pl011.h"
42
+#define TYPE_PVPANIC_PCI_DEVICE "pvpanic-pci"
26
43
27
#define TYPE_XLNX_VERSAL "xlnx-versal"
44
#define PVPANIC_IOPORT_PROP "ioport"
28
#define XLNX_VERSAL(obj) OBJECT_CHECK(Versal, (obj), TYPE_XLNX_VERSAL)
45
29
@@ -XXX,XX +XXX,XX @@ typedef struct Versal {
46
diff --git a/include/hw/pci/pci.h b/include/hw/pci/pci.h
30
MemoryRegion mr_ocm;
31
32
struct {
33
- SysBusDevice *uart[XLNX_VERSAL_NR_UARTS];
34
+ PL011State uart[XLNX_VERSAL_NR_UARTS];
35
SysBusDevice *gem[XLNX_VERSAL_NR_GEMS];
36
SysBusDevice *adma[XLNX_VERSAL_NR_ADMAS];
37
} iou;
38
diff --git a/hw/arm/xlnx-versal.c b/hw/arm/xlnx-versal.c
39
index XXXXXXX..XXXXXXX 100644
47
index XXXXXXX..XXXXXXX 100644
40
--- a/hw/arm/xlnx-versal.c
48
--- a/include/hw/pci/pci.h
41
+++ b/hw/arm/xlnx-versal.c
49
+++ b/include/hw/pci/pci.h
50
@@ -XXX,XX +XXX,XX @@ extern bool pci_available;
51
#define PCI_DEVICE_ID_REDHAT_PCIE_BRIDGE 0x000e
52
#define PCI_DEVICE_ID_REDHAT_MDPY 0x000f
53
#define PCI_DEVICE_ID_REDHAT_NVME 0x0010
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
42
@@ -XXX,XX +XXX,XX @@
63
@@ -XXX,XX +XXX,XX @@
43
#include "kvm_arm.h"
64
+/*
44
#include "hw/misc/unimp.h"
65
+ * QEMU simulated PCI pvpanic device.
45
#include "hw/arm/xlnx-versal.h"
66
+ *
46
-#include "hw/char/pl011.h"
67
+ * Copyright (C) 2020 Oracle
47
68
+ *
48
#define XLNX_VERSAL_ACPU_TYPE ARM_CPU_TYPE_NAME("cortex-a72")
69
+ * Authors:
49
#define GEM_REVISION 0x40070106
70
+ * Mihai Carabas <mihai.carabas@oracle.com>
50
@@ -XXX,XX +XXX,XX @@ static void versal_create_uarts(Versal *s, qemu_irq *pic)
71
+ *
51
DeviceState *dev;
72
+ * This work is licensed under the terms of the GNU GPL, version 2 or later.
52
MemoryRegion *mr;
73
+ * See the COPYING file in the top-level directory.
53
74
+ *
54
- dev = qdev_create(NULL, TYPE_PL011);
75
+ */
55
- s->lpd.iou.uart[i] = SYS_BUS_DEVICE(dev);
76
+
56
+ sysbus_init_child_obj(OBJECT(s), name,
77
+#include "qemu/osdep.h"
57
+ &s->lpd.iou.uart[i], sizeof(s->lpd.iou.uart[i]),
78
+#include "qemu/log.h"
58
+ TYPE_PL011);
79
+#include "qemu/module.h"
59
+ dev = DEVICE(&s->lpd.iou.uart[i]);
80
+#include "sysemu/runstate.h"
60
qdev_prop_set_chr(dev, "chardev", serial_hd(i));
81
+
61
- object_property_add_child(OBJECT(s), name, OBJECT(dev), &error_fatal);
82
+#include "hw/nvram/fw_cfg.h"
62
qdev_init_nofail(dev);
83
+#include "hw/qdev-properties.h"
63
84
+#include "migration/vmstate.h"
64
- mr = sysbus_mmio_get_region(s->lpd.iou.uart[i], 0);
85
+#include "hw/misc/pvpanic.h"
65
+ mr = sysbus_mmio_get_region(SYS_BUS_DEVICE(dev), 0);
86
+#include "qom/object.h"
66
memory_region_add_subregion(&s->mr_ps, addrs[i], mr);
87
+#include "hw/pci/pci.h"
67
88
+
68
- sysbus_connect_irq(s->lpd.iou.uart[i], 0, pic[irqs[i]]);
89
+OBJECT_DECLARE_SIMPLE_TYPE(PVPanicPCIState, PVPANIC_PCI_DEVICE)
69
+ sysbus_connect_irq(SYS_BUS_DEVICE(dev), 0, pic[irqs[i]]);
90
+
70
g_free(name);
91
+/*
71
}
92
+ * PVPanicPCIState for PCI device
72
}
93
+ */
94
+typedef struct PVPanicPCIState {
95
+ PCIDevice dev;
96
+ PVPanicState pvpanic;
97
+} PVPanicPCIState;
98
+
99
+static const VMStateDescription vmstate_pvpanic_pci = {
100
+ .name = "pvpanic-pci",
101
+ .version_id = 1,
102
+ .minimum_version_id = 1,
103
+ .fields = (VMStateField[]) {
104
+ VMSTATE_PCI_DEVICE(dev, PVPanicPCIState),
105
+ VMSTATE_END_OF_LIST()
106
+ }
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
+}
118
+
119
+static Property pvpanic_pci_properties[] = {
120
+ DEFINE_PROP_UINT8("events", PVPanicPCIState, pvpanic.events, PVPANIC_PANICKED | PVPANIC_CRASHLOADED),
121
+ DEFINE_PROP_END_OF_LIST(),
122
+};
123
+
124
+static void pvpanic_pci_class_init(ObjectClass *klass, void *data)
125
+{
126
+ DeviceClass *dc = DEVICE_CLASS(klass);
127
+ PCIDeviceClass *pc = PCI_DEVICE_CLASS(klass);
128
+
129
+ device_class_set_props(dc, pvpanic_pci_properties);
130
+
131
+ pc->realize = pvpanic_pci_realizefn;
132
+ pc->vendor_id = PCI_VENDOR_ID_REDHAT;
133
+ pc->device_id = PCI_DEVICE_ID_REDHAT_PVPANIC;
134
+ pc->revision = 1;
135
+ pc->class_id = PCI_CLASS_SYSTEM_OTHER;
136
+ dc->vmsd = &vmstate_pvpanic_pci;
137
+
138
+ set_bit(DEVICE_CATEGORY_MISC, dc->categories);
139
+}
140
+
141
+static TypeInfo pvpanic_pci_info = {
142
+ .name = TYPE_PVPANIC_PCI_DEVICE,
143
+ .parent = TYPE_PCI_DEVICE,
144
+ .instance_size = sizeof(PVPanicPCIState),
145
+ .class_init = pvpanic_pci_class_init,
146
+ .interfaces = (InterfaceInfo[]) {
147
+ { INTERFACE_CONVENTIONAL_PCI_DEVICE },
148
+ { }
149
+ }
150
+};
151
+
152
+static void pvpanic_register_types(void)
153
+{
154
+ type_register_static(&pvpanic_pci_info);
155
+}
156
+
157
+type_init(pvpanic_register_types);
158
diff --git a/hw/misc/Kconfig b/hw/misc/Kconfig
159
index XXXXXXX..XXXXXXX 100644
160
--- a/hw/misc/Kconfig
161
+++ b/hw/misc/Kconfig
162
@@ -XXX,XX +XXX,XX @@ config IOTKIT_SYSINFO
163
config PVPANIC_COMMON
164
bool
165
166
+config PVPANIC_PCI
167
+ bool
168
+ default y if PCI_DEVICES
169
+ depends on PCI
170
+ select PVPANIC_COMMON
171
+
172
config PVPANIC_ISA
173
bool
174
depends on ISA_BUS
175
diff --git a/hw/misc/meson.build b/hw/misc/meson.build
176
index XXXXXXX..XXXXXXX 100644
177
--- a/hw/misc/meson.build
178
+++ b/hw/misc/meson.build
179
@@ -XXX,XX +XXX,XX @@ softmmu_ss.add(when: 'CONFIG_ARMSSE_CPUID', if_true: files('armsse-cpuid.c'))
180
softmmu_ss.add(when: 'CONFIG_ARMSSE_MHU', if_true: files('armsse-mhu.c'))
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'))
73
--
187
--
74
2.20.1
188
2.20.1
75
189
76
190
diff view generated by jsdifflib
1
From: "Edgar E. Iglesias" <edgar.iglesias@xilinx.com>
1
From: Mihai Carabas <mihai.carabas@oracle.com>
2
2
3
Remove inclusion of arm_gicv3_common.h, this already gets
3
Add pvpanic PCI device support details in docs/specs/pvpanic.txt.
4
included via xlnx-versal.h.
5
4
6
Signed-off-by: Edgar E. Iglesias <edgar.iglesias@xilinx.com>
5
Signed-off-by: Mihai Carabas <mihai.carabas@oracle.com>
7
Reviewed-by: Alistair Francis <alistair.francis@wdc.com>
6
Reviewed-by: Peter Maydell <peter.maydell@linaro.org>
8
Reviewed-by: Luc Michel <luc.michel@greensocs.com>
9
Message-id: 20200427181649.26851-2-edgar.iglesias@gmail.com
10
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
7
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
11
---
8
---
12
hw/arm/xlnx-versal.c | 1 -
9
docs/specs/pvpanic.txt | 13 ++++++++++++-
13
1 file changed, 1 deletion(-)
10
1 file changed, 12 insertions(+), 1 deletion(-)
14
11
15
diff --git a/hw/arm/xlnx-versal.c b/hw/arm/xlnx-versal.c
12
diff --git a/docs/specs/pvpanic.txt b/docs/specs/pvpanic.txt
16
index XXXXXXX..XXXXXXX 100644
13
index XXXXXXX..XXXXXXX 100644
17
--- a/hw/arm/xlnx-versal.c
14
--- a/docs/specs/pvpanic.txt
18
+++ b/hw/arm/xlnx-versal.c
15
+++ b/docs/specs/pvpanic.txt
19
@@ -XXX,XX +XXX,XX @@
16
@@ -XXX,XX +XXX,XX @@
20
#include "hw/arm/boot.h"
17
PVPANIC DEVICE
21
#include "kvm_arm.h"
18
==============
22
#include "hw/misc/unimp.h"
19
23
-#include "hw/intc/arm_gicv3_common.h"
20
-pvpanic device is a simulated ISA device, through which a guest panic
24
#include "hw/arm/xlnx-versal.h"
21
+pvpanic device is a simulated device, through which a guest panic
25
#include "hw/char/pl011.h"
22
event is sent to qemu, and a QMP event is generated. This allows
23
management apps (e.g. libvirt) to be notified and respond to the event.
24
25
@@ -XXX,XX +XXX,XX @@ The management app has the option of waiting for GUEST_PANICKED events,
26
and/or polling for guest-panicked RunState, to learn when the pvpanic
27
device has fired a panic event.
28
29
+The pvpanic device can be implemented as an ISA device (using IOPORT) or as a
30
+PCI device.
31
+
32
ISA Interface
33
-------------
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
--------------
26
49
27
--
50
--
28
2.20.1
51
2.20.1
29
52
30
53
diff view generated by jsdifflib
1
Convert the Neon VMUL, VMLA, VMLS and VSHL insns in the
1
From: Mihai Carabas <mihai.carabas@oracle.com>
2
3-reg-same grouping to decodetree.
3
2
3
Add a test case for pvpanic-pci device. The scenario is the same as pvpanic
4
ISA device, but is using the PCI bus.
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>
9
Signed-off-by: Mihai Carabas <mihai.carabas@oracle.com>
4
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
10
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
5
Reviewed-by: Richard Henderson <richard.henderson@linaro.org>
6
Message-id: 20200430181003.21682-20-peter.maydell@linaro.org
7
---
11
---
8
target/arm/neon-dp.decode | 9 +++++++
12
tests/qtest/pvpanic-pci-test.c | 94 ++++++++++++++++++++++++++++++++++
9
target/arm/translate-neon.inc.c | 44 +++++++++++++++++++++++++++++++++
13
tests/qtest/meson.build | 1 +
10
target/arm/translate.c | 28 +++------------------
14
2 files changed, 95 insertions(+)
11
3 files changed, 56 insertions(+), 25 deletions(-)
15
create mode 100644 tests/qtest/pvpanic-pci-test.c
12
16
13
diff --git a/target/arm/neon-dp.decode b/target/arm/neon-dp.decode
17
diff --git a/tests/qtest/pvpanic-pci-test.c b/tests/qtest/pvpanic-pci-test.c
14
index XXXXXXX..XXXXXXX 100644
18
new file mode 100644
15
--- a/target/arm/neon-dp.decode
19
index XXXXXXX..XXXXXXX
16
+++ b/target/arm/neon-dp.decode
20
--- /dev/null
17
@@ -XXX,XX +XXX,XX @@ VCGT_U_3s 1111 001 1 0 . .. .... .... 0011 . . . 0 .... @3same
21
+++ b/tests/qtest/pvpanic-pci-test.c
18
VCGE_S_3s 1111 001 0 0 . .. .... .... 0011 . . . 1 .... @3same
22
@@ -XXX,XX +XXX,XX @@
19
VCGE_U_3s 1111 001 1 0 . .. .... .... 0011 . . . 1 .... @3same
23
+/*
20
24
+ * QTest testcase for PV Panic PCI device
21
+VSHL_S_3s 1111 001 0 0 . .. .... .... 0100 . . . 0 .... @3same
25
+ *
22
+VSHL_U_3s 1111 001 1 0 . .. .... .... 0100 . . . 0 .... @3same
26
+ * Copyright (C) 2020 Oracle
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
+ */
23
+
35
+
24
VMAX_S_3s 1111 001 0 0 . .. .... .... 0110 . . . 0 .... @3same
36
+#include "qemu/osdep.h"
25
VMAX_U_3s 1111 001 1 0 . .. .... .... 0110 . . . 0 .... @3same
37
+#include "libqos/libqtest.h"
26
VMIN_S_3s 1111 001 0 0 . .. .... .... 0110 . . . 1 .... @3same
38
+#include "qapi/qmp/qdict.h"
27
@@ -XXX,XX +XXX,XX @@ VSUB_3s 1111 001 1 0 . .. .... .... 1000 . . . 0 .... @3same
39
+#include "libqos/pci.h"
28
40
+#include "libqos/pci-pc.h"
29
VTST_3s 1111 001 0 0 . .. .... .... 1000 . . . 1 .... @3same
41
+#include "hw/pci/pci_regs.h"
30
VCEQ_3s 1111 001 1 0 . .. .... .... 1000 . . . 1 .... @3same
31
+
42
+
32
+VMLA_3s 1111 001 0 0 . .. .... .... 1001 . . . 0 .... @3same
43
+static void test_panic_nopause(void)
33
+VMLS_3s 1111 001 1 0 . .. .... .... 1001 . . . 0 .... @3same
44
+{
45
+ uint8_t val;
46
+ QDict *response, *data;
47
+ QTestState *qts;
48
+ QPCIBus *pcibus;
49
+ QPCIDevice *dev;
50
+ QPCIBar bar;
34
+
51
+
35
+VMUL_3s 1111 001 0 0 . .. .... .... 1001 . . . 1 .... @3same
52
+ qts = qtest_init("-device pvpanic-pci,addr=04.0 -action panic=none");
36
+VMUL_p_3s 1111 001 1 0 . .. .... .... 1001 . . . 1 .... @3same
53
+ pcibus = qpci_new_pc(qts, NULL);
37
diff --git a/target/arm/translate-neon.inc.c b/target/arm/translate-neon.inc.c
54
+ dev = qpci_device_find(pcibus, QPCI_DEVFN(0x4, 0x0));
38
index XXXXXXX..XXXXXXX 100644
55
+ qpci_device_enable(dev);
39
--- a/target/arm/translate-neon.inc.c
56
+ bar = qpci_iomap(dev, 0, NULL);
40
+++ b/target/arm/translate-neon.inc.c
41
@@ -XXX,XX +XXX,XX @@ DO_3SAME_NO_SZ_3(VMAX_S, tcg_gen_gvec_smax)
42
DO_3SAME_NO_SZ_3(VMAX_U, tcg_gen_gvec_umax)
43
DO_3SAME_NO_SZ_3(VMIN_S, tcg_gen_gvec_smin)
44
DO_3SAME_NO_SZ_3(VMIN_U, tcg_gen_gvec_umin)
45
+DO_3SAME_NO_SZ_3(VMUL, tcg_gen_gvec_mul)
46
47
#define DO_3SAME_CMP(INSN, COND) \
48
static void gen_##INSN##_3s(unsigned vece, uint32_t rd_ofs, \
49
@@ -XXX,XX +XXX,XX @@ DO_3SAME_GVEC4(VQADD_S, sqadd_op)
50
DO_3SAME_GVEC4(VQADD_U, uqadd_op)
51
DO_3SAME_GVEC4(VQSUB_S, sqsub_op)
52
DO_3SAME_GVEC4(VQSUB_U, uqsub_op)
53
+
57
+
54
+static void gen_VMUL_p_3s(unsigned vece, uint32_t rd_ofs, uint32_t rn_ofs,
58
+ qpci_memread(dev, bar, 0, &val, sizeof(val));
55
+ uint32_t rm_ofs, uint32_t oprsz, uint32_t maxsz)
59
+ g_assert_cmpuint(val, ==, 3);
56
+{
60
+
57
+ tcg_gen_gvec_3_ool(rd_ofs, rn_ofs, rm_ofs, oprsz, maxsz,
61
+ val = 1;
58
+ 0, gen_helper_gvec_pmul_b);
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);
59
+}
72
+}
60
+
73
+
61
+static bool trans_VMUL_p_3s(DisasContext *s, arg_3same *a)
74
+static void test_panic(void)
62
+{
75
+{
63
+ if (a->size != 0) {
76
+ uint8_t val;
64
+ return false;
77
+ QDict *response, *data;
65
+ }
78
+ QTestState *qts;
66
+ return do_3same(s, a, gen_VMUL_p_3s);
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);
67
+}
103
+}
68
+
104
+
69
+#define DO_3SAME_GVEC3_NO_SZ_3(INSN, OPARRAY) \
105
+int main(int argc, char **argv)
70
+ static void gen_##INSN##_3s(unsigned vece, uint32_t rd_ofs, \
106
+{
71
+ uint32_t rn_ofs, uint32_t rm_ofs, \
107
+ int ret;
72
+ uint32_t oprsz, uint32_t maxsz) \
73
+ { \
74
+ tcg_gen_gvec_3(rd_ofs, rn_ofs, rm_ofs, \
75
+ oprsz, maxsz, &OPARRAY[vece]); \
76
+ } \
77
+ DO_3SAME_NO_SZ_3(INSN, gen_##INSN##_3s)
78
+
108
+
109
+ g_test_init(&argc, &argv, NULL);
110
+ qtest_add_func("/pvpanic-pci/panic", test_panic);
111
+ qtest_add_func("/pvpanic-pci/panic-nopause", test_panic_nopause);
79
+
112
+
80
+DO_3SAME_GVEC3_NO_SZ_3(VMLA, mla_op)
113
+ ret = g_test_run();
81
+DO_3SAME_GVEC3_NO_SZ_3(VMLS, mls_op)
82
+
114
+
83
+#define DO_3SAME_GVEC3_SHIFT(INSN, OPARRAY) \
115
+ return ret;
84
+ static void gen_##INSN##_3s(unsigned vece, uint32_t rd_ofs, \
116
+}
85
+ uint32_t rn_ofs, uint32_t rm_ofs, \
117
diff --git a/tests/qtest/meson.build b/tests/qtest/meson.build
86
+ uint32_t oprsz, uint32_t maxsz) \
87
+ { \
88
+ /* Note the operation is vshl vd,vm,vn */ \
89
+ tcg_gen_gvec_3(rd_ofs, rm_ofs, rn_ofs, \
90
+ oprsz, maxsz, &OPARRAY[vece]); \
91
+ } \
92
+ DO_3SAME(INSN, gen_##INSN##_3s)
93
+
94
+DO_3SAME_GVEC3_SHIFT(VSHL_S, sshl_op)
95
+DO_3SAME_GVEC3_SHIFT(VSHL_U, ushl_op)
96
diff --git a/target/arm/translate.c b/target/arm/translate.c
97
index XXXXXXX..XXXXXXX 100644
118
index XXXXXXX..XXXXXXX 100644
98
--- a/target/arm/translate.c
119
--- a/tests/qtest/meson.build
99
+++ b/target/arm/translate.c
120
+++ b/tests/qtest/meson.build
100
@@ -XXX,XX +XXX,XX @@ static int disas_neon_data_insn(DisasContext *s, uint32_t insn)
121
@@ -XXX,XX +XXX,XX @@ qtests_i386 = \
101
}
122
config_all_devices.has_key('CONFIG_ISA_IPMI_BT') ? ['ipmi-bt-test'] : []) + \
102
return 1;
123
(config_all_devices.has_key('CONFIG_WDT_IB700') ? ['wdt_ib700-test'] : []) + \
103
124
(config_all_devices.has_key('CONFIG_PVPANIC_ISA') ? ['pvpanic-test'] : []) + \
104
- case NEON_3R_VMUL: /* VMUL */
125
+ (config_all_devices.has_key('CONFIG_PVPANIC_PCI') ? ['pvpanic-pci-test'] : []) + \
105
- if (u) {
126
(config_all_devices.has_key('CONFIG_HDA') ? ['intel-hda-test'] : []) + \
106
- /* Polynomial case allows only P8. */
127
(config_all_devices.has_key('CONFIG_I82801B11') ? ['i82801b11-test'] : []) + \
107
- if (size != 0) {
128
(config_all_devices.has_key('CONFIG_IOH3420') ? ['ioh3420-test'] : []) + \
108
- return 1;
109
- }
110
- tcg_gen_gvec_3_ool(rd_ofs, rn_ofs, rm_ofs, vec_size, vec_size,
111
- 0, gen_helper_gvec_pmul_b);
112
- } else {
113
- tcg_gen_gvec_mul(size, rd_ofs, rn_ofs, rm_ofs,
114
- vec_size, vec_size);
115
- }
116
- return 0;
117
-
118
- case NEON_3R_VML: /* VMLA, VMLS */
119
- tcg_gen_gvec_3(rd_ofs, rn_ofs, rm_ofs, vec_size, vec_size,
120
- u ? &mls_op[size] : &mla_op[size]);
121
- return 0;
122
-
123
- case NEON_3R_VSHL:
124
- /* Note the operation is vshl vd,vm,vn */
125
- tcg_gen_gvec_3(rd_ofs, rm_ofs, rn_ofs, vec_size, vec_size,
126
- u ? &ushl_op[size] : &sshl_op[size]);
127
- return 0;
128
-
129
case NEON_3R_VADD_VSUB:
130
case NEON_3R_LOGIC:
131
case NEON_3R_VMAX:
132
@@ -XXX,XX +XXX,XX @@ static int disas_neon_data_insn(DisasContext *s, uint32_t insn)
133
case NEON_3R_VCGE:
134
case NEON_3R_VQADD:
135
case NEON_3R_VQSUB:
136
+ case NEON_3R_VMUL:
137
+ case NEON_3R_VML:
138
+ case NEON_3R_VSHL:
139
/* Already handled by decodetree */
140
return 1;
141
}
142
--
129
--
143
2.20.1
130
2.20.1
144
131
145
132
diff view generated by jsdifflib
1
From: "Edgar E. Iglesias" <edgar.iglesias@xilinx.com>
1
The ptimer API currently provides two methods for setting the period:
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.
2
8
3
Add support for SD.
9
Add a new function ptimer_set_period_from_clock() which takes the
10
Clock object directly to avoid the rounding issues. This includes a
11
facility for the user to specify that there is a frequency divider
12
between the Clock proper and the timer, as some timer devices like
13
the CMSDK APB dualtimer need this.
4
14
5
Signed-off-by: Edgar E. Iglesias <edgar.iglesias@xilinx.com>
15
To avoid having to drag in clock.h from ptimer.h we add the Clock
6
Reviewed-by: Alistair Francis <alistair.francis@wdc.com>
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>
7
Reviewed-by: Philippe Mathieu-Daudé <f4bug@amsat.org>
21
Reviewed-by: Philippe Mathieu-Daudé <f4bug@amsat.org>
8
Reviewed-by: Luc Michel <luc.michel@greensocs.com>
22
Message-id: 20210128114145.20536-2-peter.maydell@linaro.org
9
Message-id: 20200427181649.26851-9-edgar.iglesias@gmail.com
23
Message-id: 20210121190622.22000-2-peter.maydell@linaro.org
10
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
11
---
24
---
12
include/hw/arm/xlnx-versal.h | 12 ++++++++++++
25
include/hw/ptimer.h | 22 ++++++++++++++++++++++
13
hw/arm/xlnx-versal.c | 31 +++++++++++++++++++++++++++++++
26
include/qemu/typedefs.h | 1 +
14
2 files changed, 43 insertions(+)
27
hw/core/ptimer.c | 34 ++++++++++++++++++++++++++++++++++
28
3 files changed, 57 insertions(+)
15
29
16
diff --git a/include/hw/arm/xlnx-versal.h b/include/hw/arm/xlnx-versal.h
30
diff --git a/include/hw/ptimer.h b/include/hw/ptimer.h
17
index XXXXXXX..XXXXXXX 100644
31
index XXXXXXX..XXXXXXX 100644
18
--- a/include/hw/arm/xlnx-versal.h
32
--- a/include/hw/ptimer.h
19
+++ b/include/hw/arm/xlnx-versal.h
33
+++ b/include/hw/ptimer.h
34
@@ -XXX,XX +XXX,XX @@ void ptimer_transaction_commit(ptimer_state *s);
35
*/
36
void ptimer_set_period(ptimer_state *s, int64_t period);
37
38
+/**
39
+ * ptimer_set_period_from_clock - Set counter increment from a Clock
40
+ * @s: ptimer to configure
41
+ * @clk: pointer to Clock object to take period from
42
+ * @divisor: value to scale the clock frequency down by
43
+ *
44
+ * If the ptimer is being driven from a Clock, this is the preferred
45
+ * way to tell the ptimer about the period, because it avoids any
46
+ * possible rounding errors that might happen if the internal
47
+ * representation of the Clock period was converted to either a period
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
+
60
/**
61
* ptimer_set_freq - Set counter frequency in Hz
62
* @s: ptimer to configure
63
diff --git a/include/qemu/typedefs.h b/include/qemu/typedefs.h
64
index XXXXXXX..XXXXXXX 100644
65
--- a/include/qemu/typedefs.h
66
+++ b/include/qemu/typedefs.h
67
@@ -XXX,XX +XXX,XX @@ typedef struct BlockDriverState BlockDriverState;
68
typedef struct BusClass BusClass;
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
20
@@ -XXX,XX +XXX,XX @@
79
@@ -XXX,XX +XXX,XX @@
21
80
#include "sysemu/qtest.h"
22
#include "hw/sysbus.h"
81
#include "block/aio.h"
23
#include "hw/arm/boot.h"
82
#include "sysemu/cpus.h"
24
+#include "hw/sd/sdhci.h"
83
+#include "hw/clock.h"
25
#include "hw/intc/arm_gicv3.h"
84
26
#include "hw/char/pl011.h"
85
#define DELTA_ADJUST 1
27
#include "hw/dma/xlnx-zdma.h"
86
#define DELTA_NO_ADJUST -1
28
@@ -XXX,XX +XXX,XX @@
87
@@ -XXX,XX +XXX,XX @@ void ptimer_set_period(ptimer_state *s, int64_t period)
29
#define XLNX_VERSAL_NR_UARTS 2
30
#define XLNX_VERSAL_NR_GEMS 2
31
#define XLNX_VERSAL_NR_ADMAS 8
32
+#define XLNX_VERSAL_NR_SDS 2
33
#define XLNX_VERSAL_NR_IRQS 192
34
35
typedef struct Versal {
36
@@ -XXX,XX +XXX,XX @@ typedef struct Versal {
37
} iou;
38
} lpd;
39
40
+ /* The Platform Management Controller subsystem. */
41
+ struct {
42
+ struct {
43
+ SDHCIState sd[XLNX_VERSAL_NR_SDS];
44
+ } iou;
45
+ } pmc;
46
+
47
struct {
48
MemoryRegion *mr_ddr;
49
uint32_t psci_conduit;
50
@@ -XXX,XX +XXX,XX @@ typedef struct Versal {
51
#define VERSAL_GEM1_IRQ_0 58
52
#define VERSAL_GEM1_WAKE_IRQ_0 59
53
#define VERSAL_ADMA_IRQ_0 60
54
+#define VERSAL_SD0_IRQ_0 126
55
56
/* Architecturally reserved IRQs suitable for virtualization. */
57
#define VERSAL_RSVD_IRQ_FIRST 111
58
@@ -XXX,XX +XXX,XX @@ typedef struct Versal {
59
#define MM_FPD_CRF 0xfd1a0000U
60
#define MM_FPD_CRF_SIZE 0x140000
61
62
+#define MM_PMC_SD0 0xf1040000U
63
+#define MM_PMC_SD0_SIZE 0x10000
64
#define MM_PMC_CRP 0xf1260000U
65
#define MM_PMC_CRP_SIZE 0x10000
66
#endif
67
diff --git a/hw/arm/xlnx-versal.c b/hw/arm/xlnx-versal.c
68
index XXXXXXX..XXXXXXX 100644
69
--- a/hw/arm/xlnx-versal.c
70
+++ b/hw/arm/xlnx-versal.c
71
@@ -XXX,XX +XXX,XX @@ static void versal_create_admas(Versal *s, qemu_irq *pic)
72
}
88
}
73
}
89
}
74
90
75
+#define SDHCI_CAPABILITIES 0x280737ec6481 /* Same as on ZynqMP. */
91
+/* Set counter increment interval from a Clock */
76
+static void versal_create_sds(Versal *s, qemu_irq *pic)
92
+void ptimer_set_period_from_clock(ptimer_state *s, const Clock *clk,
93
+ unsigned int divisor)
77
+{
94
+{
78
+ int i;
95
+ /*
96
+ * The raw clock period is a 64-bit value in units of 2^-32 ns;
97
+ * put another way it's a 32.32 fixed-point ns value. Our internal
98
+ * representation of the period is 64.32 fixed point ns, so
99
+ * the conversion is simple.
100
+ */
101
+ uint64_t raw_period = clock_get(clk);
102
+ uint64_t period_frac;
79
+
103
+
80
+ for (i = 0; i < ARRAY_SIZE(s->pmc.iou.sd); i++) {
104
+ assert(s->in_transaction);
81
+ DeviceState *dev;
105
+ s->delta = ptimer_get_count(s);
82
+ MemoryRegion *mr;
106
+ s->period = extract64(raw_period, 32, 32);
107
+ period_frac = extract64(raw_period, 0, 32);
108
+ /*
109
+ * divisor specifies a possible frequency divisor between the
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;
83
+
118
+
84
+ sysbus_init_child_obj(OBJECT(s), "sd[*]",
119
+ if (s->enabled) {
85
+ &s->pmc.iou.sd[i], sizeof(s->pmc.iou.sd[i]),
120
+ s->need_reload = true;
86
+ TYPE_SYSBUS_SDHCI);
87
+ dev = DEVICE(&s->pmc.iou.sd[i]);
88
+
89
+ object_property_set_uint(OBJECT(dev),
90
+ 3, "sd-spec-version", &error_fatal);
91
+ object_property_set_uint(OBJECT(dev), SDHCI_CAPABILITIES, "capareg",
92
+ &error_fatal);
93
+ object_property_set_uint(OBJECT(dev), UHS_I, "uhs", &error_fatal);
94
+ qdev_init_nofail(dev);
95
+
96
+ mr = sysbus_mmio_get_region(SYS_BUS_DEVICE(dev), 0);
97
+ memory_region_add_subregion(&s->mr_ps,
98
+ MM_PMC_SD0 + i * MM_PMC_SD0_SIZE, mr);
99
+
100
+ sysbus_connect_irq(SYS_BUS_DEVICE(dev), 0,
101
+ pic[VERSAL_SD0_IRQ_0 + i * 2]);
102
+ }
121
+ }
103
+}
122
+}
104
+
123
+
105
/* This takes the board allocated linear DDR memory and creates aliases
124
/* Set counter frequency in Hz. */
106
* for each split DDR range/aperture on the Versal address map.
125
void ptimer_set_freq(ptimer_state *s, uint32_t freq)
107
*/
126
{
108
@@ -XXX,XX +XXX,XX @@ static void versal_realize(DeviceState *dev, Error **errp)
109
versal_create_uarts(s, pic);
110
versal_create_gems(s, pic);
111
versal_create_admas(s, pic);
112
+ versal_create_sds(s, pic);
113
versal_map_ddr(s);
114
versal_unimp(s);
115
116
--
127
--
117
2.20.1
128
2.20.1
118
129
119
130
diff view generated by jsdifflib
1
We're going to want at least some of the NeonGen* typedefs
1
Add a function for checking whether a clock has a source. This is
2
for the refactored 32-bit Neon decoder, so move them all
2
useful for devices which have input clocks that must be wired up by
3
to translate.h since it makes more sense to keep them in
3
the board as it allows them to fail in realize rather than ploughing
4
one group.
4
on with a zero-period clock.
5
5
6
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
6
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
7
Reviewed-by: Richard Henderson <richard.henderson@linaro.org>
7
Reviewed-by: Luc Michel <luc@lmichel.fr>
8
Message-id: 20200430181003.21682-23-peter.maydell@linaro.org
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
9
---
12
---
10
target/arm/translate.h | 17 +++++++++++++++++
13
docs/devel/clocks.rst | 16 ++++++++++++++++
11
target/arm/translate-a64.c | 17 -----------------
14
include/hw/clock.h | 15 +++++++++++++++
12
2 files changed, 17 insertions(+), 17 deletions(-)
15
2 files changed, 31 insertions(+)
13
16
14
diff --git a/target/arm/translate.h b/target/arm/translate.h
17
diff --git a/docs/devel/clocks.rst b/docs/devel/clocks.rst
15
index XXXXXXX..XXXXXXX 100644
18
index XXXXXXX..XXXXXXX 100644
16
--- a/target/arm/translate.h
19
--- a/docs/devel/clocks.rst
17
+++ b/target/arm/translate.h
20
+++ b/docs/devel/clocks.rst
18
@@ -XXX,XX +XXX,XX @@ typedef void GVecGen3Fn(unsigned, uint32_t, uint32_t,
21
@@ -XXX,XX +XXX,XX @@ object during device instance init. For example:
19
typedef void GVecGen4Fn(unsigned, uint32_t, uint32_t, uint32_t,
22
/* set initial value to 10ns / 100MHz */
20
uint32_t, uint32_t, uint32_t);
23
clock_set_ns(clk, 10);
21
24
22
+/* Function prototype for gen_ functions for calling Neon helpers */
25
+To enforce that the clock is wired up by the board code, you can
23
+typedef void NeonGenOneOpEnvFn(TCGv_i32, TCGv_ptr, TCGv_i32);
26
+call ``clock_has_source()`` in your device's realize method:
24
+typedef void NeonGenTwoOpFn(TCGv_i32, TCGv_i32, TCGv_i32);
25
+typedef void NeonGenTwoOpEnvFn(TCGv_i32, TCGv_ptr, TCGv_i32, TCGv_i32);
26
+typedef void NeonGenTwo64OpFn(TCGv_i64, TCGv_i64, TCGv_i64);
27
+typedef void NeonGenTwo64OpEnvFn(TCGv_i64, TCGv_ptr, TCGv_i64, TCGv_i64);
28
+typedef void NeonGenNarrowFn(TCGv_i32, TCGv_i64);
29
+typedef void NeonGenNarrowEnvFn(TCGv_i32, TCGv_ptr, TCGv_i64);
30
+typedef void NeonGenWidenFn(TCGv_i64, TCGv_i32);
31
+typedef void NeonGenTwoSingleOPFn(TCGv_i32, TCGv_i32, TCGv_i32, TCGv_ptr);
32
+typedef void NeonGenTwoDoubleOPFn(TCGv_i64, TCGv_i64, TCGv_i64, TCGv_ptr);
33
+typedef void NeonGenOneOpFn(TCGv_i64, TCGv_i64);
34
+typedef void CryptoTwoOpFn(TCGv_ptr, TCGv_ptr);
35
+typedef void CryptoThreeOpIntFn(TCGv_ptr, TCGv_ptr, TCGv_i32);
36
+typedef void CryptoThreeOpFn(TCGv_ptr, TCGv_ptr, TCGv_ptr);
37
+typedef void AtomicThreeOpFn(TCGv_i64, TCGv_i64, TCGv_i64, TCGArg, MemOp);
38
+
27
+
39
#endif /* TARGET_ARM_TRANSLATE_H */
28
+.. code-block:: c
40
diff --git a/target/arm/translate-a64.c b/target/arm/translate-a64.c
29
+
30
+ if (!clock_has_source(s->clk)) {
31
+ error_setg(errp, "MyDevice: clk input must be connected");
32
+ return;
33
+ }
34
+
35
+Note that this only checks that the clock has been wired up; it is
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
+
41
Fetching clock frequency/period
42
-------------------------------
43
44
diff --git a/include/hw/clock.h b/include/hw/clock.h
41
index XXXXXXX..XXXXXXX 100644
45
index XXXXXXX..XXXXXXX 100644
42
--- a/target/arm/translate-a64.c
46
--- a/include/hw/clock.h
43
+++ b/target/arm/translate-a64.c
47
+++ b/include/hw/clock.h
44
@@ -XXX,XX +XXX,XX @@ typedef struct AArch64DecodeTable {
48
@@ -XXX,XX +XXX,XX @@ void clock_clear_callback(Clock *clk);
45
AArch64DecodeFn *disas_fn;
49
*/
46
} AArch64DecodeTable;
50
void clock_set_source(Clock *clk, Clock *src);
47
51
48
-/* Function prototype for gen_ functions for calling Neon helpers */
52
+/**
49
-typedef void NeonGenOneOpEnvFn(TCGv_i32, TCGv_ptr, TCGv_i32);
53
+ * clock_has_source:
50
-typedef void NeonGenTwoOpFn(TCGv_i32, TCGv_i32, TCGv_i32);
54
+ * @clk: the clock
51
-typedef void NeonGenTwoOpEnvFn(TCGv_i32, TCGv_ptr, TCGv_i32, TCGv_i32);
55
+ *
52
-typedef void NeonGenTwo64OpFn(TCGv_i64, TCGv_i64, TCGv_i64);
56
+ * Returns true if the clock has a source clock connected to it.
53
-typedef void NeonGenTwo64OpEnvFn(TCGv_i64, TCGv_ptr, TCGv_i64, TCGv_i64);
57
+ * This is useful for devices which have input clocks which must
54
-typedef void NeonGenNarrowFn(TCGv_i32, TCGv_i64);
58
+ * be connected by the board/SoC code which creates them. The
55
-typedef void NeonGenNarrowEnvFn(TCGv_i32, TCGv_ptr, TCGv_i64);
59
+ * device code can use this to check in its realize method that
56
-typedef void NeonGenWidenFn(TCGv_i64, TCGv_i32);
60
+ * the clock has been connected.
57
-typedef void NeonGenTwoSingleOPFn(TCGv_i32, TCGv_i32, TCGv_i32, TCGv_ptr);
61
+ */
58
-typedef void NeonGenTwoDoubleOPFn(TCGv_i64, TCGv_i64, TCGv_i64, TCGv_ptr);
62
+static inline bool clock_has_source(const Clock *clk)
59
-typedef void NeonGenOneOpFn(TCGv_i64, TCGv_i64);
63
+{
60
-typedef void CryptoTwoOpFn(TCGv_ptr, TCGv_ptr);
64
+ return clk->source != NULL;
61
-typedef void CryptoThreeOpIntFn(TCGv_ptr, TCGv_ptr, TCGv_i32);
65
+}
62
-typedef void CryptoThreeOpFn(TCGv_ptr, TCGv_ptr, TCGv_ptr);
66
+
63
-typedef void AtomicThreeOpFn(TCGv_i64, TCGv_i64, TCGv_i64, TCGArg, MemOp);
67
/**
64
-
68
* clock_set:
65
/* initialize TCG globals. */
69
* @clk: the clock to initialize.
66
void a64_translate_init(void)
67
{
68
--
70
--
69
2.20.1
71
2.20.1
70
72
71
73
diff view generated by jsdifflib
1
Convert the Neon VQADD/VQSUB insns in the 3-reg-same grouping
1
Add a simple test of the CMSDK APB timer, since we're about to do
2
to decodetree.
2
some refactoring of how it is clocked.
3
3
4
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
4
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
5
Reviewed-by: Richard Henderson <richard.henderson@linaro.org>
5
Reviewed-by: Philippe Mathieu-Daudé <f4bug@amsat.org>
6
Message-id: 20200430181003.21682-19-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-4-peter.maydell@linaro.org
9
Message-id: 20210121190622.22000-4-peter.maydell@linaro.org
7
---
10
---
8
target/arm/neon-dp.decode | 6 ++++++
11
tests/qtest/cmsdk-apb-timer-test.c | 75 ++++++++++++++++++++++++++++++
9
target/arm/translate-neon.inc.c | 15 +++++++++++++++
12
MAINTAINERS | 1 +
10
target/arm/translate.c | 14 ++------------
13
tests/qtest/meson.build | 1 +
11
3 files changed, 23 insertions(+), 12 deletions(-)
14
3 files changed, 77 insertions(+)
15
create mode 100644 tests/qtest/cmsdk-apb-timer-test.c
12
16
13
diff --git a/target/arm/neon-dp.decode b/target/arm/neon-dp.decode
17
diff --git a/tests/qtest/cmsdk-apb-timer-test.c b/tests/qtest/cmsdk-apb-timer-test.c
18
new file mode 100644
19
index XXXXXXX..XXXXXXX
20
--- /dev/null
21
+++ b/tests/qtest/cmsdk-apb-timer-test.c
22
@@ -XXX,XX +XXX,XX @@
23
+/*
24
+ * QTest testcase for the CMSDK APB timer device
25
+ *
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
+
39
+#include "qemu/osdep.h"
40
+#include "libqtest-single.h"
41
+
42
+/* IoTKit/ARMSSE-200 timer0; driven at 25MHz in mps2-an385, so 40ns per tick */
43
+#define TIMER_BASE 0x40000000
44
+
45
+#define CTRL 0
46
+#define VALUE 4
47
+#define RELOAD 8
48
+#define INTSTATUS 0xc
49
+
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
+}
81
+
82
+int main(int argc, char **argv)
83
+{
84
+ int r;
85
+
86
+ g_test_init(&argc, &argv, NULL);
87
+
88
+ qtest_start("-machine mps2-an385");
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
14
index XXXXXXX..XXXXXXX 100644
99
index XXXXXXX..XXXXXXX 100644
15
--- a/target/arm/neon-dp.decode
100
--- a/MAINTAINERS
16
+++ b/target/arm/neon-dp.decode
101
+++ b/MAINTAINERS
17
@@ -XXX,XX +XXX,XX @@
102
@@ -XXX,XX +XXX,XX @@ F: include/hw/rtc/pl031.h
18
@3same .... ... . . . size:2 .... .... .... . q:1 . . .... \
103
F: include/hw/arm/primecell.h
19
&3same vm=%vm_dp vn=%vn_dp vd=%vd_dp
104
F: hw/timer/cmsdk-apb-timer.c
20
105
F: include/hw/timer/cmsdk-apb-timer.h
21
+VQADD_S_3s 1111 001 0 0 . .. .... .... 0000 . . . 1 .... @3same
106
+F: tests/qtest/cmsdk-apb-timer-test.c
22
+VQADD_U_3s 1111 001 1 0 . .. .... .... 0000 . . . 1 .... @3same
107
F: hw/timer/cmsdk-apb-dualtimer.c
23
+
108
F: include/hw/timer/cmsdk-apb-dualtimer.h
24
@3same_logic .... ... . . . .. .... .... .... . q:1 .. .... \
109
F: hw/char/cmsdk-apb-uart.c
25
&3same vm=%vm_dp vn=%vn_dp vd=%vd_dp size=0
110
diff --git a/tests/qtest/meson.build b/tests/qtest/meson.build
26
27
@@ -XXX,XX +XXX,XX @@ VBSL_3s 1111 001 1 0 . 01 .... .... 0001 ... 1 .... @3same_logic
28
VBIT_3s 1111 001 1 0 . 10 .... .... 0001 ... 1 .... @3same_logic
29
VBIF_3s 1111 001 1 0 . 11 .... .... 0001 ... 1 .... @3same_logic
30
31
+VQSUB_S_3s 1111 001 0 0 . .. .... .... 0010 . . . 1 .... @3same
32
+VQSUB_U_3s 1111 001 1 0 . .. .... .... 0010 . . . 1 .... @3same
33
+
34
VCGT_S_3s 1111 001 0 0 . .. .... .... 0011 . . . 0 .... @3same
35
VCGT_U_3s 1111 001 1 0 . .. .... .... 0011 . . . 0 .... @3same
36
VCGE_S_3s 1111 001 0 0 . .. .... .... 0011 . . . 1 .... @3same
37
diff --git a/target/arm/translate-neon.inc.c b/target/arm/translate-neon.inc.c
38
index XXXXXXX..XXXXXXX 100644
111
index XXXXXXX..XXXXXXX 100644
39
--- a/target/arm/translate-neon.inc.c
112
--- a/tests/qtest/meson.build
40
+++ b/target/arm/translate-neon.inc.c
113
+++ b/tests/qtest/meson.build
41
@@ -XXX,XX +XXX,XX @@ static void gen_VTST_3s(unsigned vece, uint32_t rd_ofs, uint32_t rn_ofs,
114
@@ -XXX,XX +XXX,XX @@ qtests_npcm7xx = \
42
tcg_gen_gvec_3(rd_ofs, rn_ofs, rm_ofs, oprsz, maxsz, &cmtst_op[vece]);
115
'npcm7xx_timer-test',
43
}
116
'npcm7xx_watchdog_timer-test']
44
DO_3SAME_NO_SZ_3(VTST, gen_VTST_3s)
117
qtests_arm = \
45
+
118
+ (config_all_devices.has_key('CONFIG_CMSDK_APB_TIMER') ? ['cmsdk-apb-timer-test'] : []) + \
46
+#define DO_3SAME_GVEC4(INSN, OPARRAY) \
119
(config_all_devices.has_key('CONFIG_PFLASH_CFI02') ? ['pflash-cfi02-test'] : []) + \
47
+ static void gen_##INSN##_3s(unsigned vece, uint32_t rd_ofs, \
120
(config_all_devices.has_key('CONFIG_NPCM7XX') ? qtests_npcm7xx : []) + \
48
+ uint32_t rn_ofs, uint32_t rm_ofs, \
121
['arm-cpu-features',
49
+ uint32_t oprsz, uint32_t maxsz) \
50
+ { \
51
+ tcg_gen_gvec_4(rd_ofs, offsetof(CPUARMState, vfp.qc), \
52
+ rn_ofs, rm_ofs, oprsz, maxsz, &OPARRAY[vece]); \
53
+ } \
54
+ DO_3SAME(INSN, gen_##INSN##_3s)
55
+
56
+DO_3SAME_GVEC4(VQADD_S, sqadd_op)
57
+DO_3SAME_GVEC4(VQADD_U, uqadd_op)
58
+DO_3SAME_GVEC4(VQSUB_S, sqsub_op)
59
+DO_3SAME_GVEC4(VQSUB_U, uqsub_op)
60
diff --git a/target/arm/translate.c b/target/arm/translate.c
61
index XXXXXXX..XXXXXXX 100644
62
--- a/target/arm/translate.c
63
+++ b/target/arm/translate.c
64
@@ -XXX,XX +XXX,XX @@ static int disas_neon_data_insn(DisasContext *s, uint32_t insn)
65
}
66
return 1;
67
68
- case NEON_3R_VQADD:
69
- tcg_gen_gvec_4(rd_ofs, offsetof(CPUARMState, vfp.qc),
70
- rn_ofs, rm_ofs, vec_size, vec_size,
71
- (u ? uqadd_op : sqadd_op) + size);
72
- return 0;
73
-
74
- case NEON_3R_VQSUB:
75
- tcg_gen_gvec_4(rd_ofs, offsetof(CPUARMState, vfp.qc),
76
- rn_ofs, rm_ofs, vec_size, vec_size,
77
- (u ? uqsub_op : sqsub_op) + size);
78
- return 0;
79
-
80
case NEON_3R_VMUL: /* VMUL */
81
if (u) {
82
/* Polynomial case allows only P8. */
83
@@ -XXX,XX +XXX,XX @@ static int disas_neon_data_insn(DisasContext *s, uint32_t insn)
84
case NEON_3R_VTST_VCEQ:
85
case NEON_3R_VCGT:
86
case NEON_3R_VCGE:
87
+ case NEON_3R_VQADD:
88
+ case NEON_3R_VQSUB:
89
/* Already handled by decodetree */
90
return 1;
91
}
92
--
122
--
93
2.20.1
123
2.20.1
94
124
95
125
diff view generated by jsdifflib
1
Convert the Neon 3-reg-same VADD and VSUB insns to decodetree.
1
Add a simple test of the CMSDK watchdog, since we're about to do some
2
2
refactoring of how it is clocked.
3
Note that we don't need the neon_3r_sizes[op] check here because all
4
size values are OK for VADD and VSUB; we'll add this when we convert
5
the first insn that has size restrictions.
6
7
For this we need one of the GVecGen*Fn typedefs currently in
8
translate-a64.h; move them all to translate.h as a block so they
9
are visible to the 32-bit decoder.
10
3
11
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
4
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
12
Reviewed-by: Richard Henderson <richard.henderson@linaro.org>
5
Reviewed-by: Luc Michel <luc@lmichel.fr>
13
Message-id: 20200430181003.21682-15-peter.maydell@linaro.org
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>
14
---
11
---
15
target/arm/translate-a64.h | 9 --------
12
tests/qtest/cmsdk-apb-watchdog-test.c | 79 +++++++++++++++++++++++++++
16
target/arm/translate.h | 9 ++++++++
13
MAINTAINERS | 1 +
17
target/arm/neon-dp.decode | 17 +++++++++++++++
14
tests/qtest/meson.build | 1 +
18
target/arm/translate-neon.inc.c | 38 +++++++++++++++++++++++++++++++++
15
3 files changed, 81 insertions(+)
19
target/arm/translate.c | 14 ++++--------
16
create mode 100644 tests/qtest/cmsdk-apb-watchdog-test.c
20
5 files changed, 68 insertions(+), 19 deletions(-)
21
17
22
diff --git a/target/arm/translate-a64.h b/target/arm/translate-a64.h
18
diff --git a/tests/qtest/cmsdk-apb-watchdog-test.c b/tests/qtest/cmsdk-apb-watchdog-test.c
23
index XXXXXXX..XXXXXXX 100644
19
new file mode 100644
24
--- a/target/arm/translate-a64.h
20
index XXXXXXX..XXXXXXX
25
+++ b/target/arm/translate-a64.h
21
--- /dev/null
26
@@ -XXX,XX +XXX,XX @@ static inline int vec_full_reg_size(DisasContext *s)
22
+++ b/tests/qtest/cmsdk-apb-watchdog-test.c
27
23
@@ -XXX,XX +XXX,XX @@
28
bool disas_sve(DisasContext *, uint32_t);
24
+/*
29
25
+ * QTest testcase for the CMSDK APB watchdog device
30
-/* Note that the gvec expanders operate on offsets + sizes. */
26
+ *
31
-typedef void GVecGen2Fn(unsigned, uint32_t, uint32_t, uint32_t, uint32_t);
27
+ * Copyright (c) 2021 Linaro Limited
32
-typedef void GVecGen2iFn(unsigned, uint32_t, uint32_t, int64_t,
28
+ *
33
- uint32_t, uint32_t);
29
+ * This program is free software; you can redistribute it and/or modify it
34
-typedef void GVecGen3Fn(unsigned, uint32_t, uint32_t,
30
+ * under the terms of the GNU General Public License as published by the
35
- uint32_t, uint32_t, uint32_t);
31
+ * Free Software Foundation; either version 2 of the License, or
36
-typedef void GVecGen4Fn(unsigned, uint32_t, uint32_t, uint32_t,
32
+ * (at your option) any later version.
37
- uint32_t, uint32_t, uint32_t);
33
+ *
38
-
34
+ * This program is distributed in the hope that it will be useful, but WITHOUT
39
#endif /* TARGET_ARM_TRANSLATE_A64_H */
35
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
40
diff --git a/target/arm/translate.h b/target/arm/translate.h
36
+ * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
41
index XXXXXXX..XXXXXXX 100644
37
+ * for more details.
42
--- a/target/arm/translate.h
38
+ */
43
+++ b/target/arm/translate.h
44
@@ -XXX,XX +XXX,XX @@ void gen_sshl_i64(TCGv_i64 d, TCGv_i64 a, TCGv_i64 b);
45
#define dc_isar_feature(name, ctx) \
46
({ DisasContext *ctx_ = (ctx); isar_feature_##name(ctx_->isar); })
47
48
+/* Note that the gvec expanders operate on offsets + sizes. */
49
+typedef void GVecGen2Fn(unsigned, uint32_t, uint32_t, uint32_t, uint32_t);
50
+typedef void GVecGen2iFn(unsigned, uint32_t, uint32_t, int64_t,
51
+ uint32_t, uint32_t);
52
+typedef void GVecGen3Fn(unsigned, uint32_t, uint32_t,
53
+ uint32_t, uint32_t, uint32_t);
54
+typedef void GVecGen4Fn(unsigned, uint32_t, uint32_t, uint32_t,
55
+ uint32_t, uint32_t, uint32_t);
56
+
39
+
57
#endif /* TARGET_ARM_TRANSLATE_H */
40
+#include "qemu/osdep.h"
58
diff --git a/target/arm/neon-dp.decode b/target/arm/neon-dp.decode
41
+#include "libqtest-single.h"
59
index XXXXXXX..XXXXXXX 100644
60
--- a/target/arm/neon-dp.decode
61
+++ b/target/arm/neon-dp.decode
62
@@ -XXX,XX +XXX,XX @@
63
#
64
# This file is processed by scripts/decodetree.py
65
#
66
+# VFP/Neon register fields; same as vfp.decode
67
+%vm_dp 5:1 0:4
68
+%vn_dp 7:1 16:4
69
+%vd_dp 22:1 12:4
70
71
# Encodings for Neon data processing instructions where the T32 encoding
72
# is a simple transformation of the A32 encoding.
73
@@ -XXX,XX +XXX,XX @@
74
# 0b111p_1111_qqqq_qqqq_qqqq_qqqq_qqqq_qqqq
75
# This file works on the A32 encoding only; calling code for T32 has to
76
# transform the insn into the A32 version first.
77
+
42
+
78
+######################################################################
43
+/*
79
+# 3-reg-same grouping:
44
+ * lm3s811evb watchdog; at board startup this runs at 200MHz / 16 == 12.5MHz,
80
+# 1111 001 U 0 D sz:2 Vn:4 Vd:4 opc:4 N Q M op Vm:4
45
+ * which is 80ns per tick.
81
+######################################################################
46
+ */
47
+#define WDOG_BASE 0x40000000
82
+
48
+
83
+&3same vm vn vd q size
49
+#define WDOGLOAD 0
50
+#define WDOGVALUE 4
51
+#define WDOGCONTROL 8
52
+#define WDOGINTCLR 0xc
53
+#define WDOGRIS 0x10
54
+#define WDOGMIS 0x14
55
+#define WDOGLOCK 0xc00
84
+
56
+
85
+@3same .... ... . . . size:2 .... .... .... . q:1 . . .... \
57
+static void test_watchdog(void)
86
+ &3same vm=%vm_dp vn=%vn_dp vd=%vd_dp
58
+{
59
+ g_assert_cmpuint(readl(WDOG_BASE + WDOGRIS), ==, 0);
87
+
60
+
88
+VADD_3s 1111 001 0 0 . .. .... .... 1000 . . . 0 .... @3same
61
+ writel(WDOG_BASE + WDOGCONTROL, 1);
89
+VSUB_3s 1111 001 1 0 . .. .... .... 1000 . . . 0 .... @3same
62
+ writel(WDOG_BASE + WDOGLOAD, 1000);
90
diff --git a/target/arm/translate-neon.inc.c b/target/arm/translate-neon.inc.c
91
index XXXXXXX..XXXXXXX 100644
92
--- a/target/arm/translate-neon.inc.c
93
+++ b/target/arm/translate-neon.inc.c
94
@@ -XXX,XX +XXX,XX @@ static bool trans_VLDST_single(DisasContext *s, arg_VLDST_single *a)
95
96
return true;
97
}
98
+
63
+
99
+static bool do_3same(DisasContext *s, arg_3same *a, GVecGen3Fn fn)
64
+ /* Step to just past the 500th tick */
100
+{
65
+ clock_step(500 * 80 + 1);
101
+ int vec_size = a->q ? 16 : 8;
66
+ g_assert_cmpuint(readl(WDOG_BASE + WDOGRIS), ==, 0);
102
+ int rd_ofs = neon_reg_offset(a->vd, 0);
67
+ g_assert_cmpuint(readl(WDOG_BASE + WDOGVALUE), ==, 500);
103
+ int rn_ofs = neon_reg_offset(a->vn, 0);
104
+ int rm_ofs = neon_reg_offset(a->vm, 0);
105
+
68
+
106
+ if (!arm_dc_feature(s, ARM_FEATURE_NEON)) {
69
+ /* Just past the 1000th tick: timer should have fired */
107
+ return false;
70
+ clock_step(500 * 80);
108
+ }
71
+ g_assert_cmpuint(readl(WDOG_BASE + WDOGRIS), ==, 1);
72
+ g_assert_cmpuint(readl(WDOG_BASE + WDOGVALUE), ==, 0);
109
+
73
+
110
+ /* UNDEF accesses to D16-D31 if they don't exist. */
74
+ /* VALUE reloads at following tick */
111
+ if (!dc_isar_feature(aa32_simd_r32, s) &&
75
+ clock_step(80);
112
+ ((a->vd | a->vn | a->vm) & 0x10)) {
76
+ g_assert_cmpuint(readl(WDOG_BASE + WDOGVALUE), ==, 1000);
113
+ return false;
114
+ }
115
+
77
+
116
+ if ((a->vn | a->vm | a->vd) & a->q) {
78
+ /* Writing any value to WDOGINTCLR clears the interrupt and reloads */
117
+ return false;
79
+ clock_step(500 * 80);
118
+ }
80
+ g_assert_cmpuint(readl(WDOG_BASE + WDOGVALUE), ==, 500);
119
+
81
+ g_assert_cmpuint(readl(WDOG_BASE + WDOGRIS), ==, 1);
120
+ if (!vfp_access_check(s)) {
82
+ writel(WDOG_BASE + WDOGINTCLR, 0);
121
+ return true;
83
+ g_assert_cmpuint(readl(WDOG_BASE + WDOGVALUE), ==, 1000);
122
+ }
84
+ g_assert_cmpuint(readl(WDOG_BASE + WDOGRIS), ==, 0);
123
+
124
+ fn(a->size, rd_ofs, rn_ofs, rm_ofs, vec_size, vec_size);
125
+ return true;
126
+}
85
+}
127
+
86
+
128
+#define DO_3SAME(INSN, FUNC) \
87
+int main(int argc, char **argv)
129
+ static bool trans_##INSN##_3s(DisasContext *s, arg_3same *a) \
88
+{
130
+ { \
89
+ int r;
131
+ return do_3same(s, a, FUNC); \
132
+ }
133
+
90
+
134
+DO_3SAME(VADD, tcg_gen_gvec_add)
91
+ g_test_init(&argc, &argv, NULL);
135
+DO_3SAME(VSUB, tcg_gen_gvec_sub)
92
+
136
diff --git a/target/arm/translate.c b/target/arm/translate.c
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
137
index XXXXXXX..XXXXXXX 100644
104
index XXXXXXX..XXXXXXX 100644
138
--- a/target/arm/translate.c
105
--- a/MAINTAINERS
139
+++ b/target/arm/translate.c
106
+++ b/MAINTAINERS
140
@@ -XXX,XX +XXX,XX @@ static int disas_neon_data_insn(DisasContext *s, uint32_t insn)
107
@@ -XXX,XX +XXX,XX @@ F: hw/char/cmsdk-apb-uart.c
141
}
108
F: include/hw/char/cmsdk-apb-uart.h
142
return 0;
109
F: hw/watchdog/cmsdk-apb-watchdog.c
143
110
F: include/hw/watchdog/cmsdk-apb-watchdog.h
144
- case NEON_3R_VADD_VSUB:
111
+F: tests/qtest/cmsdk-apb-watchdog-test.c
145
- if (u) {
112
F: hw/misc/tz-ppc.c
146
- tcg_gen_gvec_sub(size, rd_ofs, rn_ofs, rm_ofs,
113
F: include/hw/misc/tz-ppc.h
147
- vec_size, vec_size);
114
F: hw/misc/tz-mpc.c
148
- } else {
115
diff --git a/tests/qtest/meson.build b/tests/qtest/meson.build
149
- tcg_gen_gvec_add(size, rd_ofs, rn_ofs, rm_ofs,
116
index XXXXXXX..XXXXXXX 100644
150
- vec_size, vec_size);
117
--- a/tests/qtest/meson.build
151
- }
118
+++ b/tests/qtest/meson.build
152
- return 0;
119
@@ -XXX,XX +XXX,XX @@ qtests_npcm7xx = \
153
-
120
'npcm7xx_watchdog_timer-test']
154
case NEON_3R_VQADD:
121
qtests_arm = \
155
tcg_gen_gvec_4(rd_ofs, offsetof(CPUARMState, vfp.qc),
122
(config_all_devices.has_key('CONFIG_CMSDK_APB_TIMER') ? ['cmsdk-apb-timer-test'] : []) + \
156
rn_ofs, rm_ofs, vec_size, vec_size,
123
+ (config_all_devices.has_key('CONFIG_CMSDK_APB_WATCHDOG') ? ['cmsdk-apb-watchdog-test'] : []) + \
157
@@ -XXX,XX +XXX,XX @@ static int disas_neon_data_insn(DisasContext *s, uint32_t insn)
124
(config_all_devices.has_key('CONFIG_PFLASH_CFI02') ? ['pflash-cfi02-test'] : []) + \
158
tcg_gen_gvec_3(rd_ofs, rm_ofs, rn_ofs, vec_size, vec_size,
125
(config_all_devices.has_key('CONFIG_NPCM7XX') ? qtests_npcm7xx : []) + \
159
u ? &ushl_op[size] : &sshl_op[size]);
126
['arm-cpu-features',
160
return 0;
161
+
162
+ case NEON_3R_VADD_VSUB:
163
+ /* Already handled by decodetree */
164
+ return 1;
165
}
166
167
if (size == 3) {
168
--
127
--
169
2.20.1
128
2.20.1
170
129
171
130
diff view generated by jsdifflib
1
Convert the Neon "load single structure to all lanes" insns to
1
Add a simple test of the CMSDK dual timer, since we're about to do
2
decodetree.
2
some refactoring of how it is clocked.
3
3
4
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
4
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
5
Reviewed-by: Richard Henderson <richard.henderson@linaro.org>
5
Tested-by: Philippe Mathieu-Daudé <f4bug@amsat.org>
6
Message-id: 20200430181003.21682-13-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
7
---
10
---
8
target/arm/neon-ls.decode | 5 +++
11
tests/qtest/cmsdk-apb-dualtimer-test.c | 130 +++++++++++++++++++++++++
9
target/arm/translate-neon.inc.c | 73 +++++++++++++++++++++++++++++++++
12
MAINTAINERS | 1 +
10
target/arm/translate.c | 55 +------------------------
13
tests/qtest/meson.build | 1 +
11
3 files changed, 80 insertions(+), 53 deletions(-)
14
3 files changed, 132 insertions(+)
15
create mode 100644 tests/qtest/cmsdk-apb-dualtimer-test.c
12
16
13
diff --git a/target/arm/neon-ls.decode b/target/arm/neon-ls.decode
17
diff --git a/tests/qtest/cmsdk-apb-dualtimer-test.c b/tests/qtest/cmsdk-apb-dualtimer-test.c
14
index XXXXXXX..XXXXXXX 100644
18
new file mode 100644
15
--- a/target/arm/neon-ls.decode
19
index XXXXXXX..XXXXXXX
16
+++ b/target/arm/neon-ls.decode
20
--- /dev/null
21
+++ b/tests/qtest/cmsdk-apb-dualtimer-test.c
17
@@ -XXX,XX +XXX,XX @@
22
@@ -XXX,XX +XXX,XX @@
18
23
+/*
19
VLDST_multiple 1111 0100 0 . l:1 0 rn:4 .... itype:4 size:2 align:2 rm:4 \
24
+ * QTest testcase for the CMSDK APB dualtimer device
20
vd=%vd_dp
25
+ *
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
+ */
21
+
38
+
22
+# Neon load single element to all lanes
39
+#include "qemu/osdep.h"
40
+#include "libqtest-single.h"
23
+
41
+
24
+VLD_all_lanes 1111 0100 1 . 1 0 rn:4 .... 11 n:2 size:2 t:1 a:1 rm:4 \
42
+/* IoTKit/ARMSSE dualtimer; driven at 25MHz in mps2-an385, so 40ns per tick */
25
+ vd=%vd_dp
43
+#define TIMER_BASE 0x40002000
26
diff --git a/target/arm/translate-neon.inc.c b/target/arm/translate-neon.inc.c
27
index XXXXXXX..XXXXXXX 100644
28
--- a/target/arm/translate-neon.inc.c
29
+++ b/target/arm/translate-neon.inc.c
30
@@ -XXX,XX +XXX,XX @@ static bool trans_VLDST_multiple(DisasContext *s, arg_VLDST_multiple *a)
31
gen_neon_ldst_base_update(s, a->rm, a->rn, nregs * interleave * 8);
32
return true;
33
}
34
+
44
+
35
+static bool trans_VLD_all_lanes(DisasContext *s, arg_VLD_all_lanes *a)
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)
36
+{
71
+{
37
+ /* Neon load single structure to all lanes */
72
+ g_assert_true(readl(TIMER_BASE + TIMER1RIS) == 0);
38
+ int reg, stride, vec_size;
39
+ int vd = a->vd;
40
+ int size = a->size;
41
+ int nregs = a->n + 1;
42
+ TCGv_i32 addr, tmp;
43
+
73
+
44
+ if (!arm_dc_feature(s, ARM_FEATURE_NEON)) {
74
+ /* Start timer: will fire after 40000 ns */
45
+ return false;
75
+ writel(TIMER_BASE + TIMER1LOAD, 1000);
46
+ }
76
+ /* enable in free-running, wrapping, interrupt mode */
77
+ writel(TIMER_BASE + TIMER1CONTROL, CTRL_ENABLE | CTRL_INTEN);
47
+
78
+
48
+ /* UNDEF accesses to D16-D31 if they don't exist */
79
+ /* Step to just past the 500th tick and check VALUE */
49
+ if (!dc_isar_feature(aa32_simd_r32, s) && (a->vd & 0x10)) {
80
+ clock_step(500 * 40 + 1);
50
+ return false;
81
+ g_assert_cmpuint(readl(TIMER_BASE + TIMER1RIS), ==, 0);
51
+ }
82
+ g_assert_cmpuint(readl(TIMER_BASE + TIMER1VALUE), ==, 500);
52
+
83
+
53
+ if (size == 3) {
84
+ /* Just past the 1000th tick: timer should have fired */
54
+ if (nregs != 4 || a->a == 0) {
85
+ clock_step(500 * 40);
55
+ return false;
86
+ g_assert_cmpuint(readl(TIMER_BASE + TIMER1RIS), ==, 1);
56
+ }
87
+ g_assert_cmpuint(readl(TIMER_BASE + TIMER1VALUE), ==, 0);
57
+ /* For VLD4 size == 3 a == 1 means 32 bits at 16 byte alignment */
58
+ size = 2;
59
+ }
60
+ if (nregs == 1 && a->a == 1 && size == 0) {
61
+ return false;
62
+ }
63
+ if (nregs == 3 && a->a == 1) {
64
+ return false;
65
+ }
66
+
67
+ if (!vfp_access_check(s)) {
68
+ return true;
69
+ }
70
+
88
+
71
+ /*
89
+ /*
72
+ * VLD1 to all lanes: T bit indicates how many Dregs to write.
90
+ * We are in free-running wrapping 16-bit mode, so on the following
73
+ * VLD2/3/4 to all lanes: T bit indicates register stride.
91
+ * tick VALUE should have wrapped round to 0xffff.
74
+ */
92
+ */
75
+ stride = a->t ? 2 : 1;
93
+ clock_step(40);
76
+ vec_size = nregs == 1 ? stride * 8 : 8;
94
+ g_assert_cmpuint(readl(TIMER_BASE + TIMER1VALUE), ==, 0xffff);
77
+
95
+
78
+ tmp = tcg_temp_new_i32();
96
+ /* Check that any write to INTCLR clears interrupt */
79
+ addr = tcg_temp_new_i32();
97
+ writel(TIMER_BASE + TIMER1INTCLR, 1);
80
+ load_reg_var(s, addr, a->rn);
98
+ g_assert_cmpuint(readl(TIMER_BASE + TIMER1RIS), ==, 0);
81
+ for (reg = 0; reg < nregs; reg++) {
82
+ gen_aa32_ld_i32(s, tmp, addr, get_mem_index(s),
83
+ s->be_data | size);
84
+ if ((vd & 1) && vec_size == 16) {
85
+ /*
86
+ * We cannot write 16 bytes at once because the
87
+ * destination is unaligned.
88
+ */
89
+ tcg_gen_gvec_dup_i32(size, neon_reg_offset(vd, 0),
90
+ 8, 8, tmp);
91
+ tcg_gen_gvec_mov(0, neon_reg_offset(vd + 1, 0),
92
+ neon_reg_offset(vd, 0), 8, 8);
93
+ } else {
94
+ tcg_gen_gvec_dup_i32(size, neon_reg_offset(vd, 0),
95
+ vec_size, vec_size, tmp);
96
+ }
97
+ tcg_gen_addi_i32(addr, addr, 1 << size);
98
+ vd += stride;
99
+ }
100
+ tcg_temp_free_i32(tmp);
101
+ tcg_temp_free_i32(addr);
102
+
99
+
103
+ gen_neon_ldst_base_update(s, a->rm, a->rn, (1 << size) * nregs);
100
+ /* Turn off the timer */
101
+ writel(TIMER_BASE + TIMER1CONTROL, 0);
102
+}
104
+
103
+
105
+ return true;
104
+static void test_prescale(void)
105
+{
106
+ g_assert_true(readl(TIMER_BASE + TIMER2RIS) == 0);
107
+
108
+ /* Start timer: will fire after 40 * 256 * 1000 == 1024000 ns */
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
+
114
+ /* Step to just past the 500th tick and check VALUE */
115
+ clock_step(40 * 256 * 501);
116
+ g_assert_cmpuint(readl(TIMER_BASE + TIMER2RIS), ==, 0);
117
+ g_assert_cmpuint(readl(TIMER_BASE + TIMER2VALUE), ==, 500);
118
+
119
+ /* Just past the 1000th tick: timer should have fired */
120
+ clock_step(40 * 256 * 500);
121
+ g_assert_cmpuint(readl(TIMER_BASE + TIMER2RIS), ==, 1);
122
+ g_assert_cmpuint(readl(TIMER_BASE + TIMER2VALUE), ==, 0);
123
+
124
+ /* In periodic mode the tick VALUE now reloads */
125
+ clock_step(40 * 256);
126
+ g_assert_cmpuint(readl(TIMER_BASE + TIMER2VALUE), ==, 1000);
127
+
128
+ /* Check that any write to INTCLR clears interrupt */
129
+ writel(TIMER_BASE + TIMER2INTCLR, 1);
130
+ g_assert_cmpuint(readl(TIMER_BASE + TIMER2RIS), ==, 0);
131
+
132
+ /* Turn off the timer */
133
+ writel(TIMER_BASE + TIMER2CONTROL, 0);
106
+}
134
+}
107
diff --git a/target/arm/translate.c b/target/arm/translate.c
135
+
136
+int main(int argc, char **argv)
137
+{
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
108
index XXXXXXX..XXXXXXX 100644
154
index XXXXXXX..XXXXXXX 100644
109
--- a/target/arm/translate.c
155
--- a/MAINTAINERS
110
+++ b/target/arm/translate.c
156
+++ b/MAINTAINERS
111
@@ -XXX,XX +XXX,XX @@ static int disas_neon_ls_insn(DisasContext *s, uint32_t insn)
157
@@ -XXX,XX +XXX,XX @@ F: include/hw/timer/cmsdk-apb-timer.h
112
int size;
158
F: tests/qtest/cmsdk-apb-timer-test.c
113
int reg;
159
F: hw/timer/cmsdk-apb-dualtimer.c
114
int load;
160
F: include/hw/timer/cmsdk-apb-dualtimer.h
115
- int vec_size;
161
+F: tests/qtest/cmsdk-apb-dualtimer-test.c
116
TCGv_i32 addr;
162
F: hw/char/cmsdk-apb-uart.c
117
TCGv_i32 tmp;
163
F: include/hw/char/cmsdk-apb-uart.h
118
164
F: hw/watchdog/cmsdk-apb-watchdog.c
119
@@ -XXX,XX +XXX,XX @@ static int disas_neon_ls_insn(DisasContext *s, uint32_t insn)
165
diff --git a/tests/qtest/meson.build b/tests/qtest/meson.build
120
} else {
166
index XXXXXXX..XXXXXXX 100644
121
size = (insn >> 10) & 3;
167
--- a/tests/qtest/meson.build
122
if (size == 3) {
168
+++ b/tests/qtest/meson.build
123
- /* Load single element to all lanes. */
169
@@ -XXX,XX +XXX,XX @@ qtests_npcm7xx = \
124
- int a = (insn >> 4) & 1;
170
'npcm7xx_timer-test',
125
- if (!load) {
171
'npcm7xx_watchdog_timer-test']
126
- return 1;
172
qtests_arm = \
127
- }
173
+ (config_all_devices.has_key('CONFIG_CMSDK_APB_DUALTIMER') ? ['cmsdk-apb-dualtimer-test'] : []) + \
128
- size = (insn >> 6) & 3;
174
(config_all_devices.has_key('CONFIG_CMSDK_APB_TIMER') ? ['cmsdk-apb-timer-test'] : []) + \
129
- nregs = ((insn >> 8) & 3) + 1;
175
(config_all_devices.has_key('CONFIG_CMSDK_APB_WATCHDOG') ? ['cmsdk-apb-watchdog-test'] : []) + \
130
-
176
(config_all_devices.has_key('CONFIG_PFLASH_CFI02') ? ['pflash-cfi02-test'] : []) + \
131
- if (size == 3) {
132
- if (nregs != 4 || a == 0) {
133
- return 1;
134
- }
135
- /* For VLD4 size==3 a == 1 means 32 bits at 16 byte alignment */
136
- size = 2;
137
- }
138
- if (nregs == 1 && a == 1 && size == 0) {
139
- return 1;
140
- }
141
- if (nregs == 3 && a == 1) {
142
- return 1;
143
- }
144
- addr = tcg_temp_new_i32();
145
- load_reg_var(s, addr, rn);
146
-
147
- /* VLD1 to all lanes: bit 5 indicates how many Dregs to write.
148
- * VLD2/3/4 to all lanes: bit 5 indicates register stride.
149
- */
150
- stride = (insn & (1 << 5)) ? 2 : 1;
151
- vec_size = nregs == 1 ? stride * 8 : 8;
152
-
153
- tmp = tcg_temp_new_i32();
154
- for (reg = 0; reg < nregs; reg++) {
155
- gen_aa32_ld_i32(s, tmp, addr, get_mem_index(s),
156
- s->be_data | size);
157
- if ((rd & 1) && vec_size == 16) {
158
- /* We cannot write 16 bytes at once because the
159
- * destination is unaligned.
160
- */
161
- tcg_gen_gvec_dup_i32(size, neon_reg_offset(rd, 0),
162
- 8, 8, tmp);
163
- tcg_gen_gvec_mov(0, neon_reg_offset(rd + 1, 0),
164
- neon_reg_offset(rd, 0), 8, 8);
165
- } else {
166
- tcg_gen_gvec_dup_i32(size, neon_reg_offset(rd, 0),
167
- vec_size, vec_size, tmp);
168
- }
169
- tcg_gen_addi_i32(addr, addr, 1 << size);
170
- rd += stride;
171
- }
172
- tcg_temp_free_i32(tmp);
173
- tcg_temp_free_i32(addr);
174
- stride = (1 << size) * nregs;
175
+ /* Load single element to all lanes -- handled by decodetree */
176
+ return 1;
177
} else {
178
/* Single element. */
179
int idx = (insn >> 4) & 0xf;
180
--
177
--
181
2.20.1
178
2.20.1
182
179
183
180
diff view generated by jsdifflib
1
Convert the Neon comparison ops in the 3-reg-same grouping
1
The state struct for the CMSDK APB timer device doesn't follow our
2
to decodetree.
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
8
Commit created with:
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
3
10
4
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
11
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
5
Reviewed-by: Richard Henderson <richard.henderson@linaro.org>
12
Reviewed-by: Philippe Mathieu-Daudé <f4bug@amsat.org>
6
Message-id: 20200430181003.21682-18-peter.maydell@linaro.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
7
---
17
---
8
target/arm/neon-dp.decode | 8 ++++++++
18
include/hw/arm/armsse.h | 6 +++---
9
target/arm/translate-neon.inc.c | 22 ++++++++++++++++++++++
19
include/hw/timer/cmsdk-apb-timer.h | 4 ++--
10
target/arm/translate.c | 23 +++--------------------
20
hw/timer/cmsdk-apb-timer.c | 28 ++++++++++++++--------------
11
3 files changed, 33 insertions(+), 20 deletions(-)
21
3 files changed, 19 insertions(+), 19 deletions(-)
12
22
13
diff --git a/target/arm/neon-dp.decode b/target/arm/neon-dp.decode
23
diff --git a/include/hw/arm/armsse.h b/include/hw/arm/armsse.h
14
index XXXXXXX..XXXXXXX 100644
24
index XXXXXXX..XXXXXXX 100644
15
--- a/target/arm/neon-dp.decode
25
--- a/include/hw/arm/armsse.h
16
+++ b/target/arm/neon-dp.decode
26
+++ b/include/hw/arm/armsse.h
17
@@ -XXX,XX +XXX,XX @@ VBSL_3s 1111 001 1 0 . 01 .... .... 0001 ... 1 .... @3same_logic
27
@@ -XXX,XX +XXX,XX @@ struct ARMSSE {
18
VBIT_3s 1111 001 1 0 . 10 .... .... 0001 ... 1 .... @3same_logic
28
TZPPC apb_ppc0;
19
VBIF_3s 1111 001 1 0 . 11 .... .... 0001 ... 1 .... @3same_logic
29
TZPPC apb_ppc1;
20
30
TZMPC mpc[IOTS_NUM_MPC];
21
+VCGT_S_3s 1111 001 0 0 . .. .... .... 0011 . . . 0 .... @3same
31
- CMSDKAPBTIMER timer0;
22
+VCGT_U_3s 1111 001 1 0 . .. .... .... 0011 . . . 0 .... @3same
32
- CMSDKAPBTIMER timer1;
23
+VCGE_S_3s 1111 001 0 0 . .. .... .... 0011 . . . 1 .... @3same
33
- CMSDKAPBTIMER s32ktimer;
24
+VCGE_U_3s 1111 001 1 0 . .. .... .... 0011 . . . 1 .... @3same
34
+ CMSDKAPBTimer timer0;
25
+
35
+ CMSDKAPBTimer timer1;
26
VMAX_S_3s 1111 001 0 0 . .. .... .... 0110 . . . 0 .... @3same
36
+ CMSDKAPBTimer s32ktimer;
27
VMAX_U_3s 1111 001 1 0 . .. .... .... 0110 . . . 0 .... @3same
37
qemu_or_irq ppc_irq_orgate;
28
VMIN_S_3s 1111 001 0 0 . .. .... .... 0110 . . . 1 .... @3same
38
SplitIRQ sec_resp_splitter;
29
@@ -XXX,XX +XXX,XX @@ VMIN_U_3s 1111 001 1 0 . .. .... .... 0110 . . . 1 .... @3same
39
SplitIRQ ppc_irq_splitter[NUM_PPCS];
30
40
diff --git a/include/hw/timer/cmsdk-apb-timer.h b/include/hw/timer/cmsdk-apb-timer.h
31
VADD_3s 1111 001 0 0 . .. .... .... 1000 . . . 0 .... @3same
32
VSUB_3s 1111 001 1 0 . .. .... .... 1000 . . . 0 .... @3same
33
+
34
+VTST_3s 1111 001 0 0 . .. .... .... 1000 . . . 1 .... @3same
35
+VCEQ_3s 1111 001 1 0 . .. .... .... 1000 . . . 1 .... @3same
36
diff --git a/target/arm/translate-neon.inc.c b/target/arm/translate-neon.inc.c
37
index XXXXXXX..XXXXXXX 100644
41
index XXXXXXX..XXXXXXX 100644
38
--- a/target/arm/translate-neon.inc.c
42
--- a/include/hw/timer/cmsdk-apb-timer.h
39
+++ b/target/arm/translate-neon.inc.c
43
+++ b/include/hw/timer/cmsdk-apb-timer.h
40
@@ -XXX,XX +XXX,XX @@ DO_3SAME_NO_SZ_3(VMAX_S, tcg_gen_gvec_smax)
44
@@ -XXX,XX +XXX,XX @@
41
DO_3SAME_NO_SZ_3(VMAX_U, tcg_gen_gvec_umax)
45
#include "qom/object.h"
42
DO_3SAME_NO_SZ_3(VMIN_S, tcg_gen_gvec_smin)
46
43
DO_3SAME_NO_SZ_3(VMIN_U, tcg_gen_gvec_umin)
47
#define TYPE_CMSDK_APB_TIMER "cmsdk-apb-timer"
44
+
48
-OBJECT_DECLARE_SIMPLE_TYPE(CMSDKAPBTIMER, CMSDK_APB_TIMER)
45
+#define DO_3SAME_CMP(INSN, COND) \
49
+OBJECT_DECLARE_SIMPLE_TYPE(CMSDKAPBTimer, CMSDK_APB_TIMER)
46
+ static void gen_##INSN##_3s(unsigned vece, uint32_t rd_ofs, \
50
47
+ uint32_t rn_ofs, uint32_t rm_ofs, \
51
-struct CMSDKAPBTIMER {
48
+ uint32_t oprsz, uint32_t maxsz) \
52
+struct CMSDKAPBTimer {
49
+ { \
53
/*< private >*/
50
+ tcg_gen_gvec_cmp(COND, vece, rd_ofs, rn_ofs, rm_ofs, oprsz, maxsz); \
54
SysBusDevice parent_obj;
51
+ } \
55
52
+ DO_3SAME_NO_SZ_3(INSN, gen_##INSN##_3s)
56
diff --git a/hw/timer/cmsdk-apb-timer.c b/hw/timer/cmsdk-apb-timer.c
53
+
54
+DO_3SAME_CMP(VCGT_S, TCG_COND_GT)
55
+DO_3SAME_CMP(VCGT_U, TCG_COND_GTU)
56
+DO_3SAME_CMP(VCGE_S, TCG_COND_GE)
57
+DO_3SAME_CMP(VCGE_U, TCG_COND_GEU)
58
+DO_3SAME_CMP(VCEQ, TCG_COND_EQ)
59
+
60
+static void gen_VTST_3s(unsigned vece, uint32_t rd_ofs, uint32_t rn_ofs,
61
+ uint32_t rm_ofs, uint32_t oprsz, uint32_t maxsz)
62
+{
63
+ tcg_gen_gvec_3(rd_ofs, rn_ofs, rm_ofs, oprsz, maxsz, &cmtst_op[vece]);
64
+}
65
+DO_3SAME_NO_SZ_3(VTST, gen_VTST_3s)
66
diff --git a/target/arm/translate.c b/target/arm/translate.c
67
index XXXXXXX..XXXXXXX 100644
57
index XXXXXXX..XXXXXXX 100644
68
--- a/target/arm/translate.c
58
--- a/hw/timer/cmsdk-apb-timer.c
69
+++ b/target/arm/translate.c
59
+++ b/hw/timer/cmsdk-apb-timer.c
70
@@ -XXX,XX +XXX,XX @@ static int disas_neon_data_insn(DisasContext *s, uint32_t insn)
60
@@ -XXX,XX +XXX,XX @@ static const int timer_id[] = {
71
u ? &mls_op[size] : &mla_op[size]);
61
0x0d, 0xf0, 0x05, 0xb1, /* CID0..CID3 */
72
return 0;
62
};
73
63
74
- case NEON_3R_VTST_VCEQ:
64
-static void cmsdk_apb_timer_update(CMSDKAPBTIMER *s)
75
- if (u) { /* VCEQ */
65
+static void cmsdk_apb_timer_update(CMSDKAPBTimer *s)
76
- tcg_gen_gvec_cmp(TCG_COND_EQ, size, rd_ofs, rn_ofs, rm_ofs,
66
{
77
- vec_size, vec_size);
67
qemu_set_irq(s->timerint, !!(s->intstatus & R_INTSTATUS_IRQ_MASK));
78
- } else { /* VTST */
68
}
79
- tcg_gen_gvec_3(rd_ofs, rn_ofs, rm_ofs,
69
80
- vec_size, vec_size, &cmtst_op[size]);
70
static uint64_t cmsdk_apb_timer_read(void *opaque, hwaddr offset, unsigned size)
81
- }
71
{
82
- return 0;
72
- CMSDKAPBTIMER *s = CMSDK_APB_TIMER(opaque);
83
-
73
+ CMSDKAPBTimer *s = CMSDK_APB_TIMER(opaque);
84
- case NEON_3R_VCGT:
74
uint64_t r;
85
- tcg_gen_gvec_cmp(u ? TCG_COND_GTU : TCG_COND_GT, size,
75
86
- rd_ofs, rn_ofs, rm_ofs, vec_size, vec_size);
76
switch (offset) {
87
- return 0;
77
@@ -XXX,XX +XXX,XX @@ static uint64_t cmsdk_apb_timer_read(void *opaque, hwaddr offset, unsigned size)
88
-
78
static void cmsdk_apb_timer_write(void *opaque, hwaddr offset, uint64_t value,
89
- case NEON_3R_VCGE:
79
unsigned size)
90
- tcg_gen_gvec_cmp(u ? TCG_COND_GEU : TCG_COND_GE, size,
80
{
91
- rd_ofs, rn_ofs, rm_ofs, vec_size, vec_size);
81
- CMSDKAPBTIMER *s = CMSDK_APB_TIMER(opaque);
92
- return 0;
82
+ CMSDKAPBTimer *s = CMSDK_APB_TIMER(opaque);
93
-
83
94
case NEON_3R_VSHL:
84
trace_cmsdk_apb_timer_write(offset, value, size);
95
/* Note the operation is vshl vd,vm,vn */
85
96
tcg_gen_gvec_3(rd_ofs, rm_ofs, rn_ofs, vec_size, vec_size,
86
@@ -XXX,XX +XXX,XX @@ static const MemoryRegionOps cmsdk_apb_timer_ops = {
97
@@ -XXX,XX +XXX,XX @@ static int disas_neon_data_insn(DisasContext *s, uint32_t insn)
87
98
case NEON_3R_LOGIC:
88
static void cmsdk_apb_timer_tick(void *opaque)
99
case NEON_3R_VMAX:
89
{
100
case NEON_3R_VMIN:
90
- CMSDKAPBTIMER *s = CMSDK_APB_TIMER(opaque);
101
+ case NEON_3R_VTST_VCEQ:
91
+ CMSDKAPBTimer *s = CMSDK_APB_TIMER(opaque);
102
+ case NEON_3R_VCGT:
92
103
+ case NEON_3R_VCGE:
93
if (s->ctrl & R_CTRL_IRQEN_MASK) {
104
/* Already handled by decodetree */
94
s->intstatus |= R_INTSTATUS_IRQ_MASK;
105
return 1;
95
@@ -XXX,XX +XXX,XX @@ static void cmsdk_apb_timer_tick(void *opaque)
106
}
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
};
107
--
155
--
108
2.20.1
156
2.20.1
109
157
110
158
diff view generated by jsdifflib
1
Convert the Neon 3-reg-same VMAX and VMIN insns to decodetree.
1
As the first step in converting the CMSDK_APB_TIMER device to the
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
7
Since the device doesn't already have a doc comment for its "QEMU
8
interface", we add one including the new Clock.
9
10
This is a migration compatibility break for machines mps2-an505,
11
mps2-an521, musca-a, musca-b1.
2
12
3
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
13
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
4
Reviewed-by: Richard Henderson <richard.henderson@linaro.org>
14
Reviewed-by: Philippe Mathieu-Daudé <f4bug@amsat.org>
5
Message-id: 20200430181003.21682-17-peter.maydell@linaro.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
6
---
19
---
7
target/arm/neon-dp.decode | 5 +++++
20
include/hw/timer/cmsdk-apb-timer.h | 9 +++++++++
8
target/arm/translate-neon.inc.c | 14 ++++++++++++++
21
hw/timer/cmsdk-apb-timer.c | 7 +++++--
9
target/arm/translate.c | 21 ++-------------------
22
2 files changed, 14 insertions(+), 2 deletions(-)
10
3 files changed, 21 insertions(+), 19 deletions(-)
11
23
12
diff --git a/target/arm/neon-dp.decode b/target/arm/neon-dp.decode
24
diff --git a/include/hw/timer/cmsdk-apb-timer.h b/include/hw/timer/cmsdk-apb-timer.h
13
index XXXXXXX..XXXXXXX 100644
25
index XXXXXXX..XXXXXXX 100644
14
--- a/target/arm/neon-dp.decode
26
--- a/include/hw/timer/cmsdk-apb-timer.h
15
+++ b/target/arm/neon-dp.decode
27
+++ b/include/hw/timer/cmsdk-apb-timer.h
16
@@ -XXX,XX +XXX,XX @@ VBSL_3s 1111 001 1 0 . 01 .... .... 0001 ... 1 .... @3same_logic
28
@@ -XXX,XX +XXX,XX @@
17
VBIT_3s 1111 001 1 0 . 10 .... .... 0001 ... 1 .... @3same_logic
29
#include "hw/qdev-properties.h"
18
VBIF_3s 1111 001 1 0 . 11 .... .... 0001 ... 1 .... @3same_logic
30
#include "hw/sysbus.h"
19
31
#include "hw/ptimer.h"
20
+VMAX_S_3s 1111 001 0 0 . .. .... .... 0110 . . . 0 .... @3same
32
+#include "hw/clock.h"
21
+VMAX_U_3s 1111 001 1 0 . .. .... .... 0110 . . . 0 .... @3same
33
#include "qom/object.h"
22
+VMIN_S_3s 1111 001 0 0 . .. .... .... 0110 . . . 1 .... @3same
34
23
+VMIN_U_3s 1111 001 1 0 . .. .... .... 0110 . . . 1 .... @3same
35
#define TYPE_CMSDK_APB_TIMER "cmsdk-apb-timer"
24
+
36
OBJECT_DECLARE_SIMPLE_TYPE(CMSDKAPBTimer, CMSDK_APB_TIMER)
25
VADD_3s 1111 001 0 0 . .. .... .... 1000 . . . 0 .... @3same
37
26
VSUB_3s 1111 001 1 0 . .. .... .... 1000 . . . 0 .... @3same
38
+/*
27
diff --git a/target/arm/translate-neon.inc.c b/target/arm/translate-neon.inc.c
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
28
index XXXXXXX..XXXXXXX 100644
57
index XXXXXXX..XXXXXXX 100644
29
--- a/target/arm/translate-neon.inc.c
58
--- a/hw/timer/cmsdk-apb-timer.c
30
+++ b/target/arm/translate-neon.inc.c
59
+++ b/hw/timer/cmsdk-apb-timer.c
31
@@ -XXX,XX +XXX,XX @@ DO_3SAME(VEOR, tcg_gen_gvec_xor)
60
@@ -XXX,XX +XXX,XX @@
32
DO_3SAME_BITSEL(VBSL, rd_ofs, rn_ofs, rm_ofs)
61
#include "hw/sysbus.h"
33
DO_3SAME_BITSEL(VBIT, rm_ofs, rn_ofs, rd_ofs)
62
#include "hw/irq.h"
34
DO_3SAME_BITSEL(VBIF, rm_ofs, rd_ofs, rn_ofs)
63
#include "hw/registerfields.h"
35
+
64
+#include "hw/qdev-clock.h"
36
+#define DO_3SAME_NO_SZ_3(INSN, FUNC) \
65
#include "hw/timer/cmsdk-apb-timer.h"
37
+ static bool trans_##INSN##_3s(DisasContext *s, arg_3same *a) \
66
#include "migration/vmstate.h"
38
+ { \
67
39
+ if (a->size == 3) { \
68
@@ -XXX,XX +XXX,XX @@ static void cmsdk_apb_timer_init(Object *obj)
40
+ return false; \
69
s, "cmsdk-apb-timer", 0x1000);
41
+ } \
70
sysbus_init_mmio(sbd, &s->iomem);
42
+ return do_3same(s, a, FUNC); \
71
sysbus_init_irq(sbd, &s->timerint);
43
+ }
72
+ s->pclk = qdev_init_clock_in(DEVICE(s), "pclk", NULL, NULL);
44
+
73
}
45
+DO_3SAME_NO_SZ_3(VMAX_S, tcg_gen_gvec_smax)
74
46
+DO_3SAME_NO_SZ_3(VMAX_U, tcg_gen_gvec_umax)
75
static void cmsdk_apb_timer_realize(DeviceState *dev, Error **errp)
47
+DO_3SAME_NO_SZ_3(VMIN_S, tcg_gen_gvec_smin)
76
@@ -XXX,XX +XXX,XX @@ static void cmsdk_apb_timer_realize(DeviceState *dev, Error **errp)
48
+DO_3SAME_NO_SZ_3(VMIN_U, tcg_gen_gvec_umin)
77
49
diff --git a/target/arm/translate.c b/target/arm/translate.c
78
static const VMStateDescription cmsdk_apb_timer_vmstate = {
50
index XXXXXXX..XXXXXXX 100644
79
.name = "cmsdk-apb-timer",
51
--- a/target/arm/translate.c
80
- .version_id = 1,
52
+++ b/target/arm/translate.c
81
- .minimum_version_id = 1,
53
@@ -XXX,XX +XXX,XX @@ static int disas_neon_data_insn(DisasContext *s, uint32_t insn)
82
+ .version_id = 2,
54
rd_ofs, rn_ofs, rm_ofs, vec_size, vec_size);
83
+ .minimum_version_id = 2,
55
return 0;
84
.fields = (VMStateField[]) {
56
85
VMSTATE_PTIMER(timer, CMSDKAPBTimer),
57
- case NEON_3R_VMAX:
86
+ VMSTATE_CLOCK(pclk, CMSDKAPBTimer),
58
- if (u) {
87
VMSTATE_UINT32(ctrl, CMSDKAPBTimer),
59
- tcg_gen_gvec_umax(size, rd_ofs, rn_ofs, rm_ofs,
88
VMSTATE_UINT32(value, CMSDKAPBTimer),
60
- vec_size, vec_size);
89
VMSTATE_UINT32(reload, CMSDKAPBTimer),
61
- } else {
62
- tcg_gen_gvec_smax(size, rd_ofs, rn_ofs, rm_ofs,
63
- vec_size, vec_size);
64
- }
65
- return 0;
66
- case NEON_3R_VMIN:
67
- if (u) {
68
- tcg_gen_gvec_umin(size, rd_ofs, rn_ofs, rm_ofs,
69
- vec_size, vec_size);
70
- } else {
71
- tcg_gen_gvec_smin(size, rd_ofs, rn_ofs, rm_ofs,
72
- vec_size, vec_size);
73
- }
74
- return 0;
75
-
76
case NEON_3R_VSHL:
77
/* Note the operation is vshl vd,vm,vn */
78
tcg_gen_gvec_3(rd_ofs, rm_ofs, rn_ofs, vec_size, vec_size,
79
@@ -XXX,XX +XXX,XX @@ static int disas_neon_data_insn(DisasContext *s, uint32_t insn)
80
81
case NEON_3R_VADD_VSUB:
82
case NEON_3R_LOGIC:
83
+ case NEON_3R_VMAX:
84
+ case NEON_3R_VMIN:
85
/* Already handled by decodetree */
86
return 1;
87
}
88
--
90
--
89
2.20.1
91
2.20.1
90
92
91
93
diff view generated by jsdifflib
1
Convert the Neon logic ops in the 3-reg-same grouping to decodetree.
1
As the first step in converting the CMSDK_APB_DUALTIMER device to the
2
Note that for the logic ops the 'size' field forms part of their
2
Clock framework, add a Clock input. For the moment we do nothing
3
decode and the actual operations are always bitwise.
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
7
We take the opportunity to correct the name of the clock input to
8
match the hardware -- the dual timer names the clock which drives the
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
13
This is a migration compatibility break for machines mps2-an385,
14
mps2-an386, mps2-an500, mps2-an511, mps2-an505, mps2-an521, musca-a,
15
musca-b1.
4
16
5
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
17
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
6
Reviewed-by: Richard Henderson <richard.henderson@linaro.org>
18
Reviewed-by: Philippe Mathieu-Daudé <f4bug@amsat.org>
7
Message-id: 20200430181003.21682-16-peter.maydell@linaro.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
8
---
23
---
9
target/arm/neon-dp.decode | 12 +++++++++++
24
include/hw/timer/cmsdk-apb-dualtimer.h | 3 +++
10
target/arm/translate-neon.inc.c | 19 +++++++++++++++++
25
hw/timer/cmsdk-apb-dualtimer.c | 7 +++++--
11
target/arm/translate.c | 38 +--------------------------------
26
2 files changed, 8 insertions(+), 2 deletions(-)
12
3 files changed, 32 insertions(+), 37 deletions(-)
13
27
14
diff --git a/target/arm/neon-dp.decode b/target/arm/neon-dp.decode
28
diff --git a/include/hw/timer/cmsdk-apb-dualtimer.h b/include/hw/timer/cmsdk-apb-dualtimer.h
15
index XXXXXXX..XXXXXXX 100644
29
index XXXXXXX..XXXXXXX 100644
16
--- a/target/arm/neon-dp.decode
30
--- a/include/hw/timer/cmsdk-apb-dualtimer.h
17
+++ b/target/arm/neon-dp.decode
31
+++ b/include/hw/timer/cmsdk-apb-dualtimer.h
18
@@ -XXX,XX +XXX,XX @@
32
@@ -XXX,XX +XXX,XX @@
19
@3same .... ... . . . size:2 .... .... .... . q:1 . . .... \
33
*
20
&3same vm=%vm_dp vn=%vn_dp vd=%vd_dp
34
* QEMU interface:
21
35
* + QOM property "pclk-frq": frequency at which the timer is clocked
22
+@3same_logic .... ... . . . .. .... .... .... . q:1 .. .... \
36
+ * + Clock input "TIMCLK": clock (for both timers)
23
+ &3same vm=%vm_dp vn=%vn_dp vd=%vd_dp size=0
37
* + sysbus MMIO region 0: the register bank
24
+
38
* + sysbus IRQ 0: combined timer interrupt TIMINTC
25
+VAND_3s 1111 001 0 0 . 00 .... .... 0001 ... 1 .... @3same_logic
39
* + sysbus IRO 1: timer block 1 interrupt TIMINT1
26
+VBIC_3s 1111 001 0 0 . 01 .... .... 0001 ... 1 .... @3same_logic
40
@@ -XXX,XX +XXX,XX @@
27
+VORR_3s 1111 001 0 0 . 10 .... .... 0001 ... 1 .... @3same_logic
41
28
+VORN_3s 1111 001 0 0 . 11 .... .... 0001 ... 1 .... @3same_logic
42
#include "hw/sysbus.h"
29
+VEOR_3s 1111 001 1 0 . 00 .... .... 0001 ... 1 .... @3same_logic
43
#include "hw/ptimer.h"
30
+VBSL_3s 1111 001 1 0 . 01 .... .... 0001 ... 1 .... @3same_logic
44
+#include "hw/clock.h"
31
+VBIT_3s 1111 001 1 0 . 10 .... .... 0001 ... 1 .... @3same_logic
45
#include "qom/object.h"
32
+VBIF_3s 1111 001 1 0 . 11 .... .... 0001 ... 1 .... @3same_logic
46
33
+
47
#define TYPE_CMSDK_APB_DUALTIMER "cmsdk-apb-dualtimer"
34
VADD_3s 1111 001 0 0 . .. .... .... 1000 . . . 0 .... @3same
48
@@ -XXX,XX +XXX,XX @@ struct CMSDKAPBDualTimer {
35
VSUB_3s 1111 001 1 0 . .. .... .... 1000 . . . 0 .... @3same
49
MemoryRegion iomem;
36
diff --git a/target/arm/translate-neon.inc.c b/target/arm/translate-neon.inc.c
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
37
index XXXXXXX..XXXXXXX 100644
57
index XXXXXXX..XXXXXXX 100644
38
--- a/target/arm/translate-neon.inc.c
58
--- a/hw/timer/cmsdk-apb-dualtimer.c
39
+++ b/target/arm/translate-neon.inc.c
59
+++ b/hw/timer/cmsdk-apb-dualtimer.c
40
@@ -XXX,XX +XXX,XX @@ static bool do_3same(DisasContext *s, arg_3same *a, GVecGen3Fn fn)
60
@@ -XXX,XX +XXX,XX @@
41
61
#include "hw/irq.h"
42
DO_3SAME(VADD, tcg_gen_gvec_add)
62
#include "hw/qdev-properties.h"
43
DO_3SAME(VSUB, tcg_gen_gvec_sub)
63
#include "hw/registerfields.h"
44
+DO_3SAME(VAND, tcg_gen_gvec_and)
64
+#include "hw/qdev-clock.h"
45
+DO_3SAME(VBIC, tcg_gen_gvec_andc)
65
#include "hw/timer/cmsdk-apb-dualtimer.h"
46
+DO_3SAME(VORR, tcg_gen_gvec_or)
66
#include "migration/vmstate.h"
47
+DO_3SAME(VORN, tcg_gen_gvec_orc)
67
48
+DO_3SAME(VEOR, tcg_gen_gvec_xor)
68
@@ -XXX,XX +XXX,XX @@ static void cmsdk_apb_dualtimer_init(Object *obj)
49
+
69
for (i = 0; i < ARRAY_SIZE(s->timermod); i++) {
50
+/* These insns are all gvec_bitsel but with the inputs in various orders. */
70
sysbus_init_irq(sbd, &s->timermod[i].timerint);
51
+#define DO_3SAME_BITSEL(INSN, O1, O2, O3) \
71
}
52
+ static void gen_##INSN##_3s(unsigned vece, uint32_t rd_ofs, \
72
+ s->timclk = qdev_init_clock_in(DEVICE(s), "TIMCLK", NULL, NULL);
53
+ uint32_t rn_ofs, uint32_t rm_ofs, \
73
}
54
+ uint32_t oprsz, uint32_t maxsz) \
74
55
+ { \
75
static void cmsdk_apb_dualtimer_realize(DeviceState *dev, Error **errp)
56
+ tcg_gen_gvec_bitsel(vece, rd_ofs, O1, O2, O3, oprsz, maxsz); \
76
@@ -XXX,XX +XXX,XX @@ static const VMStateDescription cmsdk_dualtimermod_vmstate = {
57
+ } \
77
58
+ DO_3SAME(INSN, gen_##INSN##_3s)
78
static const VMStateDescription cmsdk_apb_dualtimer_vmstate = {
59
+
79
.name = "cmsdk-apb-dualtimer",
60
+DO_3SAME_BITSEL(VBSL, rd_ofs, rn_ofs, rm_ofs)
80
- .version_id = 1,
61
+DO_3SAME_BITSEL(VBIT, rm_ofs, rn_ofs, rd_ofs)
81
- .minimum_version_id = 1,
62
+DO_3SAME_BITSEL(VBIF, rm_ofs, rd_ofs, rn_ofs)
82
+ .version_id = 2,
63
diff --git a/target/arm/translate.c b/target/arm/translate.c
83
+ .minimum_version_id = 2,
64
index XXXXXXX..XXXXXXX 100644
84
.fields = (VMStateField[]) {
65
--- a/target/arm/translate.c
85
+ VMSTATE_CLOCK(timclk, CMSDKAPBDualTimer),
66
+++ b/target/arm/translate.c
86
VMSTATE_STRUCT_ARRAY(timermod, CMSDKAPBDualTimer,
67
@@ -XXX,XX +XXX,XX @@ static int disas_neon_data_insn(DisasContext *s, uint32_t insn)
87
CMSDK_APB_DUALTIMER_NUM_MODULES,
68
}
88
1, cmsdk_dualtimermod_vmstate,
69
return 1;
70
71
- case NEON_3R_LOGIC: /* Logic ops. */
72
- switch ((u << 2) | size) {
73
- case 0: /* VAND */
74
- tcg_gen_gvec_and(0, rd_ofs, rn_ofs, rm_ofs,
75
- vec_size, vec_size);
76
- break;
77
- case 1: /* VBIC */
78
- tcg_gen_gvec_andc(0, rd_ofs, rn_ofs, rm_ofs,
79
- vec_size, vec_size);
80
- break;
81
- case 2: /* VORR */
82
- tcg_gen_gvec_or(0, rd_ofs, rn_ofs, rm_ofs,
83
- vec_size, vec_size);
84
- break;
85
- case 3: /* VORN */
86
- tcg_gen_gvec_orc(0, rd_ofs, rn_ofs, rm_ofs,
87
- vec_size, vec_size);
88
- break;
89
- case 4: /* VEOR */
90
- tcg_gen_gvec_xor(0, rd_ofs, rn_ofs, rm_ofs,
91
- vec_size, vec_size);
92
- break;
93
- case 5: /* VBSL */
94
- tcg_gen_gvec_bitsel(MO_8, rd_ofs, rd_ofs, rn_ofs, rm_ofs,
95
- vec_size, vec_size);
96
- break;
97
- case 6: /* VBIT */
98
- tcg_gen_gvec_bitsel(MO_8, rd_ofs, rm_ofs, rn_ofs, rd_ofs,
99
- vec_size, vec_size);
100
- break;
101
- case 7: /* VBIF */
102
- tcg_gen_gvec_bitsel(MO_8, rd_ofs, rm_ofs, rd_ofs, rn_ofs,
103
- vec_size, vec_size);
104
- break;
105
- }
106
- return 0;
107
-
108
case NEON_3R_VQADD:
109
tcg_gen_gvec_4(rd_ofs, offsetof(CPUARMState, vfp.qc),
110
rn_ofs, rm_ofs, vec_size, vec_size,
111
@@ -XXX,XX +XXX,XX @@ static int disas_neon_data_insn(DisasContext *s, uint32_t insn)
112
return 0;
113
114
case NEON_3R_VADD_VSUB:
115
+ case NEON_3R_LOGIC:
116
/* Already handled by decodetree */
117
return 1;
118
}
119
--
89
--
120
2.20.1
90
2.20.1
121
91
122
92
diff view generated by jsdifflib
1
Convert the V[US]DOT (scalar) insns in the 2reg-scalar-ext group
1
As the first step in converting the CMSDK_APB_TIMER device to the
2
to decodetree.
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
7
This is a migration compatibility break for machines mps2-an385,
8
mps2-an386, mps2-an500, mps2-an511, mps2-an505, mps2-an521, musca-a,
9
musca-b1, lm3s811evb, lm3s6965evb.
3
10
4
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
11
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
5
Reviewed-by: Richard Henderson <richard.henderson@linaro.org>
12
Reviewed-by: Philippe Mathieu-Daudé <f4bug@amsat.org>
6
Message-id: 20200430181003.21682-10-peter.maydell@linaro.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
7
---
17
---
8
target/arm/neon-shared.decode | 3 +++
18
include/hw/watchdog/cmsdk-apb-watchdog.h | 3 +++
9
target/arm/translate-neon.inc.c | 35 +++++++++++++++++++++++++++++++++
19
hw/watchdog/cmsdk-apb-watchdog.c | 7 +++++--
10
target/arm/translate.c | 13 +-----------
20
2 files changed, 8 insertions(+), 2 deletions(-)
11
3 files changed, 39 insertions(+), 12 deletions(-)
12
21
13
diff --git a/target/arm/neon-shared.decode b/target/arm/neon-shared.decode
22
diff --git a/include/hw/watchdog/cmsdk-apb-watchdog.h b/include/hw/watchdog/cmsdk-apb-watchdog.h
14
index XXXXXXX..XXXXXXX 100644
23
index XXXXXXX..XXXXXXX 100644
15
--- a/target/arm/neon-shared.decode
24
--- a/include/hw/watchdog/cmsdk-apb-watchdog.h
16
+++ b/target/arm/neon-shared.decode
25
+++ b/include/hw/watchdog/cmsdk-apb-watchdog.h
17
@@ -XXX,XX +XXX,XX @@ VCMLA_scalar 1111 1110 0 . rot:2 .... .... 1000 . q:1 index:1 0 vm:4 \
26
@@ -XXX,XX +XXX,XX @@
18
vn=%vn_dp vd=%vd_dp size=0
27
*
19
VCMLA_scalar 1111 1110 1 . rot:2 .... .... 1000 . q:1 . 0 .... \
28
* QEMU interface:
20
vm=%vm_dp vn=%vn_dp vd=%vd_dp size=1 index=0
29
* + QOM property "wdogclk-frq": frequency at which the watchdog is clocked
21
+
30
+ * + Clock input "WDOGCLK": clock for the watchdog's timer
22
+VDOT_scalar 1111 1110 0 . 10 .... .... 1101 . q:1 index:1 u:1 rm:4 \
31
* + sysbus MMIO region 0: the register bank
23
+ vm=%vm_dp vn=%vn_dp vd=%vd_dp
32
* + sysbus IRQ 0: watchdog interrupt
24
diff --git a/target/arm/translate-neon.inc.c b/target/arm/translate-neon.inc.c
33
*
34
@@ -XXX,XX +XXX,XX @@
35
36
#include "hw/sysbus.h"
37
#include "hw/ptimer.h"
38
+#include "hw/clock.h"
39
#include "qom/object.h"
40
41
#define TYPE_CMSDK_APB_WATCHDOG "cmsdk-apb-watchdog"
42
@@ -XXX,XX +XXX,XX @@ struct CMSDKAPBWatchdog {
43
uint32_t wdogclk_frq;
44
bool is_luminary;
45
struct ptimer_state *timer;
46
+ Clock *wdogclk;
47
48
uint32_t control;
49
uint32_t intstatus;
50
diff --git a/hw/watchdog/cmsdk-apb-watchdog.c b/hw/watchdog/cmsdk-apb-watchdog.c
25
index XXXXXXX..XXXXXXX 100644
51
index XXXXXXX..XXXXXXX 100644
26
--- a/target/arm/translate-neon.inc.c
52
--- a/hw/watchdog/cmsdk-apb-watchdog.c
27
+++ b/target/arm/translate-neon.inc.c
53
+++ b/hw/watchdog/cmsdk-apb-watchdog.c
28
@@ -XXX,XX +XXX,XX @@ static bool trans_VCMLA_scalar(DisasContext *s, arg_VCMLA_scalar *a)
54
@@ -XXX,XX +XXX,XX @@
29
tcg_temp_free_ptr(fpst);
55
#include "hw/irq.h"
30
return true;
56
#include "hw/qdev-properties.h"
31
}
57
#include "hw/registerfields.h"
32
+
58
+#include "hw/qdev-clock.h"
33
+static bool trans_VDOT_scalar(DisasContext *s, arg_VDOT_scalar *a)
59
#include "hw/watchdog/cmsdk-apb-watchdog.h"
34
+{
60
#include "migration/vmstate.h"
35
+ gen_helper_gvec_3 *fn_gvec;
61
36
+ int opr_sz;
62
@@ -XXX,XX +XXX,XX @@ static void cmsdk_apb_watchdog_init(Object *obj)
37
+ TCGv_ptr fpst;
63
s, "cmsdk-apb-watchdog", 0x1000);
38
+
64
sysbus_init_mmio(sbd, &s->iomem);
39
+ if (!dc_isar_feature(aa32_dp, s)) {
65
sysbus_init_irq(sbd, &s->wdogint);
40
+ return false;
66
+ s->wdogclk = qdev_init_clock_in(DEVICE(s), "WDOGCLK", NULL, NULL);
41
+ }
67
42
+
68
s->is_luminary = false;
43
+ /* UNDEF accesses to D16-D31 if they don't exist. */
69
s->id = cmsdk_apb_watchdog_id;
44
+ if (!dc_isar_feature(aa32_simd_r32, s) &&
70
@@ -XXX,XX +XXX,XX @@ static void cmsdk_apb_watchdog_realize(DeviceState *dev, Error **errp)
45
+ ((a->vd | a->vn) & 0x10)) {
71
46
+ return false;
72
static const VMStateDescription cmsdk_apb_watchdog_vmstate = {
47
+ }
73
.name = "cmsdk-apb-watchdog",
48
+
74
- .version_id = 1,
49
+ if ((a->vd | a->vn) & a->q) {
75
- .minimum_version_id = 1,
50
+ return false;
76
+ .version_id = 2,
51
+ }
77
+ .minimum_version_id = 2,
52
+
78
.fields = (VMStateField[]) {
53
+ if (!vfp_access_check(s)) {
79
+ VMSTATE_CLOCK(wdogclk, CMSDKAPBWatchdog),
54
+ return true;
80
VMSTATE_PTIMER(timer, CMSDKAPBWatchdog),
55
+ }
81
VMSTATE_UINT32(control, CMSDKAPBWatchdog),
56
+
82
VMSTATE_UINT32(intstatus, CMSDKAPBWatchdog),
57
+ fn_gvec = a->u ? gen_helper_gvec_udot_idx_b : gen_helper_gvec_sdot_idx_b;
58
+ opr_sz = (1 + a->q) * 8;
59
+ fpst = get_fpstatus_ptr(1);
60
+ tcg_gen_gvec_3_ool(vfp_reg_offset(1, a->vd),
61
+ vfp_reg_offset(1, a->vn),
62
+ vfp_reg_offset(1, a->rm),
63
+ opr_sz, opr_sz, a->index, fn_gvec);
64
+ tcg_temp_free_ptr(fpst);
65
+ return true;
66
+}
67
diff --git a/target/arm/translate.c b/target/arm/translate.c
68
index XXXXXXX..XXXXXXX 100644
69
--- a/target/arm/translate.c
70
+++ b/target/arm/translate.c
71
@@ -XXX,XX +XXX,XX @@ static int disas_neon_insn_2reg_scalar_ext(DisasContext *s, uint32_t insn)
72
bool is_long = false, q = extract32(insn, 6, 1);
73
bool ptr_is_env = false;
74
75
- if ((insn & 0xffb00f00) == 0xfe200d00) {
76
- /* V[US]DOT -- 1111 1110 0.10 .... .... 1101 .Q.U .... */
77
- int u = extract32(insn, 4, 1);
78
-
79
- if (!dc_isar_feature(aa32_dp, s)) {
80
- return 1;
81
- }
82
- fn_gvec = u ? gen_helper_gvec_udot_idx_b : gen_helper_gvec_sdot_idx_b;
83
- /* rm is just Vm, and index is M. */
84
- data = extract32(insn, 5, 1); /* index */
85
- rm = extract32(insn, 0, 4);
86
- } else if ((insn & 0xffa00f10) == 0xfe000810) {
87
+ if ((insn & 0xffa00f10) == 0xfe000810) {
88
/* VFM[AS]L -- 1111 1110 0.0S .... .... 1000 .Q.1 .... */
89
int is_s = extract32(insn, 20, 1);
90
int vm20 = extract32(insn, 0, 3);
91
--
83
--
92
2.20.1
84
2.20.1
93
85
94
86
diff view generated by jsdifflib
1
In aarch64_max_initfn() we update both 32-bit and 64-bit ID
1
While we transition the ARMSSE code from integer properties
2
registers. The intended pattern is that for 64-bit ID registers we
2
specifying clock frequencies to Clock objects, we want to have the
3
use FIELD_DP64 and the uint64_t 't' register, while 32-bit ID
3
device provide both at once. We want the final name of the main
4
registers use FIELD_DP32 and the uint32_t 'u' register. For
4
input Clock to be "MAINCLK", following the hardware name.
5
ID_AA64DFR0 we accidentally used 'u', meaning that the top 32 bits of
5
Unfortunately creating an input Clock with a name X creates an
6
this 64-bit ID register would end up always zero. Luckily at the
6
under-the-hood QOM property X; for "MAINCLK" this clashes with the
7
moment that's what they should be anyway, so this bug has no visible
7
existing UINT32 property of that name.
8
effects.
9
8
10
Use the right-sized variable.
9
Rename the UINT32 property to MAINCLK_FRQ so it can coexist with the
10
MAINCLK Clock; once the transition is complete MAINCLK_FRQ will be
11
deleted.
11
12
12
Fixes: 3bec78447a958d481991
13
Commit created with:
14
perl -p -i -e 's/MAINCLK/MAINCLK_FRQ/g' hw/arm/{armsse,mps2-tz,musca}.c include/hw/arm/armsse.h
15
13
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
16
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
14
Reviewed-by: Laurent Desnogues <laurent.desnogues@gmail.com>
15
Reviewed-by: Philippe Mathieu-Daudé <f4bug@amsat.org>
17
Reviewed-by: Philippe Mathieu-Daudé <f4bug@amsat.org>
16
Message-id: 20200423110915.10527-1-peter.maydell@linaro.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
17
---
22
---
18
target/arm/cpu64.c | 6 +++---
23
include/hw/arm/armsse.h | 2 +-
19
1 file changed, 3 insertions(+), 3 deletions(-)
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(-)
20
28
21
diff --git a/target/arm/cpu64.c b/target/arm/cpu64.c
29
diff --git a/include/hw/arm/armsse.h b/include/hw/arm/armsse.h
22
index XXXXXXX..XXXXXXX 100644
30
index XXXXXXX..XXXXXXX 100644
23
--- a/target/arm/cpu64.c
31
--- a/include/hw/arm/armsse.h
24
+++ b/target/arm/cpu64.c
32
+++ b/include/hw/arm/armsse.h
25
@@ -XXX,XX +XXX,XX @@ static void aarch64_max_initfn(Object *obj)
33
@@ -XXX,XX +XXX,XX @@
26
u = FIELD_DP32(u, ID_MMFR4, XNX, 1); /* TTS2UXN */
34
* QEMU interface:
27
cpu->isar.id_mmfr4 = u;
35
* + QOM property "memory" is a MemoryRegion containing the devices provided
28
36
* by the board model.
29
- u = cpu->isar.id_aa64dfr0;
37
- * + QOM property "MAINCLK" is the frequency of the main system clock
30
- u = FIELD_DP64(u, ID_AA64DFR0, PMUVER, 5); /* v8.4-PMU */
38
+ * + QOM property "MAINCLK_FRQ" is the frequency of the main system clock
31
- cpu->isar.id_aa64dfr0 = u;
39
* + QOM property "EXP_NUMIRQ" sets the number of expansion interrupts.
32
+ t = cpu->isar.id_aa64dfr0;
40
* (In hardware, the SSE-200 permits the number of expansion interrupts
33
+ t = FIELD_DP64(t, ID_AA64DFR0, PMUVER, 5); /* v8.4-PMU */
41
* for the two CPUs to be configured separately, but we restrict it to
34
+ cpu->isar.id_aa64dfr0 = t;
42
diff --git a/hw/arm/armsse.c b/hw/arm/armsse.c
35
43
index XXXXXXX..XXXXXXX 100644
36
u = cpu->isar.id_dfr0;
44
--- a/hw/arm/armsse.c
37
u = FIELD_DP32(u, ID_DFR0, PERFMON, 5); /* v8.4-PMU */
45
+++ b/hw/arm/armsse.c
46
@@ -XXX,XX +XXX,XX @@ static Property iotkit_properties[] = {
47
DEFINE_PROP_LINK("memory", ARMSSE, board_memory, TYPE_MEMORY_REGION,
48
MemoryRegion *),
49
DEFINE_PROP_UINT32("EXP_NUMIRQ", ARMSSE, exp_numirq, 64),
50
- DEFINE_PROP_UINT32("MAINCLK", ARMSSE, mainclk_frq, 0),
51
+ DEFINE_PROP_UINT32("MAINCLK_FRQ", ARMSSE, mainclk_frq, 0),
52
DEFINE_PROP_UINT32("SRAM_ADDR_WIDTH", ARMSSE, sram_addr_width, 15),
53
DEFINE_PROP_UINT32("init-svtor", ARMSSE, init_svtor, 0x10000000),
54
DEFINE_PROP_BOOL("CPU0_FPU", ARMSSE, cpu_fpu[0], true),
55
@@ -XXX,XX +XXX,XX @@ static Property armsse_properties[] = {
56
DEFINE_PROP_LINK("memory", ARMSSE, board_memory, TYPE_MEMORY_REGION,
57
MemoryRegion *),
58
DEFINE_PROP_UINT32("EXP_NUMIRQ", ARMSSE, exp_numirq, 64),
59
- DEFINE_PROP_UINT32("MAINCLK", ARMSSE, mainclk_frq, 0),
60
+ DEFINE_PROP_UINT32("MAINCLK_FRQ", ARMSSE, mainclk_frq, 0),
61
DEFINE_PROP_UINT32("SRAM_ADDR_WIDTH", ARMSSE, sram_addr_width, 15),
62
DEFINE_PROP_UINT32("init-svtor", ARMSSE, init_svtor, 0x10000000),
63
DEFINE_PROP_BOOL("CPU0_FPU", ARMSSE, cpu_fpu[0], false),
64
@@ -XXX,XX +XXX,XX @@ static void armsse_realize(DeviceState *dev, Error **errp)
65
}
66
67
if (!s->mainclk_frq) {
68
- error_setg(errp, "MAINCLK property was not set");
69
+ error_setg(errp, "MAINCLK_FRQ property was not set");
70
return;
71
}
72
73
diff --git a/hw/arm/mps2-tz.c b/hw/arm/mps2-tz.c
74
index XXXXXXX..XXXXXXX 100644
75
--- a/hw/arm/mps2-tz.c
76
+++ b/hw/arm/mps2-tz.c
77
@@ -XXX,XX +XXX,XX @@ static void mps2tz_common_init(MachineState *machine)
78
object_property_set_link(OBJECT(&mms->iotkit), "memory",
79
OBJECT(system_memory), &error_abort);
80
qdev_prop_set_uint32(iotkitdev, "EXP_NUMIRQ", MPS2TZ_NUMIRQ);
81
- qdev_prop_set_uint32(iotkitdev, "MAINCLK", SYSCLK_FRQ);
82
+ qdev_prop_set_uint32(iotkitdev, "MAINCLK_FRQ", SYSCLK_FRQ);
83
sysbus_realize(SYS_BUS_DEVICE(&mms->iotkit), &error_fatal);
84
85
/*
86
diff --git a/hw/arm/musca.c b/hw/arm/musca.c
87
index XXXXXXX..XXXXXXX 100644
88
--- a/hw/arm/musca.c
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.
38
--
99
--
39
2.20.1
100
2.20.1
40
101
41
102
diff view generated by jsdifflib
1
Convert the V[US]DOT (vector) insns to decodetree.
1
Create two input clocks on the ARMSSE devices, one for the normal
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
6
This is a migration compatibility break for machines mps2-an505,
7
mps2-an521, musca-a, musca-b1.
2
8
3
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
9
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
4
Reviewed-by: Richard Henderson <richard.henderson@linaro.org>
10
Reviewed-by: Philippe Mathieu-Daudé <f4bug@amsat.org>
5
Message-id: 20200430181003.21682-7-peter.maydell@linaro.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
6
---
15
---
7
target/arm/neon-shared.decode | 4 ++++
16
include/hw/arm/armsse.h | 6 ++++++
8
target/arm/translate-neon.inc.c | 32 ++++++++++++++++++++++++++++++++
17
hw/arm/armsse.c | 17 +++++++++++++++--
9
target/arm/translate.c | 9 +--------
18
2 files changed, 21 insertions(+), 2 deletions(-)
10
3 files changed, 37 insertions(+), 8 deletions(-)
11
19
12
diff --git a/target/arm/neon-shared.decode b/target/arm/neon-shared.decode
20
diff --git a/include/hw/arm/armsse.h b/include/hw/arm/armsse.h
13
index XXXXXXX..XXXXXXX 100644
21
index XXXXXXX..XXXXXXX 100644
14
--- a/target/arm/neon-shared.decode
22
--- a/include/hw/arm/armsse.h
15
+++ b/target/arm/neon-shared.decode
23
+++ b/include/hw/arm/armsse.h
16
@@ -XXX,XX +XXX,XX @@ VCMLA 1111 110 rot:2 . 1 size:1 .... .... 1000 . q:1 . 0 .... \
24
@@ -XXX,XX +XXX,XX @@
17
25
* per-CPU identity and control register blocks
18
VCADD 1111 110 rot:1 1 . 0 size:1 .... .... 1000 . q:1 . 0 .... \
26
*
19
vm=%vm_dp vn=%vn_dp vd=%vd_dp
27
* QEMU interface:
28
+ * + Clock input "MAINCLK": clock for CPUs and most peripherals
29
+ * + Clock input "S32KCLK": slow 32KHz clock used for a few peripherals
30
* + QOM property "memory" is a MemoryRegion containing the devices provided
31
* by the board model.
32
* + QOM property "MAINCLK_FRQ" is the frequency of the main system clock
33
@@ -XXX,XX +XXX,XX @@
34
#include "hw/misc/armsse-mhu.h"
35
#include "hw/misc/unimp.h"
36
#include "hw/or-irq.h"
37
+#include "hw/clock.h"
38
#include "hw/core/split-irq.h"
39
#include "hw/cpu/cluster.h"
40
#include "qom/object.h"
41
@@ -XXX,XX +XXX,XX @@ struct ARMSSE {
42
43
uint32_t nsccfg;
44
45
+ Clock *mainclk;
46
+ Clock *s32kclk;
20
+
47
+
21
+# VUDOT and VSDOT
48
/* Properties */
22
+VDOT 1111 110 00 . 10 .... .... 1101 . q:1 . u:1 .... \
49
MemoryRegion *board_memory;
23
+ vm=%vm_dp vn=%vn_dp vd=%vd_dp
50
uint32_t exp_numirq;
24
diff --git a/target/arm/translate-neon.inc.c b/target/arm/translate-neon.inc.c
51
diff --git a/hw/arm/armsse.c b/hw/arm/armsse.c
25
index XXXXXXX..XXXXXXX 100644
52
index XXXXXXX..XXXXXXX 100644
26
--- a/target/arm/translate-neon.inc.c
53
--- a/hw/arm/armsse.c
27
+++ b/target/arm/translate-neon.inc.c
54
+++ b/hw/arm/armsse.c
28
@@ -XXX,XX +XXX,XX @@ static bool trans_VCADD(DisasContext *s, arg_VCADD *a)
55
@@ -XXX,XX +XXX,XX @@
29
tcg_temp_free_ptr(fpst);
56
#include "hw/arm/armsse.h"
30
return true;
57
#include "hw/arm/boot.h"
31
}
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);
32
+
69
+
33
+static bool trans_VDOT(DisasContext *s, arg_VDOT *a)
70
memory_region_init(&s->container, obj, "armsse-container", UINT64_MAX);
34
+{
71
35
+ int opr_sz;
72
for (i = 0; i < info->num_cpus; i++) {
36
+ gen_helper_gvec_3 *fn_gvec;
73
@@ -XXX,XX +XXX,XX @@ static void armsse_realize(DeviceState *dev, Error **errp)
37
+
74
* map its upstream ends to the right place in the container.
38
+ if (!dc_isar_feature(aa32_dp, s)) {
75
*/
39
+ return false;
76
qdev_prop_set_uint32(DEVICE(&s->timer0), "pclk-frq", s->mainclk_frq);
40
+ }
77
+ qdev_connect_clock_in(DEVICE(&s->timer0), "pclk", s->mainclk);
41
+
78
if (!sysbus_realize(SYS_BUS_DEVICE(&s->timer0), errp)) {
42
+ /* UNDEF accesses to D16-D31 if they don't exist. */
79
return;
43
+ if (!dc_isar_feature(aa32_simd_r32, s) &&
80
}
44
+ ((a->vd | a->vn | a->vm) & 0x10)) {
81
@@ -XXX,XX +XXX,XX @@ static void armsse_realize(DeviceState *dev, Error **errp)
45
+ return false;
82
&error_abort);
46
+ }
83
47
+
84
qdev_prop_set_uint32(DEVICE(&s->timer1), "pclk-frq", s->mainclk_frq);
48
+ if ((a->vn | a->vm | a->vd) & a->q) {
85
+ qdev_connect_clock_in(DEVICE(&s->timer1), "pclk", s->mainclk);
49
+ return false;
86
if (!sysbus_realize(SYS_BUS_DEVICE(&s->timer1), errp)) {
50
+ }
87
return;
51
+
88
}
52
+ if (!vfp_access_check(s)) {
89
@@ -XXX,XX +XXX,XX @@ static void armsse_realize(DeviceState *dev, Error **errp)
53
+ return true;
90
&error_abort);
54
+ }
91
55
+
92
qdev_prop_set_uint32(DEVICE(&s->dualtimer), "pclk-frq", s->mainclk_frq);
56
+ opr_sz = (1 + a->q) * 8;
93
+ qdev_connect_clock_in(DEVICE(&s->dualtimer), "TIMCLK", s->mainclk);
57
+ fn_gvec = a->u ? gen_helper_gvec_udot_b : gen_helper_gvec_sdot_b;
94
if (!sysbus_realize(SYS_BUS_DEVICE(&s->dualtimer), errp)) {
58
+ tcg_gen_gvec_3_ool(vfp_reg_offset(1, a->vd),
95
return;
59
+ vfp_reg_offset(1, a->vn),
96
}
60
+ vfp_reg_offset(1, a->vm),
97
@@ -XXX,XX +XXX,XX @@ static void armsse_realize(DeviceState *dev, Error **errp)
61
+ opr_sz, opr_sz, 0, fn_gvec);
98
* 0x4002f000: S32K timer
62
+ return true;
99
*/
63
+}
100
qdev_prop_set_uint32(DEVICE(&s->s32ktimer), "pclk-frq", S32KCLK);
64
diff --git a/target/arm/translate.c b/target/arm/translate.c
101
+ qdev_connect_clock_in(DEVICE(&s->s32ktimer), "pclk", s->s32kclk);
65
index XXXXXXX..XXXXXXX 100644
102
if (!sysbus_realize(SYS_BUS_DEVICE(&s->s32ktimer), errp)) {
66
--- a/target/arm/translate.c
103
return;
67
+++ b/target/arm/translate.c
104
}
68
@@ -XXX,XX +XXX,XX @@ static int disas_neon_insn_3same_ext(DisasContext *s, uint32_t insn)
105
@@ -XXX,XX +XXX,XX @@ static void armsse_realize(DeviceState *dev, Error **errp)
69
bool is_long = false, q = extract32(insn, 6, 1);
106
qdev_get_gpio_in_named(DEVICE(&s->armv7m), "NMI", 0));
70
bool ptr_is_env = false;
107
71
108
qdev_prop_set_uint32(DEVICE(&s->s32kwatchdog), "wdogclk-frq", S32KCLK);
72
- if ((insn & 0xfeb00f00) == 0xfc200d00) {
109
+ qdev_connect_clock_in(DEVICE(&s->s32kwatchdog), "WDOGCLK", s->s32kclk);
73
- /* V[US]DOT -- 1111 1100 0.10 .... .... 1101 .Q.U .... */
110
if (!sysbus_realize(SYS_BUS_DEVICE(&s->s32kwatchdog), errp)) {
74
- bool u = extract32(insn, 4, 1);
111
return;
75
- if (!dc_isar_feature(aa32_dp, s)) {
112
}
76
- return 1;
113
@@ -XXX,XX +XXX,XX @@ static void armsse_realize(DeviceState *dev, Error **errp)
77
- }
114
/* 0x40080000 .. 0x4008ffff : ARMSSE second Base peripheral region */
78
- fn_gvec = u ? gen_helper_gvec_udot_b : gen_helper_gvec_sdot_b;
115
79
- } else if ((insn & 0xff300f10) == 0xfc200810) {
116
qdev_prop_set_uint32(DEVICE(&s->nswatchdog), "wdogclk-frq", s->mainclk_frq);
80
+ if ((insn & 0xff300f10) == 0xfc200810) {
117
+ qdev_connect_clock_in(DEVICE(&s->nswatchdog), "WDOGCLK", s->mainclk);
81
/* VFM[AS]L -- 1111 1100 S.10 .... .... 1000 .Q.1 .... */
118
if (!sysbus_realize(SYS_BUS_DEVICE(&s->nswatchdog), errp)) {
82
int is_s = extract32(insn, 23, 1);
119
return;
83
if (!dc_isar_feature(aa32_fhm, s)) {
120
}
121
@@ -XXX,XX +XXX,XX @@ static void armsse_realize(DeviceState *dev, Error **errp)
122
sysbus_mmio_map(SYS_BUS_DEVICE(&s->nswatchdog), 0, 0x40081000);
123
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
}
129
@@ -XXX,XX +XXX,XX @@ static void armsse_idau_check(IDAUInterface *ii, uint32_t address,
130
131
static const VMStateDescription armsse_vmstate = {
132
.name = "iotkit",
133
- .version_id = 1,
134
- .minimum_version_id = 1,
135
+ .version_id = 2,
136
+ .minimum_version_id = 2,
137
.fields = (VMStateField[]) {
138
+ VMSTATE_CLOCK(mainclk, ARMSSE),
139
+ VMSTATE_CLOCK(s32kclk, ARMSSE),
140
VMSTATE_UINT32(nsccfg, ARMSSE),
141
VMSTATE_END_OF_LIST()
142
}
84
--
143
--
85
2.20.1
144
2.20.1
86
145
87
146
diff view generated by jsdifflib
1
Convert the VCADD (vector) insns to decodetree.
1
The old-style convenience function cmsdk_apb_timer_create() for
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
6
We want to connect up a Clock object which should be done between the
7
object creation and realization; rather than adding a Clock* argument
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.
2
12
3
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
13
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
4
Reviewed-by: Richard Henderson <richard.henderson@linaro.org>
14
Reviewed-by: Philippe Mathieu-Daudé <f4bug@amsat.org>
5
Message-id: 20200430181003.21682-6-peter.maydell@linaro.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
6
---
19
---
7
target/arm/neon-shared.decode | 3 +++
20
include/hw/timer/cmsdk-apb-timer.h | 21 ---------------------
8
target/arm/translate-neon.inc.c | 37 +++++++++++++++++++++++++++++++++
21
hw/arm/mps2.c | 18 ++++++++++++++++--
9
target/arm/translate.c | 11 +---------
22
2 files changed, 16 insertions(+), 23 deletions(-)
10
3 files changed, 41 insertions(+), 10 deletions(-)
11
23
12
diff --git a/target/arm/neon-shared.decode b/target/arm/neon-shared.decode
24
diff --git a/include/hw/timer/cmsdk-apb-timer.h b/include/hw/timer/cmsdk-apb-timer.h
13
index XXXXXXX..XXXXXXX 100644
25
index XXXXXXX..XXXXXXX 100644
14
--- a/target/arm/neon-shared.decode
26
--- a/include/hw/timer/cmsdk-apb-timer.h
15
+++ b/target/arm/neon-shared.decode
27
+++ b/include/hw/timer/cmsdk-apb-timer.h
16
@@ -XXX,XX +XXX,XX @@
28
@@ -XXX,XX +XXX,XX @@ struct CMSDKAPBTimer {
17
29
uint32_t intstatus;
18
VCMLA 1111 110 rot:2 . 1 size:1 .... .... 1000 . q:1 . 0 .... \
30
};
19
vm=%vm_dp vn=%vn_dp vd=%vd_dp
31
32
-/**
33
- * cmsdk_apb_timer_create - convenience function to create TYPE_CMSDK_APB_TIMER
34
- * @addr: location in system memory to map registers
35
- * @pclk_frq: frequency in Hz of the PCLK clock (used for calculating baud rate)
36
- */
37
-static inline DeviceState *cmsdk_apb_timer_create(hwaddr addr,
38
- qemu_irq timerint,
39
- uint32_t pclk_frq)
40
-{
41
- DeviceState *dev;
42
- SysBusDevice *s;
43
-
44
- dev = qdev_new(TYPE_CMSDK_APB_TIMER);
45
- s = SYS_BUS_DEVICE(dev);
46
- qdev_prop_set_uint32(dev, "pclk-frq", pclk_frq);
47
- sysbus_realize_and_unref(s, &error_fatal);
48
- sysbus_mmio_map(s, 0, addr);
49
- sysbus_connect_irq(s, 0, timerint);
50
- return dev;
51
-}
52
-
53
#endif
54
diff --git a/hw/arm/mps2.c b/hw/arm/mps2.c
55
index XXXXXXX..XXXXXXX 100644
56
--- a/hw/arm/mps2.c
57
+++ b/hw/arm/mps2.c
58
@@ -XXX,XX +XXX,XX @@ struct MPS2MachineState {
59
/* CMSDK APB subsystem */
60
CMSDKAPBDualTimer dualtimer;
61
CMSDKAPBWatchdog watchdog;
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;
20
+
77
+
21
+VCADD 1111 110 rot:1 1 . 0 size:1 .... .... 1000 . q:1 . 0 .... \
78
+ object_initialize_child(OBJECT(mms), name, &mms->timer[i],
22
+ vm=%vm_dp vn=%vn_dp vd=%vd_dp
79
+ TYPE_CMSDK_APB_TIMER);
23
diff --git a/target/arm/translate-neon.inc.c b/target/arm/translate-neon.inc.c
80
+ sbd = SYS_BUS_DEVICE(&mms->timer[i]);
24
index XXXXXXX..XXXXXXX 100644
81
+ qdev_prop_set_uint32(DEVICE(&mms->timer[i]), "pclk-frq", SYSCLK_FRQ);
25
--- a/target/arm/translate-neon.inc.c
82
+ sysbus_realize_and_unref(sbd, &error_fatal);
26
+++ b/target/arm/translate-neon.inc.c
83
+ sysbus_mmio_map(sbd, 0, base);
27
@@ -XXX,XX +XXX,XX @@ static bool trans_VCMLA(DisasContext *s, arg_VCMLA *a)
84
+ sysbus_connect_irq(sbd, 0, qdev_get_gpio_in(armv7m, irqno));
28
tcg_temp_free_ptr(fpst);
29
return true;
30
}
31
+
32
+static bool trans_VCADD(DisasContext *s, arg_VCADD *a)
33
+{
34
+ int opr_sz;
35
+ TCGv_ptr fpst;
36
+ gen_helper_gvec_3_ptr *fn_gvec_ptr;
37
+
38
+ if (!dc_isar_feature(aa32_vcma, s)
39
+ || (!a->size && !dc_isar_feature(aa32_fp16_arith, s))) {
40
+ return false;
41
+ }
85
+ }
42
+
86
+
43
+ /* UNDEF accesses to D16-D31 if they don't exist. */
87
object_initialize_child(OBJECT(mms), "dualtimer", &mms->dualtimer,
44
+ if (!dc_isar_feature(aa32_simd_r32, s) &&
88
TYPE_CMSDK_APB_DUALTIMER);
45
+ ((a->vd | a->vn | a->vm) & 0x10)) {
89
qdev_prop_set_uint32(DEVICE(&mms->dualtimer), "pclk-frq", SYSCLK_FRQ);
46
+ return false;
47
+ }
48
+
49
+ if ((a->vn | a->vm | a->vd) & a->q) {
50
+ return false;
51
+ }
52
+
53
+ if (!vfp_access_check(s)) {
54
+ return true;
55
+ }
56
+
57
+ opr_sz = (1 + a->q) * 8;
58
+ fpst = get_fpstatus_ptr(1);
59
+ fn_gvec_ptr = a->size ? gen_helper_gvec_fcadds : gen_helper_gvec_fcaddh;
60
+ tcg_gen_gvec_3_ptr(vfp_reg_offset(1, a->vd),
61
+ vfp_reg_offset(1, a->vn),
62
+ vfp_reg_offset(1, a->vm),
63
+ fpst, opr_sz, opr_sz, a->rot,
64
+ fn_gvec_ptr);
65
+ tcg_temp_free_ptr(fpst);
66
+ return true;
67
+}
68
diff --git a/target/arm/translate.c b/target/arm/translate.c
69
index XXXXXXX..XXXXXXX 100644
70
--- a/target/arm/translate.c
71
+++ b/target/arm/translate.c
72
@@ -XXX,XX +XXX,XX @@ static int disas_neon_insn_3same_ext(DisasContext *s, uint32_t insn)
73
bool is_long = false, q = extract32(insn, 6, 1);
74
bool ptr_is_env = false;
75
76
- if ((insn & 0xfea00f10) == 0xfc800800) {
77
- /* VCADD -- 1111 110R 1.0S .... .... 1000 ...0 .... */
78
- int size = extract32(insn, 20, 1);
79
- data = extract32(insn, 24, 1); /* rot */
80
- if (!dc_isar_feature(aa32_vcma, s)
81
- || (!size && !dc_isar_feature(aa32_fp16_arith, s))) {
82
- return 1;
83
- }
84
- fn_gvec_ptr = size ? gen_helper_gvec_fcadds : gen_helper_gvec_fcaddh;
85
- } else if ((insn & 0xfeb00f00) == 0xfc200d00) {
86
+ if ((insn & 0xfeb00f00) == 0xfc200d00) {
87
/* V[US]DOT -- 1111 1100 0.10 .... .... 1101 .Q.U .... */
88
bool u = extract32(insn, 4, 1);
89
if (!dc_isar_feature(aa32_dp, s)) {
90
--
90
--
91
2.20.1
91
2.20.1
92
92
93
93
diff view generated by jsdifflib
1
Convert the VCMLA (vector) insns in the 3same extension group to
1
Create a fixed-frequency Clock object to be the SYSCLK, and wire it
2
decodetree.
2
up to the devices that require it.
3
3
4
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
4
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
5
Reviewed-by: Richard Henderson <richard.henderson@linaro.org>
5
Reviewed-by: Philippe Mathieu-Daudé <f4bug@amsat.org>
6
Message-id: 20200430181003.21682-5-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-14-peter.maydell@linaro.org
9
Message-id: 20210121190622.22000-14-peter.maydell@linaro.org
7
---
10
---
8
target/arm/neon-shared.decode | 11 ++++++++++
11
hw/arm/mps2.c | 9 +++++++++
9
target/arm/translate-neon.inc.c | 37 +++++++++++++++++++++++++++++++++
12
1 file changed, 9 insertions(+)
10
target/arm/translate.c | 11 +---------
11
3 files changed, 49 insertions(+), 10 deletions(-)
12
13
13
diff --git a/target/arm/neon-shared.decode b/target/arm/neon-shared.decode
14
diff --git a/hw/arm/mps2.c b/hw/arm/mps2.c
14
index XXXXXXX..XXXXXXX 100644
15
index XXXXXXX..XXXXXXX 100644
15
--- a/target/arm/neon-shared.decode
16
--- a/hw/arm/mps2.c
16
+++ b/target/arm/neon-shared.decode
17
+++ b/hw/arm/mps2.c
17
@@ -XXX,XX +XXX,XX @@
18
@@ -XXX,XX +XXX,XX @@
18
# More specifically, this covers:
19
#include "hw/net/lan9118.h"
19
# 2reg scalar ext: 0b1111_1110_xxxx_xxxx_xxxx_1x0x_xxxx_xxxx
20
#include "net/net.h"
20
# 3same ext: 0b1111_110x_xxxx_xxxx_xxxx_1x0x_xxxx_xxxx
21
#include "hw/watchdog/cmsdk-apb-watchdog.h"
22
+#include "hw/qdev-clock.h"
23
#include "qom/object.h"
24
25
typedef enum MPS2FPGAType {
26
@@ -XXX,XX +XXX,XX @@ struct MPS2MachineState {
27
CMSDKAPBDualTimer dualtimer;
28
CMSDKAPBWatchdog watchdog;
29
CMSDKAPBTimer timer[2];
30
+ Clock *sysclk;
31
};
32
33
#define TYPE_MPS2_MACHINE "mps2"
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);
21
+
41
+
22
+# VFP/Neon register fields; same as vfp.decode
42
/* The FPGA images have an odd combination of different RAMs,
23
+%vm_dp 5:1 0:4
43
* because in hardware they are different implementations and
24
+%vm_sp 0:4 5:1
44
* connected to different buses, giving varying performance/size
25
+%vn_dp 7:1 16:4
45
@@ -XXX,XX +XXX,XX @@ static void mps2_common_init(MachineState *machine)
26
+%vn_sp 16:4 7:1
46
TYPE_CMSDK_APB_TIMER);
27
+%vd_dp 22:1 12:4
47
sbd = SYS_BUS_DEVICE(&mms->timer[i]);
28
+%vd_sp 12:4 22:1
48
qdev_prop_set_uint32(DEVICE(&mms->timer[i]), "pclk-frq", SYSCLK_FRQ);
29
+
49
+ qdev_connect_clock_in(DEVICE(&mms->timer[i]), "pclk", mms->sysclk);
30
+VCMLA 1111 110 rot:2 . 1 size:1 .... .... 1000 . q:1 . 0 .... \
50
sysbus_realize_and_unref(sbd, &error_fatal);
31
+ vm=%vm_dp vn=%vn_dp vd=%vd_dp
51
sysbus_mmio_map(sbd, 0, base);
32
diff --git a/target/arm/translate-neon.inc.c b/target/arm/translate-neon.inc.c
52
sysbus_connect_irq(sbd, 0, qdev_get_gpio_in(armv7m, irqno));
33
index XXXXXXX..XXXXXXX 100644
53
@@ -XXX,XX +XXX,XX @@ static void mps2_common_init(MachineState *machine)
34
--- a/target/arm/translate-neon.inc.c
54
object_initialize_child(OBJECT(mms), "dualtimer", &mms->dualtimer,
35
+++ b/target/arm/translate-neon.inc.c
55
TYPE_CMSDK_APB_DUALTIMER);
36
@@ -XXX,XX +XXX,XX @@
56
qdev_prop_set_uint32(DEVICE(&mms->dualtimer), "pclk-frq", SYSCLK_FRQ);
37
#include "decode-neon-dp.inc.c"
57
+ qdev_connect_clock_in(DEVICE(&mms->dualtimer), "TIMCLK", mms->sysclk);
38
#include "decode-neon-ls.inc.c"
58
sysbus_realize(SYS_BUS_DEVICE(&mms->dualtimer), &error_fatal);
39
#include "decode-neon-shared.inc.c"
59
sysbus_connect_irq(SYS_BUS_DEVICE(&mms->dualtimer), 0,
40
+
60
qdev_get_gpio_in(armv7m, 10));
41
+static bool trans_VCMLA(DisasContext *s, arg_VCMLA *a)
61
@@ -XXX,XX +XXX,XX @@ static void mps2_common_init(MachineState *machine)
42
+{
62
object_initialize_child(OBJECT(mms), "watchdog", &mms->watchdog,
43
+ int opr_sz;
63
TYPE_CMSDK_APB_WATCHDOG);
44
+ TCGv_ptr fpst;
64
qdev_prop_set_uint32(DEVICE(&mms->watchdog), "wdogclk-frq", SYSCLK_FRQ);
45
+ gen_helper_gvec_3_ptr *fn_gvec_ptr;
65
+ qdev_connect_clock_in(DEVICE(&mms->watchdog), "WDOGCLK", mms->sysclk);
46
+
66
sysbus_realize(SYS_BUS_DEVICE(&mms->watchdog), &error_fatal);
47
+ if (!dc_isar_feature(aa32_vcma, s)
67
sysbus_connect_irq(SYS_BUS_DEVICE(&mms->watchdog), 0,
48
+ || (!a->size && !dc_isar_feature(aa32_fp16_arith, s))) {
68
qdev_get_gpio_in_named(armv7m, "NMI", 0));
49
+ return false;
50
+ }
51
+
52
+ /* UNDEF accesses to D16-D31 if they don't exist. */
53
+ if (!dc_isar_feature(aa32_simd_r32, s) &&
54
+ ((a->vd | a->vn | a->vm) & 0x10)) {
55
+ return false;
56
+ }
57
+
58
+ if ((a->vn | a->vm | a->vd) & a->q) {
59
+ return false;
60
+ }
61
+
62
+ if (!vfp_access_check(s)) {
63
+ return true;
64
+ }
65
+
66
+ opr_sz = (1 + a->q) * 8;
67
+ fpst = get_fpstatus_ptr(1);
68
+ fn_gvec_ptr = a->size ? gen_helper_gvec_fcmlas : gen_helper_gvec_fcmlah;
69
+ tcg_gen_gvec_3_ptr(vfp_reg_offset(1, a->vd),
70
+ vfp_reg_offset(1, a->vn),
71
+ vfp_reg_offset(1, a->vm),
72
+ fpst, opr_sz, opr_sz, a->rot,
73
+ fn_gvec_ptr);
74
+ tcg_temp_free_ptr(fpst);
75
+ return true;
76
+}
77
diff --git a/target/arm/translate.c b/target/arm/translate.c
78
index XXXXXXX..XXXXXXX 100644
79
--- a/target/arm/translate.c
80
+++ b/target/arm/translate.c
81
@@ -XXX,XX +XXX,XX @@ static int disas_neon_insn_3same_ext(DisasContext *s, uint32_t insn)
82
bool is_long = false, q = extract32(insn, 6, 1);
83
bool ptr_is_env = false;
84
85
- if ((insn & 0xfe200f10) == 0xfc200800) {
86
- /* VCMLA -- 1111 110R R.1S .... .... 1000 ...0 .... */
87
- int size = extract32(insn, 20, 1);
88
- data = extract32(insn, 23, 2); /* rot */
89
- if (!dc_isar_feature(aa32_vcma, s)
90
- || (!size && !dc_isar_feature(aa32_fp16_arith, s))) {
91
- return 1;
92
- }
93
- fn_gvec_ptr = size ? gen_helper_gvec_fcmlas : gen_helper_gvec_fcmlah;
94
- } else if ((insn & 0xfea00f10) == 0xfc800800) {
95
+ if ((insn & 0xfea00f10) == 0xfc800800) {
96
/* VCADD -- 1111 110R 1.0S .... .... 1000 ...0 .... */
97
int size = extract32(insn, 20, 1);
98
data = extract32(insn, 24, 1); /* rot */
99
--
69
--
100
2.20.1
70
2.20.1
101
71
102
72
diff view generated by jsdifflib
1
From: Philippe Mathieu-Daudé <f4bug@amsat.org>
1
Create and connect the two clocks needed by the ARMSSE.
2
2
3
By using the TYPE_* definitions for devices, we can:
4
- quickly find where devices are used with 'git-grep'
5
- easily rename a device (one-line change).
6
7
Signed-off-by: Philippe Mathieu-Daudé <f4bug@amsat.org>
8
Message-id: 20200428154650.21991-1-f4bug@amsat.org
9
Reviewed-by: Peter Maydell <peter.maydell@linaro.org>
10
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
3
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
11
---
9
---
12
hw/arm/mps2-tz.c | 2 +-
10
hw/arm/mps2-tz.c | 13 +++++++++++++
13
1 file changed, 1 insertion(+), 1 deletion(-)
11
1 file changed, 13 insertions(+)
14
12
15
diff --git a/hw/arm/mps2-tz.c b/hw/arm/mps2-tz.c
13
diff --git a/hw/arm/mps2-tz.c b/hw/arm/mps2-tz.c
16
index XXXXXXX..XXXXXXX 100644
14
index XXXXXXX..XXXXXXX 100644
17
--- a/hw/arm/mps2-tz.c
15
--- a/hw/arm/mps2-tz.c
18
+++ b/hw/arm/mps2-tz.c
16
+++ b/hw/arm/mps2-tz.c
17
@@ -XXX,XX +XXX,XX @@
18
#include "hw/net/lan9118.h"
19
#include "net/net.h"
20
#include "hw/core/split-irq.h"
21
+#include "hw/qdev-clock.h"
22
#include "qom/object.h"
23
24
#define MPS2TZ_NUMIRQ 92
25
@@ -XXX,XX +XXX,XX @@ struct MPS2TZMachineState {
26
qemu_or_irq uart_irq_orgate;
27
DeviceState *lan9118;
28
SplitIRQ cpu_irq_splitter[MPS2TZ_NUMIRQ];
29
+ Clock *sysclk;
30
+ Clock *s32kclk;
31
};
32
33
#define TYPE_MPS2TZ_MACHINE "mps2tz"
34
@@ -XXX,XX +XXX,XX @@ OBJECT_DECLARE_TYPE(MPS2TZMachineState, MPS2TZMachineClass, MPS2TZ_MACHINE)
35
36
/* Main SYSCLK frequency in Hz */
37
#define SYSCLK_FRQ 20000000
38
+/* Slow 32Khz S32KCLK frequency in Hz */
39
+#define S32KCLK_FRQ (32 * 1000)
40
41
/* Create an alias of an entire original MemoryRegion @orig
42
* located at @base in the memory map.
19
@@ -XXX,XX +XXX,XX @@ static void mps2tz_common_init(MachineState *machine)
43
@@ -XXX,XX +XXX,XX @@ static void mps2tz_common_init(MachineState *machine)
20
exit(EXIT_FAILURE);
44
exit(EXIT_FAILURE);
21
}
45
}
22
46
23
- sysbus_init_child_obj(OBJECT(machine), "iotkit", &mms->iotkit,
47
+ /* These clocks don't need migration because they are fixed-frequency */
24
+ sysbus_init_child_obj(OBJECT(machine), TYPE_IOTKIT, &mms->iotkit,
48
+ mms->sysclk = clock_new(OBJECT(machine), "SYSCLK");
25
sizeof(mms->iotkit), mmc->armsse_type);
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);
26
iotkitdev = DEVICE(&mms->iotkit);
55
iotkitdev = DEVICE(&mms->iotkit);
27
object_property_set_link(OBJECT(&mms->iotkit), OBJECT(system_memory),
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
/*
28
--
65
--
29
2.20.1
66
2.20.1
30
67
31
68
diff view generated by jsdifflib
1
Somewhere along theline we accidentally added a duplicate
1
Create and connect the two clocks needed by the ARMSSE.
2
"using D16-D31 when they don't exist" check to do_vfm_dp()
3
(probably an artifact of a patchseries rebase). Remove it.
4
2
5
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
3
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
6
Reviewed-by: Richard Henderson <richard.henderson@linaro.org>
7
Reviewed-by: Philippe Mathieu-Daudé <f4bug@amsat.org>
4
Reviewed-by: Philippe Mathieu-Daudé <f4bug@amsat.org>
8
Message-id: 20200430181003.21682-2-peter.maydell@linaro.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
---
9
---
10
target/arm/translate-vfp.inc.c | 6 ------
10
hw/arm/musca.c | 12 ++++++++++++
11
1 file changed, 6 deletions(-)
11
1 file changed, 12 insertions(+)
12
12
13
diff --git a/target/arm/translate-vfp.inc.c b/target/arm/translate-vfp.inc.c
13
diff --git a/hw/arm/musca.c b/hw/arm/musca.c
14
index XXXXXXX..XXXXXXX 100644
14
index XXXXXXX..XXXXXXX 100644
15
--- a/target/arm/translate-vfp.inc.c
15
--- a/hw/arm/musca.c
16
+++ b/target/arm/translate-vfp.inc.c
16
+++ b/hw/arm/musca.c
17
@@ -XXX,XX +XXX,XX @@ static bool do_vfm_dp(DisasContext *s, arg_VFMA_dp *a, bool neg_n, bool neg_d)
17
@@ -XXX,XX +XXX,XX @@
18
return false;
18
#include "hw/misc/tz-ppc.h"
19
#include "hw/misc/unimp.h"
20
#include "hw/rtc/pl031.h"
21
+#include "hw/qdev-clock.h"
22
#include "qom/object.h"
23
24
#define MUSCA_NUMIRQ_MAX 96
25
@@ -XXX,XX +XXX,XX @@ struct MuscaMachineState {
26
UnimplementedDeviceState sdio;
27
UnimplementedDeviceState gpio;
28
UnimplementedDeviceState cryptoisland;
29
+ Clock *sysclk;
30
+ Clock *s32kclk;
31
};
32
33
#define TYPE_MUSCA_MACHINE "musca"
34
@@ -XXX,XX +XXX,XX @@ OBJECT_DECLARE_TYPE(MuscaMachineState, MuscaMachineClass, MUSCA_MACHINE)
35
* don't model that in our SSE-200 model yet.
36
*/
37
#define SYSCLK_FRQ 40000000
38
+/* Slow 32Khz S32KCLK frequency in Hz */
39
+#define S32KCLK_FRQ (32 * 1000)
40
41
static qemu_irq get_sse_irq_in(MuscaMachineState *mms, int irqno)
42
{
43
@@ -XXX,XX +XXX,XX @@ static void musca_init(MachineState *machine)
44
exit(1);
19
}
45
}
20
46
21
- /* UNDEF accesses to D16-D31 if they don't exist. */
47
+ mms->sysclk = clock_new(OBJECT(machine), "SYSCLK");
22
- if (!dc_isar_feature(aa32_simd_r32, s) &&
48
+ clock_set_hz(mms->sysclk, SYSCLK_FRQ);
23
- ((a->vd | a->vn | a->vm) & 0x10)) {
49
+ mms->s32kclk = clock_new(OBJECT(machine), "S32KCLK");
24
- return false;
50
+ clock_set_hz(mms->s32kclk, S32KCLK_FRQ);
25
- }
51
+
26
-
52
object_initialize_child(OBJECT(machine), "sse-200", &mms->sse,
27
if (!vfp_access_check(s)) {
53
TYPE_SSE200);
28
return true;
54
ssedev = DEVICE(&mms->sse);
29
}
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.
30
--
64
--
31
2.20.1
65
2.20.1
32
66
33
67
diff view generated by jsdifflib
1
Convert the VFM[AS]L (vector) insns to decodetree. This is the last
1
Convert the SSYS code in the Stellaris boards (which encapsulates the
2
insn in the legacy decoder for the 3same_ext group, so we can
2
system registers) to a proper QOM device. This will provide us with
3
delete the legacy decoder function for the group entirely.
3
somewhere to put the output Clock whose frequency depends on the
4
4
setting of the PLL configuration registers.
5
Note that in disas_thumb2_insn() the parts of this encoding space
5
6
where the decodetree decoder returns false will correctly be directed
6
This is a migration compatibility break for lm3s811evb, lm3s6965evb.
7
to illegal_op by the "(insn & (1 << 28))" check so they won't fall
7
8
into disas_coproc_insn() by mistake.
8
We use 3-phase reset here because the Clock will need to propagate
9
its value in the hold phase.
10
11
For the moment we reset the device during the board creation so that
12
the system_clock_scale global gets set; this will be removed in a
13
subsequent commit.
9
14
10
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
15
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
11
Reviewed-by: Richard Henderson <richard.henderson@linaro.org>
16
Reviewed-by: Luc Michel <luc@lmichel.fr>
12
Message-id: 20200430181003.21682-8-peter.maydell@linaro.org
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>
13
---
22
---
14
target/arm/neon-shared.decode | 6 +++
23
hw/arm/stellaris.c | 132 ++++++++++++++++++++++++++++++++++++---------
15
target/arm/translate-neon.inc.c | 31 +++++++++++
24
1 file changed, 107 insertions(+), 25 deletions(-)
16
target/arm/translate.c | 92 +--------------------------------
25
17
3 files changed, 38 insertions(+), 91 deletions(-)
26
diff --git a/hw/arm/stellaris.c b/hw/arm/stellaris.c
18
19
diff --git a/target/arm/neon-shared.decode b/target/arm/neon-shared.decode
20
index XXXXXXX..XXXXXXX 100644
27
index XXXXXXX..XXXXXXX 100644
21
--- a/target/arm/neon-shared.decode
28
--- a/hw/arm/stellaris.c
22
+++ b/target/arm/neon-shared.decode
29
+++ b/hw/arm/stellaris.c
23
@@ -XXX,XX +XXX,XX @@ VCADD 1111 110 rot:1 1 . 0 size:1 .... .... 1000 . q:1 . 0 .... \
30
@@ -XXX,XX +XXX,XX @@ static void stellaris_gptm_realize(DeviceState *dev, Error **errp)
24
# VUDOT and VSDOT
31
25
VDOT 1111 110 00 . 10 .... .... 1101 . q:1 . u:1 .... \
32
/* System controller. */
26
vm=%vm_dp vn=%vn_dp vd=%vd_dp
33
27
+
34
-typedef struct {
28
+# VFM[AS]L
35
+#define TYPE_STELLARIS_SYS "stellaris-sys"
29
+VFML 1111 110 0 s:1 . 10 .... .... 1000 . 0 . 1 .... \
36
+OBJECT_DECLARE_SIMPLE_TYPE(ssys_state, STELLARIS_SYS)
30
+ vm=%vm_sp vn=%vn_sp vd=%vd_dp q=0
37
+
31
+VFML 1111 110 0 s:1 . 10 .... .... 1000 . 1 . 1 .... \
38
+struct ssys_state {
32
+ vm=%vm_dp vn=%vn_dp vd=%vd_dp q=1
39
+ SysBusDevice parent_obj;
33
diff --git a/target/arm/translate-neon.inc.c b/target/arm/translate-neon.inc.c
40
+
34
index XXXXXXX..XXXXXXX 100644
41
MemoryRegion iomem;
35
--- a/target/arm/translate-neon.inc.c
42
uint32_t pborctl;
36
+++ b/target/arm/translate-neon.inc.c
43
uint32_t ldopctl;
37
@@ -XXX,XX +XXX,XX @@ static bool trans_VDOT(DisasContext *s, arg_VDOT *a)
44
@@ -XXX,XX +XXX,XX @@ typedef struct {
38
opr_sz, opr_sz, 0, fn_gvec);
45
uint32_t dcgc[3];
39
return true;
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
+}
119
+
120
+static void stellaris_sys_reset_hold(Object *obj)
121
+{
122
+ ssys_state *s = STELLARIS_SYS(obj);
123
+
124
ssys_calculate_system_clock(s);
40
}
125
}
41
+
126
42
+static bool trans_VFML(DisasContext *s, arg_VFML *a)
127
+static void stellaris_sys_reset_exit(Object *obj)
43
+{
128
+{
44
+ int opr_sz;
129
+}
45
+
130
+
46
+ if (!dc_isar_feature(aa32_fhm, s)) {
131
static int stellaris_sys_post_load(void *opaque, int version_id)
47
+ return false;
132
{
48
+ }
133
ssys_state *s = opaque;
49
+
134
@@ -XXX,XX +XXX,XX @@ static const VMStateDescription vmstate_stellaris_sys = {
50
+ /* UNDEF accesses to D16-D31 if they don't exist. */
135
}
51
+ if (!dc_isar_feature(aa32_simd_r32, s) &&
136
};
52
+ (a->vd & 0x10)) {
137
53
+ return false;
138
+static Property stellaris_sys_properties[] = {
54
+ }
139
+ DEFINE_PROP_UINT32("user0", ssys_state, user0, 0),
55
+
140
+ DEFINE_PROP_UINT32("user1", ssys_state, user1, 0),
56
+ if (a->vd & a->q) {
141
+ DEFINE_PROP_UINT32("did0", ssys_state, did0, 0),
57
+ return false;
142
+ DEFINE_PROP_UINT32("did1", ssys_state, did1, 0),
58
+ }
143
+ DEFINE_PROP_UINT32("dc0", ssys_state, dc0, 0),
59
+
144
+ DEFINE_PROP_UINT32("dc1", ssys_state, dc1, 0),
60
+ if (!vfp_access_check(s)) {
145
+ DEFINE_PROP_UINT32("dc2", ssys_state, dc2, 0),
61
+ return true;
146
+ DEFINE_PROP_UINT32("dc3", ssys_state, dc3, 0),
62
+ }
147
+ DEFINE_PROP_UINT32("dc4", ssys_state, dc4, 0),
63
+
148
+ DEFINE_PROP_END_OF_LIST()
64
+ opr_sz = (1 + a->q) * 8;
149
+};
65
+ tcg_gen_gvec_3_ptr(vfp_reg_offset(1, a->vd),
150
+
66
+ vfp_reg_offset(a->q, a->vn),
151
+static void stellaris_sys_instance_init(Object *obj)
67
+ vfp_reg_offset(a->q, a->vm),
152
+{
68
+ cpu_env, opr_sz, opr_sz, a->s, /* is_2 == 0 */
153
+ ssys_state *s = STELLARIS_SYS(obj);
69
+ gen_helper_gvec_fmlal_a32);
154
+ SysBusDevice *sbd = SYS_BUS_DEVICE(s);
70
+ return true;
155
+
71
+}
156
+ memory_region_init_io(&s->iomem, obj, &ssys_ops, s, "ssys", 0x00001000);
72
diff --git a/target/arm/translate.c b/target/arm/translate.c
157
+ sysbus_init_mmio(sbd, &s->iomem);
73
index XXXXXXX..XXXXXXX 100644
158
+ sysbus_init_irq(sbd, &s->irq);
74
--- a/target/arm/translate.c
159
+}
75
+++ b/target/arm/translate.c
160
+
76
@@ -XXX,XX +XXX,XX @@ static int disas_neon_data_insn(DisasContext *s, uint32_t insn)
161
static int stellaris_sys_init(uint32_t base, qemu_irq irq,
162
stellaris_board_info * board,
163
uint8_t *macaddr)
164
{
165
- ssys_state *s;
166
+ DeviceState *dev = qdev_new(TYPE_STELLARIS_SYS);
167
+ SysBusDevice *sbd = SYS_BUS_DEVICE(dev);
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);
77
return 0;
205
return 0;
78
}
206
}
79
207
80
-/* Advanced SIMD three registers of the same length extension.
81
- * 31 25 23 22 20 16 12 11 10 9 8 3 0
82
- * +---------------+-----+---+-----+----+----+---+----+---+----+---------+----+
83
- * | 1 1 1 1 1 1 0 | op1 | D | op2 | Vn | Vd | 1 | o3 | 0 | o4 | N Q M U | Vm |
84
- * +---------------+-----+---+-----+----+----+---+----+---+----+---------+----+
85
- */
86
-static int disas_neon_insn_3same_ext(DisasContext *s, uint32_t insn)
87
-{
88
- gen_helper_gvec_3 *fn_gvec = NULL;
89
- gen_helper_gvec_3_ptr *fn_gvec_ptr = NULL;
90
- int rd, rn, rm, opr_sz;
91
- int data = 0;
92
- int off_rn, off_rm;
93
- bool is_long = false, q = extract32(insn, 6, 1);
94
- bool ptr_is_env = false;
95
-
208
-
96
- if ((insn & 0xff300f10) == 0xfc200810) {
209
/* I2C controller. */
97
- /* VFM[AS]L -- 1111 1100 S.10 .... .... 1000 .Q.1 .... */
210
98
- int is_s = extract32(insn, 23, 1);
211
#define TYPE_STELLARIS_I2C "stellaris-i2c"
99
- if (!dc_isar_feature(aa32_fhm, s)) {
212
@@ -XXX,XX +XXX,XX @@ static const TypeInfo stellaris_adc_info = {
100
- return 1;
213
.class_init = stellaris_adc_class_init,
101
- }
214
};
102
- is_long = true;
215
103
- data = is_s; /* is_2 == 0 */
216
+static void stellaris_sys_class_init(ObjectClass *klass, void *data)
104
- fn_gvec_ptr = gen_helper_gvec_fmlal_a32;
217
+{
105
- ptr_is_env = true;
218
+ DeviceClass *dc = DEVICE_CLASS(klass);
106
- } else {
219
+ ResettableClass *rc = RESETTABLE_CLASS(klass);
107
- return 1;
220
+
108
- }
221
+ dc->vmsd = &vmstate_stellaris_sys;
109
-
222
+ rc->phases.enter = stellaris_sys_reset_enter;
110
- VFP_DREG_D(rd, insn);
223
+ rc->phases.hold = stellaris_sys_reset_hold;
111
- if (rd & q) {
224
+ rc->phases.exit = stellaris_sys_reset_exit;
112
- return 1;
225
+ device_class_set_props(dc, stellaris_sys_properties);
113
- }
226
+}
114
- if (q || !is_long) {
227
+
115
- VFP_DREG_N(rn, insn);
228
+static const TypeInfo stellaris_sys_info = {
116
- VFP_DREG_M(rm, insn);
229
+ .name = TYPE_STELLARIS_SYS,
117
- if ((rn | rm) & q & !is_long) {
230
+ .parent = TYPE_SYS_BUS_DEVICE,
118
- return 1;
231
+ .instance_size = sizeof(ssys_state),
119
- }
232
+ .instance_init = stellaris_sys_instance_init,
120
- off_rn = vfp_reg_offset(1, rn);
233
+ .class_init = stellaris_sys_class_init,
121
- off_rm = vfp_reg_offset(1, rm);
234
+};
122
- } else {
235
+
123
- rn = VFP_SREG_N(insn);
236
static void stellaris_register_types(void)
124
- rm = VFP_SREG_M(insn);
237
{
125
- off_rn = vfp_reg_offset(0, rn);
238
type_register_static(&stellaris_i2c_info);
126
- off_rm = vfp_reg_offset(0, rm);
239
type_register_static(&stellaris_gptm_info);
127
- }
240
type_register_static(&stellaris_adc_info);
128
-
241
+ type_register_static(&stellaris_sys_info);
129
- if (s->fp_excp_el) {
242
}
130
- gen_exception_insn(s, s->pc_curr, EXCP_UDEF,
243
131
- syn_simd_access_trap(1, 0xe, false), s->fp_excp_el);
244
type_init(stellaris_register_types)
132
- return 0;
133
- }
134
- if (!s->vfp_enabled) {
135
- return 1;
136
- }
137
-
138
- opr_sz = (1 + q) * 8;
139
- if (fn_gvec_ptr) {
140
- TCGv_ptr ptr;
141
- if (ptr_is_env) {
142
- ptr = cpu_env;
143
- } else {
144
- ptr = get_fpstatus_ptr(1);
145
- }
146
- tcg_gen_gvec_3_ptr(vfp_reg_offset(1, rd), off_rn, off_rm, ptr,
147
- opr_sz, opr_sz, data, fn_gvec_ptr);
148
- if (!ptr_is_env) {
149
- tcg_temp_free_ptr(ptr);
150
- }
151
- } else {
152
- tcg_gen_gvec_3_ool(vfp_reg_offset(1, rd), off_rn, off_rm,
153
- opr_sz, opr_sz, data, fn_gvec);
154
- }
155
- return 0;
156
-}
157
-
158
/* Advanced SIMD two registers and a scalar extension.
159
* 31 24 23 22 20 16 12 11 10 9 8 3 0
160
* +-----------------+----+---+----+----+----+---+----+---+----+---------+----+
161
@@ -XXX,XX +XXX,XX @@ static void disas_arm_insn(DisasContext *s, unsigned int insn)
162
}
163
}
164
}
165
- } else if ((insn & 0x0e000a00) == 0x0c000800
166
- && arm_dc_feature(s, ARM_FEATURE_V8)) {
167
- if (disas_neon_insn_3same_ext(s, insn)) {
168
- goto illegal_op;
169
- }
170
- return;
171
} else if ((insn & 0x0f000a00) == 0x0e000800
172
&& arm_dc_feature(s, ARM_FEATURE_V8)) {
173
if (disas_neon_insn_2reg_scalar_ext(s, insn)) {
174
@@ -XXX,XX +XXX,XX @@ static void disas_thumb2_insn(DisasContext *s, uint32_t insn)
175
}
176
break;
177
}
178
- if ((insn & 0xfe000a00) == 0xfc000800
179
+ if ((insn & 0xff000a00) == 0xfe000800
180
&& arm_dc_feature(s, ARM_FEATURE_V8)) {
181
/* The Thumb2 and ARM encodings are identical. */
182
- if (disas_neon_insn_3same_ext(s, insn)) {
183
- goto illegal_op;
184
- }
185
- } else if ((insn & 0xff000a00) == 0xfe000800
186
- && arm_dc_feature(s, ARM_FEATURE_V8)) {
187
- /* The Thumb2 and ARM encodings are identical. */
188
if (disas_neon_insn_2reg_scalar_ext(s, insn)) {
189
goto illegal_op;
190
}
191
--
245
--
192
2.20.1
246
2.20.1
193
247
194
248
diff view generated by jsdifflib
1
The ARMv8.2-TTS2UXN feature extends the XN field in stage 2
1
Create and connect the Clock input for the watchdog device on the
2
translation table descriptors from just bit [54] to bits [54:53],
2
Stellaris boards. Because the Stellaris boards model the ability to
3
allowing stage 2 to control execution permissions separately for EL0
3
change the clock rate by programming PLL registers, we have to create
4
and EL1. Implement the new semantics of the XN field and enable
4
an output Clock on the ssys_state device and wire it up to the
5
the feature for our 'max' CPU.
5
watchdog.
6
7
Note that the old comment on ssys_calculate_system_clock() got the
8
units wrong -- system_clock_scale is in nanoseconds, not
9
milliseconds. Improve the commentary to clarify how we are
10
calculating the period.
6
11
7
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
12
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
8
Reviewed-by: Edgar E. Iglesias <edgar.iglesias@xilinx.com>
13
Reviewed-by: Luc Michel <luc@lmichel.fr>
9
Reviewed-by: Richard Henderson <richard.henderson@linaro.org>
14
Tested-by: Philippe Mathieu-Daudé <f4bug@amsat.org>
10
Message-id: 20200330210400.11724-5-peter.maydell@linaro.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>
11
---
19
---
12
target/arm/cpu.h | 15 +++++++++++++++
20
hw/arm/stellaris.c | 43 +++++++++++++++++++++++++++++++------------
13
target/arm/cpu.c | 1 +
21
1 file changed, 31 insertions(+), 12 deletions(-)
14
target/arm/cpu64.c | 2 ++
15
target/arm/helper.c | 37 +++++++++++++++++++++++++++++++------
16
4 files changed, 49 insertions(+), 6 deletions(-)
17
22
18
diff --git a/target/arm/cpu.h b/target/arm/cpu.h
23
diff --git a/hw/arm/stellaris.c b/hw/arm/stellaris.c
19
index XXXXXXX..XXXXXXX 100644
24
index XXXXXXX..XXXXXXX 100644
20
--- a/target/arm/cpu.h
25
--- a/hw/arm/stellaris.c
21
+++ b/target/arm/cpu.h
26
+++ b/hw/arm/stellaris.c
22
@@ -XXX,XX +XXX,XX @@ static inline bool isar_feature_aa32_ccidx(const ARMISARegisters *id)
27
@@ -XXX,XX +XXX,XX @@
23
return FIELD_EX32(id->id_mmfr4, ID_MMFR4, CCIDX) != 0;
28
#include "hw/watchdog/cmsdk-apb-watchdog.h"
29
#include "migration/vmstate.h"
30
#include "hw/misc/unimp.h"
31
+#include "hw/qdev-clock.h"
32
#include "cpu.h"
33
#include "qom/object.h"
34
35
@@ -XXX,XX +XXX,XX @@ struct ssys_state {
36
uint32_t clkvclr;
37
uint32_t ldoarst;
38
qemu_irq irq;
39
+ Clock *sysclk;
40
/* Properties (all read-only registers) */
41
uint32_t user0;
42
uint32_t user1;
43
@@ -XXX,XX +XXX,XX @@ static bool ssys_use_rcc2(ssys_state *s)
24
}
44
}
25
45
26
+static inline bool isar_feature_aa32_tts2uxn(const ARMISARegisters *id)
27
+{
28
+ return FIELD_EX32(id->id_mmfr4, ID_MMFR4, XNX) != 0;
29
+}
30
+
31
/*
46
/*
32
* 64-bit feature tests via id registers.
47
- * Caculate the sys. clock period in ms.
48
+ * Calculate the system clock period. We only want to propagate
49
+ * this change to the rest of the system if we're not being called
50
+ * from migration post-load.
33
*/
51
*/
34
@@ -XXX,XX +XXX,XX @@ static inline bool isar_feature_aa64_ccidx(const ARMISARegisters *id)
52
-static void ssys_calculate_system_clock(ssys_state *s)
35
return FIELD_EX64(id->id_aa64mmfr2, ID_AA64MMFR2, CCIDX) != 0;
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
+ }
36
}
69
}
37
70
38
+static inline bool isar_feature_aa64_tts2uxn(const ARMISARegisters *id)
71
static void ssys_write(void *opaque, hwaddr offset,
39
+{
72
@@ -XXX,XX +XXX,XX @@ static void ssys_write(void *opaque, hwaddr offset,
40
+ return FIELD_EX64(id->id_aa64mmfr1, ID_AA64MMFR1, XNX) != 0;
73
s->int_status |= (1 << 6);
41
+}
74
}
42
+
75
s->rcc = value;
43
/*
76
- ssys_calculate_system_clock(s);
44
* Feature tests for "does this exist in either 32-bit or 64-bit?"
77
+ ssys_calculate_system_clock(s, true);
45
*/
78
break;
46
@@ -XXX,XX +XXX,XX @@ static inline bool isar_feature_any_ccidx(const ARMISARegisters *id)
79
case 0x070: /* RCC2 */
47
return isar_feature_aa64_ccidx(id) || isar_feature_aa32_ccidx(id);
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);
48
}
97
}
49
98
50
+static inline bool isar_feature_any_tts2uxn(const ARMISARegisters *id)
99
static void stellaris_sys_reset_exit(Object *obj)
51
+{
100
@@ -XXX,XX +XXX,XX @@ static int stellaris_sys_post_load(void *opaque, int version_id)
52
+ return isar_feature_aa64_tts2uxn(id) || isar_feature_aa32_tts2uxn(id);
53
+}
54
+
55
/*
56
* Forward to the above feature tests given an ARMCPU pointer.
57
*/
58
diff --git a/target/arm/cpu.c b/target/arm/cpu.c
59
index XXXXXXX..XXXXXXX 100644
60
--- a/target/arm/cpu.c
61
+++ b/target/arm/cpu.c
62
@@ -XXX,XX +XXX,XX @@ static void arm_max_initfn(Object *obj)
63
t = FIELD_DP32(t, ID_MMFR4, HPDS, 1); /* AA32HPD */
64
t = FIELD_DP32(t, ID_MMFR4, AC2, 1); /* ACTLR2, HACTLR2 */
65
t = FIELD_DP32(t, ID_MMFR4, CNP, 1); /* TTCNP */
66
+ t = FIELD_DP32(t, ID_MMFR4, XNX, 1); /* TTS2UXN */
67
cpu->isar.id_mmfr4 = t;
68
}
69
#endif
70
diff --git a/target/arm/cpu64.c b/target/arm/cpu64.c
71
index XXXXXXX..XXXXXXX 100644
72
--- a/target/arm/cpu64.c
73
+++ b/target/arm/cpu64.c
74
@@ -XXX,XX +XXX,XX @@ static void aarch64_max_initfn(Object *obj)
75
t = FIELD_DP64(t, ID_AA64MMFR1, VH, 1);
76
t = FIELD_DP64(t, ID_AA64MMFR1, PAN, 2); /* ATS1E1 */
77
t = FIELD_DP64(t, ID_AA64MMFR1, VMIDBITS, 2); /* VMID16 */
78
+ t = FIELD_DP64(t, ID_AA64MMFR1, XNX, 1); /* TTS2UXN */
79
cpu->isar.id_aa64mmfr1 = t;
80
81
t = cpu->isar.id_aa64mmfr2;
82
@@ -XXX,XX +XXX,XX @@ static void aarch64_max_initfn(Object *obj)
83
u = FIELD_DP32(u, ID_MMFR4, HPDS, 1); /* AA32HPD */
84
u = FIELD_DP32(u, ID_MMFR4, AC2, 1); /* ACTLR2, HACTLR2 */
85
u = FIELD_DP32(u, ID_MMFR4, CNP, 1); /* TTCNP */
86
+ u = FIELD_DP32(u, ID_MMFR4, XNX, 1); /* TTS2UXN */
87
cpu->isar.id_mmfr4 = u;
88
89
u = cpu->isar.id_aa64dfr0;
90
diff --git a/target/arm/helper.c b/target/arm/helper.c
91
index XXXXXXX..XXXXXXX 100644
92
--- a/target/arm/helper.c
93
+++ b/target/arm/helper.c
94
@@ -XXX,XX +XXX,XX @@ simple_ap_to_rw_prot(CPUARMState *env, ARMMMUIdx mmu_idx, int ap)
95
*
96
* @env: CPUARMState
97
* @s2ap: The 2-bit stage2 access permissions (S2AP)
98
- * @xn: XN (execute-never) bit
99
+ * @xn: XN (execute-never) bits
100
+ * @s1_is_el0: true if this is S2 of an S1+2 walk for EL0
101
*/
102
-static int get_S2prot(CPUARMState *env, int s2ap, int xn)
103
+static int get_S2prot(CPUARMState *env, int s2ap, int xn, bool s1_is_el0)
104
{
101
{
105
int prot = 0;
102
ssys_state *s = opaque;
106
103
107
@@ -XXX,XX +XXX,XX @@ static int get_S2prot(CPUARMState *env, int s2ap, int xn)
104
- ssys_calculate_system_clock(s);
108
if (s2ap & 2) {
105
+ ssys_calculate_system_clock(s, false);
109
prot |= PAGE_WRITE;
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()
110
}
115
}
111
- if (!xn) {
116
};
112
- if (arm_el_is_aa64(env, 2) || prot & PAGE_READ) {
117
@@ -XXX,XX +XXX,XX @@ static void stellaris_sys_instance_init(Object *obj)
113
+
118
memory_region_init_io(&s->iomem, obj, &ssys_ops, s, "ssys", 0x00001000);
114
+ if (cpu_isar_feature(any_tts2uxn, env_archcpu(env))) {
119
sysbus_init_mmio(sbd, &s->iomem);
115
+ switch (xn) {
120
sysbus_init_irq(sbd, &s->irq);
116
+ case 0:
121
+ s->sysclk = qdev_init_clock_out(DEVICE(s), "SYSCLK");
117
prot |= PAGE_EXEC;
122
}
118
+ break;
123
119
+ case 1:
124
-static int stellaris_sys_init(uint32_t base, qemu_irq irq,
120
+ if (s1_is_el0) {
125
- stellaris_board_info * board,
121
+ prot |= PAGE_EXEC;
126
- uint8_t *macaddr)
122
+ }
127
+static DeviceState *stellaris_sys_init(uint32_t base, qemu_irq irq,
123
+ break;
128
+ stellaris_board_info *board,
124
+ case 2:
129
+ uint8_t *macaddr)
125
+ break;
130
{
126
+ case 3:
131
DeviceState *dev = qdev_new(TYPE_STELLARIS_SYS);
127
+ if (!s1_is_el0) {
132
SysBusDevice *sbd = SYS_BUS_DEVICE(dev);
128
+ prot |= PAGE_EXEC;
133
@@ -XXX,XX +XXX,XX @@ static int stellaris_sys_init(uint32_t base, qemu_irq irq,
129
+ }
134
*/
130
+ break;
135
device_cold_reset(dev);
131
+ default:
136
132
+ g_assert_not_reached();
137
- return 0;
133
+ }
138
+ return dev;
134
+ } else {
139
}
135
+ if (!extract32(xn, 1, 1)) {
140
136
+ if (arm_el_is_aa64(env, 2) || prot & PAGE_READ) {
141
/* I2C controller. */
137
+ prot |= PAGE_EXEC;
142
@@ -XXX,XX +XXX,XX @@ static void stellaris_init(MachineState *ms, stellaris_board_info *board)
138
+ }
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)
139
}
151
}
140
}
152
}
141
return prot;
153
142
@@ -XXX,XX +XXX,XX @@ static bool get_phys_addr_lpae(CPUARMState *env, target_ulong address,
154
- stellaris_sys_init(0x400fe000, qdev_get_gpio_in(nvic, 28),
143
}
155
- board, nd_table[0].macaddr.a);
144
156
+ ssys_dev = stellaris_sys_init(0x400fe000, qdev_get_gpio_in(nvic, 28),
145
ap = extract32(attrs, 4, 2);
157
+ board, nd_table[0].macaddr.a);
146
- xn = extract32(attrs, 12, 1);
158
147
159
148
if (mmu_idx == ARMMMUIdx_Stage2) {
160
if (board->dc1 & (1 << 3)) { /* watchdog present */
149
ns = true;
161
@@ -XXX,XX +XXX,XX @@ static void stellaris_init(MachineState *ms, stellaris_board_info *board)
150
- *prot = get_S2prot(env, ap, xn);
162
/* system_clock_scale is valid now */
151
+ xn = extract32(attrs, 11, 2);
163
uint32_t mainclk = NANOSECONDS_PER_SECOND / system_clock_scale;
152
+ *prot = get_S2prot(env, ap, xn, s1_is_el0);
164
qdev_prop_set_uint32(dev, "wdogclk-frq", mainclk);
153
} else {
165
+ qdev_connect_clock_in(dev, "WDOGCLK",
154
ns = extract32(attrs, 3, 1);
166
+ qdev_get_clock_out(ssys_dev, "SYSCLK"));
155
+ xn = extract32(attrs, 12, 1);
167
156
pxn = extract32(attrs, 11, 1);
168
sysbus_realize_and_unref(SYS_BUS_DEVICE(dev), &error_fatal);
157
*prot = get_S1prot(env, mmu_idx, aarch64, ap, ns, xn, pxn);
169
sysbus_mmio_map(SYS_BUS_DEVICE(dev),
158
}
159
--
170
--
160
2.20.1
171
2.20.1
161
172
162
173
diff view generated by jsdifflib
1
Convert the Neon "load/store single structure to one lane" insns to
1
Switch the CMSDK APB timer device over to using its Clock input; the
2
decodetree.
2
pclk-frq property is now ignored.
3
4
As this is the last set of insns in the neon load/store group,
5
we can remove the whole disas_neon_ls_insn() function.
6
3
7
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
4
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
8
Reviewed-by: Richard Henderson <richard.henderson@linaro.org>
5
Reviewed-by: Philippe Mathieu-Daudé <f4bug@amsat.org>
9
Message-id: 20200430181003.21682-14-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
---
10
---
11
target/arm/neon-ls.decode | 11 +++
11
hw/timer/cmsdk-apb-timer.c | 18 ++++++++++++++----
12
target/arm/translate-neon.inc.c | 89 +++++++++++++++++++
12
1 file changed, 14 insertions(+), 4 deletions(-)
13
target/arm/translate.c | 147 --------------------------------
14
3 files changed, 100 insertions(+), 147 deletions(-)
15
13
16
diff --git a/target/arm/neon-ls.decode b/target/arm/neon-ls.decode
14
diff --git a/hw/timer/cmsdk-apb-timer.c b/hw/timer/cmsdk-apb-timer.c
17
index XXXXXXX..XXXXXXX 100644
15
index XXXXXXX..XXXXXXX 100644
18
--- a/target/arm/neon-ls.decode
16
--- a/hw/timer/cmsdk-apb-timer.c
19
+++ b/target/arm/neon-ls.decode
17
+++ b/hw/timer/cmsdk-apb-timer.c
20
@@ -XXX,XX +XXX,XX @@ VLDST_multiple 1111 0100 0 . l:1 0 rn:4 .... itype:4 size:2 align:2 rm:4 \
18
@@ -XXX,XX +XXX,XX @@ static void cmsdk_apb_timer_reset(DeviceState *dev)
21
19
ptimer_transaction_commit(s->timer);
22
VLD_all_lanes 1111 0100 1 . 1 0 rn:4 .... 11 n:2 size:2 t:1 a:1 rm:4 \
20
}
23
vd=%vd_dp
21
22
+static void cmsdk_apb_timer_clk_update(void *opaque)
23
+{
24
+ CMSDKAPBTimer *s = CMSDK_APB_TIMER(opaque);
24
+
25
+
25
+# Neon load/store single structure to one lane
26
+ ptimer_transaction_begin(s->timer);
26
+%imm1_5_p1 5:1 !function=plus1
27
+ ptimer_set_period_from_clock(s->timer, s->pclk, 1);
27
+%imm1_6_p1 6:1 !function=plus1
28
+ ptimer_transaction_commit(s->timer);
28
+
29
+VLDST_single 1111 0100 1 . l:1 0 rn:4 .... 00 n:2 reg_idx:3 align:1 rm:4 \
30
+ vd=%vd_dp size=0 stride=1
31
+VLDST_single 1111 0100 1 . l:1 0 rn:4 .... 01 n:2 reg_idx:2 align:2 rm:4 \
32
+ vd=%vd_dp size=1 stride=%imm1_5_p1
33
+VLDST_single 1111 0100 1 . l:1 0 rn:4 .... 10 n:2 reg_idx:1 align:3 rm:4 \
34
+ vd=%vd_dp size=2 stride=%imm1_6_p1
35
diff --git a/target/arm/translate-neon.inc.c b/target/arm/translate-neon.inc.c
36
index XXXXXXX..XXXXXXX 100644
37
--- a/target/arm/translate-neon.inc.c
38
+++ b/target/arm/translate-neon.inc.c
39
@@ -XXX,XX +XXX,XX @@
40
* It might be possible to convert it to a standalone .c file eventually.
41
*/
42
43
+static inline int plus1(DisasContext *s, int x)
44
+{
45
+ return x + 1;
46
+}
29
+}
47
+
30
+
48
/* Include the generated Neon decoder */
31
static void cmsdk_apb_timer_init(Object *obj)
49
#include "decode-neon-dp.inc.c"
32
{
50
#include "decode-neon-ls.inc.c"
33
SysBusDevice *sbd = SYS_BUS_DEVICE(obj);
51
@@ -XXX,XX +XXX,XX @@ static bool trans_VLD_all_lanes(DisasContext *s, arg_VLD_all_lanes *a)
34
@@ -XXX,XX +XXX,XX @@ static void cmsdk_apb_timer_init(Object *obj)
52
35
s, "cmsdk-apb-timer", 0x1000);
53
return true;
36
sysbus_init_mmio(sbd, &s->iomem);
37
sysbus_init_irq(sbd, &s->timerint);
38
- s->pclk = qdev_init_clock_in(DEVICE(s), "pclk", NULL, NULL);
39
+ s->pclk = qdev_init_clock_in(DEVICE(s), "pclk",
40
+ cmsdk_apb_timer_clk_update, s);
54
}
41
}
55
+
42
56
+static bool trans_VLDST_single(DisasContext *s, arg_VLDST_single *a)
43
static void cmsdk_apb_timer_realize(DeviceState *dev, Error **errp)
57
+{
44
{
58
+ /* Neon load/store single structure to one lane */
45
CMSDKAPBTimer *s = CMSDK_APB_TIMER(dev);
59
+ int reg;
46
60
+ int nregs = a->n + 1;
47
- if (s->pclk_frq == 0) {
61
+ int vd = a->vd;
48
- error_setg(errp, "CMSDK APB timer: pclk-frq property must be set");
62
+ TCGv_i32 addr, tmp;
49
+ if (!clock_has_source(s->pclk)) {
63
+
50
+ error_setg(errp, "CMSDK APB timer: pclk clock must be connected");
64
+ if (!arm_dc_feature(s, ARM_FEATURE_NEON)) {
51
return;
65
+ return false;
52
}
66
+ }
53
67
+
54
@@ -XXX,XX +XXX,XX @@ static void cmsdk_apb_timer_realize(DeviceState *dev, Error **errp)
68
+ /* UNDEF accesses to D16-D31 if they don't exist */
55
PTIMER_POLICY_NO_COUNTER_ROUND_DOWN);
69
+ if (!dc_isar_feature(aa32_simd_r32, s) && (a->vd & 0x10)) {
56
70
+ return false;
57
ptimer_transaction_begin(s->timer);
71
+ }
58
- ptimer_set_freq(s->timer, s->pclk_frq);
72
+
59
+ ptimer_set_period_from_clock(s->timer, s->pclk, 1);
73
+ /* Catch the UNDEF cases. This is unavoidably a bit messy. */
60
ptimer_transaction_commit(s->timer);
74
+ switch (nregs) {
75
+ case 1:
76
+ if (((a->align & (1 << a->size)) != 0) ||
77
+ (a->size == 2 && ((a->align & 3) == 1 || (a->align & 3) == 2))) {
78
+ return false;
79
+ }
80
+ break;
81
+ case 3:
82
+ if ((a->align & 1) != 0) {
83
+ return false;
84
+ }
85
+ /* fall through */
86
+ case 2:
87
+ if (a->size == 2 && (a->align & 2) != 0) {
88
+ return false;
89
+ }
90
+ break;
91
+ case 4:
92
+ if ((a->size == 2) && ((a->align & 3) == 3)) {
93
+ return false;
94
+ }
95
+ break;
96
+ default:
97
+ abort();
98
+ }
99
+ if ((vd + a->stride * (nregs - 1)) > 31) {
100
+ /*
101
+ * Attempts to write off the end of the register file are
102
+ * UNPREDICTABLE; we choose to UNDEF because otherwise we would
103
+ * access off the end of the array that holds the register data.
104
+ */
105
+ return false;
106
+ }
107
+
108
+ if (!vfp_access_check(s)) {
109
+ return true;
110
+ }
111
+
112
+ tmp = tcg_temp_new_i32();
113
+ addr = tcg_temp_new_i32();
114
+ load_reg_var(s, addr, a->rn);
115
+ /*
116
+ * TODO: if we implemented alignment exceptions, we should check
117
+ * addr against the alignment encoded in a->align here.
118
+ */
119
+ for (reg = 0; reg < nregs; reg++) {
120
+ if (a->l) {
121
+ gen_aa32_ld_i32(s, tmp, addr, get_mem_index(s),
122
+ s->be_data | a->size);
123
+ neon_store_element(vd, a->reg_idx, a->size, tmp);
124
+ } else { /* Store */
125
+ neon_load_element(tmp, vd, a->reg_idx, a->size);
126
+ gen_aa32_st_i32(s, tmp, addr, get_mem_index(s),
127
+ s->be_data | a->size);
128
+ }
129
+ vd += a->stride;
130
+ tcg_gen_addi_i32(addr, addr, 1 << a->size);
131
+ }
132
+ tcg_temp_free_i32(addr);
133
+ tcg_temp_free_i32(tmp);
134
+
135
+ gen_neon_ldst_base_update(s, a->rm, a->rn, (1 << a->size) * nregs);
136
+
137
+ return true;
138
+}
139
diff --git a/target/arm/translate.c b/target/arm/translate.c
140
index XXXXXXX..XXXXXXX 100644
141
--- a/target/arm/translate.c
142
+++ b/target/arm/translate.c
143
@@ -XXX,XX +XXX,XX @@ static void gen_neon_trn_u16(TCGv_i32 t0, TCGv_i32 t1)
144
tcg_temp_free_i32(rd);
145
}
61
}
146
62
147
-
148
-/* Translate a NEON load/store element instruction. Return nonzero if the
149
- instruction is invalid. */
150
-static int disas_neon_ls_insn(DisasContext *s, uint32_t insn)
151
-{
152
- int rd, rn, rm;
153
- int nregs;
154
- int stride;
155
- int size;
156
- int reg;
157
- int load;
158
- TCGv_i32 addr;
159
- TCGv_i32 tmp;
160
-
161
- if (!arm_dc_feature(s, ARM_FEATURE_NEON)) {
162
- return 1;
163
- }
164
-
165
- /* FIXME: this access check should not take precedence over UNDEF
166
- * for invalid encodings; we will generate incorrect syndrome information
167
- * for attempts to execute invalid vfp/neon encodings with FP disabled.
168
- */
169
- if (s->fp_excp_el) {
170
- gen_exception_insn(s, s->pc_curr, EXCP_UDEF,
171
- syn_simd_access_trap(1, 0xe, false), s->fp_excp_el);
172
- return 0;
173
- }
174
-
175
- if (!s->vfp_enabled)
176
- return 1;
177
- VFP_DREG_D(rd, insn);
178
- rn = (insn >> 16) & 0xf;
179
- rm = insn & 0xf;
180
- load = (insn & (1 << 21)) != 0;
181
- if ((insn & (1 << 23)) == 0) {
182
- /* Load store all elements -- handled already by decodetree */
183
- return 1;
184
- } else {
185
- size = (insn >> 10) & 3;
186
- if (size == 3) {
187
- /* Load single element to all lanes -- handled by decodetree */
188
- return 1;
189
- } else {
190
- /* Single element. */
191
- int idx = (insn >> 4) & 0xf;
192
- int reg_idx;
193
- switch (size) {
194
- case 0:
195
- reg_idx = (insn >> 5) & 7;
196
- stride = 1;
197
- break;
198
- case 1:
199
- reg_idx = (insn >> 6) & 3;
200
- stride = (insn & (1 << 5)) ? 2 : 1;
201
- break;
202
- case 2:
203
- reg_idx = (insn >> 7) & 1;
204
- stride = (insn & (1 << 6)) ? 2 : 1;
205
- break;
206
- default:
207
- abort();
208
- }
209
- nregs = ((insn >> 8) & 3) + 1;
210
- /* Catch the UNDEF cases. This is unavoidably a bit messy. */
211
- switch (nregs) {
212
- case 1:
213
- if (((idx & (1 << size)) != 0) ||
214
- (size == 2 && ((idx & 3) == 1 || (idx & 3) == 2))) {
215
- return 1;
216
- }
217
- break;
218
- case 3:
219
- if ((idx & 1) != 0) {
220
- return 1;
221
- }
222
- /* fall through */
223
- case 2:
224
- if (size == 2 && (idx & 2) != 0) {
225
- return 1;
226
- }
227
- break;
228
- case 4:
229
- if ((size == 2) && ((idx & 3) == 3)) {
230
- return 1;
231
- }
232
- break;
233
- default:
234
- abort();
235
- }
236
- if ((rd + stride * (nregs - 1)) > 31) {
237
- /* Attempts to write off the end of the register file
238
- * are UNPREDICTABLE; we choose to UNDEF because otherwise
239
- * the neon_load_reg() would write off the end of the array.
240
- */
241
- return 1;
242
- }
243
- tmp = tcg_temp_new_i32();
244
- addr = tcg_temp_new_i32();
245
- load_reg_var(s, addr, rn);
246
- for (reg = 0; reg < nregs; reg++) {
247
- if (load) {
248
- gen_aa32_ld_i32(s, tmp, addr, get_mem_index(s),
249
- s->be_data | size);
250
- neon_store_element(rd, reg_idx, size, tmp);
251
- } else { /* Store */
252
- neon_load_element(tmp, rd, reg_idx, size);
253
- gen_aa32_st_i32(s, tmp, addr, get_mem_index(s),
254
- s->be_data | size);
255
- }
256
- rd += stride;
257
- tcg_gen_addi_i32(addr, addr, 1 << size);
258
- }
259
- tcg_temp_free_i32(addr);
260
- tcg_temp_free_i32(tmp);
261
- stride = nregs * (1 << size);
262
- }
263
- }
264
- if (rm != 15) {
265
- TCGv_i32 base;
266
-
267
- base = load_reg(s, rn);
268
- if (rm == 13) {
269
- tcg_gen_addi_i32(base, base, stride);
270
- } else {
271
- TCGv_i32 index;
272
- index = load_reg(s, rm);
273
- tcg_gen_add_i32(base, base, index);
274
- tcg_temp_free_i32(index);
275
- }
276
- store_reg(s, rn, base);
277
- }
278
- return 0;
279
-}
280
-
281
static inline void gen_neon_narrow(int size, TCGv_i32 dest, TCGv_i64 src)
282
{
283
switch (size) {
284
@@ -XXX,XX +XXX,XX @@ static void disas_arm_insn(DisasContext *s, unsigned int insn)
285
}
286
return;
287
}
288
- if ((insn & 0x0f100000) == 0x04000000) {
289
- /* NEON load/store. */
290
- if (disas_neon_ls_insn(s, insn)) {
291
- goto illegal_op;
292
- }
293
- return;
294
- }
295
if ((insn & 0x0e000f00) == 0x0c000100) {
296
if (arm_dc_feature(s, ARM_FEATURE_IWMMXT)) {
297
/* iWMMXt register transfer. */
298
@@ -XXX,XX +XXX,XX @@ static void disas_thumb2_insn(DisasContext *s, uint32_t insn)
299
}
300
break;
301
case 12:
302
- if ((insn & 0x01100000) == 0x01000000) {
303
- if (disas_neon_ls_insn(s, insn)) {
304
- goto illegal_op;
305
- }
306
- break;
307
- }
308
goto illegal_op;
309
default:
310
illegal_op:
311
--
63
--
312
2.20.1
64
2.20.1
313
65
314
66
diff view generated by jsdifflib
1
From: "Edgar E. Iglesias" <edgar.iglesias@xilinx.com>
1
Switch the CMSDK APB dualtimer device over to using its Clock input;
2
the pclk-frq property is now ignored.
2
3
3
Add support for SD.
4
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
---
12
hw/timer/cmsdk-apb-dualtimer.c | 42 ++++++++++++++++++++++++++++++----
13
1 file changed, 37 insertions(+), 5 deletions(-)
4
14
5
Signed-off-by: Edgar E. Iglesias <edgar.iglesias@xilinx.com>
15
diff --git a/hw/timer/cmsdk-apb-dualtimer.c b/hw/timer/cmsdk-apb-dualtimer.c
6
Reviewed-by: Alistair Francis <alistair.francis@wdc.com>
7
Reviewed-by: Luc Michel <luc.michel@greensocs.com>
8
Message-id: 20200427181649.26851-11-edgar.iglesias@gmail.com
9
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
10
---
11
hw/arm/xlnx-versal-virt.c | 46 +++++++++++++++++++++++++++++++++++++++
12
1 file changed, 46 insertions(+)
13
14
diff --git a/hw/arm/xlnx-versal-virt.c b/hw/arm/xlnx-versal-virt.c
15
index XXXXXXX..XXXXXXX 100644
16
index XXXXXXX..XXXXXXX 100644
16
--- a/hw/arm/xlnx-versal-virt.c
17
--- a/hw/timer/cmsdk-apb-dualtimer.c
17
+++ b/hw/arm/xlnx-versal-virt.c
18
+++ b/hw/timer/cmsdk-apb-dualtimer.c
18
@@ -XXX,XX +XXX,XX @@
19
@@ -XXX,XX +XXX,XX @@ static void cmsdk_apb_dualtimer_update(CMSDKAPBDualTimer *s)
19
#include "hw/arm/sysbus-fdt.h"
20
qemu_set_irq(s->timerintc, timintc);
20
#include "hw/arm/fdt.h"
21
#include "cpu.h"
22
+#include "hw/qdev-properties.h"
23
#include "hw/arm/xlnx-versal.h"
24
25
#define TYPE_XLNX_VERSAL_VIRT_MACHINE MACHINE_TYPE_NAME("xlnx-versal-virt")
26
@@ -XXX,XX +XXX,XX @@ static void fdt_add_zdma_nodes(VersalVirt *s)
27
}
28
}
21
}
29
22
30
+static void fdt_add_sd_nodes(VersalVirt *s)
23
+static int cmsdk_dualtimermod_divisor(CMSDKAPBDualTimerModule *m)
31
+{
24
+{
32
+ const char clocknames[] = "clk_xin\0clk_ahb";
25
+ /* Return the divisor set by the current CONTROL.PRESCALE value */
33
+ const char compat[] = "arasan,sdhci-8.9a";
26
+ switch (FIELD_EX32(m->control, CONTROL, PRESCALE)) {
34
+ int i;
27
+ case 0:
35
+
28
+ return 1;
36
+ for (i = ARRAY_SIZE(s->soc.pmc.iou.sd) - 1; i >= 0; i--) {
29
+ case 1:
37
+ uint64_t addr = MM_PMC_SD0 + MM_PMC_SD0_SIZE * i;
30
+ return 16;
38
+ char *name = g_strdup_printf("/sdhci@%" PRIx64, addr);
31
+ case 2:
39
+
32
+ case 3: /* UNDEFINED, we treat like 2 (and complained when it was set) */
40
+ qemu_fdt_add_subnode(s->fdt, name);
33
+ return 256;
41
+
34
+ default:
42
+ qemu_fdt_setprop_cells(s->fdt, name, "clocks",
35
+ g_assert_not_reached();
43
+ s->phandle.clk_25Mhz, s->phandle.clk_25Mhz);
44
+ qemu_fdt_setprop(s->fdt, name, "clock-names",
45
+ clocknames, sizeof(clocknames));
46
+ qemu_fdt_setprop_cells(s->fdt, name, "interrupts",
47
+ GIC_FDT_IRQ_TYPE_SPI, VERSAL_SD0_IRQ_0 + i * 2,
48
+ GIC_FDT_IRQ_FLAGS_LEVEL_HI);
49
+ qemu_fdt_setprop_sized_cells(s->fdt, name, "reg",
50
+ 2, addr, 2, MM_PMC_SD0_SIZE);
51
+ qemu_fdt_setprop(s->fdt, name, "compatible", compat, sizeof(compat));
52
+ g_free(name);
53
+ }
36
+ }
54
+}
37
+}
55
+
38
+
56
static void fdt_nop_memory_nodes(void *fdt, Error **errp)
39
static void cmsdk_dualtimermod_write_control(CMSDKAPBDualTimerModule *m,
40
uint32_t newctrl)
57
{
41
{
58
Error *err = NULL;
42
@@ -XXX,XX +XXX,XX @@ static void cmsdk_dualtimermod_write_control(CMSDKAPBDualTimerModule *m,
59
@@ -XXX,XX +XXX,XX @@ static void create_virtio_regions(VersalVirt *s)
43
default:
44
g_assert_not_reached();
45
}
46
- ptimer_set_freq(m->timer, m->parent->pclk_frq / divisor);
47
+ ptimer_set_period_from_clock(m->timer, m->parent->timclk, divisor);
60
}
48
}
49
50
if (changed & R_CONTROL_MODE_MASK) {
51
@@ -XXX,XX +XXX,XX @@ static void cmsdk_dualtimermod_reset(CMSDKAPBDualTimerModule *m)
52
* limit must both be set to 0xffff, so we wrap at 16 bits.
53
*/
54
ptimer_set_limit(m->timer, 0xffff, 1);
55
- ptimer_set_freq(m->timer, m->parent->pclk_frq);
56
+ ptimer_set_period_from_clock(m->timer, m->parent->timclk,
57
+ cmsdk_dualtimermod_divisor(m));
58
ptimer_transaction_commit(m->timer);
61
}
59
}
62
60
63
+static void sd_plugin_card(SDHCIState *sd, DriveInfo *di)
61
@@ -XXX,XX +XXX,XX @@ static void cmsdk_apb_dualtimer_reset(DeviceState *dev)
62
s->timeritop = 0;
63
}
64
65
+static void cmsdk_apb_dualtimer_clk_update(void *opaque)
64
+{
66
+{
65
+ BlockBackend *blk = di ? blk_by_legacy_dinfo(di) : NULL;
67
+ CMSDKAPBDualTimer *s = CMSDK_APB_DUALTIMER(opaque);
66
+ DeviceState *card;
68
+ int i;
67
+
69
+
68
+ card = qdev_create(qdev_get_child_bus(DEVICE(sd), "sd-bus"), TYPE_SD_CARD);
70
+ for (i = 0; i < ARRAY_SIZE(s->timermod); i++) {
69
+ object_property_add_child(OBJECT(sd), "card[*]", OBJECT(card),
71
+ CMSDKAPBDualTimerModule *m = &s->timermod[i];
70
+ &error_fatal);
72
+ ptimer_transaction_begin(m->timer);
71
+ qdev_prop_set_drive(card, "drive", blk, &error_fatal);
73
+ ptimer_set_period_from_clock(m->timer, m->parent->timclk,
72
+ object_property_set_bool(OBJECT(card), true, "realized", &error_fatal);
74
+ cmsdk_dualtimermod_divisor(m));
75
+ ptimer_transaction_commit(m->timer);
76
+ }
73
+}
77
+}
74
+
78
+
75
static void versal_virt_init(MachineState *machine)
79
static void cmsdk_apb_dualtimer_init(Object *obj)
76
{
80
{
77
VersalVirt *s = XLNX_VERSAL_VIRT_MACHINE(machine);
81
SysBusDevice *sbd = SYS_BUS_DEVICE(obj);
78
int psci_conduit = QEMU_PSCI_CONDUIT_DISABLED;
82
@@ -XXX,XX +XXX,XX @@ static void cmsdk_apb_dualtimer_init(Object *obj)
79
+ int i;
83
for (i = 0; i < ARRAY_SIZE(s->timermod); i++) {
80
84
sysbus_init_irq(sbd, &s->timermod[i].timerint);
81
/*
85
}
82
* If the user provides an Operating System to be loaded, we expect them
86
- s->timclk = qdev_init_clock_in(DEVICE(s), "TIMCLK", NULL, NULL);
83
@@ -XXX,XX +XXX,XX @@ static void versal_virt_init(MachineState *machine)
87
+ s->timclk = qdev_init_clock_in(DEVICE(s), "TIMCLK",
84
fdt_add_gic_nodes(s);
88
+ cmsdk_apb_dualtimer_clk_update, s);
85
fdt_add_timer_nodes(s);
89
}
86
fdt_add_zdma_nodes(s);
90
87
+ fdt_add_sd_nodes(s);
91
static void cmsdk_apb_dualtimer_realize(DeviceState *dev, Error **errp)
88
fdt_add_cpu_nodes(s, psci_conduit);
92
@@ -XXX,XX +XXX,XX @@ static void cmsdk_apb_dualtimer_realize(DeviceState *dev, Error **errp)
89
fdt_add_clk_node(s, "/clk125", 125000000, s->phandle.clk_125Mhz);
93
CMSDKAPBDualTimer *s = CMSDK_APB_DUALTIMER(dev);
90
fdt_add_clk_node(s, "/clk25", 25000000, s->phandle.clk_25Mhz);
94
int i;
91
@@ -XXX,XX +XXX,XX @@ static void versal_virt_init(MachineState *machine)
95
92
memory_region_add_subregion_overlap(get_system_memory(),
96
- if (s->pclk_frq == 0) {
93
0, &s->soc.fpd.apu.mr, 0);
97
- error_setg(errp, "CMSDK APB timer: pclk-frq property must be set");
94
98
+ if (!clock_has_source(s->timclk)) {
95
+ /* Plugin SD cards. */
99
+ error_setg(errp, "CMSDK APB dualtimer: TIMCLK clock must be connected");
96
+ for (i = 0; i < ARRAY_SIZE(s->soc.pmc.iou.sd); i++) {
100
return;
97
+ sd_plugin_card(&s->soc.pmc.iou.sd[i], drive_get_next(IF_SD));
101
}
98
+ }
102
99
+
100
s->binfo.ram_size = machine->ram_size;
101
s->binfo.loader_start = 0x0;
102
s->binfo.get_dtb = versal_virt_get_dtb;
103
--
103
--
104
2.20.1
104
2.20.1
105
105
106
106
diff view generated by jsdifflib
1
For ARMv8.2-TTS2UXN, the stage 2 page table walk wants to know
1
Switch the CMSDK APB watchdog device over to using its Clock input;
2
whether the stage 1 access is for EL0 or not, because whether
2
the wdogclk_frq property is now ignored.
3
exec permission is given can depend on whether this is an EL0
4
or EL1 access. Add a new argument to get_phys_addr_lpae() so
5
the call sites can pass this information in.
6
7
Since get_phys_addr_lpae() doesn't already have a doc comment,
8
add one so we have a place to put the documentation of the
9
semantics of the new s1_is_el0 argument.
10
3
11
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
4
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
12
Reviewed-by: Edgar E. Iglesias <edgar.iglesias@xilinx.com>
5
Reviewed-by: Philippe Mathieu-Daudé <f4bug@amsat.org>
13
Reviewed-by: Richard Henderson <richard.henderson@linaro.org>
6
Reviewed-by: Luc Michel <luc@lmichel.fr>
14
Message-id: 20200330210400.11724-4-peter.maydell@linaro.org
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
15
---
10
---
16
target/arm/helper.c | 29 ++++++++++++++++++++++++++++-
11
hw/watchdog/cmsdk-apb-watchdog.c | 18 ++++++++++++++----
17
1 file changed, 28 insertions(+), 1 deletion(-)
12
1 file changed, 14 insertions(+), 4 deletions(-)
18
13
19
diff --git a/target/arm/helper.c b/target/arm/helper.c
14
diff --git a/hw/watchdog/cmsdk-apb-watchdog.c b/hw/watchdog/cmsdk-apb-watchdog.c
20
index XXXXXXX..XXXXXXX 100644
15
index XXXXXXX..XXXXXXX 100644
21
--- a/target/arm/helper.c
16
--- a/hw/watchdog/cmsdk-apb-watchdog.c
22
+++ b/target/arm/helper.c
17
+++ b/hw/watchdog/cmsdk-apb-watchdog.c
23
@@ -XXX,XX +XXX,XX @@
18
@@ -XXX,XX +XXX,XX @@ static void cmsdk_apb_watchdog_reset(DeviceState *dev)
24
19
ptimer_transaction_commit(s->timer);
25
static bool get_phys_addr_lpae(CPUARMState *env, target_ulong address,
26
MMUAccessType access_type, ARMMMUIdx mmu_idx,
27
+ bool s1_is_el0,
28
hwaddr *phys_ptr, MemTxAttrs *txattrs, int *prot,
29
target_ulong *page_size_ptr,
30
ARMMMUFaultInfo *fi, ARMCacheAttrs *cacheattrs);
31
@@ -XXX,XX +XXX,XX @@ static hwaddr S1_ptw_translate(CPUARMState *env, ARMMMUIdx mmu_idx,
32
}
33
34
ret = get_phys_addr_lpae(env, addr, MMU_DATA_LOAD, ARMMMUIdx_Stage2,
35
+ false,
36
&s2pa, &txattrs, &s2prot, &s2size, fi,
37
pcacheattrs);
38
if (ret) {
39
@@ -XXX,XX +XXX,XX @@ static ARMVAParameters aa32_va_parameters(CPUARMState *env, uint32_t va,
40
};
41
}
20
}
42
21
43
+/**
22
+static void cmsdk_apb_watchdog_clk_update(void *opaque)
44
+ * get_phys_addr_lpae: perform one stage of page table walk, LPAE format
23
+{
45
+ *
24
+ CMSDKAPBWatchdog *s = CMSDK_APB_WATCHDOG(opaque);
46
+ * Returns false if the translation was successful. Otherwise, phys_ptr, attrs,
25
+
47
+ * prot and page_size may not be filled in, and the populated fsr value provides
26
+ ptimer_transaction_begin(s->timer);
48
+ * information on why the translation aborted, in the format of a long-format
27
+ ptimer_set_period_from_clock(s->timer, s->wdogclk, 1);
49
+ * DFSR/IFSR fault register, with the following caveats:
28
+ ptimer_transaction_commit(s->timer);
50
+ * * the WnR bit is never set (the caller must do this).
29
+}
51
+ *
30
+
52
+ * @env: CPUARMState
31
static void cmsdk_apb_watchdog_init(Object *obj)
53
+ * @address: virtual address to get physical address for
32
{
54
+ * @access_type: MMU_DATA_LOAD, MMU_DATA_STORE or MMU_INST_FETCH
33
SysBusDevice *sbd = SYS_BUS_DEVICE(obj);
55
+ * @mmu_idx: MMU index indicating required translation regime
34
@@ -XXX,XX +XXX,XX @@ static void cmsdk_apb_watchdog_init(Object *obj)
56
+ * @s1_is_el0: if @mmu_idx is ARMMMUIdx_Stage2 (so this is a stage 2 page table
35
s, "cmsdk-apb-watchdog", 0x1000);
57
+ * walk), must be true if this is stage 2 of a stage 1+2 walk for an
36
sysbus_init_mmio(sbd, &s->iomem);
58
+ * EL0 access). If @mmu_idx is anything else, @s1_is_el0 is ignored.
37
sysbus_init_irq(sbd, &s->wdogint);
59
+ * @phys_ptr: set to the physical address corresponding to the virtual address
38
- s->wdogclk = qdev_init_clock_in(DEVICE(s), "WDOGCLK", NULL, NULL);
60
+ * @attrs: set to the memory transaction attributes to use
39
+ s->wdogclk = qdev_init_clock_in(DEVICE(s), "WDOGCLK",
61
+ * @prot: set to the permissions for the page containing phys_ptr
40
+ cmsdk_apb_watchdog_clk_update, s);
62
+ * @page_size_ptr: set to the size of the page containing phys_ptr
41
63
+ * @fi: set to fault info if the translation fails
42
s->is_luminary = false;
64
+ * @cacheattrs: (if non-NULL) set to the cacheability/shareability attributes
43
s->id = cmsdk_apb_watchdog_id;
65
+ */
44
@@ -XXX,XX +XXX,XX @@ static void cmsdk_apb_watchdog_realize(DeviceState *dev, Error **errp)
66
static bool get_phys_addr_lpae(CPUARMState *env, target_ulong address,
45
{
67
MMUAccessType access_type, ARMMMUIdx mmu_idx,
46
CMSDKAPBWatchdog *s = CMSDK_APB_WATCHDOG(dev);
68
+ bool s1_is_el0,
47
69
hwaddr *phys_ptr, MemTxAttrs *txattrs, int *prot,
48
- if (s->wdogclk_frq == 0) {
70
target_ulong *page_size_ptr,
49
+ if (!clock_has_source(s->wdogclk)) {
71
ARMMMUFaultInfo *fi, ARMCacheAttrs *cacheattrs)
50
error_setg(errp,
72
@@ -XXX,XX +XXX,XX @@ bool get_phys_addr(CPUARMState *env, target_ulong address,
51
- "CMSDK APB watchdog: wdogclk-frq property must be set");
73
52
+ "CMSDK APB watchdog: WDOGCLK clock must be connected");
74
/* S1 is done. Now do S2 translation. */
53
return;
75
ret = get_phys_addr_lpae(env, ipa, access_type, ARMMMUIdx_Stage2,
76
+ mmu_idx == ARMMMUIdx_E10_0,
77
phys_ptr, attrs, &s2_prot,
78
page_size, fi,
79
cacheattrs != NULL ? &cacheattrs2 : NULL);
80
@@ -XXX,XX +XXX,XX @@ bool get_phys_addr(CPUARMState *env, target_ulong address,
81
}
54
}
82
55
83
if (regime_using_lpae_format(env, mmu_idx)) {
56
@@ -XXX,XX +XXX,XX @@ static void cmsdk_apb_watchdog_realize(DeviceState *dev, Error **errp)
84
- return get_phys_addr_lpae(env, address, access_type, mmu_idx,
57
PTIMER_POLICY_NO_COUNTER_ROUND_DOWN);
85
+ return get_phys_addr_lpae(env, address, access_type, mmu_idx, false,
58
86
phys_ptr, attrs, prot, page_size,
59
ptimer_transaction_begin(s->timer);
87
fi, cacheattrs);
60
- ptimer_set_freq(s->timer, s->wdogclk_frq);
88
} else if (regime_sctlr(env, mmu_idx) & SCTLR_XP) {
61
+ ptimer_set_period_from_clock(s->timer, s->wdogclk, 1);
62
ptimer_transaction_commit(s->timer);
63
}
64
89
--
65
--
90
2.20.1
66
2.20.1
91
67
92
68
diff view generated by jsdifflib
1
From: "Edgar E. Iglesias" <edgar.iglesias@xilinx.com>
1
Now that the CMSDK APB watchdog uses its Clock input, it will
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.
2
6
3
hw/arm: versal: Add support for the RTC.
7
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
---
14
tests/qtest/cmsdk-apb-watchdog-test.c | 52 +++++++++++++++++++++++++++
15
1 file changed, 52 insertions(+)
4
16
5
Signed-off-by: Edgar E. Iglesias <edgar.iglesias@xilinx.com>
17
diff --git a/tests/qtest/cmsdk-apb-watchdog-test.c b/tests/qtest/cmsdk-apb-watchdog-test.c
6
Reviewed-by: Philippe Mathieu-Daudé <f4bug@amsat.org>
7
Reviewed-by: Alistair Francis <alistair.francis@wdc.com>
8
Reviewed-by: Luc Michel <luc.michel@greensocs.com>
9
Message-id: 20200427181649.26851-10-edgar.iglesias@gmail.com
10
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
11
---
12
include/hw/arm/xlnx-versal.h | 8 ++++++++
13
hw/arm/xlnx-versal.c | 21 +++++++++++++++++++++
14
2 files changed, 29 insertions(+)
15
16
diff --git a/include/hw/arm/xlnx-versal.h b/include/hw/arm/xlnx-versal.h
17
index XXXXXXX..XXXXXXX 100644
18
index XXXXXXX..XXXXXXX 100644
18
--- a/include/hw/arm/xlnx-versal.h
19
--- a/tests/qtest/cmsdk-apb-watchdog-test.c
19
+++ b/include/hw/arm/xlnx-versal.h
20
+++ b/tests/qtest/cmsdk-apb-watchdog-test.c
20
@@ -XXX,XX +XXX,XX @@
21
@@ -XXX,XX +XXX,XX @@
21
#include "hw/char/pl011.h"
22
*/
22
#include "hw/dma/xlnx-zdma.h"
23
23
#include "hw/net/cadence_gem.h"
24
#include "qemu/osdep.h"
24
+#include "hw/rtc/xlnx-zynqmp-rtc.h"
25
+#include "qemu/bitops.h"
25
26
#include "libqtest-single.h"
26
#define TYPE_XLNX_VERSAL "xlnx-versal"
27
27
#define XLNX_VERSAL(obj) OBJECT_CHECK(Versal, (obj), TYPE_XLNX_VERSAL)
28
/*
28
@@ -XXX,XX +XXX,XX @@ typedef struct Versal {
29
@@ -XXX,XX +XXX,XX @@
29
struct {
30
#define WDOGMIS 0x14
30
SDHCIState sd[XLNX_VERSAL_NR_SDS];
31
#define WDOGLOCK 0xc00
31
} iou;
32
33
+#define SSYS_BASE 0x400fe000
34
+#define RCC 0x60
35
+#define SYSDIV_SHIFT 23
36
+#define SYSDIV_LENGTH 4
32
+
37
+
33
+ XlnxZynqMPRTC rtc;
38
static void test_watchdog(void)
34
} pmc;
39
{
35
40
g_assert_cmpuint(readl(WDOG_BASE + WDOGRIS), ==, 0);
36
struct {
41
@@ -XXX,XX +XXX,XX @@ static void test_watchdog(void)
37
@@ -XXX,XX +XXX,XX @@ typedef struct Versal {
42
g_assert_cmpuint(readl(WDOG_BASE + WDOGRIS), ==, 0);
38
#define VERSAL_GEM1_IRQ_0 58
39
#define VERSAL_GEM1_WAKE_IRQ_0 59
40
#define VERSAL_ADMA_IRQ_0 60
41
+#define VERSAL_RTC_APB_ERR_IRQ 121
42
#define VERSAL_SD0_IRQ_0 126
43
+#define VERSAL_RTC_ALARM_IRQ 142
44
+#define VERSAL_RTC_SECONDS_IRQ 143
45
46
/* Architecturally reserved IRQs suitable for virtualization. */
47
#define VERSAL_RSVD_IRQ_FIRST 111
48
@@ -XXX,XX +XXX,XX @@ typedef struct Versal {
49
#define MM_PMC_SD0_SIZE 0x10000
50
#define MM_PMC_CRP 0xf1260000U
51
#define MM_PMC_CRP_SIZE 0x10000
52
+#define MM_PMC_RTC 0xf12a0000
53
+#define MM_PMC_RTC_SIZE 0x10000
54
#endif
55
diff --git a/hw/arm/xlnx-versal.c b/hw/arm/xlnx-versal.c
56
index XXXXXXX..XXXXXXX 100644
57
--- a/hw/arm/xlnx-versal.c
58
+++ b/hw/arm/xlnx-versal.c
59
@@ -XXX,XX +XXX,XX @@ static void versal_create_sds(Versal *s, qemu_irq *pic)
60
}
61
}
43
}
62
44
63
+static void versal_create_rtc(Versal *s, qemu_irq *pic)
45
+static void test_clock_change(void)
64
+{
46
+{
65
+ SysBusDevice *sbd;
47
+ uint32_t rcc;
66
+ MemoryRegion *mr;
67
+
68
+ sysbus_init_child_obj(OBJECT(s), "rtc", &s->pmc.rtc, sizeof(s->pmc.rtc),
69
+ TYPE_XLNX_ZYNQMP_RTC);
70
+ sbd = SYS_BUS_DEVICE(&s->pmc.rtc);
71
+ qdev_init_nofail(DEVICE(sbd));
72
+
73
+ mr = sysbus_mmio_get_region(sbd, 0);
74
+ memory_region_add_subregion(&s->mr_ps, MM_PMC_RTC, mr);
75
+
48
+
76
+ /*
49
+ /*
77
+ * TODO: Connect the ALARM and SECONDS interrupts once our RTC model
50
+ * Test that writing to the stellaris board's RCC register to
78
+ * supports them.
51
+ * change the system clock frequency causes the watchdog
52
+ * to change the speed it counts at.
79
+ */
53
+ */
80
+ sysbus_connect_irq(sbd, 1, pic[VERSAL_RTC_APB_ERR_IRQ]);
54
+ g_assert_cmpuint(readl(WDOG_BASE + WDOGRIS), ==, 0);
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);
81
+}
87
+}
82
+
88
+
83
/* This takes the board allocated linear DDR memory and creates aliases
89
int main(int argc, char **argv)
84
* for each split DDR range/aperture on the Versal address map.
90
{
85
*/
91
int r;
86
@@ -XXX,XX +XXX,XX @@ static void versal_realize(DeviceState *dev, Error **errp)
92
@@ -XXX,XX +XXX,XX @@ int main(int argc, char **argv)
87
versal_create_gems(s, pic);
93
qtest_start("-machine lm3s811evb");
88
versal_create_admas(s, pic);
94
89
versal_create_sds(s, pic);
95
qtest_add_func("/cmsdk-apb-watchdog/watchdog", test_watchdog);
90
+ versal_create_rtc(s, pic);
96
+ qtest_add_func("/cmsdk-apb-watchdog/watchdog_clock_change",
91
versal_map_ddr(s);
97
+ test_clock_change);
92
versal_unimp(s);
98
99
r = g_test_run();
93
100
94
--
101
--
95
2.20.1
102
2.20.1
96
103
97
104
diff view generated by jsdifflib
1
Convert the Neon "load/store multiple structures" insns to decodetree.
1
Use the MAINCLK Clock input to set the system_clock_scale variable
2
rather than using the mainclk_frq property.
2
3
3
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
4
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
4
Reviewed-by: Richard Henderson <richard.henderson@linaro.org>
5
Reviewed-by: Philippe Mathieu-Daudé <f4bug@amsat.org>
5
Message-id: 20200430181003.21682-12-peter.maydell@linaro.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
6
---
10
---
7
target/arm/neon-ls.decode | 7 ++
11
hw/arm/armsse.c | 24 +++++++++++++++++++-----
8
target/arm/translate-neon.inc.c | 124 ++++++++++++++++++++++++++++++++
12
1 file changed, 19 insertions(+), 5 deletions(-)
9
target/arm/translate.c | 91 +----------------------
10
3 files changed, 133 insertions(+), 89 deletions(-)
11
13
12
diff --git a/target/arm/neon-ls.decode b/target/arm/neon-ls.decode
14
diff --git a/hw/arm/armsse.c b/hw/arm/armsse.c
13
index XXXXXXX..XXXXXXX 100644
15
index XXXXXXX..XXXXXXX 100644
14
--- a/target/arm/neon-ls.decode
16
--- a/hw/arm/armsse.c
15
+++ b/target/arm/neon-ls.decode
17
+++ b/hw/arm/armsse.c
16
@@ -XXX,XX +XXX,XX @@
18
@@ -XXX,XX +XXX,XX @@ static void armsse_forward_sec_resp_cfg(ARMSSE *s)
17
# 0b1111_1001_xxx0_xxxx_xxxx_xxxx_xxxx_xxxx
19
qdev_connect_gpio_out(dev_splitter, 2, s->sec_resp_cfg_in);
18
# This file works on the A32 encoding only; calling code for T32 has to
19
# transform the insn into the A32 version first.
20
+
21
+%vd_dp 22:1 12:4
22
+
23
+# Neon load/store multiple structures
24
+
25
+VLDST_multiple 1111 0100 0 . l:1 0 rn:4 .... itype:4 size:2 align:2 rm:4 \
26
+ vd=%vd_dp
27
diff --git a/target/arm/translate-neon.inc.c b/target/arm/translate-neon.inc.c
28
index XXXXXXX..XXXXXXX 100644
29
--- a/target/arm/translate-neon.inc.c
30
+++ b/target/arm/translate-neon.inc.c
31
@@ -XXX,XX +XXX,XX @@ static bool trans_VFML_scalar(DisasContext *s, arg_VFML_scalar *a)
32
gen_helper_gvec_fmlal_idx_a32);
33
return true;
34
}
20
}
35
+
21
36
+static struct {
22
+static void armsse_mainclk_update(void *opaque)
37
+ int nregs;
38
+ int interleave;
39
+ int spacing;
40
+} const neon_ls_element_type[11] = {
41
+ {1, 4, 1},
42
+ {1, 4, 2},
43
+ {4, 1, 1},
44
+ {2, 2, 2},
45
+ {1, 3, 1},
46
+ {1, 3, 2},
47
+ {3, 1, 1},
48
+ {1, 1, 1},
49
+ {1, 2, 1},
50
+ {1, 2, 2},
51
+ {2, 1, 1}
52
+};
53
+
54
+static void gen_neon_ldst_base_update(DisasContext *s, int rm, int rn,
55
+ int stride)
56
+{
23
+{
57
+ if (rm != 15) {
24
+ ARMSSE *s = ARM_SSE(opaque);
58
+ TCGv_i32 base;
25
+ /*
59
+
26
+ * Set system_clock_scale from our Clock input; this is what
60
+ base = load_reg(s, rn);
27
+ * controls the tick rate of the CPU SysTick timer.
61
+ if (rm == 13) {
28
+ */
62
+ tcg_gen_addi_i32(base, base, stride);
29
+ system_clock_scale = clock_ticks_to_ns(s->mainclk, 1);
63
+ } else {
64
+ TCGv_i32 index;
65
+ index = load_reg(s, rm);
66
+ tcg_gen_add_i32(base, base, index);
67
+ tcg_temp_free_i32(index);
68
+ }
69
+ store_reg(s, rn, base);
70
+ }
71
+}
30
+}
72
+
31
+
73
+static bool trans_VLDST_multiple(DisasContext *s, arg_VLDST_multiple *a)
32
static void armsse_init(Object *obj)
74
+{
33
{
75
+ /* Neon load/store multiple structures */
34
ARMSSE *s = ARM_SSE(obj);
76
+ int nregs, interleave, spacing, reg, n;
35
@@ -XXX,XX +XXX,XX @@ static void armsse_init(Object *obj)
77
+ MemOp endian = s->be_data;
36
assert(info->sram_banks <= MAX_SRAM_BANKS);
78
+ int mmu_idx = get_mem_index(s);
37
assert(info->num_cpus <= SSE_MAX_CPUS);
79
+ int size = a->size;
38
80
+ TCGv_i64 tmp64;
39
- s->mainclk = qdev_init_clock_in(DEVICE(s), "MAINCLK", NULL, NULL);
81
+ TCGv_i32 addr, tmp;
40
+ s->mainclk = qdev_init_clock_in(DEVICE(s), "MAINCLK",
82
+
41
+ armsse_mainclk_update, s);
83
+ if (!arm_dc_feature(s, ARM_FEATURE_NEON)) {
42
s->s32kclk = qdev_init_clock_in(DEVICE(s), "S32KCLK", NULL, NULL);
84
+ return false;
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");
85
+ }
54
+ }
86
+
55
+ if (!clock_has_source(s->s32kclk)) {
87
+ /* UNDEF accesses to D16-D31 if they don't exist */
56
+ error_setg(errp, "S32KCLK clock was not connected");
88
+ if (!dc_isar_feature(aa32_simd_r32, s) && (a->vd & 0x10)) {
57
}
89
+ return false;
58
90
+ }
59
assert(info->num_cpus <= SSE_MAX_CPUS);
91
+ if (a->itype > 10) {
60
@@ -XXX,XX +XXX,XX @@ static void armsse_realize(DeviceState *dev, Error **errp)
92
+ return false;
61
*/
93
+ }
62
sysbus_init_mmio(SYS_BUS_DEVICE(s), &s->container);
94
+ /* Catch UNDEF cases for bad values of align field */
63
95
+ switch (a->itype & 0xc) {
64
- system_clock_scale = NANOSECONDS_PER_SECOND / s->mainclk_frq;
96
+ case 4:
65
+ /* Set initial system_clock_scale from MAINCLK */
97
+ if (a->align >= 2) {
66
+ armsse_mainclk_update(s);
98
+ return false;
99
+ }
100
+ break;
101
+ case 8:
102
+ if (a->align == 3) {
103
+ return false;
104
+ }
105
+ break;
106
+ default:
107
+ break;
108
+ }
109
+ nregs = neon_ls_element_type[a->itype].nregs;
110
+ interleave = neon_ls_element_type[a->itype].interleave;
111
+ spacing = neon_ls_element_type[a->itype].spacing;
112
+ if (size == 3 && (interleave | spacing) != 1) {
113
+ return false;
114
+ }
115
+
116
+ if (!vfp_access_check(s)) {
117
+ return true;
118
+ }
119
+
120
+ /* For our purposes, bytes are always little-endian. */
121
+ if (size == 0) {
122
+ endian = MO_LE;
123
+ }
124
+ /*
125
+ * Consecutive little-endian elements from a single register
126
+ * can be promoted to a larger little-endian operation.
127
+ */
128
+ if (interleave == 1 && endian == MO_LE) {
129
+ size = 3;
130
+ }
131
+ tmp64 = tcg_temp_new_i64();
132
+ addr = tcg_temp_new_i32();
133
+ tmp = tcg_const_i32(1 << size);
134
+ load_reg_var(s, addr, a->rn);
135
+ for (reg = 0; reg < nregs; reg++) {
136
+ for (n = 0; n < 8 >> size; n++) {
137
+ int xs;
138
+ for (xs = 0; xs < interleave; xs++) {
139
+ int tt = a->vd + reg + spacing * xs;
140
+
141
+ if (a->l) {
142
+ gen_aa32_ld_i64(s, tmp64, addr, mmu_idx, endian | size);
143
+ neon_store_element64(tt, n, size, tmp64);
144
+ } else {
145
+ neon_load_element64(tmp64, tt, n, size);
146
+ gen_aa32_st_i64(s, tmp64, addr, mmu_idx, endian | size);
147
+ }
148
+ tcg_gen_add_i32(addr, addr, tmp);
149
+ }
150
+ }
151
+ }
152
+ tcg_temp_free_i32(addr);
153
+ tcg_temp_free_i32(tmp);
154
+ tcg_temp_free_i64(tmp64);
155
+
156
+ gen_neon_ldst_base_update(s, a->rm, a->rn, nregs * interleave * 8);
157
+ return true;
158
+}
159
diff --git a/target/arm/translate.c b/target/arm/translate.c
160
index XXXXXXX..XXXXXXX 100644
161
--- a/target/arm/translate.c
162
+++ b/target/arm/translate.c
163
@@ -XXX,XX +XXX,XX @@ static void gen_neon_trn_u16(TCGv_i32 t0, TCGv_i32 t1)
164
}
67
}
165
68
166
69
static void armsse_idau_check(IDAUInterface *ii, uint32_t address,
167
-static struct {
168
- int nregs;
169
- int interleave;
170
- int spacing;
171
-} const neon_ls_element_type[11] = {
172
- {1, 4, 1},
173
- {1, 4, 2},
174
- {4, 1, 1},
175
- {2, 2, 2},
176
- {1, 3, 1},
177
- {1, 3, 2},
178
- {3, 1, 1},
179
- {1, 1, 1},
180
- {1, 2, 1},
181
- {1, 2, 2},
182
- {2, 1, 1}
183
-};
184
-
185
/* Translate a NEON load/store element instruction. Return nonzero if the
186
instruction is invalid. */
187
static int disas_neon_ls_insn(DisasContext *s, uint32_t insn)
188
{
189
int rd, rn, rm;
190
- int op;
191
int nregs;
192
- int interleave;
193
- int spacing;
194
int stride;
195
int size;
196
int reg;
197
int load;
198
- int n;
199
int vec_size;
200
- int mmu_idx;
201
- MemOp endian;
202
TCGv_i32 addr;
203
TCGv_i32 tmp;
204
- TCGv_i32 tmp2;
205
- TCGv_i64 tmp64;
206
207
if (!arm_dc_feature(s, ARM_FEATURE_NEON)) {
208
return 1;
209
@@ -XXX,XX +XXX,XX @@ static int disas_neon_ls_insn(DisasContext *s, uint32_t insn)
210
rn = (insn >> 16) & 0xf;
211
rm = insn & 0xf;
212
load = (insn & (1 << 21)) != 0;
213
- endian = s->be_data;
214
- mmu_idx = get_mem_index(s);
215
if ((insn & (1 << 23)) == 0) {
216
- /* Load store all elements. */
217
- op = (insn >> 8) & 0xf;
218
- size = (insn >> 6) & 3;
219
- if (op > 10)
220
- return 1;
221
- /* Catch UNDEF cases for bad values of align field */
222
- switch (op & 0xc) {
223
- case 4:
224
- if (((insn >> 5) & 1) == 1) {
225
- return 1;
226
- }
227
- break;
228
- case 8:
229
- if (((insn >> 4) & 3) == 3) {
230
- return 1;
231
- }
232
- break;
233
- default:
234
- break;
235
- }
236
- nregs = neon_ls_element_type[op].nregs;
237
- interleave = neon_ls_element_type[op].interleave;
238
- spacing = neon_ls_element_type[op].spacing;
239
- if (size == 3 && (interleave | spacing) != 1) {
240
- return 1;
241
- }
242
- /* For our purposes, bytes are always little-endian. */
243
- if (size == 0) {
244
- endian = MO_LE;
245
- }
246
- /* Consecutive little-endian elements from a single register
247
- * can be promoted to a larger little-endian operation.
248
- */
249
- if (interleave == 1 && endian == MO_LE) {
250
- size = 3;
251
- }
252
- tmp64 = tcg_temp_new_i64();
253
- addr = tcg_temp_new_i32();
254
- tmp2 = tcg_const_i32(1 << size);
255
- load_reg_var(s, addr, rn);
256
- for (reg = 0; reg < nregs; reg++) {
257
- for (n = 0; n < 8 >> size; n++) {
258
- int xs;
259
- for (xs = 0; xs < interleave; xs++) {
260
- int tt = rd + reg + spacing * xs;
261
-
262
- if (load) {
263
- gen_aa32_ld_i64(s, tmp64, addr, mmu_idx, endian | size);
264
- neon_store_element64(tt, n, size, tmp64);
265
- } else {
266
- neon_load_element64(tmp64, tt, n, size);
267
- gen_aa32_st_i64(s, tmp64, addr, mmu_idx, endian | size);
268
- }
269
- tcg_gen_add_i32(addr, addr, tmp2);
270
- }
271
- }
272
- }
273
- tcg_temp_free_i32(addr);
274
- tcg_temp_free_i32(tmp2);
275
- tcg_temp_free_i64(tmp64);
276
- stride = nregs * interleave * 8;
277
+ /* Load store all elements -- handled already by decodetree */
278
+ return 1;
279
} else {
280
size = (insn >> 10) & 3;
281
if (size == 3) {
282
--
70
--
283
2.20.1
71
2.20.1
284
72
285
73
diff view generated by jsdifflib
1
We were accidentally permitting decode of Thumb Neon insns even if
1
Remove all the code that sets frequency properties on the CMSDK
2
the CPU didn't have the FEATURE_NEON bit set, because the feature
2
timer, dualtimer and watchdog devices and on the ARMSSE SoC device:
3
check was being done before the call to disas_neon_data_insn() and
3
these properties are unused now that the devices rely on their Clock
4
disas_neon_ls_insn() in the Arm decoder but was omitted from the
4
inputs instead.
5
Thumb decoder. Push the feature bit check down into the called
6
functions so it is done for both Arm and Thumb encodings.
7
5
8
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
6
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
9
Reviewed-by: Richard Henderson <richard.henderson@linaro.org>
10
Reviewed-by: Philippe Mathieu-Daudé <f4bug@amsat.org>
7
Reviewed-by: Philippe Mathieu-Daudé <f4bug@amsat.org>
11
Message-id: 20200430181003.21682-3-peter.maydell@linaro.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
---
12
---
13
target/arm/translate.c | 16 ++++++++--------
13
hw/arm/armsse.c | 7 -------
14
1 file changed, 8 insertions(+), 8 deletions(-)
14
hw/arm/mps2-tz.c | 1 -
15
hw/arm/mps2.c | 3 ---
16
hw/arm/musca.c | 1 -
17
hw/arm/stellaris.c | 3 ---
18
5 files changed, 15 deletions(-)
15
19
16
diff --git a/target/arm/translate.c b/target/arm/translate.c
20
diff --git a/hw/arm/armsse.c b/hw/arm/armsse.c
17
index XXXXXXX..XXXXXXX 100644
21
index XXXXXXX..XXXXXXX 100644
18
--- a/target/arm/translate.c
22
--- a/hw/arm/armsse.c
19
+++ b/target/arm/translate.c
23
+++ b/hw/arm/armsse.c
20
@@ -XXX,XX +XXX,XX @@ static int disas_neon_ls_insn(DisasContext *s, uint32_t insn)
24
@@ -XXX,XX +XXX,XX @@ static void armsse_realize(DeviceState *dev, Error **errp)
21
TCGv_i32 tmp2;
25
* it to the appropriate PPC port; then we can realize the PPC and
22
TCGv_i64 tmp64;
26
* map its upstream ends to the right place in the container.
23
27
*/
24
+ if (!arm_dc_feature(s, ARM_FEATURE_NEON)) {
28
- qdev_prop_set_uint32(DEVICE(&s->timer0), "pclk-frq", s->mainclk_frq);
25
+ return 1;
29
qdev_connect_clock_in(DEVICE(&s->timer0), "pclk", s->mainclk);
26
+ }
30
if (!sysbus_realize(SYS_BUS_DEVICE(&s->timer0), errp)) {
27
+
31
return;
28
/* FIXME: this access check should not take precedence over UNDEF
32
@@ -XXX,XX +XXX,XX @@ static void armsse_realize(DeviceState *dev, Error **errp)
29
* for invalid encodings; we will generate incorrect syndrome information
33
object_property_set_link(OBJECT(&s->apb_ppc0), "port[0]", OBJECT(mr),
30
* for attempts to execute invalid vfp/neon encodings with FP disabled.
34
&error_abort);
31
@@ -XXX,XX +XXX,XX @@ static int disas_neon_data_insn(DisasContext *s, uint32_t insn)
35
32
TCGv_ptr ptr1, ptr2, ptr3;
36
- qdev_prop_set_uint32(DEVICE(&s->timer1), "pclk-frq", s->mainclk_frq);
33
TCGv_i64 tmp64;
37
qdev_connect_clock_in(DEVICE(&s->timer1), "pclk", s->mainclk);
34
38
if (!sysbus_realize(SYS_BUS_DEVICE(&s->timer1), errp)) {
35
+ if (!arm_dc_feature(s, ARM_FEATURE_NEON)) {
39
return;
36
+ return 1;
40
@@ -XXX,XX +XXX,XX @@ static void armsse_realize(DeviceState *dev, Error **errp)
37
+ }
41
object_property_set_link(OBJECT(&s->apb_ppc0), "port[1]", OBJECT(mr),
38
+
42
&error_abort);
39
/* FIXME: this access check should not take precedence over UNDEF
43
40
* for invalid encodings; we will generate incorrect syndrome information
44
- qdev_prop_set_uint32(DEVICE(&s->dualtimer), "pclk-frq", s->mainclk_frq);
41
* for attempts to execute invalid vfp/neon encodings with FP disabled.
45
qdev_connect_clock_in(DEVICE(&s->dualtimer), "TIMCLK", s->mainclk);
42
@@ -XXX,XX +XXX,XX @@ static void disas_arm_insn(DisasContext *s, unsigned int insn)
46
if (!sysbus_realize(SYS_BUS_DEVICE(&s->dualtimer), errp)) {
43
47
return;
44
if (((insn >> 25) & 7) == 1) {
48
@@ -XXX,XX +XXX,XX @@ static void armsse_realize(DeviceState *dev, Error **errp)
45
/* NEON Data processing. */
49
/* Devices behind APB PPC1:
46
- if (!arm_dc_feature(s, ARM_FEATURE_NEON)) {
50
* 0x4002f000: S32K timer
47
- goto illegal_op;
51
*/
48
- }
52
- qdev_prop_set_uint32(DEVICE(&s->s32ktimer), "pclk-frq", S32KCLK);
49
-
53
qdev_connect_clock_in(DEVICE(&s->s32ktimer), "pclk", s->s32kclk);
50
if (disas_neon_data_insn(s, insn)) {
54
if (!sysbus_realize(SYS_BUS_DEVICE(&s->s32ktimer), errp)) {
51
goto illegal_op;
55
return;
52
}
56
@@ -XXX,XX +XXX,XX @@ static void armsse_realize(DeviceState *dev, Error **errp)
53
@@ -XXX,XX +XXX,XX @@ static void disas_arm_insn(DisasContext *s, unsigned int insn)
57
qdev_connect_gpio_out(DEVICE(&s->nmi_orgate), 0,
54
}
58
qdev_get_gpio_in_named(DEVICE(&s->armv7m), "NMI", 0));
55
if ((insn & 0x0f100000) == 0x04000000) {
59
56
/* NEON load/store. */
60
- qdev_prop_set_uint32(DEVICE(&s->s32kwatchdog), "wdogclk-frq", S32KCLK);
57
- if (!arm_dc_feature(s, ARM_FEATURE_NEON)) {
61
qdev_connect_clock_in(DEVICE(&s->s32kwatchdog), "WDOGCLK", s->s32kclk);
58
- goto illegal_op;
62
if (!sysbus_realize(SYS_BUS_DEVICE(&s->s32kwatchdog), errp)) {
59
- }
63
return;
60
-
64
@@ -XXX,XX +XXX,XX @@ static void armsse_realize(DeviceState *dev, Error **errp)
61
if (disas_neon_ls_insn(s, insn)) {
65
62
goto illegal_op;
66
/* 0x40080000 .. 0x4008ffff : ARMSSE second Base peripheral region */
63
}
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
82
--- a/hw/arm/mps2-tz.c
83
+++ b/hw/arm/mps2-tz.c
84
@@ -XXX,XX +XXX,XX @@ static void mps2tz_common_init(MachineState *machine)
85
object_property_set_link(OBJECT(&mms->iotkit), "memory",
86
OBJECT(system_memory), &error_abort);
87
qdev_prop_set_uint32(iotkitdev, "EXP_NUMIRQ", MPS2TZ_NUMIRQ);
88
- qdev_prop_set_uint32(iotkitdev, "MAINCLK_FRQ", SYSCLK_FRQ);
89
qdev_connect_clock_in(iotkitdev, "MAINCLK", mms->sysclk);
90
qdev_connect_clock_in(iotkitdev, "S32KCLK", mms->s32kclk);
91
sysbus_realize(SYS_BUS_DEVICE(&mms->iotkit), &error_fatal);
92
diff --git a/hw/arm/mps2.c b/hw/arm/mps2.c
93
index XXXXXXX..XXXXXXX 100644
94
--- a/hw/arm/mps2.c
95
+++ b/hw/arm/mps2.c
96
@@ -XXX,XX +XXX,XX @@ static void mps2_common_init(MachineState *machine)
97
object_initialize_child(OBJECT(mms), name, &mms->timer[i],
98
TYPE_CMSDK_APB_TIMER);
99
sbd = SYS_BUS_DEVICE(&mms->timer[i]);
100
- qdev_prop_set_uint32(DEVICE(&mms->timer[i]), "pclk-frq", SYSCLK_FRQ);
101
qdev_connect_clock_in(DEVICE(&mms->timer[i]), "pclk", mms->sysclk);
102
sysbus_realize_and_unref(sbd, &error_fatal);
103
sysbus_mmio_map(sbd, 0, base);
104
@@ -XXX,XX +XXX,XX @@ static void mps2_common_init(MachineState *machine)
105
106
object_initialize_child(OBJECT(mms), "dualtimer", &mms->dualtimer,
107
TYPE_CMSDK_APB_DUALTIMER);
108
- qdev_prop_set_uint32(DEVICE(&mms->dualtimer), "pclk-frq", SYSCLK_FRQ);
109
qdev_connect_clock_in(DEVICE(&mms->dualtimer), "TIMCLK", mms->sysclk);
110
sysbus_realize(SYS_BUS_DEVICE(&mms->dualtimer), &error_fatal);
111
sysbus_connect_irq(SYS_BUS_DEVICE(&mms->dualtimer), 0,
112
@@ -XXX,XX +XXX,XX @@ static void mps2_common_init(MachineState *machine)
113
sysbus_mmio_map(SYS_BUS_DEVICE(&mms->dualtimer), 0, 0x40002000);
114
object_initialize_child(OBJECT(mms), "watchdog", &mms->watchdog,
115
TYPE_CMSDK_APB_WATCHDOG);
116
- qdev_prop_set_uint32(DEVICE(&mms->watchdog), "wdogclk-frq", SYSCLK_FRQ);
117
qdev_connect_clock_in(DEVICE(&mms->watchdog), "WDOGCLK", mms->sysclk);
118
sysbus_realize(SYS_BUS_DEVICE(&mms->watchdog), &error_fatal);
119
sysbus_connect_irq(SYS_BUS_DEVICE(&mms->watchdog), 0,
120
diff --git a/hw/arm/musca.c b/hw/arm/musca.c
121
index XXXXXXX..XXXXXXX 100644
122
--- a/hw/arm/musca.c
123
+++ b/hw/arm/musca.c
124
@@ -XXX,XX +XXX,XX @@ static void musca_init(MachineState *machine)
125
qdev_prop_set_uint32(ssedev, "EXP_NUMIRQ", mmc->num_irqs);
126
qdev_prop_set_uint32(ssedev, "init-svtor", mmc->init_svtor);
127
qdev_prop_set_uint32(ssedev, "SRAM_ADDR_WIDTH", mmc->sram_addr_width);
128
- qdev_prop_set_uint32(ssedev, "MAINCLK_FRQ", SYSCLK_FRQ);
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
64
--
146
--
65
2.20.1
147
2.20.1
66
148
67
149
diff view generated by jsdifflib
1
Convert the VFM[AS]L (scalar) insns in the 2reg-scalar-ext group
1
Now no users are setting the frq properties on the CMSDK timer,
2
to decodetree. These are the last ones in the group so we can remove
2
dualtimer, watchdog or ARMSSE SoC devices, we can remove the
3
all the legacy decode for the group.
3
properties and the struct fields that back them.
4
5
Note that in disas_thumb2_insn() the parts of this encoding space
6
where the decodetree decoder returns false will correctly be directed
7
to illegal_op by the "(insn & (1 << 28))" check so they won't fall
8
into disas_coproc_insn() by mistake.
9
4
10
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
5
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
11
Reviewed-by: Richard Henderson <richard.henderson@linaro.org>
6
Reviewed-by: Philippe Mathieu-Daudé <f4bug@amsat.org>
12
Message-id: 20200430181003.21682-11-peter.maydell@linaro.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
13
---
11
---
14
target/arm/neon-shared.decode | 7 +++
12
include/hw/arm/armsse.h | 2 --
15
target/arm/translate-neon.inc.c | 32 ++++++++++
13
include/hw/timer/cmsdk-apb-dualtimer.h | 2 --
16
target/arm/translate.c | 107 +-------------------------------
14
include/hw/timer/cmsdk-apb-timer.h | 2 --
17
3 files changed, 40 insertions(+), 106 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(-)
18
21
19
diff --git a/target/arm/neon-shared.decode b/target/arm/neon-shared.decode
22
diff --git a/include/hw/arm/armsse.h b/include/hw/arm/armsse.h
20
index XXXXXXX..XXXXXXX 100644
23
index XXXXXXX..XXXXXXX 100644
21
--- a/target/arm/neon-shared.decode
24
--- a/include/hw/arm/armsse.h
22
+++ b/target/arm/neon-shared.decode
25
+++ b/include/hw/arm/armsse.h
23
@@ -XXX,XX +XXX,XX @@ VCMLA_scalar 1111 1110 1 . rot:2 .... .... 1000 . q:1 . 0 .... \
26
@@ -XXX,XX +XXX,XX @@
24
27
* + Clock input "S32KCLK": slow 32KHz clock used for a few peripherals
25
VDOT_scalar 1111 1110 0 . 10 .... .... 1101 . q:1 index:1 u:1 rm:4 \
28
* + QOM property "memory" is a MemoryRegion containing the devices provided
26
vm=%vm_dp vn=%vn_dp vd=%vd_dp
29
* by the board model.
27
+
30
- * + QOM property "MAINCLK_FRQ" is the frequency of the main system clock
28
+%vfml_scalar_q0_rm 0:3 5:1
31
* + QOM property "EXP_NUMIRQ" sets the number of expansion interrupts.
29
+%vfml_scalar_q1_index 5:1 3:1
32
* (In hardware, the SSE-200 permits the number of expansion interrupts
30
+VFML_scalar 1111 1110 0 . 0 s:1 .... .... 1000 . 0 . 1 index:1 ... \
33
* for the two CPUs to be configured separately, but we restrict it to
31
+ rm=%vfml_scalar_q0_rm vn=%vn_sp vd=%vd_dp q=0
34
@@ -XXX,XX +XXX,XX @@ struct ARMSSE {
32
+VFML_scalar 1111 1110 0 . 0 s:1 .... .... 1000 . 1 . 1 . rm:3 \
35
/* Properties */
33
+ index=%vfml_scalar_q1_index vn=%vn_dp vd=%vd_dp q=1
36
MemoryRegion *board_memory;
34
diff --git a/target/arm/translate-neon.inc.c b/target/arm/translate-neon.inc.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
35
index XXXXXXX..XXXXXXX 100644
43
index XXXXXXX..XXXXXXX 100644
36
--- a/target/arm/translate-neon.inc.c
44
--- a/include/hw/timer/cmsdk-apb-dualtimer.h
37
+++ b/target/arm/translate-neon.inc.c
45
+++ b/include/hw/timer/cmsdk-apb-dualtimer.h
38
@@ -XXX,XX +XXX,XX @@ static bool trans_VDOT_scalar(DisasContext *s, arg_VDOT_scalar *a)
46
@@ -XXX,XX +XXX,XX @@
39
tcg_temp_free_ptr(fpst);
47
* https://developer.arm.com/products/system-design/system-design-kits/cortex-m-system-design-kit
40
return true;
48
*
49
* QEMU interface:
50
- * + QOM property "pclk-frq": frequency at which the timer is clocked
51
* + Clock input "TIMCLK": clock (for both timers)
52
* + sysbus MMIO region 0: the register bank
53
* + sysbus IRQ 0: combined timer interrupt TIMINTC
54
@@ -XXX,XX +XXX,XX @@ struct CMSDKAPBDualTimer {
55
/*< public >*/
56
MemoryRegion iomem;
57
qemu_irq timerintc;
58
- uint32_t pclk_frq;
59
Clock *timclk;
60
61
CMSDKAPBDualTimerModule timermod[CMSDK_APB_DUALTIMER_NUM_MODULES];
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
68
/*
69
* QEMU interface:
70
- * + QOM property "pclk-frq": frequency at which the timer is clocked
71
* + Clock input "pclk": clock for the timer
72
* + sysbus MMIO region 0: the register bank
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
};
129
130
-static Property cmsdk_apb_dualtimer_properties[] = {
131
- DEFINE_PROP_UINT32("pclk-frq", CMSDKAPBDualTimer, pclk_frq, 0),
132
- DEFINE_PROP_END_OF_LIST(),
133
-};
134
-
135
static void cmsdk_apb_dualtimer_class_init(ObjectClass *klass, void *data)
136
{
137
DeviceClass *dc = DEVICE_CLASS(klass);
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);
41
}
143
}
42
+
144
43
+static bool trans_VFML_scalar(DisasContext *s, arg_VFML_scalar *a)
145
static const TypeInfo cmsdk_apb_dualtimer_info = {
44
+{
146
diff --git a/hw/timer/cmsdk-apb-timer.c b/hw/timer/cmsdk-apb-timer.c
45
+ int opr_sz;
46
+
47
+ if (!dc_isar_feature(aa32_fhm, s)) {
48
+ return false;
49
+ }
50
+
51
+ /* UNDEF accesses to D16-D31 if they don't exist. */
52
+ if (!dc_isar_feature(aa32_simd_r32, s) &&
53
+ ((a->vd & 0x10) || (a->q && (a->vn & 0x10)))) {
54
+ return false;
55
+ }
56
+
57
+ if (a->vd & a->q) {
58
+ return false;
59
+ }
60
+
61
+ if (!vfp_access_check(s)) {
62
+ return true;
63
+ }
64
+
65
+ opr_sz = (1 + a->q) * 8;
66
+ tcg_gen_gvec_3_ptr(vfp_reg_offset(1, a->vd),
67
+ vfp_reg_offset(a->q, a->vn),
68
+ vfp_reg_offset(a->q, a->rm),
69
+ cpu_env, opr_sz, opr_sz,
70
+ (a->index << 2) | a->s, /* is_2 == 0 */
71
+ gen_helper_gvec_fmlal_idx_a32);
72
+ return true;
73
+}
74
diff --git a/target/arm/translate.c b/target/arm/translate.c
75
index XXXXXXX..XXXXXXX 100644
147
index XXXXXXX..XXXXXXX 100644
76
--- a/target/arm/translate.c
148
--- a/hw/timer/cmsdk-apb-timer.c
77
+++ b/target/arm/translate.c
149
+++ b/hw/timer/cmsdk-apb-timer.c
78
@@ -XXX,XX +XXX,XX @@ static int disas_dsp_insn(DisasContext *s, uint32_t insn)
150
@@ -XXX,XX +XXX,XX @@ static const VMStateDescription cmsdk_apb_timer_vmstate = {
151
}
152
};
153
154
-static Property cmsdk_apb_timer_properties[] = {
155
- DEFINE_PROP_UINT32("pclk-frq", CMSDKAPBTimer, pclk_frq, 0),
156
- DEFINE_PROP_END_OF_LIST(),
157
-};
158
-
159
static void cmsdk_apb_timer_class_init(ObjectClass *klass, void *data)
160
{
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);
79
}
167
}
80
168
81
#define VFP_REG_SHR(x, n) (((n) > 0) ? (x) >> (n) : (x) << -(n))
169
static const TypeInfo cmsdk_apb_timer_info = {
82
-#define VFP_SREG(insn, bigbit, smallbit) \
170
diff --git a/hw/watchdog/cmsdk-apb-watchdog.c b/hw/watchdog/cmsdk-apb-watchdog.c
83
- ((VFP_REG_SHR(insn, bigbit - 1) & 0x1e) | (((insn) >> (smallbit)) & 1))
171
index XXXXXXX..XXXXXXX 100644
84
#define VFP_DREG(reg, insn, bigbit, smallbit) do { \
172
--- a/hw/watchdog/cmsdk-apb-watchdog.c
85
if (dc_isar_feature(aa32_simd_r32, s)) { \
173
+++ b/hw/watchdog/cmsdk-apb-watchdog.c
86
reg = (((insn) >> (bigbit)) & 0x0f) \
174
@@ -XXX,XX +XXX,XX @@ static const VMStateDescription cmsdk_apb_watchdog_vmstate = {
87
@@ -XXX,XX +XXX,XX @@ static int disas_dsp_insn(DisasContext *s, uint32_t insn)
175
}
88
reg = ((insn) >> (bigbit)) & 0x0f; \
176
};
89
}} while (0)
177
90
178
-static Property cmsdk_apb_watchdog_properties[] = {
91
-#define VFP_SREG_D(insn) VFP_SREG(insn, 12, 22)
179
- DEFINE_PROP_UINT32("wdogclk-frq", CMSDKAPBWatchdog, wdogclk_frq, 0),
92
#define VFP_DREG_D(reg, insn) VFP_DREG(reg, insn, 12, 22)
180
- DEFINE_PROP_END_OF_LIST(),
93
-#define VFP_SREG_N(insn) VFP_SREG(insn, 16, 7)
181
-};
94
#define VFP_DREG_N(reg, insn) VFP_DREG(reg, insn, 16, 7)
182
-
95
-#define VFP_SREG_M(insn) VFP_SREG(insn, 0, 5)
183
static void cmsdk_apb_watchdog_class_init(ObjectClass *klass, void *data)
96
#define VFP_DREG_M(reg, insn) VFP_DREG(reg, insn, 0, 5)
184
{
97
185
DeviceClass *dc = DEVICE_CLASS(klass);
98
static void gen_neon_dup_low16(TCGv_i32 var)
186
@@ -XXX,XX +XXX,XX @@ static void cmsdk_apb_watchdog_class_init(ObjectClass *klass, void *data)
99
@@ -XXX,XX +XXX,XX @@ static int disas_neon_data_insn(DisasContext *s, uint32_t insn)
187
dc->realize = cmsdk_apb_watchdog_realize;
100
return 0;
188
dc->vmsd = &cmsdk_apb_watchdog_vmstate;
189
dc->reset = cmsdk_apb_watchdog_reset;
190
- device_class_set_props(dc, cmsdk_apb_watchdog_properties);
101
}
191
}
102
192
103
-/* Advanced SIMD two registers and a scalar extension.
193
static const TypeInfo cmsdk_apb_watchdog_info = {
104
- * 31 24 23 22 20 16 12 11 10 9 8 3 0
105
- * +-----------------+----+---+----+----+----+---+----+---+----+---------+----+
106
- * | 1 1 1 1 1 1 1 0 | o1 | D | o2 | Vn | Vd | 1 | o3 | 0 | o4 | N Q M U | Vm |
107
- * +-----------------+----+---+----+----+----+---+----+---+----+---------+----+
108
- *
109
- */
110
-
111
-static int disas_neon_insn_2reg_scalar_ext(DisasContext *s, uint32_t insn)
112
-{
113
- gen_helper_gvec_3 *fn_gvec = NULL;
114
- gen_helper_gvec_3_ptr *fn_gvec_ptr = NULL;
115
- int rd, rn, rm, opr_sz, data;
116
- int off_rn, off_rm;
117
- bool is_long = false, q = extract32(insn, 6, 1);
118
- bool ptr_is_env = false;
119
-
120
- if ((insn & 0xffa00f10) == 0xfe000810) {
121
- /* VFM[AS]L -- 1111 1110 0.0S .... .... 1000 .Q.1 .... */
122
- int is_s = extract32(insn, 20, 1);
123
- int vm20 = extract32(insn, 0, 3);
124
- int vm3 = extract32(insn, 3, 1);
125
- int m = extract32(insn, 5, 1);
126
- int index;
127
-
128
- if (!dc_isar_feature(aa32_fhm, s)) {
129
- return 1;
130
- }
131
- if (q) {
132
- rm = vm20;
133
- index = m * 2 + vm3;
134
- } else {
135
- rm = vm20 * 2 + m;
136
- index = vm3;
137
- }
138
- is_long = true;
139
- data = (index << 2) | is_s; /* is_2 == 0 */
140
- fn_gvec_ptr = gen_helper_gvec_fmlal_idx_a32;
141
- ptr_is_env = true;
142
- } else {
143
- return 1;
144
- }
145
-
146
- VFP_DREG_D(rd, insn);
147
- if (rd & q) {
148
- return 1;
149
- }
150
- if (q || !is_long) {
151
- VFP_DREG_N(rn, insn);
152
- if (rn & q & !is_long) {
153
- return 1;
154
- }
155
- off_rn = vfp_reg_offset(1, rn);
156
- off_rm = vfp_reg_offset(1, rm);
157
- } else {
158
- rn = VFP_SREG_N(insn);
159
- off_rn = vfp_reg_offset(0, rn);
160
- off_rm = vfp_reg_offset(0, rm);
161
- }
162
- if (s->fp_excp_el) {
163
- gen_exception_insn(s, s->pc_curr, EXCP_UDEF,
164
- syn_simd_access_trap(1, 0xe, false), s->fp_excp_el);
165
- return 0;
166
- }
167
- if (!s->vfp_enabled) {
168
- return 1;
169
- }
170
-
171
- opr_sz = (1 + q) * 8;
172
- if (fn_gvec_ptr) {
173
- TCGv_ptr ptr;
174
- if (ptr_is_env) {
175
- ptr = cpu_env;
176
- } else {
177
- ptr = get_fpstatus_ptr(1);
178
- }
179
- tcg_gen_gvec_3_ptr(vfp_reg_offset(1, rd), off_rn, off_rm, ptr,
180
- opr_sz, opr_sz, data, fn_gvec_ptr);
181
- if (!ptr_is_env) {
182
- tcg_temp_free_ptr(ptr);
183
- }
184
- } else {
185
- tcg_gen_gvec_3_ool(vfp_reg_offset(1, rd), off_rn, off_rm,
186
- opr_sz, opr_sz, data, fn_gvec);
187
- }
188
- return 0;
189
-}
190
-
191
static int disas_coproc_insn(DisasContext *s, uint32_t insn)
192
{
193
int cpnum, is64, crn, crm, opc1, opc2, isread, rt, rt2;
194
@@ -XXX,XX +XXX,XX @@ static void disas_arm_insn(DisasContext *s, unsigned int insn)
195
}
196
}
197
}
198
- } else if ((insn & 0x0f000a00) == 0x0e000800
199
- && arm_dc_feature(s, ARM_FEATURE_V8)) {
200
- if (disas_neon_insn_2reg_scalar_ext(s, insn)) {
201
- goto illegal_op;
202
- }
203
- return;
204
}
205
goto illegal_op;
206
}
207
@@ -XXX,XX +XXX,XX @@ static void disas_thumb2_insn(DisasContext *s, uint32_t insn)
208
}
209
break;
210
}
211
- if ((insn & 0xff000a00) == 0xfe000800
212
- && arm_dc_feature(s, ARM_FEATURE_V8)) {
213
- /* The Thumb2 and ARM encodings are identical. */
214
- if (disas_neon_insn_2reg_scalar_ext(s, insn)) {
215
- goto illegal_op;
216
- }
217
- } else if (((insn >> 24) & 3) == 3) {
218
+ if (((insn >> 24) & 3) == 3) {
219
/* Translate into the equivalent ARM encoding. */
220
insn = (insn & 0xe2ffffff) | ((insn & (1 << 28)) >> 4) | (1 << 28);
221
if (disas_neon_data_insn(s, insn)) {
222
--
194
--
223
2.20.1
195
2.20.1
224
196
225
197
diff view generated by jsdifflib
1
Convert VCMLA (scalar) in the 2reg-scalar-ext group to decodetree.
1
Now that the watchdog device uses its Clock input rather than being
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.
2
7
3
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
8
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
4
Reviewed-by: Richard Henderson <richard.henderson@linaro.org>
9
Reviewed-by: Luc Michel <luc@lmichel.fr>
5
Message-id: 20200430181003.21682-9-peter.maydell@linaro.org
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>
6
---
15
---
7
target/arm/neon-shared.decode | 5 +++++
16
hw/arm/stellaris.c | 10 ----------
8
target/arm/translate-neon.inc.c | 40 +++++++++++++++++++++++++++++++++
17
1 file changed, 10 deletions(-)
9
target/arm/translate.c | 26 +--------------------
10
3 files changed, 46 insertions(+), 25 deletions(-)
11
18
12
diff --git a/target/arm/neon-shared.decode b/target/arm/neon-shared.decode
19
diff --git a/hw/arm/stellaris.c b/hw/arm/stellaris.c
13
index XXXXXXX..XXXXXXX 100644
20
index XXXXXXX..XXXXXXX 100644
14
--- a/target/arm/neon-shared.decode
21
--- a/hw/arm/stellaris.c
15
+++ b/target/arm/neon-shared.decode
22
+++ b/hw/arm/stellaris.c
16
@@ -XXX,XX +XXX,XX @@ VFML 1111 110 0 s:1 . 10 .... .... 1000 . 0 . 1 .... \
23
@@ -XXX,XX +XXX,XX @@ static DeviceState *stellaris_sys_init(uint32_t base, qemu_irq irq,
17
vm=%vm_sp vn=%vn_sp vd=%vd_dp q=0
24
sysbus_mmio_map(sbd, 0, base);
18
VFML 1111 110 0 s:1 . 10 .... .... 1000 . 1 . 1 .... \
25
sysbus_connect_irq(sbd, 0, irq);
19
vm=%vm_dp vn=%vn_dp vd=%vd_dp q=1
26
20
+
27
- /*
21
+VCMLA_scalar 1111 1110 0 . rot:2 .... .... 1000 . q:1 index:1 0 vm:4 \
28
- * Normally we should not be resetting devices like this during
22
+ vn=%vn_dp vd=%vd_dp size=0
29
- * board creation. For the moment we need to do so, because
23
+VCMLA_scalar 1111 1110 1 . rot:2 .... .... 1000 . q:1 . 0 .... \
30
- * system_clock_scale will only get set when the STELLARIS_SYS
24
+ vm=%vm_dp vn=%vn_dp vd=%vd_dp size=1 index=0
31
- * device is reset, and we need its initial value to pass to
25
diff --git a/target/arm/translate-neon.inc.c b/target/arm/translate-neon.inc.c
32
- * the watchdog device. This hack can be removed once the
26
index XXXXXXX..XXXXXXX 100644
33
- * watchdog has been converted to use a Clock input instead.
27
--- a/target/arm/translate-neon.inc.c
34
- */
28
+++ b/target/arm/translate-neon.inc.c
35
- device_cold_reset(dev);
29
@@ -XXX,XX +XXX,XX @@ static bool trans_VFML(DisasContext *s, arg_VFML *a)
36
-
30
gen_helper_gvec_fmlal_a32);
37
return dev;
31
return true;
32
}
38
}
33
+
34
+static bool trans_VCMLA_scalar(DisasContext *s, arg_VCMLA_scalar *a)
35
+{
36
+ gen_helper_gvec_3_ptr *fn_gvec_ptr;
37
+ int opr_sz;
38
+ TCGv_ptr fpst;
39
+
40
+ if (!dc_isar_feature(aa32_vcma, s)) {
41
+ return false;
42
+ }
43
+ if (a->size == 0 && !dc_isar_feature(aa32_fp16_arith, s)) {
44
+ return false;
45
+ }
46
+
47
+ /* UNDEF accesses to D16-D31 if they don't exist. */
48
+ if (!dc_isar_feature(aa32_simd_r32, s) &&
49
+ ((a->vd | a->vn | a->vm) & 0x10)) {
50
+ return false;
51
+ }
52
+
53
+ if ((a->vd | a->vn) & a->q) {
54
+ return false;
55
+ }
56
+
57
+ if (!vfp_access_check(s)) {
58
+ return true;
59
+ }
60
+
61
+ fn_gvec_ptr = (a->size ? gen_helper_gvec_fcmlas_idx
62
+ : gen_helper_gvec_fcmlah_idx);
63
+ opr_sz = (1 + a->q) * 8;
64
+ fpst = get_fpstatus_ptr(1);
65
+ tcg_gen_gvec_3_ptr(vfp_reg_offset(1, a->vd),
66
+ vfp_reg_offset(1, a->vn),
67
+ vfp_reg_offset(1, a->vm),
68
+ fpst, opr_sz, opr_sz,
69
+ (a->index << 2) | a->rot, fn_gvec_ptr);
70
+ tcg_temp_free_ptr(fpst);
71
+ return true;
72
+}
73
diff --git a/target/arm/translate.c b/target/arm/translate.c
74
index XXXXXXX..XXXXXXX 100644
75
--- a/target/arm/translate.c
76
+++ b/target/arm/translate.c
77
@@ -XXX,XX +XXX,XX @@ static int disas_neon_insn_2reg_scalar_ext(DisasContext *s, uint32_t insn)
78
bool is_long = false, q = extract32(insn, 6, 1);
79
bool ptr_is_env = false;
80
81
- if ((insn & 0xff000f10) == 0xfe000800) {
82
- /* VCMLA (indexed) -- 1111 1110 S.RR .... .... 1000 ...0 .... */
83
- int rot = extract32(insn, 20, 2);
84
- int size = extract32(insn, 23, 1);
85
- int index;
86
-
87
- if (!dc_isar_feature(aa32_vcma, s)) {
88
- return 1;
89
- }
90
- if (size == 0) {
91
- if (!dc_isar_feature(aa32_fp16_arith, s)) {
92
- return 1;
93
- }
94
- /* For fp16, rm is just Vm, and index is M. */
95
- rm = extract32(insn, 0, 4);
96
- index = extract32(insn, 5, 1);
97
- } else {
98
- /* For fp32, rm is the usual M:Vm, and index is 0. */
99
- VFP_DREG_M(rm, insn);
100
- index = 0;
101
- }
102
- data = (index << 2) | rot;
103
- fn_gvec_ptr = (size ? gen_helper_gvec_fcmlas_idx
104
- : gen_helper_gvec_fcmlah_idx);
105
- } else if ((insn & 0xffb00f00) == 0xfe200d00) {
106
+ if ((insn & 0xffb00f00) == 0xfe200d00) {
107
/* V[US]DOT -- 1111 1110 0.10 .... .... 1101 .Q.U .... */
108
int u = extract32(insn, 4, 1);
109
39
110
--
40
--
111
2.20.1
41
2.20.1
112
42
113
43
diff view generated by jsdifflib