Remove PDX and NPDENTRIES
[akaros.git] / kern / include / ns.h
index 0755e3b..797d895 100644 (file)
@@ -385,6 +385,10 @@ struct chan {
                void *aux;
                char tag[4];                    /* for iproute */
        };
+       /* mountpoint, as discovered during walk.
+        * Used for rename at present.
+        */
+       struct chan *mountpoint;
        struct chan *mchan;                     /* channel to mounted server */
        struct qid mqid;                        /* qid of root of mount point */
        struct cname *name;
@@ -423,8 +427,8 @@ 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);
-       /* we need to be aligned, i think to 32 bytes, for the linker tables. */
-} __attribute__ ((aligned(32)));
+       /* we need to be aligned, we think to 64 bytes, for the linker tables. */
+} __attribute__ ((aligned(64)));
 
 struct dirtab {
        char name[KNAMELEN];
@@ -576,7 +580,7 @@ enum {
        PRINTSIZE = 256,
        NUMSIZE = 12,   /* size of formatted number */
        MB = (1024 * 1024),
-       READSTR = 1000, /* temporary buffer size for device reads */
+       READSTR = 2000, /* temporary buffer size for device reads */
 };
 
 extern struct dev devtab[];
@@ -646,6 +650,7 @@ void closemount(struct mount *);
 void closepgrp(struct pgrp *);
 void closesigs(struct skeyset *);
 void cmderror(struct cmdbuf *, char *unused_char_p_t);
+void debugcmd(struct cmdbuf *cb);
 struct mhead *newmhead(struct chan *from);
 int cmount(struct chan *, struct chan *, int unused_int, char *unused_char_p_t);
 void cnameclose(struct cname *);
@@ -871,7 +876,6 @@ 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 *);
-void werrstr(char *unused_char_p_t, ...);
 void *xalloc(uint32_t);
 void *xallocz(uint32_t, int);
 void xfree(void *);
@@ -973,7 +977,7 @@ void cmderror(struct cmdbuf *cb, char *s);
 struct cmdtab *lookupcmd(struct cmdbuf *cb, struct cmdtab *ctab, int nctab);
 
 /* kern/src/ns/sysfile.c */
-int newfd(struct chan *c);
+int newfd(struct chan *c, bool oflags);
 struct chan *fdtochan(struct fgrp *f, int fd, int mode, int chkmnt, int iref);
 long kchanio(void *vc, void *buf, int n, int mode);
 int openmode(uint32_t o);
@@ -983,6 +987,8 @@ int grpclose(struct fgrp *f, int fd);
 int sysclose(int fd);
 int syscreate(char *path, int mode, uint32_t perm);
 int sysdup(int old, int new);
+int sys_dup_to(struct proc *from_proc, unsigned int from_fd,
+               struct proc *to_proc, unsigned int to_fd);
 int sysfstat(int fd, uint8_t*, int n);
 int sysfstatakaros(int fd, struct kstat *);
 char *sysfd2path(int fd);
@@ -996,6 +1002,7 @@ int sysmount(int fd, int afd, char *old, int flags, char *spec);
 int sysunmount(char *old, char *new);
 int sysopen(char *path, int mode);
 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);
 long syspread(int fd, void *va, long n, int64_t off);
 int sysremove(char *path);