]>
Commit | Line | Data |
---|---|---|
cb9c377f | 1 | #ifndef HW_LM32_H |
175de524 | 2 | #define HW_LM32_H |
cb9c377f | 3 | |
a0b97927 | 4 | #include "hw/char/lm32_juart.h" |
a27bd6c7 | 5 | #include "hw/qdev-properties.h" |
3e80f690 | 6 | #include "qapi/error.h" |
f89286ae MW |
7 | |
8 | static inline DeviceState *lm32_pic_init(qemu_irq cpu_irq) | |
9 | { | |
10 | DeviceState *dev; | |
11 | SysBusDevice *d; | |
12 | ||
3e80f690 | 13 | dev = qdev_new("lm32-pic"); |
1356b98d | 14 | d = SYS_BUS_DEVICE(dev); |
3c6ef471 | 15 | sysbus_realize_and_unref(d, &error_fatal); |
f89286ae MW |
16 | sysbus_connect_irq(d, 0, cpu_irq); |
17 | ||
18 | return dev; | |
19 | } | |
20 | ||
0ec7b3e7 | 21 | static inline DeviceState *lm32_juart_init(Chardev *chr) |
f89286ae MW |
22 | { |
23 | DeviceState *dev; | |
24 | ||
3e80f690 | 25 | dev = qdev_new(TYPE_LM32_JUART); |
c2ddaa62 | 26 | qdev_prop_set_chr(dev, "chardev", chr); |
3c6ef471 | 27 | sysbus_realize_and_unref(SYS_BUS_DEVICE(dev), &error_fatal); |
f89286ae MW |
28 | |
29 | return dev; | |
30 | } | |
cb9c377f | 31 | |
7aaefcaf XZ |
32 | static inline DeviceState *lm32_uart_create(hwaddr addr, |
33 | qemu_irq irq, | |
0ec7b3e7 | 34 | Chardev *chr) |
7aaefcaf XZ |
35 | { |
36 | DeviceState *dev; | |
37 | SysBusDevice *s; | |
38 | ||
3e80f690 | 39 | dev = qdev_new("lm32-uart"); |
7aaefcaf XZ |
40 | s = SYS_BUS_DEVICE(dev); |
41 | qdev_prop_set_chr(dev, "chardev", chr); | |
3c6ef471 | 42 | sysbus_realize_and_unref(s, &error_fatal); |
7aaefcaf XZ |
43 | sysbus_mmio_map(s, 0, addr); |
44 | sysbus_connect_irq(s, 0, irq); | |
45 | return dev; | |
46 | } | |
47 | ||
cb9c377f | 48 | #endif |