|
@@ -130,7 +130,7 @@ static uint64_t riscv_aclint_mtimer_read(void *opaque, hwaddr addr,
|
|
|
addr < (mtimer->timecmp_base + (mtimer->num_harts << 3))) {
|
|
|
size_t hartid = mtimer->hartid_base +
|
|
|
((addr - mtimer->timecmp_base) >> 3);
|
|
|
- CPUState *cpu = qemu_get_cpu(hartid);
|
|
|
+ CPUState *cpu = cpu_by_arch_id(hartid);
|
|
|
CPURISCVState *env = cpu ? cpu->env_ptr : NULL;
|
|
|
if (!env) {
|
|
|
qemu_log_mask(LOG_GUEST_ERROR,
|
|
@@ -173,7 +173,7 @@ static void riscv_aclint_mtimer_write(void *opaque, hwaddr addr,
|
|
|
addr < (mtimer->timecmp_base + (mtimer->num_harts << 3))) {
|
|
|
size_t hartid = mtimer->hartid_base +
|
|
|
((addr - mtimer->timecmp_base) >> 3);
|
|
|
- CPUState *cpu = qemu_get_cpu(hartid);
|
|
|
+ CPUState *cpu = cpu_by_arch_id(hartid);
|
|
|
CPURISCVState *env = cpu ? cpu->env_ptr : NULL;
|
|
|
if (!env) {
|
|
|
qemu_log_mask(LOG_GUEST_ERROR,
|
|
@@ -231,7 +231,7 @@ static void riscv_aclint_mtimer_write(void *opaque, hwaddr addr,
|
|
|
|
|
|
/* Check if timer interrupt is triggered for each hart. */
|
|
|
for (i = 0; i < mtimer->num_harts; i++) {
|
|
|
- CPUState *cpu = qemu_get_cpu(mtimer->hartid_base + i);
|
|
|
+ CPUState *cpu = cpu_by_arch_id(mtimer->hartid_base + i);
|
|
|
CPURISCVState *env = cpu ? cpu->env_ptr : NULL;
|
|
|
if (!env) {
|
|
|
continue;
|
|
@@ -292,7 +292,7 @@ static void riscv_aclint_mtimer_realize(DeviceState *dev, Error **errp)
|
|
|
s->timecmp = g_new0(uint64_t, s->num_harts);
|
|
|
/* Claim timer interrupt bits */
|
|
|
for (i = 0; i < s->num_harts; i++) {
|
|
|
- RISCVCPU *cpu = RISCV_CPU(qemu_get_cpu(s->hartid_base + i));
|
|
|
+ RISCVCPU *cpu = RISCV_CPU(cpu_by_arch_id(s->hartid_base + i));
|
|
|
if (riscv_cpu_claim_interrupts(cpu, MIP_MTIP) < 0) {
|
|
|
error_report("MTIP already claimed");
|
|
|
exit(1);
|
|
@@ -372,7 +372,7 @@ DeviceState *riscv_aclint_mtimer_create(hwaddr addr, hwaddr size,
|
|
|
sysbus_mmio_map(SYS_BUS_DEVICE(dev), 0, addr);
|
|
|
|
|
|
for (i = 0; i < num_harts; i++) {
|
|
|
- CPUState *cpu = qemu_get_cpu(hartid_base + i);
|
|
|
+ CPUState *cpu = cpu_by_arch_id(hartid_base + i);
|
|
|
RISCVCPU *rvcpu = RISCV_CPU(cpu);
|
|
|
CPURISCVState *env = cpu ? cpu->env_ptr : NULL;
|
|
|
riscv_aclint_mtimer_callback *cb =
|
|
@@ -407,7 +407,7 @@ static uint64_t riscv_aclint_swi_read(void *opaque, hwaddr addr,
|
|
|
|
|
|
if (addr < (swi->num_harts << 2)) {
|
|
|
size_t hartid = swi->hartid_base + (addr >> 2);
|
|
|
- CPUState *cpu = qemu_get_cpu(hartid);
|
|
|
+ CPUState *cpu = cpu_by_arch_id(hartid);
|
|
|
CPURISCVState *env = cpu ? cpu->env_ptr : NULL;
|
|
|
if (!env) {
|
|
|
qemu_log_mask(LOG_GUEST_ERROR,
|
|
@@ -430,7 +430,7 @@ static void riscv_aclint_swi_write(void *opaque, hwaddr addr, uint64_t value,
|
|
|
|
|
|
if (addr < (swi->num_harts << 2)) {
|
|
|
size_t hartid = swi->hartid_base + (addr >> 2);
|
|
|
- CPUState *cpu = qemu_get_cpu(hartid);
|
|
|
+ CPUState *cpu = cpu_by_arch_id(hartid);
|
|
|
CPURISCVState *env = cpu ? cpu->env_ptr : NULL;
|
|
|
if (!env) {
|
|
|
qemu_log_mask(LOG_GUEST_ERROR,
|
|
@@ -545,7 +545,7 @@ DeviceState *riscv_aclint_swi_create(hwaddr addr, uint32_t hartid_base,
|
|
|
sysbus_mmio_map(SYS_BUS_DEVICE(dev), 0, addr);
|
|
|
|
|
|
for (i = 0; i < num_harts; i++) {
|
|
|
- CPUState *cpu = qemu_get_cpu(hartid_base + i);
|
|
|
+ CPUState *cpu = cpu_by_arch_id(hartid_base + i);
|
|
|
RISCVCPU *rvcpu = RISCV_CPU(cpu);
|
|
|
|
|
|
qdev_connect_gpio_out(dev, i,
|