diff options
author | Alistair Francis <alistair.francis@wdc.com> | 2022-06-01 11:36:31 +1000 |
---|---|---|
committer | Alistair Francis <alistair.francis@wdc.com> | 2022-06-10 09:31:42 +1000 |
commit | 40244040a7ac00d40db4dea02234d13502c30112 (patch) | |
tree | dcda9e053d79419cb0cf24b7bb53ef545e464a56 /linux-headers | |
parent | f9a461b2d3b8ef4f36b7891eb4040693ee071719 (diff) | |
download | qemu-40244040a7ac00d40db4dea02234d13502c30112.zip qemu-40244040a7ac00d40db4dea02234d13502c30112.tar.gz qemu-40244040a7ac00d40db4dea02234d13502c30112.tar.bz2 |
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 'linux-headers')
0 files changed, 0 insertions, 0 deletions