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

Linux/Unix编程

开发平台:

Unix_Linux

  1. /*
  2.  *  linux/include/asm-arm/unistd.h
  3.  *
  4.  *  Copyright (C) 2001 Russell King
  5.  *
  6.  * This program is free software; you can redistribute it and/or modify
  7.  * it under the terms of the GNU General Public License version 2 as
  8.  * published by the Free Software Foundation.
  9.  *
  10.  * Please forward _all_ changes to this file to rmk@arm.linux.org.uk,
  11.  * no matter what the change is.  Thanks!
  12.  */
  13. #ifndef __ASM_ARM_UNISTD_H
  14. #define __ASM_ARM_UNISTD_H
  15. #define __NR_SYSCALL_BASE 0x900000
  16. /*
  17.  * This file contains the system call numbers.
  18.  */
  19. #define __NR_exit (__NR_SYSCALL_BASE+  1)
  20. #define __NR_fork (__NR_SYSCALL_BASE+  2)
  21. #define __NR_read (__NR_SYSCALL_BASE+  3)
  22. #define __NR_write (__NR_SYSCALL_BASE+  4)
  23. #define __NR_open (__NR_SYSCALL_BASE+  5)
  24. #define __NR_close (__NR_SYSCALL_BASE+  6)
  25. #define __NR_waitpid (__NR_SYSCALL_BASE+  7)
  26. #define __NR_creat (__NR_SYSCALL_BASE+  8)
  27. #define __NR_link (__NR_SYSCALL_BASE+  9)
  28. #define __NR_unlink (__NR_SYSCALL_BASE+ 10)
  29. #define __NR_execve (__NR_SYSCALL_BASE+ 11)
  30. #define __NR_chdir (__NR_SYSCALL_BASE+ 12)
  31. #define __NR_time (__NR_SYSCALL_BASE+ 13)
  32. #define __NR_mknod (__NR_SYSCALL_BASE+ 14)
  33. #define __NR_chmod (__NR_SYSCALL_BASE+ 15)
  34. #define __NR_lchown (__NR_SYSCALL_BASE+ 16)
  35. #define __NR_break (__NR_SYSCALL_BASE+ 17)
  36. #define __NR_lseek (__NR_SYSCALL_BASE+ 19)
  37. #define __NR_getpid (__NR_SYSCALL_BASE+ 20)
  38. #define __NR_mount (__NR_SYSCALL_BASE+ 21)
  39. #define __NR_umount (__NR_SYSCALL_BASE+ 22)
  40. #define __NR_setuid (__NR_SYSCALL_BASE+ 23)
  41. #define __NR_getuid (__NR_SYSCALL_BASE+ 24)
  42. #define __NR_stime (__NR_SYSCALL_BASE+ 25)
  43. #define __NR_ptrace (__NR_SYSCALL_BASE+ 26)
  44. #define __NR_alarm (__NR_SYSCALL_BASE+ 27)
  45. #define __NR_pause (__NR_SYSCALL_BASE+ 29)
  46. #define __NR_utime (__NR_SYSCALL_BASE+ 30)
  47. #define __NR_stty (__NR_SYSCALL_BASE+ 31)
  48. #define __NR_gtty (__NR_SYSCALL_BASE+ 32)
  49. #define __NR_access (__NR_SYSCALL_BASE+ 33)
  50. #define __NR_nice (__NR_SYSCALL_BASE+ 34)
  51. #define __NR_ftime (__NR_SYSCALL_BASE+ 35)
  52. #define __NR_sync (__NR_SYSCALL_BASE+ 36)
  53. #define __NR_kill (__NR_SYSCALL_BASE+ 37)
  54. #define __NR_rename (__NR_SYSCALL_BASE+ 38)
  55. #define __NR_mkdir (__NR_SYSCALL_BASE+ 39)
  56. #define __NR_rmdir (__NR_SYSCALL_BASE+ 40)
  57. #define __NR_dup (__NR_SYSCALL_BASE+ 41)
  58. #define __NR_pipe (__NR_SYSCALL_BASE+ 42)
  59. #define __NR_times (__NR_SYSCALL_BASE+ 43)
  60. #define __NR_prof (__NR_SYSCALL_BASE+ 44)
  61. #define __NR_brk (__NR_SYSCALL_BASE+ 45)
  62. #define __NR_setgid (__NR_SYSCALL_BASE+ 46)
  63. #define __NR_getgid (__NR_SYSCALL_BASE+ 47)
  64. #define __NR_signal (__NR_SYSCALL_BASE+ 48)
  65. #define __NR_geteuid (__NR_SYSCALL_BASE+ 49)
  66. #define __NR_getegid (__NR_SYSCALL_BASE+ 50)
  67. #define __NR_acct (__NR_SYSCALL_BASE+ 51)
  68. #define __NR_umount2 (__NR_SYSCALL_BASE+ 52)
  69. #define __NR_lock (__NR_SYSCALL_BASE+ 53)
  70. #define __NR_ioctl (__NR_SYSCALL_BASE+ 54)
  71. #define __NR_fcntl (__NR_SYSCALL_BASE+ 55)
  72. #define __NR_mpx (__NR_SYSCALL_BASE+ 56)
  73. #define __NR_setpgid (__NR_SYSCALL_BASE+ 57)
  74. #define __NR_ulimit (__NR_SYSCALL_BASE+ 58)
  75. #define __NR_umask (__NR_SYSCALL_BASE+ 60)
  76. #define __NR_chroot (__NR_SYSCALL_BASE+ 61)
  77. #define __NR_ustat (__NR_SYSCALL_BASE+ 62)
  78. #define __NR_dup2 (__NR_SYSCALL_BASE+ 63)
  79. #define __NR_getppid (__NR_SYSCALL_BASE+ 64)
  80. #define __NR_getpgrp (__NR_SYSCALL_BASE+ 65)
  81. #define __NR_setsid (__NR_SYSCALL_BASE+ 66)
  82. #define __NR_sigaction (__NR_SYSCALL_BASE+ 67)
  83. #define __NR_sgetmask (__NR_SYSCALL_BASE+ 68)
  84. #define __NR_ssetmask (__NR_SYSCALL_BASE+ 69)
  85. #define __NR_setreuid (__NR_SYSCALL_BASE+ 70)
  86. #define __NR_setregid (__NR_SYSCALL_BASE+ 71)
  87. #define __NR_sigsuspend (__NR_SYSCALL_BASE+ 72)
  88. #define __NR_sigpending (__NR_SYSCALL_BASE+ 73)
  89. #define __NR_sethostname (__NR_SYSCALL_BASE+ 74)
  90. #define __NR_setrlimit (__NR_SYSCALL_BASE+ 75)
  91. #define __NR_getrlimit (__NR_SYSCALL_BASE+ 76) /* Back compat 2GB limited rlimit */
  92. #define __NR_getrusage (__NR_SYSCALL_BASE+ 77)
  93. #define __NR_gettimeofday (__NR_SYSCALL_BASE+ 78)
  94. #define __NR_settimeofday (__NR_SYSCALL_BASE+ 79)
  95. #define __NR_getgroups (__NR_SYSCALL_BASE+ 80)
  96. #define __NR_setgroups (__NR_SYSCALL_BASE+ 81)
  97. #define __NR_select (__NR_SYSCALL_BASE+ 82)
  98. #define __NR_symlink (__NR_SYSCALL_BASE+ 83)
  99. #define __NR_readlink (__NR_SYSCALL_BASE+ 85)
  100. #define __NR_uselib (__NR_SYSCALL_BASE+ 86)
  101. #define __NR_swapon (__NR_SYSCALL_BASE+ 87)
  102. #define __NR_reboot (__NR_SYSCALL_BASE+ 88)
  103. #define __NR_readdir (__NR_SYSCALL_BASE+ 89)
  104. #define __NR_mmap (__NR_SYSCALL_BASE+ 90)
  105. #define __NR_munmap (__NR_SYSCALL_BASE+ 91)
  106. #define __NR_truncate (__NR_SYSCALL_BASE+ 92)
  107. #define __NR_ftruncate (__NR_SYSCALL_BASE+ 93)
  108. #define __NR_fchmod (__NR_SYSCALL_BASE+ 94)
  109. #define __NR_fchown (__NR_SYSCALL_BASE+ 95)
  110. #define __NR_getpriority (__NR_SYSCALL_BASE+ 96)
  111. #define __NR_setpriority (__NR_SYSCALL_BASE+ 97)
  112. #define __NR_profil (__NR_SYSCALL_BASE+ 98)
  113. #define __NR_statfs (__NR_SYSCALL_BASE+ 99)
  114. #define __NR_fstatfs (__NR_SYSCALL_BASE+100)
  115. #define __NR_ioperm (__NR_SYSCALL_BASE+101)
  116. #define __NR_socketcall (__NR_SYSCALL_BASE+102)
  117. #define __NR_syslog (__NR_SYSCALL_BASE+103)
  118. #define __NR_setitimer (__NR_SYSCALL_BASE+104)
  119. #define __NR_getitimer (__NR_SYSCALL_BASE+105)
  120. #define __NR_stat (__NR_SYSCALL_BASE+106)
  121. #define __NR_lstat (__NR_SYSCALL_BASE+107)
  122. #define __NR_fstat (__NR_SYSCALL_BASE+108)
  123. #define __NR_vhangup (__NR_SYSCALL_BASE+111)
  124. #define __NR_idle (__NR_SYSCALL_BASE+112)
  125. #define __NR_syscall (__NR_SYSCALL_BASE+113) /* syscall to call a syscall! */
  126. #define __NR_wait4 (__NR_SYSCALL_BASE+114)
  127. #define __NR_swapoff (__NR_SYSCALL_BASE+115)
  128. #define __NR_sysinfo (__NR_SYSCALL_BASE+116)
  129. #define __NR_ipc (__NR_SYSCALL_BASE+117)
  130. #define __NR_fsync (__NR_SYSCALL_BASE+118)
  131. #define __NR_sigreturn (__NR_SYSCALL_BASE+119)
  132. #define __NR_clone (__NR_SYSCALL_BASE+120)
  133. #define __NR_setdomainname (__NR_SYSCALL_BASE+121)
  134. #define __NR_uname (__NR_SYSCALL_BASE+122)
  135. #define __NR_modify_ldt (__NR_SYSCALL_BASE+123)
  136. #define __NR_adjtimex (__NR_SYSCALL_BASE+124)
  137. #define __NR_mprotect (__NR_SYSCALL_BASE+125)
  138. #define __NR_sigprocmask (__NR_SYSCALL_BASE+126)
  139. #define __NR_create_module (__NR_SYSCALL_BASE+127)
  140. #define __NR_init_module (__NR_SYSCALL_BASE+128)
  141. #define __NR_delete_module (__NR_SYSCALL_BASE+129)
  142. #define __NR_get_kernel_syms (__NR_SYSCALL_BASE+130)
  143. #define __NR_quotactl (__NR_SYSCALL_BASE+131)
  144. #define __NR_getpgid (__NR_SYSCALL_BASE+132)
  145. #define __NR_fchdir (__NR_SYSCALL_BASE+133)
  146. #define __NR_bdflush (__NR_SYSCALL_BASE+134)
  147. #define __NR_sysfs (__NR_SYSCALL_BASE+135)
  148. #define __NR_personality (__NR_SYSCALL_BASE+136)
  149. #define __NR_afs_syscall (__NR_SYSCALL_BASE+137) /* Syscall for Andrew File System */
  150. #define __NR_setfsuid (__NR_SYSCALL_BASE+138)
  151. #define __NR_setfsgid (__NR_SYSCALL_BASE+139)
  152. #define __NR__llseek (__NR_SYSCALL_BASE+140)
  153. #define __NR_getdents (__NR_SYSCALL_BASE+141)
  154. #define __NR__newselect (__NR_SYSCALL_BASE+142)
  155. #define __NR_flock (__NR_SYSCALL_BASE+143)
  156. #define __NR_msync (__NR_SYSCALL_BASE+144)
  157. #define __NR_readv (__NR_SYSCALL_BASE+145)
  158. #define __NR_writev (__NR_SYSCALL_BASE+146)
  159. #define __NR_getsid (__NR_SYSCALL_BASE+147)
  160. #define __NR_fdatasync (__NR_SYSCALL_BASE+148)
  161. #define __NR__sysctl (__NR_SYSCALL_BASE+149)
  162. #define __NR_mlock (__NR_SYSCALL_BASE+150)
  163. #define __NR_munlock (__NR_SYSCALL_BASE+151)
  164. #define __NR_mlockall (__NR_SYSCALL_BASE+152)
  165. #define __NR_munlockall (__NR_SYSCALL_BASE+153)
  166. #define __NR_sched_setparam (__NR_SYSCALL_BASE+154)
  167. #define __NR_sched_getparam (__NR_SYSCALL_BASE+155)
  168. #define __NR_sched_setscheduler (__NR_SYSCALL_BASE+156)
  169. #define __NR_sched_getscheduler (__NR_SYSCALL_BASE+157)
  170. #define __NR_sched_yield (__NR_SYSCALL_BASE+158)
  171. #define __NR_sched_get_priority_max (__NR_SYSCALL_BASE+159)
  172. #define __NR_sched_get_priority_min (__NR_SYSCALL_BASE+160)
  173. #define __NR_sched_rr_get_interval (__NR_SYSCALL_BASE+161)
  174. #define __NR_nanosleep (__NR_SYSCALL_BASE+162)
  175. #define __NR_mremap (__NR_SYSCALL_BASE+163)
  176. #define __NR_setresuid (__NR_SYSCALL_BASE+164)
  177. #define __NR_getresuid (__NR_SYSCALL_BASE+165)
  178. #define __NR_vm86 (__NR_SYSCALL_BASE+166)
  179. #define __NR_query_module (__NR_SYSCALL_BASE+167)
  180. #define __NR_poll (__NR_SYSCALL_BASE+168)
  181. #define __NR_nfsservctl (__NR_SYSCALL_BASE+169)
  182. #define __NR_setresgid (__NR_SYSCALL_BASE+170)
  183. #define __NR_getresgid (__NR_SYSCALL_BASE+171)
  184. #define __NR_prctl (__NR_SYSCALL_BASE+172)
  185. #define __NR_rt_sigreturn (__NR_SYSCALL_BASE+173)
  186. #define __NR_rt_sigaction (__NR_SYSCALL_BASE+174)
  187. #define __NR_rt_sigprocmask (__NR_SYSCALL_BASE+175)
  188. #define __NR_rt_sigpending (__NR_SYSCALL_BASE+176)
  189. #define __NR_rt_sigtimedwait (__NR_SYSCALL_BASE+177)
  190. #define __NR_rt_sigqueueinfo (__NR_SYSCALL_BASE+178)
  191. #define __NR_rt_sigsuspend (__NR_SYSCALL_BASE+179)
  192. #define __NR_pread (__NR_SYSCALL_BASE+180)
  193. #define __NR_pwrite (__NR_SYSCALL_BASE+181)
  194. #define __NR_chown (__NR_SYSCALL_BASE+182)
  195. #define __NR_getcwd (__NR_SYSCALL_BASE+183)
  196. #define __NR_capget (__NR_SYSCALL_BASE+184)
  197. #define __NR_capset (__NR_SYSCALL_BASE+185)
  198. #define __NR_sigaltstack (__NR_SYSCALL_BASE+186)
  199. #define __NR_sendfile (__NR_SYSCALL_BASE+187)
  200. /* 188 reserved */
  201. /* 189 reserved */
  202. #define __NR_vfork (__NR_SYSCALL_BASE+190)
  203. #define __NR_ugetrlimit (__NR_SYSCALL_BASE+191) /* SuS compliant getrlimit */
  204. #define __NR_mmap2 (__NR_SYSCALL_BASE+192)
  205. #define __NR_truncate64 (__NR_SYSCALL_BASE+193)
  206. #define __NR_ftruncate64 (__NR_SYSCALL_BASE+194)
  207. #define __NR_stat64 (__NR_SYSCALL_BASE+195)
  208. #define __NR_lstat64 (__NR_SYSCALL_BASE+196)
  209. #define __NR_fstat64 (__NR_SYSCALL_BASE+197)
  210. #define __NR_lchown32 (__NR_SYSCALL_BASE+198)
  211. #define __NR_getuid32 (__NR_SYSCALL_BASE+199)
  212. #define __NR_getgid32 (__NR_SYSCALL_BASE+200)
  213. #define __NR_geteuid32 (__NR_SYSCALL_BASE+201)
  214. #define __NR_getegid32 (__NR_SYSCALL_BASE+202)
  215. #define __NR_setreuid32 (__NR_SYSCALL_BASE+203)
  216. #define __NR_setregid32 (__NR_SYSCALL_BASE+204)
  217. #define __NR_getgroups32 (__NR_SYSCALL_BASE+205)
  218. #define __NR_setgroups32 (__NR_SYSCALL_BASE+206)
  219. #define __NR_fchown32 (__NR_SYSCALL_BASE+207)
  220. #define __NR_setresuid32 (__NR_SYSCALL_BASE+208)
  221. #define __NR_getresuid32 (__NR_SYSCALL_BASE+209)
  222. #define __NR_setresgid32 (__NR_SYSCALL_BASE+210)
  223. #define __NR_getresgid32 (__NR_SYSCALL_BASE+211)
  224. #define __NR_chown32 (__NR_SYSCALL_BASE+212)
  225. #define __NR_setuid32 (__NR_SYSCALL_BASE+213)
  226. #define __NR_setgid32 (__NR_SYSCALL_BASE+214)
  227. #define __NR_setfsuid32 (__NR_SYSCALL_BASE+215)
  228. #define __NR_setfsgid32 (__NR_SYSCALL_BASE+216)
  229. #define __NR_getdents64 (__NR_SYSCALL_BASE+217)
  230. #define __NR_pivot_root (__NR_SYSCALL_BASE+218)
  231. #define __NR_mincore (__NR_SYSCALL_BASE+219)
  232. #define __NR_madvise (__NR_SYSCALL_BASE+220)
  233. #define __NR_fcntl64 (__NR_SYSCALL_BASE+221)
  234. /* 222 for tux */
  235. #define __NR_security (__NR_SYSCALL_BASE+223)
  236. #define __NR_gettid (__NR_SYSCALL_BASE+224)
  237. #define __NR_readahead (__NR_SYSCALL_BASE+225)
  238. #if 0 /* allocated in 2.5 */
  239. #define __NR_setxattr (__NR_SYSCALL_BASE+226)
  240. #define __NR_lsetxattr (__NR_SYSCALL_BASE+227)
  241. #define __NR_fsetxattr (__NR_SYSCALL_BASE+228)
  242. #define __NR_getxattr (__NR_SYSCALL_BASE+229)
  243. #define __NR_lgetxattr (__NR_SYSCALL_BASE+230)
  244. #define __NR_fgetxattr (__NR_SYSCALL_BASE+231)
  245. #define __NR_listxattr (__NR_SYSCALL_BASE+232)
  246. #define __NR_llistxattr (__NR_SYSCALL_BASE+233)
  247. #define __NR_flistxattr (__NR_SYSCALL_BASE+234)
  248. #define __NR_removexattr (__NR_SYSCALL_BASE+235)
  249. #define __NR_lremovexattr (__NR_SYSCALL_BASE+236)
  250. #define __NR_fremovexattr (__NR_SYSCALL_BASE+237)
  251. #endif
  252. #define __NR_tkill (__NR_SYSCALL_BASE+238)
  253. /*
  254.  * Please check 2.5 _before_ adding calls here,
  255.  * and copy changes to rmk@arm.linux.org.uk.  Thanks.
  256.  */
  257. /*
  258.  * The following SWIs are ARM private.
  259.  */
  260. #define __ARM_NR_BASE (__NR_SYSCALL_BASE+0x0f0000)
  261. #define __ARM_NR_breakpoint (__ARM_NR_BASE+1)
  262. #define __ARM_NR_cacheflush (__ARM_NR_BASE+2)
  263. #define __ARM_NR_usr26 (__ARM_NR_BASE+3)
  264. #define __ARM_NR_usr32 (__ARM_NR_BASE+4)
  265. #define __sys2(x) #x
  266. #define __sys1(x) __sys2(x)
  267. #ifndef __syscall
  268. #define __syscall(name) "swit" __sys1(__NR_##name) "nt"
  269. #endif
  270. #define __syscall_return(type, res)
  271. do {
  272. if ((unsigned long)(res) >= (unsigned long)(-125)) {
  273. errno = -(res);
  274. res = -1;
  275. }
  276. return (type) (res);
  277. } while (0)
  278. #define _syscall0(type,name)
  279. type name(void) {
  280.   long __res;
  281.   __asm__ __volatile__ (
  282.   __syscall(name)
  283.   "mov %0,r0"
  284.   :"=r" (__res) : : "r0","lr");
  285.   __syscall_return(type,__res);
  286. }
  287. #define _syscall1(type,name,type1,arg1)
  288. type name(type1 arg1) {
  289.   long __res;
  290.   __asm__ __volatile__ (
  291.   "movtr0,%1nt"
  292.   __syscall(name)
  293.   "mov %0,r0"
  294.         : "=r" (__res)
  295.         : "r" ((long)(arg1))
  296. : "r0","lr");
  297.   __syscall_return(type,__res);
  298. }
  299. #define _syscall2(type,name,type1,arg1,type2,arg2)
  300. type name(type1 arg1,type2 arg2) {
  301.   long __res;
  302.   __asm__ __volatile__ (
  303.   "movtr0,%1nt"
  304.   "movtr1,%2nt"
  305.   __syscall(name)
  306.   "movt%0,r0"
  307.         : "=r" (__res)
  308.         : "r" ((long)(arg1)),"r" ((long)(arg2))
  309. : "r0","r1","lr");
  310.   __syscall_return(type,__res);
  311. }
  312. #define _syscall3(type,name,type1,arg1,type2,arg2,type3,arg3)
  313. type name(type1 arg1,type2 arg2,type3 arg3) {
  314.   long __res;
  315.   __asm__ __volatile__ (
  316.   "movtr0,%1nt"
  317.   "movtr1,%2nt"
  318.   "movtr2,%3nt"
  319.   __syscall(name)
  320.   "movt%0,r0"
  321.         : "=r" (__res)
  322.         : "r" ((long)(arg1)),"r" ((long)(arg2)),"r" ((long)(arg3))
  323.         : "r0","r1","r2","lr");
  324.   __syscall_return(type,__res);
  325. }
  326. #define _syscall4(type,name,type1,arg1,type2,arg2,type3,arg3,type4,arg4)
  327. type name(type1 arg1, type2 arg2, type3 arg3, type4 arg4) {
  328.   long __res;
  329.   __asm__ __volatile__ (
  330.   "movtr0,%1nt"
  331.   "movtr1,%2nt"
  332.   "movtr2,%3nt"
  333.   "movtr3,%4nt"
  334.   __syscall(name)
  335.   "movt%0,r0"
  336.    : "=r" (__res)
  337.    : "r" ((long)(arg1)),"r" ((long)(arg2)),"r" ((long)(arg3)),"r" ((long)(arg4))
  338.    : "r0","r1","r2","r3","lr");
  339.   __syscall_return(type,__res);
  340. }
  341.   
  342. #define _syscall5(type,name,type1,arg1,type2,arg2,type3,arg3,type4,arg4,type5,arg5)
  343. type name(type1 arg1, type2 arg2, type3 arg3, type4 arg4, type5 arg5) {
  344.   long __res;
  345.   __asm__ __volatile__ (
  346.   "movtr0,%1nt"
  347.   "movtr1,%2nt"
  348.   "movtr2,%3nt"
  349.   "movtr3,%4nt"
  350.   "movtr4,%5nt"
  351.   __syscall(name)
  352.   "movt%0,r0"
  353.    : "=r" (__res)
  354.    : "r" ((long)(arg1)),"r" ((long)(arg2)),"r" ((long)(arg3)),"r" ((long)(arg4)),
  355.   "r" ((long)(arg5))
  356. : "r0","r1","r2","r3","r4","lr");
  357.   __syscall_return(type,__res);
  358. }
  359. #ifdef __KERNEL_SYSCALLS__
  360. static inline long idle(void)
  361. {
  362. extern long sys_idle(void);
  363. return sys_idle();
  364. }
  365. static inline long pause(void)
  366. {
  367. extern long sys_pause(void);
  368. return sys_pause();
  369. }
  370. static inline long sync(void)
  371. {
  372. extern long sys_sync(void);
  373. return sys_sync();
  374. }
  375. static inline pid_t setsid(void)
  376. {
  377. extern long sys_setsid(void);
  378. return sys_setsid();
  379. }
  380. static inline long write(int fd, const char *buf, off_t count)
  381. {
  382. extern long sys_write(int, const char *, int);
  383. return sys_write(fd, buf, count);
  384. }
  385. static inline long read(int fd, char *buf, off_t count)
  386. {
  387. extern long sys_read(int, char *, int);
  388. return sys_read(fd, buf, count);
  389. }
  390. static inline off_t lseek(int fd, off_t offset, int count)
  391. {
  392. extern off_t sys_lseek(int, off_t, int);
  393. return sys_lseek(fd, offset, count);
  394. }
  395. static inline long dup(int fd)
  396. {
  397. extern long sys_dup(int);
  398. return sys_dup(fd);
  399. }
  400. static inline long open(const char *file, int flag, int mode)
  401. {
  402. extern long sys_open(const char *, int, int);
  403. return sys_open(file, flag, mode);
  404. }
  405. static inline long close(int fd)
  406. {
  407. extern long sys_close(unsigned int);
  408. return sys_close(fd);
  409. }
  410. static inline long _exit(int exitcode)
  411. {
  412. extern long sys_exit(int) __attribute__((noreturn));
  413. return sys_exit(exitcode);
  414. }
  415. static inline pid_t waitpid(pid_t pid, int *wait_stat, int options)
  416. {
  417. return sys_wait4((int)pid, wait_stat, options, NULL);
  418. }
  419. static inline long delete_module(const char *name)
  420. {
  421. extern long sys_delete_module(const char *name);
  422. return sys_delete_module(name);
  423. }
  424. static inline pid_t wait(int * wait_stat)
  425. {
  426. return sys_wait4(-1, wait_stat, 0, NULL);
  427. }
  428. /*
  429.  * The following two can't be eliminated yet - they rely on
  430.  * specific conditions.
  431.  */
  432. static inline _syscall3(int,execve,const char *,file,char **,argv,char **,envp);
  433. #endif
  434. #endif /* __ASM_ARM_UNISTD_H */