瀏覽代碼

vhost-user: disable chardev handlers on close

This otherwise causes a use-after-free if network backend cleanup
is performed before character device cleanup.

Cc: Marc-André Lureau <marcandre.lureau@redhat.com>
Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
Paolo Bonzini 9 年之前
父節點
當前提交
25f0d2aa5e
共有 1 個文件被更改,包括 5 次插入0 次删除
  1. 5 0
      net/vhost-user.c

+ 5 - 0
net/vhost-user.c

@@ -151,6 +151,11 @@ static void vhost_user_cleanup(NetClientState *nc)
         vhost_net_cleanup(s->vhost_net);
         vhost_net_cleanup(s->vhost_net);
         s->vhost_net = NULL;
         s->vhost_net = NULL;
     }
     }
+    if (s->chr) {
+        qemu_chr_add_handlers(s->chr, NULL, NULL, NULL, NULL);
+        qemu_chr_fe_release(s->chr);
+        s->chr = NULL;
+    }
 
 
     qemu_purge_queued_packets(nc);
     qemu_purge_queued_packets(nc);
 }
 }