]> git.lizzy.rs Git - plan9front.git/blob - sys/include/libc.h
Import sources from 2011-03-30 iso image - lib
[plan9front.git] / sys / include / libc.h
1 #pragma lib     "libc.a"
2 #pragma src     "/sys/src/libc"
3
4 #define nelem(x)        (sizeof(x)/sizeof((x)[0]))
5 #define offsetof(s, m)  (ulong)(&(((s*)0)->m))
6 #define assert(x)       if(x){}else _assert("x")
7
8 /*
9  * mem routines
10  */
11 extern  void*   memccpy(void*, void*, int, ulong);
12 extern  void*   memset(void*, int, ulong);
13 extern  int     memcmp(void*, void*, ulong);
14 extern  void*   memcpy(void*, void*, ulong);
15 extern  void*   memmove(void*, void*, ulong);
16 extern  void*   memchr(void*, int, ulong);
17
18 /*
19  * string routines
20  */
21 extern  char*   strcat(char*, char*);
22 extern  char*   strchr(char*, int);
23 extern  int     strcmp(char*, char*);
24 extern  char*   strcpy(char*, char*);
25 extern  char*   strecpy(char*, char*, char*);
26 extern  char*   strdup(char*);
27 extern  char*   strncat(char*, char*, long);
28 extern  char*   strncpy(char*, char*, long);
29 extern  int     strncmp(char*, char*, long);
30 extern  char*   strpbrk(char*, char*);
31 extern  char*   strrchr(char*, int);
32 extern  char*   strtok(char*, char*);
33 extern  long    strlen(char*);
34 extern  long    strspn(char*, char*);
35 extern  long    strcspn(char*, char*);
36 extern  char*   strstr(char*, char*);
37 extern  int     cistrncmp(char*, char*, int);
38 extern  int     cistrcmp(char*, char*);
39 extern  char*   cistrstr(char*, char*);
40 extern  int     tokenize(char*, char**, int);
41
42 enum
43 {
44         UTFmax          = 3,            /* maximum bytes per rune */
45         Runesync        = 0x80,         /* cannot represent part of a UTF sequence (<) */
46         Runeself        = 0x80,         /* rune and UTF sequences are the same (<) */
47         Runeerror       = 0xFFFD,       /* decoding error in UTF */
48 };
49
50 /*
51  * rune routines
52  */
53 extern  int     runetochar(char*, Rune*);
54 extern  int     chartorune(Rune*, char*);
55 extern  int     runelen(long);
56 extern  int     runenlen(Rune*, int);
57 extern  int     fullrune(char*, int);
58 extern  int     utflen(char*);
59 extern  int     utfnlen(char*, long);
60 extern  char*   utfrune(char*, long);
61 extern  char*   utfrrune(char*, long);
62 extern  char*   utfutf(char*, char*);
63 extern  char*   utfecpy(char*, char*, char*);
64
65 extern  Rune*   runestrcat(Rune*, Rune*);
66 extern  Rune*   runestrchr(Rune*, Rune);
67 extern  int     runestrcmp(Rune*, Rune*);
68 extern  Rune*   runestrcpy(Rune*, Rune*);
69 extern  Rune*   runestrncpy(Rune*, Rune*, long);
70 extern  Rune*   runestrecpy(Rune*, Rune*, Rune*);
71 extern  Rune*   runestrdup(Rune*);
72 extern  Rune*   runestrncat(Rune*, Rune*, long);
73 extern  int     runestrncmp(Rune*, Rune*, long);
74 extern  Rune*   runestrrchr(Rune*, Rune);
75 extern  long    runestrlen(Rune*);
76 extern  Rune*   runestrstr(Rune*, Rune*);
77
78 extern  Rune    tolowerrune(Rune);
79 extern  Rune    totitlerune(Rune);
80 extern  Rune    toupperrune(Rune);
81 extern  int     isalpharune(Rune);
82 extern  int     islowerrune(Rune);
83 extern  int     isspacerune(Rune);
84 extern  int     istitlerune(Rune);
85 extern  int     isupperrune(Rune);
86 extern  int     isdigitrune(Rune);
87
88 /*
89  * malloc
90  */
91 extern  void*   malloc(ulong);
92 extern  void*   mallocz(ulong, int);
93 extern  void    free(void*);
94 extern  ulong   msize(void*);
95 extern  void*   mallocalign(ulong, ulong, long, ulong);
96 extern  void*   calloc(ulong, ulong);
97 extern  void*   realloc(void*, ulong);
98 extern  void    setmalloctag(void*, ulong);
99 extern  void    setrealloctag(void*, ulong);
100 extern  ulong   getmalloctag(void*);
101 extern  ulong   getrealloctag(void*);
102 extern  void*   malloctopoolblock(void*);
103
104 /*
105  * print routines
106  */
107 typedef struct Fmt      Fmt;
108 struct Fmt{
109         uchar   runes;                  /* output buffer is runes or chars? */
110         void    *start;                 /* of buffer */
111         void    *to;                    /* current place in the buffer */
112         void    *stop;                  /* end of the buffer; overwritten if flush fails */
113         int     (*flush)(Fmt *);        /* called when to == stop */
114         void    *farg;                  /* to make flush a closure */
115         int     nfmt;                   /* num chars formatted so far */
116         va_list args;                   /* args passed to dofmt */
117         int     r;                      /* % format Rune */
118         int     width;
119         int     prec;
120         ulong   flags;
121 };
122
123 enum{
124         FmtWidth        = 1,
125         FmtLeft         = FmtWidth << 1,
126         FmtPrec         = FmtLeft << 1,
127         FmtSharp        = FmtPrec << 1,
128         FmtSpace        = FmtSharp << 1,
129         FmtSign         = FmtSpace << 1,
130         FmtZero         = FmtSign << 1,
131         FmtUnsigned     = FmtZero << 1,
132         FmtShort        = FmtUnsigned << 1,
133         FmtLong         = FmtShort << 1,
134         FmtVLong        = FmtLong << 1,
135         FmtComma        = FmtVLong << 1,
136         FmtByte         = FmtComma << 1,
137
138         FmtFlag         = FmtByte << 1
139 };
140
141 extern  int     print(char*, ...);
142 extern  char*   seprint(char*, char*, char*, ...);
143 extern  char*   vseprint(char*, char*, char*, va_list);
144 extern  int     snprint(char*, int, char*, ...);
145 extern  int     vsnprint(char*, int, char*, va_list);
146 extern  char*   smprint(char*, ...);
147 extern  char*   vsmprint(char*, va_list);
148 extern  int     sprint(char*, char*, ...);
149 extern  int     fprint(int, char*, ...);
150 extern  int     vfprint(int, char*, va_list);
151
152 extern  int     runesprint(Rune*, char*, ...);
153 extern  int     runesnprint(Rune*, int, char*, ...);
154 extern  int     runevsnprint(Rune*, int, char*, va_list);
155 extern  Rune*   runeseprint(Rune*, Rune*, char*, ...);
156 extern  Rune*   runevseprint(Rune*, Rune*, char*, va_list);
157 extern  Rune*   runesmprint(char*, ...);
158 extern  Rune*   runevsmprint(char*, va_list);
159
160 extern  int     fmtfdinit(Fmt*, int, char*, int);
161 extern  int     fmtfdflush(Fmt*);
162 extern  int     fmtstrinit(Fmt*);
163 extern  char*   fmtstrflush(Fmt*);
164 extern  int     runefmtstrinit(Fmt*);
165 extern  Rune*   runefmtstrflush(Fmt*);
166
167 #pragma varargck        argpos  fmtprint        2
168 #pragma varargck        argpos  fprint          2
169 #pragma varargck        argpos  print           1
170 #pragma varargck        argpos  runeseprint     3
171 #pragma varargck        argpos  runesmprint     1
172 #pragma varargck        argpos  runesnprint     3
173 #pragma varargck        argpos  runesprint      2
174 #pragma varargck        argpos  seprint         3
175 #pragma varargck        argpos  smprint         1
176 #pragma varargck        argpos  snprint         3
177 #pragma varargck        argpos  sprint          2
178
179 #pragma varargck        type    "lld"   vlong
180 #pragma varargck        type    "llx"   vlong
181 #pragma varargck        type    "lld"   uvlong
182 #pragma varargck        type    "llx"   uvlong
183 #pragma varargck        type    "ld"    long
184 #pragma varargck        type    "lx"    long
185 #pragma varargck        type    "lb"    long
186 #pragma varargck        type    "ld"    ulong
187 #pragma varargck        type    "lx"    ulong
188 #pragma varargck        type    "lb"    ulong
189 #pragma varargck        type    "d"     int
190 #pragma varargck        type    "x"     int
191 #pragma varargck        type    "c"     int
192 #pragma varargck        type    "C"     int
193 #pragma varargck        type    "b"     int
194 #pragma varargck        type    "d"     uint
195 #pragma varargck        type    "x"     uint
196 #pragma varargck        type    "c"     uint
197 #pragma varargck        type    "C"     uint
198 #pragma varargck        type    "b"     uint
199 #pragma varargck        type    "f"     double
200 #pragma varargck        type    "e"     double
201 #pragma varargck        type    "g"     double
202 #pragma varargck        type    "s"     char*
203 #pragma varargck        type    "q"     char*
204 #pragma varargck        type    "S"     Rune*
205 #pragma varargck        type    "Q"     Rune*
206 #pragma varargck        type    "r"     void
207 #pragma varargck        type    "%"     void
208 #pragma varargck        type    "n"     int*
209 #pragma varargck        type    "p"     uintptr
210 #pragma varargck        type    "p"     void*
211 #pragma varargck        flag    ','
212 #pragma varargck        flag    ' '
213 #pragma varargck        flag    'h'
214 #pragma varargck        type    "<"     void*
215 #pragma varargck        type    "["     void*
216 #pragma varargck        type    "H"     void*
217 #pragma varargck        type    "lH"    void*
218
219 extern  int     fmtinstall(int, int (*)(Fmt*));
220 extern  int     dofmt(Fmt*, char*);
221 extern  int     dorfmt(Fmt*, Rune*);
222 extern  int     fmtprint(Fmt*, char*, ...);
223 extern  int     fmtvprint(Fmt*, char*, va_list);
224 extern  int     fmtrune(Fmt*, int);
225 extern  int     fmtstrcpy(Fmt*, char*);
226 extern  int     fmtrunestrcpy(Fmt*, Rune*);
227 /*
228  * error string for %r
229  * supplied on per os basis, not part of fmt library
230  */
231 extern  int     errfmt(Fmt *f);
232
233 /*
234  * quoted strings
235  */
236 extern  char    *unquotestrdup(char*);
237 extern  Rune    *unquoterunestrdup(Rune*);
238 extern  char    *quotestrdup(char*);
239 extern  Rune    *quoterunestrdup(Rune*);
240 extern  int     quotestrfmt(Fmt*);
241 extern  int     quoterunestrfmt(Fmt*);
242 extern  void    quotefmtinstall(void);
243 extern  int     (*doquote)(int);
244 extern  int     needsrcquote(int);
245
246 /*
247  * random number
248  */
249 extern  void    srand(long);
250 extern  int     rand(void);
251 extern  int     nrand(int);
252 extern  long    lrand(void);
253 extern  long    lnrand(long);
254 extern  double  frand(void);
255 extern  ulong   truerand(void);                 /* uses /dev/random */
256 extern  ulong   ntruerand(ulong);               /* uses /dev/random */
257
258 /*
259  * math
260  */
261 extern  ulong   getfcr(void);
262 extern  void    setfsr(ulong);
263 extern  ulong   getfsr(void);
264 extern  void    setfcr(ulong);
265 extern  double  NaN(void);
266 extern  double  Inf(int);
267 extern  int     isNaN(double);
268 extern  int     isInf(double, int);
269 extern  ulong   umuldiv(ulong, ulong, ulong);
270 extern  long    muldiv(long, long, long);
271
272 extern  double  pow(double, double);
273 extern  double  atan2(double, double);
274 extern  double  fabs(double);
275 extern  double  atan(double);
276 extern  double  log(double);
277 extern  double  log10(double);
278 extern  double  exp(double);
279 extern  double  floor(double);
280 extern  double  ceil(double);
281 extern  double  hypot(double, double);
282 extern  double  sin(double);
283 extern  double  cos(double);
284 extern  double  tan(double);
285 extern  double  asin(double);
286 extern  double  acos(double);
287 extern  double  sinh(double);
288 extern  double  cosh(double);
289 extern  double  tanh(double);
290 extern  double  sqrt(double);
291 extern  double  fmod(double, double);
292
293 #define HUGE    3.4028234e38
294 #define PIO2    1.570796326794896619231e0
295 #define PI      (PIO2+PIO2)
296
297 /*
298  * Time-of-day
299  */
300
301 typedef
302 struct Tm
303 {
304         int     sec;
305         int     min;
306         int     hour;
307         int     mday;
308         int     mon;
309         int     year;
310         int     wday;
311         int     yday;
312         char    zone[4];
313         int     tzoff;
314 } Tm;
315
316 extern  Tm*     gmtime(long);
317 extern  Tm*     localtime(long);
318 extern  char*   asctime(Tm*);
319 extern  char*   ctime(long);
320 extern  double  cputime(void);
321 extern  long    times(long*);
322 extern  long    tm2sec(Tm*);
323 extern  vlong   nsec(void);
324
325 extern  void    cycles(uvlong*);        /* 64-bit value of the cycle counter if there is one, 0 if there isn't */
326
327 /*
328  * one-of-a-kind
329  */
330 enum
331 {
332         PNPROC          = 1,
333         PNGROUP         = 2,
334 };
335
336 extern  void    _assert(char*);
337 extern  int     abs(int);
338 extern  int     atexit(void(*)(void));
339 extern  void    atexitdont(void(*)(void));
340 extern  int     atnotify(int(*)(void*, char*), int);
341 extern  double  atof(char*);
342 extern  int     atoi(char*);
343 extern  long    atol(char*);
344 extern  vlong   atoll(char*);
345 extern  double  charstod(int(*)(void*), void*);
346 extern  char*   cleanname(char*);
347 extern  int     decrypt(void*, void*, int);
348 extern  int     encrypt(void*, void*, int);
349 extern  int     dec64(uchar*, int, char*, int);
350 extern  int     enc64(char*, int, uchar*, int);
351 extern  int     dec32(uchar*, int, char*, int);
352 extern  int     enc32(char*, int, uchar*, int);
353 extern  int     dec16(uchar*, int, char*, int);
354 extern  int     enc16(char*, int, uchar*, int);
355 extern  int     encodefmt(Fmt*);
356 extern  void    exits(char*);
357 extern  double  frexp(double, int*);
358 extern  uintptr getcallerpc(void*);
359 extern  char*   getenv(char*);
360 extern  int     getfields(char*, char**, int, int, char*);
361 extern  int     gettokens(char *, char **, int, char *);
362 extern  char*   getuser(void);
363 extern  char*   getwd(char*, int);
364 extern  int     iounit(int);
365 extern  long    labs(long);
366 extern  double  ldexp(double, int);
367 extern  void    longjmp(jmp_buf, int);
368 extern  char*   mktemp(char*);
369 extern  double  modf(double, double*);
370 extern  int     netcrypt(void*, void*);
371 extern  void    notejmp(void*, jmp_buf, int);
372 extern  void    perror(char*);
373 extern  int     postnote(int, int, char *);
374 extern  double  pow10(int);
375 extern  int     putenv(char*, char*);
376 extern  void    qsort(void*, long, long, int (*)(void*, void*));
377 extern  int     setjmp(jmp_buf);
378 extern  double  strtod(char*, char**);
379 extern  long    strtol(char*, char**, int);
380 extern  ulong   strtoul(char*, char**, int);
381 extern  vlong   strtoll(char*, char**, int);
382 extern  uvlong  strtoull(char*, char**, int);
383 extern  void    sysfatal(char*, ...);
384 #pragma varargck        argpos  sysfatal        1
385 extern  void    syslog(int, char*, char*, ...);
386 #pragma varargck        argpos  syslog  3
387 extern  long    time(long*);
388 extern  int     tolower(int);
389 extern  int     toupper(int);
390
391 /*
392  *  profiling
393  */
394 enum {
395         Profoff,                /* No profiling */
396         Profuser,               /* Measure user time only (default) */
397         Profkernel,             /* Measure user + kernel time */
398         Proftime,               /* Measure total time */
399         Profsample,             /* Use clock interrupt to sample (default when there is no cycle counter) */
400 }; /* what */
401 extern  void    prof(void (*fn)(void*), void *arg, int entries, int what);
402
403 /*
404  *  synchronization
405  */
406 typedef
407 struct Lock {
408         int     val;
409 } Lock;
410
411 extern int      _tas(int*);
412
413 extern  void    lock(Lock*);
414 extern  void    unlock(Lock*);
415 extern  int     canlock(Lock*);
416
417 typedef struct QLp QLp;
418 struct QLp
419 {
420         int     inuse;
421         QLp     *next;
422         char    state;
423 };
424
425 typedef
426 struct QLock
427 {
428         Lock    lock;
429         int     locked;
430         QLp     *head;
431         QLp     *tail;
432 } QLock;
433
434 extern  void    qlock(QLock*);
435 extern  void    qunlock(QLock*);
436 extern  int     canqlock(QLock*);
437 extern  void    _qlockinit(void* (*)(void*, void*));    /* called only by the thread library */
438
439 typedef
440 struct RWLock
441 {
442         Lock    lock;
443         int     readers;        /* number of readers */
444         int     writer;         /* number of writers */
445         QLp     *head;          /* list of waiting processes */
446         QLp     *tail;
447 } RWLock;
448
449 extern  void    rlock(RWLock*);
450 extern  void    runlock(RWLock*);
451 extern  int     canrlock(RWLock*);
452 extern  void    wlock(RWLock*);
453 extern  void    wunlock(RWLock*);
454 extern  int     canwlock(RWLock*);
455
456 typedef
457 struct Rendez
458 {
459         QLock   *l;
460         QLp     *head;
461         QLp     *tail;
462 } Rendez;
463
464 extern  void    rsleep(Rendez*);        /* unlocks r->l, sleeps, locks r->l again */
465 extern  int     rwakeup(Rendez*);
466 extern  int     rwakeupall(Rendez*);
467 extern  void**  privalloc(void);
468 extern  void    privfree(void**);
469
470 /*
471  *  network dialing
472  */
473 #define NETPATHLEN 40
474 extern  int     accept(int, char*);
475 extern  int     announce(char*, char*);
476 extern  int     dial(char*, char*, char*, int*);
477 extern  void    setnetmtpt(char*, int, char*);
478 extern  int     hangup(int);
479 extern  int     listen(char*, char*);
480 extern  char*   netmkaddr(char*, char*, char*);
481 extern  int     reject(int, char*, char*);
482
483 /*
484  *  encryption
485  */
486 extern  int     pushssl(int, char*, char*, char*, int*);
487 extern  int     pushtls(int, char*, char*, int, char*, char*);
488
489 /*
490  *  network services
491  */
492 typedef struct NetConnInfo NetConnInfo;
493 struct NetConnInfo
494 {
495         char    *dir;           /* connection directory */
496         char    *root;          /* network root */
497         char    *spec;          /* binding spec */
498         char    *lsys;          /* local system */
499         char    *lserv;         /* local service */
500         char    *rsys;          /* remote system */
501         char    *rserv;         /* remote service */
502         char    *laddr;         /* local address */
503         char    *raddr;         /* remote address */
504 };
505 extern  NetConnInfo*    getnetconninfo(char*, int);
506 extern  void            freenetconninfo(NetConnInfo*);
507
508 /*
509  * system calls
510  *
511  */
512 #define STATMAX 65535U  /* max length of machine-independent stat structure */
513 #define DIRMAX  (sizeof(Dir)+STATMAX)   /* max length of Dir structure */
514 #define ERRMAX  128     /* max length of error string */
515
516 #define MORDER  0x0003  /* mask for bits defining order of mounting */
517 #define MREPL   0x0000  /* mount replaces object */
518 #define MBEFORE 0x0001  /* mount goes before others in union directory */
519 #define MAFTER  0x0002  /* mount goes after others in union directory */
520 #define MCREATE 0x0004  /* permit creation in mounted directory */
521 #define MCACHE  0x0010  /* cache some data */
522 #define MMASK   0x0017  /* all bits on */
523
524 #define OREAD   0       /* open for read */
525 #define OWRITE  1       /* write */
526 #define ORDWR   2       /* read and write */
527 #define OEXEC   3       /* execute, == read but check execute permission */
528 #define OTRUNC  16      /* or'ed in (except for exec), truncate file first */
529 #define OCEXEC  32      /* or'ed in, close on exec */
530 #define ORCLOSE 64      /* or'ed in, remove on close */
531 #define OEXCL   0x1000  /* or'ed in, exclusive use (create only) */
532
533 #define AEXIST  0       /* accessible: exists */
534 #define AEXEC   1       /* execute access */
535 #define AWRITE  2       /* write access */
536 #define AREAD   4       /* read access */
537
538 /* Segattch */
539 #define SG_RONLY        0040    /* read only */
540 #define SG_CEXEC        0100    /* detach on exec */
541
542 #define NCONT   0       /* continue after note */
543 #define NDFLT   1       /* terminate after note */
544 #define NSAVE   2       /* clear note but hold state */
545 #define NRSTR   3       /* restore saved state */
546
547 /* bits in Qid.type */
548 #define QTDIR           0x80            /* type bit for directories */
549 #define QTAPPEND        0x40            /* type bit for append only files */
550 #define QTEXCL          0x20            /* type bit for exclusive use files */
551 #define QTMOUNT         0x10            /* type bit for mounted channel */
552 #define QTAUTH          0x08            /* type bit for authentication file */
553 #define QTTMP           0x04            /* type bit for not-backed-up file */
554 #define QTFILE          0x00            /* plain file */
555
556 /* bits in Dir.mode */
557 #define DMDIR           0x80000000      /* mode bit for directories */
558 #define DMAPPEND        0x40000000      /* mode bit for append only files */
559 #define DMEXCL          0x20000000      /* mode bit for exclusive use files */
560 #define DMMOUNT         0x10000000      /* mode bit for mounted channel */
561 #define DMAUTH          0x08000000      /* mode bit for authentication file */
562 #define DMTMP           0x04000000      /* mode bit for non-backed-up files */
563 #define DMREAD          0x4             /* mode bit for read permission */
564 #define DMWRITE         0x2             /* mode bit for write permission */
565 #define DMEXEC          0x1             /* mode bit for execute permission */
566
567 /* rfork */
568 enum
569 {
570         RFNAMEG         = (1<<0),
571         RFENVG          = (1<<1),
572         RFFDG           = (1<<2),
573         RFNOTEG         = (1<<3),
574         RFPROC          = (1<<4),
575         RFMEM           = (1<<5),
576         RFNOWAIT        = (1<<6),
577         RFCNAMEG        = (1<<10),
578         RFCENVG         = (1<<11),
579         RFCFDG          = (1<<12),
580         RFREND          = (1<<13),
581         RFNOMNT         = (1<<14)
582 };
583
584 typedef
585 struct Qid
586 {
587         uvlong  path;
588         ulong   vers;
589         uchar   type;
590 } Qid;
591
592 typedef
593 struct Dir {
594         /* system-modified data */
595         ushort  type;   /* server type */
596         uint    dev;    /* server subtype */
597         /* file data */
598         Qid     qid;    /* unique id from server */
599         ulong   mode;   /* permissions */
600         ulong   atime;  /* last read time */
601         ulong   mtime;  /* last write time */
602         vlong   length; /* file length */
603         char    *name;  /* last element of path */
604         char    *uid;   /* owner name */
605         char    *gid;   /* group name */
606         char    *muid;  /* last modifier name */
607 } Dir;
608
609 /* keep /sys/src/ape/lib/ap/plan9/sys9.h in sync with this -rsc */
610 typedef
611 struct Waitmsg
612 {
613         int     pid;            /* of loved one */
614         ulong   time[3];        /* of loved one & descendants */
615         char    *msg;
616 } Waitmsg;
617
618 typedef
619 struct IOchunk
620 {
621         void    *addr;
622         ulong   len;
623 } IOchunk;
624
625 extern  void    _exits(char*);
626
627 extern  void    abort(void);
628 extern  int     access(char*, int);
629 extern  long    alarm(ulong);
630 extern  int     await(char*, int);
631 extern  int     bind(char*, char*, int);
632 extern  int     brk(void*);
633 extern  int     chdir(char*);
634 extern  int     close(int);
635 extern  int     create(char*, int, ulong);
636 extern  int     dup(int, int);
637 extern  int     errstr(char*, uint);
638 extern  int     exec(char*, char*[]);
639 extern  int     execl(char*, ...);
640 extern  int     fork(void);
641 extern  int     rfork(int);
642 extern  int     fauth(int, char*);
643 extern  int     fstat(int, uchar*, int);
644 extern  int     fwstat(int, uchar*, int);
645 extern  int     fversion(int, int, char*, int);
646 extern  int     mount(int, int, char*, int, char*);
647 extern  int     unmount(char*, char*);
648 extern  int     noted(int);
649 extern  int     notify(void(*)(void*, char*));
650 extern  int     open(char*, int);
651 extern  int     fd2path(int, char*, int);
652 extern  int     pipe(int*);
653 extern  long    pread(int, void*, long, vlong);
654 extern  long    preadv(int, IOchunk*, int, vlong);
655 extern  long    pwrite(int, void*, long, vlong);
656 extern  long    pwritev(int, IOchunk*, int, vlong);
657 extern  long    read(int, void*, long);
658 extern  long    readn(int, void*, long);
659 extern  long    readv(int, IOchunk*, int);
660 extern  int     remove(char*);
661 extern  void*   sbrk(ulong);
662 extern  long    oseek(int, long, int);
663 extern  vlong   seek(int, vlong, int);
664 extern  void*   segattach(int, char*, void*, ulong);
665 extern  void*   segbrk(void*, void*);
666 extern  int     segdetach(void*);
667 extern  int     segflush(void*, ulong);
668 extern  int     segfree(void*, ulong);
669 extern  int     semacquire(long*, int);
670 extern  long    semrelease(long*, long);
671 extern  int     sleep(long);
672 extern  int     stat(char*, uchar*, int);
673 extern  Waitmsg*        wait(void);
674 extern  int     waitpid(void);
675 extern  long    write(int, void*, long);
676 extern  long    writev(int, IOchunk*, int);
677 extern  int     wstat(char*, uchar*, int);
678 extern  void*   rendezvous(void*, void*);
679
680 extern  Dir*    dirstat(char*);
681 extern  Dir*    dirfstat(int);
682 extern  int     dirwstat(char*, Dir*);
683 extern  int     dirfwstat(int, Dir*);
684 extern  long    dirread(int, Dir**);
685 extern  void    nulldir(Dir*);
686 extern  long    dirreadall(int, Dir**);
687 extern  int     getpid(void);
688 extern  int     getppid(void);
689 extern  void    rerrstr(char*, uint);
690 extern  char*   sysname(void);
691 extern  void    werrstr(char*, ...);
692 #pragma varargck        argpos  werrstr 1
693
694 extern char *argv0;
695 #define ARGBEGIN        for((argv0||(argv0=*argv)),argv++,argc--;\
696                             argv[0] && argv[0][0]=='-' && argv[0][1];\
697                             argc--, argv++) {\
698                                 char *_args, *_argt;\
699                                 Rune _argc;\
700                                 _args = &argv[0][1];\
701                                 if(_args[0]=='-' && _args[1]==0){\
702                                         argc--; argv++; break;\
703                                 }\
704                                 _argc = 0;\
705                                 while(*_args && (_args += chartorune(&_argc, _args)))\
706                                 switch(_argc)
707 #define ARGEND          SET(_argt);USED(_argt,_argc,_args);}USED(argv, argc);
708 #define ARGF()          (_argt=_args, _args="",\
709                                 (*_argt? _argt: argv[1]? (argc--, *++argv): 0))
710 #define EARGF(x)        (_argt=_args, _args="",\
711                                 (*_argt? _argt: argv[1]? (argc--, *++argv): ((x), abort(), (char*)0)))
712
713 #define ARGC()          _argc
714
715 /* this is used by sbrk and brk,  it's a really bad idea to redefine it */
716 extern  char    end[];