mirror of https://github.com/xemu-project/xemu.git
hw/arm: Allow manually specified /psci node
Change the code to avoid exiting QEMU if user provided DTB contains
manually specified /psci node and skip any /psci related fixups
instead.
Fixes: 4cbca7d9b4
("hw/arm: Move virt's PSCI DT fixup code to
arm/boot.c")
Signed-off-by: Andrey Smirnov <andrew.smirnov@gmail.com>
Reported-by: Marc Zyngier <marc.zyngier@arm.com>
Tested-by: Marc Zyngier <marc.zyngier@arm.com>
Message-id: 20180402205654.14572-1-andrew.smirnov@gmail.com
Reviewed-by: Peter Maydell <peter.maydell@linaro.org>
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
This commit is contained in:
parent
fb4fe32d5b
commit
c39770cd63
|
@ -422,6 +422,7 @@ static void fdt_add_psci_node(void *fdt)
|
||||||
ARMCPU *armcpu = ARM_CPU(qemu_get_cpu(0));
|
ARMCPU *armcpu = ARM_CPU(qemu_get_cpu(0));
|
||||||
const char *psci_method;
|
const char *psci_method;
|
||||||
int64_t psci_conduit;
|
int64_t psci_conduit;
|
||||||
|
int rc;
|
||||||
|
|
||||||
psci_conduit = object_property_get_int(OBJECT(armcpu),
|
psci_conduit = object_property_get_int(OBJECT(armcpu),
|
||||||
"psci-conduit",
|
"psci-conduit",
|
||||||
|
@ -439,6 +440,15 @@ static void fdt_add_psci_node(void *fdt)
|
||||||
g_assert_not_reached();
|
g_assert_not_reached();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* If /psci node is present in provided DTB, assume that no fixup
|
||||||
|
* is necessary and all PSCI configuration should be taken as-is
|
||||||
|
*/
|
||||||
|
rc = fdt_path_offset(fdt, "/psci");
|
||||||
|
if (rc >= 0) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
qemu_fdt_add_subnode(fdt, "/psci");
|
qemu_fdt_add_subnode(fdt, "/psci");
|
||||||
if (armcpu->psci_version == 2) {
|
if (armcpu->psci_version == 2) {
|
||||||
const char comp[] = "arm,psci-0.2\0arm,psci";
|
const char comp[] = "arm,psci-0.2\0arm,psci";
|
||||||
|
|
Loading…
Reference in New Issue