mirror of
https://github.com/Motorhead1991/qemu.git
synced 2025-08-07 01:33:56 -06:00
hw/intc/aspeed: Support different memory region ops
The previous implementation set the "aspeed_intc_ops" struct, containing read and write callbacks, to be used when I/O is performed on the INTC region. Both "aspeed_intc_read" and "aspeed_intc_write" callback functions were used for INTC (CPU Die). To support the INTCIO (IO Die) model, introduces a new "reg_ops" class attribute. This allows setting different memory region operations to support different INTC models. Will introduce "aspeed_intcio_read" and "aspeed_intcio_write" callback functions are used for INTCIO. Signed-off-by: Jamin Lin <jamin_lin@aspeedtech.com> Reviewed-by: Cédric Le Goater <clg@redhat.com> Link: https://lore.kernel.org/qemu-devel/20250307035945.3698802-11-jamin_lin@aspeedtech.com Signed-off-by: Cédric Le Goater <clg@redhat.com>
This commit is contained in:
parent
617cacefb7
commit
28194d5d15
2 changed files with 5 additions and 1 deletions
|
@ -332,7 +332,7 @@ static void aspeed_intc_realize(DeviceState *dev, Error **errp)
|
|||
sysbus_init_mmio(sbd, &s->iomem_container);
|
||||
|
||||
s->regs = g_new(uint32_t, aic->nr_regs);
|
||||
memory_region_init_io(&s->iomem, OBJECT(s), &aspeed_intc_ops, s,
|
||||
memory_region_init_io(&s->iomem, OBJECT(s), aic->reg_ops, s,
|
||||
TYPE_ASPEED_INTC ".regs", aic->nr_regs << 2);
|
||||
|
||||
memory_region_add_subregion(&s->iomem_container, aic->reg_offset,
|
||||
|
@ -359,12 +359,15 @@ static void aspeed_intc_unrealize(DeviceState *dev)
|
|||
static void aspeed_intc_class_init(ObjectClass *klass, void *data)
|
||||
{
|
||||
DeviceClass *dc = DEVICE_CLASS(klass);
|
||||
AspeedINTCClass *aic = ASPEED_INTC_CLASS(klass);
|
||||
|
||||
dc->desc = "ASPEED INTC Controller";
|
||||
dc->realize = aspeed_intc_realize;
|
||||
dc->unrealize = aspeed_intc_unrealize;
|
||||
device_class_set_legacy_reset(dc, aspeed_intc_reset);
|
||||
dc->vmsd = NULL;
|
||||
|
||||
aic->reg_ops = &aspeed_intc_ops;
|
||||
}
|
||||
|
||||
static const TypeInfo aspeed_intc_info = {
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue