j_mayer | 3cbee15 | 2007-10-28 23:42:18 +0000 | [diff] [blame] | 1 | /* |
| 2 | * PowerMac MacIO device emulation |
| 3 | * |
| 4 | * Copyright (c) 2005-2007 Fabrice Bellard |
| 5 | * Copyright (c) 2007 Jocelyn Mayer |
| 6 | * |
| 7 | * Permission is hereby granted, free of charge, to any person obtaining a copy |
| 8 | * of this software and associated documentation files (the "Software"), to deal |
| 9 | * in the Software without restriction, including without limitation the rights |
| 10 | * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell |
| 11 | * copies of the Software, and to permit persons to whom the Software is |
| 12 | * furnished to do so, subject to the following conditions: |
| 13 | * |
| 14 | * The above copyright notice and this permission notice shall be included in |
| 15 | * all copies or substantial portions of the Software. |
| 16 | * |
| 17 | * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR |
| 18 | * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, |
| 19 | * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL |
| 20 | * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER |
| 21 | * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, |
| 22 | * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN |
| 23 | * THE SOFTWARE. |
| 24 | */ |
Markus Armbruster | 0b8fa32 | 2019-05-23 16:35:07 +0200 | [diff] [blame] | 25 | |
Peter Maydell | 0d75590 | 2016-01-26 18:16:58 +0000 | [diff] [blame] | 26 | #include "qemu/osdep.h" |
Markus Armbruster | da34e65 | 2016-03-14 09:01:28 +0100 | [diff] [blame] | 27 | #include "qapi/error.h" |
Markus Armbruster | 0b8fa32 | 2019-05-23 16:35:07 +0200 | [diff] [blame] | 28 | #include "qemu/module.h" |
Paolo Bonzini | 83c9f4c | 2013-02-04 15:40:22 +0100 | [diff] [blame] | 29 | #include "hw/ppc/mac.h" |
Mark Cave-Ayland | 7092e84 | 2018-02-09 18:51:41 +0000 | [diff] [blame] | 30 | #include "hw/misc/macio/cuda.h" |
Paolo Bonzini | 83c9f4c | 2013-02-04 15:40:22 +0100 | [diff] [blame] | 31 | #include "hw/pci/pci.h" |
Paolo Bonzini | 0d09e41 | 2013-02-05 17:06:20 +0100 | [diff] [blame] | 32 | #include "hw/ppc/mac_dbdma.h" |
Markus Armbruster | a27bd6c | 2019-08-12 07:23:51 +0200 | [diff] [blame] | 33 | #include "hw/qdev-properties.h" |
Markus Armbruster | d645427 | 2019-08-12 07:23:45 +0200 | [diff] [blame] | 34 | #include "migration/vmstate.h" |
Paolo Bonzini | 0d09e41 | 2013-02-05 17:06:20 +0100 | [diff] [blame] | 35 | #include "hw/char/escc.h" |
Mark Cave-Ayland | e1218e4 | 2018-02-28 20:32:37 +0000 | [diff] [blame] | 36 | #include "hw/misc/macio/macio.h" |
Mark Cave-Ayland | 017812d | 2018-02-28 20:32:38 +0000 | [diff] [blame] | 37 | #include "hw/intc/heathrow_pic.h" |
Markus Armbruster | 2f780b6 | 2019-08-12 07:23:58 +0200 | [diff] [blame] | 38 | #include "sysemu/sysemu.h" |
Mark Cave-Ayland | 56e7404 | 2018-05-06 15:20:03 +0100 | [diff] [blame] | 39 | #include "trace.h" |
Andreas Färber | 07a7484 | 2013-01-23 23:04:01 +0000 | [diff] [blame] | 40 | |
Mark Cave-Ayland | b6712ea | 2018-02-28 20:32:43 +0000 | [diff] [blame] | 41 | /* Note: this code is strongly inspirated from the corresponding code |
| 42 | * in PearPC */ |
| 43 | |
Alexander Graf | 0d54a50 | 2013-06-26 13:58:31 +0200 | [diff] [blame] | 44 | /* |
| 45 | * The mac-io has two interfaces to the ESCC. One is called "escc-legacy", |
| 46 | * while the other one is the normal, current ESCC interface. |
| 47 | * |
| 48 | * The magic below creates memory aliases to spawn the escc-legacy device |
| 49 | * purely by rerouting the respective registers to our escc region. This |
| 50 | * works because the only difference between the two memory regions is the |
| 51 | * register layout, not their semantics. |
| 52 | * |
| 53 | * Reference: ftp://ftp.software.ibm.com/rs6000/technology/spec/chrp/inwork/CHRP_IORef_1.0.pdf |
| 54 | */ |
Mark Cave-Ayland | 343bd85 | 2018-02-28 20:32:33 +0000 | [diff] [blame] | 55 | static void macio_escc_legacy_setup(MacIOState *s) |
Alexander Graf | 0d54a50 | 2013-06-26 13:58:31 +0200 | [diff] [blame] | 56 | { |
Mark Cave-Ayland | 343bd85 | 2018-02-28 20:32:33 +0000 | [diff] [blame] | 57 | ESCCState *escc = ESCC(&s->escc); |
| 58 | SysBusDevice *sbd = SYS_BUS_DEVICE(escc); |
Alexander Graf | 0d54a50 | 2013-06-26 13:58:31 +0200 | [diff] [blame] | 59 | MemoryRegion *escc_legacy = g_new(MemoryRegion, 1); |
Mark Cave-Ayland | 343bd85 | 2018-02-28 20:32:33 +0000 | [diff] [blame] | 60 | MemoryRegion *bar = &s->bar; |
Alexander Graf | 0d54a50 | 2013-06-26 13:58:31 +0200 | [diff] [blame] | 61 | int i; |
| 62 | static const int maps[] = { |
Benjamin Herrenschmidt | dd2fa4f | 2016-08-02 19:22:43 +1000 | [diff] [blame] | 63 | 0x00, 0x00, /* Command B */ |
| 64 | 0x02, 0x20, /* Command A */ |
| 65 | 0x04, 0x10, /* Data B */ |
| 66 | 0x06, 0x30, /* Data A */ |
| 67 | 0x08, 0x40, /* Enhancement B */ |
| 68 | 0x0A, 0x50, /* Enhancement A */ |
| 69 | 0x80, 0x80, /* Recovery count */ |
| 70 | 0x90, 0x90, /* Start A */ |
| 71 | 0xa0, 0xa0, /* Start B */ |
| 72 | 0xb0, 0xb0, /* Detect AB */ |
Alexander Graf | 0d54a50 | 2013-06-26 13:58:31 +0200 | [diff] [blame] | 73 | }; |
| 74 | |
Mark Cave-Ayland | 343bd85 | 2018-02-28 20:32:33 +0000 | [diff] [blame] | 75 | memory_region_init(escc_legacy, OBJECT(s), "escc-legacy", 256); |
Alexander Graf | 0d54a50 | 2013-06-26 13:58:31 +0200 | [diff] [blame] | 76 | for (i = 0; i < ARRAY_SIZE(maps); i += 2) { |
| 77 | MemoryRegion *port = g_new(MemoryRegion, 1); |
Mark Cave-Ayland | 343bd85 | 2018-02-28 20:32:33 +0000 | [diff] [blame] | 78 | memory_region_init_alias(port, OBJECT(s), "escc-legacy-port", |
| 79 | sysbus_mmio_get_region(sbd, 0), |
| 80 | maps[i + 1], 0x2); |
Alexander Graf | 0d54a50 | 2013-06-26 13:58:31 +0200 | [diff] [blame] | 81 | memory_region_add_subregion(escc_legacy, maps[i], port); |
| 82 | } |
| 83 | |
| 84 | memory_region_add_subregion(bar, 0x12000, escc_legacy); |
| 85 | } |
| 86 | |
Mark Cave-Ayland | 343bd85 | 2018-02-28 20:32:33 +0000 | [diff] [blame] | 87 | static void macio_bar_setup(MacIOState *s) |
j_mayer | 3cbee15 | 2007-10-28 23:42:18 +0000 | [diff] [blame] | 88 | { |
Mark Cave-Ayland | 343bd85 | 2018-02-28 20:32:33 +0000 | [diff] [blame] | 89 | ESCCState *escc = ESCC(&s->escc); |
| 90 | SysBusDevice *sbd = SYS_BUS_DEVICE(escc); |
| 91 | MemoryRegion *bar = &s->bar; |
j_mayer | 3cbee15 | 2007-10-28 23:42:18 +0000 | [diff] [blame] | 92 | |
Mark Cave-Ayland | 343bd85 | 2018-02-28 20:32:33 +0000 | [diff] [blame] | 93 | memory_region_add_subregion(bar, 0x13000, sysbus_mmio_get_region(sbd, 0)); |
| 94 | macio_escc_legacy_setup(s); |
j_mayer | 3cbee15 | 2007-10-28 23:42:18 +0000 | [diff] [blame] | 95 | } |
| 96 | |
Mark Cave-Ayland | bf31c56 | 2018-08-29 17:59:06 +0100 | [diff] [blame] | 97 | static void macio_init_child_obj(MacIOState *s, const char *childname, |
| 98 | void *child, size_t childsize, |
| 99 | const char *childtype) |
| 100 | { |
| 101 | object_initialize_child(OBJECT(s), childname, child, childsize, childtype, |
| 102 | &error_abort, NULL); |
| 103 | qdev_set_parent_bus(DEVICE(child), BUS(&s->macio_bus)); |
| 104 | } |
| 105 | |
Markus Armbruster | 62e9cd7 | 2015-03-17 08:46:15 +0100 | [diff] [blame] | 106 | static void macio_common_realize(PCIDevice *d, Error **errp) |
Anthony Liguori | d8c51b0 | 2011-12-21 16:14:09 -0600 | [diff] [blame] | 107 | { |
Andreas Färber | 7b92507 | 2013-01-23 23:03:56 +0000 | [diff] [blame] | 108 | MacIOState *s = MACIO(d); |
Andreas Färber | 45fa67f | 2013-01-23 23:04:02 +0000 | [diff] [blame] | 109 | SysBusDevice *sysbus_dev; |
Markus Armbruster | 62e9cd7 | 2015-03-17 08:46:15 +0100 | [diff] [blame] | 110 | Error *err = NULL; |
Paolo Bonzini | c710440 | 2015-10-01 10:59:52 +0200 | [diff] [blame] | 111 | |
Mark Cave-Ayland | a504b9b | 2018-02-28 20:32:32 +0000 | [diff] [blame] | 112 | object_property_set_bool(OBJECT(&s->dbdma), true, "realized", &err); |
Mark Cave-Ayland | ecba28d | 2017-09-24 15:47:42 +0100 | [diff] [blame] | 113 | if (err) { |
| 114 | error_propagate(errp, err); |
| 115 | return; |
| 116 | } |
Mark Cave-Ayland | a504b9b | 2018-02-28 20:32:32 +0000 | [diff] [blame] | 117 | sysbus_dev = SYS_BUS_DEVICE(&s->dbdma); |
Mark Cave-Ayland | ecba28d | 2017-09-24 15:47:42 +0100 | [diff] [blame] | 118 | memory_region_add_subregion(&s->bar, 0x08000, |
| 119 | sysbus_mmio_get_region(sysbus_dev, 0)); |
Andreas Färber | 7b92507 | 2013-01-23 23:03:56 +0000 | [diff] [blame] | 120 | |
Thomas Huth | ddd835f | 2018-03-19 15:00:46 +0100 | [diff] [blame] | 121 | qdev_prop_set_uint32(DEVICE(&s->escc), "disabled", 0); |
| 122 | qdev_prop_set_uint32(DEVICE(&s->escc), "frequency", ESCC_CLOCK); |
| 123 | qdev_prop_set_uint32(DEVICE(&s->escc), "it_shift", 4); |
Peter Maydell | 9bca0ed | 2018-04-20 15:52:43 +0100 | [diff] [blame] | 124 | qdev_prop_set_chr(DEVICE(&s->escc), "chrA", serial_hd(0)); |
| 125 | qdev_prop_set_chr(DEVICE(&s->escc), "chrB", serial_hd(1)); |
Thomas Huth | ddd835f | 2018-03-19 15:00:46 +0100 | [diff] [blame] | 126 | qdev_prop_set_uint32(DEVICE(&s->escc), "chnBtype", escc_serial); |
| 127 | qdev_prop_set_uint32(DEVICE(&s->escc), "chnAtype", escc_serial); |
Mark Cave-Ayland | 343bd85 | 2018-02-28 20:32:33 +0000 | [diff] [blame] | 128 | object_property_set_bool(OBJECT(&s->escc), true, "realized", &err); |
| 129 | if (err) { |
| 130 | error_propagate(errp, err); |
| 131 | return; |
| 132 | } |
| 133 | |
Andreas Färber | 7b92507 | 2013-01-23 23:03:56 +0000 | [diff] [blame] | 134 | macio_bar_setup(s); |
| 135 | pci_register_bar(d, 0, PCI_BASE_ADDRESS_SPACE_MEMORY, &s->bar); |
Anthony Liguori | d8c51b0 | 2011-12-21 16:14:09 -0600 | [diff] [blame] | 136 | } |
| 137 | |
Markus Armbruster | 62e9cd7 | 2015-03-17 08:46:15 +0100 | [diff] [blame] | 138 | static void macio_realize_ide(MacIOState *s, MACIOIDEState *ide, |
| 139 | qemu_irq irq0, qemu_irq irq1, int dmaid, |
| 140 | Error **errp) |
Alexander Graf | 14eefd0 | 2013-06-24 21:40:50 +0200 | [diff] [blame] | 141 | { |
| 142 | SysBusDevice *sysbus_dev; |
| 143 | |
| 144 | sysbus_dev = SYS_BUS_DEVICE(ide); |
| 145 | sysbus_connect_irq(sysbus_dev, 0, irq0); |
| 146 | sysbus_connect_irq(sysbus_dev, 1, irq1); |
Mark Cave-Ayland | 0fc8433 | 2017-09-24 15:47:43 +0100 | [diff] [blame] | 147 | qdev_prop_set_uint32(DEVICE(ide), "channel", dmaid); |
Mark Cave-Ayland | a504b9b | 2018-02-28 20:32:32 +0000 | [diff] [blame] | 148 | object_property_set_link(OBJECT(ide), OBJECT(&s->dbdma), "dbdma", errp); |
Mark Cave-Ayland | e451b85 | 2017-09-24 15:47:44 +0100 | [diff] [blame] | 149 | macio_ide_register_dma(ide); |
Mark Cave-Ayland | 0fc8433 | 2017-09-24 15:47:43 +0100 | [diff] [blame] | 150 | |
Markus Armbruster | 62e9cd7 | 2015-03-17 08:46:15 +0100 | [diff] [blame] | 151 | object_property_set_bool(OBJECT(ide), true, "realized", errp); |
Alexander Graf | 14eefd0 | 2013-06-24 21:40:50 +0200 | [diff] [blame] | 152 | } |
| 153 | |
Markus Armbruster | 62e9cd7 | 2015-03-17 08:46:15 +0100 | [diff] [blame] | 154 | static void macio_oldworld_realize(PCIDevice *d, Error **errp) |
Andreas Färber | d037834 | 2013-01-23 23:03:57 +0000 | [diff] [blame] | 155 | { |
| 156 | MacIOState *s = MACIO(d); |
Andreas Färber | 95ed3b7 | 2013-01-23 23:04:00 +0000 | [diff] [blame] | 157 | OldWorldMacIOState *os = OLDWORLD_MACIO(d); |
Mark Cave-Ayland | 20d2514 | 2018-03-06 22:01:59 +0000 | [diff] [blame] | 158 | DeviceState *pic_dev = DEVICE(os->pic); |
Markus Armbruster | 62e9cd7 | 2015-03-17 08:46:15 +0100 | [diff] [blame] | 159 | Error *err = NULL; |
Andreas Färber | 95ed3b7 | 2013-01-23 23:04:00 +0000 | [diff] [blame] | 160 | SysBusDevice *sysbus_dev; |
Markus Armbruster | 62e9cd7 | 2015-03-17 08:46:15 +0100 | [diff] [blame] | 161 | |
| 162 | macio_common_realize(d, &err); |
| 163 | if (err) { |
| 164 | error_propagate(errp, err); |
| 165 | return; |
Andreas Färber | d037834 | 2013-01-23 23:03:57 +0000 | [diff] [blame] | 166 | } |
| 167 | |
Mark Cave-Ayland | d811d61 | 2018-06-12 17:44:02 +0100 | [diff] [blame] | 168 | qdev_prop_set_uint64(DEVICE(&s->cuda), "timebase-frequency", |
| 169 | s->frequency); |
| 170 | object_property_set_bool(OBJECT(&s->cuda), true, "realized", &err); |
| 171 | if (err) { |
| 172 | error_propagate(errp, err); |
| 173 | return; |
| 174 | } |
Andreas Färber | 45fa67f | 2013-01-23 23:04:02 +0000 | [diff] [blame] | 175 | sysbus_dev = SYS_BUS_DEVICE(&s->cuda); |
Mark Cave-Ayland | d811d61 | 2018-06-12 17:44:02 +0100 | [diff] [blame] | 176 | memory_region_add_subregion(&s->bar, 0x16000, |
| 177 | sysbus_mmio_get_region(sysbus_dev, 0)); |
Mark Cave-Ayland | 20d2514 | 2018-03-06 22:01:59 +0000 | [diff] [blame] | 178 | sysbus_connect_irq(sysbus_dev, 0, qdev_get_gpio_in(pic_dev, |
| 179 | OLDWORLD_CUDA_IRQ)); |
Andreas Färber | 45fa67f | 2013-01-23 23:04:02 +0000 | [diff] [blame] | 180 | |
Mark Cave-Ayland | 343bd85 | 2018-02-28 20:32:33 +0000 | [diff] [blame] | 181 | sysbus_dev = SYS_BUS_DEVICE(&s->escc); |
Mark Cave-Ayland | 20d2514 | 2018-03-06 22:01:59 +0000 | [diff] [blame] | 182 | sysbus_connect_irq(sysbus_dev, 0, qdev_get_gpio_in(pic_dev, |
| 183 | OLDWORLD_ESCCB_IRQ)); |
| 184 | sysbus_connect_irq(sysbus_dev, 1, qdev_get_gpio_in(pic_dev, |
| 185 | OLDWORLD_ESCCA_IRQ)); |
Mark Cave-Ayland | 343bd85 | 2018-02-28 20:32:33 +0000 | [diff] [blame] | 186 | |
Markus Armbruster | 62e9cd7 | 2015-03-17 08:46:15 +0100 | [diff] [blame] | 187 | object_property_set_bool(OBJECT(&os->nvram), true, "realized", &err); |
| 188 | if (err) { |
| 189 | error_propagate(errp, err); |
| 190 | return; |
Andreas Färber | 95ed3b7 | 2013-01-23 23:04:00 +0000 | [diff] [blame] | 191 | } |
| 192 | sysbus_dev = SYS_BUS_DEVICE(&os->nvram); |
| 193 | memory_region_add_subregion(&s->bar, 0x60000, |
| 194 | sysbus_mmio_get_region(sysbus_dev, 0)); |
| 195 | pmac_format_nvram_partition(&os->nvram, os->nvram.size); |
| 196 | |
Mark Cave-Ayland | 017812d | 2018-02-28 20:32:38 +0000 | [diff] [blame] | 197 | /* Heathrow PIC */ |
| 198 | sysbus_dev = SYS_BUS_DEVICE(os->pic); |
| 199 | memory_region_add_subregion(&s->bar, 0x0, |
| 200 | sysbus_mmio_get_region(sysbus_dev, 0)); |
Andreas Färber | d037834 | 2013-01-23 23:03:57 +0000 | [diff] [blame] | 201 | |
Alexander Graf | 14eefd0 | 2013-06-24 21:40:50 +0200 | [diff] [blame] | 202 | /* IDE buses */ |
Mark Cave-Ayland | 20d2514 | 2018-03-06 22:01:59 +0000 | [diff] [blame] | 203 | macio_realize_ide(s, &os->ide[0], |
| 204 | qdev_get_gpio_in(pic_dev, OLDWORLD_IDE0_IRQ), |
| 205 | qdev_get_gpio_in(pic_dev, OLDWORLD_IDE0_DMA_IRQ), |
| 206 | 0x16, &err); |
| 207 | if (err) { |
| 208 | error_propagate(errp, err); |
| 209 | return; |
| 210 | } |
Alexander Graf | 14eefd0 | 2013-06-24 21:40:50 +0200 | [diff] [blame] | 211 | |
Mark Cave-Ayland | 20d2514 | 2018-03-06 22:01:59 +0000 | [diff] [blame] | 212 | macio_realize_ide(s, &os->ide[1], |
| 213 | qdev_get_gpio_in(pic_dev, OLDWORLD_IDE1_IRQ), |
| 214 | qdev_get_gpio_in(pic_dev, OLDWORLD_IDE1_DMA_IRQ), |
| 215 | 0x1a, &err); |
| 216 | if (err) { |
| 217 | error_propagate(errp, err); |
| 218 | return; |
Andreas Färber | 07a7484 | 2013-01-23 23:04:01 +0000 | [diff] [blame] | 219 | } |
Andreas Färber | d037834 | 2013-01-23 23:03:57 +0000 | [diff] [blame] | 220 | } |
| 221 | |
Andreas Färber | 213f0c4 | 2013-08-23 19:37:12 +0200 | [diff] [blame] | 222 | static void macio_init_ide(MacIOState *s, MACIOIDEState *ide, size_t ide_size, |
| 223 | int index) |
Alexander Graf | 14eefd0 | 2013-06-24 21:40:50 +0200 | [diff] [blame] | 224 | { |
Thomas Huth | 1069a3c | 2018-07-17 16:51:54 +0200 | [diff] [blame] | 225 | gchar *name = g_strdup_printf("ide[%i]", index); |
Mark Cave-Ayland | 5c8e3d1 | 2018-08-29 17:59:07 +0100 | [diff] [blame] | 226 | uint32_t addr = 0x1f000 + ((index + 1) * 0x1000); |
Alexander Graf | 14eefd0 | 2013-06-24 21:40:50 +0200 | [diff] [blame] | 227 | |
Mark Cave-Ayland | bf31c56 | 2018-08-29 17:59:06 +0100 | [diff] [blame] | 228 | macio_init_child_obj(s, name, ide, ide_size, TYPE_MACIO_IDE); |
Mark Cave-Ayland | 5c8e3d1 | 2018-08-29 17:59:07 +0100 | [diff] [blame] | 229 | qdev_prop_set_uint32(DEVICE(ide), "addr", addr); |
| 230 | memory_region_add_subregion(&s->bar, addr, &ide->mem); |
Alexander Graf | 14eefd0 | 2013-06-24 21:40:50 +0200 | [diff] [blame] | 231 | g_free(name); |
| 232 | } |
| 233 | |
Andreas Färber | 95ed3b7 | 2013-01-23 23:04:00 +0000 | [diff] [blame] | 234 | static void macio_oldworld_init(Object *obj) |
| 235 | { |
Andreas Färber | 07a7484 | 2013-01-23 23:04:01 +0000 | [diff] [blame] | 236 | MacIOState *s = MACIO(obj); |
Andreas Färber | 95ed3b7 | 2013-01-23 23:04:00 +0000 | [diff] [blame] | 237 | OldWorldMacIOState *os = OLDWORLD_MACIO(obj); |
| 238 | DeviceState *dev; |
Alexander Graf | 14eefd0 | 2013-06-24 21:40:50 +0200 | [diff] [blame] | 239 | int i; |
Andreas Färber | 95ed3b7 | 2013-01-23 23:04:00 +0000 | [diff] [blame] | 240 | |
Mark Cave-Ayland | 017812d | 2018-02-28 20:32:38 +0000 | [diff] [blame] | 241 | object_property_add_link(obj, "pic", TYPE_HEATHROW, |
| 242 | (Object **) &os->pic, |
| 243 | qdev_prop_allow_set_link_before_realize, |
Markus Armbruster | d262312 | 2020-05-05 17:29:22 +0200 | [diff] [blame] | 244 | 0); |
Mark Cave-Ayland | 017812d | 2018-02-28 20:32:38 +0000 | [diff] [blame] | 245 | |
Mark Cave-Ayland | bf31c56 | 2018-08-29 17:59:06 +0100 | [diff] [blame] | 246 | macio_init_child_obj(s, "cuda", &s->cuda, sizeof(s->cuda), TYPE_CUDA); |
Mark Cave-Ayland | d811d61 | 2018-06-12 17:44:02 +0100 | [diff] [blame] | 247 | |
Markus Armbruster | 514db77 | 2020-06-09 14:23:29 +0200 | [diff] [blame] | 248 | macio_init_child_obj(s, "nvram", &os->nvram, sizeof(os->nvram), |
| 249 | TYPE_MACIO_NVRAM); |
Andreas Färber | 95ed3b7 | 2013-01-23 23:04:00 +0000 | [diff] [blame] | 250 | dev = DEVICE(&os->nvram); |
| 251 | qdev_prop_set_uint32(dev, "size", 0x2000); |
| 252 | qdev_prop_set_uint32(dev, "it_shift", 4); |
Andreas Färber | 07a7484 | 2013-01-23 23:04:01 +0000 | [diff] [blame] | 253 | |
Alexander Graf | 14eefd0 | 2013-06-24 21:40:50 +0200 | [diff] [blame] | 254 | for (i = 0; i < 2; i++) { |
Andreas Färber | 213f0c4 | 2013-08-23 19:37:12 +0200 | [diff] [blame] | 255 | macio_init_ide(s, &os->ide[i], sizeof(os->ide[i]), i); |
Alexander Graf | 14eefd0 | 2013-06-24 21:40:50 +0200 | [diff] [blame] | 256 | } |
Andreas Färber | 95ed3b7 | 2013-01-23 23:04:00 +0000 | [diff] [blame] | 257 | } |
| 258 | |
Alexander Graf | a0f9fdf | 2013-06-30 05:15:14 +0200 | [diff] [blame] | 259 | static void timer_write(void *opaque, hwaddr addr, uint64_t value, |
| 260 | unsigned size) |
| 261 | { |
Mark Cave-Ayland | 56e7404 | 2018-05-06 15:20:03 +0100 | [diff] [blame] | 262 | trace_macio_timer_write(addr, size, value); |
Alexander Graf | a0f9fdf | 2013-06-30 05:15:14 +0200 | [diff] [blame] | 263 | } |
| 264 | |
| 265 | static uint64_t timer_read(void *opaque, hwaddr addr, unsigned size) |
| 266 | { |
| 267 | uint32_t value = 0; |
Alexander Graf | d696760 | 2014-07-13 16:45:46 +0200 | [diff] [blame] | 268 | uint64_t systime = qemu_clock_get_ns(QEMU_CLOCK_VIRTUAL); |
| 269 | uint64_t kltime; |
| 270 | |
Rutuja Shah | 73bcb24 | 2016-03-21 21:32:30 +0530 | [diff] [blame] | 271 | kltime = muldiv64(systime, 4194300, NANOSECONDS_PER_SECOND * 4); |
Alexander Graf | d696760 | 2014-07-13 16:45:46 +0200 | [diff] [blame] | 272 | kltime = muldiv64(kltime, 18432000, 1048575); |
Alexander Graf | a0f9fdf | 2013-06-30 05:15:14 +0200 | [diff] [blame] | 273 | |
| 274 | switch (addr) { |
| 275 | case 0x38: |
Alexander Graf | d696760 | 2014-07-13 16:45:46 +0200 | [diff] [blame] | 276 | value = kltime; |
Alexander Graf | a0f9fdf | 2013-06-30 05:15:14 +0200 | [diff] [blame] | 277 | break; |
| 278 | case 0x3c: |
Alexander Graf | d696760 | 2014-07-13 16:45:46 +0200 | [diff] [blame] | 279 | value = kltime >> 32; |
Alexander Graf | a0f9fdf | 2013-06-30 05:15:14 +0200 | [diff] [blame] | 280 | break; |
| 281 | } |
| 282 | |
Mark Cave-Ayland | 56e7404 | 2018-05-06 15:20:03 +0100 | [diff] [blame] | 283 | trace_macio_timer_read(addr, size, value); |
Alexander Graf | a0f9fdf | 2013-06-30 05:15:14 +0200 | [diff] [blame] | 284 | return value; |
| 285 | } |
| 286 | |
| 287 | static const MemoryRegionOps timer_ops = { |
| 288 | .read = timer_read, |
| 289 | .write = timer_write, |
Alexander Graf | 9397a7c | 2014-05-27 01:59:06 +0200 | [diff] [blame] | 290 | .endianness = DEVICE_LITTLE_ENDIAN, |
Alexander Graf | a0f9fdf | 2013-06-30 05:15:14 +0200 | [diff] [blame] | 291 | }; |
| 292 | |
Markus Armbruster | 62e9cd7 | 2015-03-17 08:46:15 +0100 | [diff] [blame] | 293 | static void macio_newworld_realize(PCIDevice *d, Error **errp) |
Andreas Färber | d037834 | 2013-01-23 23:03:57 +0000 | [diff] [blame] | 294 | { |
| 295 | MacIOState *s = MACIO(d); |
Andreas Färber | 07a7484 | 2013-01-23 23:04:01 +0000 | [diff] [blame] | 296 | NewWorldMacIOState *ns = NEWWORLD_MACIO(d); |
Mark Cave-Ayland | 0fcd2a8 | 2018-05-03 21:24:41 +0100 | [diff] [blame] | 297 | DeviceState *pic_dev = DEVICE(ns->pic); |
Markus Armbruster | 62e9cd7 | 2015-03-17 08:46:15 +0100 | [diff] [blame] | 298 | Error *err = NULL; |
Andreas Färber | 07a7484 | 2013-01-23 23:04:01 +0000 | [diff] [blame] | 299 | SysBusDevice *sysbus_dev; |
Gonglei | 6c5819c | 2015-02-27 15:50:14 +0800 | [diff] [blame] | 300 | MemoryRegion *timer_memory = NULL; |
Markus Armbruster | 62e9cd7 | 2015-03-17 08:46:15 +0100 | [diff] [blame] | 301 | |
| 302 | macio_common_realize(d, &err); |
| 303 | if (err) { |
| 304 | error_propagate(errp, err); |
| 305 | return; |
Andreas Färber | d037834 | 2013-01-23 23:03:57 +0000 | [diff] [blame] | 306 | } |
| 307 | |
Mark Cave-Ayland | 343bd85 | 2018-02-28 20:32:33 +0000 | [diff] [blame] | 308 | sysbus_dev = SYS_BUS_DEVICE(&s->escc); |
Mark Cave-Ayland | 0fcd2a8 | 2018-05-03 21:24:41 +0100 | [diff] [blame] | 309 | sysbus_connect_irq(sysbus_dev, 0, qdev_get_gpio_in(pic_dev, |
| 310 | NEWWORLD_ESCCB_IRQ)); |
| 311 | sysbus_connect_irq(sysbus_dev, 1, qdev_get_gpio_in(pic_dev, |
| 312 | NEWWORLD_ESCCA_IRQ)); |
Mark Cave-Ayland | 343bd85 | 2018-02-28 20:32:33 +0000 | [diff] [blame] | 313 | |
Mark Cave-Ayland | dda12e9 | 2018-02-28 20:32:41 +0000 | [diff] [blame] | 314 | /* OpenPIC */ |
| 315 | sysbus_dev = SYS_BUS_DEVICE(ns->pic); |
| 316 | memory_region_add_subregion(&s->bar, 0x40000, |
| 317 | sysbus_mmio_get_region(sysbus_dev, 0)); |
Andreas Färber | d037834 | 2013-01-23 23:03:57 +0000 | [diff] [blame] | 318 | |
Alexander Graf | 14eefd0 | 2013-06-24 21:40:50 +0200 | [diff] [blame] | 319 | /* IDE buses */ |
Mark Cave-Ayland | 0fcd2a8 | 2018-05-03 21:24:41 +0100 | [diff] [blame] | 320 | macio_realize_ide(s, &ns->ide[0], |
| 321 | qdev_get_gpio_in(pic_dev, NEWWORLD_IDE0_IRQ), |
| 322 | qdev_get_gpio_in(pic_dev, NEWWORLD_IDE0_DMA_IRQ), |
| 323 | 0x16, &err); |
| 324 | if (err) { |
| 325 | error_propagate(errp, err); |
| 326 | return; |
| 327 | } |
Andreas Färber | 07a7484 | 2013-01-23 23:04:01 +0000 | [diff] [blame] | 328 | |
Mark Cave-Ayland | 0fcd2a8 | 2018-05-03 21:24:41 +0100 | [diff] [blame] | 329 | macio_realize_ide(s, &ns->ide[1], |
| 330 | qdev_get_gpio_in(pic_dev, NEWWORLD_IDE1_IRQ), |
| 331 | qdev_get_gpio_in(pic_dev, NEWWORLD_IDE1_DMA_IRQ), |
| 332 | 0x1a, &err); |
| 333 | if (err) { |
| 334 | error_propagate(errp, err); |
| 335 | return; |
Andreas Färber | 07a7484 | 2013-01-23 23:04:01 +0000 | [diff] [blame] | 336 | } |
| 337 | |
Alexander Graf | a0f9fdf | 2013-06-30 05:15:14 +0200 | [diff] [blame] | 338 | /* Timer */ |
Gonglei | 6c5819c | 2015-02-27 15:50:14 +0800 | [diff] [blame] | 339 | timer_memory = g_new(MemoryRegion, 1); |
Alexander Graf | a0f9fdf | 2013-06-30 05:15:14 +0200 | [diff] [blame] | 340 | memory_region_init_io(timer_memory, OBJECT(s), &timer_ops, NULL, "timer", |
| 341 | 0x1000); |
| 342 | memory_region_add_subregion(&s->bar, 0x15000, timer_memory); |
Mark Cave-Ayland | 7c4166a | 2018-06-12 17:43:58 +0100 | [diff] [blame] | 343 | |
| 344 | if (ns->has_pmu) { |
| 345 | /* GPIOs */ |
| 346 | sysbus_dev = SYS_BUS_DEVICE(&ns->gpio); |
| 347 | object_property_set_link(OBJECT(&ns->gpio), OBJECT(pic_dev), "pic", |
| 348 | &error_abort); |
| 349 | memory_region_add_subregion(&s->bar, 0x50, |
| 350 | sysbus_mmio_get_region(sysbus_dev, 0)); |
| 351 | object_property_set_bool(OBJECT(&ns->gpio), true, "realized", &err); |
Mark Cave-Ayland | d811d61 | 2018-06-12 17:44:02 +0100 | [diff] [blame] | 352 | |
| 353 | /* PMU */ |
Philippe Mathieu-Daudé | 954d976 | 2019-05-07 18:34:02 +0200 | [diff] [blame] | 354 | object_initialize_child(OBJECT(s), "pmu", &s->pmu, sizeof(s->pmu), |
| 355 | TYPE_VIA_PMU, &error_abort, NULL); |
Mark Cave-Ayland | d811d61 | 2018-06-12 17:44:02 +0100 | [diff] [blame] | 356 | object_property_set_link(OBJECT(&s->pmu), OBJECT(sysbus_dev), "gpio", |
| 357 | &error_abort); |
| 358 | qdev_prop_set_bit(DEVICE(&s->pmu), "has-adb", ns->has_adb); |
Mark Cave-Ayland | bf31c56 | 2018-08-29 17:59:06 +0100 | [diff] [blame] | 359 | qdev_set_parent_bus(DEVICE(&s->pmu), BUS(&s->macio_bus)); |
Mark Cave-Ayland | d811d61 | 2018-06-12 17:44:02 +0100 | [diff] [blame] | 360 | |
| 361 | object_property_set_bool(OBJECT(&s->pmu), true, "realized", &err); |
| 362 | if (err) { |
| 363 | error_propagate(errp, err); |
| 364 | return; |
| 365 | } |
| 366 | sysbus_dev = SYS_BUS_DEVICE(&s->pmu); |
| 367 | sysbus_connect_irq(sysbus_dev, 0, qdev_get_gpio_in(pic_dev, |
| 368 | NEWWORLD_PMU_IRQ)); |
| 369 | memory_region_add_subregion(&s->bar, 0x16000, |
| 370 | sysbus_mmio_get_region(sysbus_dev, 0)); |
| 371 | } else { |
Markus Armbruster | 3320843 | 2020-06-09 14:23:25 +0200 | [diff] [blame] | 372 | object_unparent(OBJECT(&ns->gpio)); |
| 373 | |
Mark Cave-Ayland | d811d61 | 2018-06-12 17:44:02 +0100 | [diff] [blame] | 374 | /* CUDA */ |
Philippe Mathieu-Daudé | 954d976 | 2019-05-07 18:34:02 +0200 | [diff] [blame] | 375 | object_initialize_child(OBJECT(s), "cuda", &s->cuda, sizeof(s->cuda), |
| 376 | TYPE_CUDA, &error_abort, NULL); |
Mark Cave-Ayland | bf31c56 | 2018-08-29 17:59:06 +0100 | [diff] [blame] | 377 | qdev_set_parent_bus(DEVICE(&s->cuda), BUS(&s->macio_bus)); |
Mark Cave-Ayland | d811d61 | 2018-06-12 17:44:02 +0100 | [diff] [blame] | 378 | qdev_prop_set_uint64(DEVICE(&s->cuda), "timebase-frequency", |
| 379 | s->frequency); |
| 380 | |
| 381 | object_property_set_bool(OBJECT(&s->cuda), true, "realized", &err); |
| 382 | if (err) { |
| 383 | error_propagate(errp, err); |
| 384 | return; |
| 385 | } |
| 386 | sysbus_dev = SYS_BUS_DEVICE(&s->cuda); |
| 387 | sysbus_connect_irq(sysbus_dev, 0, qdev_get_gpio_in(pic_dev, |
| 388 | NEWWORLD_CUDA_IRQ)); |
| 389 | memory_region_add_subregion(&s->bar, 0x16000, |
| 390 | sysbus_mmio_get_region(sysbus_dev, 0)); |
Mark Cave-Ayland | 7c4166a | 2018-06-12 17:43:58 +0100 | [diff] [blame] | 391 | } |
Andreas Färber | d037834 | 2013-01-23 23:03:57 +0000 | [diff] [blame] | 392 | } |
| 393 | |
Andreas Färber | 07a7484 | 2013-01-23 23:04:01 +0000 | [diff] [blame] | 394 | static void macio_newworld_init(Object *obj) |
| 395 | { |
| 396 | MacIOState *s = MACIO(obj); |
| 397 | NewWorldMacIOState *ns = NEWWORLD_MACIO(obj); |
| 398 | int i; |
Andreas Färber | 07a7484 | 2013-01-23 23:04:01 +0000 | [diff] [blame] | 399 | |
Mark Cave-Ayland | dda12e9 | 2018-02-28 20:32:41 +0000 | [diff] [blame] | 400 | object_property_add_link(obj, "pic", TYPE_OPENPIC, |
| 401 | (Object **) &ns->pic, |
| 402 | qdev_prop_allow_set_link_before_realize, |
Markus Armbruster | d262312 | 2020-05-05 17:29:22 +0200 | [diff] [blame] | 403 | 0); |
Mark Cave-Ayland | dda12e9 | 2018-02-28 20:32:41 +0000 | [diff] [blame] | 404 | |
Mark Cave-Ayland | bf31c56 | 2018-08-29 17:59:06 +0100 | [diff] [blame] | 405 | macio_init_child_obj(s, "gpio", &ns->gpio, sizeof(ns->gpio), |
| 406 | TYPE_MACIO_GPIO); |
Mark Cave-Ayland | 7c4166a | 2018-06-12 17:43:58 +0100 | [diff] [blame] | 407 | |
Andreas Färber | 07a7484 | 2013-01-23 23:04:01 +0000 | [diff] [blame] | 408 | for (i = 0; i < 2; i++) { |
Andreas Färber | 213f0c4 | 2013-08-23 19:37:12 +0200 | [diff] [blame] | 409 | macio_init_ide(s, &ns->ide[i], sizeof(ns->ide[i]), i); |
Andreas Färber | 07a7484 | 2013-01-23 23:04:01 +0000 | [diff] [blame] | 410 | } |
| 411 | } |
| 412 | |
Andreas Färber | fcf1bba | 2013-01-23 23:03:55 +0000 | [diff] [blame] | 413 | static void macio_instance_init(Object *obj) |
| 414 | { |
| 415 | MacIOState *s = MACIO(obj); |
| 416 | |
Paolo Bonzini | 81e0ab4 | 2015-10-01 10:59:51 +0200 | [diff] [blame] | 417 | memory_region_init(&s->bar, obj, "macio", 0x80000); |
Andreas Färber | 07a7484 | 2013-01-23 23:04:01 +0000 | [diff] [blame] | 418 | |
Mark Cave-Ayland | bf31c56 | 2018-08-29 17:59:06 +0100 | [diff] [blame] | 419 | qbus_create_inplace(&s->macio_bus, sizeof(s->macio_bus), TYPE_MACIO_BUS, |
| 420 | DEVICE(obj), "macio.0"); |
Mark Cave-Ayland | 343bd85 | 2018-02-28 20:32:33 +0000 | [diff] [blame] | 421 | |
Mark Cave-Ayland | bf31c56 | 2018-08-29 17:59:06 +0100 | [diff] [blame] | 422 | macio_init_child_obj(s, "dbdma", &s->dbdma, sizeof(s->dbdma), |
| 423 | TYPE_MAC_DBDMA); |
| 424 | |
| 425 | macio_init_child_obj(s, "escc", &s->escc, sizeof(s->escc), TYPE_ESCC); |
Andreas Färber | fcf1bba | 2013-01-23 23:03:55 +0000 | [diff] [blame] | 426 | } |
| 427 | |
Mark Cave-Ayland | 0263592 | 2015-02-09 22:40:44 +0000 | [diff] [blame] | 428 | static const VMStateDescription vmstate_macio_oldworld = { |
| 429 | .name = "macio-oldworld", |
| 430 | .version_id = 0, |
| 431 | .minimum_version_id = 0, |
| 432 | .fields = (VMStateField[]) { |
| 433 | VMSTATE_PCI_DEVICE(parent_obj.parent, OldWorldMacIOState), |
| 434 | VMSTATE_END_OF_LIST() |
| 435 | } |
| 436 | }; |
| 437 | |
Andreas Färber | d037834 | 2013-01-23 23:03:57 +0000 | [diff] [blame] | 438 | static void macio_oldworld_class_init(ObjectClass *oc, void *data) |
| 439 | { |
| 440 | PCIDeviceClass *pdc = PCI_DEVICE_CLASS(oc); |
Mark Cave-Ayland | 0263592 | 2015-02-09 22:40:44 +0000 | [diff] [blame] | 441 | DeviceClass *dc = DEVICE_CLASS(oc); |
Andreas Färber | d037834 | 2013-01-23 23:03:57 +0000 | [diff] [blame] | 442 | |
Markus Armbruster | 62e9cd7 | 2015-03-17 08:46:15 +0100 | [diff] [blame] | 443 | pdc->realize = macio_oldworld_realize; |
Andreas Färber | d037834 | 2013-01-23 23:03:57 +0000 | [diff] [blame] | 444 | pdc->device_id = PCI_DEVICE_ID_APPLE_343S1201; |
Mark Cave-Ayland | 0263592 | 2015-02-09 22:40:44 +0000 | [diff] [blame] | 445 | dc->vmsd = &vmstate_macio_oldworld; |
Andreas Färber | d037834 | 2013-01-23 23:03:57 +0000 | [diff] [blame] | 446 | } |
| 447 | |
Mark Cave-Ayland | 0263592 | 2015-02-09 22:40:44 +0000 | [diff] [blame] | 448 | static const VMStateDescription vmstate_macio_newworld = { |
| 449 | .name = "macio-newworld", |
| 450 | .version_id = 0, |
| 451 | .minimum_version_id = 0, |
| 452 | .fields = (VMStateField[]) { |
| 453 | VMSTATE_PCI_DEVICE(parent_obj.parent, NewWorldMacIOState), |
| 454 | VMSTATE_END_OF_LIST() |
| 455 | } |
| 456 | }; |
| 457 | |
Mark Cave-Ayland | f1114c1 | 2018-06-12 17:43:57 +0100 | [diff] [blame] | 458 | static Property macio_newworld_properties[] = { |
| 459 | DEFINE_PROP_BOOL("has-pmu", NewWorldMacIOState, has_pmu, false), |
| 460 | DEFINE_PROP_BOOL("has-adb", NewWorldMacIOState, has_adb, false), |
| 461 | DEFINE_PROP_END_OF_LIST() |
| 462 | }; |
| 463 | |
Andreas Färber | d037834 | 2013-01-23 23:03:57 +0000 | [diff] [blame] | 464 | static void macio_newworld_class_init(ObjectClass *oc, void *data) |
| 465 | { |
| 466 | PCIDeviceClass *pdc = PCI_DEVICE_CLASS(oc); |
Mark Cave-Ayland | 0263592 | 2015-02-09 22:40:44 +0000 | [diff] [blame] | 467 | DeviceClass *dc = DEVICE_CLASS(oc); |
Andreas Färber | d037834 | 2013-01-23 23:03:57 +0000 | [diff] [blame] | 468 | |
Markus Armbruster | 62e9cd7 | 2015-03-17 08:46:15 +0100 | [diff] [blame] | 469 | pdc->realize = macio_newworld_realize; |
Andreas Färber | d037834 | 2013-01-23 23:03:57 +0000 | [diff] [blame] | 470 | pdc->device_id = PCI_DEVICE_ID_APPLE_UNI_N_KEYL; |
Mark Cave-Ayland | 0263592 | 2015-02-09 22:40:44 +0000 | [diff] [blame] | 471 | dc->vmsd = &vmstate_macio_newworld; |
Marc-André Lureau | 4f67d30 | 2020-01-10 19:30:32 +0400 | [diff] [blame] | 472 | device_class_set_props(dc, macio_newworld_properties); |
Andreas Färber | d037834 | 2013-01-23 23:03:57 +0000 | [diff] [blame] | 473 | } |
| 474 | |
Alexander Graf | b981289 | 2014-07-13 22:31:53 +0200 | [diff] [blame] | 475 | static Property macio_properties[] = { |
| 476 | DEFINE_PROP_UINT64("frequency", MacIOState, frequency, 0), |
| 477 | DEFINE_PROP_END_OF_LIST() |
| 478 | }; |
| 479 | |
Anthony Liguori | 40021f0 | 2011-12-04 12:22:06 -0600 | [diff] [blame] | 480 | static void macio_class_init(ObjectClass *klass, void *data) |
| 481 | { |
| 482 | PCIDeviceClass *k = PCI_DEVICE_CLASS(klass); |
Alexander Graf | b981289 | 2014-07-13 22:31:53 +0200 | [diff] [blame] | 483 | DeviceClass *dc = DEVICE_CLASS(klass); |
Anthony Liguori | 40021f0 | 2011-12-04 12:22:06 -0600 | [diff] [blame] | 484 | |
Anthony Liguori | 40021f0 | 2011-12-04 12:22:06 -0600 | [diff] [blame] | 485 | k->vendor_id = PCI_VENDOR_ID_APPLE; |
| 486 | k->class_id = PCI_CLASS_OTHERS << 8; |
Marc-André Lureau | 4f67d30 | 2020-01-10 19:30:32 +0400 | [diff] [blame] | 487 | device_class_set_props(dc, macio_properties); |
Laurent Vivier | f9f2a9f | 2015-09-26 18:22:10 +0200 | [diff] [blame] | 488 | set_bit(DEVICE_CATEGORY_BRIDGE, dc->categories); |
Thomas Huth | 1ca15d8 | 2018-03-07 15:22:54 +0100 | [diff] [blame] | 489 | /* Reason: Uses serial_hds in macio_instance_init */ |
| 490 | dc->user_creatable = false; |
Anthony Liguori | 40021f0 | 2011-12-04 12:22:06 -0600 | [diff] [blame] | 491 | } |
| 492 | |
Mark Cave-Ayland | bf31c56 | 2018-08-29 17:59:06 +0100 | [diff] [blame] | 493 | static const TypeInfo macio_bus_info = { |
| 494 | .name = TYPE_MACIO_BUS, |
Markus Armbruster | 6741a34 | 2020-06-09 14:23:30 +0200 | [diff] [blame^] | 495 | .parent = TYPE_SYSTEM_BUS, |
Mark Cave-Ayland | bf31c56 | 2018-08-29 17:59:06 +0100 | [diff] [blame] | 496 | .instance_size = sizeof(MacIOBusState), |
| 497 | }; |
| 498 | |
Andreas Färber | d037834 | 2013-01-23 23:03:57 +0000 | [diff] [blame] | 499 | static const TypeInfo macio_oldworld_type_info = { |
| 500 | .name = TYPE_OLDWORLD_MACIO, |
| 501 | .parent = TYPE_MACIO, |
Andreas Färber | 95ed3b7 | 2013-01-23 23:04:00 +0000 | [diff] [blame] | 502 | .instance_size = sizeof(OldWorldMacIOState), |
| 503 | .instance_init = macio_oldworld_init, |
Andreas Färber | d037834 | 2013-01-23 23:03:57 +0000 | [diff] [blame] | 504 | .class_init = macio_oldworld_class_init, |
| 505 | }; |
| 506 | |
| 507 | static const TypeInfo macio_newworld_type_info = { |
| 508 | .name = TYPE_NEWWORLD_MACIO, |
| 509 | .parent = TYPE_MACIO, |
Andreas Färber | 07a7484 | 2013-01-23 23:04:01 +0000 | [diff] [blame] | 510 | .instance_size = sizeof(NewWorldMacIOState), |
| 511 | .instance_init = macio_newworld_init, |
Andreas Färber | d037834 | 2013-01-23 23:03:57 +0000 | [diff] [blame] | 512 | .class_init = macio_newworld_class_init, |
| 513 | }; |
| 514 | |
Andreas Färber | fcf1bba | 2013-01-23 23:03:55 +0000 | [diff] [blame] | 515 | static const TypeInfo macio_type_info = { |
| 516 | .name = TYPE_MACIO, |
Anthony Liguori | 39bffca | 2011-12-07 21:34:16 -0600 | [diff] [blame] | 517 | .parent = TYPE_PCI_DEVICE, |
| 518 | .instance_size = sizeof(MacIOState), |
Andreas Färber | fcf1bba | 2013-01-23 23:03:55 +0000 | [diff] [blame] | 519 | .instance_init = macio_instance_init, |
Andreas Färber | d037834 | 2013-01-23 23:03:57 +0000 | [diff] [blame] | 520 | .abstract = true, |
Anthony Liguori | 39bffca | 2011-12-07 21:34:16 -0600 | [diff] [blame] | 521 | .class_init = macio_class_init, |
Eduardo Habkost | fd3b02c | 2017-09-27 16:56:34 -0300 | [diff] [blame] | 522 | .interfaces = (InterfaceInfo[]) { |
| 523 | { INTERFACE_CONVENTIONAL_PCI_DEVICE }, |
| 524 | { }, |
| 525 | }, |
Anthony Liguori | d8c51b0 | 2011-12-21 16:14:09 -0600 | [diff] [blame] | 526 | }; |
| 527 | |
Andreas Färber | 83f7d43 | 2012-02-09 15:20:55 +0100 | [diff] [blame] | 528 | static void macio_register_types(void) |
Anthony Liguori | d8c51b0 | 2011-12-21 16:14:09 -0600 | [diff] [blame] | 529 | { |
Mark Cave-Ayland | bf31c56 | 2018-08-29 17:59:06 +0100 | [diff] [blame] | 530 | type_register_static(&macio_bus_info); |
Andreas Färber | fcf1bba | 2013-01-23 23:03:55 +0000 | [diff] [blame] | 531 | type_register_static(&macio_type_info); |
Andreas Färber | d037834 | 2013-01-23 23:03:57 +0000 | [diff] [blame] | 532 | type_register_static(&macio_oldworld_type_info); |
| 533 | type_register_static(&macio_newworld_type_info); |
Anthony Liguori | d8c51b0 | 2011-12-21 16:14:09 -0600 | [diff] [blame] | 534 | } |
| 535 | |
Andreas Färber | 83f7d43 | 2012-02-09 15:20:55 +0100 | [diff] [blame] | 536 | type_init(macio_register_types) |