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