Implement sys_open() with sys_openat() (XCC)
[akaros.git] / kern / include / ns.h
index f17dc8e..8e7a29e 100644 (file)
@@ -7,6 +7,7 @@
 #include <rendez.h>
 #include <rwlock.h>
 #include <linker_func.h>
+#include <fdtap.h>
 
 /*
  * functions (possibly) linked in, complete, from libc.
@@ -310,13 +311,16 @@ enum {
        CCACHE =                0x0008, /* client cache */
        CINTERNAL_FLAGS = (COPEN | CMSG | CFREE | CCACHE),
 
-       /* chan/file flags, setably via open and sometimes fcntl/setfl.  these are
-        * the internal names used in some parts of 9ns */
-       CCEXEC =                O_CLOEXEC,      /* (prob should be on the FD, 9ns has it here) */
-       CRCLOSE =               O_REMCLO,       /* remove on close (also, maybe should be on FD) */
-       CAPPEND =               O_APPEND,       /* append on write */
-       CNONBLOCK =     O_NONBLOCK,     /* don't block, can't be set via setfl */
-       CEXTERNAL_FLAGS = (CCEXEC | CRCLOSE | CAPPEND | CNONBLOCK),
+       /* chan/file flags, getable via fcntl/getfl and setably via open and
+        * sometimes fcntl/setfl.  those that can't be set cause an error() in
+        * fd_setfl. */
+       CEXTERNAL_FLAGS = (
+           O_CLOEXEC      | /* (prob should be on the FD, 9ns has it here) */
+           O_REMCLO       | /* remove on close (also, maybe should be on FD) */
+           O_APPEND       | /* append on write */
+           O_NONBLOCK     | /* don't block, can't be set via setfl */
+           O_PATH         | /* path open, just the name, no I/O */
+           0),
 };
 
 #define NS_IPCK_SHIFT  2
