hw/intc: sifive_plic: Fix multi-socket plic configuraiton
Since commit40244040a7
, multi-socket configuration with plic is broken as the hartid for second socket is calculated incorrectly. The hartid stored in addr_config already includes the offset for the base hartid for that socket. Adding it again would lead to segfault while creating the plic device for the virt machine. qdev_connect_gpio_out was also invoked with incorrect number of gpio lines. Fixes:40244040a7
(hw/intc: sifive_plic: Avoid overflowing the addr_config buffer) Signed-off-by: Atish Patra <atishp@rivosinc.com> Reviewed-by: Alistair Francis <alistair.francis@wdc.com> Message-Id: <20220723090335.671105-1-atishp@rivosinc.com> [ Changes by AF: - Change the qdev_connect_gpio_out() numbering ] Signed-off-by: Alistair Francis <alistair.francis@wdc.com>
This commit is contained in:
parent
44602af858
commit
54f2183630
@ -454,10 +454,10 @@ DeviceState *sifive_plic_create(hwaddr addr, char *hart_config,
|
||||
|
||||
for (i = 0; i < plic->num_addrs; i++) {
|
||||
int cpu_num = plic->addr_config[i].hartid;
|
||||
CPUState *cpu = qemu_get_cpu(hartid_base + cpu_num);
|
||||
CPUState *cpu = qemu_get_cpu(cpu_num);
|
||||
|
||||
if (plic->addr_config[i].mode == PLICMode_M) {
|
||||
qdev_connect_gpio_out(dev, num_harts + cpu_num,
|
||||
qdev_connect_gpio_out(dev, num_harts - plic->hartid_base + cpu_num,
|
||||
qdev_get_gpio_in(DEVICE(cpu), IRQ_M_EXT));
|
||||
}
|
||||
if (plic->addr_config[i].mode == PLICMode_S) {
|
||||
|
Loading…
Reference in New Issue
Block a user