1
target-arm queue for rc1 -- these are all bug fixes.
1
Hi; here's a collection of Arm bug fixes for rc2.
2
2
3
thanks
3
thanks
4
-- PMM
4
-- PMM
5
5
6
The following changes since commit b9404bf592e7ba74180e1a54ed7a266ec6ee67f2:
6
The following changes since commit a082fab9d259473a9d5d53307cf83b1223301181:
7
7
8
Merge remote-tracking branch 'remotes/dgilbert/tags/pull-hmp-20190715' into staging (2019-07-15 12:22:07 +0100)
8
Merge tag 'pull-ppc-20221117' of https://gitlab.com/danielhb/qemu into staging (2022-11-17 12:39:38 -0500)
9
9
10
are available in the Git repository at:
10
are available in the Git repository at:
11
11
12
https://git.linaro.org/people/pmaydell/qemu-arm.git tags/pull-target-arm-20190715
12
https://git.linaro.org/people/pmaydell/qemu-arm.git tags/pull-target-arm-20221121
13
13
14
for you to fetch changes up to 51c9122e92b776a3f16af0b9282f1dc5012e2a19:
14
for you to fetch changes up to 312b71abce3005ca7294dc0db7d548dc7cc41fbf:
15
15
16
target/arm: NS BusFault on vector table fetch escalates to NS HardFault (2019-07-15 14:17:04 +0100)
16
target/arm: Limit LPA2 effective output address when TCR.DS == 0 (2022-11-21 11:46:46 +0000)
17
17
18
----------------------------------------------------------------
18
----------------------------------------------------------------
19
target-arm queue:
19
target-arm queue:
20
* report ARMv8-A FP support for AArch32 -cpu max
20
* hw/sd: Fix sun4i allwinner-sdhost for U-Boot
21
* hw/ssi/xilinx_spips: Avoid AXI writes to the LQSPI linear memory
21
* hw/intc: add implementation of GICD_IIDR to Arm GIC
22
* hw/ssi/xilinx_spips: Avoid out-of-bound access to lqspi_buf[]
22
* tests/avocado/boot_linux.py: Bump aarch64 virt test timeout
23
* hw/ssi/mss-spi: Avoid crash when reading empty RX FIFO
23
* target/arm: Limit LPA2 effective output address when TCR.DS == 0
24
* hw/display/xlnx_dp: Avoid crash when reading empty RX FIFO
25
* hw/arm/virt: Fix non-secure flash mode
26
* pl031: Correctly migrate state when using -rtc clock=host
27
* fix regression that meant arm926 and arm1026 lost VFP
28
double-precision support
29
* v8M: NS BusFault on vector table fetch escalates to NS HardFault
30
24
31
----------------------------------------------------------------
25
----------------------------------------------------------------
32
Alex Bennée (1):
26
Alex Bennée (2):
33
target/arm: report ARMv8-A FP support for AArch32 -cpu max
27
hw/intc: clean-up access to GIC multi-byte registers
28
hw/intc: add implementation of GICD_IIDR to Arm GIC
34
29
35
David Engraf (1):
30
Ard Biesheuvel (1):
36
hw/arm/virt: Fix non-secure flash mode
31
target/arm: Limit LPA2 effective output address when TCR.DS == 0
37
32
38
Peter Maydell (3):
33
Peter Maydell (1):
39
pl031: Correctly migrate state when using -rtc clock=host
34
tests/avocado/boot_linux.py: Bump aarch64 virt test timeout to 720s
40
target/arm: Set VFP-related MVFR0 fields for arm926 and arm1026
41
target/arm: NS BusFault on vector table fetch escalates to NS HardFault
42
35
43
Philippe Mathieu-Daudé (5):
36
Strahinja Jankovic (1):
44
hw/ssi/xilinx_spips: Convert lqspi_read() to read_with_attrs
37
hw/sd: Fix sun4i allwinner-sdhost for U-Boot
45
hw/ssi/xilinx_spips: Avoid AXI writes to the LQSPI linear memory
46
hw/ssi/xilinx_spips: Avoid out-of-bound access to lqspi_buf[]
47
hw/ssi/mss-spi: Avoid crash when reading empty RX FIFO
48
hw/display/xlnx_dp: Avoid crash when reading empty RX FIFO
49
38
50
include/hw/timer/pl031.h | 2 ++
39
include/hw/sd/allwinner-sdhost.h | 1 +
51
hw/arm/virt.c | 2 +-
40
hw/intc/arm_gic.c | 28 ++++++++++++-----
52
hw/core/machine.c | 1 +
41
hw/sd/allwinner-sdhost.c | 67 +++++++++++++++++++++++++++-------------
53
hw/display/xlnx_dp.c | 15 +++++---
42
target/arm/ptw.c | 8 +++++
54
hw/ssi/mss-spi.c | 8 ++++-
43
tests/avocado/boot_linux.py | 2 +-
55
hw/ssi/xilinx_spips.c | 43 +++++++++++++++-------
44
5 files changed, 77 insertions(+), 29 deletions(-)
56
hw/timer/pl031.c | 92 +++++++++++++++++++++++++++++++++++++++++++++---
57
target/arm/cpu.c | 16 +++++++++
58
target/arm/m_helper.c | 21 ++++++++---
59
9 files changed, 174 insertions(+), 26 deletions(-)
60
45
diff view generated by jsdifflib
1
The PL031 RTC tracks the difference between the guest RTC
1
From: Strahinja Jankovic <strahinjapjankovic@gmail.com>
2
and the host RTC using a tick_offset field. For migration,
3
however, we currently always migrate the offset between
4
the guest and the vm_clock, even if the RTC clock is not
5
the same as the vm_clock; this was an attempt to retain
6
migration backwards compatibility.
7
2
8
Unfortunately this results in the RTC behaving oddly across
3
Trying to run U-Boot for Cubieboard (Allwinner A10) fails because it cannot
9
a VM state save and restore -- since the VM clock stands still
4
access SD card. The problem is that FIFO register in current
10
across save-then-restore, regardless of how much real world
5
allwinner-sdhost implementation is at the address corresponding to
11
time has elapsed, the guest RTC ends up out of sync with the
6
Allwinner H3, but not A10.
12
host RTC in the restored VM.
7
Linux kernel is not affected since Linux driver uses DMA access and does
8
not use FIFO register for reading/writing.
13
9
14
Fix this by migrating the raw tick_offset. To retain migration
10
This patch adds new class parameter `is_sun4i` and based on that
15
compatibility as far as possible, we have a new property
11
parameter uses register at offset 0x100 either as FIFO register (if
16
migrate-tick-offset; by default this is 'true' and we will
12
sun4i) or as threshold register (if not sun4i; in this case register at
17
migrate the true tick offset in a new subsection; if the
13
0x200 is FIFO register).
18
incoming data has no subsection we fall back to the old
19
vm_clock-based offset information, so old->new migration
20
compatibility is preserved. For complete new->old migration
21
compatibility, the property is set to 'false' for 4.0 and
22
earlier machine types (this will only affect 'virt-4.0'
23
and below, as none of the other pl031-using machines are
24
versioned).
25
14
26
Reported-by: Russell King <rmk@armlinux.org.uk>
15
Tested with U-Boot and Linux kernel image built for Cubieboard and
16
OrangePi PC.
17
18
Signed-off-by: Strahinja Jankovic <strahinja.p.jankovic@gmail.com>
19
Reviewed-by: Peter Maydell <peter.maydell@linaro.org>
20
Message-id: 20221112214900.24152-1-strahinja.p.jankovic@gmail.com
27
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
21
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
28
Reviewed-by: Dr. David Alan Gilbert <dgilbert@redhat.com>
29
Message-id: 20190709143912.28905-1-peter.maydell@linaro.org
30
---
22
---
31
include/hw/timer/pl031.h | 2 +
23
include/hw/sd/allwinner-sdhost.h | 1 +
32
hw/core/machine.c | 1 +
24
hw/sd/allwinner-sdhost.c | 67 ++++++++++++++++++++++----------
33
hw/timer/pl031.c | 92 ++++++++++++++++++++++++++++++++++++++--
25
2 files changed, 47 insertions(+), 21 deletions(-)
34
3 files changed, 91 insertions(+), 4 deletions(-)
35
26
36
diff --git a/include/hw/timer/pl031.h b/include/hw/timer/pl031.h
27
diff --git a/include/hw/sd/allwinner-sdhost.h b/include/hw/sd/allwinner-sdhost.h
37
index XXXXXXX..XXXXXXX 100644
28
index XXXXXXX..XXXXXXX 100644
38
--- a/include/hw/timer/pl031.h
29
--- a/include/hw/sd/allwinner-sdhost.h
39
+++ b/include/hw/timer/pl031.h
30
+++ b/include/hw/sd/allwinner-sdhost.h
40
@@ -XXX,XX +XXX,XX @@ typedef struct PL031State {
31
@@ -XXX,XX +XXX,XX @@ struct AwSdHostClass {
41
*/
32
42
uint32_t tick_offset_vmstate;
33
/** Maximum buffer size in bytes per DMA descriptor */
43
uint32_t tick_offset;
34
size_t max_desc_size;
44
+ bool tick_offset_migrated;
35
+ bool is_sun4i;
45
+ bool migrate_tick_offset;
36
46
37
};
47
uint32_t mr;
38
48
uint32_t lr;
39
diff --git a/hw/sd/allwinner-sdhost.c b/hw/sd/allwinner-sdhost.c
49
diff --git a/hw/core/machine.c b/hw/core/machine.c
50
index XXXXXXX..XXXXXXX 100644
40
index XXXXXXX..XXXXXXX 100644
51
--- a/hw/core/machine.c
41
--- a/hw/sd/allwinner-sdhost.c
52
+++ b/hw/core/machine.c
42
+++ b/hw/sd/allwinner-sdhost.c
53
@@ -XXX,XX +XXX,XX @@ GlobalProperty hw_compat_4_0[] = {
43
@@ -XXX,XX +XXX,XX @@ enum {
54
{ "virtio-gpu-pci", "edid", "false" },
44
REG_SD_DLBA = 0x84, /* Descriptor List Base Address */
55
{ "virtio-device", "use-started", "false" },
45
REG_SD_IDST = 0x88, /* Internal DMA Controller Status */
56
{ "virtio-balloon-device", "qemu-4-0-config-size", "true" },
46
REG_SD_IDIE = 0x8C, /* Internal DMA Controller IRQ Enable */
57
+ { "pl031", "migrate-tick-offset", "false" },
47
- REG_SD_THLDC = 0x100, /* Card Threshold Control */
58
};
48
+ REG_SD_THLDC = 0x100, /* Card Threshold Control / FIFO (sun4i only)*/
59
const size_t hw_compat_4_0_len = G_N_ELEMENTS(hw_compat_4_0);
49
REG_SD_DSBD = 0x10C, /* eMMC DDR Start Bit Detection Control */
60
50
REG_SD_RES_CRC = 0x110, /* Response CRC from card/eMMC */
61
diff --git a/hw/timer/pl031.c b/hw/timer/pl031.c
51
REG_SD_DATA7_CRC = 0x114, /* CRC Data 7 from card/eMMC */
62
index XXXXXXX..XXXXXXX 100644
52
@@ -XXX,XX +XXX,XX @@ static void allwinner_sdhost_dma(AwSdHostState *s)
63
--- a/hw/timer/pl031.c
53
}
64
+++ b/hw/timer/pl031.c
65
@@ -XXX,XX +XXX,XX @@ static int pl031_pre_save(void *opaque)
66
{
67
PL031State *s = opaque;
68
69
- /* tick_offset is base_time - rtc_clock base time. Instead, we want to
70
- * store the base time relative to the QEMU_CLOCK_VIRTUAL for backwards-compatibility. */
71
+ /*
72
+ * The PL031 device model code uses the tick_offset field, which is
73
+ * the offset between what the guest RTC should read and what the
74
+ * QEMU rtc_clock reads:
75
+ * guest_rtc = rtc_clock + tick_offset
76
+ * and so
77
+ * tick_offset = guest_rtc - rtc_clock
78
+ *
79
+ * We want to migrate this offset, which sounds straightforward.
80
+ * Unfortunately older versions of QEMU migrated a conversion of this
81
+ * offset into an offset from the vm_clock. (This was in turn an
82
+ * attempt to be compatible with even older QEMU versions, but it
83
+ * has incorrect behaviour if the rtc_clock is not the same as the
84
+ * vm_clock.) So we put the actual tick_offset into a migration
85
+ * subsection, and the backwards-compatible time-relative-to-vm_clock
86
+ * in the main migration state.
87
+ *
88
+ * Calculate base time relative to QEMU_CLOCK_VIRTUAL:
89
+ */
90
int64_t delta = qemu_clock_get_ns(rtc_clock) - qemu_clock_get_ns(QEMU_CLOCK_VIRTUAL);
91
s->tick_offset_vmstate = s->tick_offset + delta / NANOSECONDS_PER_SECOND;
92
93
return 0;
94
}
54
}
95
55
96
+static int pl031_pre_load(void *opaque)
56
+static uint32_t allwinner_sdhost_fifo_read(AwSdHostState *s)
97
+{
57
+{
98
+ PL031State *s = opaque;
58
+ uint32_t res = 0;
99
+
59
+
100
+ s->tick_offset_migrated = false;
60
+ if (sdbus_data_ready(&s->sdbus)) {
101
+ return 0;
61
+ sdbus_read_data(&s->sdbus, &res, sizeof(uint32_t));
62
+ le32_to_cpus(&res);
63
+ allwinner_sdhost_update_transfer_cnt(s, sizeof(uint32_t));
64
+ allwinner_sdhost_auto_stop(s);
65
+ allwinner_sdhost_update_irq(s);
66
+ } else {
67
+ qemu_log_mask(LOG_GUEST_ERROR, "%s: no data ready on SD bus\n",
68
+ __func__);
69
+ }
70
+
71
+ return res;
102
+}
72
+}
103
+
73
+
104
static int pl031_post_load(void *opaque, int version_id)
74
static uint64_t allwinner_sdhost_read(void *opaque, hwaddr offset,
75
unsigned size)
105
{
76
{
106
PL031State *s = opaque;
77
AwSdHostState *s = AW_SDHOST(opaque);
107
78
+ AwSdHostClass *sc = AW_SDHOST_GET_CLASS(s);
108
- int64_t delta = qemu_clock_get_ns(rtc_clock) - qemu_clock_get_ns(QEMU_CLOCK_VIRTUAL);
79
uint32_t res = 0;
109
- s->tick_offset = s->tick_offset_vmstate - delta / NANOSECONDS_PER_SECOND;
80
110
+ /*
81
switch (offset) {
111
+ * If we got the tick_offset subsection, then we can just use
82
@@ -XXX,XX +XXX,XX @@ static uint64_t allwinner_sdhost_read(void *opaque, hwaddr offset,
112
+ * the value in that. Otherwise the source is an older QEMU and
83
case REG_SD_IDIE: /* Internal DMA Controller Interrupt Enable */
113
+ * has given us the offset from the vm_clock; convert it back to
84
res = s->dmac_irq;
114
+ * an offset from the rtc_clock. This will cause time to incorrectly
85
break;
115
+ * go backwards compared to the host RTC, but this is unavoidable.
86
- case REG_SD_THLDC: /* Card Threshold Control */
116
+ */
87
- res = s->card_threshold;
117
+
88
+ case REG_SD_THLDC: /* Card Threshold Control or FIFO register (sun4i) */
118
+ if (!s->tick_offset_migrated) {
89
+ if (sc->is_sun4i) {
119
+ int64_t delta = qemu_clock_get_ns(rtc_clock) -
90
+ res = allwinner_sdhost_fifo_read(s);
120
+ qemu_clock_get_ns(QEMU_CLOCK_VIRTUAL);
91
+ } else {
121
+ s->tick_offset = s->tick_offset_vmstate -
92
+ res = s->card_threshold;
122
+ delta / NANOSECONDS_PER_SECOND;
93
+ }
123
+ }
94
break;
124
pl031_set_alarm(s);
95
case REG_SD_DSBD: /* eMMC DDR Start Bit Detection Control */
125
return 0;
96
res = s->startbit_detect;
97
@@ -XXX,XX +XXX,XX @@ static uint64_t allwinner_sdhost_read(void *opaque, hwaddr offset,
98
res = s->status_crc;
99
break;
100
case REG_SD_FIFO: /* Read/Write FIFO */
101
- if (sdbus_data_ready(&s->sdbus)) {
102
- sdbus_read_data(&s->sdbus, &res, sizeof(uint32_t));
103
- le32_to_cpus(&res);
104
- allwinner_sdhost_update_transfer_cnt(s, sizeof(uint32_t));
105
- allwinner_sdhost_auto_stop(s);
106
- allwinner_sdhost_update_irq(s);
107
- } else {
108
- qemu_log_mask(LOG_GUEST_ERROR, "%s: no data ready on SD bus\n",
109
- __func__);
110
- }
111
+ res = allwinner_sdhost_fifo_read(s);
112
break;
113
default:
114
qemu_log_mask(LOG_GUEST_ERROR, "%s: out-of-bounds offset %"
115
@@ -XXX,XX +XXX,XX @@ static uint64_t allwinner_sdhost_read(void *opaque, hwaddr offset,
116
return res;
126
}
117
}
127
118
128
+static int pl031_tick_offset_post_load(void *opaque, int version_id)
119
+static void allwinner_sdhost_fifo_write(AwSdHostState *s, uint64_t value)
129
+{
120
+{
130
+ PL031State *s = opaque;
121
+ uint32_t u32 = cpu_to_le32(value);
131
+
122
+ sdbus_write_data(&s->sdbus, &u32, sizeof(u32));
132
+ s->tick_offset_migrated = true;
123
+ allwinner_sdhost_update_transfer_cnt(s, sizeof(u32));
133
+ return 0;
124
+ allwinner_sdhost_auto_stop(s);
125
+ allwinner_sdhost_update_irq(s);
134
+}
126
+}
135
+
127
+
136
+static bool pl031_tick_offset_needed(void *opaque)
128
static void allwinner_sdhost_write(void *opaque, hwaddr offset,
137
+{
129
uint64_t value, unsigned size)
138
+ PL031State *s = opaque;
139
+
140
+ return s->migrate_tick_offset;
141
+}
142
+
143
+static const VMStateDescription vmstate_pl031_tick_offset = {
144
+ .name = "pl031/tick-offset",
145
+ .version_id = 1,
146
+ .minimum_version_id = 1,
147
+ .needed = pl031_tick_offset_needed,
148
+ .post_load = pl031_tick_offset_post_load,
149
+ .fields = (VMStateField[]) {
150
+ VMSTATE_UINT32(tick_offset, PL031State),
151
+ VMSTATE_END_OF_LIST()
152
+ }
153
+};
154
+
155
static const VMStateDescription vmstate_pl031 = {
156
.name = "pl031",
157
.version_id = 1,
158
.minimum_version_id = 1,
159
.pre_save = pl031_pre_save,
160
+ .pre_load = pl031_pre_load,
161
.post_load = pl031_post_load,
162
.fields = (VMStateField[]) {
163
VMSTATE_UINT32(tick_offset_vmstate, PL031State),
164
@@ -XXX,XX +XXX,XX @@ static const VMStateDescription vmstate_pl031 = {
165
VMSTATE_UINT32(im, PL031State),
166
VMSTATE_UINT32(is, PL031State),
167
VMSTATE_END_OF_LIST()
168
+ },
169
+ .subsections = (const VMStateDescription*[]) {
170
+ &vmstate_pl031_tick_offset,
171
+ NULL
172
}
173
};
174
175
+static Property pl031_properties[] = {
176
+ /*
177
+ * True to correctly migrate the tick offset of the RTC. False to
178
+ * obtain backward migration compatibility with older QEMU versions,
179
+ * at the expense of the guest RTC going backwards compared with the
180
+ * host RTC when the VM is saved/restored if using -rtc host.
181
+ * (Even if set to 'true' older QEMU can migrate forward to newer QEMU;
182
+ * 'false' also permits newer QEMU to migrate to older QEMU.)
183
+ */
184
+ DEFINE_PROP_BOOL("migrate-tick-offset",
185
+ PL031State, migrate_tick_offset, true),
186
+ DEFINE_PROP_END_OF_LIST()
187
+};
188
+
189
static void pl031_class_init(ObjectClass *klass, void *data)
190
{
130
{
191
DeviceClass *dc = DEVICE_CLASS(klass);
131
AwSdHostState *s = AW_SDHOST(opaque);
192
132
- uint32_t u32;
193
dc->vmsd = &vmstate_pl031;
133
+ AwSdHostClass *sc = AW_SDHOST_GET_CLASS(s);
194
+ dc->props = pl031_properties;
134
135
trace_allwinner_sdhost_write(offset, value, size);
136
137
@@ -XXX,XX +XXX,XX @@ static void allwinner_sdhost_write(void *opaque, hwaddr offset,
138
s->dmac_irq = value;
139
allwinner_sdhost_update_irq(s);
140
break;
141
- case REG_SD_THLDC: /* Card Threshold Control */
142
- s->card_threshold = value;
143
+ case REG_SD_THLDC: /* Card Threshold Control or FIFO (sun4i) */
144
+ if (sc->is_sun4i) {
145
+ allwinner_sdhost_fifo_write(s, value);
146
+ } else {
147
+ s->card_threshold = value;
148
+ }
149
break;
150
case REG_SD_DSBD: /* eMMC DDR Start Bit Detection Control */
151
s->startbit_detect = value;
152
break;
153
case REG_SD_FIFO: /* Read/Write FIFO */
154
- u32 = cpu_to_le32(value);
155
- sdbus_write_data(&s->sdbus, &u32, sizeof(u32));
156
- allwinner_sdhost_update_transfer_cnt(s, sizeof(u32));
157
- allwinner_sdhost_auto_stop(s);
158
- allwinner_sdhost_update_irq(s);
159
+ allwinner_sdhost_fifo_write(s, value);
160
break;
161
case REG_SD_RES_CRC: /* Response CRC from card/eMMC */
162
case REG_SD_DATA7_CRC: /* CRC Data 7 from card/eMMC */
163
@@ -XXX,XX +XXX,XX @@ static void allwinner_sdhost_sun4i_class_init(ObjectClass *klass, void *data)
164
{
165
AwSdHostClass *sc = AW_SDHOST_CLASS(klass);
166
sc->max_desc_size = 8 * KiB;
167
+ sc->is_sun4i = true;
195
}
168
}
196
169
197
static const TypeInfo pl031_info = {
170
static void allwinner_sdhost_sun5i_class_init(ObjectClass *klass, void *data)
171
{
172
AwSdHostClass *sc = AW_SDHOST_CLASS(klass);
173
sc->max_desc_size = 64 * KiB;
174
+ sc->is_sun4i = false;
175
}
176
177
static const TypeInfo allwinner_sdhost_info = {
198
--
178
--
199
2.20.1
179
2.25.1
200
201
diff view generated by jsdifflib
1
From: David Engraf <david.engraf@sysgo.com>
1
From: Alex Bennée <alex.bennee@linaro.org>
2
2
3
Using the whole 128 MiB flash in non-secure mode is not working because
3
gic_dist_readb was returning a word value which just happened to work
4
virt_flash_fdt() expects the same address for secure_sysmem and sysmem.
4
as a result of the way we OR the data together. Lets fix it so only
5
This is not correctly handled by caller because it forwards NULL for
5
the explicit byte is returned for each part of GICD_TYPER. I've
6
secure_sysmem in non-secure flash mode.
6
changed the return type to uint8_t although the overflow is only
7
detected with an explicit -Wconversion.
7
8
8
Fixed by using sysmem when secure_sysmem is NULL.
9
Signed-off-by: Alex Bennée <alex.bennee@linaro.org>
9
10
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
10
Signed-off-by: David Engraf <david.engraf@sysgo.com>
11
Reviewed-by: Philippe Mathieu-Daudé <philmd@linaro.org>
11
Message-id: 20190712075002.14326-1-david.engraf@sysgo.com
12
Reviewed-by: Peter Maydell <peter.maydell@linaro.org>
12
Reviewed-by: Peter Maydell <peter.maydell@linaro.org>
13
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
13
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
14
---
14
---
15
hw/arm/virt.c | 2 +-
15
hw/intc/arm_gic.c | 16 ++++++++++------
16
1 file changed, 1 insertion(+), 1 deletion(-)
16
1 file changed, 10 insertions(+), 6 deletions(-)
17
17
18
diff --git a/hw/arm/virt.c b/hw/arm/virt.c
18
diff --git a/hw/intc/arm_gic.c b/hw/intc/arm_gic.c
19
index XXXXXXX..XXXXXXX 100644
19
index XXXXXXX..XXXXXXX 100644
20
--- a/hw/arm/virt.c
20
--- a/hw/intc/arm_gic.c
21
+++ b/hw/arm/virt.c
21
+++ b/hw/intc/arm_gic.c
22
@@ -XXX,XX +XXX,XX @@ static void machvirt_init(MachineState *machine)
22
@@ -XXX,XX +XXX,XX @@ static void gic_complete_irq(GICState *s, int cpu, int irq, MemTxAttrs attrs)
23
&machine->device_memory->mr);
23
gic_update(s);
24
}
24
}
25
25
26
- virt_flash_fdt(vms, sysmem, secure_sysmem);
26
-static uint32_t gic_dist_readb(void *opaque, hwaddr offset, MemTxAttrs attrs)
27
+ virt_flash_fdt(vms, sysmem, secure_sysmem ?: sysmem);
27
+static uint8_t gic_dist_readb(void *opaque, hwaddr offset, MemTxAttrs attrs)
28
28
{
29
create_gic(vms, pic);
29
GICState *s = (GICState *)opaque;
30
30
uint32_t res;
31
@@ -XXX,XX +XXX,XX @@ static uint32_t gic_dist_readb(void *opaque, hwaddr offset, MemTxAttrs attrs)
32
cm = 1 << cpu;
33
if (offset < 0x100) {
34
if (offset == 0) { /* GICD_CTLR */
35
+ /* We rely here on the only non-zero bits being in byte 0 */
36
if (s->security_extn && !attrs.secure) {
37
/* The NS bank of this register is just an alias of the
38
* EnableGrp1 bit in the S bank version.
39
@@ -XXX,XX +XXX,XX @@ static uint32_t gic_dist_readb(void *opaque, hwaddr offset, MemTxAttrs attrs)
40
return s->ctlr;
41
}
42
}
43
- if (offset == 4)
44
- /* Interrupt Controller Type Register */
45
- return ((s->num_irq / 32) - 1)
46
- | ((s->num_cpu - 1) << 5)
47
- | (s->security_extn << 10);
48
+ if (offset == 4) {
49
+ /* GICD_TYPER byte 0 */
50
+ return ((s->num_irq / 32) - 1) | ((s->num_cpu - 1) << 5);
51
+ }
52
+ if (offset == 5) {
53
+ /* GICD_TYPER byte 1 */
54
+ return (s->security_extn << 2);
55
+ }
56
if (offset < 0x08)
57
return 0;
58
if (offset >= 0x80) {
31
--
59
--
32
2.20.1
60
2.25.1
33
61
34
62
diff view generated by jsdifflib
1
From: Alex Bennée <alex.bennee@linaro.org>
1
From: Alex Bennée <alex.bennee@linaro.org>
2
2
3
When we converted to using feature bits in 602f6e42cfbf we missed out
3
a66a24585f (hw/intc/arm_gic: Implement read of GICC_IIDR) implemented
4
the fact (dp && arm_dc_feature(s, ARM_FEATURE_V8)) was supported for
4
this for the CPU interface register. The fact we don't implement it
5
-cpu max configurations. This caused a regression in the GCC test
5
shows up when running Xen with -d guest_error which is definitely
6
suite. Fix this by setting the appropriate bits in mvfr1.FPHP to
6
wrong because the guest is perfectly entitled to read it.
7
report ARMv8-A with FP support (but not ARMv8.2-FP16).
8
7
9
Fixes: https://bugs.launchpad.net/qemu/+bug/1836078
10
Signed-off-by: Alex Bennée <alex.bennee@linaro.org>
8
Signed-off-by: Alex Bennée <alex.bennee@linaro.org>
11
Reviewed-by: Richard Henderson <richard.henderson@linaro.org>
9
Reviewed-by: Philippe Mathieu-Daudé <philmd@linaro.org>
12
Message-id: 20190711103737.10017-1-alex.bennee@linaro.org
10
Reviewed-by: Peter Maydell <peter.maydell@linaro.org>
13
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
11
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
14
---
12
---
15
target/arm/cpu.c | 4 ++++
13
hw/intc/arm_gic.c | 12 +++++++++++-
16
1 file changed, 4 insertions(+)
14
1 file changed, 11 insertions(+), 1 deletion(-)
17
15
18
diff --git a/target/arm/cpu.c b/target/arm/cpu.c
16
diff --git a/hw/intc/arm_gic.c b/hw/intc/arm_gic.c
19
index XXXXXXX..XXXXXXX 100644
17
index XXXXXXX..XXXXXXX 100644
20
--- a/target/arm/cpu.c
18
--- a/hw/intc/arm_gic.c
21
+++ b/target/arm/cpu.c
19
+++ b/hw/intc/arm_gic.c
22
@@ -XXX,XX +XXX,XX @@ static void arm_max_initfn(Object *obj)
20
@@ -XXX,XX +XXX,XX @@ static uint8_t gic_dist_readb(void *opaque, hwaddr offset, MemTxAttrs attrs)
23
t = FIELD_DP32(t, ID_ISAR6, SPECRES, 1);
21
/* GICD_TYPER byte 1 */
24
cpu->isar.id_isar6 = t;
22
return (s->security_extn << 2);
25
23
}
26
+ t = cpu->isar.mvfr1;
24
- if (offset < 0x08)
27
+ t = FIELD_DP32(t, MVFR1, FPHP, 2); /* v8.0 FP support */
25
+ if (offset == 8) {
28
+ cpu->isar.mvfr1 = t;
26
+ /* GICD_IIDR byte 0 */
29
+
27
+ return 0x3b; /* Arm JEP106 identity */
30
t = cpu->isar.mvfr2;
28
+ }
31
t = FIELD_DP32(t, MVFR2, SIMDMISC, 3); /* SIMD MaxNum */
29
+ if (offset == 9) {
32
t = FIELD_DP32(t, MVFR2, FPMISC, 4); /* FP MaxNum */
30
+ /* GICD_IIDR byte 1 */
31
+ return 0x04; /* Arm JEP106 identity */
32
+ }
33
+ if (offset < 0x0c) {
34
+ /* All other bytes in this range are RAZ */
35
return 0;
36
+ }
37
if (offset >= 0x80) {
38
/* Interrupt Group Registers: these RAZ/WI if this is an NS
39
* access to a GIC with the security extensions, or if the GIC
33
--
40
--
34
2.20.1
41
2.25.1
35
42
36
43
diff view generated by jsdifflib
Deleted patch
1
From: Philippe Mathieu-Daudé <philmd@redhat.com>
2
1
3
In the next commit we will implement the write_with_attrs()
4
handler. To avoid using different APIs, convert the read()
5
handler first.
6
7
Reviewed-by: Francisco Iglesias <frasse.iglesias@gmail.com>
8
Tested-by: Francisco Iglesias <frasse.iglesias@gmail.com>
9
Signed-off-by: Philippe Mathieu-Daudé <philmd@redhat.com>
10
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
11
---
12
hw/ssi/xilinx_spips.c | 23 +++++++++++------------
13
1 file changed, 11 insertions(+), 12 deletions(-)
14
15
diff --git a/hw/ssi/xilinx_spips.c b/hw/ssi/xilinx_spips.c
16
index XXXXXXX..XXXXXXX 100644
17
--- a/hw/ssi/xilinx_spips.c
18
+++ b/hw/ssi/xilinx_spips.c
19
@@ -XXX,XX +XXX,XX @@ static void lqspi_load_cache(void *opaque, hwaddr addr)
20
}
21
}
22
23
-static uint64_t
24
-lqspi_read(void *opaque, hwaddr addr, unsigned int size)
25
+static MemTxResult lqspi_read(void *opaque, hwaddr addr, uint64_t *value,
26
+ unsigned size, MemTxAttrs attrs)
27
{
28
- XilinxQSPIPS *q = opaque;
29
- uint32_t ret;
30
+ XilinxQSPIPS *q = XILINX_QSPIPS(opaque);
31
32
if (addr >= q->lqspi_cached_addr &&
33
addr <= q->lqspi_cached_addr + LQSPI_CACHE_SIZE - 4) {
34
uint8_t *retp = &q->lqspi_buf[addr - q->lqspi_cached_addr];
35
- ret = cpu_to_le32(*(uint32_t *)retp);
36
- DB_PRINT_L(1, "addr: %08x, data: %08x\n", (unsigned)addr,
37
- (unsigned)ret);
38
- return ret;
39
- } else {
40
- lqspi_load_cache(opaque, addr);
41
- return lqspi_read(opaque, addr, size);
42
+ *value = cpu_to_le32(*(uint32_t *)retp);
43
+ DB_PRINT_L(1, "addr: %08" HWADDR_PRIx ", data: %08" PRIx64 "\n",
44
+ addr, *value);
45
+ return MEMTX_OK;
46
}
47
+
48
+ lqspi_load_cache(opaque, addr);
49
+ return lqspi_read(opaque, addr, value, size, attrs);
50
}
51
52
static const MemoryRegionOps lqspi_ops = {
53
- .read = lqspi_read,
54
+ .read_with_attrs = lqspi_read,
55
.endianness = DEVICE_NATIVE_ENDIAN,
56
.valid = {
57
.min_access_size = 1,
58
--
59
2.20.1
60
61
diff view generated by jsdifflib
Deleted patch
1
From: Philippe Mathieu-Daudé <philmd@redhat.com>
2
1
3
Lei Sun found while auditing the code that a CPU write would
4
trigger a NULL pointer dereference.
5
6
>From UG1085 datasheet [*] AXI writes in this region are ignored
7
and generates an AXI Slave Error (SLVERR).
8
9
Fix by implementing the write_with_attrs() handler.
10
Return MEMTX_ERROR when the region is accessed (this error maps
11
to an AXI slave error).
12
13
[*] https://www.xilinx.com/support/documentation/user_guides/ug1085-zynq-ultrascale-trm.pdf
14
15
Reported-by: Lei Sun <slei.casper@gmail.com>
16
Reviewed-by: Francisco Iglesias <frasse.iglesias@gmail.com>
17
Tested-by: Francisco Iglesias <frasse.iglesias@gmail.com>
18
Signed-off-by: Philippe Mathieu-Daudé <philmd@redhat.com>
19
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
20
---
21
hw/ssi/xilinx_spips.c | 16 ++++++++++++++++
22
1 file changed, 16 insertions(+)
23
24
diff --git a/hw/ssi/xilinx_spips.c b/hw/ssi/xilinx_spips.c
25
index XXXXXXX..XXXXXXX 100644
26
--- a/hw/ssi/xilinx_spips.c
27
+++ b/hw/ssi/xilinx_spips.c
28
@@ -XXX,XX +XXX,XX @@ static MemTxResult lqspi_read(void *opaque, hwaddr addr, uint64_t *value,
29
return lqspi_read(opaque, addr, value, size, attrs);
30
}
31
32
+static MemTxResult lqspi_write(void *opaque, hwaddr offset, uint64_t value,
33
+ unsigned size, MemTxAttrs attrs)
34
+{
35
+ /*
36
+ * From UG1085, Chapter 24 (Quad-SPI controllers):
37
+ * - Writes are ignored
38
+ * - AXI writes generate an external AXI slave error (SLVERR)
39
+ */
40
+ qemu_log_mask(LOG_GUEST_ERROR, "%s Unexpected %u-bit access to 0x%" PRIx64
41
+ " (value: 0x%" PRIx64 "\n",
42
+ __func__, size << 3, offset, value);
43
+
44
+ return MEMTX_ERROR;
45
+}
46
+
47
static const MemoryRegionOps lqspi_ops = {
48
.read_with_attrs = lqspi_read,
49
+ .write_with_attrs = lqspi_write,
50
.endianness = DEVICE_NATIVE_ENDIAN,
51
.valid = {
52
.min_access_size = 1,
53
--
54
2.20.1
55
56
diff view generated by jsdifflib
Deleted patch
1
From: Philippe Mathieu-Daudé <philmd@redhat.com>
2
1
3
Both lqspi_read() and lqspi_load_cache() expect a 32-bit
4
aligned address.
5
6
>From UG1085 datasheet [*] chapter on 'Quad-SPI Controller':
7
8
Transfer Size Limitations
9
10
Because of the 32-bit wide TX, RX, and generic FIFO, all
11
APB/AXI transfers must be an integer multiple of 4-bytes.
12
Shorter transfers are not possible.
13
14
Set MemoryRegionOps.impl values to force 32-bit accesses,
15
this way we are sure we do not access the lqspi_buf[] array
16
out of bound.
17
18
[*] https://www.xilinx.com/support/documentation/user_guides/ug1085-zynq-ultrascale-trm.pdf
19
20
Reviewed-by: Francisco Iglesias <frasse.iglesias@gmail.com>
21
Tested-by: Francisco Iglesias <frasse.iglesias@gmail.com>
22
Signed-off-by: Philippe Mathieu-Daudé <philmd@redhat.com>
23
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
24
---
25
hw/ssi/xilinx_spips.c | 4 ++++
26
1 file changed, 4 insertions(+)
27
28
diff --git a/hw/ssi/xilinx_spips.c b/hw/ssi/xilinx_spips.c
29
index XXXXXXX..XXXXXXX 100644
30
--- a/hw/ssi/xilinx_spips.c
31
+++ b/hw/ssi/xilinx_spips.c
32
@@ -XXX,XX +XXX,XX @@ static const MemoryRegionOps lqspi_ops = {
33
.read_with_attrs = lqspi_read,
34
.write_with_attrs = lqspi_write,
35
.endianness = DEVICE_NATIVE_ENDIAN,
36
+ .impl = {
37
+ .min_access_size = 4,
38
+ .max_access_size = 4,
39
+ },
40
.valid = {
41
.min_access_size = 1,
42
.max_access_size = 4
43
--
44
2.20.1
45
46
diff view generated by jsdifflib
Deleted patch
1
From: Philippe Mathieu-Daudé <philmd@redhat.com>
2
1
3
Reading the RX_DATA register when the RX_FIFO is empty triggers
4
an abort. This can be easily reproduced:
5
6
$ qemu-system-arm -M emcraft-sf2 -monitor stdio -S
7
QEMU 4.0.50 monitor - type 'help' for more information
8
(qemu) x 0x40001010
9
Aborted (core dumped)
10
11
(gdb) bt
12
#1 0x00007f035874f895 in abort () at /lib64/libc.so.6
13
#2 0x00005628686591ff in fifo8_pop (fifo=0x56286a9a4c68) at util/fifo8.c:66
14
#3 0x00005628683e0b8e in fifo32_pop (fifo=0x56286a9a4c68) at include/qemu/fifo32.h:137
15
#4 0x00005628683e0efb in spi_read (opaque=0x56286a9a4850, addr=4, size=4) at hw/ssi/mss-spi.c:168
16
#5 0x0000562867f96801 in memory_region_read_accessor (mr=0x56286a9a4b60, addr=16, value=0x7ffeecb0c5c8, size=4, shift=0, mask=4294967295, attrs=...) at memory.c:439
17
#6 0x0000562867f96cdb in access_with_adjusted_size (addr=16, value=0x7ffeecb0c5c8, size=4, access_size_min=1, access_size_max=4, access_fn=0x562867f967c3 <memory_region_read_accessor>, mr=0x56286a9a4b60, attrs=...) at memory.c:569
18
#7 0x0000562867f99940 in memory_region_dispatch_read1 (mr=0x56286a9a4b60, addr=16, pval=0x7ffeecb0c5c8, size=4, attrs=...) at memory.c:1420
19
#8 0x0000562867f99a08 in memory_region_dispatch_read (mr=0x56286a9a4b60, addr=16, pval=0x7ffeecb0c5c8, size=4, attrs=...) at memory.c:1447
20
#9 0x0000562867f38721 in flatview_read_continue (fv=0x56286aec6360, addr=1073745936, attrs=..., buf=0x7ffeecb0c7c0 "\340ǰ\354\376\177", len=4, addr1=16, l=4, mr=0x56286a9a4b60) at exec.c:3385
21
#10 0x0000562867f38874 in flatview_read (fv=0x56286aec6360, addr=1073745936, attrs=..., buf=0x7ffeecb0c7c0 "\340ǰ\354\376\177", len=4) at exec.c:3423
22
#11 0x0000562867f388ea in address_space_read_full (as=0x56286aa3e890, addr=1073745936, attrs=..., buf=0x7ffeecb0c7c0 "\340ǰ\354\376\177", len=4) at exec.c:3436
23
#12 0x0000562867f389c5 in address_space_rw (as=0x56286aa3e890, addr=1073745936, attrs=..., buf=0x7ffeecb0c7c0 "\340ǰ\354\376\177", len=4, is_write=false) at exec.c:3466
24
#13 0x0000562867f3bdd7 in cpu_memory_rw_debug (cpu=0x56286aa19d00, addr=1073745936, buf=0x7ffeecb0c7c0 "\340ǰ\354\376\177", len=4, is_write=0) at exec.c:3976
25
#14 0x000056286811ed51 in memory_dump (mon=0x56286a8c32d0, count=1, format=120, wsize=4, addr=1073745936, is_physical=0) at monitor/misc.c:730
26
#15 0x000056286811eff1 in hmp_memory_dump (mon=0x56286a8c32d0, qdict=0x56286b15c400) at monitor/misc.c:785
27
#16 0x00005628684740ee in handle_hmp_command (mon=0x56286a8c32d0, cmdline=0x56286a8caeb2 "0x40001010") at monitor/hmp.c:1082
28
29
From the datasheet "Actel SmartFusion Microcontroller Subsystem
30
User's Guide" Rev.1, Table 13-3 "SPI Register Summary", this
31
register has a reset value of 0.
32
33
Check the FIFO is not empty before accessing it, else log an
34
error message.
35
36
Signed-off-by: Philippe Mathieu-Daudé <philmd@redhat.com>
37
Reviewed-by: Alistair Francis <alistair.francis@wdc.com>
38
Message-id: 20190709113715.7761-3-philmd@redhat.com
39
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
40
---
41
hw/ssi/mss-spi.c | 8 +++++++-
42
1 file changed, 7 insertions(+), 1 deletion(-)
43
44
diff --git a/hw/ssi/mss-spi.c b/hw/ssi/mss-spi.c
45
index XXXXXXX..XXXXXXX 100644
46
--- a/hw/ssi/mss-spi.c
47
+++ b/hw/ssi/mss-spi.c
48
@@ -XXX,XX +XXX,XX @@ spi_read(void *opaque, hwaddr addr, unsigned int size)
49
case R_SPI_RX:
50
s->regs[R_SPI_STATUS] &= ~S_RXFIFOFUL;
51
s->regs[R_SPI_STATUS] &= ~S_RXCHOVRF;
52
- ret = fifo32_pop(&s->rx_fifo);
53
+ if (fifo32_is_empty(&s->rx_fifo)) {
54
+ qemu_log_mask(LOG_GUEST_ERROR,
55
+ "%s: Reading empty RX_FIFO\n",
56
+ __func__);
57
+ } else {
58
+ ret = fifo32_pop(&s->rx_fifo);
59
+ }
60
if (fifo32_is_empty(&s->rx_fifo)) {
61
s->regs[R_SPI_STATUS] |= S_RXFIFOEMP;
62
}
63
--
64
2.20.1
65
66
diff view generated by jsdifflib
1
In the M-profile architecture, when we do a vector table fetch and it
1
The two tests
2
fails, we need to report a HardFault. Whether this is a Secure HF or
2
tests/avocado/boot_linux.py:BootLinuxAarch64.test_virt_tcg_gicv2
3
a NonSecure HF depends on several things. If AIRCR.BFHFNMINS is 0
3
tests/avocado/boot_linux.py:BootLinuxAarch64.test_virt_tcg_gicv3
4
then HF is always Secure, because there is no NonSecure HardFault.
5
Otherwise, the answer depends on whether the 'underlying exception'
6
(MemManage, BusFault, SecureFault) targets Secure or NonSecure. (In
7
the pseudocode, this is handled in the Vector() function: the final
8
exc.isSecure is calculated by looking at the exc.isSecure from the
9
exception returned from the memory access, not the isSecure input
10
argument.)
11
4
12
We weren't doing this correctly, because we were looking at
5
take quite a long time to run, and the current timeout of 240s
13
the target security domain of the exception we were trying to
6
is not enough for the tests to complete on slow machines:
14
load the vector table entry for. This produces errors of two kinds:
7
we've seen these tests time out in the gitlab CI in the
15
* a load from the NS vector table which hits the "NS access
8
'avocado-system-alpine' CI job, for instance. The timeout
16
to S memory" SecureFault should end up as a Secure HardFault,
9
is also insufficient for running the test with a debug build
17
but we were raising an NS HardFault
10
of QEMU: on my machine the tests take over 10 minutes to run
18
* a load from the S vector table which causes a BusFault
11
in that config.
19
should raise an NS HardFault if BFHFNMINS == 1 (because
20
in that case all BusFaults are NonSecure), but we were raising
21
a Secure HardFault
22
12
23
Correct the logic.
13
Push the timeout up to 720s so that the test definitely has
24
14
enough time to complete.
25
We also fix a comment error where we claimed that we might
26
be escalating MemManage to HardFault, and forgot about SecureFault.
27
(Vector loads can never hit MPU access faults, because they're
28
always aligned and always use the default address map.)
29
15
30
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
16
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
31
Message-id: 20190705094823.28905-1-peter.maydell@linaro.org
17
Reviewed-by: Thomas Huth <thuth@redhat.com>
18
Reviewed-by: Philippe Mathieu-Daudé <philmd@linaro.org>
32
---
19
---
33
target/arm/m_helper.c | 21 +++++++++++++++++----
20
tests/avocado/boot_linux.py | 2 +-
34
1 file changed, 17 insertions(+), 4 deletions(-)
21
1 file changed, 1 insertion(+), 1 deletion(-)
35
22
36
diff --git a/target/arm/m_helper.c b/target/arm/m_helper.c
23
diff --git a/tests/avocado/boot_linux.py b/tests/avocado/boot_linux.py
37
index XXXXXXX..XXXXXXX 100644
24
index XXXXXXX..XXXXXXX 100644
38
--- a/target/arm/m_helper.c
25
--- a/tests/avocado/boot_linux.py
39
+++ b/target/arm/m_helper.c
26
+++ b/tests/avocado/boot_linux.py
40
@@ -XXX,XX +XXX,XX @@ static bool arm_v7m_load_vector(ARMCPU *cpu, int exc, bool targets_secure,
27
@@ -XXX,XX +XXX,XX @@ class BootLinuxAarch64(LinuxTest):
41
if (sattrs.ns) {
28
:avocado: tags=machine:virt
42
attrs.secure = false;
29
:avocado: tags=machine:gic-version=2
43
} else if (!targets_secure) {
30
"""
44
- /* NS access to S memory */
31
- timeout = 240
45
+ /*
32
+ timeout = 720
46
+ * NS access to S memory: the underlying exception which we escalate
33
47
+ * to HardFault is SecureFault, which always targets Secure.
34
def add_common_args(self):
48
+ */
35
self.vm.add_args('-bios',
49
+ exc_secure = true;
50
goto load_fail;
51
}
52
}
53
@@ -XXX,XX +XXX,XX @@ static bool arm_v7m_load_vector(ARMCPU *cpu, int exc, bool targets_secure,
54
vector_entry = address_space_ldl(arm_addressspace(cs, attrs), addr,
55
attrs, &result);
56
if (result != MEMTX_OK) {
57
+ /*
58
+ * Underlying exception is BusFault: its target security state
59
+ * depends on BFHFNMINS.
60
+ */
61
+ exc_secure = !(cpu->env.v7m.aircr & R_V7M_AIRCR_BFHFNMINS_MASK);
62
goto load_fail;
63
}
64
*pvec = vector_entry;
65
@@ -XXX,XX +XXX,XX @@ load_fail:
66
/*
67
* All vector table fetch fails are reported as HardFault, with
68
* HFSR.VECTTBL and .FORCED set. (FORCED is set because
69
- * technically the underlying exception is a MemManage or BusFault
70
+ * technically the underlying exception is a SecureFault or BusFault
71
* that is escalated to HardFault.) This is a terminal exception,
72
* so we will either take the HardFault immediately or else enter
73
* lockup (the latter case is handled in armv7m_nvic_set_pending_derived()).
74
+ * The HardFault is Secure if BFHFNMINS is 0 (meaning that all HFs are
75
+ * secure); otherwise it targets the same security state as the
76
+ * underlying exception.
77
*/
78
- exc_secure = targets_secure ||
79
- !(cpu->env.v7m.aircr & R_V7M_AIRCR_BFHFNMINS_MASK);
80
+ if (!(cpu->env.v7m.aircr & R_V7M_AIRCR_BFHFNMINS_MASK)) {
81
+ exc_secure = true;
82
+ }
83
env->v7m.hfsr |= R_V7M_HFSR_VECTTBL_MASK | R_V7M_HFSR_FORCED_MASK;
84
armv7m_nvic_set_pending_derived(env->nvic, ARMV7M_EXCP_HARD, exc_secure);
85
return false;
86
--
36
--
87
2.20.1
37
2.25.1
88
38
89
39
diff view generated by jsdifflib
1
From: Philippe Mathieu-Daudé <philmd@redhat.com>
1
From: Ard Biesheuvel <ardb@kernel.org>
2
2
3
In the previous commit we fixed a crash when the guest read a
3
With LPA2, the effective output address size is at most 48 bits when
4
register that pop from an empty FIFO.
4
TCR.DS == 0. This case is currently unhandled in the page table walker,
5
By auditing the repository, we found another similar use with
5
where we happily assume LVA/64k granule when outputsize > 48 and
6
an easy way to reproduce:
6
param.ds == 0, resulting in the wrong conversion to be used from a
7
page table descriptor to a physical address.
7
8
8
$ qemu-system-aarch64 -M xlnx-zcu102 -monitor stdio -S
9
if (outputsize > 48) {
9
QEMU 4.0.50 monitor - type 'help' for more information
10
if (param.ds) {
10
(qemu) xp/b 0xfd4a0134
11
descaddr |= extract64(descriptor, 8, 2) << 50;
11
Aborted (core dumped)
12
} else {
13
descaddr |= extract64(descriptor, 12, 4) << 48;
14
}
12
15
13
(gdb) bt
16
So cap the outputsize to 48 when TCR.DS is cleared, as per the
14
#0 0x00007f6936dea57f in raise () at /lib64/libc.so.6
17
architecture.
15
#1 0x00007f6936dd4895 in abort () at /lib64/libc.so.6
16
#2 0x0000561ad32975ec in xlnx_dp_aux_pop_rx_fifo (s=0x7f692babee70) at hw/display/xlnx_dp.c:431
17
#3 0x0000561ad3297dc0 in xlnx_dp_read (opaque=0x7f692babee70, offset=77, size=4) at hw/display/xlnx_dp.c:667
18
#4 0x0000561ad321b896 in memory_region_read_accessor (mr=0x7f692babf620, addr=308, value=0x7ffe05c1db88, size=4, shift=0, mask=4294967295, attrs=...) at memory.c:439
19
#5 0x0000561ad321bd70 in access_with_adjusted_size (addr=308, value=0x7ffe05c1db88, size=1, access_size_min=4, access_size_max=4, access_fn=0x561ad321b858 <memory_region_read_accessor>, mr=0x7f692babf620, attrs=...) at memory.c:569
20
#6 0x0000561ad321e9d5 in memory_region_dispatch_read1 (mr=0x7f692babf620, addr=308, pval=0x7ffe05c1db88, size=1, attrs=...) at memory.c:1420
21
#7 0x0000561ad321ea9d in memory_region_dispatch_read (mr=0x7f692babf620, addr=308, pval=0x7ffe05c1db88, size=1, attrs=...) at memory.c:1447
22
#8 0x0000561ad31bd742 in flatview_read_continue (fv=0x561ad69c04f0, addr=4249485620, attrs=..., buf=0x7ffe05c1dcf0 "\020\335\301\005\376\177", len=1, addr1=308, l=1, mr=0x7f692babf620) at exec.c:3385
23
#9 0x0000561ad31bd895 in flatview_read (fv=0x561ad69c04f0, addr=4249485620, attrs=..., buf=0x7ffe05c1dcf0 "\020\335\301\005\376\177", len=1) at exec.c:3423
24
#10 0x0000561ad31bd90b in address_space_read_full (as=0x561ad5bb3020, addr=4249485620, attrs=..., buf=0x7ffe05c1dcf0 "\020\335\301\005\376\177", len=1) at exec.c:3436
25
#11 0x0000561ad33b1c42 in address_space_read (len=1, buf=0x7ffe05c1dcf0 "\020\335\301\005\376\177", attrs=..., addr=4249485620, as=0x561ad5bb3020) at include/exec/memory.h:2131
26
#12 0x0000561ad33b1c42 in memory_dump (mon=0x561ad59c4530, count=1, format=120, wsize=1, addr=4249485620, is_physical=1) at monitor/misc.c:723
27
#13 0x0000561ad33b1fc1 in hmp_physical_memory_dump (mon=0x561ad59c4530, qdict=0x561ad6c6fd00) at monitor/misc.c:795
28
#14 0x0000561ad37b4a9f in handle_hmp_command (mon=0x561ad59c4530, cmdline=0x561ad59d0f22 "/b 0x00000000fd4a0134") at monitor/hmp.c:1082
29
18
30
Fix by checking the FIFO is not empty before popping from it.
19
Cc: Peter Maydell <peter.maydell@linaro.org>
31
20
Cc: Philippe Mathieu-Daudé <f4bug@amsat.org>
32
The datasheet is not clear about the reset value of this register,
21
Cc: Richard Henderson <richard.henderson@linaro.org>
33
we choose to return '0'.
22
Signed-off-by: Ard Biesheuvel <ardb@kernel.org>
34
23
Reviewed-by: Richard Henderson <richard.henderson@linaro.org>
35
Signed-off-by: Philippe Mathieu-Daudé <philmd@redhat.com>
24
Message-id: 20221116170316.259695-1-ardb@kernel.org
36
Reviewed-by: Alistair Francis <alistair.francis@wdc.com>
37
Message-id: 20190709113715.7761-4-philmd@redhat.com
38
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
25
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
39
---
26
---
40
hw/display/xlnx_dp.c | 15 +++++++++++----
27
target/arm/ptw.c | 8 ++++++++
41
1 file changed, 11 insertions(+), 4 deletions(-)
28
1 file changed, 8 insertions(+)
42
29
43
diff --git a/hw/display/xlnx_dp.c b/hw/display/xlnx_dp.c
30
diff --git a/target/arm/ptw.c b/target/arm/ptw.c
44
index XXXXXXX..XXXXXXX 100644
31
index XXXXXXX..XXXXXXX 100644
45
--- a/hw/display/xlnx_dp.c
32
--- a/target/arm/ptw.c
46
+++ b/hw/display/xlnx_dp.c
33
+++ b/target/arm/ptw.c
47
@@ -XXX,XX +XXX,XX @@ static uint8_t xlnx_dp_aux_pop_rx_fifo(XlnxDPState *s)
34
@@ -XXX,XX +XXX,XX @@ static bool get_phys_addr_lpae(CPUARMState *env, S1Translate *ptw,
48
uint8_t ret;
35
ps = MIN(ps, param.ps);
49
36
assert(ps < ARRAY_SIZE(pamax_map));
50
if (fifo8_is_empty(&s->rx_fifo)) {
37
outputsize = pamax_map[ps];
51
- DPRINTF("rx_fifo underflow..\n");
38
+
52
- abort();
53
+ qemu_log_mask(LOG_GUEST_ERROR,
54
+ "%s: Reading empty RX_FIFO\n",
55
+ __func__);
56
+ /*
39
+ /*
57
+ * The datasheet is not clear about the reset value, it seems
40
+ * With LPA2, the effective output address (OA) size is at most 48 bits
58
+ * to be unspecified. We choose to return '0'.
41
+ * unless TCR.DS == 1
59
+ */
42
+ */
60
+ ret = 0;
43
+ if (!param.ds && param.gran != Gran64K) {
61
+ } else {
44
+ outputsize = MIN(outputsize, 48);
62
+ ret = fifo8_pop(&s->rx_fifo);
45
+ }
63
+ DPRINTF("pop 0x%" PRIX8 " from rx_fifo.\n", ret);
46
} else {
64
}
47
param = aa32_va_parameters(env, address, mmu_idx);
65
- ret = fifo8_pop(&s->rx_fifo);
48
level = 1;
66
- DPRINTF("pop 0x%" PRIX8 " from rx_fifo.\n", ret);
67
return ret;
68
}
69
70
--
49
--
71
2.20.1
50
2.25.1
72
51
73
52
diff view generated by jsdifflib
Deleted patch
1
The ARMv5 architecture didn't specify detailed per-feature ID
2
registers. Now that we're using the MVFR0 register fields to
3
gate the existence of VFP instructions, we need to set up
4
the correct values in the cpu->isar structure so that we still
5
provide an FPU to the guest.
6
1
7
This fixes a regression in the arm926 and arm1026 CPUs, which
8
are the only ones that both have VFP and are ARMv5 or earlier.
9
This regression was introduced by the VFP refactoring, and more
10
specifically by commits 1120827fa182f0e76 and 266bd25c485597c,
11
which accidentally disabled VFP short-vector support and
12
double-precision support on these CPUs.
13
14
Fixes: 1120827fa182f0e
15
Fixes: 266bd25c485597c
16
Fixes: https://bugs.launchpad.net/qemu/+bug/1836192
17
Reported-by: Christophe Lyon <christophe.lyon@linaro.org>
18
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
19
Reviewed-by: Richard Henderson <richard.henderson@linaro.org>
20
Reviewed-by: Alex Bennée <alex.bennee@linaro.org>
21
Tested-by: Christophe Lyon <christophe.lyon@linaro.org>
22
Message-id: 20190711131241.22231-1-peter.maydell@linaro.org
23
---
24
target/arm/cpu.c | 12 ++++++++++++
25
1 file changed, 12 insertions(+)
26
27
diff --git a/target/arm/cpu.c b/target/arm/cpu.c
28
index XXXXXXX..XXXXXXX 100644
29
--- a/target/arm/cpu.c
30
+++ b/target/arm/cpu.c
31
@@ -XXX,XX +XXX,XX @@ static void arm926_initfn(Object *obj)
32
* set the field to indicate Jazelle support within QEMU.
33
*/
34
cpu->isar.id_isar1 = FIELD_DP32(cpu->isar.id_isar1, ID_ISAR1, JAZELLE, 1);
35
+ /*
36
+ * Similarly, we need to set MVFR0 fields to enable double precision
37
+ * and short vector support even though ARMv5 doesn't have this register.
38
+ */
39
+ cpu->isar.mvfr0 = FIELD_DP32(cpu->isar.mvfr0, MVFR0, FPSHVEC, 1);
40
+ cpu->isar.mvfr0 = FIELD_DP32(cpu->isar.mvfr0, MVFR0, FPDP, 1);
41
}
42
43
static void arm946_initfn(Object *obj)
44
@@ -XXX,XX +XXX,XX @@ static void arm1026_initfn(Object *obj)
45
* set the field to indicate Jazelle support within QEMU.
46
*/
47
cpu->isar.id_isar1 = FIELD_DP32(cpu->isar.id_isar1, ID_ISAR1, JAZELLE, 1);
48
+ /*
49
+ * Similarly, we need to set MVFR0 fields to enable double precision
50
+ * and short vector support even though ARMv5 doesn't have this register.
51
+ */
52
+ cpu->isar.mvfr0 = FIELD_DP32(cpu->isar.mvfr0, MVFR0, FPSHVEC, 1);
53
+ cpu->isar.mvfr0 = FIELD_DP32(cpu->isar.mvfr0, MVFR0, FPDP, 1);
54
55
{
56
/* The 1026 had an IFAR at c6,c0,0,1 rather than the ARMv6 c6,c0,0,2 */
57
--
58
2.20.1
59
60
diff view generated by jsdifflib