diff options
author | Alistair Francis | 2022-06-01 03:36:31 +0200 |
---|---|---|
committer | Alistair Francis | 2022-06-10 01:31:42 +0200 |
commit | 40244040a7ac00d40db4dea02234d13502c30112 (patch) | |
tree | dcda9e053d79419cb0cf24b7bb53ef545e464a56 /hw/core/generic-loader.c | |
parent | hw/riscv: virt: Generate fw_cfg DT node correctly (diff) | |
download | qemu-40244040a7ac00d40db4dea02234d13502c30112.tar.gz qemu-40244040a7ac00d40db4dea02234d13502c30112.tar.xz qemu-40244040a7ac00d40db4dea02234d13502c30112.zip |
hw/intc: sifive_plic: Avoid overflowing the addr_config buffer
Since commit ad40be27 "target/riscv: Support start kernel directly by
KVM" we have been overflowing the addr_config on "M,MS..."
configurations, as reported https://gitlab.com/qemu-project/qemu/-/issues/1050.
This commit changes the loop in sifive_plic_create() from iterating over
the number of harts to just iterating over the addr_config. The
addr_config is based on the hart_config, and will contain interrup details
for all harts. This way we can't iterate past the end of addr_config.
Fixes: ad40be27084536 ("target/riscv: Support start kernel directly by KVM")
Resolves: https://gitlab.com/qemu-project/qemu/-/issues/1050
Signed-off-by: Alistair Francis <alistair.francis@wdc.com>
Reviewed-by: Mingwang Li <limingwang@huawei.com>
Reviewed-by: Philippe Mathieu-Daudé <f4bug@amsat.org>
Message-Id: <20220601013631.196854-1-alistair.francis@opensource.wdc.com>
Diffstat (limited to 'hw/core/generic-loader.c')
0 files changed, 0 insertions, 0 deletions