root / hw / qdev.h @ 7fc2f2c0
History | View | Annotate | Download (7 kB)
1 | aae9460e | Paul Brook | #ifndef QDEV_H
|
---|---|---|---|
2 | aae9460e | Paul Brook | #define QDEV_H
|
3 | aae9460e | Paul Brook | |
4 | aae9460e | Paul Brook | #include "hw.h" |
5 | 14b41872 | Gerd Hoffmann | #include "sysemu.h" |
6 | 02e2da45 | Paul Brook | #include "sys-queue.h" |
7 | 313feaab | Gerd Hoffmann | #include "qemu-char.h" |
8 | f31d07d1 | Gerd Hoffmann | #include "qemu-option.h" |
9 | aae9460e | Paul Brook | |
10 | ee6847d1 | Gerd Hoffmann | typedef struct Property Property; |
11 | ee6847d1 | Gerd Hoffmann | |
12 | ee6847d1 | Gerd Hoffmann | typedef struct PropertyInfo PropertyInfo; |
13 | aae9460e | Paul Brook | |
14 | b6b61144 | Gerd Hoffmann | typedef struct CompatProperty CompatProperty; |
15 | b6b61144 | Gerd Hoffmann | |
16 | ee6847d1 | Gerd Hoffmann | typedef struct DeviceInfo DeviceInfo; |
17 | aae9460e | Paul Brook | |
18 | 02e2da45 | Paul Brook | typedef struct BusState BusState; |
19 | 4d6ae674 | Paul Brook | |
20 | 10c4c98a | Gerd Hoffmann | typedef struct BusInfo BusInfo; |
21 | 10c4c98a | Gerd Hoffmann | |
22 | aae9460e | Paul Brook | /* This structure should not be accessed directly. We declare it here
|
23 | aae9460e | Paul Brook | so that it can be embedded in individual device state structures. */
|
24 | 02e2da45 | Paul Brook | struct DeviceState {
|
25 | f31d07d1 | Gerd Hoffmann | const char *id; |
26 | 042f84d0 | Gerd Hoffmann | DeviceInfo *info; |
27 | 02e2da45 | Paul Brook | BusState *parent_bus; |
28 | aae9460e | Paul Brook | int num_gpio_out;
|
29 | aae9460e | Paul Brook | qemu_irq *gpio_out; |
30 | aae9460e | Paul Brook | int num_gpio_in;
|
31 | aae9460e | Paul Brook | qemu_irq *gpio_in; |
32 | 02e2da45 | Paul Brook | LIST_HEAD(, BusState) child_bus; |
33 | d271de9f | Gerd Hoffmann | int num_child_bus;
|
34 | 9d07d757 | Paul Brook | NICInfo *nd; |
35 | 02e2da45 | Paul Brook | LIST_ENTRY(DeviceState) sibling; |
36 | 02e2da45 | Paul Brook | }; |
37 | 02e2da45 | Paul Brook | |
38 | 10c4c98a | Gerd Hoffmann | typedef void (*bus_dev_printfn)(Monitor *mon, DeviceState *dev, int indent); |
39 | 10c4c98a | Gerd Hoffmann | struct BusInfo {
|
40 | 10c4c98a | Gerd Hoffmann | const char *name; |
41 | 10c4c98a | Gerd Hoffmann | size_t size; |
42 | 10c4c98a | Gerd Hoffmann | bus_dev_printfn print_dev; |
43 | ee6847d1 | Gerd Hoffmann | Property *props; |
44 | 10c4c98a | Gerd Hoffmann | }; |
45 | 02e2da45 | Paul Brook | |
46 | 02e2da45 | Paul Brook | struct BusState {
|
47 | 02e2da45 | Paul Brook | DeviceState *parent; |
48 | 10c4c98a | Gerd Hoffmann | BusInfo *info; |
49 | 02e2da45 | Paul Brook | const char *name; |
50 | 02e2da45 | Paul Brook | LIST_HEAD(, DeviceState) children; |
51 | 02e2da45 | Paul Brook | LIST_ENTRY(BusState) sibling; |
52 | aae9460e | Paul Brook | }; |
53 | aae9460e | Paul Brook | |
54 | ee6847d1 | Gerd Hoffmann | struct Property {
|
55 | ee6847d1 | Gerd Hoffmann | const char *name; |
56 | ee6847d1 | Gerd Hoffmann | PropertyInfo *info; |
57 | ee6847d1 | Gerd Hoffmann | int offset;
|
58 | ee6847d1 | Gerd Hoffmann | void *defval;
|
59 | ee6847d1 | Gerd Hoffmann | }; |
60 | ee6847d1 | Gerd Hoffmann | |
61 | ee6847d1 | Gerd Hoffmann | enum PropertyType {
|
62 | ee6847d1 | Gerd Hoffmann | PROP_TYPE_UNSPEC = 0,
|
63 | ee6847d1 | Gerd Hoffmann | PROP_TYPE_UINT16, |
64 | ee6847d1 | Gerd Hoffmann | PROP_TYPE_UINT32, |
65 | 5a053d1f | Blue Swirl | PROP_TYPE_UINT64, |
66 | ee6847d1 | Gerd Hoffmann | PROP_TYPE_TADDR, |
67 | ee6847d1 | Gerd Hoffmann | PROP_TYPE_MACADDR, |
68 | 14b41872 | Gerd Hoffmann | PROP_TYPE_DRIVE, |
69 | 313feaab | Gerd Hoffmann | PROP_TYPE_CHR, |
70 | ee6847d1 | Gerd Hoffmann | PROP_TYPE_PTR, |
71 | ee6847d1 | Gerd Hoffmann | }; |
72 | ee6847d1 | Gerd Hoffmann | |
73 | ee6847d1 | Gerd Hoffmann | struct PropertyInfo {
|
74 | ee6847d1 | Gerd Hoffmann | const char *name; |
75 | ee6847d1 | Gerd Hoffmann | size_t size; |
76 | ee6847d1 | Gerd Hoffmann | enum PropertyType type;
|
77 | ee6847d1 | Gerd Hoffmann | int (*parse)(DeviceState *dev, Property *prop, const char *str); |
78 | ee6847d1 | Gerd Hoffmann | int (*print)(DeviceState *dev, Property *prop, char *dest, size_t len); |
79 | ee6847d1 | Gerd Hoffmann | }; |
80 | ee6847d1 | Gerd Hoffmann | |
81 | b6b61144 | Gerd Hoffmann | struct CompatProperty {
|
82 | b6b61144 | Gerd Hoffmann | const char *driver; |
83 | b6b61144 | Gerd Hoffmann | const char *property; |
84 | b6b61144 | Gerd Hoffmann | const char *value; |
85 | b6b61144 | Gerd Hoffmann | }; |
86 | b6b61144 | Gerd Hoffmann | |
87 | aae9460e | Paul Brook | /*** Board API. This should go away once we have a machine config file. ***/
|
88 | aae9460e | Paul Brook | |
89 | 02e2da45 | Paul Brook | DeviceState *qdev_create(BusState *bus, const char *name); |
90 | f31d07d1 | Gerd Hoffmann | DeviceState *qdev_device_add(QemuOpts *opts); |
91 | 81a322d4 | Gerd Hoffmann | int qdev_init(DeviceState *dev);
|
92 | 02e2da45 | Paul Brook | void qdev_free(DeviceState *dev);
|
93 | aae9460e | Paul Brook | |
94 | aae9460e | Paul Brook | qemu_irq qdev_get_gpio_in(DeviceState *dev, int n);
|
95 | aae9460e | Paul Brook | void qdev_connect_gpio_out(DeviceState *dev, int n, qemu_irq pin); |
96 | aae9460e | Paul Brook | |
97 | 02e2da45 | Paul Brook | BusState *qdev_get_child_bus(DeviceState *dev, const char *name); |
98 | 4d6ae674 | Paul Brook | |
99 | aae9460e | Paul Brook | /*** Device API. ***/
|
100 | aae9460e | Paul Brook | |
101 | 81a322d4 | Gerd Hoffmann | typedef int (*qdev_initfn)(DeviceState *dev, DeviceInfo *info); |
102 | aae9460e | Paul Brook | |
103 | 02e2da45 | Paul Brook | struct DeviceInfo {
|
104 | 074f2fff | Gerd Hoffmann | const char *name; |
105 | 3320e56e | Gerd Hoffmann | const char *alias; |
106 | 3320e56e | Gerd Hoffmann | const char *desc; |
107 | 074f2fff | Gerd Hoffmann | size_t size; |
108 | ee6847d1 | Gerd Hoffmann | Property *props; |
109 | 3320e56e | Gerd Hoffmann | int no_user;
|
110 | 074f2fff | Gerd Hoffmann | |
111 | 074f2fff | Gerd Hoffmann | /* Private to qdev / bus. */
|
112 | 02e2da45 | Paul Brook | qdev_initfn init; |
113 | 10c4c98a | Gerd Hoffmann | BusInfo *bus_info; |
114 | 042f84d0 | Gerd Hoffmann | struct DeviceInfo *next;
|
115 | 02e2da45 | Paul Brook | }; |
116 | 02e2da45 | Paul Brook | |
117 | 074f2fff | Gerd Hoffmann | void qdev_register(DeviceInfo *info);
|
118 | aae9460e | Paul Brook | |
119 | aae9460e | Paul Brook | /* Register device properties. */
|
120 | 067a3ddc | Paul Brook | /* GPIO inputs also double as IRQ sinks. */
|
121 | aae9460e | Paul Brook | void qdev_init_gpio_in(DeviceState *dev, qemu_irq_handler handler, int n); |
122 | aae9460e | Paul Brook | void qdev_init_gpio_out(DeviceState *dev, qemu_irq *pins, int n); |
123 | aae9460e | Paul Brook | |
124 | aae9460e | Paul Brook | CharDriverState *qdev_init_chardev(DeviceState *dev); |
125 | aae9460e | Paul Brook | |
126 | 02e2da45 | Paul Brook | BusState *qdev_get_parent_bus(DeviceState *dev); |
127 | aae9460e | Paul Brook | |
128 | aae9460e | Paul Brook | /* Convery from a base type to a parent type, with compile time checking. */
|
129 | aae9460e | Paul Brook | #ifdef __GNUC__
|
130 | aae9460e | Paul Brook | #define DO_UPCAST(type, field, dev) ( __extension__ ( { \
|
131 | aae9460e | Paul Brook | char __attribute__((unused)) offset_must_be_zero[ \
|
132 | aae9460e | Paul Brook | -offsetof(type, field)]; \ |
133 | aae9460e | Paul Brook | container_of(dev, type, field);})) |
134 | aae9460e | Paul Brook | #else
|
135 | aae9460e | Paul Brook | #define DO_UPCAST(type, field, dev) container_of(dev, type, field)
|
136 | aae9460e | Paul Brook | #endif
|
137 | aae9460e | Paul Brook | |
138 | 02e2da45 | Paul Brook | /*** BUS API. ***/
|
139 | 02e2da45 | Paul Brook | |
140 | 10c4c98a | Gerd Hoffmann | BusState *qbus_create(BusInfo *info, DeviceState *parent, const char *name); |
141 | 02e2da45 | Paul Brook | |
142 | 02e2da45 | Paul Brook | #define FROM_QBUS(type, dev) DO_UPCAST(type, qbus, dev)
|
143 | 02e2da45 | Paul Brook | |
144 | cae4956e | Gerd Hoffmann | /*** monitor commands ***/
|
145 | cae4956e | Gerd Hoffmann | |
146 | cae4956e | Gerd Hoffmann | void do_info_qtree(Monitor *mon);
|
147 | f6c64e0e | Gerd Hoffmann | void do_info_qdm(Monitor *mon);
|
148 | cae4956e | Gerd Hoffmann | |
149 | ee6847d1 | Gerd Hoffmann | /*** qdev-properties.c ***/
|
150 | ee6847d1 | Gerd Hoffmann | |
151 | ee6847d1 | Gerd Hoffmann | extern PropertyInfo qdev_prop_uint16;
|
152 | ee6847d1 | Gerd Hoffmann | extern PropertyInfo qdev_prop_uint32;
|
153 | 5a053d1f | Blue Swirl | extern PropertyInfo qdev_prop_uint64;
|
154 | ee6847d1 | Gerd Hoffmann | extern PropertyInfo qdev_prop_hex32;
|
155 | 5a053d1f | Blue Swirl | extern PropertyInfo qdev_prop_hex64;
|
156 | 313feaab | Gerd Hoffmann | extern PropertyInfo qdev_prop_chr;
|
157 | ee6847d1 | Gerd Hoffmann | extern PropertyInfo qdev_prop_ptr;
|
158 | ee6847d1 | Gerd Hoffmann | extern PropertyInfo qdev_prop_macaddr;
|
159 | 14b41872 | Gerd Hoffmann | extern PropertyInfo qdev_prop_drive;
|
160 | 05cb5fe4 | Gerd Hoffmann | extern PropertyInfo qdev_prop_pci_devfn;
|
161 | ee6847d1 | Gerd Hoffmann | |
162 | cf12b95b | Gerd Hoffmann | #define DEFINE_PROP(_name, _state, _field, _prop, _type) { \
|
163 | cf12b95b | Gerd Hoffmann | .name = (_name), \ |
164 | cf12b95b | Gerd Hoffmann | .info = &(_prop), \ |
165 | cf12b95b | Gerd Hoffmann | .offset = offsetof(_state, _field) \ |
166 | cf12b95b | Gerd Hoffmann | + type_check(_type,typeof_field(_state, _field)), \ |
167 | cf12b95b | Gerd Hoffmann | } |
168 | cf12b95b | Gerd Hoffmann | #define DEFINE_PROP_DEFAULT(_name, _state, _field, _defval, _prop, _type) { \
|
169 | cf12b95b | Gerd Hoffmann | .name = (_name), \ |
170 | cf12b95b | Gerd Hoffmann | .info = &(_prop), \ |
171 | cf12b95b | Gerd Hoffmann | .offset = offsetof(_state, _field) \ |
172 | cf12b95b | Gerd Hoffmann | + type_check(_type,typeof_field(_state, _field)), \ |
173 | cf12b95b | Gerd Hoffmann | .defval = (_type[]) { _defval }, \ |
174 | cf12b95b | Gerd Hoffmann | } |
175 | cf12b95b | Gerd Hoffmann | |
176 | cf12b95b | Gerd Hoffmann | #define DEFINE_PROP_UINT16(_n, _s, _f, _d) \
|
177 | cf12b95b | Gerd Hoffmann | DEFINE_PROP_DEFAULT(_n, _s, _f, _d, qdev_prop_uint16, uint16_t) |
178 | cf12b95b | Gerd Hoffmann | #define DEFINE_PROP_UINT32(_n, _s, _f, _d) \
|
179 | cf12b95b | Gerd Hoffmann | DEFINE_PROP_DEFAULT(_n, _s, _f, _d, qdev_prop_uint32, uint32_t) |
180 | cf12b95b | Gerd Hoffmann | #define DEFINE_PROP_UINT64(_n, _s, _f, _d) \
|
181 | cf12b95b | Gerd Hoffmann | DEFINE_PROP_DEFAULT(_n, _s, _f, _d, qdev_prop_uint64, uint64_t) |
182 | cf12b95b | Gerd Hoffmann | #define DEFINE_PROP_HEX32(_n, _s, _f, _d) \
|
183 | cf12b95b | Gerd Hoffmann | DEFINE_PROP_DEFAULT(_n, _s, _f, _d, qdev_prop_hex32, uint32_t) |
184 | cf12b95b | Gerd Hoffmann | #define DEFINE_PROP_HEX64(_n, _s, _f, _d) \
|
185 | cf12b95b | Gerd Hoffmann | DEFINE_PROP_DEFAULT(_n, _s, _f, _d, qdev_prop_hex64, uint64_t) |
186 | cf12b95b | Gerd Hoffmann | #define DEFINE_PROP_PCI_DEVFN(_n, _s, _f, _d) \
|
187 | cf12b95b | Gerd Hoffmann | DEFINE_PROP_DEFAULT(_n, _s, _f, _d, qdev_prop_pci_devfn, uint32_t) |
188 | cf12b95b | Gerd Hoffmann | |
189 | cf12b95b | Gerd Hoffmann | #define DEFINE_PROP_PTR(_n, _s, _f) \
|
190 | cf12b95b | Gerd Hoffmann | DEFINE_PROP(_n, _s, _f, qdev_prop_ptr, void*)
|
191 | 313feaab | Gerd Hoffmann | #define DEFINE_PROP_CHR(_n, _s, _f) \
|
192 | 313feaab | Gerd Hoffmann | DEFINE_PROP(_n, _s, _f, qdev_prop_chr, CharDriverState*) |
193 | f6c64e0e | Gerd Hoffmann | #define DEFINE_PROP_DRIVE(_n, _s, _f) \
|
194 | c981d39c | Anthony Liguori | DEFINE_PROP(_n, _s, _f, qdev_prop_drive, DriveInfo*) |
195 | cf12b95b | Gerd Hoffmann | #define DEFINE_PROP_MACADDR(_n, _s, _f) \
|
196 | cf12b95b | Gerd Hoffmann | DEFINE_PROP(_n, _s, _f, qdev_prop_macaddr, uint8_t[6])
|
197 | cf12b95b | Gerd Hoffmann | |
198 | cf12b95b | Gerd Hoffmann | #define DEFINE_PROP_END_OF_LIST() \
|
199 | cf12b95b | Gerd Hoffmann | {} |
200 | cf12b95b | Gerd Hoffmann | |
201 | ee6847d1 | Gerd Hoffmann | /* Set properties between creation and init. */
|
202 | ee6847d1 | Gerd Hoffmann | void *qdev_get_prop_ptr(DeviceState *dev, Property *prop);
|
203 | ee6847d1 | Gerd Hoffmann | int qdev_prop_parse(DeviceState *dev, const char *name, const char *value); |
204 | ee6847d1 | Gerd Hoffmann | void qdev_prop_set(DeviceState *dev, const char *name, void *src, enum PropertyType type); |
205 | ee6847d1 | Gerd Hoffmann | void qdev_prop_set_uint16(DeviceState *dev, const char *name, uint16_t value); |
206 | ee6847d1 | Gerd Hoffmann | void qdev_prop_set_uint32(DeviceState *dev, const char *name, uint32_t value); |
207 | 5a053d1f | Blue Swirl | void qdev_prop_set_uint64(DeviceState *dev, const char *name, uint64_t value); |
208 | 313feaab | Gerd Hoffmann | void qdev_prop_set_chr(DeviceState *dev, const char *name, CharDriverState *value); |
209 | 14b41872 | Gerd Hoffmann | void qdev_prop_set_drive(DeviceState *dev, const char *name, DriveInfo *value); |
210 | ee6847d1 | Gerd Hoffmann | /* FIXME: Remove opaque pointer properties. */
|
211 | ee6847d1 | Gerd Hoffmann | void qdev_prop_set_ptr(DeviceState *dev, const char *name, void *value); |
212 | ee6847d1 | Gerd Hoffmann | void qdev_prop_set_defaults(DeviceState *dev, Property *props);
|
213 | ee6847d1 | Gerd Hoffmann | |
214 | b6b61144 | Gerd Hoffmann | void qdev_prop_register_compat(CompatProperty *props);
|
215 | b6b61144 | Gerd Hoffmann | void qdev_prop_set_compat(DeviceState *dev);
|
216 | b6b61144 | Gerd Hoffmann | |
217 | a9ff9df1 | Blue Swirl | /* This is a nasty hack to allow passing a NULL bus to qdev_create. */
|
218 | a9ff9df1 | Blue Swirl | extern struct BusInfo system_bus_info; |
219 | a9ff9df1 | Blue Swirl | |
220 | aae9460e | Paul Brook | #endif |