Allow devpermcheck() to check perms
[akaros.git] / kern / src / ns / devtab.c
index 7b0acd7..aaa33ce 100644 (file)
@@ -20,8 +20,10 @@ void devtabreset()
 {
        int i;
 
-       for (i = 0; &devtab[i] < __devtabend; i++)
-               devtab[i].reset();
+       for (i = 0; &devtab[i] < __devtabend; i++) {
+               if (devtab[i].reset)
+                       devtab[i].reset();
+       }
 }
 
 void devtabinit()
@@ -32,7 +34,8 @@ void devtabinit()
                /* if we have errors, check the align of struct dev and objdump */
                printd("i %d, '%s', dev %p, init %p\n", i, devtab[i].name,
                                &devtab[i], devtab[i].init);
-               devtab[i].init();
+               if (devtab[i].init)
+                       devtab[i].init();
        }
 }
 
@@ -44,8 +47,10 @@ void devtabshutdown()
         * Shutdown in reverse order.
         */
        for (i = 0; &devtab[i] < __devtabend; i++) ;
-       for (i--; i >= 0; i--)
-               devtab[i].shutdown();
+       for (i--; i >= 0; i--) {
+               if (devtab[i].shutdown)
+                       devtab[i].shutdown();
+       }
 }
 
 struct dev *devtabget(const char *name, int user)
@@ -55,8 +60,7 @@ struct dev *devtabget(const char *name, int user)
                return &devtab[i];
 
        printk("devtabget FAILED %s\n", name);
-       set_errno(ENOENT);
-       error(Enonexist);
+       error(ENOENT, ERROR_FIXME);
 }
 
 long devtabread(struct chan *c, void *buf, long n, int64_t off)
@@ -67,9 +71,9 @@ long devtabread(struct chan *c, void *buf, long n, int64_t off)
        struct dev *dev;
        char *alloc, *e, *p;
 
-       alloc = kzmalloc(READSTR, KMALLOC_WAIT);
+       alloc = kzmalloc(READSTR, MEM_WAIT);
        if (alloc == NULL)
-               error(Enomem);
+               error(ENOMEM, ERROR_FIXME);
 
        p = alloc;
        e = p + READSTR;