mac-nubus-bridge.c 2.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263
  1. /*
  2. * QEMU Macintosh Nubus
  3. *
  4. * Copyright (c) 2013-2018 Laurent Vivier <laurent@vivier.eu>
  5. *
  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. #include "qemu/osdep.h"
  11. #include "hw/sysbus.h"
  12. #include "hw/nubus/mac-nubus-bridge.h"
  13. static void mac_nubus_bridge_init(Object *obj)
  14. {
  15. MacNubusBridge *s = MAC_NUBUS_BRIDGE(obj);
  16. NubusBridge *nb = NUBUS_BRIDGE(obj);
  17. SysBusDevice *sbd = SYS_BUS_DEVICE(obj);
  18. NubusBus *bus = &nb->bus;
  19. /* Macintosh only has slots 0x9 to 0xe available */
  20. bus->slot_available_mask = MAKE_64BIT_MASK(MAC_NUBUS_FIRST_SLOT,
  21. MAC_NUBUS_SLOT_NB);
  22. /* Aliases for slots 0x9 to 0xe */
  23. memory_region_init_alias(&s->super_slot_alias, obj, "super-slot-alias",
  24. &bus->nubus_mr,
  25. MAC_NUBUS_FIRST_SLOT * NUBUS_SUPER_SLOT_SIZE,
  26. MAC_NUBUS_SLOT_NB * NUBUS_SUPER_SLOT_SIZE);
  27. memory_region_init_alias(&s->slot_alias, obj, "slot-alias",
  28. &bus->nubus_mr,
  29. NUBUS_SLOT_BASE +
  30. MAC_NUBUS_FIRST_SLOT * NUBUS_SLOT_SIZE,
  31. MAC_NUBUS_SLOT_NB * NUBUS_SLOT_SIZE);
  32. sysbus_init_mmio(sbd, &s->super_slot_alias);
  33. sysbus_init_mmio(sbd, &s->slot_alias);
  34. }
  35. static void mac_nubus_bridge_class_init(ObjectClass *klass, void *data)
  36. {
  37. DeviceClass *dc = DEVICE_CLASS(klass);
  38. dc->desc = "Nubus bridge";
  39. }
  40. static const TypeInfo mac_nubus_bridge_info = {
  41. .name = TYPE_MAC_NUBUS_BRIDGE,
  42. .parent = TYPE_NUBUS_BRIDGE,
  43. .instance_init = mac_nubus_bridge_init,
  44. .instance_size = sizeof(MacNubusBridge),
  45. .class_init = mac_nubus_bridge_class_init,
  46. };
  47. static void mac_nubus_bridge_register_types(void)
  48. {
  49. type_register_static(&mac_nubus_bridge_info);
  50. }
  51. type_init(mac_nubus_bridge_register_types)