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 mount_9p: add initial support for 9P...



details:   https://anonhg.NetBSD.org/src/rev/ee78ba4f8280
branches:  trunk
changeset: 456591:ee78ba4f8280
user:      ozaki-r <ozaki-r%NetBSD.org@localhost>
date:      Fri May 17 08:48:04 2019 +0000

description:
mount_9p: add initial support for 9P2000.u

The implementation enables to work with a server talking 9P2000.u.  However, it
doesn't use the extended fields yet; it just ignores those of received messages
and sets "please ignore" values to those of sending messages such as zero-length
strings and maximum unsigned values.

The feature is enabled by the -u option.

diffstat:

 usr.sbin/puffs/mount_9p/fs.c        |  32 ++++++++++++++++++++++++++++----
 usr.sbin/puffs/mount_9p/mount_9p.8  |  18 +++++++++++++++++-
 usr.sbin/puffs/mount_9p/nineproto.c |  30 +++++++++++++++++++++++-------
 usr.sbin/puffs/mount_9p/nineproto.h |  28 ++++++++++++++++++++++++++--
 usr.sbin/puffs/mount_9p/ninepuffs.c |  12 +++++++++---
 usr.sbin/puffs/mount_9p/ninepuffs.h |  13 ++++++++-----
 usr.sbin/puffs/mount_9p/node.c      |  16 +++++++++-------
 7 files changed, 120 insertions(+), 29 deletions(-)

diffs (truncated from 473 to 300 lines):

diff -r 6d7b5e029af6 -r ee78ba4f8280 usr.sbin/puffs/mount_9p/fs.c
--- a/usr.sbin/puffs/mount_9p/fs.c      Fri May 17 08:26:20 2019 +0000
+++ b/usr.sbin/puffs/mount_9p/fs.c      Fri May 17 08:48:04 2019 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: fs.c,v 1.9 2011/06/22 04:03:23 mrg Exp $       */
+/*     $NetBSD: fs.c,v 1.10 2019/05/17 08:48:04 ozaki-r Exp $  */
 
 /*
  * Copyright (c) 2007  Antti Kantee.  All Rights Reserved.
@@ -27,7 +27,7 @@
 
 #include <sys/cdefs.h>
 #ifndef lint
-__RCSID("$NetBSD: fs.c,v 1.9 2011/06/22 04:03:23 mrg Exp $");
+__RCSID("$NetBSD: fs.c,v 1.10 2019/05/17 08:48:04 ozaki-r Exp $");
 #endif /* !lint */
 
 #include <assert.h>
@@ -48,6 +48,17 @@
        rv = fname(a1, a2, a3, a4);                                     \
        if (rv) errx(1, "p9p_handshake io failed %d, %d", rv, *a4) 
 
+static const char *
+p9p_ver2str(int version)
+{
+
+       switch (version) {
+       case P9PROTO_VERSION:   return P9PROTO_VERSTR;
+       case P9PROTO_VERSION_U: return P9PROTO_VERSTR_U;
+       }
+       return NULL;
+}
+
 struct puffs_node *
 p9p_handshake(struct puffs_usermount *pu,
        const char *username, const char *path)
@@ -63,13 +74,15 @@
        const char *p;
        uint8_t type;
        int rv, done, x = 1, ncomp;
+       uint16_t strsize;
+       char *str;
 
        /* send initial handshake */
        pb = p9pbuf_makeout();
        p9pbuf_put_1(pb, P9PROTO_T_VERSION);
        p9pbuf_put_2(pb, P9PROTO_NOTAG);
        p9pbuf_put_4(pb, p9p->maxreq);
-       p9pbuf_put_str(pb, P9PROTO_VERSION);
+       p9pbuf_put_str(pb, p9p_ver2str(p9p->protover));
        DO_IO(p9pbuf_write, pu, pb, p9p->servsock, &done, rv);
 
        puffs_framebuf_recycle(pb);
