This patch adds some errors and warnings where there were none before:
    If someone typos "ubd" as "udb", that is caught and a warning is printed
    If a ubd file can't be opened, that now results in an error message
    If there are more telnet connections to port consoles than there are 
consoles, then a message will appear in the telnet session explaining why
there is no login prompt.

Signed-off-by: Jeff Dike <[EMAIL PROTECTED]>

Index: linux-2.6.11/arch/um/drivers/port_kern.c
===================================================================
--- linux-2.6.11.orig/arch/um/drivers/port_kern.c       2005-03-05 
12:07:31.000000000 -0500
+++ linux-2.6.11/arch/um/drivers/port_kern.c    2005-03-05 12:25:42.000000000 
-0500
@@ -10,6 +10,7 @@
 #include "linux/irq.h"
 #include "linux/spinlock.h"
 #include "linux/errno.h"
+#include "asm/atomic.h"
 #include "asm/semaphore.h"
 #include "asm/errno.h"
 #include "kern_util.h"
@@ -22,6 +23,7 @@
 
 struct port_list {
        struct list_head list;
+       atomic_t wait_count;
        int has_connection;
        struct semaphore sem;
        int port;
@@ -70,6 +72,13 @@
        return(IRQ_HANDLED);
 }
 
+#define NO_WAITER_MSG \
+    "****\n" \
+    "There are currently no UML consoles waiting for port connections.\n" \
+    "Either disconnect from one to make it available or activate some more\n" \
+    "by enabling more consoles in the UML /etc/inittab.\n" \
+    "****\n"
+
 static int port_accept(struct port_list *port)
 {
        struct connection *conn;
@@ -104,6 +113,10 @@
                goto out_free;
        }
 
+       if(atomic_read(&port->wait_count) == 0){
+               os_write_file(fd, NO_WAITER_MSG, sizeof(NO_WAITER_MSG));
+               printk("No one waiting for port\n");
+       }
        list_add(&conn->list, &port->pending);
        return(1);
 
@@ -182,6 +195,7 @@
 
        *port = ((struct port_list) 
                { .list                 = LIST_HEAD_INIT(port->list),
+                 .wait_count           = ATOMIC_INIT(0),
                  .has_connection       = 0,
                  .sem                  = __SEMAPHORE_INITIALIZER(port->sem, 
                                                                  0),
@@ -220,9 +234,11 @@
        struct port_list *port = dev->port;
        int fd;
 
+        atomic_inc(&port->wait_count);
        while(1){
+               fd = -ERESTARTSYS;
                if(down_interruptible(&port->sem))
-                       return(-ERESTARTSYS);
+                        goto out;
 
                spin_lock(&port->lock);
 
@@ -254,8 +270,9 @@
        dev->helper_pid = conn->helper_pid;
        dev->telnetd_pid = conn->telnetd_pid;
        kfree(conn);
-
-       return(fd);
+ out:
+       atomic_dec(&port->wait_count);
+       return fd;
 }
 
 void port_remove_dev(void *d)
Index: linux-2.6.11/arch/um/drivers/ubd_kern.c
===================================================================
--- linux-2.6.11.orig/arch/um/drivers/ubd_kern.c        2005-03-05 
12:11:43.000000000 -0500
+++ linux-2.6.11/arch/um/drivers/ubd_kern.c     2005-03-05 12:24:27.000000000 
-0500
@@ -453,6 +453,22 @@
 "    an 's' will cause data to be written to disk on the host immediately.\n\n"
 );
 
+static int udb_setup(char *str)
+{
+       printk("udb%s specified on command line is almost certainly a ubd -> "
+              "udb TYPO\n", str);
+       return(1);
+}
+
+__setup("udb", udb_setup);
+__uml_help(udb_setup,
+"udb\n"
+"    This option is here solely to catch ubd -> udb typos, which can be\n\n"
+"    to impossible to catch visually unless you specifically look for\n\n"
+"    them.  The only result of any option starting with 'udb' is an error\n\n"
+"    in the boot output.\n\n"
+);
+
 static int fakehd_set = 0;
 static int fakehd(char *str)
 {
@@ -605,7 +621,11 @@
                }
        }
 
-       if(dev->fd < 0) return(dev->fd);
+       if(dev->fd < 0){
+               printk("Failed to open '%s', errno = %d\n", dev->file, 
+                      -dev->fd);
+               return(dev->fd);
+       }
 
        if(dev->cow.file != NULL){
                err = -ENOMEM;

-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to [EMAIL PROTECTED]
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Please read the FAQ at  http://www.tux.org/lkml/

Reply via email to