Remove CONFIG_KTHREAD_POISON
[akaros.git] / kern / src / ns / sysfile.c
index 1563006..0011513 100644 (file)
@@ -353,52 +353,6 @@ int sysfversion(int fd, unsigned int msize, char *vers, unsigned int arglen)
        return m;
 }
 
-int syspipe(int fd[2])
-{
-       ERRSTACK(1);
-       struct dev *d;
-       struct chan *c[2];
-       static char *names[] = { "data", "data1" };
-
-       d = &devtab[devno("pipe", 0)];
-       c[0] = 0;
-       c[1] = 0;
-       fd[0] = -1;
-       fd[1] = -1;
-       if (waserror()) {
-               /* need to remove from the fd table and make sure the chan is closed
-                * exactly once.  if fd[i] >= 0, then the fd is valid (or it was!) and
-                * the fd table has the only ref (newfd() currently decrefs/consumes the
-                * reference).  cclose() doesn't care if you pass it 0 (like kfree()). */
-               if (fd[0] >= 0)
-                       close_fd(&current->open_files, fd[0]);
-               else
-                       cclose(c[0]);
-               if (fd[1] >= 0)
-                       close_fd(&current->open_files, fd[1]);
-               else
-                       cclose(c[1]);
-               poperror();
-               return -1;
-       }
-       c[0] = namec("#pipe", Atodir, 0, 0);
-       c[1] = cclone(c[0]);
-       if (walk(&c[0], &names[0], 1, FALSE, NULL) < 0)
-               error(EINVAL, ERROR_FIXME);
-       if (walk(&c[1], &names[1], 1, FALSE, NULL) < 0)
-               error(EINVAL, ERROR_FIXME);
-       c[0] = d->open(c[0], O_RDWR);
-       c[1] = d->open(c[1], O_RDWR);
-       fd[0] = newfd(c[0], 0);
-       if (fd[0] < 0)
-               error(-fd[0], ERROR_FIXME);
-       fd[1] = newfd(c[1], 0);
-       if (fd[1] < 0)
-               error(-fd[1], ERROR_FIXME);
-       poperror();
-       return 0;
-}
-
 int sysfwstat(int fd, uint8_t * buf, int n)
 {
        ERRSTACK(2);
@@ -894,7 +848,7 @@ int64_t sysseek(int fd, int64_t off, int whence)
 
 void validstat(uint8_t * s, int n, int slashok)
 {
-       
+
        int m;
        char buf[64];
 
@@ -946,7 +900,7 @@ int sysfstat(int fd, uint8_t *buf, int n)
 
 int sysfstatakaros(int fd, struct kstat *ks)
 {
-       
+
        int n = 4096;
        uint8_t *buf;
        buf = kmalloc(n, MEM_WAIT);
@@ -985,7 +939,7 @@ int sysstat(char *path, uint8_t *buf, int n)
 
 int sysstatakaros(char *path, struct kstat *ks)
 {
-       
+
        int n = 4096;
        uint8_t *buf;
        buf = kmalloc(n, MEM_WAIT);
@@ -1184,7 +1138,7 @@ struct dir *sysdirfstat(int fd)
 
 int sysdirwstat(char *name, struct dir *dir)
 {
-       
+
        uint8_t *buf;
        int r;
 
@@ -1198,7 +1152,7 @@ int sysdirwstat(char *name, struct dir *dir)
 
 int sysdirfwstat(int fd, struct dir *dir)
 {
-       
+
        uint8_t *buf;
        int r;
 
@@ -1212,7 +1166,7 @@ int sysdirfwstat(int fd, struct dir *dir)
 
 static long dirpackage(uint8_t * buf, long ts, struct kdirent **d)
 {
-       
+
        char *s;
        long ss, i, n, nn, m = 0;
 
@@ -1307,20 +1261,18 @@ int sysiounit(int fd)
 
 void print_chaninfo(struct chan *c)
 {
-       
-       char buf[64] = { 0 };
+
+       char buf[128] = { 0 };
        bool has_dev = c->type != -1;
-       if (has_dev && !devtab[c->type].chaninfo) {
-               printk("Chan type %d has no chaninfo!\n", c->type);
-               has_dev = FALSE;
-       }
+       bool has_chaninfo = has_dev && devtab[c->type].chaninfo;
+
        printk("Chan flags: %p, pathname: %s, ref: %d, Dev: %s, Devinfo: %s",
                   c->flag,
                   c->name ? c->name->s : "no cname",
                   kref_refcnt(&c->ref),
                   has_dev ? devtab[c->type].name : "no dev",
-                  has_dev ? devtab[c->type].chaninfo(c, buf, sizeof(buf)) : "");
-       if (!has_dev)
+                  has_chaninfo ? devtab[c->type].chaninfo(c, buf, sizeof(buf)) : "");
+       if (!has_chaninfo)
                printk("qid.path: %p\n", c->qid.path);
        printk("\n");
 }
@@ -1330,7 +1282,7 @@ void print_chaninfo(struct chan *c)
  * the pgrp. */
 int plan9setup(struct proc *new_proc, struct proc *parent, int flags)
 {
-       
+
        struct kref *new_dot_ref;
        ERRSTACK(1);
        if (waserror()) {