hw/riscv: Provide rdtime callback for TCG in CLINT emulation
This patch extends CLINT emulation to provide rdtime callback for TCG. This rdtime callback will be called wheneven TIME CSRs are read in privileged modes. Signed-off-by: Anup Patel <anup.patel@wdc.com> Reviewed-by: Alistair Francis <alistair.francis@wdc.com> Signed-off-by: Palmer Dabbelt <palmerdabbelt@google.com>
This commit is contained in:
parent
c695724868
commit
5f3616ccce
@ -227,7 +227,8 @@ type_init(sifive_clint_register_types)
|
|||||||
* Create CLINT device.
|
* Create CLINT device.
|
||||||
*/
|
*/
|
||||||
DeviceState *sifive_clint_create(hwaddr addr, hwaddr size, uint32_t num_harts,
|
DeviceState *sifive_clint_create(hwaddr addr, hwaddr size, uint32_t num_harts,
|
||||||
uint32_t sip_base, uint32_t timecmp_base, uint32_t time_base)
|
uint32_t sip_base, uint32_t timecmp_base, uint32_t time_base,
|
||||||
|
bool provide_rdtime)
|
||||||
{
|
{
|
||||||
int i;
|
int i;
|
||||||
for (i = 0; i < num_harts; i++) {
|
for (i = 0; i < num_harts; i++) {
|
||||||
@ -236,6 +237,9 @@ DeviceState *sifive_clint_create(hwaddr addr, hwaddr size, uint32_t num_harts,
|
|||||||
if (!env) {
|
if (!env) {
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
if (provide_rdtime) {
|
||||||
|
riscv_cpu_set_rdtime_fn(env, cpu_riscv_read_rtc);
|
||||||
|
}
|
||||||
env->timer = timer_new_ns(QEMU_CLOCK_VIRTUAL,
|
env->timer = timer_new_ns(QEMU_CLOCK_VIRTUAL,
|
||||||
&sifive_clint_timer_cb, cpu);
|
&sifive_clint_timer_cb, cpu);
|
||||||
env->timecmp = 0;
|
env->timecmp = 0;
|
||||||
|
@ -164,7 +164,7 @@ static void riscv_sifive_e_soc_realize(DeviceState *dev, Error **errp)
|
|||||||
memmap[SIFIVE_E_PLIC].size);
|
memmap[SIFIVE_E_PLIC].size);
|
||||||
sifive_clint_create(memmap[SIFIVE_E_CLINT].base,
|
sifive_clint_create(memmap[SIFIVE_E_CLINT].base,
|
||||||
memmap[SIFIVE_E_CLINT].size, ms->smp.cpus,
|
memmap[SIFIVE_E_CLINT].size, ms->smp.cpus,
|
||||||
SIFIVE_SIP_BASE, SIFIVE_TIMECMP_BASE, SIFIVE_TIME_BASE);
|
SIFIVE_SIP_BASE, SIFIVE_TIMECMP_BASE, SIFIVE_TIME_BASE, false);
|
||||||
create_unimplemented_device("riscv.sifive.e.aon",
|
create_unimplemented_device("riscv.sifive.e.aon",
|
||||||
memmap[SIFIVE_E_AON].base, memmap[SIFIVE_E_AON].size);
|
memmap[SIFIVE_E_AON].base, memmap[SIFIVE_E_AON].size);
|
||||||
sifive_e_prci_create(memmap[SIFIVE_E_PRCI].base);
|
sifive_e_prci_create(memmap[SIFIVE_E_PRCI].base);
|
||||||
|
@ -549,7 +549,7 @@ static void riscv_sifive_u_soc_realize(DeviceState *dev, Error **errp)
|
|||||||
serial_hd(1), qdev_get_gpio_in(DEVICE(s->plic), SIFIVE_U_UART1_IRQ));
|
serial_hd(1), qdev_get_gpio_in(DEVICE(s->plic), SIFIVE_U_UART1_IRQ));
|
||||||
sifive_clint_create(memmap[SIFIVE_U_CLINT].base,
|
sifive_clint_create(memmap[SIFIVE_U_CLINT].base,
|
||||||
memmap[SIFIVE_U_CLINT].size, ms->smp.cpus,
|
memmap[SIFIVE_U_CLINT].size, ms->smp.cpus,
|
||||||
SIFIVE_SIP_BASE, SIFIVE_TIMECMP_BASE, SIFIVE_TIME_BASE);
|
SIFIVE_SIP_BASE, SIFIVE_TIMECMP_BASE, SIFIVE_TIME_BASE, false);
|
||||||
|
|
||||||
object_property_set_bool(OBJECT(&s->prci), true, "realized", &err);
|
object_property_set_bool(OBJECT(&s->prci), true, "realized", &err);
|
||||||
sysbus_mmio_map(SYS_BUS_DEVICE(&s->prci), 0, memmap[SIFIVE_U_PRCI].base);
|
sysbus_mmio_map(SYS_BUS_DEVICE(&s->prci), 0, memmap[SIFIVE_U_PRCI].base);
|
||||||
|
@ -227,7 +227,8 @@ static void spike_board_init(MachineState *machine)
|
|||||||
|
|
||||||
/* Core Local Interruptor (timer and IPI) */
|
/* Core Local Interruptor (timer and IPI) */
|
||||||
sifive_clint_create(memmap[SPIKE_CLINT].base, memmap[SPIKE_CLINT].size,
|
sifive_clint_create(memmap[SPIKE_CLINT].base, memmap[SPIKE_CLINT].size,
|
||||||
smp_cpus, SIFIVE_SIP_BASE, SIFIVE_TIMECMP_BASE, SIFIVE_TIME_BASE);
|
smp_cpus, SIFIVE_SIP_BASE, SIFIVE_TIMECMP_BASE, SIFIVE_TIME_BASE,
|
||||||
|
false);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void spike_v1_10_0_board_init(MachineState *machine)
|
static void spike_v1_10_0_board_init(MachineState *machine)
|
||||||
@ -316,7 +317,8 @@ static void spike_v1_10_0_board_init(MachineState *machine)
|
|||||||
|
|
||||||
/* Core Local Interruptor (timer and IPI) */
|
/* Core Local Interruptor (timer and IPI) */
|
||||||
sifive_clint_create(memmap[SPIKE_CLINT].base, memmap[SPIKE_CLINT].size,
|
sifive_clint_create(memmap[SPIKE_CLINT].base, memmap[SPIKE_CLINT].size,
|
||||||
smp_cpus, SIFIVE_SIP_BASE, SIFIVE_TIMECMP_BASE, SIFIVE_TIME_BASE);
|
smp_cpus, SIFIVE_SIP_BASE, SIFIVE_TIMECMP_BASE, SIFIVE_TIME_BASE,
|
||||||
|
false);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void spike_v1_09_1_board_init(MachineState *machine)
|
static void spike_v1_09_1_board_init(MachineState *machine)
|
||||||
@ -424,7 +426,8 @@ static void spike_v1_09_1_board_init(MachineState *machine)
|
|||||||
|
|
||||||
/* Core Local Interruptor (timer and IPI) */
|
/* Core Local Interruptor (timer and IPI) */
|
||||||
sifive_clint_create(memmap[SPIKE_CLINT].base, memmap[SPIKE_CLINT].size,
|
sifive_clint_create(memmap[SPIKE_CLINT].base, memmap[SPIKE_CLINT].size,
|
||||||
smp_cpus, SIFIVE_SIP_BASE, SIFIVE_TIMECMP_BASE, SIFIVE_TIME_BASE);
|
smp_cpus, SIFIVE_SIP_BASE, SIFIVE_TIMECMP_BASE, SIFIVE_TIME_BASE,
|
||||||
|
false);
|
||||||
|
|
||||||
g_free(config_string);
|
g_free(config_string);
|
||||||
}
|
}
|
||||||
|
@ -593,7 +593,7 @@ static void riscv_virt_board_init(MachineState *machine)
|
|||||||
memmap[VIRT_PLIC].size);
|
memmap[VIRT_PLIC].size);
|
||||||
sifive_clint_create(memmap[VIRT_CLINT].base,
|
sifive_clint_create(memmap[VIRT_CLINT].base,
|
||||||
memmap[VIRT_CLINT].size, smp_cpus,
|
memmap[VIRT_CLINT].size, smp_cpus,
|
||||||
SIFIVE_SIP_BASE, SIFIVE_TIMECMP_BASE, SIFIVE_TIME_BASE);
|
SIFIVE_SIP_BASE, SIFIVE_TIMECMP_BASE, SIFIVE_TIME_BASE, true);
|
||||||
sifive_test_create(memmap[VIRT_TEST].base);
|
sifive_test_create(memmap[VIRT_TEST].base);
|
||||||
|
|
||||||
for (i = 0; i < VIRTIO_COUNT; i++) {
|
for (i = 0; i < VIRTIO_COUNT; i++) {
|
||||||
|
@ -41,7 +41,8 @@ typedef struct SiFiveCLINTState {
|
|||||||
} SiFiveCLINTState;
|
} SiFiveCLINTState;
|
||||||
|
|
||||||
DeviceState *sifive_clint_create(hwaddr addr, hwaddr size, uint32_t num_harts,
|
DeviceState *sifive_clint_create(hwaddr addr, hwaddr size, uint32_t num_harts,
|
||||||
uint32_t sip_base, uint32_t timecmp_base, uint32_t time_base);
|
uint32_t sip_base, uint32_t timecmp_base, uint32_t time_base,
|
||||||
|
bool provide_rdtime);
|
||||||
|
|
||||||
enum {
|
enum {
|
||||||
SIFIVE_SIP_BASE = 0x0,
|
SIFIVE_SIP_BASE = 0x0,
|
||||||
|
Loading…
Reference in New Issue
Block a user