Syscall tests for PATH_MAX
[akaros.git] / user / ndblib / csipinfo.c
1 /* 
2  * This file is part of the UCB release of Plan 9. It is subject to the license
3  * terms in the LICENSE file found in the top-level directory of this
4  * distribution and at http://akaros.cs.berkeley.edu/files/Plan9License. No
5  * part of the UCB release of Plan 9, including this file, may be copied,
6  * modified, propagated, or distributed except according to the terms contained
7  * in the LICENSE file.
8  */
9 #include <stdlib.h>
10
11 #include <stdio.h>
12 #include <parlib.h>
13 #include <unistd.h>
14 #include <signal.h>
15 #include <fcntl.h>
16 #include <iplib.h>
17 #include <ndb.h>
18
19 /*
20  *  look up the ip attributes 'list' for an entry that has the
21  *  given 'attr=val' and a 'ip=' tuples.
22  *
23  *  return NULL if not found.
24  */
25 struct ndbtuple*
26 csipinfo(char *netroot, char *attr, char *val, char **list, int n)
27 {
28         struct ndbtuple *t, *first, *last;
29         int i;
30         char line[1024];
31         int fd;
32         char *p, *e;
33         int left,amt;
34
35         if(netroot)
36                 snprintf(line, sizeof(line), "%s/cs", netroot);
37         else
38                 strcpy(line, "/net/cs");
39         fd = open(line, O_RDWR);
40         if(fd < 0)
41                 return 0;
42         lseek(fd, 0, 0);
43         left = sizeof(line);
44         amt = snprintf(line, left, "!ipinfo %s=%s", attr, val);
45         if(amt < 0)
46                 return 0;
47         left -= amt;
48         for(i = 0; i < n; i++){
49                 if(*list == NULL)
50                         break;
51                 amt = snprintf(p, left, " %s", *list++);
52                 if(amt < 0)
53                         return 0;
54                 left -= amt;
55         }
56         
57         if(write(fd, line, strlen(line)) < 0){
58                 close(fd);
59                 return 0;
60         }
61         lseek(fd, 0, 0);
62
63         first = last = 0;
64         for(;;){
65                 n = read(fd, line, sizeof(line)-2);
66                 if(n <= 0)
67                         break;
68                 line[n] = '\n';
69                 line[n+1] = 0;
70
71                 t = _ndbparseline(line);
72                 if(t == 0)
73                         continue;
74                 if(first)
75                         last->entry = t;
76                 else
77                         first = t;
78                 last = t;
79
80                 while(last->entry)
81                         last = last->entry;
82         }
83         close(fd);
84
85         ndbsetmalloctag(first, getcallerpc(&netroot));
86         return first;
87 }