]> git.proxmox.com Git - qemu.git/commitdiff
console: add qemu_console_lookup_by_device
authorGerd Hoffmann <kraxel@redhat.com>
Thu, 18 Apr 2013 05:30:40 +0000 (07:30 +0200)
committerAnthony Liguori <aliguori@us.ibm.com>
Thu, 25 Apr 2013 19:45:46 +0000 (14:45 -0500)
Look up the QemuConsole for a given device, using the new link.

Signed-off-by: Gerd Hoffmann <kraxel@redhat.com>
include/ui/console.h
ui/console.c

index 6e69f7f8899b44070a7497b61414511bc2f46304..c65940fe3b043de29864b5c51408dbdf06e0aede 100644 (file)
@@ -287,6 +287,7 @@ void graphic_hw_invalidate(QemuConsole *con);
 void graphic_hw_text_update(QemuConsole *con, console_ch_t *chardata);
 
 QemuConsole *qemu_console_lookup_by_index(unsigned int index);
+QemuConsole *qemu_console_lookup_by_device(DeviceState *dev);
 bool qemu_console_is_visible(QemuConsole *con);
 bool qemu_console_is_graphic(QemuConsole *con);
 bool qemu_console_is_fixedsize(QemuConsole *con);
index 4102e8c697ff27c302eae335085af983b7485630..e3ab9853eca281f5c961a142625ca45b1588590f 100644 (file)
@@ -1596,6 +1596,25 @@ QemuConsole *qemu_console_lookup_by_index(unsigned int index)
     return consoles[index];
 }
 
+QemuConsole *qemu_console_lookup_by_device(DeviceState *dev)
+{
+    Error *local_err = NULL;
+    Object *obj;
+    int i;
+
+    for (i = 0; i < nb_consoles; i++) {
+        if (!consoles[i]) {
+            continue;
+        }
+        obj = object_property_get_link(OBJECT(consoles[i]),
+                                       "device", &local_err);
+        if (DEVICE(obj) == dev) {
+            return consoles[i];
+        }
+    }
+    return NULL;
+}
+
 bool qemu_console_is_visible(QemuConsole *con)
 {
     return (con == active_console) || (con->dcls > 0);