]> git.proxmox.com Git - qemu.git/blame - hw/ssi.c
sun4u: implement interrupt clearing registers
[qemu.git] / hw / ssi.c
CommitLineData
90d37239
PB
1/*
2 * QEMU Synchronous Serial Interface support
3 *
4 * Copyright (c) 2009 CodeSourcery.
5 * Written by Paul Brook
6 *
8e31bf38 7 * This code is licensed under the GNU GPL v2.
6b620ca3
PB
8 *
9 * Contributions after 2012-01-13 are licensed under the terms of the
10 * GNU GPL, version 2 or (at your option) any later version.
90d37239
PB
11 */
12
13#include "ssi.h"
14
15struct SSIBus {
02e2da45 16 BusState qbus;
90d37239
PB
17};
18
10c4c98a
GH
19static struct BusInfo ssi_bus_info = {
20 .name = "SSI",
21 .size = sizeof(SSIBus),
22};
23
d307af79 24static int ssi_slave_init(DeviceState *dev)
90d37239 25{
cd6c4cf2
AL
26 SSISlave *s = SSI_SLAVE(dev);
27 SSISlaveClass *ssc = SSI_SLAVE_GET_CLASS(s);
02e2da45
PB
28 SSIBus *bus;
29
30 bus = FROM_QBUS(SSIBus, qdev_get_parent_bus(dev));
d8bb00d6
PB
31 if (QTAILQ_FIRST(&bus->qbus.children) != dev
32 || QTAILQ_NEXT(dev, sibling) != NULL) {
02e2da45
PB
33 hw_error("Too many devices on SSI bus");
34 }
90d37239 35
cd6c4cf2 36 return ssc->init(s);
90d37239
PB
37}
38
39bffca2 39static void ssi_slave_class_init(ObjectClass *klass, void *data)
90d37239 40{
39bffca2
AL
41 DeviceClass *dc = DEVICE_CLASS(klass);
42 dc->init = ssi_slave_init;
43 dc->bus_info = &ssi_bus_info;
90d37239
PB
44}
45
39bffca2
AL
46static TypeInfo ssi_slave_info = {
47 .name = TYPE_SSI_SLAVE,
48 .parent = TYPE_DEVICE,
49 .class_init = ssi_slave_class_init,
50 .class_size = sizeof(SSISlaveClass),
51 .abstract = true,
52};
53
90d37239
PB
54DeviceState *ssi_create_slave(SSIBus *bus, const char *name)
55{
56 DeviceState *dev;
02e2da45 57 dev = qdev_create(&bus->qbus, name);
e23a1b33 58 qdev_init_nofail(dev);
90d37239
PB
59 return dev;
60}
61
02e2da45 62SSIBus *ssi_create_bus(DeviceState *parent, const char *name)
90d37239 63{
02e2da45 64 BusState *bus;
10c4c98a 65 bus = qbus_create(&ssi_bus_info, parent, name);
02e2da45 66 return FROM_QBUS(SSIBus, bus);
90d37239
PB
67}
68
69uint32_t ssi_transfer(SSIBus *bus, uint32_t val)
70{
02e2da45
PB
71 DeviceState *dev;
72 SSISlave *slave;
cd6c4cf2 73 SSISlaveClass *ssc;
d8bb00d6 74 dev = QTAILQ_FIRST(&bus->qbus.children);
02e2da45 75 if (!dev) {
90d37239
PB
76 return 0;
77 }
cd6c4cf2
AL
78 slave = SSI_SLAVE(dev);
79 ssc = SSI_SLAVE_GET_CLASS(slave);
80 return ssc->transfer(slave, val);
90d37239 81}
39bffca2 82
83f7d43a 83static void ssi_slave_register_types(void)
39bffca2
AL
84{
85 type_register_static(&ssi_slave_info);
86}
87
83f7d43a 88type_init(ssi_slave_register_types)