Comments
Patch
@@ -58,12 +58,15 @@ typedef int (qbus_del_devfn)(BusState *bus, DeviceState *dev);
typedef void (qbus_realizefn)(BusState *bus);
+typedef int (qbus_resetfn)(BusState *bus);
+
struct BusInfo {
const char *name;
size_t size;
qbus_add_devfn *add_dev;
qbus_del_devfn *del_dev;
qbus_realizefn *realize;
+ qbus_resetfn *reset;
bus_get_dev_path get_dev_path;
Property *props;
};
@@ -166,9 +166,17 @@ static int qdev_reset_one(DeviceState *dev, void *opaque)
return 0;
}
+static int qbus_reset_one(BusState *bus, void *opaque)
+{
+ if (bus->info->reset) {
+ return bus->info->reset(bus);
+ }
+ return 0;
+}
+
void qbus_reset_all(BusState *bus)
{
- qbus_walk_children(bus, qdev_reset_one, NULL, NULL);
+ qbus_walk_children(bus, qdev_reset_one, qbus_reset_one, NULL);
}
static int qdev_realize_one(DeviceState *dev, void *opaque)
and make it called via qbus_reset_all(). The qbus reset callback will be used by pci bus reset. Signed-off-by: Isaku Yamahata <yamahata@valinux.co.jp> --- hw/qdev-core.h | 3 +++ hw/qdev.c | 10 +++++++++- 2 files changed, 12 insertions(+), 1 deletions(-)