1
Patches for rc1: nothing major, just some minor bugfixes and
1
The following changes since commit 131c58469f6fb68c89b38fee6aba8bbb20c7f4bf:
2
code cleanups.
3
2
4
-- PMM
3
rust: add --rust-target option for bindgen (2025-02-06 13:51:46 -0500)
5
6
The following changes since commit f7e1914adad8885a5d4c70239ab90d901ed97e9f:
7
8
Merge remote-tracking branch 'remotes/alistair/tags/pull-riscv-to-apply-20201109' into staging (2020-11-10 09:24:56 +0000)
9
4
10
are available in the Git repository at:
5
are available in the Git repository at:
11
6
12
https://git.linaro.org/people/pmaydell/qemu-arm.git tags/pull-target-arm-20201110
7
https://git.linaro.org/people/pmaydell/qemu-arm.git tags/pull-target-arm-20250210
13
8
14
for you to fetch changes up to b6c56c8a9a4064ea783f352f43c5df6231a110fa:
9
for you to fetch changes up to 27a8d899c7a100fd5aa040a8b993bb257687c393:
15
10
16
target/arm/translate-neon.c: Handle VTBL UNDEF case before VFP access check (2020-11-10 11:03:48 +0000)
11
linux-user: Do not define struct sched_attr if libc headers do (2025-02-07 16:09:20 +0000)
17
12
18
----------------------------------------------------------------
13
----------------------------------------------------------------
19
target-arm queue:
14
target-arm queue:
20
* hw/arm/Kconfig: ARM_V7M depends on PTIMER
15
* Deprecate pxa2xx CPUs, iwMMXt emulation, -old-param option
21
* Minor coding style fixes
16
* Drop unused AArch64DecodeTable typedefs
22
* docs: add some notes on the sbsa-ref machine
17
* Minor code cleanups
23
* hw/arm/virt: Remove dependency on Cortex-A15 MPCore peripherals
18
* hw/net/cadence_gem: Fix the mask/compare/disable-mask logic
24
* target/arm: Fix neon VTBL/VTBX for len > 1
19
* linux-user: Do not define struct sched_attr if libc headers do
25
* hw/arm/armsse: Correct expansion MPC interrupt lines
26
* hw/misc/stm32f2xx_syscfg: Remove extraneous IRQ
27
* hw/arm/nseries: Remove invalid/unnecessary n8x0_uart_setup()
28
* hw/arm/musicpal: Don't connect two qemu_irqs directly to the same input
29
* hw/arm/musicpal: Only use qdev_get_gpio_in() when necessary
30
* hw/arm/nseries: Check return value from load_image_targphys()
31
* tests/qtest/npcm7xx_rng-test: count runs properly
32
* target/arm/translate-neon.c: Handle VTBL UNDEF case before VFP access check
33
20
34
----------------------------------------------------------------
21
----------------------------------------------------------------
35
Alex Bennée (1):
22
Andrew Yuan (1):
36
docs: add some notes on the sbsa-ref machine
23
hw/net/cadence_gem: Fix the mask/compare/disable-mask logic
37
24
38
AlexChen (1):
25
Khem Raj (1):
39
ssi: Fix bad printf format specifiers
26
linux-user: Do not define struct sched_attr if libc headers do
40
27
41
Andrew Jones (1):
28
Peter Maydell (4):
42
hw/arm/Kconfig: ARM_V7M depends on PTIMER
29
target/arm: deprecate the pxa2xx CPUs and iwMMXt emulation
43
30
tests/tcg/arm: Remove test-arm-iwmmxt test
44
Havard Skinnemoen (1):
31
target/arm: Drop unused AArch64DecodeTable typedefs
45
tests/qtest/npcm7xx_rng-test: count runs properly
32
qemu-options: Deprecate -old-param command line option
46
47
Peter Maydell (2):
48
hw/arm/nseries: Check return value from load_image_targphys()
49
target/arm/translate-neon.c: Handle VTBL UNDEF case before VFP access check
50
33
51
Philippe Mathieu-Daudé (6):
34
Philippe Mathieu-Daudé (6):
52
hw/arm/virt: Remove dependency on Cortex-A15 MPCore peripherals
35
hw/arm/boot: Propagate vCPU to arm_load_dtb()
53
hw/arm/armsse: Correct expansion MPC interrupt lines
36
hw/arm/fsl-imx6: Add local 'mpcore/gic' variables
54
hw/misc/stm32f2xx_syscfg: Remove extraneous IRQ
37
hw/arm/fsl-imx6ul: Add local 'mpcore/gic' variables
55
hw/arm/nseries: Remove invalid/unnecessary n8x0_uart_setup()
38
hw/arm/fsl-imx7: Add local 'mpcore/gic' variables
56
hw/arm/musicpal: Don't connect two qemu_irqs directly to the same input
39
hw/cpu/arm: Alias 'num-cpu' property on TYPE_REALVIEW_MPCORE
57
hw/arm/musicpal: Only use qdev_get_gpio_in() when necessary
40
hw/cpu/arm: Declare CPU QOM types using DEFINE_TYPES() macro
58
41
59
Richard Henderson (1):
42
docs/about/deprecated.rst | 34 ++++++++++++++++++++++
60
target/arm: Fix neon VTBL/VTBX for len > 1
43
include/hw/arm/boot.h | 4 ++-
44
target/arm/cpu.h | 1 +
45
hw/arm/boot.c | 11 +++----
46
hw/arm/fsl-imx6.c | 52 ++++++++++++++-------------------
47
hw/arm/fsl-imx6ul.c | 64 +++++++++++++++++------------------------
48
hw/arm/fsl-imx7.c | 52 +++++++++++++++------------------
49
hw/arm/virt.c | 2 +-
50
hw/cpu/a15mpcore.c | 21 ++++++--------
51
hw/cpu/a9mpcore.c | 21 ++++++--------
52
hw/cpu/arm11mpcore.c | 21 ++++++--------
53
hw/cpu/realview_mpcore.c | 29 +++++++------------
54
hw/net/cadence_gem.c | 26 +++++++++++++----
55
linux-user/syscall.c | 4 ++-
56
system/vl.c | 1 +
57
target/arm/cpu.c | 3 ++
58
target/arm/tcg/cpu32.c | 36 +++++++++++++++--------
59
target/arm/tcg/translate-a64.c | 11 -------
60
tests/tcg/arm/Makefile.target | 7 -----
61
tests/tcg/arm/README | 5 ----
62
tests/tcg/arm/test-arm-iwmmxt.S | 49 -------------------------------
63
21 files changed, 205 insertions(+), 249 deletions(-)
64
delete mode 100644 tests/tcg/arm/test-arm-iwmmxt.S
61
65
62
Xinhao Zhang (3):
63
target/arm: add spaces around operator
64
target/arm: Don't use '#' flag of printf format
65
target/arm: add space before the open parenthesis '('
66
67
docs/system/arm/sbsa.rst | 32 ++++++++++++++++++++++
68
docs/system/target-arm.rst | 1 +
69
include/hw/misc/stm32f2xx_syscfg.h | 2 --
70
target/arm/helper.h | 2 +-
71
hw/arm/armsse.c | 3 +-
72
hw/arm/musicpal.c | 40 +++++++++++++++++----------
73
hw/arm/nseries.c | 26 ++++++++----------
74
hw/arm/stm32f205_soc.c | 1 -
75
hw/misc/stm32f2xx_syscfg.c | 2 --
76
hw/ssi/imx_spi.c | 2 +-
77
hw/ssi/xilinx_spi.c | 2 +-
78
target/arm/arch_dump.c | 8 +++---
79
target/arm/arm-semi.c | 8 +++---
80
target/arm/helper.c | 2 +-
81
target/arm/op_helper.c | 23 +++++++++-------
82
target/arm/translate-a64.c | 4 +--
83
target/arm/translate.c | 2 +-
84
tests/qtest/npcm7xx_rng-test.c | 2 +-
85
hw/arm/Kconfig | 3 +-
86
target/arm/translate-neon.c.inc | 56 ++++++++++++++------------------------
87
20 files changed, 123 insertions(+), 98 deletions(-)
88
create mode 100644 docs/system/arm/sbsa.rst
89
diff view generated by jsdifflib
Deleted patch
1
From: Andrew Jones <drjones@redhat.com>
2
1
3
commit 32bd322a0134 ("hw/timer/armv7m_systick: Rewrite to use ptimers")
4
changed armv7m_systick to build on ptimers. Make sure we have ptimers
5
in the build when building armv7m_systick.
6
7
Signed-off-by: Andrew Jones <drjones@redhat.com>
8
Reviewed-by: Philippe Mathieu-Daudé <philmd@redhat.com>
9
Message-id: 20201104103343.30392-1-drjones@redhat.com
10
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
11
---
12
hw/arm/Kconfig | 1 +
13
1 file changed, 1 insertion(+)
14
15
diff --git a/hw/arm/Kconfig b/hw/arm/Kconfig
16
index XXXXXXX..XXXXXXX 100644
17
--- a/hw/arm/Kconfig
18
+++ b/hw/arm/Kconfig
19
@@ -XXX,XX +XXX,XX @@ config ZYNQ
20
21
config ARM_V7M
22
bool
23
+ select PTIMER
24
25
config ALLWINNER_A10
26
bool
27
--
28
2.20.1
29
30
diff view generated by jsdifflib
1
From: Havard Skinnemoen <hskinnemoen@google.com>
1
The pxa2xx CPUs are now only useful with user-mode emulation, because
2
we dropped all the machine types that used them in 9.2. (Technically
3
you could alse use "-cpu pxa270" with a board model like versatilepb
4
which doesn't sanity-check the CPU type, but that has never been a
5
supported config.)
2
6
3
The number of runs is equal to the number of 0-1 and 1-0 transitions,
7
To use them (or iwMMXt emulation) with QEMU user-mode you would need
4
plus one. Currently, it's counting the number of times these transitions
8
to explicitly select them with the -cpu option or the QEMU_CPU
5
do _not_ happen, plus one.
9
environment variable. A google search finds no examples of anybody
10
doing this in the last decade; I don't believe the GCC folks are
11
using QEMU to test their iwMMXt codegen either. In fact, GCC is in
12
the process of dropping support for iwMMXT entirely.
6
13
7
Source:
14
The iwMMXt emulation is thousands of lines of code in QEMU, and
8
https://nvlpubs.nist.gov/nistpubs/Legacy/SP/nistspecialpublication800-22r1a.pdf
15
is now the only bit of Arm insn decode which doesn't use decodetree.
9
section 2.3.4 point (3).
16
We have no way to test or validate changes to it. This code is
17
just dead weight that is almost certainly not being used by anybody.
18
Mark it as deprecated.
10
19
11
Signed-off-by: Havard Skinnemoen <hskinnemoen@google.com>
12
Message-id: 20201103011457.2959989-2-hskinnemoen@google.com
13
Reviewed-by: Peter Maydell <peter.maydell@linaro.org>
14
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
20
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
21
Reviewed-by: Richard Henderson <richard.henderson@linaro.org>
22
Reviewed-by: Philippe Mathieu-Daudé <philmd@linaro.org>
23
Message-id: 20250127112715.2936555-2-peter.maydell@linaro.org
15
---
24
---
16
tests/qtest/npcm7xx_rng-test.c | 2 +-
25
docs/about/deprecated.rst | 21 +++++++++++++++++++++
17
1 file changed, 1 insertion(+), 1 deletion(-)
26
target/arm/cpu.h | 1 +
27
target/arm/cpu.c | 3 +++
28
target/arm/tcg/cpu32.c | 36 ++++++++++++++++++++++++------------
29
4 files changed, 49 insertions(+), 12 deletions(-)
18
30
19
diff --git a/tests/qtest/npcm7xx_rng-test.c b/tests/qtest/npcm7xx_rng-test.c
31
diff --git a/docs/about/deprecated.rst b/docs/about/deprecated.rst
20
index XXXXXXX..XXXXXXX 100644
32
index XXXXXXX..XXXXXXX 100644
21
--- a/tests/qtest/npcm7xx_rng-test.c
33
--- a/docs/about/deprecated.rst
22
+++ b/tests/qtest/npcm7xx_rng-test.c
34
+++ b/docs/about/deprecated.rst
23
@@ -XXX,XX +XXX,XX @@ static double calc_runs_p(const unsigned long *buf, unsigned int nr_bits)
35
@@ -XXX,XX +XXX,XX @@ is going to be so much slower it wouldn't make sense for any serious
24
pi = (double)nr_ones / nr_bits;
36
instrumentation. Due to implementation differences there will also be
25
37
anomalies in things like memory instrumentation.
26
for (k = 0; k < nr_bits - 1; k++) {
38
27
- vn_obs += !(test_bit(k, buf) ^ test_bit(k + 1, buf));
39
+linux-user mode CPUs
28
+ vn_obs += (test_bit(k, buf) ^ test_bit(k + 1, buf));
40
+--------------------
29
}
41
+
30
vn_obs += 1;
42
+iwMMXt emulation and the ``pxa`` CPUs (since 10.0)
31
43
+''''''''''''''''''''''''''''''''''''''''''''''''''
44
+
45
+The ``pxa`` CPU family (``pxa250``, ``pxa255``, ``pxa260``,
46
+``pxa261``, ``pxa262``, ``pxa270-a0``, ``pxa270-a1``, ``pxa270``,
47
+``pxa270-b0``, ``pxa270-b1``, ``pxa270-c0``, ``pxa270-c5``) are no
48
+longer used in system emulation, because all the machine types which
49
+used these CPUs were removed in the QEMU 9.2 release. These CPUs can
50
+now only be used in linux-user mode, and to do that you would have to
51
+explicitly select one of these CPUs with the ``-cpu`` command line
52
+option or the ``QEMU_CPU`` environment variable.
53
+
54
+We don't believe that anybody is using the iwMMXt emulation, and we do
55
+not have any tests to validate it or any real hardware or similar
56
+known-good implementation to test against. GCC is in the process of
57
+dropping their support for iwMMXt codegen. These CPU types are
58
+therefore deprecated in QEMU, and will be removed in a future release.
59
+
60
System emulator CPUs
61
--------------------
62
63
diff --git a/target/arm/cpu.h b/target/arm/cpu.h
64
index XXXXXXX..XXXXXXX 100644
65
--- a/target/arm/cpu.h
66
+++ b/target/arm/cpu.h
67
@@ -XXX,XX +XXX,XX @@ struct ArchCPU {
68
69
typedef struct ARMCPUInfo {
70
const char *name;
71
+ const char *deprecation_note;
72
void (*initfn)(Object *obj);
73
void (*class_init)(ObjectClass *oc, void *data);
74
} ARMCPUInfo;
75
diff --git a/target/arm/cpu.c b/target/arm/cpu.c
76
index XXXXXXX..XXXXXXX 100644
77
--- a/target/arm/cpu.c
78
+++ b/target/arm/cpu.c
79
@@ -XXX,XX +XXX,XX @@ static void cpu_register_class_init(ObjectClass *oc, void *data)
80
81
acc->info = data;
82
cc->gdb_core_xml_file = "arm-core.xml";
83
+ if (acc->info->deprecation_note) {
84
+ cc->deprecation_note = acc->info->deprecation_note;
85
+ }
86
}
87
88
void arm_cpu_register(const ARMCPUInfo *info)
89
diff --git a/target/arm/tcg/cpu32.c b/target/arm/tcg/cpu32.c
90
index XXXXXXX..XXXXXXX 100644
91
--- a/target/arm/tcg/cpu32.c
92
+++ b/target/arm/tcg/cpu32.c
93
@@ -XXX,XX +XXX,XX @@ static const ARMCPUInfo arm_tcg_cpus[] = {
94
{ .name = "ti925t", .initfn = ti925t_initfn },
95
{ .name = "sa1100", .initfn = sa1100_initfn },
96
{ .name = "sa1110", .initfn = sa1110_initfn },
97
- { .name = "pxa250", .initfn = pxa250_initfn },
98
- { .name = "pxa255", .initfn = pxa255_initfn },
99
- { .name = "pxa260", .initfn = pxa260_initfn },
100
- { .name = "pxa261", .initfn = pxa261_initfn },
101
- { .name = "pxa262", .initfn = pxa262_initfn },
102
+ { .name = "pxa250", .initfn = pxa250_initfn,
103
+ .deprecation_note = "iwMMXt CPUs are no longer supported", },
104
+ { .name = "pxa255", .initfn = pxa255_initfn,
105
+ .deprecation_note = "iwMMXt CPUs are no longer supported", },
106
+ { .name = "pxa260", .initfn = pxa260_initfn,
107
+ .deprecation_note = "iwMMXt CPUs are no longer supported", },
108
+ { .name = "pxa261", .initfn = pxa261_initfn,
109
+ .deprecation_note = "iwMMXt CPUs are no longer supported", },
110
+ { .name = "pxa262", .initfn = pxa262_initfn,
111
+ .deprecation_note = "iwMMXt CPUs are no longer supported", },
112
/* "pxa270" is an alias for "pxa270-a0" */
113
- { .name = "pxa270", .initfn = pxa270a0_initfn },
114
- { .name = "pxa270-a0", .initfn = pxa270a0_initfn },
115
- { .name = "pxa270-a1", .initfn = pxa270a1_initfn },
116
- { .name = "pxa270-b0", .initfn = pxa270b0_initfn },
117
- { .name = "pxa270-b1", .initfn = pxa270b1_initfn },
118
- { .name = "pxa270-c0", .initfn = pxa270c0_initfn },
119
- { .name = "pxa270-c5", .initfn = pxa270c5_initfn },
120
+ { .name = "pxa270", .initfn = pxa270a0_initfn,
121
+ .deprecation_note = "iwMMXt CPUs are no longer supported", },
122
+ { .name = "pxa270-a0", .initfn = pxa270a0_initfn,
123
+ .deprecation_note = "iwMMXt CPUs are no longer supported", },
124
+ { .name = "pxa270-a1", .initfn = pxa270a1_initfn,
125
+ .deprecation_note = "iwMMXt CPUs are no longer supported", },
126
+ { .name = "pxa270-b0", .initfn = pxa270b0_initfn,
127
+ .deprecation_note = "iwMMXt CPUs are no longer supported", },
128
+ { .name = "pxa270-b1", .initfn = pxa270b1_initfn,
129
+ .deprecation_note = "iwMMXt CPUs are no longer supported", },
130
+ { .name = "pxa270-c0", .initfn = pxa270c0_initfn,
131
+ .deprecation_note = "iwMMXt CPUs are no longer supported", },
132
+ { .name = "pxa270-c5", .initfn = pxa270c5_initfn,
133
+ .deprecation_note = "iwMMXt CPUs are no longer supported", },
134
#ifndef TARGET_AARCH64
135
{ .name = "max", .initfn = arm_max_initfn },
136
#endif
32
--
137
--
33
2.20.1
138
2.34.1
34
139
35
140
diff view generated by jsdifflib
1
Checks for UNDEF cases should go before the "is VFP enabled?" access
1
The test-arm-iwmmmxt test isn't testing what it thinks it's testing.
2
check, except in special cases. Move a stray UNDEF check in the VTBL
2
3
trans function up above the access check.
3
If you run it with a CPU type that supports iwMMXt then it will crash
4
immediately with a SIGILL, because (even with -marm) GCC will link it
5
against startup code that is in Thumb mode, and no iwMMXt CPU has
6
Thumb:
7
8
00010338 <_start>:
9
10338: f04f 0b00 mov.w fp, #0
10
1033c: f04f 0e00 mov.w lr, #0
11
12
If you run it with a CPU type which does *not* support iwMMXt, which
13
is what 'make check-tcg' does, then QEMU will not try to handle the
14
insns as iwMMXt. Instead the translator turns them into illegal
15
instructions. Then in the linux-user cpu_loop() code we identify
16
them as FPA11 instructions inside emulate_arm_fpa11(), because the
17
FPA11 happened to use the same coprocessor number as these iwMMXt
18
insns. So we execute a completely different set of FPA11 insns,
19
which means we don't crash, but we will print garbage to stdout.
20
Then the test binary always exits with a 0 return code, so 'make
21
check-tcg' thinks the test passes.
22
23
Modern gnueabihf toolchains assume in their startup code that the CPU
24
is not so old as to not support Thumb, so there's no way to get them
25
to generate a binary that actually does what the test wants. Since
26
we're deprecating iwMMXt emulation anyway, it's not worth trying to
27
salvage the test case to get it to really test the iwMMXt insns.
28
29
Delete the test entirely.
4
30
5
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
31
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
6
Reviewed-by: Richard Henderson <richard.henderson@linaro.org>
32
Reviewed-by: Richard Henderson <richard.henderson@linaro.org>
7
Message-id: 20201109145324.2859-1-peter.maydell@linaro.org
33
Reviewed-by: Philippe Mathieu-Daudé <philmd@linaro.org>
34
Message-id: 20250127112715.2936555-3-peter.maydell@linaro.org
8
---
35
---
9
target/arm/translate-neon.c.inc | 8 ++++----
36
tests/tcg/arm/Makefile.target | 7 -----
10
1 file changed, 4 insertions(+), 4 deletions(-)
37
tests/tcg/arm/README | 5 ----
38
tests/tcg/arm/test-arm-iwmmxt.S | 49 ---------------------------------
39
3 files changed, 61 deletions(-)
40
delete mode 100644 tests/tcg/arm/test-arm-iwmmxt.S
11
41
12
diff --git a/target/arm/translate-neon.c.inc b/target/arm/translate-neon.c.inc
42
diff --git a/tests/tcg/arm/Makefile.target b/tests/tcg/arm/Makefile.target
13
index XXXXXXX..XXXXXXX 100644
43
index XXXXXXX..XXXXXXX 100644
14
--- a/target/arm/translate-neon.c.inc
44
--- a/tests/tcg/arm/Makefile.target
15
+++ b/target/arm/translate-neon.c.inc
45
+++ b/tests/tcg/arm/Makefile.target
16
@@ -XXX,XX +XXX,XX @@ static bool trans_VTBL(DisasContext *s, arg_VTBL *a)
46
@@ -XXX,XX +XXX,XX @@ ARM_TESTS = hello-arm
17
return false;
47
hello-arm: CFLAGS+=-marm -ffreestanding -fno-stack-protector
18
}
48
hello-arm: LDFLAGS+=-nostdlib
19
49
20
- if (!vfp_access_check(s)) {
50
-# IWMXT floating point extensions
21
- return true;
51
-ARM_TESTS += test-arm-iwmmxt
22
- }
52
-# Clang assembler does not support IWMXT, so use the external assembler.
53
-test-arm-iwmmxt: CFLAGS += -marm -march=iwmmxt -mabi=aapcs -mfpu=fpv4-sp-d16 $(CROSS_CC_HAS_FNIA)
54
-test-arm-iwmmxt: test-arm-iwmmxt.S
55
-    $(CC) $(CFLAGS) -Wa,--noexecstack $< -o $@ $(LDFLAGS)
23
-
56
-
24
if ((a->vn + a->len + 1) > 32) {
57
# Float-convert Tests
25
/*
58
ARM_TESTS += fcvt
26
* This is UNPREDICTABLE; we choose to UNDEF to avoid the
59
fcvt: LDFLAGS += -lm
27
@@ -XXX,XX +XXX,XX @@ static bool trans_VTBL(DisasContext *s, arg_VTBL *a)
60
diff --git a/tests/tcg/arm/README b/tests/tcg/arm/README
28
return false;
61
index XXXXXXX..XXXXXXX 100644
29
}
62
--- a/tests/tcg/arm/README
30
63
+++ b/tests/tcg/arm/README
31
+ if (!vfp_access_check(s)) {
64
@@ -XXX,XX +XXX,XX @@ hello-arm
32
+ return true;
65
---------
33
+ }
66
34
+
67
A very simple inline assembly, write syscall based hello world
35
desc = tcg_const_i32((a->vn << 2) | a->len);
68
-
36
def = tcg_temp_new_i64();
69
-test-arm-iwmmxt
37
if (a->op) {
70
----------------
71
-
72
-A simple test case for older iwmmxt extended ARMs
73
diff --git a/tests/tcg/arm/test-arm-iwmmxt.S b/tests/tcg/arm/test-arm-iwmmxt.S
74
deleted file mode 100644
75
index XXXXXXX..XXXXXXX
76
--- a/tests/tcg/arm/test-arm-iwmmxt.S
77
+++ /dev/null
78
@@ -XXX,XX +XXX,XX @@
79
-@ Checks whether iwMMXt is functional.
80
-.code    32
81
-.globl    main
82
-
83
-main:
84
-ldr    r0, =data0
85
-ldr    r1, =data1
86
-ldr    r2, =data2
87
-#ifndef FPA
88
-wldrd    wr0, [r0, #0]
89
-wldrd    wr1, [r0, #8]
90
-wldrd    wr2, [r1, #0]
91
-wldrd    wr3, [r1, #8]
92
-wsubb    wr2, wr2, wr0
93
-wsubb    wr3, wr3, wr1
94
-wldrd    wr0, [r2, #0]
95
-wldrd    wr1, [r2, #8]
96
-waddb    wr0, wr0, wr2
97
-waddb    wr1, wr1, wr3
98
-wstrd    wr0, [r2, #0]
99
-wstrd    wr1, [r2, #8]
100
-#else
101
-ldfe    f0, [r0, #0]
102
-ldfe    f1, [r0, #8]
103
-ldfe    f2, [r1, #0]
104
-ldfe    f3, [r1, #8]
105
-adfdp    f2, f2, f0
106
-adfdp    f3, f3, f1
107
-ldfe    f0, [r2, #0]
108
-ldfe    f1, [r2, #8]
109
-adfd    f0, f0, f2
110
-adfd    f1, f1, f3
111
-stfe    f0, [r2, #0]
112
-stfe    f1, [r2, #8]
113
-#endif
114
-mov    r0, #1
115
-mov    r1, r2
116
-mov    r2, #0x11
117
-swi    #0x900004
118
-mov    r0, #0
119
-swi    #0x900001
120
-
121
-.data
122
-data0:
123
-.string    "aaaabbbbccccdddd"
124
-data1:
125
-.string    "bbbbccccddddeeee"
126
-data2:
127
-.string    "hvLLWs\x1fsdrs9\x1fNJ-\n"
38
--
128
--
39
2.20.1
129
2.34.1
40
130
41
131
diff view generated by jsdifflib
1
The nseries machines have a codepath that allows them to load a
1
We removed the old table-based decoder in favour of decodetree, but
2
secondary bootloader. This code wasn't checking that the
2
we left a couple of typedefs that are now unused; delete them.
3
load_image_targphys() succeeded. Check the return value and report
4
the error to the user.
5
3
6
While we're in the vicinity, fix the comment style of the
4
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
7
comment documenting what this image load is doing.
5
Reviewed-by: Richard Henderson <richard.henderson@linaro.org>
6
Message-id: 20250128135046.4108775-1-peter.maydell@linaro.org
7
---
8
target/arm/tcg/translate-a64.c | 11 -----------
9
1 file changed, 11 deletions(-)
8
10
9
Fixes: Coverity CID 1192904
11
diff --git a/target/arm/tcg/translate-a64.c b/target/arm/tcg/translate-a64.c
10
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
11
Reviewed-by: Philippe Mathieu-Daudé <f4bug@amsat.org>
12
Message-id: 20201103114918.11807-1-peter.maydell@linaro.org
13
---
14
hw/arm/nseries.c | 15 +++++++++++----
15
1 file changed, 11 insertions(+), 4 deletions(-)
16
17
diff --git a/hw/arm/nseries.c b/hw/arm/nseries.c
18
index XXXXXXX..XXXXXXX 100644
12
index XXXXXXX..XXXXXXX 100644
19
--- a/hw/arm/nseries.c
13
--- a/target/arm/tcg/translate-a64.c
20
+++ b/hw/arm/nseries.c
14
+++ b/target/arm/tcg/translate-a64.c
21
@@ -XXX,XX +XXX,XX @@ static void n8x0_init(MachineState *machine,
15
@@ -XXX,XX +XXX,XX @@ static int scale_by_log2_tag_granule(DisasContext *s, int x)
22
/* No, wait, better start at the ROM. */
16
#include "decode-sme-fa64.c.inc"
23
s->mpu->cpu->env.regs[15] = OMAP2_Q2_BASE + 0x400000;
17
#include "decode-a64.c.inc"
24
18
25
- /* This is intended for loading the `secondary.bin' program from
19
-/* Table based decoder typedefs - used when the relevant bits for decode
26
+ /*
20
- * are too awkwardly scattered across the instruction (eg SIMD).
27
+ * This is intended for loading the `secondary.bin' program from
21
- */
28
* Nokia images (the NOLO bootloader). The entry point seems
22
-typedef void AArch64DecodeFn(DisasContext *s, uint32_t insn);
29
* to be at OMAP2_Q2_BASE + 0x400000.
23
-
30
*
24
-typedef struct AArch64DecodeTable {
31
@@ -XXX,XX +XXX,XX @@ static void n8x0_init(MachineState *machine,
25
- uint32_t pattern;
32
* for them the entry point needs to be set to OMAP2_SRAM_BASE.
26
- uint32_t mask;
33
*
27
- AArch64DecodeFn *disas_fn;
34
* The code above is for loading the `zImage' file from Nokia
28
-} AArch64DecodeTable;
35
- * images. */
29
-
36
- load_image_targphys(option_rom[0].name, OMAP2_Q2_BASE + 0x400000,
30
/* initialize TCG globals. */
37
- machine->ram_size - 0x400000);
31
void a64_translate_init(void)
38
+ * images.
32
{
39
+ */
40
+ if (load_image_targphys(option_rom[0].name,
41
+ OMAP2_Q2_BASE + 0x400000,
42
+ machine->ram_size - 0x400000) < 0) {
43
+ error_report("Failed to load secondary bootloader %s",
44
+ option_rom[0].name);
45
+ exit(EXIT_FAILURE);
46
+ }
47
48
n800_setup_nolo_tags(nolo_tags);
49
cpu_physical_memory_write(OMAP2_SRAM_BASE, nolo_tags, 0x10000);
50
--
33
--
51
2.20.1
34
2.34.1
52
53
diff view generated by jsdifflib
1
From: Richard Henderson <richard.henderson@linaro.org>
1
From: Philippe Mathieu-Daudé <philmd@linaro.org>
2
2
3
The helper function did not get updated when we reorganized
3
In heterogeneous setup the first vCPU might not be
4
the vector register file for SVE. Since then, the neon dregs
4
the one expected, better pass it explicitly.
5
are non-sequential and cannot be simply indexed.
6
5
7
At the same time, make the helper function operate on 64-bit
6
Signed-off-by: Philippe Mathieu-Daudé <philmd@linaro.org>
8
quantities so that we do not have to call it twice.
7
Reviewed-by: Cédric Le Goater <clg@kaod.org>
9
8
Message-id: 20250130112615.3219-2-philmd@linaro.org
10
Fixes: c39c2b9043e
11
Reported-by: Ard Biesheuvel <ardb@kernel.org>
12
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
13
[PMM: use aa32_vfp_dreg() rather than opencoding]
14
Message-id: 20201105171126.88014-1-richard.henderson@linaro.org
15
Reviewed-by: Peter Maydell <peter.maydell@linaro.org>
16
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
9
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
17
---
10
---
18
target/arm/helper.h | 2 +-
11
include/hw/arm/boot.h | 4 +++-
19
target/arm/op_helper.c | 23 +++++++++--------
12
hw/arm/boot.c | 11 ++++++-----
20
target/arm/translate-neon.c.inc | 44 +++++++++++----------------------
13
hw/arm/virt.c | 2 +-
21
3 files changed, 29 insertions(+), 40 deletions(-)
14
3 files changed, 10 insertions(+), 7 deletions(-)
22
15
23
diff --git a/target/arm/helper.h b/target/arm/helper.h
16
diff --git a/include/hw/arm/boot.h b/include/hw/arm/boot.h
24
index XXXXXXX..XXXXXXX 100644
17
index XXXXXXX..XXXXXXX 100644
25
--- a/target/arm/helper.h
18
--- a/include/hw/arm/boot.h
26
+++ b/target/arm/helper.h
19
+++ b/include/hw/arm/boot.h
27
@@ -XXX,XX +XXX,XX @@ DEF_HELPER_FLAGS_2(rsqrte_f32, TCG_CALL_NO_RWG, f32, f32, ptr)
20
@@ -XXX,XX +XXX,XX @@ AddressSpace *arm_boot_address_space(ARMCPU *cpu,
28
DEF_HELPER_FLAGS_2(rsqrte_f64, TCG_CALL_NO_RWG, f64, f64, ptr)
21
* @binfo: struct describing the boot environment
29
DEF_HELPER_FLAGS_1(recpe_u32, TCG_CALL_NO_RWG, i32, i32)
22
* @addr_limit: upper limit of the available memory area at @addr
30
DEF_HELPER_FLAGS_1(rsqrte_u32, TCG_CALL_NO_RWG, i32, i32)
23
* @as: address space to load image to
31
-DEF_HELPER_FLAGS_4(neon_tbl, TCG_CALL_NO_RWG, i32, i32, i32, ptr, i32)
24
+ * @cpu: ARM CPU object
32
+DEF_HELPER_FLAGS_4(neon_tbl, TCG_CALL_NO_RWG, i64, env, i32, i64, i64)
25
*
33
26
* Load a device tree supplied by the machine or by the user with the
34
DEF_HELPER_3(shl_cc, i32, env, i32, i32)
27
* '-dtb' command line option, and put it at offset @addr in target
35
DEF_HELPER_3(shr_cc, i32, env, i32, i32)
28
@@ -XXX,XX +XXX,XX @@ AddressSpace *arm_boot_address_space(ARMCPU *cpu,
36
diff --git a/target/arm/op_helper.c b/target/arm/op_helper.c
29
* Note: Must not be called unless have_dtb(binfo) is true.
30
*/
31
int arm_load_dtb(hwaddr addr, const struct arm_boot_info *binfo,
32
- hwaddr addr_limit, AddressSpace *as, MachineState *ms);
33
+ hwaddr addr_limit, AddressSpace *as, MachineState *ms,
34
+ ARMCPU *cpu);
35
36
/* Write a secure board setup routine with a dummy handler for SMCs */
37
void arm_write_secure_board_setup_dummy_smc(ARMCPU *cpu,
38
diff --git a/hw/arm/boot.c b/hw/arm/boot.c
37
index XXXXXXX..XXXXXXX 100644
39
index XXXXXXX..XXXXXXX 100644
38
--- a/target/arm/op_helper.c
40
--- a/hw/arm/boot.c
39
+++ b/target/arm/op_helper.c
41
+++ b/hw/arm/boot.c
40
@@ -XXX,XX +XXX,XX @@ void raise_exception_ra(CPUARMState *env, uint32_t excp, uint32_t syndrome,
42
@@ -XXX,XX +XXX,XX @@ out:
41
cpu_loop_exit_restore(cs, ra);
43
return ret;
42
}
44
}
43
45
44
-uint32_t HELPER(neon_tbl)(uint32_t ireg, uint32_t def, void *vn,
46
-static void fdt_add_psci_node(void *fdt)
45
- uint32_t maxindex)
47
+static void fdt_add_psci_node(void *fdt, ARMCPU *armcpu)
46
+uint64_t HELPER(neon_tbl)(CPUARMState *env, uint32_t desc,
47
+ uint64_t ireg, uint64_t def)
48
{
48
{
49
- uint32_t val, shift;
49
uint32_t cpu_suspend_fn;
50
- uint64_t *table = vn;
50
uint32_t cpu_off_fn;
51
+ uint64_t tmp, val = 0;
51
uint32_t cpu_on_fn;
52
+ uint32_t maxindex = ((desc & 3) + 1) * 8;
52
uint32_t migrate_fn;
53
+ uint32_t base_reg = desc >> 2;
53
- ARMCPU *armcpu = ARM_CPU(qemu_get_cpu(0));
54
+ uint32_t shift, index, reg;
54
const char *psci_method;
55
55
int64_t psci_conduit;
56
- val = 0;
56
int rc;
57
- for (shift = 0; shift < 32; shift += 8) {
57
@@ -XXX,XX +XXX,XX @@ static void fdt_add_psci_node(void *fdt)
58
- uint32_t index = (ireg >> shift) & 0xff;
58
}
59
+ for (shift = 0; shift < 64; shift += 8) {
59
60
+ index = (ireg >> shift) & 0xff;
60
int arm_load_dtb(hwaddr addr, const struct arm_boot_info *binfo,
61
if (index < maxindex) {
61
- hwaddr addr_limit, AddressSpace *as, MachineState *ms)
62
- uint32_t tmp = (table[index >> 3] >> ((index & 7) << 3)) & 0xff;
62
+ hwaddr addr_limit, AddressSpace *as, MachineState *ms,
63
- val |= tmp << shift;
63
+ ARMCPU *cpu)
64
+ reg = base_reg + (index >> 3);
64
{
65
+ tmp = *aa32_vfp_dreg(env, reg);
65
void *fdt = NULL;
66
+ tmp = ((tmp >> ((index & 7) << 3)) & 0xff) << shift;
66
int size, rc, n = 0;
67
} else {
67
@@ -XXX,XX +XXX,XX @@ int arm_load_dtb(hwaddr addr, const struct arm_boot_info *binfo,
68
- val |= def & (0xff << shift);
69
+ tmp = def & (0xffull << shift);
70
}
68
}
71
+ val |= tmp;
72
}
69
}
73
return val;
70
74
}
71
- fdt_add_psci_node(fdt);
75
diff --git a/target/arm/translate-neon.c.inc b/target/arm/translate-neon.c.inc
72
+ fdt_add_psci_node(fdt, cpu);
73
74
if (binfo->modify_dtb) {
75
binfo->modify_dtb(binfo, fdt);
76
@@ -XXX,XX +XXX,XX @@ void arm_load_kernel(ARMCPU *cpu, MachineState *ms, struct arm_boot_info *info)
77
* decided whether to enable PSCI and set the psci-conduit CPU properties.
78
*/
79
if (!info->skip_dtb_autoload && have_dtb(info)) {
80
- if (arm_load_dtb(info->dtb_start, info, info->dtb_limit, as, ms) < 0) {
81
+ if (arm_load_dtb(info->dtb_start, info, info->dtb_limit,
82
+ as, ms, cpu) < 0) {
83
exit(1);
84
}
85
}
86
diff --git a/hw/arm/virt.c b/hw/arm/virt.c
76
index XXXXXXX..XXXXXXX 100644
87
index XXXXXXX..XXXXXXX 100644
77
--- a/target/arm/translate-neon.c.inc
88
--- a/hw/arm/virt.c
78
+++ b/target/arm/translate-neon.c.inc
89
+++ b/hw/arm/virt.c
79
@@ -XXX,XX +XXX,XX @@ static bool trans_VEXT(DisasContext *s, arg_VEXT *a)
90
@@ -XXX,XX +XXX,XX @@ void virt_machine_done(Notifier *notifier, void *data)
80
91
vms->memmap[VIRT_PLATFORM_BUS].size,
81
static bool trans_VTBL(DisasContext *s, arg_VTBL *a)
92
vms->irqmap[VIRT_PLATFORM_BUS]);
82
{
83
- int n;
84
- TCGv_i32 tmp, tmp2, tmp3, tmp4;
85
- TCGv_ptr ptr1;
86
+ TCGv_i64 val, def;
87
+ TCGv_i32 desc;
88
89
if (!arm_dc_feature(s, ARM_FEATURE_NEON)) {
90
return false;
91
@@ -XXX,XX +XXX,XX @@ static bool trans_VTBL(DisasContext *s, arg_VTBL *a)
92
return true;
93
}
93
}
94
94
- if (arm_load_dtb(info->dtb_start, info, info->dtb_limit, as, ms) < 0) {
95
- n = a->len + 1;
95
+ if (arm_load_dtb(info->dtb_start, info, info->dtb_limit, as, ms, cpu) < 0) {
96
- if ((a->vn + n) > 32) {
96
exit(1);
97
+ if ((a->vn + a->len + 1) > 32) {
98
/*
99
* This is UNPREDICTABLE; we choose to UNDEF to avoid the
100
* helper function running off the end of the register file.
101
*/
102
return false;
103
}
97
}
104
- n <<= 3;
105
- tmp = tcg_temp_new_i32();
106
- if (a->op) {
107
- read_neon_element32(tmp, a->vd, 0, MO_32);
108
- } else {
109
- tcg_gen_movi_i32(tmp, 0);
110
- }
111
- tmp2 = tcg_temp_new_i32();
112
- read_neon_element32(tmp2, a->vm, 0, MO_32);
113
- ptr1 = vfp_reg_ptr(true, a->vn);
114
- tmp4 = tcg_const_i32(n);
115
- gen_helper_neon_tbl(tmp2, tmp2, tmp, ptr1, tmp4);
116
117
+ desc = tcg_const_i32((a->vn << 2) | a->len);
118
+ def = tcg_temp_new_i64();
119
if (a->op) {
120
- read_neon_element32(tmp, a->vd, 1, MO_32);
121
+ read_neon_element64(def, a->vd, 0, MO_64);
122
} else {
123
- tcg_gen_movi_i32(tmp, 0);
124
+ tcg_gen_movi_i64(def, 0);
125
}
126
- tmp3 = tcg_temp_new_i32();
127
- read_neon_element32(tmp3, a->vm, 1, MO_32);
128
- gen_helper_neon_tbl(tmp3, tmp3, tmp, ptr1, tmp4);
129
- tcg_temp_free_i32(tmp);
130
- tcg_temp_free_i32(tmp4);
131
- tcg_temp_free_ptr(ptr1);
132
+ val = tcg_temp_new_i64();
133
+ read_neon_element64(val, a->vm, 0, MO_64);
134
135
- write_neon_element32(tmp2, a->vd, 0, MO_32);
136
- write_neon_element32(tmp3, a->vd, 1, MO_32);
137
- tcg_temp_free_i32(tmp2);
138
- tcg_temp_free_i32(tmp3);
139
+ gen_helper_neon_tbl(val, cpu_env, desc, val, def);
140
+ write_neon_element64(val, a->vd, 0, MO_64);
141
+
142
+ tcg_temp_free_i64(def);
143
+ tcg_temp_free_i64(val);
144
+ tcg_temp_free_i32(desc);
145
return true;
146
}
147
98
148
--
99
--
149
2.20.1
100
2.34.1
150
101
151
102
diff view generated by jsdifflib
1
From: Philippe Mathieu-Daudé <f4bug@amsat.org>
1
From: Philippe Mathieu-Daudé <philmd@linaro.org>
2
2
3
We don't need to fill the full pic[] array if we only use
3
The A9MPCore forward the IRQs from its internal GIC.
4
few of the interrupt lines. Directly call qdev_get_gpio_in()
4
To make the code clearer, add the 'mpcore' and 'gic'
5
when necessary.
5
variables.
6
6
7
Signed-off-by: Philippe Mathieu-Daudé <f4bug@amsat.org>
7
Reviewed-by: Cédric Le Goater <clg@kaod.org>
8
Message-id: 20201107193403.436146-6-f4bug@amsat.org
8
Signed-off-by: Philippe Mathieu-Daudé <philmd@linaro.org>
9
Reviewed-by: Peter Maydell <peter.maydell@linaro.org>
9
Message-id: 20250130112615.3219-3-philmd@linaro.org
10
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
10
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
11
---
11
---
12
hw/arm/musicpal.c | 25 +++++++++++++------------
12
hw/arm/fsl-imx6.c | 52 +++++++++++++++++++----------------------------
13
1 file changed, 13 insertions(+), 12 deletions(-)
13
1 file changed, 21 insertions(+), 31 deletions(-)
14
14
15
diff --git a/hw/arm/musicpal.c b/hw/arm/musicpal.c
15
diff --git a/hw/arm/fsl-imx6.c b/hw/arm/fsl-imx6.c
16
index XXXXXXX..XXXXXXX 100644
16
index XXXXXXX..XXXXXXX 100644
17
--- a/hw/arm/musicpal.c
17
--- a/hw/arm/fsl-imx6.c
18
+++ b/hw/arm/musicpal.c
18
+++ b/hw/arm/fsl-imx6.c
19
@@ -XXX,XX +XXX,XX @@ static struct arm_boot_info musicpal_binfo = {
19
@@ -XXX,XX +XXX,XX @@ static void fsl_imx6_realize(DeviceState *dev, Error **errp)
20
static void musicpal_init(MachineState *machine)
20
uint16_t i;
21
{
21
qemu_irq irq;
22
ARMCPU *cpu;
22
unsigned int smp_cpus = ms->smp.cpus;
23
- qemu_irq pic[32];
23
+ DeviceState *mpcore = DEVICE(&s->a9mpcore);
24
DeviceState *dev;
24
+ DeviceState *gic;
25
+ DeviceState *pic;
25
26
DeviceState *uart_orgate;
26
if (smp_cpus > FSL_IMX6_NUM_CPUS) {
27
DeviceState *i2c_dev;
27
error_setg(errp, "%s: Only %d CPUs are supported (%d requested)",
28
DeviceState *lcd_dev;
28
@@ -XXX,XX +XXX,XX @@ static void fsl_imx6_realize(DeviceState *dev, Error **errp)
29
@@ -XXX,XX +XXX,XX @@ static void musicpal_init(MachineState *machine)
29
}
30
&error_fatal);
30
}
31
memory_region_add_subregion(address_space_mem, MP_SRAM_BASE, sram);
31
32
32
- object_property_set_int(OBJECT(&s->a9mpcore), "num-cpu", smp_cpus,
33
- dev = sysbus_create_simple(TYPE_MV88W8618_PIC, MP_PIC_BASE,
33
- &error_abort);
34
+ pic = sysbus_create_simple(TYPE_MV88W8618_PIC, MP_PIC_BASE,
34
+ object_property_set_int(OBJECT(mpcore), "num-cpu", smp_cpus, &error_abort);
35
qdev_get_gpio_in(DEVICE(cpu), ARM_CPU_IRQ));
35
36
- for (i = 0; i < 32; i++) {
36
- object_property_set_int(OBJECT(&s->a9mpcore), "num-irq",
37
- pic[i] = qdev_get_gpio_in(dev, i);
37
+ object_property_set_int(OBJECT(mpcore), "num-irq",
38
- }
38
FSL_IMX6_MAX_IRQ + GIC_INTERNAL, &error_abort);
39
- sysbus_create_varargs(TYPE_MV88W8618_PIT, MP_PIT_BASE, pic[MP_TIMER1_IRQ],
39
40
- pic[MP_TIMER2_IRQ], pic[MP_TIMER3_IRQ],
40
- if (!sysbus_realize(SYS_BUS_DEVICE(&s->a9mpcore), errp)) {
41
- pic[MP_TIMER4_IRQ], NULL);
41
+ if (!sysbus_realize(SYS_BUS_DEVICE(mpcore), errp)) {
42
+ sysbus_create_varargs(TYPE_MV88W8618_PIT, MP_PIT_BASE,
42
return;
43
+ qdev_get_gpio_in(pic, MP_TIMER1_IRQ),
43
}
44
+ qdev_get_gpio_in(pic, MP_TIMER2_IRQ),
44
- sysbus_mmio_map(SYS_BUS_DEVICE(&s->a9mpcore), 0, FSL_IMX6_A9MPCORE_ADDR);
45
+ qdev_get_gpio_in(pic, MP_TIMER3_IRQ),
45
+ sysbus_mmio_map(SYS_BUS_DEVICE(mpcore), 0, FSL_IMX6_A9MPCORE_ADDR);
46
+ qdev_get_gpio_in(pic, MP_TIMER4_IRQ), NULL);
46
47
47
+ gic = mpcore;
48
/* Logically OR both UART IRQs together */
48
for (i = 0; i < smp_cpus; i++) {
49
uart_orgate = DEVICE(object_new(TYPE_OR_IRQ));
49
- sysbus_connect_irq(SYS_BUS_DEVICE(&s->a9mpcore), i,
50
object_property_set_int(OBJECT(uart_orgate), "num-lines", 2, &error_fatal);
50
+ sysbus_connect_irq(SYS_BUS_DEVICE(gic), i,
51
qdev_realize_and_unref(uart_orgate, NULL, &error_fatal);
51
qdev_get_gpio_in(DEVICE(&s->cpu[i]), ARM_CPU_IRQ));
52
- qdev_connect_gpio_out(DEVICE(uart_orgate), 0, pic[MP_UART_SHARED_IRQ]);
52
- sysbus_connect_irq(SYS_BUS_DEVICE(&s->a9mpcore), i + smp_cpus,
53
+ qdev_connect_gpio_out(DEVICE(uart_orgate), 0,
53
+ sysbus_connect_irq(SYS_BUS_DEVICE(gic), i + smp_cpus,
54
+ qdev_get_gpio_in(pic, MP_UART_SHARED_IRQ));
54
qdev_get_gpio_in(DEVICE(&s->cpu[i]), ARM_CPU_FIQ));
55
55
}
56
serial_mm_init(address_space_mem, MP_UART1_BASE, 2,
56
57
qdev_get_gpio_in(uart_orgate, 0),
57
@@ -XXX,XX +XXX,XX @@ static void fsl_imx6_realize(DeviceState *dev, Error **errp)
58
@@ -XXX,XX +XXX,XX @@ static void musicpal_init(MachineState *machine)
58
59
OBJECT(get_system_memory()), &error_fatal);
59
sysbus_mmio_map(SYS_BUS_DEVICE(&s->uart[i]), 0, serial_table[i].addr);
60
sysbus_realize_and_unref(SYS_BUS_DEVICE(dev), &error_fatal);
60
sysbus_connect_irq(SYS_BUS_DEVICE(&s->uart[i]), 0,
61
sysbus_mmio_map(SYS_BUS_DEVICE(dev), 0, MP_ETH_BASE);
61
- qdev_get_gpio_in(DEVICE(&s->a9mpcore),
62
- sysbus_connect_irq(SYS_BUS_DEVICE(dev), 0, pic[MP_ETH_IRQ]);
62
- serial_table[i].irq));
63
+ sysbus_connect_irq(SYS_BUS_DEVICE(dev), 0,
63
+ qdev_get_gpio_in(gic, serial_table[i].irq));
64
+ qdev_get_gpio_in(pic, MP_ETH_IRQ));
64
}
65
65
66
sysbus_create_simple("mv88w8618_wlan", MP_WLAN_BASE, NULL);
66
s->gpt.ccm = IMX_CCM(&s->ccm);
67
67
@@ -XXX,XX +XXX,XX @@ static void fsl_imx6_realize(DeviceState *dev, Error **errp)
68
sysbus_create_simple(TYPE_MUSICPAL_MISC, MP_MISC_BASE, NULL);
68
69
69
sysbus_mmio_map(SYS_BUS_DEVICE(&s->gpt), 0, FSL_IMX6_GPT_ADDR);
70
dev = sysbus_create_simple(TYPE_MUSICPAL_GPIO, MP_GPIO_BASE,
70
sysbus_connect_irq(SYS_BUS_DEVICE(&s->gpt), 0,
71
- pic[MP_GPIO_IRQ]);
71
- qdev_get_gpio_in(DEVICE(&s->a9mpcore),
72
+ qdev_get_gpio_in(pic, MP_GPIO_IRQ));
72
- FSL_IMX6_GPT_IRQ));
73
i2c_dev = sysbus_create_simple("gpio_i2c", -1, NULL);
73
+ qdev_get_gpio_in(gic, FSL_IMX6_GPT_IRQ));
74
i2c = (I2CBus *)qdev_get_child_bus(i2c_dev, "i2c");
74
75
75
/* Initialize all EPIT timers */
76
@@ -XXX,XX +XXX,XX @@ static void musicpal_init(MachineState *machine)
76
for (i = 0; i < FSL_IMX6_NUM_EPITS; i++) {
77
NULL);
77
@@ -XXX,XX +XXX,XX @@ static void fsl_imx6_realize(DeviceState *dev, Error **errp)
78
sysbus_realize_and_unref(s, &error_fatal);
78
79
sysbus_mmio_map(s, 0, MP_AUDIO_BASE);
79
sysbus_mmio_map(SYS_BUS_DEVICE(&s->epit[i]), 0, epit_table[i].addr);
80
- sysbus_connect_irq(s, 0, pic[MP_AUDIO_IRQ]);
80
sysbus_connect_irq(SYS_BUS_DEVICE(&s->epit[i]), 0,
81
+ sysbus_connect_irq(s, 0, qdev_get_gpio_in(pic, MP_AUDIO_IRQ));
81
- qdev_get_gpio_in(DEVICE(&s->a9mpcore),
82
82
- epit_table[i].irq));
83
musicpal_binfo.ram_size = MP_RAM_DEFAULT_SIZE;
83
+ qdev_get_gpio_in(gic, epit_table[i].irq));
84
arm_load_kernel(cpu, machine, &musicpal_binfo);
84
}
85
86
/* Initialize all I2C */
87
@@ -XXX,XX +XXX,XX @@ static void fsl_imx6_realize(DeviceState *dev, Error **errp)
88
89
sysbus_mmio_map(SYS_BUS_DEVICE(&s->i2c[i]), 0, i2c_table[i].addr);
90
sysbus_connect_irq(SYS_BUS_DEVICE(&s->i2c[i]), 0,
91
- qdev_get_gpio_in(DEVICE(&s->a9mpcore),
92
- i2c_table[i].irq));
93
+ qdev_get_gpio_in(gic, i2c_table[i].irq));
94
}
95
96
/* Initialize all GPIOs */
97
@@ -XXX,XX +XXX,XX @@ static void fsl_imx6_realize(DeviceState *dev, Error **errp)
98
99
sysbus_mmio_map(SYS_BUS_DEVICE(&s->gpio[i]), 0, gpio_table[i].addr);
100
sysbus_connect_irq(SYS_BUS_DEVICE(&s->gpio[i]), 0,
101
- qdev_get_gpio_in(DEVICE(&s->a9mpcore),
102
- gpio_table[i].irq_low));
103
+ qdev_get_gpio_in(gic, gpio_table[i].irq_low));
104
sysbus_connect_irq(SYS_BUS_DEVICE(&s->gpio[i]), 1,
105
- qdev_get_gpio_in(DEVICE(&s->a9mpcore),
106
- gpio_table[i].irq_high));
107
+ qdev_get_gpio_in(gic, gpio_table[i].irq_high));
108
}
109
110
/* Initialize all SDHC */
111
@@ -XXX,XX +XXX,XX @@ static void fsl_imx6_realize(DeviceState *dev, Error **errp)
112
}
113
sysbus_mmio_map(SYS_BUS_DEVICE(&s->esdhc[i]), 0, esdhc_table[i].addr);
114
sysbus_connect_irq(SYS_BUS_DEVICE(&s->esdhc[i]), 0,
115
- qdev_get_gpio_in(DEVICE(&s->a9mpcore),
116
- esdhc_table[i].irq));
117
+ qdev_get_gpio_in(gic, esdhc_table[i].irq));
118
}
119
120
/* USB */
121
@@ -XXX,XX +XXX,XX @@ static void fsl_imx6_realize(DeviceState *dev, Error **errp)
122
sysbus_mmio_map(SYS_BUS_DEVICE(&s->usb[i]), 0,
123
FSL_IMX6_USBOH3_USB_ADDR + i * 0x200);
124
sysbus_connect_irq(SYS_BUS_DEVICE(&s->usb[i]), 0,
125
- qdev_get_gpio_in(DEVICE(&s->a9mpcore),
126
- FSL_IMX6_USBn_IRQ[i]));
127
+ qdev_get_gpio_in(gic, FSL_IMX6_USBn_IRQ[i]));
128
}
129
130
/* Initialize all ECSPI */
131
@@ -XXX,XX +XXX,XX @@ static void fsl_imx6_realize(DeviceState *dev, Error **errp)
132
133
sysbus_mmio_map(SYS_BUS_DEVICE(&s->spi[i]), 0, spi_table[i].addr);
134
sysbus_connect_irq(SYS_BUS_DEVICE(&s->spi[i]), 0,
135
- qdev_get_gpio_in(DEVICE(&s->a9mpcore),
136
- spi_table[i].irq));
137
+ qdev_get_gpio_in(gic, spi_table[i].irq));
138
}
139
140
object_property_set_uint(OBJECT(&s->eth), "phy-num", s->phy_num,
141
@@ -XXX,XX +XXX,XX @@ static void fsl_imx6_realize(DeviceState *dev, Error **errp)
142
}
143
sysbus_mmio_map(SYS_BUS_DEVICE(&s->eth), 0, FSL_IMX6_ENET_ADDR);
144
sysbus_connect_irq(SYS_BUS_DEVICE(&s->eth), 0,
145
- qdev_get_gpio_in(DEVICE(&s->a9mpcore),
146
- FSL_IMX6_ENET_MAC_IRQ));
147
+ qdev_get_gpio_in(gic, FSL_IMX6_ENET_MAC_IRQ));
148
sysbus_connect_irq(SYS_BUS_DEVICE(&s->eth), 1,
149
- qdev_get_gpio_in(DEVICE(&s->a9mpcore),
150
- FSL_IMX6_ENET_MAC_1588_IRQ));
151
+ qdev_get_gpio_in(gic, FSL_IMX6_ENET_MAC_1588_IRQ));
152
153
/*
154
* SNVS
155
@@ -XXX,XX +XXX,XX @@ static void fsl_imx6_realize(DeviceState *dev, Error **errp)
156
157
sysbus_mmio_map(SYS_BUS_DEVICE(&s->wdt[i]), 0, FSL_IMX6_WDOGn_ADDR[i]);
158
sysbus_connect_irq(SYS_BUS_DEVICE(&s->wdt[i]), 0,
159
- qdev_get_gpio_in(DEVICE(&s->a9mpcore),
160
- FSL_IMX6_WDOGn_IRQ[i]));
161
+ qdev_get_gpio_in(gic, FSL_IMX6_WDOGn_IRQ[i]));
162
}
163
164
/*
85
--
165
--
86
2.20.1
166
2.34.1
87
167
88
168
diff view generated by jsdifflib
1
From: Xinhao Zhang <zhangxinhao1@huawei.com>
1
From: Philippe Mathieu-Daudé <philmd@linaro.org>
2
2
3
Fix code style. Don't use '#' flag of printf format ('%#') in
3
The A7MPCore forward the IRQs from its internal GIC.
4
format strings, use '0x' prefix instead
4
To make the code clearer, add the 'mpcore' and 'gic'
5
variables. Rename 'd' variable as 'cpu'.
5
6
6
Signed-off-by: Xinhao Zhang <zhangxinhao1@huawei.com>
7
Reviewed-by: Cédric Le Goater <clg@kaod.org>
7
Signed-off-by: Kai Deng <dengkai1@huawei.com>
8
Signed-off-by: Philippe Mathieu-Daudé <philmd@linaro.org>
8
Message-id: 20201103114529.638233-2-zhangxinhao1@huawei.com
9
Message-id: 20250130112615.3219-4-philmd@linaro.org
9
Reviewed-by: Peter Maydell <peter.maydell@linaro.org>
10
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
10
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
11
---
11
---
12
target/arm/translate-a64.c | 4 ++--
12
hw/arm/fsl-imx6ul.c | 64 +++++++++++++++++++--------------------------
13
1 file changed, 2 insertions(+), 2 deletions(-)
13
1 file changed, 27 insertions(+), 37 deletions(-)
14
14
15
diff --git a/target/arm/translate-a64.c b/target/arm/translate-a64.c
15
diff --git a/hw/arm/fsl-imx6ul.c b/hw/arm/fsl-imx6ul.c
16
index XXXXXXX..XXXXXXX 100644
16
index XXXXXXX..XXXXXXX 100644
17
--- a/target/arm/translate-a64.c
17
--- a/hw/arm/fsl-imx6ul.c
18
+++ b/target/arm/translate-a64.c
18
+++ b/hw/arm/fsl-imx6ul.c
19
@@ -XXX,XX +XXX,XX @@ static void disas_simd_three_reg_same_fp16(DisasContext *s, uint32_t insn)
19
@@ -XXX,XX +XXX,XX @@ static void fsl_imx6ul_realize(DeviceState *dev, Error **errp)
20
gen_helper_advsimd_acgt_f16(tcg_res, tcg_op1, tcg_op2, fpst);
20
{
21
break;
21
MachineState *ms = MACHINE(qdev_get_machine());
22
default:
22
FslIMX6ULState *s = FSL_IMX6UL(dev);
23
- fprintf(stderr, "%s: insn %#04x, fpop %#2x @ %#" PRIx64 "\n",
23
+ DeviceState *mpcore = DEVICE(&s->a7mpcore);
24
+ fprintf(stderr, "%s: insn 0x%04x, fpop 0x%2x @ 0x%" PRIx64 "\n",
24
int i;
25
__func__, insn, fpopcode, s->pc_curr);
25
char name[NAME_SIZE];
26
g_assert_not_reached();
26
- SysBusDevice *sbd;
27
}
27
- DeviceState *d;
28
@@ -XXX,XX +XXX,XX @@ static void disas_simd_two_reg_misc_fp16(DisasContext *s, uint32_t insn)
28
+ DeviceState *gic;
29
case 0x7f: /* FSQRT (vector) */
29
+ SysBusDevice *gicsbd;
30
break;
30
+ DeviceState *cpu;
31
default:
31
32
- fprintf(stderr, "%s: insn %#04x fpop %#2x\n", __func__, insn, fpop);
32
if (ms->smp.cpus > 1) {
33
+ fprintf(stderr, "%s: insn 0x%04x fpop 0x%2x\n", __func__, insn, fpop);
33
error_setg(errp, "%s: Only a single CPU is supported (%d requested)",
34
g_assert_not_reached();
34
@@ -XXX,XX +XXX,XX @@ static void fsl_imx6ul_realize(DeviceState *dev, Error **errp)
35
/*
36
* A7MPCORE
37
*/
38
- object_property_set_int(OBJECT(&s->a7mpcore), "num-cpu", 1, &error_abort);
39
- object_property_set_int(OBJECT(&s->a7mpcore), "num-irq",
40
+ object_property_set_int(OBJECT(mpcore), "num-cpu", 1, &error_abort);
41
+ object_property_set_int(OBJECT(mpcore), "num-irq",
42
FSL_IMX6UL_MAX_IRQ + GIC_INTERNAL, &error_abort);
43
- sysbus_realize(SYS_BUS_DEVICE(&s->a7mpcore), &error_abort);
44
- sysbus_mmio_map(SYS_BUS_DEVICE(&s->a7mpcore), 0, FSL_IMX6UL_A7MPCORE_ADDR);
45
+ sysbus_realize(SYS_BUS_DEVICE(mpcore), &error_abort);
46
+ sysbus_mmio_map(SYS_BUS_DEVICE(mpcore), 0, FSL_IMX6UL_A7MPCORE_ADDR);
47
48
- sbd = SYS_BUS_DEVICE(&s->a7mpcore);
49
- d = DEVICE(&s->cpu);
50
-
51
- sysbus_connect_irq(sbd, 0, qdev_get_gpio_in(d, ARM_CPU_IRQ));
52
- sysbus_connect_irq(sbd, 1, qdev_get_gpio_in(d, ARM_CPU_FIQ));
53
- sysbus_connect_irq(sbd, 2, qdev_get_gpio_in(d, ARM_CPU_VIRQ));
54
- sysbus_connect_irq(sbd, 3, qdev_get_gpio_in(d, ARM_CPU_VFIQ));
55
+ gic = mpcore;
56
+ gicsbd = SYS_BUS_DEVICE(gic);
57
+ cpu = DEVICE(&s->cpu);
58
+ sysbus_connect_irq(gicsbd, 0, qdev_get_gpio_in(cpu, ARM_CPU_IRQ));
59
+ sysbus_connect_irq(gicsbd, 1, qdev_get_gpio_in(cpu, ARM_CPU_FIQ));
60
+ sysbus_connect_irq(gicsbd, 2, qdev_get_gpio_in(cpu, ARM_CPU_VIRQ));
61
+ sysbus_connect_irq(gicsbd, 3, qdev_get_gpio_in(cpu, ARM_CPU_VFIQ));
62
63
/*
64
* A7MPCORE DAP
65
@@ -XXX,XX +XXX,XX @@ static void fsl_imx6ul_realize(DeviceState *dev, Error **errp)
66
FSL_IMX6UL_GPTn_ADDR[i]);
67
68
sysbus_connect_irq(SYS_BUS_DEVICE(&s->gpt[i]), 0,
69
- qdev_get_gpio_in(DEVICE(&s->a7mpcore),
70
- FSL_IMX6UL_GPTn_IRQ[i]));
71
+ qdev_get_gpio_in(gic, FSL_IMX6UL_GPTn_IRQ[i]));
35
}
72
}
36
73
74
/*
75
@@ -XXX,XX +XXX,XX @@ static void fsl_imx6ul_realize(DeviceState *dev, Error **errp)
76
FSL_IMX6UL_EPITn_ADDR[i]);
77
78
sysbus_connect_irq(SYS_BUS_DEVICE(&s->epit[i]), 0,
79
- qdev_get_gpio_in(DEVICE(&s->a7mpcore),
80
- FSL_IMX6UL_EPITn_IRQ[i]));
81
+ qdev_get_gpio_in(gic, FSL_IMX6UL_EPITn_IRQ[i]));
82
}
83
84
/*
85
@@ -XXX,XX +XXX,XX @@ static void fsl_imx6ul_realize(DeviceState *dev, Error **errp)
86
FSL_IMX6UL_GPIOn_ADDR[i]);
87
88
sysbus_connect_irq(SYS_BUS_DEVICE(&s->gpio[i]), 0,
89
- qdev_get_gpio_in(DEVICE(&s->a7mpcore),
90
- FSL_IMX6UL_GPIOn_LOW_IRQ[i]));
91
+ qdev_get_gpio_in(gic, FSL_IMX6UL_GPIOn_LOW_IRQ[i]));
92
93
sysbus_connect_irq(SYS_BUS_DEVICE(&s->gpio[i]), 1,
94
- qdev_get_gpio_in(DEVICE(&s->a7mpcore),
95
- FSL_IMX6UL_GPIOn_HIGH_IRQ[i]));
96
+ qdev_get_gpio_in(gic, FSL_IMX6UL_GPIOn_HIGH_IRQ[i]));
97
}
98
99
/*
100
@@ -XXX,XX +XXX,XX @@ static void fsl_imx6ul_realize(DeviceState *dev, Error **errp)
101
FSL_IMX6UL_SPIn_ADDR[i]);
102
103
sysbus_connect_irq(SYS_BUS_DEVICE(&s->spi[i]), 0,
104
- qdev_get_gpio_in(DEVICE(&s->a7mpcore),
105
- FSL_IMX6UL_SPIn_IRQ[i]));
106
+ qdev_get_gpio_in(gic, FSL_IMX6UL_SPIn_IRQ[i]));
107
}
108
109
/*
110
@@ -XXX,XX +XXX,XX @@ static void fsl_imx6ul_realize(DeviceState *dev, Error **errp)
111
sysbus_mmio_map(SYS_BUS_DEVICE(&s->i2c[i]), 0, FSL_IMX6UL_I2Cn_ADDR[i]);
112
113
sysbus_connect_irq(SYS_BUS_DEVICE(&s->i2c[i]), 0,
114
- qdev_get_gpio_in(DEVICE(&s->a7mpcore),
115
- FSL_IMX6UL_I2Cn_IRQ[i]));
116
+ qdev_get_gpio_in(gic, FSL_IMX6UL_I2Cn_IRQ[i]));
117
}
118
119
/*
120
@@ -XXX,XX +XXX,XX @@ static void fsl_imx6ul_realize(DeviceState *dev, Error **errp)
121
FSL_IMX6UL_UARTn_ADDR[i]);
122
123
sysbus_connect_irq(SYS_BUS_DEVICE(&s->uart[i]), 0,
124
- qdev_get_gpio_in(DEVICE(&s->a7mpcore),
125
- FSL_IMX6UL_UARTn_IRQ[i]));
126
+ qdev_get_gpio_in(gic, FSL_IMX6UL_UARTn_IRQ[i]));
127
}
128
129
/*
130
@@ -XXX,XX +XXX,XX @@ static void fsl_imx6ul_realize(DeviceState *dev, Error **errp)
131
FSL_IMX6UL_ENETn_ADDR[i]);
132
133
sysbus_connect_irq(SYS_BUS_DEVICE(&s->eth[i]), 0,
134
- qdev_get_gpio_in(DEVICE(&s->a7mpcore),
135
- FSL_IMX6UL_ENETn_IRQ[i]));
136
+ qdev_get_gpio_in(gic, FSL_IMX6UL_ENETn_IRQ[i]));
137
138
sysbus_connect_irq(SYS_BUS_DEVICE(&s->eth[i]), 1,
139
- qdev_get_gpio_in(DEVICE(&s->a7mpcore),
140
- FSL_IMX6UL_ENETn_TIMER_IRQ[i]));
141
+ qdev_get_gpio_in(gic, FSL_IMX6UL_ENETn_TIMER_IRQ[i]));
142
}
143
144
/*
145
@@ -XXX,XX +XXX,XX @@ static void fsl_imx6ul_realize(DeviceState *dev, Error **errp)
146
sysbus_mmio_map(SYS_BUS_DEVICE(&s->usb[i]), 0,
147
FSL_IMX6UL_USB02_USBn_ADDR[i]);
148
sysbus_connect_irq(SYS_BUS_DEVICE(&s->usb[i]), 0,
149
- qdev_get_gpio_in(DEVICE(&s->a7mpcore),
150
- FSL_IMX6UL_USBn_IRQ[i]));
151
+ qdev_get_gpio_in(gic, FSL_IMX6UL_USBn_IRQ[i]));
152
}
153
154
/*
155
@@ -XXX,XX +XXX,XX @@ static void fsl_imx6ul_realize(DeviceState *dev, Error **errp)
156
FSL_IMX6UL_USDHCn_ADDR[i]);
157
158
sysbus_connect_irq(SYS_BUS_DEVICE(&s->usdhc[i]), 0,
159
- qdev_get_gpio_in(DEVICE(&s->a7mpcore),
160
- FSL_IMX6UL_USDHCn_IRQ[i]));
161
+ qdev_get_gpio_in(gic, FSL_IMX6UL_USDHCn_IRQ[i]));
162
}
163
164
/*
165
@@ -XXX,XX +XXX,XX @@ static void fsl_imx6ul_realize(DeviceState *dev, Error **errp)
166
sysbus_mmio_map(SYS_BUS_DEVICE(&s->wdt[i]), 0,
167
FSL_IMX6UL_WDOGn_ADDR[i]);
168
sysbus_connect_irq(SYS_BUS_DEVICE(&s->wdt[i]), 0,
169
- qdev_get_gpio_in(DEVICE(&s->a7mpcore),
170
- FSL_IMX6UL_WDOGn_IRQ[i]));
171
+ qdev_get_gpio_in(gic, FSL_IMX6UL_WDOGn_IRQ[i]));
172
}
173
174
/*
37
--
175
--
38
2.20.1
176
2.34.1
39
177
40
178
diff view generated by jsdifflib
1
From: Xinhao Zhang <zhangxinhao1@huawei.com>
1
From: Philippe Mathieu-Daudé <philmd@linaro.org>
2
2
3
Fix code style. Operator needs spaces both sides.
3
The A7MPCore forward the IRQs from its internal GIC.
4
To make the code clearer, add the 'mpcore' and 'gic'
5
variables.
4
6
5
Signed-off-by: Xinhao Zhang <zhangxinhao1@huawei.com>
7
Reviewed-by: Cédric Le Goater <clg@kaod.org>
6
Signed-off-by: Kai Deng <dengkai1@huawei.com>
8
Signed-off-by: Philippe Mathieu-Daudé <philmd@linaro.org>
7
Message-id: 20201103114529.638233-1-zhangxinhao1@huawei.com
9
Message-id: 20250130112615.3219-5-philmd@linaro.org
8
Reviewed-by: Peter Maydell <peter.maydell@linaro.org>
9
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
10
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
10
---
11
---
11
target/arm/arch_dump.c | 8 ++++----
12
hw/arm/fsl-imx7.c | 52 +++++++++++++++++++++--------------------------
12
target/arm/arm-semi.c | 8 ++++----
13
1 file changed, 23 insertions(+), 29 deletions(-)
13
target/arm/helper.c | 2 +-
14
3 files changed, 9 insertions(+), 9 deletions(-)
15
14
16
diff --git a/target/arm/arch_dump.c b/target/arm/arch_dump.c
15
diff --git a/hw/arm/fsl-imx7.c b/hw/arm/fsl-imx7.c
17
index XXXXXXX..XXXXXXX 100644
16
index XXXXXXX..XXXXXXX 100644
18
--- a/target/arm/arch_dump.c
17
--- a/hw/arm/fsl-imx7.c
19
+++ b/target/arm/arch_dump.c
18
+++ b/hw/arm/fsl-imx7.c
20
@@ -XXX,XX +XXX,XX @@ static int aarch64_write_elf64_prfpreg(WriteCoreDumpFunction f,
19
@@ -XXX,XX +XXX,XX @@ static void fsl_imx7_realize(DeviceState *dev, Error **errp)
21
20
{
22
for (i = 0; i < 32; ++i) {
21
MachineState *ms = MACHINE(qdev_get_machine());
23
uint64_t *q = aa64_vfp_qreg(env, i);
22
FslIMX7State *s = FSL_IMX7(dev);
24
- note.vfp.vregs[2*i + 0] = cpu_to_dump64(s, q[0]);
23
- Object *o;
25
- note.vfp.vregs[2*i + 1] = cpu_to_dump64(s, q[1]);
24
+ DeviceState *mpcore = DEVICE(&s->a7mpcore);
26
+ note.vfp.vregs[2 * i + 0] = cpu_to_dump64(s, q[0]);
25
+ DeviceState *gic;
27
+ note.vfp.vregs[2 * i + 1] = cpu_to_dump64(s, q[1]);
26
int i;
27
qemu_irq irq;
28
char name[NAME_SIZE];
29
@@ -XXX,XX +XXX,XX @@ static void fsl_imx7_realize(DeviceState *dev, Error **errp)
30
* CPUs
31
*/
32
for (i = 0; i < smp_cpus; i++) {
33
- o = OBJECT(&s->cpu[i]);
34
+ Object *o = OBJECT(&s->cpu[i]);
35
36
/* On uniprocessor, the CBAR is set to 0 */
37
if (smp_cpus > 1) {
38
@@ -XXX,XX +XXX,XX @@ static void fsl_imx7_realize(DeviceState *dev, Error **errp)
39
/*
40
* A7MPCORE
41
*/
42
- object_property_set_int(OBJECT(&s->a7mpcore), "num-cpu", smp_cpus,
43
- &error_abort);
44
- object_property_set_int(OBJECT(&s->a7mpcore), "num-irq",
45
+ object_property_set_int(OBJECT(mpcore), "num-cpu", smp_cpus, &error_abort);
46
+ object_property_set_int(OBJECT(mpcore), "num-irq",
47
FSL_IMX7_MAX_IRQ + GIC_INTERNAL, &error_abort);
48
+ sysbus_realize(SYS_BUS_DEVICE(mpcore), &error_abort);
49
+ sysbus_mmio_map(SYS_BUS_DEVICE(mpcore), 0, FSL_IMX7_A7MPCORE_ADDR);
50
51
- sysbus_realize(SYS_BUS_DEVICE(&s->a7mpcore), &error_abort);
52
- sysbus_mmio_map(SYS_BUS_DEVICE(&s->a7mpcore), 0, FSL_IMX7_A7MPCORE_ADDR);
53
-
54
+ gic = mpcore;
55
for (i = 0; i < smp_cpus; i++) {
56
- SysBusDevice *sbd = SYS_BUS_DEVICE(&s->a7mpcore);
57
+ SysBusDevice *sbd = SYS_BUS_DEVICE(gic);
58
DeviceState *d = DEVICE(qemu_get_cpu(i));
59
60
irq = qdev_get_gpio_in(d, ARM_CPU_IRQ);
61
@@ -XXX,XX +XXX,XX @@ static void fsl_imx7_realize(DeviceState *dev, Error **errp)
62
sysbus_realize(SYS_BUS_DEVICE(&s->gpt[i]), &error_abort);
63
sysbus_mmio_map(SYS_BUS_DEVICE(&s->gpt[i]), 0, FSL_IMX7_GPTn_ADDR[i]);
64
sysbus_connect_irq(SYS_BUS_DEVICE(&s->gpt[i]), 0,
65
- qdev_get_gpio_in(DEVICE(&s->a7mpcore),
66
- FSL_IMX7_GPTn_IRQ[i]));
67
+ qdev_get_gpio_in(gic, FSL_IMX7_GPTn_IRQ[i]));
28
}
68
}
29
69
30
if (s->dump_info.d_endian == ELFDATA2MSB) {
70
/*
31
@@ -XXX,XX +XXX,XX @@ static int aarch64_write_elf64_prfpreg(WriteCoreDumpFunction f,
71
@@ -XXX,XX +XXX,XX @@ static void fsl_imx7_realize(DeviceState *dev, Error **errp)
32
*/
72
FSL_IMX7_GPIOn_ADDR[i]);
33
for (i = 0; i < 32; ++i) {
73
34
uint64_t tmp = note.vfp.vregs[2*i];
74
sysbus_connect_irq(SYS_BUS_DEVICE(&s->gpio[i]), 0,
35
- note.vfp.vregs[2*i] = note.vfp.vregs[2*i+1];
75
- qdev_get_gpio_in(DEVICE(&s->a7mpcore),
36
- note.vfp.vregs[2*i+1] = tmp;
76
- FSL_IMX7_GPIOn_LOW_IRQ[i]));
37
+ note.vfp.vregs[2 * i] = note.vfp.vregs[2 * i + 1];
77
+ qdev_get_gpio_in(gic, FSL_IMX7_GPIOn_LOW_IRQ[i]));
38
+ note.vfp.vregs[2 * i + 1] = tmp;
78
39
}
79
sysbus_connect_irq(SYS_BUS_DEVICE(&s->gpio[i]), 1,
80
- qdev_get_gpio_in(DEVICE(&s->a7mpcore),
81
- FSL_IMX7_GPIOn_HIGH_IRQ[i]));
82
+ qdev_get_gpio_in(gic, FSL_IMX7_GPIOn_HIGH_IRQ[i]));
40
}
83
}
41
84
42
diff --git a/target/arm/arm-semi.c b/target/arm/arm-semi.c
85
/*
43
index XXXXXXX..XXXXXXX 100644
86
@@ -XXX,XX +XXX,XX @@ static void fsl_imx7_realize(DeviceState *dev, Error **errp)
44
--- a/target/arm/arm-semi.c
87
sysbus_mmio_map(SYS_BUS_DEVICE(&s->spi[i]), 0,
45
+++ b/target/arm/arm-semi.c
88
FSL_IMX7_SPIn_ADDR[i]);
46
@@ -XXX,XX +XXX,XX @@ target_ulong do_arm_semihosting(CPUARMState *env)
89
sysbus_connect_irq(SYS_BUS_DEVICE(&s->spi[i]), 0,
47
if (use_gdb_syscalls()) {
90
- qdev_get_gpio_in(DEVICE(&s->a7mpcore),
48
arm_semi_open_guestfd = guestfd;
91
- FSL_IMX7_SPIn_IRQ[i]));
49
ret = arm_gdb_syscall(cpu, arm_semi_open_cb, "open,%s,%x,1a4", arg0,
92
+ qdev_get_gpio_in(gic, FSL_IMX7_SPIn_IRQ[i]));
50
- (int)arg2+1, gdb_open_modeflags[arg1]);
93
}
51
+ (int)arg2 + 1, gdb_open_modeflags[arg1]);
94
52
} else {
95
/*
53
ret = set_swi_errno(env, open(s, open_modeflags[arg1], 0644));
96
@@ -XXX,XX +XXX,XX @@ static void fsl_imx7_realize(DeviceState *dev, Error **errp)
54
if (ret == (uint32_t)-1) {
97
sysbus_mmio_map(SYS_BUS_DEVICE(&s->i2c[i]), 0, FSL_IMX7_I2Cn_ADDR[i]);
55
@@ -XXX,XX +XXX,XX @@ target_ulong do_arm_semihosting(CPUARMState *env)
98
56
GET_ARG(1);
99
sysbus_connect_irq(SYS_BUS_DEVICE(&s->i2c[i]), 0,
57
if (use_gdb_syscalls()) {
100
- qdev_get_gpio_in(DEVICE(&s->a7mpcore),
58
ret = arm_gdb_syscall(cpu, arm_semi_cb, "unlink,%s",
101
- FSL_IMX7_I2Cn_IRQ[i]));
59
- arg0, (int)arg1+1);
102
+ qdev_get_gpio_in(gic, FSL_IMX7_I2Cn_IRQ[i]));
60
+ arg0, (int)arg1 + 1);
103
}
61
} else {
104
62
s = lock_user_string(arg0);
105
/*
63
if (!s) {
106
@@ -XXX,XX +XXX,XX @@ static void fsl_imx7_realize(DeviceState *dev, Error **errp)
64
@@ -XXX,XX +XXX,XX @@ target_ulong do_arm_semihosting(CPUARMState *env)
107
65
GET_ARG(3);
108
sysbus_mmio_map(SYS_BUS_DEVICE(&s->uart[i]), 0, FSL_IMX7_UARTn_ADDR[i]);
66
if (use_gdb_syscalls()) {
109
67
return arm_gdb_syscall(cpu, arm_semi_cb, "rename,%s,%s",
110
- irq = qdev_get_gpio_in(DEVICE(&s->a7mpcore), FSL_IMX7_UARTn_IRQ[i]);
68
- arg0, (int)arg1+1, arg2, (int)arg3+1);
111
+ irq = qdev_get_gpio_in(gic, FSL_IMX7_UARTn_IRQ[i]);
69
+ arg0, (int)arg1 + 1, arg2, (int)arg3 + 1);
112
sysbus_connect_irq(SYS_BUS_DEVICE(&s->uart[i]), 0, irq);
70
} else {
113
}
71
char *s2;
114
72
s = lock_user_string(arg0);
115
@@ -XXX,XX +XXX,XX @@ static void fsl_imx7_realize(DeviceState *dev, Error **errp)
73
@@ -XXX,XX +XXX,XX @@ target_ulong do_arm_semihosting(CPUARMState *env)
116
74
GET_ARG(1);
117
sysbus_mmio_map(SYS_BUS_DEVICE(&s->eth[i]), 0, FSL_IMX7_ENETn_ADDR[i]);
75
if (use_gdb_syscalls()) {
118
76
return arm_gdb_syscall(cpu, arm_semi_cb, "system,%s",
119
- irq = qdev_get_gpio_in(DEVICE(&s->a7mpcore), FSL_IMX7_ENET_IRQ(i, 0));
77
- arg0, (int)arg1+1);
120
+ irq = qdev_get_gpio_in(gic, FSL_IMX7_ENET_IRQ(i, 0));
78
+ arg0, (int)arg1 + 1);
121
sysbus_connect_irq(SYS_BUS_DEVICE(&s->eth[i]), 0, irq);
79
} else {
122
- irq = qdev_get_gpio_in(DEVICE(&s->a7mpcore), FSL_IMX7_ENET_IRQ(i, 3));
80
s = lock_user_string(arg0);
123
+ irq = qdev_get_gpio_in(gic, FSL_IMX7_ENET_IRQ(i, 3));
81
if (!s) {
124
sysbus_connect_irq(SYS_BUS_DEVICE(&s->eth[i]), 1, irq);
82
diff --git a/target/arm/helper.c b/target/arm/helper.c
125
}
83
index XXXXXXX..XXXXXXX 100644
126
84
--- a/target/arm/helper.c
127
@@ -XXX,XX +XXX,XX @@ static void fsl_imx7_realize(DeviceState *dev, Error **errp)
85
+++ b/target/arm/helper.c
128
sysbus_mmio_map(SYS_BUS_DEVICE(&s->usdhc[i]), 0,
86
@@ -XXX,XX +XXX,XX @@ uint32_t HELPER(usad8)(uint32_t a, uint32_t b)
129
FSL_IMX7_USDHCn_ADDR[i]);
87
uint32_t sum;
130
88
sum = do_usad(a, b);
131
- irq = qdev_get_gpio_in(DEVICE(&s->a7mpcore), FSL_IMX7_USDHCn_IRQ[i]);
89
sum += do_usad(a >> 8, b >> 8);
132
+ irq = qdev_get_gpio_in(gic, FSL_IMX7_USDHCn_IRQ[i]);
90
- sum += do_usad(a >> 16, b >>16);
133
sysbus_connect_irq(SYS_BUS_DEVICE(&s->usdhc[i]), 0, irq);
91
+ sum += do_usad(a >> 16, b >> 16);
134
}
92
sum += do_usad(a >> 24, b >> 24);
135
93
return sum;
136
@@ -XXX,XX +XXX,XX @@ static void fsl_imx7_realize(DeviceState *dev, Error **errp)
94
}
137
138
sysbus_mmio_map(SYS_BUS_DEVICE(&s->wdt[i]), 0, FSL_IMX7_WDOGn_ADDR[i]);
139
sysbus_connect_irq(SYS_BUS_DEVICE(&s->wdt[i]), 0,
140
- qdev_get_gpio_in(DEVICE(&s->a7mpcore),
141
- FSL_IMX7_WDOGn_IRQ[i]));
142
+ qdev_get_gpio_in(gic, FSL_IMX7_WDOGn_IRQ[i]));
143
}
144
145
/*
146
@@ -XXX,XX +XXX,XX @@ static void fsl_imx7_realize(DeviceState *dev, Error **errp)
147
irq = qdev_get_gpio_in(DEVICE(&s->a7mpcore), FSL_IMX7_PCI_INTD_MSI_IRQ);
148
qdev_connect_gpio_out(DEVICE(&s->pcie4_msi_irq), 0, irq);
149
150
- irq = qdev_get_gpio_in(DEVICE(&s->a7mpcore), FSL_IMX7_PCI_INTA_IRQ);
151
+ irq = qdev_get_gpio_in(gic, FSL_IMX7_PCI_INTA_IRQ);
152
sysbus_connect_irq(SYS_BUS_DEVICE(&s->pcie), 0, irq);
153
- irq = qdev_get_gpio_in(DEVICE(&s->a7mpcore), FSL_IMX7_PCI_INTB_IRQ);
154
+ irq = qdev_get_gpio_in(gic, FSL_IMX7_PCI_INTB_IRQ);
155
sysbus_connect_irq(SYS_BUS_DEVICE(&s->pcie), 1, irq);
156
- irq = qdev_get_gpio_in(DEVICE(&s->a7mpcore), FSL_IMX7_PCI_INTC_IRQ);
157
+ irq = qdev_get_gpio_in(gic, FSL_IMX7_PCI_INTC_IRQ);
158
sysbus_connect_irq(SYS_BUS_DEVICE(&s->pcie), 2, irq);
159
irq = qdev_get_gpio_in(DEVICE(&s->pcie4_msi_irq), 0);
160
sysbus_connect_irq(SYS_BUS_DEVICE(&s->pcie), 3, irq);
161
@@ -XXX,XX +XXX,XX @@ static void fsl_imx7_realize(DeviceState *dev, Error **errp)
162
sysbus_mmio_map(SYS_BUS_DEVICE(&s->usb[i]), 0,
163
FSL_IMX7_USBn_ADDR[i]);
164
165
- irq = qdev_get_gpio_in(DEVICE(&s->a7mpcore), FSL_IMX7_USBn_IRQ[i]);
166
+ irq = qdev_get_gpio_in(gic, FSL_IMX7_USBn_IRQ[i]);
167
sysbus_connect_irq(SYS_BUS_DEVICE(&s->usb[i]), 0, irq);
168
169
snprintf(name, NAME_SIZE, "usbmisc%d", i);
95
--
170
--
96
2.20.1
171
2.34.1
97
172
98
173
diff view generated by jsdifflib
1
From: AlexChen <alex.chen@huawei.com>
1
From: Philippe Mathieu-Daudé <philmd@linaro.org>
2
2
3
We should use printf format specifier "%u" instead of "%d" for
3
No need to duplicate and forward the 'num-cpu' property from
4
argument of type "unsigned int".
4
TYPE_ARM11MPCORE_PRIV to TYPE_REALVIEW_MPCORE, alias it with
5
QOM object_property_add_alias().
5
6
6
Reported-by: Euler Robot <euler.robot@huawei.com>
7
Signed-off-by: Philippe Mathieu-Daudé <philmd@linaro.org>
7
Signed-off-by: Alex Chen <alex.chen@huawei.com>
8
Reviewed-by: Cédric Le Goater <clg@kaod.org>
8
Reviewed-by: Alistair Francis <alistair.francis@wdc.com>
9
Message-id: 20250130112615.3219-6-philmd@linaro.org
9
Message-id: 5FA280F5.8060902@huawei.com
10
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
10
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
11
---
11
---
12
hw/ssi/imx_spi.c | 2 +-
12
hw/cpu/realview_mpcore.c | 8 +-------
13
hw/ssi/xilinx_spi.c | 2 +-
13
1 file changed, 1 insertion(+), 7 deletions(-)
14
2 files changed, 2 insertions(+), 2 deletions(-)
15
14
16
diff --git a/hw/ssi/imx_spi.c b/hw/ssi/imx_spi.c
15
diff --git a/hw/cpu/realview_mpcore.c b/hw/cpu/realview_mpcore.c
17
index XXXXXXX..XXXXXXX 100644
16
index XXXXXXX..XXXXXXX 100644
18
--- a/hw/ssi/imx_spi.c
17
--- a/hw/cpu/realview_mpcore.c
19
+++ b/hw/ssi/imx_spi.c
18
+++ b/hw/cpu/realview_mpcore.c
20
@@ -XXX,XX +XXX,XX @@ static const char *imx_spi_reg_name(uint32_t reg)
19
@@ -XXX,XX +XXX,XX @@
21
case ECSPI_MSGDATA:
20
#include "hw/cpu/arm11mpcore.h"
22
return "ECSPI_MSGDATA";
21
#include "hw/intc/realview_gic.h"
23
default:
22
#include "hw/irq.h"
24
- sprintf(unknown, "%d ?", reg);
23
-#include "hw/qdev-properties.h"
25
+ sprintf(unknown, "%u ?", reg);
24
#include "qom/object.h"
26
return unknown;
25
26
#define TYPE_REALVIEW_MPCORE_RIRQ "realview_mpcore"
27
@@ -XXX,XX +XXX,XX @@ static void realview_mpcore_realize(DeviceState *dev, Error **errp)
28
int n;
29
int i;
30
31
- qdev_prop_set_uint32(priv, "num-cpu", s->num_cpu);
32
if (!sysbus_realize(SYS_BUS_DEVICE(&s->priv), errp)) {
33
return;
34
}
35
@@ -XXX,XX +XXX,XX @@ static void mpcore_rirq_init(Object *obj)
36
int i;
37
38
object_initialize_child(obj, "a11priv", &s->priv, TYPE_ARM11MPCORE_PRIV);
39
+ object_property_add_alias(obj, "num-cpu", OBJECT(&s->priv), "num-cpu");
40
privbusdev = SYS_BUS_DEVICE(&s->priv);
41
sysbus_init_mmio(sbd, sysbus_mmio_get_region(privbusdev, 0));
42
43
@@ -XXX,XX +XXX,XX @@ static void mpcore_rirq_init(Object *obj)
27
}
44
}
28
}
45
}
29
diff --git a/hw/ssi/xilinx_spi.c b/hw/ssi/xilinx_spi.c
46
30
index XXXXXXX..XXXXXXX 100644
47
-static const Property mpcore_rirq_properties[] = {
31
--- a/hw/ssi/xilinx_spi.c
48
- DEFINE_PROP_UINT32("num-cpu", mpcore_rirq_state, num_cpu, 1),
32
+++ b/hw/ssi/xilinx_spi.c
49
-};
33
@@ -XXX,XX +XXX,XX @@ static void xlx_spi_update_irq(XilinxSPI *s)
50
-
34
irq chain unless things really changed. */
51
static void mpcore_rirq_class_init(ObjectClass *klass, void *data)
35
if (pending != s->irqline) {
52
{
36
s->irqline = pending;
53
DeviceClass *dc = DEVICE_CLASS(klass);
37
- DB_PRINT("irq_change of state %d ISR:%x IER:%X\n",
54
38
+ DB_PRINT("irq_change of state %u ISR:%x IER:%X\n",
55
dc->realize = realview_mpcore_realize;
39
pending, s->regs[R_IPISR], s->regs[R_IPIER]);
56
- device_class_set_props(dc, mpcore_rirq_properties);
40
qemu_set_irq(s->irq, pending);
57
}
41
}
58
59
static const TypeInfo mpcore_rirq_info = {
42
--
60
--
43
2.20.1
61
2.34.1
44
62
45
63
diff view generated by jsdifflib
Deleted patch
1
From: Xinhao Zhang <zhangxinhao1@huawei.com>
2
1
3
Fix code style. Space required before the open parenthesis '('.
4
5
Signed-off-by: Xinhao Zhang <zhangxinhao1@huawei.com>
6
Signed-off-by: Kai Deng <dengkai1@huawei.com>
7
Message-id: 20201103114529.638233-3-zhangxinhao1@huawei.com
8
Reviewed-by: Peter Maydell <peter.maydell@linaro.org>
9
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
10
---
11
target/arm/translate.c | 2 +-
12
1 file changed, 1 insertion(+), 1 deletion(-)
13
14
diff --git a/target/arm/translate.c b/target/arm/translate.c
15
index XXXXXXX..XXXXXXX 100644
16
--- a/target/arm/translate.c
17
+++ b/target/arm/translate.c
18
@@ -XXX,XX +XXX,XX @@ static void arm_tr_tb_stop(DisasContextBase *dcbase, CPUState *cpu)
19
- Hardware watchpoints.
20
Hardware breakpoints have already been handled and skip this code.
21
*/
22
- switch(dc->base.is_jmp) {
23
+ switch (dc->base.is_jmp) {
24
case DISAS_NEXT:
25
case DISAS_TOO_MANY:
26
gen_goto_tb(dc, 1, dc->base.pc_next);
27
--
28
2.20.1
29
30
diff view generated by jsdifflib
Deleted patch
1
From: Alex Bennée <alex.bennee@linaro.org>
2
1
3
We should at least document what this machine is about.
4
5
Reviewed-by: Graeme Gregory <graeme@nuviainc.com>
6
Signed-off-by: Alex Bennée <alex.bennee@linaro.org>
7
Message-id: 20201104165254.24822-1-alex.bennee@linaro.org
8
Cc: Leif Lindholm <leif@nuviainc.com>
9
Cc: Shashi Mallela <shashi.mallela@linaro.org>
10
Signed-off-by: Alex Bennée <alex.bennee@linaro.org>
11
[PMM: fixed filename mismatch]
12
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
13
---
14
docs/system/arm/sbsa.rst | 32 ++++++++++++++++++++++++++++++++
15
docs/system/target-arm.rst | 1 +
16
2 files changed, 33 insertions(+)
17
create mode 100644 docs/system/arm/sbsa.rst
18
19
diff --git a/docs/system/arm/sbsa.rst b/docs/system/arm/sbsa.rst
20
new file mode 100644
21
index XXXXXXX..XXXXXXX
22
--- /dev/null
23
+++ b/docs/system/arm/sbsa.rst
24
@@ -XXX,XX +XXX,XX @@
25
+Arm Server Base System Architecture Reference board (``sbsa-ref``)
26
+==================================================================
27
+
28
+While the `virt` board is a generic board platform that doesn't match
29
+any real hardware the `sbsa-ref` board intends to look like real
30
+hardware. The `Server Base System Architecture
31
+<https://developer.arm.com/documentation/den0029/latest>` defines a
32
+minimum base line of hardware support and importantly how the firmware
33
+reports that to any operating system. It is a static system that
34
+reports a very minimal DT to the firmware for non-discoverable
35
+information about components affected by the qemu command line (i.e.
36
+cpus and memory). As a result it must have a firmware specifically
37
+built to expect a certain hardware layout (as you would in a real
38
+machine).
39
+
40
+It is intended to be a machine for developing firmware and testing
41
+standards compliance with operating systems.
42
+
43
+Supported devices
44
+"""""""""""""""""
45
+
46
+The sbsa-ref board supports:
47
+
48
+ - A configurable number of AArch64 CPUs
49
+ - GIC version 3
50
+ - System bus AHCI controller
51
+ - System bus EHCI controller
52
+ - CDROM and hard disc on AHCI bus
53
+ - E1000E ethernet card on PCIe bus
54
+ - VGA display adaptor on PCIe bus
55
+ - A generic SBSA watchdog device
56
+
57
diff --git a/docs/system/target-arm.rst b/docs/system/target-arm.rst
58
index XXXXXXX..XXXXXXX 100644
59
--- a/docs/system/target-arm.rst
60
+++ b/docs/system/target-arm.rst
61
@@ -XXX,XX +XXX,XX @@ undocumented; you can get a complete list by running
62
arm/mps2
63
arm/musca
64
arm/realview
65
+ arm/sbsa
66
arm/versatile
67
arm/vexpress
68
arm/aspeed
69
--
70
2.20.1
71
72
diff view generated by jsdifflib
Deleted patch
1
From: Philippe Mathieu-Daudé <philmd@redhat.com>
2
1
3
When using a Cortex-A15, the Virt machine does not use any
4
MPCore peripherals. Remove the dependency.
5
6
Fixes: 7951c7b7c05 ("hw/arm: Express dependencies of the virt machine with Kconfig")
7
Reported-by: Miroslav Rezanina <mrezanin@redhat.com>
8
Signed-off-by: Philippe Mathieu-Daudé <philmd@redhat.com>
9
Message-id: 20201107114852.271922-1-philmd@redhat.com
10
Reviewed-by: Peter Maydell <peter.maydell@linaro.org>
11
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
12
---
13
hw/arm/Kconfig | 1 -
14
1 file changed, 1 deletion(-)
15
16
diff --git a/hw/arm/Kconfig b/hw/arm/Kconfig
17
index XXXXXXX..XXXXXXX 100644
18
--- a/hw/arm/Kconfig
19
+++ b/hw/arm/Kconfig
20
@@ -XXX,XX +XXX,XX @@ config ARM_VIRT
21
imply VFIO_PLATFORM
22
imply VFIO_XGMAC
23
imply TPM_TIS_SYSBUS
24
- select A15MPCORE
25
select ACPI
26
select ARM_SMMUV3
27
select GPIO_KEY
28
--
29
2.20.1
30
31
diff view generated by jsdifflib
1
From: Philippe Mathieu-Daudé <f4bug@amsat.org>
1
From: Philippe Mathieu-Daudé <philmd@linaro.org>
2
2
3
omap2420_mpu_init() introduced in commit 827df9f3c5f ("Add basic
3
When multiple QOM types are registered in the same file,
4
OMAP2 chip support") takes care of creating the 3 UARTs.
4
it is simpler to use the the DEFINE_TYPES() macro. In
5
particular because type array declared with such macro
6
are easier to review.
5
7
6
Then commit 58a26b477e9 ("Emulate a serial bluetooth HCI with H4+
8
Signed-off-by: Philippe Mathieu-Daudé <philmd@linaro.org>
7
extensions and attach to n8x0's UART") added n8x0_uart_setup()
9
Reviewed-by: Cédric Le Goater <clg@kaod.org>
8
which create the UART and connects it to an IRQ output,
10
Message-id: 20250130112615.3219-7-philmd@linaro.org
9
overwritting the existing peripheral and its IRQ connection.
10
This is incorrect.
11
12
Fortunately we don't need to fix this, because commit 6da68df7f9b
13
("hw/arm/nseries: Replace the bluetooth chardev with a "null"
14
chardev") removed the use of this peripheral. We can simply
15
remove the code.
16
17
Signed-off-by: Philippe Mathieu-Daudé <f4bug@amsat.org>
18
Message-id: 20201107193403.436146-4-f4bug@amsat.org
19
Reviewed-by: Peter Maydell <peter.maydell@linaro.org>
20
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
11
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
21
---
12
---
22
hw/arm/nseries.c | 11 -----------
13
hw/cpu/a15mpcore.c | 21 +++++++++------------
23
1 file changed, 11 deletions(-)
14
hw/cpu/a9mpcore.c | 21 +++++++++------------
15
hw/cpu/arm11mpcore.c | 21 +++++++++------------
16
hw/cpu/realview_mpcore.c | 21 +++++++++------------
17
4 files changed, 36 insertions(+), 48 deletions(-)
24
18
25
diff --git a/hw/arm/nseries.c b/hw/arm/nseries.c
19
diff --git a/hw/cpu/a15mpcore.c b/hw/cpu/a15mpcore.c
26
index XXXXXXX..XXXXXXX 100644
20
index XXXXXXX..XXXXXXX 100644
27
--- a/hw/arm/nseries.c
21
--- a/hw/cpu/a15mpcore.c
28
+++ b/hw/arm/nseries.c
22
+++ b/hw/cpu/a15mpcore.c
29
@@ -XXX,XX +XXX,XX @@ static void n8x0_cbus_setup(struct n800_s *s)
23
@@ -XXX,XX +XXX,XX @@ static void a15mp_priv_class_init(ObjectClass *klass, void *data)
30
cbus_attach(cbus, s->tahvo = tahvo_init(tahvo_irq, 1));
24
/* We currently have no saveable state */
31
}
25
}
32
26
33
-static void n8x0_uart_setup(struct n800_s *s)
27
-static const TypeInfo a15mp_priv_info = {
28
- .name = TYPE_A15MPCORE_PRIV,
29
- .parent = TYPE_SYS_BUS_DEVICE,
30
- .instance_size = sizeof(A15MPPrivState),
31
- .instance_init = a15mp_priv_initfn,
32
- .class_init = a15mp_priv_class_init,
33
+static const TypeInfo a15mp_types[] = {
34
+ {
35
+ .name = TYPE_A15MPCORE_PRIV,
36
+ .parent = TYPE_SYS_BUS_DEVICE,
37
+ .instance_size = sizeof(A15MPPrivState),
38
+ .instance_init = a15mp_priv_initfn,
39
+ .class_init = a15mp_priv_class_init,
40
+ },
41
};
42
43
-static void a15mp_register_types(void)
34
-{
44
-{
35
- Chardev *radio = qemu_chr_new("bt-dummy-uart", "null", NULL);
45
- type_register_static(&a15mp_priv_info);
36
- /*
37
- * Note: We used to connect N8X0_BT_RESET_GPIO and N8X0_BT_WKUP_GPIO
38
- * here, but this code has been removed with the bluetooth backend.
39
- */
40
- omap_uart_attach(s->mpu->uart[BT_UART], radio);
41
-}
46
-}
42
-
47
-
43
static void n8x0_usb_setup(struct n800_s *s)
48
-type_init(a15mp_register_types)
44
{
49
+DEFINE_TYPES(a15mp_types)
45
SysBusDevice *dev;
50
diff --git a/hw/cpu/a9mpcore.c b/hw/cpu/a9mpcore.c
46
@@ -XXX,XX +XXX,XX @@ static void n8x0_init(MachineState *machine,
51
index XXXXXXX..XXXXXXX 100644
47
n8x0_spi_setup(s);
52
--- a/hw/cpu/a9mpcore.c
48
n8x0_dss_setup(s);
53
+++ b/hw/cpu/a9mpcore.c
49
n8x0_cbus_setup(s);
54
@@ -XXX,XX +XXX,XX @@ static void a9mp_priv_class_init(ObjectClass *klass, void *data)
50
- n8x0_uart_setup(s);
55
device_class_set_props(dc, a9mp_priv_properties);
51
if (machine_usb(machine)) {
56
}
52
n8x0_usb_setup(s);
57
53
}
58
-static const TypeInfo a9mp_priv_info = {
59
- .name = TYPE_A9MPCORE_PRIV,
60
- .parent = TYPE_SYS_BUS_DEVICE,
61
- .instance_size = sizeof(A9MPPrivState),
62
- .instance_init = a9mp_priv_initfn,
63
- .class_init = a9mp_priv_class_init,
64
+static const TypeInfo a9mp_types[] = {
65
+ {
66
+ .name = TYPE_A9MPCORE_PRIV,
67
+ .parent = TYPE_SYS_BUS_DEVICE,
68
+ .instance_size = sizeof(A9MPPrivState),
69
+ .instance_init = a9mp_priv_initfn,
70
+ .class_init = a9mp_priv_class_init,
71
+ },
72
};
73
74
-static void a9mp_register_types(void)
75
-{
76
- type_register_static(&a9mp_priv_info);
77
-}
78
-
79
-type_init(a9mp_register_types)
80
+DEFINE_TYPES(a9mp_types)
81
diff --git a/hw/cpu/arm11mpcore.c b/hw/cpu/arm11mpcore.c
82
index XXXXXXX..XXXXXXX 100644
83
--- a/hw/cpu/arm11mpcore.c
84
+++ b/hw/cpu/arm11mpcore.c
85
@@ -XXX,XX +XXX,XX @@ static void mpcore_priv_class_init(ObjectClass *klass, void *data)
86
device_class_set_props(dc, mpcore_priv_properties);
87
}
88
89
-static const TypeInfo mpcore_priv_info = {
90
- .name = TYPE_ARM11MPCORE_PRIV,
91
- .parent = TYPE_SYS_BUS_DEVICE,
92
- .instance_size = sizeof(ARM11MPCorePriveState),
93
- .instance_init = mpcore_priv_initfn,
94
- .class_init = mpcore_priv_class_init,
95
+static const TypeInfo arm11mp_types[] = {
96
+ {
97
+ .name = TYPE_ARM11MPCORE_PRIV,
98
+ .parent = TYPE_SYS_BUS_DEVICE,
99
+ .instance_size = sizeof(ARM11MPCorePriveState),
100
+ .instance_init = mpcore_priv_initfn,
101
+ .class_init = mpcore_priv_class_init,
102
+ },
103
};
104
105
-static void arm11mpcore_register_types(void)
106
-{
107
- type_register_static(&mpcore_priv_info);
108
-}
109
-
110
-type_init(arm11mpcore_register_types)
111
+DEFINE_TYPES(arm11mp_types)
112
diff --git a/hw/cpu/realview_mpcore.c b/hw/cpu/realview_mpcore.c
113
index XXXXXXX..XXXXXXX 100644
114
--- a/hw/cpu/realview_mpcore.c
115
+++ b/hw/cpu/realview_mpcore.c
116
@@ -XXX,XX +XXX,XX @@ static void mpcore_rirq_class_init(ObjectClass *klass, void *data)
117
dc->realize = realview_mpcore_realize;
118
}
119
120
-static const TypeInfo mpcore_rirq_info = {
121
- .name = TYPE_REALVIEW_MPCORE_RIRQ,
122
- .parent = TYPE_SYS_BUS_DEVICE,
123
- .instance_size = sizeof(mpcore_rirq_state),
124
- .instance_init = mpcore_rirq_init,
125
- .class_init = mpcore_rirq_class_init,
126
+static const TypeInfo realview_mpcore_types[] = {
127
+ {
128
+ .name = TYPE_REALVIEW_MPCORE_RIRQ,
129
+ .parent = TYPE_SYS_BUS_DEVICE,
130
+ .instance_size = sizeof(mpcore_rirq_state),
131
+ .instance_init = mpcore_rirq_init,
132
+ .class_init = mpcore_rirq_class_init,
133
+ },
134
};
135
136
-static void realview_mpcore_register_types(void)
137
-{
138
- type_register_static(&mpcore_rirq_info);
139
-}
140
-
141
-type_init(realview_mpcore_register_types)
142
+DEFINE_TYPES(realview_mpcore_types)
54
--
143
--
55
2.20.1
144
2.34.1
56
145
57
146
diff view generated by jsdifflib
1
From: Philippe Mathieu-Daudé <f4bug@amsat.org>
1
From: Andrew Yuan <andrew.yuan@jaguarmicro.com>
2
2
3
The MusicPal board code connects both of the IRQ outputs of the UART
3
Our current handling of the mask/compare logic in the Cadence
4
to the same INTC qemu_irq. Connecting two qemu_irqs outputs directly
4
GEM ethernet device is wrong:
5
to the same input is not valid as it produces subtly wrong behaviour
5
(1) we load the same byte twice from rx_buf when
6
(for instance if both the IRQ lines are high, and then one goes
6
creating the compare value
7
low, the INTC input will see this as a high-to-low transition
7
(2) we ignore the DISABLE_MASK flag
8
even though the second IRQ line should still be holding it high).
9
8
10
This kind of wiring needs an explicitly created OR gate; add one.
9
The "Cadence IP for Gigabit Ethernet MAC Part Number: IP7014 IP Rev:
10
R1p12 - Doc Rev: 1.3 User Guide" states that if the DISABLE_MASK bit
11
in type2_compare_x_word_1 is set, the mask_value field in
12
type2_compare_x_word_0 is used as an additional 2 byte Compare Value.
11
13
12
Inspired-by: Peter Maydell <peter.maydell@linaro.org>
14
Correct these bugs:
13
Signed-off-by: Philippe Mathieu-Daudé <f4bug@amsat.org>
15
* in the !disable_mask codepath, use lduw_le_p() so we
14
Message-id: 20201107193403.436146-5-f4bug@amsat.org
16
correctly load a 16-bit value for comparison
17
* in the disable_mask codepath, we load a full 4-byte value
18
from rx_buf for the comparison, set the compare value to
19
the whole of the cr0 register (i.e. the concatenation of
20
the mask and compare fields), and set mask to 0xffffffff
21
to force a 32-bit comparison
22
23
Signed-off-by: Andrew Yuan <andrew.yuan@jaguarmicro.com>
24
Message-id: 20241219061658.805-1-andrew.yuan@jaguarmicro.com
25
Suggested-by: Philippe Mathieu-Daudé <philmd@linaro.org>
26
[PMM: Expand commit message and comment]
15
Reviewed-by: Peter Maydell <peter.maydell@linaro.org>
27
Reviewed-by: Peter Maydell <peter.maydell@linaro.org>
28
Reviewed-by: Edgar E. Iglesias <edgar.iglesias@gmail.com>
16
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
29
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
17
---
30
---
18
hw/arm/musicpal.c | 17 +++++++++++++----
31
hw/net/cadence_gem.c | 26 +++++++++++++++++++++-----
19
hw/arm/Kconfig | 1 +
32
1 file changed, 21 insertions(+), 5 deletions(-)
20
2 files changed, 14 insertions(+), 4 deletions(-)
21
33
22
diff --git a/hw/arm/musicpal.c b/hw/arm/musicpal.c
34
diff --git a/hw/net/cadence_gem.c b/hw/net/cadence_gem.c
23
index XXXXXXX..XXXXXXX 100644
35
index XXXXXXX..XXXXXXX 100644
24
--- a/hw/arm/musicpal.c
36
--- a/hw/net/cadence_gem.c
25
+++ b/hw/arm/musicpal.c
37
+++ b/hw/net/cadence_gem.c
26
@@ -XXX,XX +XXX,XX @@
38
@@ -XXX,XX +XXX,XX @@ static int get_queue_from_screen(CadenceGEMState *s, uint8_t *rxbuf_ptr,
27
#include "ui/console.h"
39
28
#include "hw/i2c/i2c.h"
40
/* Compare A, B, C */
29
#include "hw/irq.h"
41
for (j = 0; j < 3; j++) {
30
+#include "hw/or-irq.h"
42
- uint32_t cr0, cr1, mask, compare;
31
#include "hw/audio/wm8750.h"
43
- uint16_t rx_cmp;
32
#include "sysemu/block-backend.h"
44
+ uint32_t cr0, cr1, mask, compare, disable_mask;
33
#include "sysemu/runstate.h"
45
+ uint32_t rx_cmp;
34
@@ -XXX,XX +XXX,XX @@
46
int offset;
35
#define MP_TIMER4_IRQ 7
47
int cr_idx = extract32(reg, R_SCREENING_TYPE2_REG0_COMPARE_A_SHIFT + j * 6,
36
#define MP_EHCI_IRQ 8
48
R_SCREENING_TYPE2_REG0_COMPARE_A_LENGTH);
37
#define MP_ETH_IRQ 9
49
@@ -XXX,XX +XXX,XX @@ static int get_queue_from_screen(CadenceGEMState *s, uint8_t *rxbuf_ptr,
38
-#define MP_UART1_IRQ 11
50
break;
39
-#define MP_UART2_IRQ 11
51
}
40
+#define MP_UART_SHARED_IRQ 11
52
41
#define MP_GPIO_IRQ 12
53
- rx_cmp = rxbuf_ptr[offset] << 8 | rxbuf_ptr[offset];
42
#define MP_RTC_IRQ 28
54
- mask = FIELD_EX32(cr0, TYPE2_COMPARE_0_WORD_0, MASK_VALUE);
43
#define MP_AUDIO_IRQ 30
55
- compare = FIELD_EX32(cr0, TYPE2_COMPARE_0_WORD_0, COMPARE_VALUE);
44
@@ -XXX,XX +XXX,XX @@ static void musicpal_init(MachineState *machine)
56
+ disable_mask =
45
ARMCPU *cpu;
57
+ FIELD_EX32(cr1, TYPE2_COMPARE_0_WORD_1, DISABLE_MASK);
46
qemu_irq pic[32];
58
+ if (disable_mask) {
47
DeviceState *dev;
59
+ /*
48
+ DeviceState *uart_orgate;
60
+ * If disable_mask is set, mask_value is used as an
49
DeviceState *i2c_dev;
61
+ * additional 2 byte Compare Value; that is equivalent
50
DeviceState *lcd_dev;
62
+ * to using the whole cr0 register as the comparison value.
51
DeviceState *key_dev;
63
+ * Load 32 bits of data from rx_buf, and set mask to
52
@@ -XXX,XX +XXX,XX @@ static void musicpal_init(MachineState *machine)
64
+ * all-ones so we compare all 32 bits.
53
pic[MP_TIMER2_IRQ], pic[MP_TIMER3_IRQ],
65
+ */
54
pic[MP_TIMER4_IRQ], NULL);
66
+ rx_cmp = ldl_le_p(rxbuf_ptr + offset);
55
67
+ mask = 0xFFFFFFFF;
56
- serial_mm_init(address_space_mem, MP_UART1_BASE, 2, pic[MP_UART1_IRQ],
68
+ compare = cr0;
57
+ /* Logically OR both UART IRQs together */
69
+ } else {
58
+ uart_orgate = DEVICE(object_new(TYPE_OR_IRQ));
70
+ rx_cmp = lduw_le_p(rxbuf_ptr + offset);
59
+ object_property_set_int(OBJECT(uart_orgate), "num-lines", 2, &error_fatal);
71
+ mask = FIELD_EX32(cr0, TYPE2_COMPARE_0_WORD_0, MASK_VALUE);
60
+ qdev_realize_and_unref(uart_orgate, NULL, &error_fatal);
72
+ compare =
61
+ qdev_connect_gpio_out(DEVICE(uart_orgate), 0, pic[MP_UART_SHARED_IRQ]);
73
+ FIELD_EX32(cr0, TYPE2_COMPARE_0_WORD_0, COMPARE_VALUE);
62
+
74
+ }
63
+ serial_mm_init(address_space_mem, MP_UART1_BASE, 2,
75
64
+ qdev_get_gpio_in(uart_orgate, 0),
76
if ((rx_cmp & mask) == (compare & mask)) {
65
1825000, serial_hd(0), DEVICE_NATIVE_ENDIAN);
77
matched = true;
66
- serial_mm_init(address_space_mem, MP_UART2_BASE, 2, pic[MP_UART2_IRQ],
67
+ serial_mm_init(address_space_mem, MP_UART2_BASE, 2,
68
+ qdev_get_gpio_in(uart_orgate, 1),
69
1825000, serial_hd(1), DEVICE_NATIVE_ENDIAN);
70
71
/* Register flash */
72
diff --git a/hw/arm/Kconfig b/hw/arm/Kconfig
73
index XXXXXXX..XXXXXXX 100644
74
--- a/hw/arm/Kconfig
75
+++ b/hw/arm/Kconfig
76
@@ -XXX,XX +XXX,XX @@ config MUSCA
77
78
config MUSICPAL
79
bool
80
+ select OR_IRQ
81
select BITBANG_I2C
82
select MARVELL_88W8618
83
select PTIMER
84
--
78
--
85
2.20.1
79
2.34.1
86
80
87
81
diff view generated by jsdifflib
1
From: Philippe Mathieu-Daudé <f4bug@amsat.org>
1
The '-old-param' command line option is specific to Arm targets; it
2
is very briefly documented as "old param mode". What this option
3
actually does is change the behaviour when directly booting a guest
4
kernel, so that command line arguments are passed to the kernel using
5
the extremely old "param_struct" ABI, rather than the newer ATAGS or
6
even newer DTB mechanisms.
2
7
3
The system configuration controller (SYSCFG) doesn't have
8
This support was added back in 2007 to support an old vendor kernel
4
any output IRQ (and the INTC input #71 belongs to the UART6).
9
on the akita/terrier board types:
5
Remove the invalid code.
10
https://mail.gnu.org/archive/html/qemu-devel/2007-07/msg00344.html
11
Even then, it was an out-of-date mechanism from the kernel's
12
point of view -- the kernel has had a comment since 2001 marking
13
it as deprecated. As of mid-2024, the kernel only retained
14
param_struct support for the RiscPC and Footbridge platforms:
15
https://lore.kernel.org/linux-arm-kernel/2831c5a6-cfbf-4fe0-b51c-0396e5b0aeb7@app.fastmail.com/
6
16
7
Fixes: db635521a02 ("stm32f205: Add the stm32f205 SoC")
17
None of the board types QEMU supports need param_struct support;
8
Signed-off-by: Philippe Mathieu-Daudé <f4bug@amsat.org>
18
mark this option as deprecated.
9
Message-id: 20201107193403.436146-3-f4bug@amsat.org
19
10
Reviewed-by: Peter Maydell <peter.maydell@linaro.org>
11
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
20
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
21
Reviewed-by: Daniel P. Berrangé <berrange@redhat.com>
22
Message-id: 20250127123113.2947620-1-peter.maydell@linaro.org
12
---
23
---
13
include/hw/misc/stm32f2xx_syscfg.h | 2 --
24
docs/about/deprecated.rst | 13 +++++++++++++
14
hw/arm/stm32f205_soc.c | 1 -
25
system/vl.c | 1 +
15
hw/misc/stm32f2xx_syscfg.c | 2 --
26
2 files changed, 14 insertions(+)
16
3 files changed, 5 deletions(-)
17
27
18
diff --git a/include/hw/misc/stm32f2xx_syscfg.h b/include/hw/misc/stm32f2xx_syscfg.h
28
diff --git a/docs/about/deprecated.rst b/docs/about/deprecated.rst
19
index XXXXXXX..XXXXXXX 100644
29
index XXXXXXX..XXXXXXX 100644
20
--- a/include/hw/misc/stm32f2xx_syscfg.h
30
--- a/docs/about/deprecated.rst
21
+++ b/include/hw/misc/stm32f2xx_syscfg.h
31
+++ b/docs/about/deprecated.rst
22
@@ -XXX,XX +XXX,XX @@ struct STM32F2XXSyscfgState {
32
@@ -XXX,XX +XXX,XX @@ configurations (e.g. -smp drawers=1,books=1,clusters=1 for x86 PC machine) is
23
uint32_t syscfg_exticr3;
33
marked deprecated since 9.0, users have to ensure that all the topology members
24
uint32_t syscfg_exticr4;
34
described with -smp are supported by the target machine.
25
uint32_t syscfg_cmpcr;
35
26
-
36
+``-old-param`` option for booting Arm kernels via param_struct (since 10.0)
27
- qemu_irq irq;
37
+'''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''
28
};
38
+
29
39
+The ``-old-param`` command line option is specific to Arm targets:
30
#endif /* HW_STM32F2XX_SYSCFG_H */
40
+it is used when directly booting a guest kernel to pass it the
31
diff --git a/hw/arm/stm32f205_soc.c b/hw/arm/stm32f205_soc.c
41
+command line and other information via the old ``param_struct`` ABI,
42
+rather than the newer ATAGS or DTB mechanisms. This option was only
43
+ever needed to support ancient kernels on some old board types
44
+like the ``akita`` or ``terrier``; it has been deprecated in the
45
+kernel since 2001. None of the board types QEMU supports need
46
+``param_struct`` support, so this option has been deprecated and will
47
+be removed in a future QEMU version.
48
+
49
User-mode emulator command line arguments
50
-----------------------------------------
51
52
diff --git a/system/vl.c b/system/vl.c
32
index XXXXXXX..XXXXXXX 100644
53
index XXXXXXX..XXXXXXX 100644
33
--- a/hw/arm/stm32f205_soc.c
54
--- a/system/vl.c
34
+++ b/hw/arm/stm32f205_soc.c
55
+++ b/system/vl.c
35
@@ -XXX,XX +XXX,XX @@ static void stm32f205_soc_realize(DeviceState *dev_soc, Error **errp)
56
@@ -XXX,XX +XXX,XX @@ void qemu_init(int argc, char **argv)
36
}
57
nb_prom_envs++;
37
busdev = SYS_BUS_DEVICE(dev);
58
break;
38
sysbus_mmio_map(busdev, 0, 0x40013800);
59
case QEMU_OPTION_old_param:
39
- sysbus_connect_irq(busdev, 0, qdev_get_gpio_in(armv7m, 71));
60
+ warn_report("-old-param is deprecated");
40
61
old_param = 1;
41
/* Attach UART (uses USART registers) and USART controllers */
62
break;
42
for (i = 0; i < STM_NUM_USARTS; i++) {
63
case QEMU_OPTION_rtc:
43
diff --git a/hw/misc/stm32f2xx_syscfg.c b/hw/misc/stm32f2xx_syscfg.c
44
index XXXXXXX..XXXXXXX 100644
45
--- a/hw/misc/stm32f2xx_syscfg.c
46
+++ b/hw/misc/stm32f2xx_syscfg.c
47
@@ -XXX,XX +XXX,XX @@ static void stm32f2xx_syscfg_init(Object *obj)
48
{
49
STM32F2XXSyscfgState *s = STM32F2XX_SYSCFG(obj);
50
51
- sysbus_init_irq(SYS_BUS_DEVICE(obj), &s->irq);
52
-
53
memory_region_init_io(&s->mmio, obj, &stm32f2xx_syscfg_ops, s,
54
TYPE_STM32F2XX_SYSCFG, 0x400);
55
sysbus_init_mmio(SYS_BUS_DEVICE(obj), &s->mmio);
56
--
64
--
57
2.20.1
65
2.34.1
58
66
59
67
diff view generated by jsdifflib
1
From: Philippe Mathieu-Daudé <f4bug@amsat.org>
1
From: Khem Raj <raj.khem@gmail.com>
2
2
3
We can use one MPC per SRAM bank, but we currently only wire the
3
glibc 2.41+ has added [1] definitions for sched_setattr and
4
IRQ from the first expansion MPC to the IRQ splitter. Fix that.
4
sched_getattr functions and struct sched_attr. Therefore, it needs
5
to be checked for here as well before defining sched_attr, to avoid
6
a compilation failure.
5
7
6
Fixes: bb75e16d5e6 ("hw/arm/iotkit: Wire up MPC interrupt lines")
8
Define sched_attr conditionally only when SCHED_ATTR_SIZE_VER0 is
7
Signed-off-by: Philippe Mathieu-Daudé <f4bug@amsat.org>
9
not defined.
8
Message-id: 20201107193403.436146-2-f4bug@amsat.org
10
11
[1] https://sourceware.org/git/?p=glibc.git;a=commitdiff;h=21571ca0d70302909cf72707b2a7736cf12190a0;hp=298bc488fdc047da37482f4003023cb9adef78f8
12
13
Signed-off-by: Khem Raj <raj.khem@gmail.com>
14
Resolves: https://gitlab.com/qemu-project/qemu/-/issues/2799
15
Cc: qemu-stable@nongnu.org
9
Reviewed-by: Peter Maydell <peter.maydell@linaro.org>
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/armsse.c | 3 ++-
19
linux-user/syscall.c | 4 +++-
13
1 file changed, 2 insertions(+), 1 deletion(-)
20
1 file changed, 3 insertions(+), 1 deletion(-)
14
21
15
diff --git a/hw/arm/armsse.c b/hw/arm/armsse.c
22
diff --git a/linux-user/syscall.c b/linux-user/syscall.c
16
index XXXXXXX..XXXXXXX 100644
23
index XXXXXXX..XXXXXXX 100644
17
--- a/hw/arm/armsse.c
24
--- a/linux-user/syscall.c
18
+++ b/hw/arm/armsse.c
25
+++ b/linux-user/syscall.c
19
@@ -XXX,XX +XXX,XX @@ static void armsse_realize(DeviceState *dev, Error **errp)
26
@@ -XXX,XX +XXX,XX @@ _syscall3(int, sys_sched_getaffinity, pid_t, pid, unsigned int, len,
20
qdev_get_gpio_in(dev_splitter, 0));
27
#define __NR_sys_sched_setaffinity __NR_sched_setaffinity
21
qdev_connect_gpio_out(dev_splitter, 0,
28
_syscall3(int, sys_sched_setaffinity, pid_t, pid, unsigned int, len,
22
qdev_get_gpio_in_named(dev_secctl,
29
unsigned long *, user_mask_ptr);
23
- "mpc_status", 0));
30
-/* sched_attr is not defined in glibc */
24
+ "mpc_status",
31
+/* sched_attr is not defined in glibc < 2.41 */
25
+ i - IOTS_NUM_EXP_MPC));
32
+#ifndef SCHED_ATTR_SIZE_VER0
26
}
33
struct sched_attr {
27
34
uint32_t size;
28
qdev_connect_gpio_out(dev_splitter, 1,
35
uint32_t sched_policy;
36
@@ -XXX,XX +XXX,XX @@ struct sched_attr {
37
uint32_t sched_util_min;
38
uint32_t sched_util_max;
39
};
40
+#endif
41
#define __NR_sys_sched_getattr __NR_sched_getattr
42
_syscall4(int, sys_sched_getattr, pid_t, pid, struct sched_attr *, attr,
43
unsigned int, size, unsigned int, flags);
29
--
44
--
30
2.20.1
45
2.34.1
31
32
diff view generated by jsdifflib