@@ -89,6 +102,13 @@
                    "%d vs. %d", P9P_MINREQLEN, maxreq);
        p9p->maxreq = maxreq;
 
+       if (p9pbuf_get_str(pb, &str, &strsize))
+               errx(1, "server invalid response: no version");
+       if (strncmp(str, p9p_ver2str(p9p->protover), P9PROTO_VERSTR_MAXLEN) != 0) {
+               errx(1, "server doesn't support %s", p9p_ver2str(p9p->protover));
+               /* Should downgrade from 9P2000.u to 9P2000 if the server request? */
+       }
+
        /* tell the server we don't support authentication */
        p9pbuf_recycleout(pb);
        tagid = NEXTTAG(p9p);
@@ -97,6 +117,8 @@
        p9pbuf_put_4(pb, P9PROTO_NOFID);
        p9pbuf_put_str(pb, username);
        p9pbuf_put_str(pb, "");
+       if (p9p->protover == P9PROTO_VERSION_U)
+               p9pbuf_put_4(pb, P9PROTO_NUNAME_UNSPECIFIED); /* n_uname[4] */
        DO_IO(p9pbuf_write, pu, pb, p9p->servsock, &done, rv);
 
        puffs_framebuf_recycle(pb);
@@ -117,6 +139,8 @@
        p9pbuf_put_4(pb, P9PROTO_NOFID);
        p9pbuf_put_str(pb, username);
        p9pbuf_put_str(pb, "");
+       if (p9p->protover == P9PROTO_VERSION_U)
+               p9pbuf_put_4(pb, P9PROTO_NUNAME_UNSPECIFIED); /* n_uname[4] */
        DO_IO(p9pbuf_write, pu, pb, p9p->servsock, &done, rv);
 
        puffs_framebuf_recycle(pb);
@@ -213,7 +237,7 @@
                errx(1, "server invalid tag: %d vs. %d", tagid, rtagid);
        if (p9pbuf_get_2(pb, &dummy))
                errx(1, "couldn't get stat len parameter");
-       if (proto_getstat(pb, &rootva, NULL, NULL))
+       if (proto_getstat(pu, pb, &rootva, NULL, NULL))
                errx(1, "could not parse root attributes");
        puffs_framebuf_destroy(pb);
 
diff -r 6d7b5e029af6 -r ee78ba4f8280 usr.sbin/puffs/mount_9p/mount_9p.8
--- a/usr.sbin/puffs/mount_9p/mount_9p.8        Fri May 17 08:26:20 2019 +0000
+++ b/usr.sbin/puffs/mount_9p/mount_9p.8        Fri May 17 08:48:04 2019 +0000
@@ -1,4 +1,4 @@
-.\"    $NetBSD: mount_9p.8,v 1.7 2019/05/17 08:26:20 wiz Exp $
+.\"    $NetBSD: mount_9p.8,v 1.8 2019/05/17 08:48:04 ozaki-r Exp $
 .\"
 .\" Copyright (c) 2007 Antti Kantee.  All rights reserved.
 .\"
@@ -32,6 +32,7 @@
 .Sh SYNOPSIS
 .Nm
 .Op Fl s
+.Op Fl u
 .Op Fl o Ar mntopts
 .Op Fl p Ar port
 .Ar [user@]host[:path]
@@ -61,6 +62,16 @@
 option
 .Nm
 runs in the forground.
+.Pp
+By default
+.Nm
+follows the 9P2000 protocol.
+With
+.Fl u
+option
+.Nm
+follows the 9P2000.u protocol that includes extensions to better support Unix
+environments.
 .Sh SEE ALSO
 .Xr puffs 3 ,
 .Xr puffs 4 ,
@@ -74,6 +85,9 @@
 .Nm
 utility first appeared in
 .Nx 5.0 .
+.Pp
+Experimental 9P2000.u support appeared in
+.Nx 9.0 .
 .Sh CAVEATS
 Permissions are not handled well.
 .Pp
@@ -82,3 +96,5 @@
 Error code handling is missing.
 .Pp
 Under construction.
