net/9p: Handle mount errors correctly.
authorAneesh Kumar K.V <aneesh.kumar@linux.vnet.ibm.com>
Mon, 15 Feb 2010 17:27:02 +0000 (17:27 +0000)
committerEric Van Hensbergen <ericvh@gmail.com>
Fri, 5 Mar 2010 21:04:41 +0000 (15:04 -0600)
With this patch we have

# mount -t 9p -o trans=virtio virtio2 /mnt/
# mount -t 9p -o trans=virtio virtio2 /mnt/
mount: virtio2 already mounted or /mnt/ busy
mount: according to mtab, virtio2 is already mounted on /mnt
# mount -t 9p -o trans=virtio virtio3 /mnt/ -o debug=0xfff
mount: special device virtio3 does not exist

Signed-off-by: Aneesh Kumar K.V <aneesh.kumar@linux.vnet.ibm.com>
Signed-off-by: Eric Van Hensbergen <ericvh@gmail.com>
net/9p/trans_virtio.c

index 05918d3cb40de7fce1bd14bc503dff458541ed97..0aaed48193795407f87c3a9ecbdf1b7f2869a8b2 100644 (file)
@@ -279,6 +279,7 @@ static int
 p9_virtio_create(struct p9_client *client, const char *devname, char *args)
 {
        struct virtio_chan *chan;
+       int ret = -ENOENT;
        int found = 0;
 
        mutex_lock(&virtio_9p_lock);
@@ -289,13 +290,14 @@ p9_virtio_create(struct p9_client *client, const char *devname, char *args)
                                found = 1;
                                break;
                        }
+                       ret = -EBUSY;
                }
        }
        mutex_unlock(&virtio_9p_lock);
 
        if (!found) {
                printk(KERN_ERR "9p: no channels available\n");
-               return -ENODEV;
+               return ret;
        }
 
        client->trans = (void *)chan;