[PATCH] knfsd: Check return value of lockd_up in write_ports
authorNeilBrown <neilb@suse.de>
Mon, 2 Oct 2006 09:17:51 +0000 (02:17 -0700)
committerLinus Torvalds <torvalds@g5.osdl.org>
Mon, 2 Oct 2006 14:57:18 +0000 (07:57 -0700)
We should be checking the return value of lockd_up when adding a new socket to
nfsd.  So move the lockd_up before the svc_addsock and check the return value.

The move is because lockd_down is easy, but there is no easy way to remove a
recently added socket.

Cc: "J. Bruce Fields" <bfields@fieldses.org>
Signed-off-by: Neil Brown <neilb@suse.de>
Signed-off-by: Andrew Morton <akpm@osdl.org>
Signed-off-by: Linus Torvalds <torvalds@osdl.org>
fs/nfsd/nfsctl.c

index 80e97a5ffc3f835e3bcc60b0ed541733daa60cf4..36e8e135d5a654e65d045e9740e18a6c08850605 100644 (file)
@@ -454,12 +454,15 @@ static ssize_t write_ports(struct file *file, char *buf, size_t size)
                err = nfsd_create_serv();
                if (!err) {
                        int proto = 0;
-                       err = svc_addsock(nfsd_serv, fd, buf, &proto);
+                       err = lockd_up(proto);
+                       if (!err) {
+                               err = svc_addsock(nfsd_serv, fd, buf, &proto);
+                               if (err)
+                                       lockd_down();
+                       }
                        /* Decrease the count, but don't shutdown the
                         * the service
                         */
-                       if (err >= 0)
-                               lockd_up(proto);
                        nfsd_serv->sv_nrthreads--;
                }
                return err;