+.Pp
+9P2000.u support doesn't use extension fields.
diff -r 6d7b5e029af6 -r ee78ba4f8280 usr.sbin/puffs/mount_9p/nineproto.c
--- a/usr.sbin/puffs/mount_9p/nineproto.c       Fri May 17 08:26:20 2019 +0000
+++ b/usr.sbin/puffs/mount_9p/nineproto.c       Fri May 17 08:48:04 2019 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: nineproto.c,v 1.9 2007/11/30 19:02:38 pooka Exp $      */
+/*     $NetBSD: nineproto.c,v 1.10 2019/05/17 08:48:04 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.9 2007/11/30 19:02:38 pooka Exp $");
+__RCSID("$NetBSD: nineproto.c,v 1.10 2019/05/17 08:48:04 ozaki-r Exp $");
 #endif /* !lint */
 
 #include <sys/types.h>
@@ -117,9 +117,10 @@
        size -= *strsize;                                               \
 } while (/*CONSTCOND*/0)
 int
-proto_getstat(struct puffs_framebuf *pb, struct vattr *vap,
+proto_getstat(struct puffs_usermount *pu, struct puffs_framebuf *pb, struct vattr *vap,
        char **name, uint16_t *rs)
 {
+       struct puffs9p *p9p = puffs_getspecific(pu);
        char *uid, *gid;
        struct qid9p qid;
        uint64_t flen;
@@ -176,6 +177,13 @@
 
        /* muid, not used */
        GETSTR(NULL, &v16);
+       if (p9p->protover == P9PROTO_VERSION_U) {
+               uint32_t dummy;
+               GETSTR(NULL, &v16); /* extention[s], not used */
+               GETFIELD(p9pbuf_get_4, &dummy, 4); /* n_uid[4], not used */
+               GETFIELD(p9pbuf_get_4, &dummy, 4); /* n_gid[4], not used */
+               GETFIELD(p9pbuf_get_4, &dummy, 4); /* n_muid[4], not used */
+       }
 
        return 0;
 }
@@ -269,9 +277,10 @@
 }
 
 void
-proto_make_stat(struct puffs_framebuf *pb, const struct vattr *vap,
-       const char *filename, enum vtype vt)
+proto_make_stat(struct puffs_usermount *pu, struct puffs_framebuf *pb,
+    const struct vattr *vap, const char *filename, enum vtype vt)
 {
+       struct puffs9p *p9p = puffs_getspecific(pu);
        struct vattr fakeva;
        uint32_t mode, atime, mtime;
        uint64_t flen;
@@ -324,6 +333,12 @@
        p9pbuf_put_str(pb, owner);
        p9pbuf_put_str(pb, group);
        p9pbuf_put_str(pb, "");                 /* muid         */
+       if (p9p->protover == P9PROTO_VERSION_U) {
+               p9pbuf_put_str(pb, P9PROTO_STAT_NOSTR); /* extentions[s] */
+               p9pbuf_put_4(pb, P9PROTO_STAT_NOVAL4);  /* n_uid[4] */
+               p9pbuf_put_4(pb, P9PROTO_STAT_NOVAL4);  /* n_gid[4] */
+               p9pbuf_put_4(pb, P9PROTO_STAT_NOVAL4);  /* n_muid[4] */
+       }
 
        curoff = puffs_framebuf_telloff(pb);
        puffs_framebuf_seekset(pb, startoff);
@@ -352,7 +367,8 @@
 }
 
 int
-proto_expect_stat(struct puffs_framebuf *pb, struct vattr *va)
+proto_expect_stat(struct puffs_usermount *pu, struct puffs_framebuf *pb,
+    struct vattr *va)
 {
        uint16_t dummy;
        int rv;
@@ -361,5 +377,5 @@
                return EPROTO;
        if ((rv = p9pbuf_get_2(pb, &dummy)))
                return rv;
-       return proto_getstat(pb, va, NULL, NULL);
+       return proto_getstat(pu, pb, va, NULL, NULL);
 }
