1 #ifndef QEMU_HW_MILKYMIST_H
2 #define QEMU_HW_MILKYMIST_H
8 static inline DeviceState
*milkymist_uart_create(hwaddr base
,
13 dev
= qdev_create(NULL
, "milkymist-uart");
14 qdev_init_nofail(dev
);
15 sysbus_mmio_map(SYS_BUS_DEVICE(dev
), 0, base
);
16 sysbus_connect_irq(SYS_BUS_DEVICE(dev
), 0, irq
);
21 static inline DeviceState
*milkymist_hpdmc_create(hwaddr base
)
25 dev
= qdev_create(NULL
, "milkymist-hpdmc");
26 qdev_init_nofail(dev
);
27 sysbus_mmio_map(SYS_BUS_DEVICE(dev
), 0, base
);
32 static inline DeviceState
*milkymist_memcard_create(hwaddr base
)
36 dev
= qdev_create(NULL
, "milkymist-memcard");
37 qdev_init_nofail(dev
);
38 sysbus_mmio_map(SYS_BUS_DEVICE(dev
), 0, base
);
43 static inline DeviceState
*milkymist_vgafb_create(hwaddr base
,
44 uint32_t fb_offset
, uint32_t fb_mask
)
48 dev
= qdev_create(NULL
, "milkymist-vgafb");
49 qdev_prop_set_uint32(dev
, "fb_offset", fb_offset
);
50 qdev_prop_set_uint32(dev
, "fb_mask", fb_mask
);
51 qdev_init_nofail(dev
);
52 sysbus_mmio_map(SYS_BUS_DEVICE(dev
), 0, base
);
57 static inline DeviceState
*milkymist_sysctl_create(hwaddr base
,
58 qemu_irq gpio_irq
, qemu_irq timer0_irq
, qemu_irq timer1_irq
,
59 uint32_t freq_hz
, uint32_t system_id
, uint32_t capabilities
,
60 uint32_t gpio_strappings
)
64 dev
= qdev_create(NULL
, "milkymist-sysctl");
65 qdev_prop_set_uint32(dev
, "frequency", freq_hz
);
66 qdev_prop_set_uint32(dev
, "systemid", system_id
);
67 qdev_prop_set_uint32(dev
, "capabilities", capabilities
);
68 qdev_prop_set_uint32(dev
, "gpio_strappings", gpio_strappings
);
69 qdev_init_nofail(dev
);
70 sysbus_mmio_map(SYS_BUS_DEVICE(dev
), 0, base
);
71 sysbus_connect_irq(SYS_BUS_DEVICE(dev
), 0, gpio_irq
);
72 sysbus_connect_irq(SYS_BUS_DEVICE(dev
), 1, timer0_irq
);
73 sysbus_connect_irq(SYS_BUS_DEVICE(dev
), 2, timer1_irq
);
78 static inline DeviceState
*milkymist_pfpu_create(hwaddr base
,
83 dev
= qdev_create(NULL
, "milkymist-pfpu");
84 qdev_init_nofail(dev
);
85 sysbus_mmio_map(SYS_BUS_DEVICE(dev
), 0, base
);
86 sysbus_connect_irq(SYS_BUS_DEVICE(dev
), 0, irq
);
93 static const int glx_fbconfig_attr
[] = {
101 static inline DeviceState
*milkymist_tmu2_create(hwaddr base
,
107 GLXFBConfig
*configs
;
109 int ver_major
, ver_minor
;
111 if (display_type
== DT_NOGRAPHIC
) {
115 /* check that GLX will work */
116 d
= XOpenDisplay(NULL
);
121 if (!glXQueryVersion(d
, &ver_major
, &ver_minor
)) {
122 /* Yeah, sometimes getting the GLX version can fail.
123 * Isn't X beautiful? */
128 if ((ver_major
< 1) || ((ver_major
== 1) && (ver_minor
< 3))) {
129 printf("Your GLX version is %d.%d,"
130 "but TMU emulation needs at least 1.3. TMU disabled.\n",
131 ver_major
, ver_minor
);
136 configs
= glXChooseFBConfig(d
, 0, glx_fbconfig_attr
, &nelements
);
137 if (configs
== NULL
) {
145 dev
= qdev_create(NULL
, "milkymist-tmu2");
146 qdev_init_nofail(dev
);
147 sysbus_mmio_map(SYS_BUS_DEVICE(dev
), 0, base
);
148 sysbus_connect_irq(SYS_BUS_DEVICE(dev
), 0, irq
);
156 static inline DeviceState
*milkymist_ac97_create(hwaddr base
,
157 qemu_irq crrequest_irq
, qemu_irq crreply_irq
, qemu_irq dmar_irq
,
162 dev
= qdev_create(NULL
, "milkymist-ac97");
163 qdev_init_nofail(dev
);
164 sysbus_mmio_map(SYS_BUS_DEVICE(dev
), 0, base
);
165 sysbus_connect_irq(SYS_BUS_DEVICE(dev
), 0, crrequest_irq
);
166 sysbus_connect_irq(SYS_BUS_DEVICE(dev
), 1, crreply_irq
);
167 sysbus_connect_irq(SYS_BUS_DEVICE(dev
), 2, dmar_irq
);
168 sysbus_connect_irq(SYS_BUS_DEVICE(dev
), 3, dmaw_irq
);
173 static inline DeviceState
*milkymist_minimac_create(hwaddr base
,
174 qemu_irq rx_irq
, qemu_irq tx_irq
)
178 qemu_check_nic_model(&nd_table
[0], "minimac");
179 dev
= qdev_create(NULL
, "milkymist-minimac");
180 qdev_set_nic_properties(dev
, &nd_table
[0]);
181 qdev_init_nofail(dev
);
182 sysbus_mmio_map(SYS_BUS_DEVICE(dev
), 0, base
);
183 sysbus_connect_irq(SYS_BUS_DEVICE(dev
), 0, rx_irq
);
184 sysbus_connect_irq(SYS_BUS_DEVICE(dev
), 1, tx_irq
);
189 static inline DeviceState
*milkymist_minimac2_create(hwaddr base
,
190 hwaddr buffers_base
, qemu_irq rx_irq
, qemu_irq tx_irq
)
194 qemu_check_nic_model(&nd_table
[0], "minimac2");
195 dev
= qdev_create(NULL
, "milkymist-minimac2");
196 qdev_prop_set_taddr(dev
, "buffers_base", buffers_base
);
197 qdev_set_nic_properties(dev
, &nd_table
[0]);
198 qdev_init_nofail(dev
);
199 sysbus_mmio_map(SYS_BUS_DEVICE(dev
), 0, base
);
200 sysbus_connect_irq(SYS_BUS_DEVICE(dev
), 0, rx_irq
);
201 sysbus_connect_irq(SYS_BUS_DEVICE(dev
), 1, tx_irq
);
206 static inline DeviceState
*milkymist_softusb_create(hwaddr base
,
207 qemu_irq irq
, uint32_t pmem_base
, uint32_t pmem_size
,
208 uint32_t dmem_base
, uint32_t dmem_size
)
212 dev
= qdev_create(NULL
, "milkymist-softusb");
213 qdev_prop_set_uint32(dev
, "pmem_base", pmem_base
);
214 qdev_prop_set_uint32(dev
, "pmem_size", pmem_size
);
215 qdev_prop_set_uint32(dev
, "dmem_base", dmem_base
);
216 qdev_prop_set_uint32(dev
, "dmem_size", dmem_size
);
217 qdev_init_nofail(dev
);
218 sysbus_mmio_map(SYS_BUS_DEVICE(dev
), 0, base
);
219 sysbus_connect_irq(SYS_BUS_DEVICE(dev
), 0, irq
);
224 #endif /* QEMU_HW_MILKYMIST_H */