1fa2ba3b8SLaurent Vivier /* 2fa2ba3b8SLaurent Vivier * Copyright (c) 2013-2018 Laurent Vivier <laurent@vivier.eu> 3fa2ba3b8SLaurent Vivier * 4fa2ba3b8SLaurent Vivier * This work is licensed under the terms of the GNU GPL, version 2 or later. 5fa2ba3b8SLaurent Vivier * See the COPYING file in the top-level directory. 6fa2ba3b8SLaurent Vivier * 7fa2ba3b8SLaurent Vivier */ 8fa2ba3b8SLaurent Vivier 9fa2ba3b8SLaurent Vivier #include "qemu/osdep.h" 10fa2ba3b8SLaurent Vivier #include "hw/sysbus.h" 11fa2ba3b8SLaurent Vivier #include "hw/nubus/mac-nubus-bridge.h" 12fa2ba3b8SLaurent Vivier 13fa2ba3b8SLaurent Vivier 14fa2ba3b8SLaurent Vivier static void mac_nubus_bridge_init(Object *obj) 15fa2ba3b8SLaurent Vivier { 16fa2ba3b8SLaurent Vivier MacNubusState *s = MAC_NUBUS_BRIDGE(obj); 17fa2ba3b8SLaurent Vivier SysBusDevice *sbd = SYS_BUS_DEVICE(obj); 18fa2ba3b8SLaurent Vivier 19fa2ba3b8SLaurent Vivier s->bus = NUBUS_BUS(qbus_create(TYPE_NUBUS_BUS, DEVICE(s), NULL)); 20fa2ba3b8SLaurent Vivier 2103deab99SMark Cave-Ayland /* Macintosh only has slots 0x9 to 0xe available */ 2203deab99SMark Cave-Ayland s->bus->slot_available_mask = MAKE_64BIT_MASK(MAC_NUBUS_FIRST_SLOT, 2303deab99SMark Cave-Ayland MAC_NUBUS_SLOT_NB); 2403deab99SMark Cave-Ayland 25*62437f90SMark Cave-Ayland /* Aliases for slots 0x9 to 0xe */ 26*62437f90SMark Cave-Ayland memory_region_init_alias(&s->super_slot_alias, obj, "super-slot-alias", 27*62437f90SMark Cave-Ayland &s->bus->nubus_mr, 28*62437f90SMark Cave-Ayland MAC_NUBUS_FIRST_SLOT * NUBUS_SUPER_SLOT_SIZE, 29*62437f90SMark Cave-Ayland MAC_NUBUS_SLOT_NB * NUBUS_SUPER_SLOT_SIZE); 30*62437f90SMark Cave-Ayland 31*62437f90SMark Cave-Ayland memory_region_init_alias(&s->slot_alias, obj, "slot-alias", 32*62437f90SMark Cave-Ayland &s->bus->nubus_mr, 33*62437f90SMark Cave-Ayland NUBUS_SLOT_BASE + 34*62437f90SMark Cave-Ayland MAC_NUBUS_FIRST_SLOT * NUBUS_SLOT_SIZE, 35*62437f90SMark Cave-Ayland MAC_NUBUS_SLOT_NB * NUBUS_SLOT_SIZE); 36*62437f90SMark Cave-Ayland 37*62437f90SMark Cave-Ayland sysbus_init_mmio(sbd, &s->super_slot_alias); 38*62437f90SMark Cave-Ayland sysbus_init_mmio(sbd, &s->slot_alias); 39fa2ba3b8SLaurent Vivier } 40fa2ba3b8SLaurent Vivier 41fa2ba3b8SLaurent Vivier static void mac_nubus_bridge_class_init(ObjectClass *klass, void *data) 42fa2ba3b8SLaurent Vivier { 43fa2ba3b8SLaurent Vivier DeviceClass *dc = DEVICE_CLASS(klass); 44fa2ba3b8SLaurent Vivier 45fa2ba3b8SLaurent Vivier dc->desc = "Nubus bridge"; 46fa2ba3b8SLaurent Vivier } 47fa2ba3b8SLaurent Vivier 48fa2ba3b8SLaurent Vivier static const TypeInfo mac_nubus_bridge_info = { 49fa2ba3b8SLaurent Vivier .name = TYPE_MAC_NUBUS_BRIDGE, 50fa2ba3b8SLaurent Vivier .parent = TYPE_NUBUS_BRIDGE, 51fa2ba3b8SLaurent Vivier .instance_init = mac_nubus_bridge_init, 52fa2ba3b8SLaurent Vivier .instance_size = sizeof(MacNubusState), 53fa2ba3b8SLaurent Vivier .class_init = mac_nubus_bridge_class_init, 54fa2ba3b8SLaurent Vivier }; 55fa2ba3b8SLaurent Vivier 56fa2ba3b8SLaurent Vivier static void mac_nubus_bridge_register_types(void) 57fa2ba3b8SLaurent Vivier { 58fa2ba3b8SLaurent Vivier type_register_static(&mac_nubus_bridge_info); 59fa2ba3b8SLaurent Vivier } 60fa2ba3b8SLaurent Vivier 61fa2ba3b8SLaurent Vivier type_init(mac_nubus_bridge_register_types) 62