mirror of https://gitee.com/openkylin/qemu.git
macio: Split MacIO in two
Let the machines create two different types. This prepares to move knowledge about sub-devices from the machines into the devices. Signed-off-by: Andreas Färber <afaerber@suse.de> Signed-off-by: Alexander Graf <agraf@suse.de>
This commit is contained in:
parent
7b925079e3
commit
d037834a9d
89
hw/macio.c
89
hw/macio.c
|
@ -36,7 +36,6 @@ typedef struct MacIOState
|
||||||
PCIDevice parent;
|
PCIDevice parent;
|
||||||
/*< public >*/
|
/*< public >*/
|
||||||
|
|
||||||
int is_oldworld;
|
|
||||||
MemoryRegion bar;
|
MemoryRegion bar;
|
||||||
MemoryRegion *pic_mem;
|
MemoryRegion *pic_mem;
|
||||||
MemoryRegion *dbdma_mem;
|
MemoryRegion *dbdma_mem;
|
||||||
|
@ -52,15 +51,6 @@ static void macio_bar_setup(MacIOState *macio_state)
|
||||||
int i;
|
int i;
|
||||||
MemoryRegion *bar = &macio_state->bar;
|
MemoryRegion *bar = &macio_state->bar;
|
||||||
|
|
||||||
if (macio_state->pic_mem) {
|
|
||||||
if (macio_state->is_oldworld) {
|
|
||||||
/* Heathrow PIC */
|
|
||||||
memory_region_add_subregion(bar, 0x00000, macio_state->pic_mem);
|
|
||||||
} else {
|
|
||||||
/* OpenPIC */
|
|
||||||
memory_region_add_subregion(bar, 0x40000, macio_state->pic_mem);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if (macio_state->dbdma_mem) {
|
if (macio_state->dbdma_mem) {
|
||||||
memory_region_add_subregion(bar, 0x08000, macio_state->dbdma_mem);
|
memory_region_add_subregion(bar, 0x08000, macio_state->dbdma_mem);
|
||||||
}
|
}
|
||||||
|
@ -80,7 +70,7 @@ static void macio_bar_setup(MacIOState *macio_state)
|
||||||
macio_nvram_setup_bar(macio_state->nvram, bar, 0x60000);
|
macio_nvram_setup_bar(macio_state->nvram, bar, 0x60000);
|
||||||
}
|
}
|
||||||
|
|
||||||
static int macio_initfn(PCIDevice *d)
|
static int macio_common_initfn(PCIDevice *d)
|
||||||
{
|
{
|
||||||
MacIOState *s = MACIO(d);
|
MacIOState *s = MACIO(d);
|
||||||
|
|
||||||
|
@ -92,6 +82,38 @@ static int macio_initfn(PCIDevice *d)
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static int macio_oldworld_initfn(PCIDevice *d)
|
||||||
|
{
|
||||||
|
MacIOState *s = MACIO(d);
|
||||||
|
int ret = macio_common_initfn(d);
|
||||||
|
if (ret < 0) {
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (s->pic_mem) {
|
||||||
|
/* Heathrow PIC */
|
||||||
|
memory_region_add_subregion(&s->bar, 0x00000, s->pic_mem);
|
||||||
|
}
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
static int macio_newworld_initfn(PCIDevice *d)
|
||||||
|
{
|
||||||
|
MacIOState *s = MACIO(d);
|
||||||
|
int ret = macio_common_initfn(d);
|
||||||
|
if (ret < 0) {
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (s->pic_mem) {
|
||||||
|
/* OpenPIC */
|
||||||
|
memory_region_add_subregion(&s->bar, 0x40000, s->pic_mem);
|
||||||
|
}
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
static void macio_instance_init(Object *obj)
|
static void macio_instance_init(Object *obj)
|
||||||
{
|
{
|
||||||
MacIOState *s = MACIO(obj);
|
MacIOState *s = MACIO(obj);
|
||||||
|
@ -99,44 +121,69 @@ static void macio_instance_init(Object *obj)
|
||||||
memory_region_init(&s->bar, "macio", 0x80000);
|
memory_region_init(&s->bar, "macio", 0x80000);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void macio_oldworld_class_init(ObjectClass *oc, void *data)
|
||||||
|
{
|
||||||
|
PCIDeviceClass *pdc = PCI_DEVICE_CLASS(oc);
|
||||||
|
|
||||||
|
pdc->init = macio_oldworld_initfn;
|
||||||
|
pdc->device_id = PCI_DEVICE_ID_APPLE_343S1201;
|
||||||
|
}
|
||||||
|
|
||||||
|
static void macio_newworld_class_init(ObjectClass *oc, void *data)
|
||||||
|
{
|
||||||
|
PCIDeviceClass *pdc = PCI_DEVICE_CLASS(oc);
|
||||||
|
|
||||||
|
pdc->init = macio_newworld_initfn;
|
||||||
|
pdc->device_id = PCI_DEVICE_ID_APPLE_UNI_N_KEYL;
|
||||||
|
}
|
||||||
|
|
||||||
static void macio_class_init(ObjectClass *klass, void *data)
|
static void macio_class_init(ObjectClass *klass, void *data)
|
||||||
{
|
{
|
||||||
PCIDeviceClass *k = PCI_DEVICE_CLASS(klass);
|
PCIDeviceClass *k = PCI_DEVICE_CLASS(klass);
|
||||||
|
|
||||||
k->init = macio_initfn;
|
|
||||||
k->vendor_id = PCI_VENDOR_ID_APPLE;
|
k->vendor_id = PCI_VENDOR_ID_APPLE;
|
||||||
k->class_id = PCI_CLASS_OTHERS << 8;
|
k->class_id = PCI_CLASS_OTHERS << 8;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static const TypeInfo macio_oldworld_type_info = {
|
||||||
|
.name = TYPE_OLDWORLD_MACIO,
|
||||||
|
.parent = TYPE_MACIO,
|
||||||
|
.class_init = macio_oldworld_class_init,
|
||||||
|
};
|
||||||
|
|
||||||
|
static const TypeInfo macio_newworld_type_info = {
|
||||||
|
.name = TYPE_NEWWORLD_MACIO,
|
||||||
|
.parent = TYPE_MACIO,
|
||||||
|
.class_init = macio_newworld_class_init,
|
||||||
|
};
|
||||||
|
|
||||||
static const TypeInfo macio_type_info = {
|
static const TypeInfo macio_type_info = {
|
||||||
.name = TYPE_MACIO,
|
.name = TYPE_MACIO,
|
||||||
.parent = TYPE_PCI_DEVICE,
|
.parent = TYPE_PCI_DEVICE,
|
||||||
.instance_size = sizeof(MacIOState),
|
.instance_size = sizeof(MacIOState),
|
||||||
.instance_init = macio_instance_init,
|
.instance_init = macio_instance_init,
|
||||||
|
.abstract = true,
|
||||||
.class_init = macio_class_init,
|
.class_init = macio_class_init,
|
||||||
};
|
};
|
||||||
|
|
||||||
static void macio_register_types(void)
|
static void macio_register_types(void)
|
||||||
{
|
{
|
||||||
type_register_static(&macio_type_info);
|
type_register_static(&macio_type_info);
|
||||||
|
type_register_static(&macio_oldworld_type_info);
|
||||||
|
type_register_static(&macio_newworld_type_info);
|
||||||
}
|
}
|
||||||
|
|
||||||
type_init(macio_register_types)
|
type_init(macio_register_types)
|
||||||
|
|
||||||
void macio_init (PCIBus *bus, int device_id, int is_oldworld,
|
void macio_init(PCIDevice *d,
|
||||||
MemoryRegion *pic_mem, MemoryRegion *dbdma_mem,
|
MemoryRegion *pic_mem, MemoryRegion *dbdma_mem,
|
||||||
MemoryRegion *cuda_mem, void *nvram,
|
MemoryRegion *cuda_mem, void *nvram,
|
||||||
int nb_ide, MemoryRegion **ide_mem,
|
int nb_ide, MemoryRegion **ide_mem,
|
||||||
MemoryRegion *escc_mem)
|
MemoryRegion *escc_mem)
|
||||||
{
|
{
|
||||||
PCIDevice *d;
|
MacIOState *macio_state = MACIO(d);
|
||||||
MacIOState *macio_state;
|
|
||||||
int i;
|
int i;
|
||||||
|
|
||||||
d = pci_create(bus, -1, TYPE_MACIO);
|
|
||||||
|
|
||||||
macio_state = MACIO(d);
|
|
||||||
macio_state->is_oldworld = is_oldworld;
|
|
||||||
macio_state->pic_mem = pic_mem;
|
macio_state->pic_mem = pic_mem;
|
||||||
macio_state->dbdma_mem = dbdma_mem;
|
macio_state->dbdma_mem = dbdma_mem;
|
||||||
macio_state->cuda_mem = cuda_mem;
|
macio_state->cuda_mem = cuda_mem;
|
||||||
|
@ -147,12 +194,8 @@ void macio_init (PCIBus *bus, int device_id, int is_oldworld,
|
||||||
macio_state->nb_ide = nb_ide;
|
macio_state->nb_ide = nb_ide;
|
||||||
for (i = 0; i < nb_ide; i++)
|
for (i = 0; i < nb_ide; i++)
|
||||||
macio_state->ide_mem[i] = ide_mem[i];
|
macio_state->ide_mem[i] = ide_mem[i];
|
||||||
for (; i < 4; i++)
|
|
||||||
macio_state->ide_mem[i] = NULL;
|
|
||||||
/* Note: this code is strongly inspirated from the corresponding code
|
/* Note: this code is strongly inspirated from the corresponding code
|
||||||
in PearPC */
|
in PearPC */
|
||||||
|
|
||||||
pci_config_set_device_id(d->config, device_id);
|
|
||||||
|
|
||||||
qdev_init_nofail(DEVICE(d));
|
qdev_init_nofail(DEVICE(d));
|
||||||
}
|
}
|
||||||
|
|
|
@ -45,7 +45,9 @@
|
||||||
void cuda_init (MemoryRegion **cuda_mem, qemu_irq irq);
|
void cuda_init (MemoryRegion **cuda_mem, qemu_irq irq);
|
||||||
|
|
||||||
/* MacIO */
|
/* MacIO */
|
||||||
void macio_init (PCIBus *bus, int device_id, int is_oldworld,
|
#define TYPE_OLDWORLD_MACIO "macio-oldworld"
|
||||||
|
#define TYPE_NEWWORLD_MACIO "macio-newworld"
|
||||||
|
void macio_init(PCIDevice *dev,
|
||||||
MemoryRegion *pic_mem, MemoryRegion *dbdma_mem,
|
MemoryRegion *pic_mem, MemoryRegion *dbdma_mem,
|
||||||
MemoryRegion *cuda_mem, void *nvram,
|
MemoryRegion *cuda_mem, void *nvram,
|
||||||
int nb_ide, MemoryRegion **ide_mem, MemoryRegion *escc_mem);
|
int nb_ide, MemoryRegion **ide_mem, MemoryRegion *escc_mem);
|
||||||
|
|
|
@ -147,6 +147,7 @@ static void ppc_core99_init(QEMUMachineInitArgs *args)
|
||||||
hwaddr kernel_base, initrd_base, cmdline_base = 0;
|
hwaddr kernel_base, initrd_base, cmdline_base = 0;
|
||||||
long kernel_size, initrd_size;
|
long kernel_size, initrd_size;
|
||||||
PCIBus *pci_bus;
|
PCIBus *pci_bus;
|
||||||
|
PCIDevice *macio;
|
||||||
MacIONVRAMState *nvr;
|
MacIONVRAMState *nvr;
|
||||||
int bios_size;
|
int bios_size;
|
||||||
MemoryRegion *pic_mem, *dbdma_mem, *cuda_mem, *escc_mem;
|
MemoryRegion *pic_mem, *dbdma_mem, *cuda_mem, *escc_mem;
|
||||||
|
@ -374,7 +375,8 @@ static void ppc_core99_init(QEMUMachineInitArgs *args)
|
||||||
adb_kbd_init(&adb_bus);
|
adb_kbd_init(&adb_bus);
|
||||||
adb_mouse_init(&adb_bus);
|
adb_mouse_init(&adb_bus);
|
||||||
|
|
||||||
macio_init(pci_bus, PCI_DEVICE_ID_APPLE_UNI_N_KEYL, 0, pic_mem,
|
macio = pci_create(pci_bus, -1, TYPE_NEWWORLD_MACIO);
|
||||||
|
macio_init(macio, pic_mem,
|
||||||
dbdma_mem, cuda_mem, NULL, 3, ide_mem, escc_bar);
|
dbdma_mem, cuda_mem, NULL, 3, ide_mem, escc_bar);
|
||||||
|
|
||||||
if (usb_enabled(machine_arch == ARCH_MAC99_U3)) {
|
if (usb_enabled(machine_arch == ARCH_MAC99_U3)) {
|
||||||
|
|
|
@ -90,6 +90,7 @@ static void ppc_heathrow_init(QEMUMachineInitArgs *args)
|
||||||
uint32_t kernel_base, initrd_base, cmdline_base = 0;
|
uint32_t kernel_base, initrd_base, cmdline_base = 0;
|
||||||
int32_t kernel_size, initrd_size;
|
int32_t kernel_size, initrd_size;
|
||||||
PCIBus *pci_bus;
|
PCIBus *pci_bus;
|
||||||
|
PCIDevice *macio;
|
||||||
MacIONVRAMState *nvr;
|
MacIONVRAMState *nvr;
|
||||||
int bios_size;
|
int bios_size;
|
||||||
MemoryRegion *pic_mem, *dbdma_mem, *cuda_mem;
|
MemoryRegion *pic_mem, *dbdma_mem, *cuda_mem;
|
||||||
|
@ -283,7 +284,8 @@ static void ppc_heathrow_init(QEMUMachineInitArgs *args)
|
||||||
nvr = macio_nvram_init(0x2000, 4);
|
nvr = macio_nvram_init(0x2000, 4);
|
||||||
pmac_format_nvram_partition(nvr, 0x2000);
|
pmac_format_nvram_partition(nvr, 0x2000);
|
||||||
|
|
||||||
macio_init(pci_bus, PCI_DEVICE_ID_APPLE_343S1201, 1, pic_mem,
|
macio = pci_create(pci_bus, -1, TYPE_OLDWORLD_MACIO);
|
||||||
|
macio_init(macio, pic_mem,
|
||||||
dbdma_mem, cuda_mem, nvr, 2, ide_mem, escc_bar);
|
dbdma_mem, cuda_mem, nvr, 2, ide_mem, escc_bar);
|
||||||
|
|
||||||
if (usb_enabled(false)) {
|
if (usb_enabled(false)) {
|
||||||
|
|
Loading…
Reference in New Issue