diff options
author | Anthony Liguori <anthony@codemonkey.ws> | 2010-11-19 18:55:59 +0900 |
---|---|---|
committer | Michael S. Tsirkin <mst@redhat.com> | 2010-11-22 10:00:07 +0200 |
commit | ec990eb622ad46df5ddcb1e94c418c271894d416 (patch) | |
tree | e70d39d0b76d8179a3aff43abc1e31da021194d2 /vl.c | |
parent | 81699d8a90deac361e9e14fd853f8341f40b2fad (diff) | |
download | qemu-ec990eb622ad46df5ddcb1e94c418c271894d416.zip qemu-ec990eb622ad46df5ddcb1e94c418c271894d416.tar.gz qemu-ec990eb622ad46df5ddcb1e94c418c271894d416.tar.bz2 |
qdev: reset qdev along with qdev tree
This patch changes the reset handling so that qdev has no knowledge of the
global system reset. Instead, a new bus/device level function is introduced
that allows all devices/buses on the bus/device to be reset using a depth
first transversal.
N.B. we have to expose the implicit system bus because we have various hacks
that result in an implicit system bus existing. Instead, we ought to have an
explicitly created system bus that we can trigger reset from. That's a topic
for a future patch though.
Signed-off-by: Anthony Liguori <aliguori@us.ibm.com>
Signed-off-by: Isaku Yamahata <yamahata@valinux.co.jp>
Signed-off-by: Michael S. Tsirkin <mst@redhat.com>
Diffstat (limited to 'vl.c')
-rw-r--r-- | vl.c | 1 |
1 files changed, 1 insertions, 0 deletions
@@ -2976,6 +2976,7 @@ int main(int argc, char **argv, char **envp) exit(1); } + qemu_register_reset((void *)qbus_reset_all, sysbus_get_default()); qemu_system_reset(); if (loadvm) { if (load_vmstate(loadvm) < 0) { |