unistd.h
上传用户:jlfgdled
上传日期:2013-04-10
资源大小:33168k
文件大小:13k
源码类别:

Linux/Unix编程

开发平台:

Unix_Linux

  1. /*
  2.  * BK Id: SCCS/s.unistd.h 1.11 10/18/01 17:29:53 trini
  3.  */
  4. #ifndef _ASM_PPC_UNISTD_H_
  5. #define _ASM_PPC_UNISTD_H_
  6. /*
  7.  * This file contains the system call numbers.
  8.  */
  9. #define __NR_exit   1
  10. #define __NR_fork   2
  11. #define __NR_read   3
  12. #define __NR_write   4
  13. #define __NR_open   5
  14. #define __NR_close   6
  15. #define __NR_waitpid   7
  16. #define __NR_creat   8
  17. #define __NR_link   9
  18. #define __NR_unlink  10
  19. #define __NR_execve  11
  20. #define __NR_chdir  12
  21. #define __NR_time  13
  22. #define __NR_mknod  14
  23. #define __NR_chmod  15
  24. #define __NR_lchown  16
  25. #define __NR_break  17
  26. #define __NR_oldstat  18
  27. #define __NR_lseek  19
  28. #define __NR_getpid  20
  29. #define __NR_mount  21
  30. #define __NR_umount  22
  31. #define __NR_setuid  23
  32. #define __NR_getuid  24
  33. #define __NR_stime  25
  34. #define __NR_ptrace  26
  35. #define __NR_alarm  27
  36. #define __NR_oldfstat  28
  37. #define __NR_pause  29
  38. #define __NR_utime  30
  39. #define __NR_stty  31
  40. #define __NR_gtty  32
  41. #define __NR_access  33
  42. #define __NR_nice  34
  43. #define __NR_ftime  35
  44. #define __NR_sync  36
  45. #define __NR_kill  37
  46. #define __NR_rename  38
  47. #define __NR_mkdir  39
  48. #define __NR_rmdir  40
  49. #define __NR_dup  41
  50. #define __NR_pipe  42
  51. #define __NR_times  43
  52. #define __NR_prof  44
  53. #define __NR_brk  45
  54. #define __NR_setgid  46
  55. #define __NR_getgid  47
  56. #define __NR_signal  48
  57. #define __NR_geteuid  49
  58. #define __NR_getegid  50
  59. #define __NR_acct  51
  60. #define __NR_umount2  52
  61. #define __NR_lock  53
  62. #define __NR_ioctl  54
  63. #define __NR_fcntl  55
  64. #define __NR_mpx  56
  65. #define __NR_setpgid  57
  66. #define __NR_ulimit  58
  67. #define __NR_oldolduname  59
  68. #define __NR_umask  60
  69. #define __NR_chroot  61
  70. #define __NR_ustat  62
  71. #define __NR_dup2  63
  72. #define __NR_getppid  64
  73. #define __NR_getpgrp  65
  74. #define __NR_setsid  66
  75. #define __NR_sigaction  67
  76. #define __NR_sgetmask  68
  77. #define __NR_ssetmask  69
  78. #define __NR_setreuid  70
  79. #define __NR_setregid  71
  80. #define __NR_sigsuspend  72
  81. #define __NR_sigpending  73
  82. #define __NR_sethostname  74
  83. #define __NR_setrlimit  75
  84. #define __NR_getrlimit  76
  85. #define __NR_getrusage  77
  86. #define __NR_gettimeofday  78
  87. #define __NR_settimeofday  79
  88. #define __NR_getgroups  80
  89. #define __NR_setgroups  81
  90. #define __NR_select  82
  91. #define __NR_symlink  83
  92. #define __NR_oldlstat  84
  93. #define __NR_readlink  85
  94. #define __NR_uselib  86
  95. #define __NR_swapon  87
  96. #define __NR_reboot  88
  97. #define __NR_readdir  89
  98. #define __NR_mmap  90
  99. #define __NR_munmap  91
  100. #define __NR_truncate  92
  101. #define __NR_ftruncate  93
  102. #define __NR_fchmod  94
  103. #define __NR_fchown  95
  104. #define __NR_getpriority  96
  105. #define __NR_setpriority  97
  106. #define __NR_profil  98
  107. #define __NR_statfs  99
  108. #define __NR_fstatfs 100
  109. #define __NR_ioperm 101
  110. #define __NR_socketcall 102
  111. #define __NR_syslog 103
  112. #define __NR_setitimer 104
  113. #define __NR_getitimer 105
  114. #define __NR_stat 106
  115. #define __NR_lstat 107
  116. #define __NR_fstat 108
  117. #define __NR_olduname 109
  118. #define __NR_iopl 110
  119. #define __NR_vhangup 111
  120. #define __NR_idle 112
  121. #define __NR_vm86 113
  122. #define __NR_wait4 114
  123. #define __NR_swapoff 115
  124. #define __NR_sysinfo 116
  125. #define __NR_ipc 117
  126. #define __NR_fsync 118
  127. #define __NR_sigreturn 119
  128. #define __NR_clone 120
  129. #define __NR_setdomainname 121
  130. #define __NR_uname 122
  131. #define __NR_modify_ldt 123
  132. #define __NR_adjtimex 124
  133. #define __NR_mprotect 125
  134. #define __NR_sigprocmask 126
  135. #define __NR_create_module 127
  136. #define __NR_init_module 128
  137. #define __NR_delete_module 129
  138. #define __NR_get_kernel_syms 130
  139. #define __NR_quotactl 131
  140. #define __NR_getpgid 132
  141. #define __NR_fchdir 133
  142. #define __NR_bdflush 134
  143. #define __NR_sysfs 135
  144. #define __NR_personality 136
  145. #define __NR_afs_syscall 137 /* Syscall for Andrew File System */
  146. #define __NR_setfsuid 138
  147. #define __NR_setfsgid 139
  148. #define __NR__llseek 140
  149. #define __NR_getdents 141
  150. #define __NR__newselect 142
  151. #define __NR_flock 143
  152. #define __NR_msync 144
  153. #define __NR_readv 145
  154. #define __NR_writev 146
  155. #define __NR_getsid 147
  156. #define __NR_fdatasync 148
  157. #define __NR__sysctl 149
  158. #define __NR_mlock 150
  159. #define __NR_munlock 151
  160. #define __NR_mlockall 152
  161. #define __NR_munlockall 153
  162. #define __NR_sched_setparam 154
  163. #define __NR_sched_getparam 155
  164. #define __NR_sched_setscheduler 156
  165. #define __NR_sched_getscheduler 157
  166. #define __NR_sched_yield 158
  167. #define __NR_sched_get_priority_max 159
  168. #define __NR_sched_get_priority_min 160
  169. #define __NR_sched_rr_get_interval 161
  170. #define __NR_nanosleep 162
  171. #define __NR_mremap 163
  172. #define __NR_setresuid 164
  173. #define __NR_getresuid 165
  174. #define __NR_query_module 166
  175. #define __NR_poll 167
  176. #define __NR_nfsservctl 168
  177. #define __NR_setresgid 169
  178. #define __NR_getresgid 170
  179. #define __NR_prctl 171
  180. #define __NR_rt_sigreturn 172
  181. #define __NR_rt_sigaction 173
  182. #define __NR_rt_sigprocmask 174
  183. #define __NR_rt_sigpending 175
  184. #define __NR_rt_sigtimedwait 176
  185. #define __NR_rt_sigqueueinfo 177
  186. #define __NR_rt_sigsuspend 178
  187. #define __NR_pread 179
  188. #define __NR_pwrite 180
  189. #define __NR_chown 181
  190. #define __NR_getcwd 182
  191. #define __NR_capget 183
  192. #define __NR_capset 184
  193. #define __NR_sigaltstack 185
  194. #define __NR_sendfile 186
  195. #define __NR_getpmsg 187 /* some people actually want streams */
  196. #define __NR_putpmsg 188 /* some people actually want streams */
  197. #define __NR_vfork 189
  198. #define __NR_ugetrlimit 190 /* SuS compliant getrlimit */
  199. #define __NR_readahead 191
  200. #define __NR_mmap2 192
  201. #define __NR_truncate64 193
  202. #define __NR_ftruncate64 194
  203. #define __NR_stat64 195
  204. #define __NR_lstat64 196
  205. #define __NR_fstat64 197
  206. #define __NR_pciconfig_read 198
  207. #define __NR_pciconfig_write 199
  208. #define __NR_pciconfig_iobase 200
  209. #define __NR_multiplexer 201
  210. #define __NR_getdents64 202
  211. #define __NR_pivot_root 203
  212. #define __NR_fcntl64 204
  213. #define __NR_madvise 205
  214. #define __NR_mincore 206
  215. #define __NR_gettid 207
  216. #define __NR_tkill 208
  217. #define __NR_setxattr 209
  218. #define __NR_lsetxattr 210
  219. #define __NR_fsetxattr 211
  220. #define __NR_getxattr 212
  221. #define __NR_lgetxattr 213
  222. #define __NR_fgetxattr 214
  223. #define __NR_listxattr 215
  224. #define __NR_llistxattr 216
  225. #define __NR_flistxattr 217
  226. #define __NR_removexattr 218
  227. #define __NR_lremovexattr 219
  228. #define __NR_fremovexattr 220
  229. #if 0
  230. #define __NR_futex 221
  231. #define __NR_sched_setaffinity 222
  232. #define __NR_sched_getaffinity 223
  233. #define __NR_security 224
  234. #define __NR_tuxcall 225
  235. #define __NR_sendfile64 226
  236. #define __NR_io_setup 227
  237. #define __NR_io_destroy 228
  238. #define __NR_io_getevents 229
  239. #define __NR_io_submit 230
  240. #define __NR_io_cancel 231
  241. #endif
  242. #define __NR(n) #n
  243. #define __syscall_return(type) 
  244. return (__sc_err & 0x10000000 ? errno = __sc_ret, __sc_ret = -1 : 0), 
  245.        (type) __sc_ret
  246. #define __syscall_clobbers 
  247. "r4", "r5", "r6", "r7", "r8", "r9", "r10", "r11", "r12"
  248. #define _syscall0(type,name)
  249. type name(void)
  250. {
  251. unsigned long __sc_ret, __sc_err;
  252. {
  253. register unsigned long __sc_0 __asm__ ("r0");
  254. register unsigned long __sc_3 __asm__ ("r3");
  255. __sc_0 = __NR_##name;
  256. __asm__ __volatile__
  257. ("sc           nt"
  258.  "mfcr %1      "
  259. : "=&r" (__sc_3), "=&r" (__sc_0)
  260. : "0"   (__sc_3), "1"   (__sc_0)
  261. : __syscall_clobbers);
  262. __sc_ret = __sc_3;
  263. __sc_err = __sc_0;
  264. }
  265. __syscall_return (type);
  266. }
  267. #define _syscall1(type,name,type1,arg1)
  268. type name(type1 arg1)
  269. {
  270. unsigned long __sc_ret, __sc_err;
  271. {
  272. register unsigned long __sc_0 __asm__ ("r0");
  273. register unsigned long __sc_3 __asm__ ("r3");
  274. __sc_3 = (unsigned long) (arg1);
  275. __sc_0 = __NR_##name;
  276. __asm__ __volatile__
  277. ("sc           nt"
  278.  "mfcr %1      "
  279. : "=&r" (__sc_3), "=&r" (__sc_0)
  280. : "0"   (__sc_3), "1"   (__sc_0)
  281. : __syscall_clobbers);
  282. __sc_ret = __sc_3;
  283. __sc_err = __sc_0;
  284. }
  285. __syscall_return (type);
  286. }
  287. #define _syscall2(type,name,type1,arg1,type2,arg2)
  288. type name(type1 arg1, type2 arg2)
  289. {
  290. unsigned long __sc_ret, __sc_err;
  291. {
  292. register unsigned long __sc_0 __asm__ ("r0");
  293. register unsigned long __sc_3 __asm__ ("r3");
  294. register unsigned long __sc_4 __asm__ ("r4");
  295. __sc_3 = (unsigned long) (arg1);
  296. __sc_4 = (unsigned long) (arg2);
  297. __sc_0 = __NR_##name;
  298. __asm__ __volatile__
  299. ("sc           nt"
  300.  "mfcr %1      "
  301. : "=&r" (__sc_3), "=&r" (__sc_0)
  302. : "0"   (__sc_3), "1"   (__sc_0),
  303.   "r"   (__sc_4)
  304. : __syscall_clobbers);
  305. __sc_ret = __sc_3;
  306. __sc_err = __sc_0;
  307. }
  308. __syscall_return (type);
  309. }
  310. #define _syscall3(type,name,type1,arg1,type2,arg2,type3,arg3)
  311. type name(type1 arg1, type2 arg2, type3 arg3)
  312. {
  313. unsigned long __sc_ret, __sc_err;
  314. {
  315. register unsigned long __sc_0 __asm__ ("r0");
  316. register unsigned long __sc_3 __asm__ ("r3");
  317. register unsigned long __sc_4 __asm__ ("r4");
  318. register unsigned long __sc_5 __asm__ ("r5");
  319. __sc_3 = (unsigned long) (arg1);
  320. __sc_4 = (unsigned long) (arg2);
  321. __sc_5 = (unsigned long) (arg3);
  322. __sc_0 = __NR_##name;
  323. __asm__ __volatile__
  324. ("sc           nt"
  325.  "mfcr %1      "
  326. : "=&r" (__sc_3), "=&r" (__sc_0)
  327. : "0"   (__sc_3), "1"   (__sc_0),
  328.   "r"   (__sc_4),
  329.   "r"   (__sc_5)
  330. : __syscall_clobbers);
  331. __sc_ret = __sc_3;
  332. __sc_err = __sc_0;
  333. }
  334. __syscall_return (type);
  335. }
  336. #define _syscall4(type,name,type1,arg1,type2,arg2,type3,arg3,type4,arg4) 
  337. type name(type1 arg1, type2 arg2, type3 arg3, type4 arg4)
  338. {
  339. unsigned long __sc_ret, __sc_err;
  340. {
  341. register unsigned long __sc_0 __asm__ ("r0");
  342. register unsigned long __sc_3 __asm__ ("r3");
  343. register unsigned long __sc_4 __asm__ ("r4");
  344. register unsigned long __sc_5 __asm__ ("r5");
  345. register unsigned long __sc_6 __asm__ ("r6");
  346. __sc_3 = (unsigned long) (arg1);
  347. __sc_4 = (unsigned long) (arg2);
  348. __sc_5 = (unsigned long) (arg3);
  349. __sc_6 = (unsigned long) (arg4);
  350. __sc_0 = __NR_##name;
  351. __asm__ __volatile__
  352. ("sc           nt"
  353.  "mfcr %1      "
  354. : "=&r" (__sc_3), "=&r" (__sc_0)
  355. : "0"   (__sc_3), "1"   (__sc_0),
  356.   "r"   (__sc_4),
  357.   "r"   (__sc_5),
  358.   "r"   (__sc_6)
  359. : __syscall_clobbers);
  360. __sc_ret = __sc_3;
  361. __sc_err = __sc_0;
  362. }
  363. __syscall_return (type);
  364. }
  365. #define _syscall5(type,name,type1,arg1,type2,arg2,type3,arg3,type4,arg4,type5,arg5) 
  366. type name(type1 arg1, type2 arg2, type3 arg3, type4 arg4, type5 arg5)
  367. {
  368. unsigned long __sc_ret, __sc_err;
  369. {
  370. register unsigned long __sc_0 __asm__ ("r0");
  371. register unsigned long __sc_3 __asm__ ("r3");
  372. register unsigned long __sc_4 __asm__ ("r4");
  373. register unsigned long __sc_5 __asm__ ("r5");
  374. register unsigned long __sc_6 __asm__ ("r6");
  375. register unsigned long __sc_7 __asm__ ("r7");
  376. __sc_3 = (unsigned long) (arg1);
  377. __sc_4 = (unsigned long) (arg2);
  378. __sc_5 = (unsigned long) (arg3);
  379. __sc_6 = (unsigned long) (arg4);
  380. __sc_7 = (unsigned long) (arg5);
  381. __sc_0 = __NR_##name;
  382. __asm__ __volatile__
  383. ("sc           nt"
  384.  "mfcr %1      "
  385. : "=&r" (__sc_3), "=&r" (__sc_0)
  386. : "0"   (__sc_3), "1"   (__sc_0),
  387.   "r"   (__sc_4),
  388.   "r"   (__sc_5),
  389.   "r"   (__sc_6),
  390.   "r"   (__sc_7)
  391. : __syscall_clobbers);
  392. __sc_ret = __sc_3;
  393. __sc_err = __sc_0;
  394. }
  395. __syscall_return (type);
  396. }
  397. #ifdef __KERNEL_SYSCALLS__
  398. /*
  399.  * Forking from kernel space will result in the child getting a new,
  400.  * empty kernel stack area.  Thus the child cannot access automatic
  401.  * variables set in the parent unless they are in registers, and the
  402.  * procedure where the fork was done cannot return to its caller in
  403.  * the child.
  404.  */
  405. /*
  406.  * System call prototypes.
  407.  */
  408. #define __NR__exit __NR_exit
  409. static inline _syscall0(int,pause)
  410. static inline _syscall0(int,sync)
  411. static inline _syscall0(pid_t,setsid)
  412. static inline _syscall3(int,write,int,fd,const char *,buf,off_t,count)
  413. static inline _syscall3(int,read,int,fd,char *,buf,off_t,count)
  414. static inline _syscall3(off_t,lseek,int,fd,off_t,offset,int,count)
  415. static inline _syscall1(int,dup,int,fd)
  416. static inline _syscall3(int,execve,const char *,file,char **,argv,char **,envp)
  417. static inline _syscall3(int,open,const char *,file,int,flag,int,mode)
  418. static inline _syscall1(int,close,int,fd)
  419. static inline _syscall1(int,_exit,int,exitcode)
  420. static inline _syscall3(pid_t,waitpid,pid_t,pid,int *,wait_stat,int,options)
  421. static inline _syscall1(int,delete_module,const char *,name)
  422. static inline pid_t wait(int * wait_stat) 
  423. {
  424. return waitpid(-1,wait_stat,0);
  425. }
  426. #endif /* __KERNEL_SYSCALLS__ */
  427. #endif /* _ASM_PPC_UNISTD_H_ */