blob: a0da5a8b2fafb90e65c968ce67635f1fb36aa2ae [file] [log] [blame]
Laurent Vivierfa2ba3b2019-10-26 18:45:42 +02001/*
Mark Cave-Aylandf48d6132021-09-24 08:38:02 +01002 * QEMU Macintosh Nubus
3 *
4 * Copyright (c) 2013-2018 Laurent Vivier <laurent@vivier.eu>
Laurent Vivierfa2ba3b2019-10-26 18:45:42 +02005 *
6 * This work is licensed under the terms of the GNU GPL, version 2 or later.
7 * See the COPYING file in the top-level directory.
8 *
9 */
10
11#include "qemu/osdep.h"
12#include "hw/sysbus.h"
13#include "hw/nubus/mac-nubus-bridge.h"
14
15
16static void mac_nubus_bridge_init(Object *obj)
17{
Mark Cave-Aylandf48d6132021-09-24 08:38:02 +010018 MacNubusBridge *s = MAC_NUBUS_BRIDGE(obj);
Mark Cave-Ayland1fa04232021-09-24 08:38:03 +010019 NubusBridge *nb = NUBUS_BRIDGE(obj);
Laurent Vivierfa2ba3b2019-10-26 18:45:42 +020020 SysBusDevice *sbd = SYS_BUS_DEVICE(obj);
Mark Cave-Aylandd585d892021-09-24 08:38:04 +010021 NubusBus *bus = &nb->bus;
Laurent Vivierfa2ba3b2019-10-26 18:45:42 +020022
Mark Cave-Ayland03deab92021-09-24 08:37:52 +010023 /* Macintosh only has slots 0x9 to 0xe available */
Mark Cave-Aylandd585d892021-09-24 08:38:04 +010024 bus->slot_available_mask = MAKE_64BIT_MASK(MAC_NUBUS_FIRST_SLOT,
25 MAC_NUBUS_SLOT_NB);
Mark Cave-Ayland03deab92021-09-24 08:37:52 +010026
Mark Cave-Ayland62437f92021-09-24 08:38:00 +010027 /* Aliases for slots 0x9 to 0xe */
28 memory_region_init_alias(&s->super_slot_alias, obj, "super-slot-alias",
Mark Cave-Aylandd585d892021-09-24 08:38:04 +010029 &bus->nubus_mr,
Mark Cave-Ayland62437f92021-09-24 08:38:00 +010030 MAC_NUBUS_FIRST_SLOT * NUBUS_SUPER_SLOT_SIZE,
31 MAC_NUBUS_SLOT_NB * NUBUS_SUPER_SLOT_SIZE);
32
33 memory_region_init_alias(&s->slot_alias, obj, "slot-alias",
Mark Cave-Aylandd585d892021-09-24 08:38:04 +010034 &bus->nubus_mr,
Mark Cave-Ayland62437f92021-09-24 08:38:00 +010035 NUBUS_SLOT_BASE +
36 MAC_NUBUS_FIRST_SLOT * NUBUS_SLOT_SIZE,
37 MAC_NUBUS_SLOT_NB * NUBUS_SLOT_SIZE);
38
39 sysbus_init_mmio(sbd, &s->super_slot_alias);
40 sysbus_init_mmio(sbd, &s->slot_alias);
Laurent Vivierfa2ba3b2019-10-26 18:45:42 +020041}
42
43static void mac_nubus_bridge_class_init(ObjectClass *klass, void *data)
44{
45 DeviceClass *dc = DEVICE_CLASS(klass);
46
47 dc->desc = "Nubus bridge";
48}
49
50static const TypeInfo mac_nubus_bridge_info = {
51 .name = TYPE_MAC_NUBUS_BRIDGE,
52 .parent = TYPE_NUBUS_BRIDGE,
53 .instance_init = mac_nubus_bridge_init,
Mark Cave-Aylandf48d6132021-09-24 08:38:02 +010054 .instance_size = sizeof(MacNubusBridge),
Laurent Vivierfa2ba3b2019-10-26 18:45:42 +020055 .class_init = mac_nubus_bridge_class_init,
56};
57
58static void mac_nubus_bridge_register_types(void)
59{
60 type_register_static(&mac_nubus_bridge_info);
61}
62
63type_init(mac_nubus_bridge_register_types)