home *** CD-ROM | disk | FTP | other *** search
/ Computer Club Elmshorn Atari PD / CCE_PD.iso / pc / 0600 / CCE_0638.ZIP / CCE_0638 / INCLUDE / INCL93.ZOO / mintbind.h < prev    next >
C/C++ Source or Header  |  1993-07-10  |  18KB  |  493 lines

  1. #ifndef _MINTBIND_H
  2. #define _MINTBIND_H
  3.  
  4. #ifndef _OSBIND_H
  5. #include <osbind.h>
  6. #endif
  7.  
  8. #ifdef __cplusplus
  9. extern "C" {
  10. #endif
  11.  
  12. #ifdef __TURBOC__
  13.  
  14. /* we supply a library of bindings for TurboC / PureC */
  15.  
  16. int Syield( void );                /* GEMDOS 0xff */
  17. int Fpipe( short *ptr );            /* GEMDOS 0x100 */
  18. long Fcntl( int f, long arg, int cmd);        /* GEMDOS 0x104 */
  19. #define Fcntl(f, arg, cmd) Fcntl(f, (long)(arg), cmd)
  20. long Finstat( int f );                /* GEMDOS 0x105 */
  21. long Foutstat( int f );                /* GEMDOS 0x106 */
  22. long Fgetchar(int f, int mode);            /* GEMDOS 0x107 */
  23. long Fputchar( int f, long c, int mode );     /* GEMDOS 0x108 */
  24. long Pwait( void );                /* GEMDOS 0x109 */
  25. int Pnice( int delta );                /* GEMDOS 0x10a */
  26. int Pgetpid( void );                /* GEMDOS 0x10b */
  27. int Pgetppid( void );                /* GEMDOS 0x10c */
  28. int Pgetpgrp( void );                /* GEMDOS 0x10d */
  29. int Psetpgrp(int pid, int newgrp);        /* GEMDOS 0x10e */
  30. int Pgetuid( void );                /* GEMDOS 0x10f */
  31. int Psetuid( int id );                /* GEMDOS 0x110 */
  32. int Pkill( int pid, int sig );            /* GEMDOS 0x111 */
  33. long Psignal(int sig, long handler);        /* GEMDOS 0x112 */
  34. long Pvfork( void );                /* GEMDOS 0x113 */
  35. int Pgetgid( void );                /* GEMDOS 0x114 */
  36. int Psetgid(int id);                /* GEMDOS 0x115 */
  37. long Psigblock(unsigned long mask);        /* GEMDOS 0x116 */
  38. long Psigsetmask(unsigned long mask);        /* GEMDOS 0x117 */
  39. long Pusrval(long arg);                /* GEMDOS 0x118 */
  40. int Pdomain(int newdom);            /* GEMDOS 0x119 */
  41. void Psigreturn( void );            /* GEMDOS 0x11a */
  42. long Pfork( void );                /* GEMDOS 0x11b */
  43. long Pwait3(int flag, long *rusage);        /* GEMDOS 0x11c */
  44. int Fselect(unsigned int timeout, long *rfds, long *wfds, long *xfds); /* GEMDOS 0x11d */
  45. int Prusage( long r[8] );            /* GEMDOS 0x11e */
  46. long Psetlimit(int lim, long value);        /* GEMDOS 0x11f */
  47. long Talarm( long secs );            /* GEMDOS 0x120 */
  48. void Pause( void );                /* GEMDOS 0x121 */
  49. long Sysconf( int n );                /* GEMDOS 0x122 */
  50. long Psigpending( void );            /* GEMDOS 0x123 */
  51. long Dpathconf( const char *name, int n );    /* GEMDOS 0x124 */
  52. long Pmsg( int mode, long mbox, void *msg );     /* GEMDOS 0x125 */
  53. long Fmidipipe( int pid, int in, int out );    /* GEMDOS 0x126 */
  54. int Prenice( int pid, int delta );        /* GEMDOS 0x127 */
  55. long Dopendir( const char *name, int flag );    /* GEMDOS 0x128 */
  56. long Dreaddir( int buflen, long dir, char *buf); /*GEMDOS 0x129 */
  57. #define Dreaddir(buflen, dir, buf) Dreaddir(buflen, (long)(dir), buf)
  58. long Drewinddir( long dir );            /* GEMDOS 0x12a */
  59. #define Drewinddir(dir) Drewinddir((long)(dir))
  60. long Dclosedir( long dir );            /* GEMDOS 0x12b */
  61. #define Dclosedir(dir) Dclosedir((long)(dir))
  62. long Fxattr( int flag, char *name, void *buf );    /* GEMDOS 0x12c */
  63. long Flink( char *oldname, char *newname );    /* GEMDOS 0x12d */
  64. long Fsymlink( char *oldname, char *newname );    /* GEMDOS 0x12e */
  65. long Freadlink( int siz, char *buf, char *name); /*GEMDOS 0x12f */
  66. long Dcntl( int cmd, char *name, long arg );    /* GEMDOS 0x130 */
  67. long Fchown( char *name, int uid, int gid);    /* GEMDOS 0x131 */
  68. long Fchmod( char *name, int mode );        /* GEMDOS 0x132 */
  69. int Pumask( int mask );                /* GEMDOS 0x133 */
  70. long Psemaphore(int mode, long id, long timeout); /* GEMDOS 0x134 */
  71. int Dlock( int mode, int drive );        /* GEMDOS 0x135 */
  72. void Psigpause( unsigned long mask);        /* GEMDOS 0x136 */
  73. long Psigaction(int sig, long act, long oact);    /* GEMDOS 0x137 */
  74. #define Psigaction(sig, act, oact) \
  75.     Psigaction(sig, (long)(act), (long)(oact))
  76. int Pgeteuid( void );                /* GEMDOS 0x138 */
  77. int Pgetegid( void );                /* GEMDOS 0x139 */
  78. int Pwaitpid(int pid, int flag, long *rusage);    /* GEMDOS 0x13a */
  79. long Dgetcwd(char *path, int drv, int size);    /* GEMDOS 0x13b */
  80. long Salert(char *msg);                /* GEMDOS 0x13c */
  81.  
  82. #else /* !__TURBOC__ */
  83.  
  84. #ifdef __LATTICE__
  85.  
  86. void _vmv(int);
  87. short _smv(int);
  88. int _imv(int);
  89. long _lmv(int);
  90.  
  91. int _im8(int,long[8]);
  92. void _vml(int,long);
  93. short _sms(int,int);
  94. short _smr(int,short *);
  95. long _lms(int,int);
  96. long _lml(int,long);
  97. long _lmu(int,unsigned long);
  98. long _lmp(int,void *);
  99. long _lmC(int,const char *);
  100.  
  101. void _vmls(int,long,int);
  102. short _smss(int,int,int);
  103. short _smsl(int,int,long);
  104. short _smls(int,long,int);
  105.  
  106. long _lmss(int,int,int);
  107. long _lmsl(int,int,long);
  108. long _lmsp(int,int,void *);
  109. long _lmps(int,void *,int);
  110. long _lmCs(int,const char *,short);
  111. long _lmpp(int,void *,void *);
  112. long _lmCC(int,const char *,const char *);
  113.  
  114. short _smsls(int,int,long,int);
  115. int _imssq(int,int,int,long *);
  116. long _lmsss(int,int,int,int);
  117. long _lmsls(int,int,long,int);
  118. long _lmsll(int,int,int,long);
  119. long _lmslp(int,int,long,void *);
  120. long _lmspl(int,int,void *,long);
  121. long _lmsCl(int,int,const char *,long);
  122. long _lmspp(int,int,void *,void *);
  123. long _lmspC(int,int,void *,const char *);
  124. long _lmlss(int,long,int,int);
  125. long _lmCss(int,const char *,int,int);
  126. long _lmcss(int,char *,int,int);
  127. short _smsqqq(int,int,long *,long *,long *);
  128.  
  129. #pragma inline _vmv((short))    {register d2,a2; "4e41";}
  130. #pragma inline d0=_smv((short))    {register d2,a2; "4e41";}
  131. #pragma inline d0=_imv((short))    {register d2,a2; "4e41";}
  132. #pragma inline d0=_lmv((short))    {register d2,a2; "4e41";}
  133.  
  134. #pragma inline d0=_im8((short),)    {register d2,a2; "4e41";}
  135. #pragma inline _vml((short),)    {register d2,a2; "4e41";}
  136. #pragma inline d0=_sms((short),(short))    {register d2,a2; "4e41";}
  137. #pragma inline d0=_smr((short),)    {register d2,a2; "4e41";}
  138. #pragma inline d0=_lms((short),(short))    {register d2,a2; "4e41";}
  139. #pragma inline d0=_lml((short),)    {register d2,a2; "4e41";}
  140. #pragma inline d0=_lmu((short),)    {register d2,a2; "4e41";}
  141. #pragma inline d0=_lmp((short),)    {register d2,a2; "4e41";}
  142. #pragma inline d0=_lmC((short),)    {register d2,a2; "4e41";}
  143.  
  144. #pragma inline _vmls((short),,(short))    {register d2,a2; "4e41";}
  145. #pragma inline d0=_smss((short),(short),(short))    {register d2,a2; "4e41";}
  146. #pragma inline d0=_smsl((short),(short),)    {register d2,a2; "4e41";}
  147. #pragma inline d0=_smls((short),,(short))    {register d2,a2; "4e41";}
  148. #pragma inline d0=_lmss((short),(short),(short))    {register d2,a2; "4e41";}
  149. #pragma inline d0=_lmsl((short),(short),)    {register d2,a2; "4e41";}
  150. #pragma inline d0=_lmsp((short),(short),)    {register d2,a2; "4e41";}
  151. #pragma inline d0=_lmps((short),,(short))    {register d2,a2; "4e41";}
  152. #pragma inline d0=_lmCs((short),,(short))    {register d2,a2; "4e41";}
  153. #pragma inline d0=_lmpp((short),,)    {register d2,a2; "4e41";}
  154. #pragma inline d0=_lmCC((short),,)    {register d2,a2; "4e41";}
  155.  
  156. #pragma inline d0=_smsls((short),(short),,(short))    {register d2,a2; "4e41";}
  157. #pragma inline d0=_imssq((short),(short),(short),)    {register d2,a2; "4e41";}
  158. #pragma inline d0=_lmsss((short),(short),(short),(short))    {register d2,a2; "4e41";}
  159. #pragma inline d0=_lmsls((short),(short),,(short))    {register d2,a2; "4e41";}
  160. #pragma inline d0=_lmsll((short),(short),(short),)    {register d2,a2; "4e41";}
  161. #pragma inline d0=_lmlss((short),,(short),(short))    {register d2,a2; "4e41";}
  162. #pragma inline d0=_lmslp((short),(short),,)    {register d2,a2; "4e41";}
  163. #pragma inline d0=_lmspl((short),(short),,)    {register d2,a2; "4e41";}
  164. #pragma inline d0=_lmsCl((short),(short),,)    {register d2,a2; "4e41";}
  165. #pragma inline d0=_lmspp((short),(short),,)    {register d2,a2; "4e41";}
  166. #pragma inline d0=_lmspC((short),(short),,)    {register d2,a2; "4e41";}
  167. #pragma inline d0=_lmlss((short),,(short),(short))    {register d2,a2; "4e41";}
  168. #pragma inline d0=_lmCss((short),,(short),(short))    {register d2,a2; "4e41";}
  169. #pragma inline d0=_lmcss((short),,(short),(short))    {register d2,a2; "4e41";}
  170. #pragma inline d0=_smsqqq((short),(short),,,)    {register d2,a2; "4e41";}
  171.  
  172. #define Syield() _smv(0xff)
  173. #define Fpipe(a) _smr(0x100, a)
  174. #define Fcntl(a, b, c) _smsls(0x104, a, b, c)
  175. #define Finstat(a) _lms(0x105, a)
  176. #define Foutstat(a) _lms(0x106, a)
  177. #define Fgetchar(a, b) _lmss(0x107, a, b)
  178. #define Fputchar(a, b, c) _lmsls(0x108, a, b, c)
  179. #define Pwait() _lmv(0x109)
  180. #define Pnice(a) _sms(0x10a, a)
  181. #define Pgetpid() _smv(0x10b)
  182. #define Pgetppid() _smv(0x10c)
  183. #define Pgetpgrp() _smv(0x10d)
  184. #define Psetpgrp(a, b) _smss(0x10e, a, b)
  185. #define Pgetuid() _smv(0x10f)
  186. #define Psetuid(a) _sms(0x110, a)
  187. #define Pkill(a, b) _smss(0x111, a, b)
  188. #define Psignal(a, b) _lmsl(0x112, a, b)
  189. #define Pvfork() _smv(0x113)
  190. #define Pgetgid() _smv(0x114)
  191. #define Psetgid(a) _sms(0x115, a)
  192. #define Psigblock(a) _lmu(0x116, a)
  193. #define Psigsetmask(a) _lmu(0x117, a)
  194. #define Pusrval(a) _lml(0x118, a)
  195. #define Pdomain(a) _sms(0x119, a)
  196. #define Psigreturn() _vmv(0x11a)
  197. #define Pfork() _lmv(0x11b)
  198. #define Pwait3(a, b) _lmsp(0x11c, a, b)
  199. #define Fselect(a, b, c, d) _smsqqq(0x11d, a, b, c, d)
  200. #define Prusage(a) _im8(0x11e, a)
  201. #define Psetlimit(a, b) _lmsl(0x11f, a, b)
  202. #define Talarm(a) _lml(0x120, a)
  203. #define Pause() _vmv(0x121)
  204. #define Sysconf(a) _lms(0x122, a)
  205. #define Psigpending() _lmv(0x123)
  206. #define Dpathconf(a, b) _lmCs(0x124, a, b)
  207. #define Pmsg(a, b, c) _lmslp(0x125, a, b, c)
  208. #define Fmidipipe(a, b, c) _lmsss(0x126, a, b, c)
  209. #define Prenice(a, b) _smss(0x127, a, b)
  210. #define Dopendir(a, b) _lmps(0x128, a, b)
  211. #define Dreaddir(a, b, c) _lmslp(0x129, a, b, c)
  212. #define Drewinddir(a) _lml(0x12a, a)
  213. #define Dclosedir(a) _lml(0x12b, a)
  214. #define Fxattr(a, b, c) _lmspp(0x12c, a, b, c)
  215. #define Flink(a, b) _lmCC(0x12d, a, b)
  216. #define Fsymlink(a, b) _lmCC(0x12e, a, b)
  217. #define Freadlink(a, b, c) _lmspC(0x12f, a, b, c)
  218. #define Dcntl(a, b, c) _lmsCl(0x130, a, b, c)
  219. #define Fchown(a, b, c) _lmCss(0x131, a, b, c)
  220. #define Fchmod(a, b) _lmCs(0x132, a, b)
  221. #define Pumask(a) _sms(0x133, a)
  222. #define Psemaphore(a, b, c) _lmsll(0x134, a, b, c)
  223. #define Dlock(a, b) _smss(0x135, a, b)
  224. #define Psigpause(a) _vml(0x136,a)
  225. #define Psigaction(a, b, c) _lmsll(0x137, a, b, c)
  226. #define Pgeteuid() _imv(0x138)
  227. #define Pgetegid() _imv(0x139)
  228. #define Pwaitpid(a, b, c) _imssq(0x13a, a, b, c)
  229. #define Dgetcwd(a, b, c) _lmcss(0x13b, a, b, c)
  230. #define Salert(a) _lmC(0x13c, a)
  231.  
  232. #else /* !__LATTICE__ */
  233.  
  234. #ifdef __GNUC_INLINE__
  235.  
  236. /* see osbind.h for __extension__ and AND_MEMORY */
  237.  
  238. #define trap_1_wwlw(n, a, b, c)                        \
  239. __extension__                                \
  240. ({                                    \
  241.     register long retvalue __asm__("d0");                \
  242.     short _a = (short)(a);                        \
  243.     long  _b = (long) (b);                        \
  244.     short  _c = (short) (c);                    \
  245.                                         \
  246.     __asm__ volatile                        \
  247.     ("\
  248.         movw    %4,sp@-; \
  249.         movl    %3,sp@-; \
  250.         movw    %2,sp@-; \
  251.         movw    %1,sp@-; \
  252.         trap    #1;    \
  253.         lea    sp@(10),sp " \
  254.     : "=r"(retvalue)            /* outputs */        \
  255.     : "g"(n), "r"(_a), "r"(_b), "r"(_c)     /* inputs  */        \
  256.     : "d0", "d1", "d2", "a0", "a1", "a2"    /* clobbered regs */    \
  257.       AND_MEMORY                            \
  258.     );                                \
  259.     retvalue;                            \
  260. })
  261.  
  262. #define trap_1_wwww(n, a, b, c)                        \
  263. __extension__                                \
  264. ({                                    \
  265.     register long retvalue __asm__("d0");                \
  266.     short _a = (short)(a);                        \
  267.     short  _b = (short)(b);                        \
  268.     short  _c = (short)(c);                        \
  269.                                         \
  270.     __asm__ volatile                        \
  271.     ("\
  272.         movw    %4,sp@-; \
  273.         movw    %3,sp@-; \
  274.         movw    %2,sp@-; \
  275.         movw    %1,sp@-; \
  276.         trap    #1;    \
  277.         addqw    #8,sp "                    \
  278.     : "=r"(retvalue)            /* outputs */        \
  279.     : "g"(n), "r"(_a), "r"(_b), "r"(_c)     /* inputs  */        \
  280.     : "d0", "d1", "d2", "a0", "a1", "a2"    /* clobbered regs */    \
  281.       AND_MEMORY                            \
  282.     );                                \
  283.     retvalue;                            \
  284. })
  285.  
  286. #define trap_1_wwwl(n, a, b, c)                        \
  287. __extension__                                \
  288. ({                                    \
  289.     register long retvalue __asm__("d0");                \
  290.     short _a = (short)(a);                        \
  291.     short  _b = (short)(b);                        \
  292.     long  _c = (long)(c);                        \
  293.                                         \
  294.     __asm__ volatile                        \
  295.     ("\
  296.         movl    %4,sp@-; \
  297.         movw    %3,sp@-; \
  298.         movw    %2,sp@-; \
  299.         movw    %1,sp@-; \
  300.         trap    #1;    \
  301.         lea     sp@(10),sp "                    \
  302.     : "=r"(retvalue)            /* outputs */        \
  303.     : "g"(n), "r"(_a), "r"(_b), "r"(_c)     /* inputs  */        \
  304.     : "d0", "d1", "d2", "a0", "a1", "a2"    /* clobbered regs */    \
  305.       AND_MEMORY                            \
  306.     );                                \
  307.     retvalue;                            \
  308. })
  309.  
  310. #define trap_1_wwl(n, a, b)                        \
  311. __extension__                                \
  312. ({                                    \
  313.     register long retvalue __asm__("d0");                \
  314.     short _a = (short)(a);                        \
  315.     long  _b = (long) (b);                        \
  316.                                         \
  317.     __asm__ volatile                        \
  318.     ("\
  319.         movl    %3,sp@-; \
  320.         movw    %2,sp@-; \
  321.         movw    %1,sp@-; \
  322.         trap    #1;    \
  323.         addqw    #8,sp "                    \
  324.     : "=r"(retvalue)            /* outputs */        \
  325.     : "g"(n), "r"(_a), "r"(_b)        /* inputs  */        \
  326.     : "d0", "d1", "d2", "a0", "a1", "a2"    /* clobbered regs */    \
  327.       AND_MEMORY                            \
  328.     );                                \
  329.     retvalue;                            \
  330. })
  331.  
  332. #else
  333.  
  334. #ifdef __GNUC__
  335. # ifndef __MSHORT__
  336. #  define __LONG_TRAPS__
  337. # endif
  338. #endif
  339.  
  340. #ifndef __LONG_TRAPS__
  341. # ifndef trap_1_w
  342. #  define trap_1_w(n)        gemdos(n)
  343. #  define trap_1_wl(n,a)        gemdos(n, (long)(a))
  344. #  define trap_1_wll(n, a, b)    gemdos(n, (long)(a), (long)(b))
  345. #  define trap_1_ww(n,a)        gemdos(n, a)
  346. #  define trap_1_www(n,a,b)    gemdos(n, a, b)
  347. #  define trap_1_wwlll(n,a,b,c,d) gemdos(n, a, (long)(b), (long)(c), (long)(d))
  348. #  define trap_1_wwll(n, a, b, c)    gemdos(n, a, (long)(b), (long)(c))
  349. #  define trap_1_wlw(n, a, b)    gemdos(n, (long)(a), b)
  350. #  define trap_1_wlww(n, a, b, c)    gemdos(n, (long)(a), b, c)
  351. #  define trap_13_w(n)        bios(n)
  352. #  define trap_14_w(n)        xbios(n)
  353. # endif
  354. # define trap_1_wwlw(n,a,b,c)    gemdos(n, a, (long)(b), c)
  355. # define trap_1_wwww(n,a,b,c)    gemdos(n, a, b, c)
  356. # define trap_1_wwl(n, a, b)    gemdos(n, a, (long)(b))
  357. # define trap_1_wwwl(n,a,b,c)    gemdos(n, a, b, (long)(c))
  358. #endif /* __LONG_TRAPS__ */
  359.  
  360. #endif /* __GNUC_INLINE__ */
  361.  
  362. #define    Syield()                        \
  363.         (int)trap_1_w(0xff)
  364. #define Fpipe(ptr)                        \
  365.         (int)trap_1_wl(0x100, (long)(ptr))
  366. #define Fcntl(f, arg, cmd)                    \
  367.         trap_1_wwlw(0x104, (short)(f), (long)(arg), (short)(cmd))
  368. #define Finstat(f)                        \
  369.         trap_1_ww(0x105, (short)(f))
  370. #define Foutstat(f)                        \
  371.         trap_1_ww(0x106, (short)(f))
  372. #define Fgetchar(f, mode)                    \
  373.         trap_1_www(0x107, (short)(f), (short)(mode))
  374. #define Fputchar(f, ch, mode)                    \
  375.         trap_1_wwlw(0x108, (short)(f), (long)(ch), (short)(mode))
  376.  
  377. #define Pwait()                            \
  378.         trap_1_w(0x109)
  379. #define Pnice(delta)                        \
  380.         (int)trap_1_ww(0x10a, (short)(delta))
  381. #define Pgetpid()                        \
  382.         (int)trap_1_w(0x10b)
  383. #define Pgetppid()                        \
  384.         (int)trap_1_w(0x10c)
  385. #define Pgetpgrp()                        \
  386.         (int)trap_1_w(0x10d)
  387. #define Psetpgrp(pid, grp)                    \
  388.         (int)trap_1_www(0x10e, (short)(pid), (short)(grp))
  389. #define Pgetuid()                        \
  390.         (int)trap_1_w(0x10f)
  391. #define Psetuid(id)                        \
  392.         (int)trap_1_ww(0x110, (short)(id))
  393. #define Pkill(pid, sig)                        \
  394.         (int)trap_1_www(0x111, (short)(pid), (short)(sig))
  395. #define Psignal(sig, handler)                    \
  396.         trap_1_wwl(0x112, (short)(sig), (long)(handler))
  397. #define Pvfork()                        \
  398.         trap_1_w(0x113)
  399. #define Pgetgid()                        \
  400.         (int)trap_1_w(0x114)
  401. #define Psetgid(id)                        \
  402.         (int)trap_1_ww(0x115, (short)(id))
  403. #define Psigblock(mask)                        \
  404.         trap_1_wl(0x116, (unsigned long)(mask))
  405. #define Psigsetmask(mask)                    \
  406.         trap_1_wl(0x117, (unsigned long)(mask))
  407. #define Pusrval(arg)                        \
  408.         trap_1_wl(0x118, (long)(arg))
  409. #define Pdomain(arg)                        \
  410.         (int)trap_1_ww(0x119, (short)(arg))
  411. #define Psigreturn()                        \
  412.         (void)trap_1_w(0x11a)
  413. #define Pfork()                            \
  414.         trap_1_w(0x11b)
  415. #define Pwait3(flag, rusage)                    \
  416.         trap_1_wwl(0x11c, (short)(flag), (long)(rusage))
  417. #define Fselect(time, rfd, wfd, xfd)                \
  418.         (int)trap_1_wwlll(0x11d, (unsigned short)(time), (long)(rfd), \
  419.                 (long)(wfd), (long)(xfd))
  420. #define Prusage(rsp)                        \
  421.         (int)trap_1_wl(0x11e, (long)(rsp))
  422. #define Psetlimit(i, val)                    \
  423.         trap_1_wwl(0x11f, (short)(i), (long)(val))
  424.  
  425. #define Talarm(sec)                        \
  426.         trap_1_wl(0x120, (long)(sec))
  427. #define Pause()                            \
  428.         (void)trap_1_w(0x121)
  429. #define Sysconf(n)                        \
  430.         trap_1_ww(0x122, (short)(n))
  431. #define Psigpending()                        \
  432.         trap_1_w(0x123)
  433. #define Dpathconf(name, which)                    \
  434.         trap_1_wlw(0x124, (long)(name), (short)(which))
  435.  
  436. #define Pmsg(mode, mbox, msg)                    \
  437.         trap_1_wwll(0x125, (short)(mode), (long)(mbox), (long)(msg))
  438. #define Fmidipipe(pid, in, out)                    \
  439.         trap_1_wwww(0x126, (short)(pid), (short)(in),(short)(out))
  440. #define Prenice(pid, delta)                    \
  441.         (int)trap_1_www(0x127, (short)(pid), (short)(delta))
  442. #define Dopendir(name, flag)                    \
  443.         trap_1_wlw(0x128, (long)(name), (short)(flag))
  444. #define Dreaddir(len, handle, buf)                \
  445.         trap_1_wwll(0x129, (short)(len), (long)(handle), (long)(buf))
  446. #define Drewinddir(handle)                    \
  447.         trap_1_wl(0x12a, (long)(handle))
  448. #define Dclosedir(handle)                    \
  449.         trap_1_wl(0x12b, (long)(handle))
  450. #define Fxattr(flag, name, buf)                    \
  451.         trap_1_wwll(0x12c, (short)(flag), (long)(name), (long)(buf))
  452. #define Flink(old, new)                        \
  453.         trap_1_wll(0x12d, (long)(old), (long)(new))
  454. #define Fsymlink(old, new)                    \
  455.         trap_1_wll(0x12e, (long)(old), (long)(new))
  456. #define Freadlink(siz, buf, linknm)                \
  457.         trap_1_wwll(0x12f, (short)(siz), (long)(buf), (long)(linknm))
  458. #define Dcntl(cmd, name, arg)                    \
  459.         trap_1_wwll(0x130, (short)(cmd), (long)(name), (long)(arg))
  460. #define Fchown(name, uid, gid)                    \
  461.         trap_1_wlww(0x131, (long)(name), (short)(uid), (short)(gid))
  462. #define Fchmod(name, mode)                    \
  463.         trap_1_wlw(0x132, (long)(name), (short)(mode))
  464. #define Pumask(mask)                        \
  465.         (int)trap_1_ww(0x133, (short)(mask))
  466. #define Psemaphore(mode, id, tmout)                \
  467.         trap_1_wwll(0x134, (short)(mode), (long)(id), (long)(tmout))
  468. #define Dlock(mode, drive)                    \
  469.         (int)trap_1_www(0x135, (short)(mode), (short)(drive))
  470. #define Psigpause(mask)                        \
  471.         (void)trap_1_wl(0x136, (unsigned long)(mask))
  472. #define Psigaction(sig, act, oact)                    \
  473.         trap_1_wwll(0x137, (short)(sig), (long)(act), (long)(oact))
  474. #define Pgeteuid()                        \
  475.         (int)trap_1_w(0x138)
  476. #define Pgetegid()                        \
  477.         (int)trap_1_w(0x139)
  478. #define Pwaitpid(pid,flag, rusage)                \
  479.         trap_1_wwwl(0x13a, (short)(pid), (short)(flag), (long)(rusage))
  480. #define Dgetcwd(path, drv, size)                \
  481.         trap_1_wlww(0x13b, (long)(path), (short)(drv), (short)(size))
  482. #define Salert(msg)                        \
  483.         trap_1_wl(0x13c, (long)(msg))
  484.  
  485. #endif /* __LATTICE__ */
  486. #endif /* __TURBOC__ */
  487.  
  488. #ifdef __cplusplus
  489. }
  490. #endif
  491.  
  492. #endif /* _MINTBIND_H */
  493.