Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/usr.sbin/puffs/mount_9p Handle Rerror and return errno corre...
details:   https://anonhg.NetBSD.org/src/rev/81efa8ecef88
branches:  trunk
changeset: 457023:81efa8ecef88
user:      ozaki-r <ozaki-r%NetBSD.org@localhost>
date:      Fri Jun 07 05:34:34 2019 +0000
description:
Handle Rerror and return errno correctly (only for 9P2000.u for now)
diffstat:
 usr.sbin/puffs/mount_9p/mount_9p.8  |   6 +-
 usr.sbin/puffs/mount_9p/nineproto.c |  65 +++++++++++++++++++++++++++++++-----
 usr.sbin/puffs/mount_9p/ninepuffs.h |   9 +++-
 usr.sbin/puffs/mount_9p/node.c      |  25 ++++++++-----
 usr.sbin/puffs/mount_9p/subr.c      |   6 +-
 5 files changed, 82 insertions(+), 29 deletions(-)
diffs (truncated from 305 to 300 lines):
diff -r 535ecf2beb45 -r 81efa8ecef88 usr.sbin/puffs/mount_9p/mount_9p.8
--- a/usr.sbin/puffs/mount_9p/mount_9p.8        Fri Jun 07 05:22:28 2019 +0000
+++ b/usr.sbin/puffs/mount_9p/mount_9p.8        Fri Jun 07 05:34:34 2019 +0000
@@ -1,4 +1,4 @@
-.\"    $NetBSD: mount_9p.8,v 1.9 2019/05/17 08:56:12 wiz Exp $
+.\"    $NetBSD: mount_9p.8,v 1.10 2019/06/07 05:34:34 ozaki-r Exp $
 .\"
 .\" Copyright (c) 2007 Antti Kantee.  All rights reserved.
 .\"
@@ -23,7 +23,7 @@
 .\" OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
 .\" SUCH DAMAGE.
 .\"
-.Dd May 15, 2019
+.Dd June 7, 2019
 .Dt MOUNT_9P 8
 .Os
 .Sh NAME
@@ -92,7 +92,7 @@
 .Pp
 Authentication support is missing.
 .Pp
-Error code handling is missing.
+Error code handling is missing for 9P2000.
 .Pp
 Under construction.
 .Pp
diff -r 535ecf2beb45 -r 81efa8ecef88 usr.sbin/puffs/mount_9p/nineproto.c
--- a/usr.sbin/puffs/mount_9p/nineproto.c       Fri Jun 07 05:22:28 2019 +0000
+++ b/usr.sbin/puffs/mount_9p/nineproto.c       Fri Jun 07 05:34:34 2019 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: nineproto.c,v 1.10 2019/05/17 08:48:04 ozaki-r Exp $   */
+/*     $NetBSD: nineproto.c,v 1.11 2019/06/07 05:34:34 ozaki-r Exp $   */
 
 /*
  * Copyright (c) 2007  Antti Kantee.  All Rights Reserved.
@@ -27,7 +27,7 @@
 
 #include <sys/cdefs.h>
 #ifndef lint
-__RCSID("$NetBSD: nineproto.c,v 1.10 2019/05/17 08:48:04 ozaki-r Exp $");
+__RCSID("$NetBSD: nineproto.c,v 1.11 2019/06/07 05:34:34 ozaki-r Exp $");
 #endif /* !lint */
 
 #include <sys/types.h>
@@ -188,6 +188,49 @@
        return 0;
 }
 
