sysbus: Add dynamic sysbus device search
Sysbus devices can be spawned by C code or dynamically via the command line. In the latter case, we need to be able to find the dynamically created devices to do things with them. This patch adds a search helper that makes it easy to look for dynamically spawned sysbus devices. Signed-off-by: Alexander Graf <agraf@suse.de>
This commit is contained in:
parent
f8833a37c0
commit
eb5722801c
@ -24,6 +24,51 @@
|
|||||||
static void sysbus_dev_print(Monitor *mon, DeviceState *dev, int indent);
|
static void sysbus_dev_print(Monitor *mon, DeviceState *dev, int indent);
|
||||||
static char *sysbus_get_fw_dev_path(DeviceState *dev);
|
static char *sysbus_get_fw_dev_path(DeviceState *dev);
|
||||||
|
|
||||||
|
typedef struct SysBusFind {
|
||||||
|
void *opaque;
|
||||||
|
FindSysbusDeviceFunc *func;
|
||||||
|
} SysBusFind;
|
||||||
|
|
||||||
|
/* Run func() for every sysbus device, traverse the tree for everything else */
|
||||||
|
static int find_sysbus_device(Object *obj, void *opaque)
|
||||||
|
{
|
||||||
|
SysBusFind *find = opaque;
|
||||||
|
Object *dev;
|
||||||
|
SysBusDevice *sbdev;
|
||||||
|
|
||||||
|
dev = object_dynamic_cast(obj, TYPE_SYS_BUS_DEVICE);
|
||||||
|
sbdev = (SysBusDevice *)dev;
|
||||||
|
|
||||||
|
if (!sbdev) {
|
||||||
|
/* Container, traverse it for children */
|
||||||
|
return object_child_foreach(obj, find_sysbus_device, opaque);
|
||||||
|
}
|
||||||
|
|
||||||
|
find->func(sbdev, find->opaque);
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Loop through all dynamically created sysbus devices and call
|
||||||
|
* func() for each instance.
|
||||||
|
*/
|
||||||
|
void foreach_dynamic_sysbus_device(FindSysbusDeviceFunc *func, void *opaque)
|
||||||
|
{
|
||||||
|
Object *container;
|
||||||
|
SysBusFind find = {
|
||||||
|
.func = func,
|
||||||
|
.opaque = opaque,
|
||||||
|
};
|
||||||
|
|
||||||
|
/* Loop through all sysbus devices that were spawened outside the machine */
|
||||||
|
container = container_get(qdev_get_machine(), "/peripheral");
|
||||||
|
find_sysbus_device(container, &find);
|
||||||
|
container = container_get(qdev_get_machine(), "/peripheral-anon");
|
||||||
|
find_sysbus_device(container, &find);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
static void system_bus_class_init(ObjectClass *klass, void *data)
|
static void system_bus_class_init(ObjectClass *klass, void *data)
|
||||||
{
|
{
|
||||||
BusClass *k = BUS_CLASS(klass);
|
BusClass *k = BUS_CLASS(klass);
|
||||||
|
@ -57,6 +57,8 @@ struct SysBusDevice {
|
|||||||
pio_addr_t pio[QDEV_MAX_PIO];
|
pio_addr_t pio[QDEV_MAX_PIO];
|
||||||
};
|
};
|
||||||
|
|
||||||
|
typedef int FindSysbusDeviceFunc(SysBusDevice *sbdev, void *opaque);
|
||||||
|
|
||||||
void sysbus_init_mmio(SysBusDevice *dev, MemoryRegion *memory);
|
void sysbus_init_mmio(SysBusDevice *dev, MemoryRegion *memory);
|
||||||
MemoryRegion *sysbus_mmio_get_region(SysBusDevice *dev, int n);
|
MemoryRegion *sysbus_mmio_get_region(SysBusDevice *dev, int n);
|
||||||
void sysbus_init_irq(SysBusDevice *dev, qemu_irq *p);
|
void sysbus_init_irq(SysBusDevice *dev, qemu_irq *p);
|
||||||
@ -72,6 +74,9 @@ void sysbus_add_io(SysBusDevice *dev, hwaddr addr,
|
|||||||
MemoryRegion *mem);
|
MemoryRegion *mem);
|
||||||
MemoryRegion *sysbus_address_space(SysBusDevice *dev);
|
MemoryRegion *sysbus_address_space(SysBusDevice *dev);
|
||||||
|
|
||||||
|
/* Call func for every dynamically created sysbus device in the system */
|
||||||
|
void foreach_dynamic_sysbus_device(FindSysbusDeviceFunc *func, void *opaque);
|
||||||
|
|
||||||
/* Legacy helper function for creating devices. */
|
/* Legacy helper function for creating devices. */
|
||||||
DeviceState *sysbus_create_varargs(const char *name,
|
DeviceState *sysbus_create_varargs(const char *name,
|
||||||
hwaddr addr, ...);
|
hwaddr addr, ...);
|
||||||
|
Loading…
Reference in New Issue
Block a user