6 #include "qemu-queue.h"
8 #include "qemu-option.h"
10 typedef struct Property Property
;
12 typedef struct PropertyInfo PropertyInfo
;
14 typedef struct CompatProperty CompatProperty
;
16 typedef struct DeviceInfo DeviceInfo
;
18 typedef struct BusState BusState
;
20 typedef struct BusInfo BusInfo
;
22 /* This structure should not be accessed directly. We declare it here
23 so that it can be embedded in individual device state structures. */
32 QLIST_HEAD(, BusState
) child_bus
;
35 QLIST_ENTRY(DeviceState
) sibling
;
38 typedef void (*bus_dev_printfn
)(Monitor
*mon
, DeviceState
*dev
, int indent
);
42 bus_dev_printfn print_dev
;
50 QLIST_HEAD(, DeviceState
) children
;
51 QLIST_ENTRY(BusState
) sibling
;
77 enum PropertyType type
;
78 int (*parse
)(DeviceState
*dev
, Property
*prop
, const char *str
);
79 int (*print
)(DeviceState
*dev
, Property
*prop
, char *dest
, size_t len
);
82 struct CompatProperty
{
88 /*** Board API. This should go away once we have a machine config file. ***/
90 DeviceState
*qdev_create(BusState
*bus
, const char *name
);
91 DeviceState
*qdev_device_add(QemuOpts
*opts
);
92 int qdev_init(DeviceState
*dev
);
93 void qdev_free(DeviceState
*dev
);
95 qemu_irq
qdev_get_gpio_in(DeviceState
*dev
, int n
);
96 void qdev_connect_gpio_out(DeviceState
*dev
, int n
, qemu_irq pin
);
98 BusState
*qdev_get_child_bus(DeviceState
*dev
, const char *name
);
100 /*** Device API. ***/
102 typedef int (*qdev_initfn
)(DeviceState
*dev
, DeviceInfo
*info
);
113 QEMUResetHandler
*reset
;
116 const VMStateDescription
*vmsd
;
118 /* Private to qdev / bus. */
121 struct DeviceInfo
*next
;
124 void qdev_register(DeviceInfo
*info
);
126 /* Register device properties. */
127 /* GPIO inputs also double as IRQ sinks. */
128 void qdev_init_gpio_in(DeviceState
*dev
, qemu_irq_handler handler
, int n
);
129 void qdev_init_gpio_out(DeviceState
*dev
, qemu_irq
*pins
, int n
);
131 CharDriverState
*qdev_init_chardev(DeviceState
*dev
);
133 BusState
*qdev_get_parent_bus(DeviceState
*dev
);
135 /* Convery from a base type to a parent type, with compile time checking. */
137 #define DO_UPCAST(type, field, dev) ( __extension__ ( { \
138 char __attribute__((unused)) offset_must_be_zero[ \
139 -offsetof(type, field)]; \
140 container_of(dev, type, field);}))
142 #define DO_UPCAST(type, field, dev) container_of(dev, type, field)
147 BusState
*qbus_create(BusInfo
*info
, DeviceState
*parent
, const char *name
);
149 #define FROM_QBUS(type, dev) DO_UPCAST(type, qbus, dev)
151 /*** monitor commands ***/
153 void do_info_qtree(Monitor
*mon
);
154 void do_info_qdm(Monitor
*mon
);
156 /*** qdev-properties.c ***/
158 extern PropertyInfo qdev_prop_uint16
;
159 extern PropertyInfo qdev_prop_uint32
;
160 extern PropertyInfo qdev_prop_int32
;
161 extern PropertyInfo qdev_prop_uint64
;
162 extern PropertyInfo qdev_prop_hex32
;
163 extern PropertyInfo qdev_prop_hex64
;
164 extern PropertyInfo qdev_prop_chr
;
165 extern PropertyInfo qdev_prop_ptr
;
166 extern PropertyInfo qdev_prop_macaddr
;
167 extern PropertyInfo qdev_prop_drive
;
168 extern PropertyInfo qdev_prop_pci_devfn
;
170 #define DEFINE_PROP(_name, _state, _field, _prop, _type) { \
173 .offset = offsetof(_state, _field) \
174 + type_check(_type,typeof_field(_state, _field)), \
176 #define DEFINE_PROP_DEFAULT(_name, _state, _field, _defval, _prop, _type) { \
179 .offset = offsetof(_state, _field) \
180 + type_check(_type,typeof_field(_state, _field)), \
181 .defval = (_type[]) { _defval }, \
184 #define DEFINE_PROP_UINT16(_n, _s, _f, _d) \
185 DEFINE_PROP_DEFAULT(_n, _s, _f, _d, qdev_prop_uint16, uint16_t)
186 #define DEFINE_PROP_UINT32(_n, _s, _f, _d) \
187 DEFINE_PROP_DEFAULT(_n, _s, _f, _d, qdev_prop_uint32, uint32_t)
188 #define DEFINE_PROP_INT32(_n, _s, _f, _d) \
189 DEFINE_PROP_DEFAULT(_n, _s, _f, _d, qdev_prop_int32, int32_t)
190 #define DEFINE_PROP_UINT64(_n, _s, _f, _d) \
191 DEFINE_PROP_DEFAULT(_n, _s, _f, _d, qdev_prop_uint64, uint64_t)
192 #define DEFINE_PROP_HEX32(_n, _s, _f, _d) \
193 DEFINE_PROP_DEFAULT(_n, _s, _f, _d, qdev_prop_hex32, uint32_t)
194 #define DEFINE_PROP_HEX64(_n, _s, _f, _d) \
195 DEFINE_PROP_DEFAULT(_n, _s, _f, _d, qdev_prop_hex64, uint64_t)
196 #define DEFINE_PROP_PCI_DEVFN(_n, _s, _f, _d) \
197 DEFINE_PROP_DEFAULT(_n, _s, _f, _d, qdev_prop_pci_devfn, uint32_t)
199 #define DEFINE_PROP_PTR(_n, _s, _f) \
200 DEFINE_PROP(_n, _s, _f, qdev_prop_ptr, void*)
201 #define DEFINE_PROP_CHR(_n, _s, _f) \
202 DEFINE_PROP(_n, _s, _f, qdev_prop_chr, CharDriverState*)
203 #define DEFINE_PROP_DRIVE(_n, _s, _f) \
204 DEFINE_PROP(_n, _s, _f, qdev_prop_drive, DriveInfo*)
205 #define DEFINE_PROP_MACADDR(_n, _s, _f) \
206 DEFINE_PROP(_n, _s, _f, qdev_prop_macaddr, uint8_t[6])
208 #define DEFINE_PROP_END_OF_LIST() \
211 /* Set properties between creation and init. */
212 void *qdev_get_prop_ptr(DeviceState
*dev
, Property
*prop
);
213 int qdev_prop_parse(DeviceState
*dev
, const char *name
, const char *value
);
214 void qdev_prop_set(DeviceState
*dev
, const char *name
, void *src
, enum PropertyType type
);
215 void qdev_prop_set_uint16(DeviceState
*dev
, const char *name
, uint16_t value
);
216 void qdev_prop_set_uint32(DeviceState
*dev
, const char *name
, uint32_t value
);
217 void qdev_prop_set_int32(DeviceState
*dev
, const char *name
, int32_t value
);
218 void qdev_prop_set_uint64(DeviceState
*dev
, const char *name
, uint64_t value
);
219 void qdev_prop_set_chr(DeviceState
*dev
, const char *name
, CharDriverState
*value
);
220 void qdev_prop_set_drive(DeviceState
*dev
, const char *name
, DriveInfo
*value
);
221 /* FIXME: Remove opaque pointer properties. */
222 void qdev_prop_set_ptr(DeviceState
*dev
, const char *name
, void *value
);
223 void qdev_prop_set_defaults(DeviceState
*dev
, Property
*props
);
225 void qdev_prop_register_compat(CompatProperty
*props
);
226 void qdev_prop_set_compat(DeviceState
*dev
);
228 /* This is a nasty hack to allow passing a NULL bus to qdev_create. */
229 extern struct BusInfo system_bus_info
;