diff -r 6d7b5e029af6 -r ee78ba4f8280 usr.sbin/puffs/mount_9p/nineproto.h
--- a/usr.sbin/puffs/mount_9p/nineproto.h       Fri May 17 08:26:20 2019 +0000
+++ b/usr.sbin/puffs/mount_9p/nineproto.h       Fri May 17 08:48:04 2019 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: nineproto.h,v 1.1 2007/04/21 14:21:43 pooka Exp $      */
+/*     $NetBSD: nineproto.h,v 1.2 2019/05/17 08:48:04 ozaki-r Exp $    */
 
 /*
  * Copyright (c) 2007  Antti Kantee.  All Rights Reserved.
@@ -30,7 +30,12 @@
 
 #include <stdint.h>
 
-#define P9PROTO_VERSION                "9P2000"
+#define P9PROTO_VERSION                0
+#define P9PROTO_VERSION_U      1
+
+#define P9PROTO_VERSTR         "9P2000"
+#define P9PROTO_VERSTR_U       "9P2000.u"
+#define P9PROTO_VERSTR_MAXLEN  (sizeof(P9PROTO_VERSTR_U))
 
 #define P9PROTO_T_VERSION      100
 #define P9PROTO_R_VERSION      101
@@ -66,12 +71,18 @@
 #define P9PROTO_NOFID          (uint32_t)~0
 #define P9PROTO_NOTAG          (uint16_t)~0
 
+#define P9PROTO_NUNAME_UNSPECIFIED     (uint16_t)~0
+
 /* type field in a qid */
 #define P9PROTO_QID_TYPE_DIR   0x80
 #define P9PROTO_QID_TYPE_APPEND        0x40
 #define P9PROTO_QID_TYPE_EXCL  0x20
 #define P9PROTO_QID_TYPE_MOUNT 0x10
 #define P9PROTO_QID_TYPE_AUTH  0x08
+/* P92000.u extensions */
+#define P9PROTO_QID_TYPE_TMP   0x04
+#define P9PROTO_QID_TYPE_LINK  0x02
+#define P9PROTO_QID_TYPE_FILE  0x00
 
 /* mode in open */
 #define P9PROTO_OMODE_READ     0x00
@@ -83,11 +94,24 @@
 
 /* for creating directories */
 #define P9PROTO_CPERM_DIR      0x80000000
+#define P9PROTO_CPERM_APPEND   0x40000000
+#define P9PROTO_CPERM_EXCL     0x20000000
+#define P9PROTO_CPERM_MOUNT    0x10000000
+#define P9PROTO_CPERM_AUTH     0x08000000
+#define P9PROTO_CPERM_TMP      0x04000000
+#define P9PROTO_CPERM_SYMLINK  0x02000000
+/* P92000.u extensions */
+#define P9PROTO_CPERM_DEVICE   0x00800000
+#define P9PROTO_CPERM_NAMEDPIPE        0x00200000
+#define P9PROTO_CPERM_SOCKET   0x00100000
+#define P9PROTO_CPERM_SETUID   0x00080000
+#define P9PROTO_CPERM_SETGID   0x00040000
 
 /* stat non-values */
 #define P9PROTO_STAT_NOVAL1    (uint8_t)~0
 #define P9PROTO_STAT_NOVAL2    (uint16_t)~0
 #define P9PROTO_STAT_NOVAL4    (uint32_t)~0
 #define P9PROTO_STAT_NOVAL8    (uint64_t)~0
+#define P9PROTO_STAT_NOSTR     ""
 
 #endif /* PUFFS9P_PROTO_H_ */
diff -r 6d7b5e029af6 -r ee78ba4f8280 usr.sbin/puffs/mount_9p/ninepuffs.c
--- a/usr.sbin/puffs/mount_9p/ninepuffs.c       Fri May 17 08:26:20 2019 +0000



Home | Main Index | Thread Index | Old Index