|
@@ -454,10 +454,10 @@ DeviceState *sifive_plic_create(hwaddr addr, char *hart_config,
|
|
|
|
|
|
for (i = 0; i < plic->num_addrs; i++) {
|
|
for (i = 0; i < plic->num_addrs; i++) {
|
|
int cpu_num = plic->addr_config[i].hartid;
|
|
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) {
|
|
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));
|
|
qdev_get_gpio_in(DEVICE(cpu), IRQ_M_EXT));
|
|
}
|
|
}
|
|
if (plic->addr_config[i].mode == PLICMode_S) {
|
|
if (plic->addr_config[i].mode == PLICMode_S) {
|