7 #include "qemu-option.h"
9 typedef struct Property Property
;
11 typedef struct PropertyInfo PropertyInfo
;
13 typedef struct CompatProperty CompatProperty
;
15 typedef struct DeviceInfo DeviceInfo
;
17 typedef struct BusState BusState
;
19 typedef struct BusInfo BusInfo
;
21 /* This structure should not be accessed directly. We declare it here
22 so that it can be embedded in individual device state structures. */
31 LIST_HEAD(, BusState
) child_bus
;
34 LIST_ENTRY(DeviceState
) sibling
;
37 typedef void (*bus_dev_printfn
)(Monitor
*mon
, DeviceState
*dev
, int indent
);
41 bus_dev_printfn print_dev
;
49 LIST_HEAD(, DeviceState
) children
;
50 LIST_ENTRY(BusState
) sibling
;
74 enum PropertyType type
;
75 int (*parse
)(DeviceState
*dev
, Property
*prop
, const char *str
);
76 int (*print
)(DeviceState
*dev
, Property
*prop
, char *dest
, size_t len
);
79 struct CompatProperty
{
85 /*** Board API. This should go away once we have a machine config file. ***/
87 DeviceState
*qdev_create(BusState
*bus
, const char *name
);
88 DeviceState
*qdev_device_add(QemuOpts
*opts
);
89 void qdev_init(DeviceState
*dev
);
90 void qdev_free(DeviceState
*dev
);
92 qemu_irq
qdev_get_gpio_in(DeviceState
*dev
, int n
);
93 void qdev_connect_gpio_out(DeviceState
*dev
, int n
, qemu_irq pin
);
95 BusState
*qdev_get_child_bus(DeviceState
*dev
, const char *name
);
99 typedef void (*qdev_initfn
)(DeviceState
*dev
, DeviceInfo
*info
);
100 typedef void (*SCSIAttachFn
)(DeviceState
*host
, BlockDriverState
*bdrv
,
111 /* Private to qdev / bus. */
114 struct DeviceInfo
*next
;
117 void qdev_register(DeviceInfo
*info
);
119 /* Register device properties. */
120 /* GPIO inputs also double as IRQ sinks. */
121 void qdev_init_gpio_in(DeviceState
*dev
, qemu_irq_handler handler
, int n
);
122 void qdev_init_gpio_out(DeviceState
*dev
, qemu_irq
*pins
, int n
);
124 void scsi_bus_new(DeviceState
*host
, SCSIAttachFn attach
);
126 CharDriverState
*qdev_init_chardev(DeviceState
*dev
);
128 BusState
*qdev_get_parent_bus(DeviceState
*dev
);
130 /* Convery from a base type to a parent type, with compile time checking. */
132 #define DO_UPCAST(type, field, dev) ( __extension__ ( { \
133 char __attribute__((unused)) offset_must_be_zero[ \
134 -offsetof(type, field)]; \
135 container_of(dev, type, field);}))
137 #define DO_UPCAST(type, field, dev) container_of(dev, type, field)
142 BusState
*qbus_create(BusInfo
*info
, DeviceState
*parent
, const char *name
);
144 #define FROM_QBUS(type, dev) DO_UPCAST(type, qbus, dev)
146 /*** monitor commands ***/
148 void do_info_qtree(Monitor
*mon
);
149 void do_info_qdrv(Monitor
*mon
);
151 /*** qdev-properties.c ***/
153 extern PropertyInfo qdev_prop_uint16
;
154 extern PropertyInfo qdev_prop_uint32
;
155 extern PropertyInfo qdev_prop_uint64
;
156 extern PropertyInfo qdev_prop_hex32
;
157 extern PropertyInfo qdev_prop_hex64
;
158 extern PropertyInfo qdev_prop_ptr
;
159 extern PropertyInfo qdev_prop_macaddr
;
160 extern PropertyInfo qdev_prop_drive
;
161 extern PropertyInfo qdev_prop_pci_devfn
;
163 #define typeof_field(type, field) typeof(((type *)0)->field)
164 #define type_check(t1,t2) ((t1*)0 - (t2*)0)
166 #define DEFINE_PROP(_name, _state, _field, _prop, _type) { \
169 .offset = offsetof(_state, _field) \
170 + type_check(_type,typeof_field(_state, _field)), \
172 #define DEFINE_PROP_DEFAULT(_name, _state, _field, _defval, _prop, _type) { \
175 .offset = offsetof(_state, _field) \
176 + type_check(_type,typeof_field(_state, _field)), \
177 .defval = (_type[]) { _defval }, \
180 #define DEFINE_PROP_UINT16(_n, _s, _f, _d) \
181 DEFINE_PROP_DEFAULT(_n, _s, _f, _d, qdev_prop_uint16, uint16_t)
182 #define DEFINE_PROP_UINT32(_n, _s, _f, _d) \
183 DEFINE_PROP_DEFAULT(_n, _s, _f, _d, qdev_prop_uint32, uint32_t)
184 #define DEFINE_PROP_UINT64(_n, _s, _f, _d) \
185 DEFINE_PROP_DEFAULT(_n, _s, _f, _d, qdev_prop_uint64, uint64_t)
186 #define DEFINE_PROP_HEX32(_n, _s, _f, _d) \
187 DEFINE_PROP_DEFAULT(_n, _s, _f, _d, qdev_prop_hex32, uint32_t)
188 #define DEFINE_PROP_HEX64(_n, _s, _f, _d) \
189 DEFINE_PROP_DEFAULT(_n, _s, _f, _d, qdev_prop_hex64, uint64_t)
190 #define DEFINE_PROP_PCI_DEVFN(_n, _s, _f, _d) \
191 DEFINE_PROP_DEFAULT(_n, _s, _f, _d, qdev_prop_pci_devfn, uint32_t)
193 #define DEFINE_PROP_PTR(_n, _s, _f) \
194 DEFINE_PROP(_n, _s, _f, qdev_prop_ptr, void*)
195 #define DEFINE_PROP_MACADDR(_n, _s, _f) \
196 DEFINE_PROP(_n, _s, _f, qdev_prop_macaddr, uint8_t[6])
198 #define DEFINE_PROP_END_OF_LIST() \
201 /* Set properties between creation and init. */
202 void *qdev_get_prop_ptr(DeviceState
*dev
, Property
*prop
);
203 int qdev_prop_parse(DeviceState
*dev
, const char *name
, const char *value
);
204 void qdev_prop_set(DeviceState
*dev
, const char *name
, void *src
, enum PropertyType type
);
205 void qdev_prop_set_uint16(DeviceState
*dev
, const char *name
, uint16_t value
);
206 void qdev_prop_set_uint32(DeviceState
*dev
, const char *name
, uint32_t value
);
207 void qdev_prop_set_uint64(DeviceState
*dev
, const char *name
, uint64_t value
);
208 void qdev_prop_set_drive(DeviceState
*dev
, const char *name
, DriveInfo
*value
);
209 /* FIXME: Remove opaque pointer properties. */
210 void qdev_prop_set_ptr(DeviceState
*dev
, const char *name
, void *value
);
211 void qdev_prop_set_defaults(DeviceState
*dev
, Property
*props
);
213 void qdev_prop_register_compat(CompatProperty
*props
);
214 void qdev_prop_set_compat(DeviceState
*dev
);
216 /* This is a nasty hack to allow passing a NULL bus to qdev_create. */
217 extern struct BusInfo system_bus_info
;