+static int
+proto_rerror(struct puffs_usermount *pu, struct puffs_framebuf *pb,
+    uint32_t *_errno)
+{
+       struct puffs9p *p9p = puffs_getspecific(pu);
+       uint16_t size;
+       int rv;
+       char *name;
+
+       /* Skip size[4] Rerror tag[2] */
+       rv = puffs_framebuf_seekset(pb,
+           sizeof(uint32_t) + sizeof(uint8_t) + sizeof(uint16_t));
+       if (rv == -1)
+               return EPROTO;
+
+       rv = p9pbuf_get_str(pb, &name, &size);
+       if (rv != 0)
+               return rv;
+       if (p9p->protover == P9PROTO_VERSION_U) {
+               rv = p9pbuf_get_4(pb, _errno);
+       } else {
+               /* TODO Convert error string to errno */
+               rv = EPROTO;
+       }
+
+       return rv;
+}
+
+int
+proto_handle_rerror(struct puffs_usermount *pu, struct puffs_framebuf *pb)
+{
+       int rv;
+       uint32_t _errno;
+
+       if (p9pbuf_get_type(pb) != P9PROTO_R_ERROR)
+               return EPROTO;
+
+       rv = proto_rerror(pu, pb, &_errno);
+       if (rv == 0)
+               rv = _errno;
+       return rv;
+}
+
 int
 proto_cc_dupfid(struct puffs_usermount *pu, p9pfid_t oldfid, p9pfid_t newfid)
 {
@@ -206,7 +249,7 @@
        p9pbuf_put_2(pb, 0);
        GETRESPONSE(pb);
 
-       rv = proto_expect_walk_nqids(pb, &qids);
+       rv = proto_expect_walk_nqids(pu, pb, &qids);
        if (rv == 0 && qids != 0)
                rv = EPROTO;
 
@@ -232,7 +275,7 @@
        if (waitforit) {
                if (puffs_framev_enqueue_cc(pcc, p9p->servsock, pb, 0) == 0) {
                        if (p9pbuf_get_type(pb) != P9PROTO_R_CLUNK)
-                               rv = EPROTO;
+                               rv = proto_handle_rerror(pu, pb);
                } else {
                        rv = errno;
                }
@@ -269,7 +312,7 @@
        p9pbuf_put_1(pb, mode);
        GETRESPONSE(pb);
        if (p9pbuf_get_type(pb) != P9PROTO_R_OPEN)
-               rv = EPROTO;
+               rv = proto_handle_rerror(pu, pb);
 
  out:
        puffs_framebuf_destroy(pb);
@@ -349,20 +392,22 @@
 }
 
 int
-proto_expect_walk_nqids(struct puffs_framebuf *pb, uint16_t *nqids)
+proto_expect_walk_nqids(struct puffs_usermount *pu, struct puffs_framebuf *pb,
+    uint16_t *nqids)
 {
 
        if (p9pbuf_get_type(pb) != P9PROTO_R_WALK)
-               return EPROTO;
+               return proto_handle_rerror(pu, pb);
        return p9pbuf_get_2(pb, nqids);
 }
 
 int
-proto_expect_qid(struct puffs_framebuf *pb, uint8_t op, struct qid9p *qid)
+proto_expect_qid(struct puffs_usermount *pu, struct puffs_framebuf *pb,
+    uint8_t op, struct qid9p *qid)
 {
 
        if (p9pbuf_get_type(pb) != op)
-               return EPROTO;
+               return proto_handle_rerror(pu, pb);
        return proto_getqid(pb, qid);
 }
 
@@ -374,7 +419,7 @@
        int rv;
 
        if (p9pbuf_get_type(pb) != P9PROTO_R_STAT)
-               return EPROTO;
+               return proto_handle_rerror(pu, pb);
        if ((rv = p9pbuf_get_2(pb, &dummy)))
                return rv;
        return proto_getstat(pu, pb, va, NULL, NULL);
diff -r 535ecf2beb45 -r 81efa8ecef88 usr.sbin/puffs/mount_9p/ninepuffs.h
--- a/usr.sbin/puffs/mount_9p/ninepuffs.h       Fri Jun 07 05:22:28 2019 +0000
+++ b/usr.sbin/puffs/mount_9p/ninepuffs.h       Fri Jun 07 05:34:34 2019 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: ninepuffs.h,v 1.13 2019/05/17 08:48:04 ozaki-r Exp $   */
+/*     $NetBSD: ninepuffs.h,v 1.14 2019/06/07 05:34:34 ozaki-r Exp $   */
 
 /*
  * Copyright (c) 2007  Antti Kantee.  All Rights Reserved.
@@ -151,10 +151,13 @@
 int    proto_getqid(struct puffs_framebuf *, struct qid9p *);
 int    proto_getstat(struct puffs_usermount *, struct puffs_framebuf *, struct vattr *,
                      char **, uint16_t *);
-int    proto_expect_walk_nqids(struct puffs_framebuf *, uint16_t *);
+int    proto_expect_walk_nqids(struct puffs_usermount *,
+                               struct puffs_framebuf *, uint16_t *);
 int    proto_expect_stat(struct puffs_usermount *, struct puffs_framebuf *,
                          struct vattr *);
-int    proto_expect_qid(struct puffs_framebuf *, uint8_t, struct qid9p *);
+int    proto_expect_qid(struct puffs_usermount *, struct puffs_framebuf *,
+                        uint8_t, struct qid9p *);
+int    proto_handle_rerror(struct puffs_usermount *, struct puffs_framebuf *);
 
 int    proto_cc_dupfid(struct puffs_usermount *, p9pfid_t, p9pfid_t);
 int    proto_cc_clunkfid(struct puffs_usermount *, p9pfid_t, int);
diff -r 535ecf2beb45 -r 81efa8ecef88 usr.sbin/puffs/mount_9p/node.c
--- a/usr.sbin/puffs/mount_9p/node.c    Fri Jun 07 05:22:28 2019 +0000
+++ b/usr.sbin/puffs/mount_9p/node.c    Fri Jun 07 05:34:34 2019 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: node.c,v 1.22 2019/05/17 08:48:04 ozaki-r Exp $        */
+/*     $NetBSD: node.c,v 1.23 2019/06/07 05:34:34 ozaki-r Exp $        */
 
 /*
  * Copyright (c) 2007  Antti Kantee.  All Rights Reserved.
@@ -27,7 +27,7 @@
 
 #include <sys/cdefs.h>
 #ifndef lint
-__RCSID("$NetBSD: node.c,v 1.22 2019/05/17 08:48:04 ozaki-r Exp $");
+__RCSID("$NetBSD: node.c,v 1.23 2019/06/07 05:34:34 ozaki-r Exp $");
 #endif /* !lint */
 
 #include <assert.h>
@@ -62,6 +62,10 @@
        p9pbuf_put_4(pb, p9n->fid_base);
        GETRESPONSE(pb);
 
+       if (p9pbuf_get_type(pb) != P9PROTO_R_STAT) {
+               rv = proto_handle_rerror(pu, pb);
+               goto out;
+       }
        rv = proto_expect_stat(pu, pb, vap);
 
  out:
@@ -101,7 +105,7 @@
        p9pbuf_put_str(pb, pcn->pcn_name);
        GETRESPONSE(pb);
 
-       rv = proto_expect_walk_nqids(pb, &nqid);
+       rv = proto_expect_walk_nqids(pu, pb, &nqid);
        if (rv) {
                rv = ENOENT;
                goto out;
@@ -234,8 +238,9 @@
        proto_make_stat(pu, pb, va, NULL, pn->pn_va.va_type);
        GETRESPONSE(pb);
 
-       if (p9pbuf_get_type(pb) != P9PROTO_R_WSTAT)
-               rv = EPROTO;
+       if (p9pbuf_get_type(pb) != P9PROTO_R_WSTAT) {
+               rv = proto_handle_rerror(pu, pb);
+       }
 
  out:
        RETURN(rv);
@@ -330,7 +335,7 @@
                GETRESPONSE(pb);
 
                if (p9pbuf_get_type(pb) != P9PROTO_R_READ) {
-                       rv = EPROTO;
+                       rv = proto_handle_rerror(pu, pb);
                        break;
                }
 
@@ -378,7 +383,7 @@
                GETRESPONSE(pb);
 
                if (p9pbuf_get_type(pb) != P9PROTO_R_WRITE) {
-                       rv = EPROTO;
+                       rv = proto_handle_rerror(pu, pb);
                        break;
                }
 
@@ -430,7 +435,7 @@
                p9pbuf_put_str(pb, ""); /* extension[s] */
        GETRESPONSE(pb);
 
-       rv = proto_expect_qid(pb, P9PROTO_R_CREATE, &nqid);
+       rv = proto_expect_qid(pu, pb, P9PROTO_R_CREATE, &nqid);
        if (rv)
                goto out;
 
@@ -512,7 +517,7 @@
        GETRESPONSE(pb);
 
        if (p9pbuf_get_type(pb) != P9PROTO_R_REMOVE) {
-               rv = EPROTO;
+               rv = proto_handle_rerror(pu, pb);
        } else {
                proto_cc_clunkfid(pu, p9n->fid_base, 0);
                p9n->fid_base = P9P_INVALFID;
@@ -585,7 +590,7 @@
        GETRESPONSE(pb);
 
        if (p9pbuf_get_type(pb) != P9PROTO_R_WSTAT)
-               rv = EPROTO;
+               rv = proto_handle_rerror(pu, pb);
 
  out:
        RETURN(rv);
diff -r 535ecf2beb45 -r 81efa8ecef88 usr.sbin/puffs/mount_9p/subr.c
--- a/usr.sbin/puffs/mount_9p/subr.c    Fri Jun 07 05:22:28 2019 +0000
+++ b/usr.sbin/puffs/mount_9p/subr.c    Fri Jun 07 05:34:34 2019 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: subr.c,v 1.6 2007/11/30 19:02:39 pooka Exp $   */
+/*     $NetBSD: subr.c,v 1.7 2019/06/07 05:34:34 ozaki-r Exp $ */
 
 /*
  * Copyright (c) 2007  Antti Kantee.  All Rights Reserved.
@@ -27,7 +27,7 @@
 
 #include <sys/cdefs.h>
 #ifndef lint
-__RCSID("$NetBSD: subr.c,v 1.6 2007/11/30 19:02:39 pooka Exp $");
+__RCSID("$NetBSD: subr.c,v 1.7 2019/06/07 05:34:34 ozaki-r Exp $");
 #endif /* !lint */
 
 #include <sys/types.h>
@@ -139,7 +139,7 @@
                GETRESPONSE(pb);
 
                if (p9pbuf_get_type(pb) != P9PROTO_R_READ) {
Home |
Main Index |
Thread Index |
Old Index