If we're using multiport, there's no point in always creating a console
port. Create the console port only if the host doesn't support
multiport.

Signed-off-by: Amit Shah <[email protected]>
---
 drivers/char/virtio_console.c |   33 +++++++++++++++------------------
 1 files changed, 15 insertions(+), 18 deletions(-)

diff --git a/drivers/char/virtio_console.c b/drivers/char/virtio_console.c
index 7b2dcdd..3d70729 100644
--- a/drivers/char/virtio_console.c
+++ b/drivers/char/virtio_console.c
@@ -791,6 +791,13 @@ int init_port_console(struct port *port)
        spin_unlock_irq(&pdrvdata_lock);
        port->guest_connected = true;
 
+       /*
+        * Start using the new console output if this is the first
+        * console to come up.
+        */
+       if (early_put_chars)
+               early_put_chars = NULL;
+
        /* Notify host of port being opened */
        send_control_msg(port, VIRTIO_CONSOLE_PORT_OPEN, 1);
 
@@ -1063,14 +1070,8 @@ static void handle_control_message(struct ports_device 
*portdev,
        switch (cpkt->event) {
        case VIRTIO_CONSOLE_PORT_ADD:
                if (port) {
-                       /*
-                        * This can happen for port 0: we have to
-                        * create a console port during probe() as was
-                        * the behaviour before the MULTIPORT feature.
-                        * On a newer host, when the host tells us
-                        * that a port 0 is available, we should just
-                        * say we have the port all set up.
-                        */
+                       dev_dbg(&portdev->vdev->dev,
+                               "Port %u already added\n", port->id);
                        send_control_msg(port, VIRTIO_CONSOLE_PORT_READY, 1);
                        break;
                }
@@ -1414,18 +1415,14 @@ static int __devinit virtcons_probe(struct 
virtio_device *vdev)
                        err = -ENOMEM;
                        goto free_vqs;
                }
-
+       } else {
+               /*
+                * If we're running on an older host, we always want
+                * to create a console port.
+                */
+               add_port(portdev, 0);
        }
 
-       /*
-        * For backward compatibility: if we're running on an older
-        * host, we always want to create a console port.
-        */
-       add_port(portdev, 0);
-
-       /* Start using the new console output. */
-       early_put_chars = NULL;
-
        __send_control_msg(portdev, VIRTIO_CONSOLE_BAD_ID,
                           VIRTIO_CONSOLE_DEVICE_READY, 1);
        return 0;
-- 
1.6.2.5

_______________________________________________
Virtualization mailing list
[email protected]
https://lists.linux-foundation.org/mailman/listinfo/virtualization

Reply via email to