@@ -412,7 +416,6 @@ struct cname {
 };
 
 struct dev {
-       int dc;
        char *name;
 
        void (*reset) (void);
@@ -433,6 +436,7 @@ struct dev {
        void (*power) (int);            /* power mgt: power(1) → on, power (0) → off */
 //  int (*config)( int unused_int, char *unused_char_p_t, DevConf*);
        char *(*chaninfo) (struct chan *, char *, size_t);
+       int (*tapfd) (struct chan *, struct fd_tap *, int);
        /* we need to be aligned, we think to 64 bytes, for the linker tables. */
 } __attribute__ ((aligned(64)));
 
@@ -527,16 +531,6 @@ struct pgrp {
        int pin;
 };
 
-struct fgrp {
-       spinlock_t lock;
-       struct kref ref;
-       struct chan **fd;
-       int nfd;                                        /* number of fd slots */
-       int maxfd;                                      /* highest fd in use */
-       int minfd;                                      /* lower bound on free fd */
-       int closed;
-};
-
 struct evalue {
        char *var;
        char *val;
@@ -651,7 +645,6 @@ void cinit(void);
 struct chan *cclone(struct chan *);
 void cclose(struct chan *);
 void closeegrp(struct egrp *);
-void closefgrp(struct fgrp *);
 void closemount(struct mount *);
 void closepgrp(struct pgrp *);
 void closesigs(struct skeyset *);
@@ -675,7 +668,7 @@ void cursordisable(void);
 int cursoron(int);
 void cursoroff(int);
 void cwrite(struct chan *, uint8_t * unused_uint8_p_t, int unused_int, int64_t);
-struct chan *devattach(int unused_int, char *unused_char_p_t);
+struct chan *devattach(const char *name, char *spec);
 struct block *devbread(struct chan *, long, uint32_t);
 long devbwrite(struct chan *, struct block *, uint32_t);
 struct chan *devclone(struct chan *);
@@ -685,7 +678,7 @@ void devdir(struct chan *, struct qid, char *, int64_t, char *, long,
 long devdirread(struct chan *, char *, long, struct dirtab *, int, Devgen *);
 Devgen devgen;
 void devinit(void);
-int devno(int unused_int, int);
+int devno(const char *name, int user);
 void devpower(int);
 struct dev *devbyname(char *unused_char_p_t);
 struct chan *devopen(struct chan *, int unused_int,
@@ -707,7 +700,6 @@ int domount(struct chan **, struct mhead **);
 void drawactive(int);
 void drawcmap(void);
 void dumpstack(void);
-struct fgrp *dupfgrp(struct proc *, struct fgrp *);
 void egrpcpy(struct egrp *, struct egrp *);
 int emptystr(char *unused_char_p_t);
 int eqchan(struct chan *, struct chan *, int);
@@ -743,7 +735,6 @@ int kbdcr2nl(struct queue *, int);
 int kbdputc(struct queue *, int);
 void kbdrepeat(int);
 void kproc(char *unused_char_p_t, void (*)(void *), void *, int);
-int fgrpclose(struct fd_table *, int);
 void kprocchild(struct proc *, void (*)(void *), void *);
 void (*kproftick) (uint32_t);
 void ksetenv(char *unused_char_p_t, char *, int);
@@ -764,9 +755,10 @@ uint64_t ms2fastticks(uint32_t);
 void mul64fract(uint64_t *, uint64_t, uint64_t);
 void muxclose(struct mnt *);
 struct chan *namec(char *unused_char_p_t, int unused_int, int, uint32_t);
+struct chan *namec_from(struct chan *c, char *name, int amode, int omode,
+                        uint32_t perm);
 struct chan *newchan(void);
 struct egrp *newegrp(void);
-struct fgrp *newfgrp(void);
 struct mount *newmount(struct mhead *, struct chan *, int unused_int,
                                           char *unused_char_p_t);
 struct pgrp *newpgrp(void);
@@ -778,6 +770,8 @@ void notkilled(void);
 int nrand(int);
 uint64_t ns2fastticks(uint64_t);
 int okaddr(uint32_t, uint32_t, int);
+int omode_to_rwx(int);
+int omode_to_9p_accmode(int open_flags);
 struct block *packblock(struct block *);
 struct block *padblock(struct block *, int);
 
@@ -825,6 +819,9 @@ void qreopen(struct queue *);
 void qsetlimit(struct queue *, int);
 int qwindow(struct queue *);
 int qwrite(struct queue *, void *, int);
+typedef void (*qio_wake_cb_t)(struct queue *q, void *data, int filter);
+void qio_set_wake_cb(struct queue *q, qio_wake_cb_t func, void *data);
+
 void randominit(void);
 uint32_t randomread(void *, uint32_t);
 void *realloc(void *, uint32_t);
@@ -871,7 +868,7 @@ void userinit(void);
 uint32_t userpc(void);
 void validname(char *, int);
 void validwstatname(char *);
-int walk(struct chan **, char **unused_char_pp_t, int unused_int, int, int *);
+int walk(struct chan **, char **unused_char_pp_t, int unused_int, bool, int *);
 void *xalloc(uint32_t);
 void *xallocz(uint32_t, int);
 void xfree(void *);
@@ -891,18 +888,13 @@ uint32_t nhgetl(void *);
 uint16_t nhgets(void *);
 
 /* error messages, from inferno emu error.h */
-extern char Enoerror[];                        /* no error */
 extern char Emount[];                  /* inconsistent mount */
 extern char Eunmount[];                        /* not mounted */
 extern char Eunion[];                  /* not in union */
 extern char Emountrpc[];               /* mount rpc error */
-extern char Eshutdown[];               /* mounted device shut down */
-extern char Eowner[];                  /* not owner */
-extern char Eunknown[];                        /* unknown user or group id */
 extern char Enocreate[];               /* mounted directory forbids creation */
 extern char Enonexist[];               /* file does not exist */
 extern char Eexist[];                  /* file already exists */
-extern char Ebadsharp[];               /* unknown device in # filename */
 extern char Enotdir[];                 /* not a directory */
 extern char Eisdir[];                  /* file is a directory */
 extern char Ebadchar[];                        /* bad character in file name */
@@ -914,46 +906,28 @@ extern char Einuse[];                     /* device or object already in use */
 extern char Eio[];                             /* i/o error */
 extern char Etoobig[];                 /* read or write too large */
 extern char Etoosmall[];               /* read or write too small */
-extern char Enetaddr[];                        /* bad network address */
-extern char Emsgsize[];                        /* message is too big for protocol */
-extern char Enetbusy[];                        /* network device is busy or allocated */
-extern char Enoproto[];                        /* network protocol not supported */
-extern char Enoport[];                 /* network port not available */
 extern char Enoifc[];                  /* bad interface or no free interface slots */
-extern char Enolisten[];               /* not announced */
 extern char Ehungup[];                 /* i/o on hungup channel */
 extern char Ebadctl[];                 /* bad process or channel control request */
 extern char Enodev[];                  /* no free devices */
-extern char Enoenv[];                  /* no free environment resources */
-extern char Ethread[];                 /* thread exited */
 extern char Enochild[];                        /* no living children */
-extern char Eioload[];                 /* i/o error in demand load */
 extern char Enovmem[];                 /* out of memory: virtual memory */
-extern char Ebadld[];                  /* illegal line discipline */
-extern char Ebadfd[];                  /* fd out of range or not open */
 extern char Eisstream[];               /* seek on a stream */
-extern char Ebadexec[];                        /* exec header invalid */
 extern char Etimedout[];               /* connection timed out */
 extern char Econrefused[];             /* connection refused */
 extern char Econinuse[];               /* connection in use */
-extern char Enetunreach[];             /* network unreachable */
 extern char Eintr[];                   /* interrupted */
 extern char Enomem[];                  /* out of memory: kernel */
-extern char Esfnotcached[];            /* subfont not cached */
-extern char Esoverlap[];               /* segments overlap */
-extern char Emouseset[];               /* mouse type already set */
 extern char Eshort[];                  /* i/o count too small */
 extern char Enobitstore[];             /* out of screen memory */
 extern char Egreg[];                   /* jim'll fix it */
 extern char Ebadspec[];                        /* bad attach specifier */
-extern char Estopped[];                        /* thread must be stopped */
 extern char Enoattach[];               /* mount/attach disallowed */
 extern char Eshortstat[];              /* stat buffer too small */
 extern char Enegoff[];                 /* negative i/o offset */
 extern char Ebadstat[];                        /* malformed stat buffer */
 extern char Ecmdargs[];                        /* wrong #args in control message */
 extern char Enofd[];                   /* no free file descriptors */
-extern char Enoctl[];                  /* unknown control request */
 extern char Eprocdied[];               /* process died */
 
 char *get_cur_genbuf(void);
@@ -997,7 +971,8 @@ long bindmount(struct chan *c, char *old, int flag, char *spec);
 int sysbind(char *new, char *old, int flags);
 int sysmount(int fd, int afd, char *old, int flags, char *spec);
 int sysunmount(char *old, char *new);
-int sysopen(char *path, int mode);
+int sysopenat(int dirfd, char *path, int vfs_flags);
+int sysopen(char *path, int vfs_flags);
 long unionread(struct chan *c, void *va, long n);
 void read_exactly_n(struct chan *c, void *vp, long n);
 long sysread(int fd, void *va, long n);
@@ -1017,9 +992,7 @@ int sysdirwstat(char *name, struct dir *dir);
 int sysdirfwstat(int fd, struct dir *dir);
 long sysdirread(int fd, struct kdirent **d);
 int sysiounit(int fd);
-void close_9ns_files(struct proc *p, bool only_cloexec);
 void print_chaninfo(struct chan *ch);
-void print_9ns_files(struct proc *p);
 int plan9setup(struct proc *new_proc, struct proc *parent, int flags);
 int iseve(void);
 int fd_getfl(int fd);