Fix Plan 9 partial write() return values
[akaros.git] / kern / src / ns / devtab.c
index f499506..95a23b1 100644 (file)
 
 void devtabreset()
 {
-       int i;
+       ERRSTACK(1);
+       volatile int i;
 
-       for (i = 0; &devtab[i] < __devtabend; i++)
-               devtab[i].reset();
+       if (waserror()) {
+               panic("A devtab reset (probably %p) failed!", devtab[i].reset);
+               poperror();
+               return;
+       }
+       for (i = 0; &devtab[i] < __devtabend; i++) {
+               if (devtab[i].reset)
+                       devtab[i].reset();
+       }
+       poperror();
 }
 
 void devtabinit()
 {
-       int i;
+       ERRSTACK(1);
+       volatile int i;
 
+       if (waserror()) {
+               panic("A devtab init (probably %p) failed!", devtab[i].init);
+               poperror();
+               return;
+       }
        for (i = 0; &devtab[i] < __devtabend; i++) {
                /* if we have errors, check the align of struct dev and objdump */
-               printd("i %d, dev %p, init %p\n", i, &devtab[i], devtab[i].init);
-               devtab[i].init();
+               printd("i %d, '%s', dev %p, init %p\n", i, devtab[i].name,
+                               &devtab[i], devtab[i].init);
+               if (devtab[i].init)
+                       devtab[i].init();
        }
+       poperror();
 }
 
 void devtabshutdown()
@@ -43,26 +61,23 @@ 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(int dc, int user)
+struct dev *devtabget(const char *name, int user)
 {
-       int i;
-
-       for (i = 0; &devtab[i] < __devtabend; i++) {
-               if (devtab[i].dc == dc)
-                       return &devtab[i];
-       }
+       int i = devno(name, user);
+       if (i > 0)
+               return &devtab[i];
 
-       printk("devtabget FAILED %c\n", dc);
-       set_errno(ENOENT);
-       error(Enonexist);
+       printk("devtabget FAILED %s\n", name);
+       error(ENOENT, ERROR_FIXME);
 }
 
-long
-devtabread(struct chan *c, void *buf, long n, int64_t off)
+long devtabread(struct chan *c, void *buf, long n, int64_t off)
 {
        ERRSTACK(1);
 
@@ -70,17 +85,17 @@ 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;
        for (i = 0; &devtab[i] < __devtabend; i++) {
                dev = &devtab[i];
                printd("p %p e %p e-p %d\n", p, e, e - p);
-               printd("do %d %c %s\n", i, dev->dc, dev->name);
-               p += snprintf(p, e - p, "#%c %s\n", dev->dc, dev->name);
+               printd("do %d %s\n", i, dev->name);
+               p += snprintf(p, e - p, "#%s\n", dev->name);
        }
 
        if (waserror()) {