2019-10-26 19:45:42 +03:00
|
|
|
/*
|
2021-09-24 10:38:01 +03:00
|
|
|
* QEMU Nubus
|
2019-10-26 19:45:42 +03:00
|
|
|
*
|
|
|
|
* Copyright (c) 2013-2018 Laurent Vivier <laurent@vivier.eu>
|
|
|
|
*
|
|
|
|
* This work is licensed under the terms of the GNU GPL, version 2 or later.
|
|
|
|
* See the COPYING file in the top-level directory.
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include "qemu/osdep.h"
|
|
|
|
#include "hw/sysbus.h"
|
|
|
|
#include "hw/nubus/nubus.h"
|
|
|
|
|
2021-09-24 10:38:03 +03:00
|
|
|
|
|
|
|
static void nubus_bridge_init(Object *obj)
|
|
|
|
{
|
|
|
|
NubusBridge *s = NUBUS_BRIDGE(obj);
|
2021-09-24 10:38:04 +03:00
|
|
|
NubusBus *bus = &s->bus;
|
2021-09-24 10:38:03 +03:00
|
|
|
|
2021-09-23 15:11:51 +03:00
|
|
|
qbus_init(bus, sizeof(s->bus), TYPE_NUBUS_BUS, DEVICE(s), NULL);
|
2021-09-24 10:38:06 +03:00
|
|
|
|
|
|
|
qdev_init_gpio_out(DEVICE(s), bus->irqs, NUBUS_IRQS);
|
2021-09-24 10:38:03 +03:00
|
|
|
}
|
|
|
|
|
2021-09-24 10:38:05 +03:00
|
|
|
static Property nubus_bridge_properties[] = {
|
|
|
|
DEFINE_PROP_UINT16("slot-available-mask", NubusBridge,
|
|
|
|
bus.slot_available_mask, 0xffff),
|
|
|
|
DEFINE_PROP_END_OF_LIST()
|
|
|
|
};
|
|
|
|
|
2019-10-26 19:45:42 +03:00
|
|
|
static void nubus_bridge_class_init(ObjectClass *klass, void *data)
|
|
|
|
{
|
|
|
|
DeviceClass *dc = DEVICE_CLASS(klass);
|
|
|
|
|
|
|
|
dc->fw_name = "nubus";
|
2021-09-24 10:38:05 +03:00
|
|
|
device_class_set_props(dc, nubus_bridge_properties);
|
2019-10-26 19:45:42 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
static const TypeInfo nubus_bridge_info = {
|
|
|
|
.name = TYPE_NUBUS_BRIDGE,
|
|
|
|
.parent = TYPE_SYS_BUS_DEVICE,
|
2021-09-24 10:38:03 +03:00
|
|
|
.instance_init = nubus_bridge_init,
|
2021-09-24 10:38:01 +03:00
|
|
|
.instance_size = sizeof(NubusBridge),
|
2019-10-26 19:45:42 +03:00
|
|
|
.class_init = nubus_bridge_class_init,
|
|
|
|
};
|
|
|
|
|
|
|
|
static void nubus_register_types(void)
|
|
|
|
{
|
|
|
|
type_register_static(&nubus_bridge_info);
|
|
|
|
}
|
|
|
|
|
|
|
|
type_init(nubus_register_types)
|