unistd.h
上传用户:lgb322
上传日期:2013-02-24
资源大小:30529k
文件大小:12k
源码类别:

嵌入式Linux

开发平台:

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(n) #n
  217. #define __syscall_return(type) 
  218. return (__sc_err & 0x10000000 ? errno = __sc_ret, __sc_ret = -1 : 0), 
  219.        (type) __sc_ret
  220. #define __syscall_clobbers 
  221. "r4", "r5", "r6", "r7", "r8", "r9", "r10", "r11", "r12"
  222. #define _syscall0(type,name)
  223. type name(void)
  224. {
  225. unsigned long __sc_ret, __sc_err;
  226. {
  227. register unsigned long __sc_0 __asm__ ("r0");
  228. register unsigned long __sc_3 __asm__ ("r3");
  229. __sc_0 = __NR_##name;
  230. __asm__ __volatile__
  231. ("sc           nt"
  232.  "mfcr %1      "
  233. : "=&r" (__sc_3), "=&r" (__sc_0)
  234. : "0"   (__sc_3), "1"   (__sc_0)
  235. : __syscall_clobbers);
  236. __sc_ret = __sc_3;
  237. __sc_err = __sc_0;
  238. }
  239. __syscall_return (type);
  240. }
  241. #define _syscall1(type,name,type1,arg1)
  242. type name(type1 arg1)
  243. {
  244. unsigned long __sc_ret, __sc_err;
  245. {
  246. register unsigned long __sc_0 __asm__ ("r0");
  247. register unsigned long __sc_3 __asm__ ("r3");
  248. __sc_3 = (unsigned long) (arg1);
  249. __sc_0 = __NR_##name;
  250. __asm__ __volatile__
  251. ("sc           nt"
  252.  "mfcr %1      "
  253. : "=&r" (__sc_3), "=&r" (__sc_0)
  254. : "0"   (__sc_3), "1"   (__sc_0)
  255. : __syscall_clobbers);
  256. __sc_ret = __sc_3;
  257. __sc_err = __sc_0;
  258. }
  259. __syscall_return (type);
  260. }
  261. #define _syscall2(type,name,type1,arg1,type2,arg2)
  262. type name(type1 arg1, type2 arg2)
  263. {
  264. unsigned long __sc_ret, __sc_err;
  265. {
  266. register unsigned long __sc_0 __asm__ ("r0");
  267. register unsigned long __sc_3 __asm__ ("r3");
  268. register unsigned long __sc_4 __asm__ ("r4");
  269. __sc_3 = (unsigned long) (arg1);
  270. __sc_4 = (unsigned long) (arg2);
  271. __sc_0 = __NR_##name;
  272. __asm__ __volatile__
  273. ("sc           nt"
  274.  "mfcr %1      "
  275. : "=&r" (__sc_3), "=&r" (__sc_0)
  276. : "0"   (__sc_3), "1"   (__sc_0),
  277.   "r"   (__sc_4)
  278. : __syscall_clobbers);
  279. __sc_ret = __sc_3;
  280. __sc_err = __sc_0;
  281. }
  282. __syscall_return (type);
  283. }
  284. #define _syscall3(type,name,type1,arg1,type2,arg2,type3,arg3)
  285. type name(type1 arg1, type2 arg2, type3 arg3)
  286. {
  287. unsigned long __sc_ret, __sc_err;
  288. {
  289. register unsigned long __sc_0 __asm__ ("r0");
  290. register unsigned long __sc_3 __asm__ ("r3");
  291. register unsigned long __sc_4 __asm__ ("r4");
  292. register unsigned long __sc_5 __asm__ ("r5");
  293. __sc_3 = (unsigned long) (arg1);
  294. __sc_4 = (unsigned long) (arg2);
  295. __sc_5 = (unsigned long) (arg3);
  296. __sc_0 = __NR_##name;
  297. __asm__ __volatile__
  298. ("sc           nt"
  299.  "mfcr %1      "
  300. : "=&r" (__sc_3), "=&r" (__sc_0)
  301. : "0"   (__sc_3), "1"   (__sc_0),
  302.   "r"   (__sc_4),
  303.   "r"   (__sc_5)
  304. : __syscall_clobbers);
  305. __sc_ret = __sc_3;
  306. __sc_err = __sc_0;
  307. }
  308. __syscall_return (type);
  309. }
  310. #define _syscall4(type,name,type1,arg1,type2,arg2,type3,arg3,type4,arg4) 
  311. type name(type1 arg1, type2 arg2, type3 arg3, type4 arg4)
  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. register unsigned long __sc_6 __asm__ ("r6");
  320. __sc_3 = (unsigned long) (arg1);
  321. __sc_4 = (unsigned long) (arg2);
  322. __sc_5 = (unsigned long) (arg3);
  323. __sc_6 = (unsigned long) (arg4);
  324. __sc_0 = __NR_##name;
  325. __asm__ __volatile__
  326. ("sc           nt"
  327.  "mfcr %1      "
  328. : "=&r" (__sc_3), "=&r" (__sc_0)
  329. : "0"   (__sc_3), "1"   (__sc_0),
  330.   "r"   (__sc_4),
  331.   "r"   (__sc_5),
  332.   "r"   (__sc_6)
  333. : __syscall_clobbers);
  334. __sc_ret = __sc_3;
  335. __sc_err = __sc_0;
  336. }
  337. __syscall_return (type);
  338. }
  339. #define _syscall5(type,name,type1,arg1,type2,arg2,type3,arg3,type4,arg4,type5,arg5) 
  340. type name(type1 arg1, type2 arg2, type3 arg3, type4 arg4, type5 arg5)
  341. {
  342. unsigned long __sc_ret, __sc_err;
  343. {
  344. register unsigned long __sc_0 __asm__ ("r0");
  345. register unsigned long __sc_3 __asm__ ("r3");
  346. register unsigned long __sc_4 __asm__ ("r4");
  347. register unsigned long __sc_5 __asm__ ("r5");
  348. register unsigned long __sc_6 __asm__ ("r6");
  349. register unsigned long __sc_7 __asm__ ("r7");
  350. __sc_3 = (unsigned long) (arg1);
  351. __sc_4 = (unsigned long) (arg2);
  352. __sc_5 = (unsigned long) (arg3);
  353. __sc_6 = (unsigned long) (arg4);
  354. __sc_7 = (unsigned long) (arg5);
  355. __sc_0 = __NR_##name;
  356. __asm__ __volatile__
  357. ("sc           nt"
  358.  "mfcr %1      "
  359. : "=&r" (__sc_3), "=&r" (__sc_0)
  360. : "0"   (__sc_3), "1"   (__sc_0),
  361.   "r"   (__sc_4),
  362.   "r"   (__sc_5),
  363.   "r"   (__sc_6),
  364.   "r"   (__sc_7)
  365. : __syscall_clobbers);
  366. __sc_ret = __sc_3;
  367. __sc_err = __sc_0;
  368. }
  369. __syscall_return (type);
  370. }
  371. #ifdef __KERNEL_SYSCALLS__
  372. /*
  373.  * Forking from kernel space will result in the child getting a new,
  374.  * empty kernel stack area.  Thus the child cannot access automatic
  375.  * variables set in the parent unless they are in registers, and the
  376.  * procedure where the fork was done cannot return to its caller in
  377.  * the child.
  378.  */
  379. /*
  380.  * System call prototypes.
  381.  */
  382. #define __NR__exit __NR_exit
  383. static inline _syscall0(int,pause)
  384. static inline _syscall0(int,sync)
  385. static inline _syscall0(pid_t,setsid)
  386. static inline _syscall3(int,write,int,fd,const char *,buf,off_t,count)
  387. static inline _syscall3(int,read,int,fd,char *,buf,off_t,count)
  388. static inline _syscall3(off_t,lseek,int,fd,off_t,offset,int,count)
  389. static inline _syscall1(int,dup,int,fd)
  390. static inline _syscall3(int,execve,const char *,file,char **,argv,char **,envp)
  391. static inline _syscall3(int,open,const char *,file,int,flag,int,mode)
  392. static inline _syscall1(int,close,int,fd)
  393. static inline _syscall1(int,_exit,int,exitcode)
  394. static inline _syscall3(pid_t,waitpid,pid_t,pid,int *,wait_stat,int,options)
  395. static inline _syscall1(int,delete_module,const char *,name)
  396. static inline pid_t wait(int * wait_stat) 
  397. {
  398. return waitpid(-1,wait_stat,0);
  399. }
  400. #endif /* __KERNEL_SYSCALLS__ */
  401. #endif /* _ASM_PPC_UNISTD_H_ */