Add a bulk interface to sem_down()
[akaros.git] / kern / src / ns / devtab.c
1 /*
2  * Stub.
3  */
4 //#define DEBUG
5 #include <kmalloc.h>
6 #include <string.h>
7 #include <stdio.h>
8 #include <assert.h>
9 #include <error.h>
10 #include <pmap.h>
11 #include <sys/queue.h>
12 #include <smp.h>
13 #include <kref.h>
14 #include <atomic.h>
15 #include <alarm.h>
16 #include <event.h>
17 #include <umem.h>
18
19 void devtabreset()
20 {
21         ERRSTACK(1);
22         volatile int i;
23
24         if (waserror()) {
25                 panic("A devtab reset (probably %p) failed!", devtab[i].reset);
26                 poperror();
27                 return;
28         }
29         for (i = 0; &devtab[i] < __devtabend; i++) {
30                 if (devtab[i].reset)
31                         devtab[i].reset();
32         }
33         poperror();
34 }
35
36 void devtabinit()
37 {
38         ERRSTACK(1);
39         volatile int i;
40
41         if (waserror()) {
42                 panic("A devtab init (probably %p) failed!", devtab[i].init);
43                 poperror();
44                 return;
45         }
46         for (i = 0; &devtab[i] < __devtabend; i++) {
47                 /* if we have errors, check the align of struct dev and objdump */
48                 printd("i %d, '%s', dev %p, init %p\n", i, devtab[i].name,
49                                 &devtab[i], devtab[i].init);
50                 if (devtab[i].init)
51                         devtab[i].init();
52         }
53         poperror();
54 }
55
56 void devtabshutdown()
57 {
58         int i;
59
60         /*
61          * Shutdown in reverse order.
62          */
63         for (i = 0; &devtab[i] < __devtabend; i++) ;
64         for (i--; i >= 0; i--) {
65                 if (devtab[i].shutdown)
66                         devtab[i].shutdown();
67         }
68 }
69
70 struct dev *devtabget(const char *name, int user)
71 {
72         int i = devno(name, user);
73         if (i > 0)
74                 return &devtab[i];
75
76         printk("devtabget FAILED %s\n", name);
77         error(ENOENT, ERROR_FIXME);
78 }
79
80 long devtabread(struct chan *c, void *buf, long n, int64_t off)
81 {
82         ERRSTACK(1);
83
84         int i;
85         struct dev *dev;
86         char *alloc, *e, *p;
87
88         alloc = kzmalloc(READSTR, MEM_WAIT);
89         if (alloc == NULL)
90                 error(ENOMEM, ERROR_FIXME);
91
92         p = alloc;
93         e = p + READSTR;
94         for (i = 0; &devtab[i] < __devtabend; i++) {
95                 dev = &devtab[i];
96                 printd("p %p e %p e-p %d\n", p, e, e - p);
97                 printd("do %d %s\n", i, dev->name);
98                 p += snprintf(p, e - p, "#%s\n", dev->name);
99         }
100
101         if (waserror()) {
102                 kfree(alloc);
103                 nexterror();
104         }
105         n = readstr(off, buf, n, alloc);
106
107         kfree(alloc);
108         poperror();
109
110         return n;
111 }