ia32entry.S 19 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744
  1. /*
  2. * Compatibility mode system call entry point for x86-64.
  3. *
  4. * Copyright 2000-2002 Andi Kleen, SuSE Labs.
  5. */
  6. #include <asm/dwarf2.h>
  7. #include <asm/calling.h>
  8. #include <asm/asm-offsets.h>
  9. #include <asm/current.h>
  10. #include <asm/errno.h>
  11. #include <asm/ia32_unistd.h>
  12. #include <asm/thread_info.h>
  13. #include <asm/segment.h>
  14. #include <asm/irqflags.h>
  15. #include <linux/linkage.h>
  16. #define IA32_NR_syscalls ((ia32_syscall_end - ia32_sys_call_table)/8)
  17. .macro IA32_ARG_FIXUP noebp=0
  18. movl %edi,%r8d
  19. .if \noebp
  20. .else
  21. movl %ebp,%r9d
  22. .endif
  23. xchg %ecx,%esi
  24. movl %ebx,%edi
  25. movl %edx,%edx /* zero extension */
  26. .endm
  27. /* clobbers %eax */
  28. .macro CLEAR_RREGS
  29. xorl %eax,%eax
  30. movq %rax,R11(%rsp)
  31. movq %rax,R10(%rsp)
  32. movq %rax,R9(%rsp)
  33. movq %rax,R8(%rsp)
  34. .endm
  35. .macro LOAD_ARGS32 offset
  36. movl \offset(%rsp),%r11d
  37. movl \offset+8(%rsp),%r10d
  38. movl \offset+16(%rsp),%r9d
  39. movl \offset+24(%rsp),%r8d
  40. movl \offset+40(%rsp),%ecx
  41. movl \offset+48(%rsp),%edx
  42. movl \offset+56(%rsp),%esi
  43. movl \offset+64(%rsp),%edi
  44. movl \offset+72(%rsp),%eax
  45. .endm
  46. .macro CFI_STARTPROC32 simple
  47. CFI_STARTPROC \simple
  48. CFI_UNDEFINED r8
  49. CFI_UNDEFINED r9
  50. CFI_UNDEFINED r10
  51. CFI_UNDEFINED r11
  52. CFI_UNDEFINED r12
  53. CFI_UNDEFINED r13
  54. CFI_UNDEFINED r14
  55. CFI_UNDEFINED r15
  56. .endm
  57. #ifdef CONFIG_PARAVIRT
  58. ENTRY(native_usergs_sysret32)
  59. swapgs
  60. sysretl
  61. ENDPROC(native_usergs_sysret32)
  62. ENTRY(native_irq_enable_sysexit)
  63. swapgs
  64. sti
  65. sysexit
  66. ENDPROC(native_irq_enable_sysexit)
  67. #endif
  68. /*
  69. * 32bit SYSENTER instruction entry.
  70. *
  71. * Arguments:
  72. * %eax System call number.
  73. * %ebx Arg1
  74. * %ecx Arg2
  75. * %edx Arg3
  76. * %esi Arg4
  77. * %edi Arg5
  78. * %ebp user stack
  79. * 0(%ebp) Arg6
  80. *
  81. * Interrupts off.
  82. *
  83. * This is purely a fast path. For anything complicated we use the int 0x80
  84. * path below. Set up a complete hardware stack frame to share code
  85. * with the int 0x80 path.
  86. */
  87. ENTRY(ia32_sysenter_target)
  88. CFI_STARTPROC32 simple
  89. CFI_SIGNAL_FRAME
  90. CFI_DEF_CFA rsp,0
  91. CFI_REGISTER rsp,rbp
  92. SWAPGS_UNSAFE_STACK
  93. movq %gs:pda_kernelstack, %rsp
  94. addq $(PDA_STACKOFFSET),%rsp
  95. /*
  96. * No need to follow this irqs on/off section: the syscall
  97. * disabled irqs, here we enable it straight after entry:
  98. */
  99. ENABLE_INTERRUPTS(CLBR_NONE)
  100. movl %ebp,%ebp /* zero extension */
  101. pushq $__USER32_DS
  102. CFI_ADJUST_CFA_OFFSET 8
  103. /*CFI_REL_OFFSET ss,0*/
  104. pushq %rbp
  105. CFI_ADJUST_CFA_OFFSET 8
  106. CFI_REL_OFFSET rsp,0
  107. pushfq
  108. CFI_ADJUST_CFA_OFFSET 8
  109. /*CFI_REL_OFFSET rflags,0*/
  110. movl 8*3-THREAD_SIZE+TI_sysenter_return(%rsp), %r10d
  111. CFI_REGISTER rip,r10
  112. pushq $__USER32_CS
  113. CFI_ADJUST_CFA_OFFSET 8
  114. /*CFI_REL_OFFSET cs,0*/
  115. movl %eax, %eax
  116. pushq %r10
  117. CFI_ADJUST_CFA_OFFSET 8
  118. CFI_REL_OFFSET rip,0
  119. pushq %rax
  120. CFI_ADJUST_CFA_OFFSET 8
  121. cld
  122. SAVE_ARGS 0,0,1
  123. /* no need to do an access_ok check here because rbp has been
  124. 32bit zero extended */
  125. 1: movl (%rbp),%r9d
  126. .section __ex_table,"a"
  127. .quad 1b,ia32_badarg
  128. .previous
  129. GET_THREAD_INFO(%r10)
  130. orl $TS_COMPAT,TI_status(%r10)
  131. testl $(_TIF_SYSCALL_TRACE|_TIF_SYSCALL_AUDIT|_TIF_SECCOMP), \
  132. TI_flags(%r10)
  133. CFI_REMEMBER_STATE
  134. jnz sysenter_tracesys
  135. sysenter_do_call:
  136. cmpl $(IA32_NR_syscalls-1),%eax
  137. ja ia32_badsys
  138. IA32_ARG_FIXUP 1
  139. call *ia32_sys_call_table(,%rax,8)
  140. movq %rax,RAX-ARGOFFSET(%rsp)
  141. GET_THREAD_INFO(%r10)
  142. DISABLE_INTERRUPTS(CLBR_NONE)
  143. TRACE_IRQS_OFF
  144. testl $_TIF_ALLWORK_MASK,TI_flags(%r10)
  145. jnz int_ret_from_sys_call
  146. andl $~TS_COMPAT,TI_status(%r10)
  147. /* clear IF, that popfq doesn't enable interrupts early */
  148. andl $~0x200,EFLAGS-R11(%rsp)
  149. movl RIP-R11(%rsp),%edx /* User %eip */
  150. CFI_REGISTER rip,rdx
  151. RESTORE_ARGS 1,24,1,1,1,1
  152. popfq
  153. CFI_ADJUST_CFA_OFFSET -8
  154. /*CFI_RESTORE rflags*/
  155. popq %rcx /* User %esp */
  156. CFI_ADJUST_CFA_OFFSET -8
  157. CFI_REGISTER rsp,rcx
  158. TRACE_IRQS_ON
  159. ENABLE_INTERRUPTS_SYSEXIT32
  160. sysenter_tracesys:
  161. CFI_RESTORE_STATE
  162. xchgl %r9d,%ebp
  163. SAVE_REST
  164. CLEAR_RREGS
  165. movq %r9,R9(%rsp)
  166. movq $-ENOSYS,RAX(%rsp)/* ptrace can change this for a bad syscall */
  167. movq %rsp,%rdi /* &pt_regs -> arg1 */
  168. call syscall_trace_enter
  169. LOAD_ARGS32 ARGOFFSET /* reload args from stack in case ptrace changed it */
  170. RESTORE_REST
  171. xchgl %ebp,%r9d
  172. cmpl $(IA32_NR_syscalls-1),%eax
  173. ja int_ret_from_sys_call /* sysenter_tracesys has set RAX(%rsp) */
  174. jmp sysenter_do_call
  175. CFI_ENDPROC
  176. ENDPROC(ia32_sysenter_target)
  177. /*
  178. * 32bit SYSCALL instruction entry.
  179. *
  180. * Arguments:
  181. * %eax System call number.
  182. * %ebx Arg1
  183. * %ecx return EIP
  184. * %edx Arg3
  185. * %esi Arg4
  186. * %edi Arg5
  187. * %ebp Arg2 [note: not saved in the stack frame, should not be touched]
  188. * %esp user stack
  189. * 0(%esp) Arg6
  190. *
  191. * Interrupts off.
  192. *
  193. * This is purely a fast path. For anything complicated we use the int 0x80
  194. * path below. Set up a complete hardware stack frame to share code
  195. * with the int 0x80 path.
  196. */
  197. ENTRY(ia32_cstar_target)
  198. CFI_STARTPROC32 simple
  199. CFI_SIGNAL_FRAME
  200. CFI_DEF_CFA rsp,PDA_STACKOFFSET
  201. CFI_REGISTER rip,rcx
  202. /*CFI_REGISTER rflags,r11*/
  203. SWAPGS_UNSAFE_STACK
  204. movl %esp,%r8d
  205. CFI_REGISTER rsp,r8
  206. movq %gs:pda_kernelstack,%rsp
  207. /*
  208. * No need to follow this irqs on/off section: the syscall
  209. * disabled irqs and here we enable it straight after entry:
  210. */
  211. ENABLE_INTERRUPTS(CLBR_NONE)
  212. SAVE_ARGS 8,1,1
  213. movl %eax,%eax /* zero extension */
  214. movq %rax,ORIG_RAX-ARGOFFSET(%rsp)
  215. movq %rcx,RIP-ARGOFFSET(%rsp)
  216. CFI_REL_OFFSET rip,RIP-ARGOFFSET
  217. movq %rbp,RCX-ARGOFFSET(%rsp) /* this lies slightly to ptrace */
  218. movl %ebp,%ecx
  219. movq $__USER32_CS,CS-ARGOFFSET(%rsp)
  220. movq $__USER32_DS,SS-ARGOFFSET(%rsp)
  221. movq %r11,EFLAGS-ARGOFFSET(%rsp)
  222. /*CFI_REL_OFFSET rflags,EFLAGS-ARGOFFSET*/
  223. movq %r8,RSP-ARGOFFSET(%rsp)
  224. CFI_REL_OFFSET rsp,RSP-ARGOFFSET
  225. /* no need to do an access_ok check here because r8 has been
  226. 32bit zero extended */
  227. /* hardware stack frame is complete now */
  228. 1: movl (%r8),%r9d
  229. .section __ex_table,"a"
  230. .quad 1b,ia32_badarg
  231. .previous
  232. GET_THREAD_INFO(%r10)
  233. orl $TS_COMPAT,TI_status(%r10)
  234. testl $(_TIF_SYSCALL_TRACE|_TIF_SYSCALL_AUDIT|_TIF_SECCOMP), \
  235. TI_flags(%r10)
  236. CFI_REMEMBER_STATE
  237. jnz cstar_tracesys
  238. cstar_do_call:
  239. cmpl $IA32_NR_syscalls-1,%eax
  240. ja ia32_badsys
  241. IA32_ARG_FIXUP 1
  242. call *ia32_sys_call_table(,%rax,8)
  243. movq %rax,RAX-ARGOFFSET(%rsp)
  244. GET_THREAD_INFO(%r10)
  245. DISABLE_INTERRUPTS(CLBR_NONE)
  246. TRACE_IRQS_OFF
  247. testl $_TIF_ALLWORK_MASK,TI_flags(%r10)
  248. jnz int_ret_from_sys_call
  249. andl $~TS_COMPAT,TI_status(%r10)
  250. RESTORE_ARGS 1,-ARG_SKIP,1,1,1
  251. movl RIP-ARGOFFSET(%rsp),%ecx
  252. CFI_REGISTER rip,rcx
  253. movl EFLAGS-ARGOFFSET(%rsp),%r11d
  254. /*CFI_REGISTER rflags,r11*/
  255. TRACE_IRQS_ON
  256. movl RSP-ARGOFFSET(%rsp),%esp
  257. CFI_RESTORE rsp
  258. USERGS_SYSRET32
  259. cstar_tracesys:
  260. CFI_RESTORE_STATE
  261. xchgl %r9d,%ebp
  262. SAVE_REST
  263. CLEAR_RREGS
  264. movq %r9,R9(%rsp)
  265. movq $-ENOSYS,RAX(%rsp) /* ptrace can change this for a bad syscall */
  266. movq %rsp,%rdi /* &pt_regs -> arg1 */
  267. call syscall_trace_enter
  268. LOAD_ARGS32 ARGOFFSET /* reload args from stack in case ptrace changed it */
  269. RESTORE_REST
  270. xchgl %ebp,%r9d
  271. movl RSP-ARGOFFSET(%rsp), %r8d
  272. cmpl $(IA32_NR_syscalls-1),%eax
  273. ja int_ret_from_sys_call /* cstar_tracesys has set RAX(%rsp) */
  274. jmp cstar_do_call
  275. END(ia32_cstar_target)
  276. ia32_badarg:
  277. movq $-EFAULT,%rax
  278. jmp ia32_sysret
  279. CFI_ENDPROC
  280. /*
  281. * Emulated IA32 system calls via int 0x80.
  282. *
  283. * Arguments:
  284. * %eax System call number.
  285. * %ebx Arg1
  286. * %ecx Arg2
  287. * %edx Arg3
  288. * %esi Arg4
  289. * %edi Arg5
  290. * %ebp Arg6 [note: not saved in the stack frame, should not be touched]
  291. *
  292. * Notes:
  293. * Uses the same stack frame as the x86-64 version.
  294. * All registers except %eax must be saved (but ptrace may violate that)
  295. * Arguments are zero extended. For system calls that want sign extension and
  296. * take long arguments a wrapper is needed. Most calls can just be called
  297. * directly.
  298. * Assumes it is only called from user space and entered with interrupts off.
  299. */
  300. ENTRY(ia32_syscall)
  301. CFI_STARTPROC32 simple
  302. CFI_SIGNAL_FRAME
  303. CFI_DEF_CFA rsp,SS+8-RIP
  304. /*CFI_REL_OFFSET ss,SS-RIP*/
  305. CFI_REL_OFFSET rsp,RSP-RIP
  306. /*CFI_REL_OFFSET rflags,EFLAGS-RIP*/
  307. /*CFI_REL_OFFSET cs,CS-RIP*/
  308. CFI_REL_OFFSET rip,RIP-RIP
  309. SWAPGS
  310. /*
  311. * No need to follow this irqs on/off section: the syscall
  312. * disabled irqs and here we enable it straight after entry:
  313. */
  314. ENABLE_INTERRUPTS(CLBR_NONE)
  315. movl %eax,%eax
  316. pushq %rax
  317. CFI_ADJUST_CFA_OFFSET 8
  318. cld
  319. /* note the registers are not zero extended to the sf.
  320. this could be a problem. */
  321. SAVE_ARGS 0,0,1
  322. GET_THREAD_INFO(%r10)
  323. orl $TS_COMPAT,TI_status(%r10)
  324. testl $(_TIF_SYSCALL_TRACE|_TIF_SYSCALL_AUDIT|_TIF_SECCOMP), \
  325. TI_flags(%r10)
  326. jnz ia32_tracesys
  327. ia32_do_syscall:
  328. cmpl $(IA32_NR_syscalls-1),%eax
  329. ja int_ret_from_sys_call /* ia32_tracesys has set RAX(%rsp) */
  330. IA32_ARG_FIXUP
  331. call *ia32_sys_call_table(,%rax,8) # xxx: rip relative
  332. ia32_sysret:
  333. movq %rax,RAX-ARGOFFSET(%rsp)
  334. jmp int_ret_from_sys_call
  335. ia32_tracesys:
  336. SAVE_REST
  337. CLEAR_RREGS
  338. movq $-ENOSYS,RAX(%rsp) /* ptrace can change this for a bad syscall */
  339. movq %rsp,%rdi /* &pt_regs -> arg1 */
  340. call syscall_trace_enter
  341. LOAD_ARGS32 ARGOFFSET /* reload args from stack in case ptrace changed it */
  342. RESTORE_REST
  343. jmp ia32_do_syscall
  344. END(ia32_syscall)
  345. ia32_badsys:
  346. movq $0,ORIG_RAX-ARGOFFSET(%rsp)
  347. movq $-ENOSYS,RAX-ARGOFFSET(%rsp)
  348. jmp int_ret_from_sys_call
  349. quiet_ni_syscall:
  350. movq $-ENOSYS,%rax
  351. ret
  352. CFI_ENDPROC
  353. .macro PTREGSCALL label, func, arg
  354. .globl \label
  355. \label:
  356. leaq \func(%rip),%rax
  357. leaq -ARGOFFSET+8(%rsp),\arg /* 8 for return address */
  358. jmp ia32_ptregs_common
  359. .endm
  360. CFI_STARTPROC32
  361. PTREGSCALL stub32_rt_sigreturn, sys32_rt_sigreturn, %rdi
  362. PTREGSCALL stub32_sigreturn, sys32_sigreturn, %rdi
  363. PTREGSCALL stub32_sigaltstack, sys32_sigaltstack, %rdx
  364. PTREGSCALL stub32_execve, sys32_execve, %rcx
  365. PTREGSCALL stub32_fork, sys_fork, %rdi
  366. PTREGSCALL stub32_clone, sys32_clone, %rdx
  367. PTREGSCALL stub32_vfork, sys_vfork, %rdi
  368. PTREGSCALL stub32_iopl, sys_iopl, %rsi
  369. ENTRY(ia32_ptregs_common)
  370. popq %r11
  371. CFI_ENDPROC
  372. CFI_STARTPROC32 simple
  373. CFI_SIGNAL_FRAME
  374. CFI_DEF_CFA rsp,SS+8-ARGOFFSET
  375. CFI_REL_OFFSET rax,RAX-ARGOFFSET
  376. CFI_REL_OFFSET rcx,RCX-ARGOFFSET
  377. CFI_REL_OFFSET rdx,RDX-ARGOFFSET
  378. CFI_REL_OFFSET rsi,RSI-ARGOFFSET
  379. CFI_REL_OFFSET rdi,RDI-ARGOFFSET
  380. CFI_REL_OFFSET rip,RIP-ARGOFFSET
  381. /* CFI_REL_OFFSET cs,CS-ARGOFFSET*/
  382. /* CFI_REL_OFFSET rflags,EFLAGS-ARGOFFSET*/
  383. CFI_REL_OFFSET rsp,RSP-ARGOFFSET
  384. /* CFI_REL_OFFSET ss,SS-ARGOFFSET*/
  385. SAVE_REST
  386. call *%rax
  387. RESTORE_REST
  388. jmp ia32_sysret /* misbalances the return cache */
  389. CFI_ENDPROC
  390. END(ia32_ptregs_common)
  391. .section .rodata,"a"
  392. .align 8
  393. ia32_sys_call_table:
  394. .quad sys_restart_syscall
  395. .quad sys_exit
  396. .quad stub32_fork
  397. .quad sys_read
  398. .quad sys_write
  399. .quad compat_sys_open /* 5 */
  400. .quad sys_close
  401. .quad sys32_waitpid
  402. .quad sys_creat
  403. .quad sys_link
  404. .quad sys_unlink /* 10 */
  405. .quad stub32_execve
  406. .quad sys_chdir
  407. .quad compat_sys_time
  408. .quad sys_mknod
  409. .quad sys_chmod /* 15 */
  410. .quad sys_lchown16
  411. .quad quiet_ni_syscall /* old break syscall holder */
  412. .quad sys_stat
  413. .quad sys32_lseek
  414. .quad sys_getpid /* 20 */
  415. .quad compat_sys_mount /* mount */
  416. .quad sys_oldumount /* old_umount */
  417. .quad sys_setuid16
  418. .quad sys_getuid16
  419. .quad compat_sys_stime /* stime */ /* 25 */
  420. .quad compat_sys_ptrace /* ptrace */
  421. .quad sys_alarm
  422. .quad sys_fstat /* (old)fstat */
  423. .quad sys_pause
  424. .quad compat_sys_utime /* 30 */
  425. .quad quiet_ni_syscall /* old stty syscall holder */
  426. .quad quiet_ni_syscall /* old gtty syscall holder */
  427. .quad sys_access
  428. .quad sys_nice
  429. .quad quiet_ni_syscall /* 35 */ /* old ftime syscall holder */
  430. .quad sys_sync
  431. .quad sys32_kill
  432. .quad sys_rename
  433. .quad sys_mkdir
  434. .quad sys_rmdir /* 40 */
  435. .quad sys_dup
  436. .quad sys32_pipe
  437. .quad compat_sys_times
  438. .quad quiet_ni_syscall /* old prof syscall holder */
  439. .quad sys_brk /* 45 */
  440. .quad sys_setgid16
  441. .quad sys_getgid16
  442. .quad sys_signal
  443. .quad sys_geteuid16
  444. .quad sys_getegid16 /* 50 */
  445. .quad sys_acct
  446. .quad sys_umount /* new_umount */
  447. .quad quiet_ni_syscall /* old lock syscall holder */
  448. .quad compat_sys_ioctl
  449. .quad compat_sys_fcntl64 /* 55 */
  450. .quad quiet_ni_syscall /* old mpx syscall holder */
  451. .quad sys_setpgid
  452. .quad quiet_ni_syscall /* old ulimit syscall holder */
  453. .quad sys32_olduname
  454. .quad sys_umask /* 60 */
  455. .quad sys_chroot
  456. .quad sys32_ustat
  457. .quad sys_dup2
  458. .quad sys_getppid
  459. .quad sys_getpgrp /* 65 */
  460. .quad sys_setsid
  461. .quad sys32_sigaction
  462. .quad sys_sgetmask
  463. .quad sys_ssetmask
  464. .quad sys_setreuid16 /* 70 */
  465. .quad sys_setregid16
  466. .quad sys32_sigsuspend
  467. .quad compat_sys_sigpending
  468. .quad sys_sethostname
  469. .quad compat_sys_setrlimit /* 75 */
  470. .quad compat_sys_old_getrlimit /* old_getrlimit */
  471. .quad compat_sys_getrusage
  472. .quad sys32_gettimeofday
  473. .quad sys32_settimeofday
  474. .quad sys_getgroups16 /* 80 */
  475. .quad sys_setgroups16
  476. .quad sys32_old_select
  477. .quad sys_symlink
  478. .quad sys_lstat
  479. .quad sys_readlink /* 85 */
  480. .quad sys_uselib
  481. .quad sys_swapon
  482. .quad sys_reboot
  483. .quad compat_sys_old_readdir
  484. .quad sys32_mmap /* 90 */
  485. .quad sys_munmap
  486. .quad sys_truncate
  487. .quad sys_ftruncate
  488. .quad sys_fchmod
  489. .quad sys_fchown16 /* 95 */
  490. .quad sys_getpriority
  491. .quad sys_setpriority
  492. .quad quiet_ni_syscall /* old profil syscall holder */
  493. .quad compat_sys_statfs
  494. .quad compat_sys_fstatfs /* 100 */
  495. .quad sys_ioperm
  496. .quad compat_sys_socketcall
  497. .quad sys_syslog
  498. .quad compat_sys_setitimer
  499. .quad compat_sys_getitimer /* 105 */
  500. .quad compat_sys_newstat
  501. .quad compat_sys_newlstat
  502. .quad compat_sys_newfstat
  503. .quad sys32_uname
  504. .quad stub32_iopl /* 110 */
  505. .quad sys_vhangup
  506. .quad quiet_ni_syscall /* old "idle" system call */
  507. .quad sys32_vm86_warning /* vm86old */
  508. .quad compat_sys_wait4
  509. .quad sys_swapoff /* 115 */
  510. .quad compat_sys_sysinfo
  511. .quad sys32_ipc
  512. .quad sys_fsync
  513. .quad stub32_sigreturn
  514. .quad stub32_clone /* 120 */
  515. .quad sys_setdomainname
  516. .quad sys_uname
  517. .quad sys_modify_ldt
  518. .quad compat_sys_adjtimex
  519. .quad sys32_mprotect /* 125 */
  520. .quad compat_sys_sigprocmask
  521. .quad quiet_ni_syscall /* create_module */
  522. .quad sys_init_module
  523. .quad sys_delete_module
  524. .quad quiet_ni_syscall /* 130 get_kernel_syms */
  525. .quad sys32_quotactl
  526. .quad sys_getpgid
  527. .quad sys_fchdir
  528. .quad quiet_ni_syscall /* bdflush */
  529. .quad sys_sysfs /* 135 */
  530. .quad sys_personality
  531. .quad quiet_ni_syscall /* for afs_syscall */
  532. .quad sys_setfsuid16
  533. .quad sys_setfsgid16
  534. .quad sys_llseek /* 140 */
  535. .quad compat_sys_getdents
  536. .quad compat_sys_select
  537. .quad sys_flock
  538. .quad sys_msync
  539. .quad compat_sys_readv /* 145 */
  540. .quad compat_sys_writev
  541. .quad sys_getsid
  542. .quad sys_fdatasync
  543. .quad sys32_sysctl /* sysctl */
  544. .quad sys_mlock /* 150 */
  545. .quad sys_munlock
  546. .quad sys_mlockall
  547. .quad sys_munlockall
  548. .quad sys_sched_setparam
  549. .quad sys_sched_getparam /* 155 */
  550. .quad sys_sched_setscheduler
  551. .quad sys_sched_getscheduler
  552. .quad sys_sched_yield
  553. .quad sys_sched_get_priority_max
  554. .quad sys_sched_get_priority_min /* 160 */
  555. .quad sys32_sched_rr_get_interval
  556. .quad compat_sys_nanosleep
  557. .quad sys_mremap
  558. .quad sys_setresuid16
  559. .quad sys_getresuid16 /* 165 */
  560. .quad sys32_vm86_warning /* vm86 */
  561. .quad quiet_ni_syscall /* query_module */
  562. .quad sys_poll
  563. .quad compat_sys_nfsservctl
  564. .quad sys_setresgid16 /* 170 */
  565. .quad sys_getresgid16
  566. .quad sys_prctl
  567. .quad stub32_rt_sigreturn
  568. .quad sys32_rt_sigaction
  569. .quad sys32_rt_sigprocmask /* 175 */
  570. .quad sys32_rt_sigpending
  571. .quad compat_sys_rt_sigtimedwait
  572. .quad sys32_rt_sigqueueinfo
  573. .quad sys_rt_sigsuspend
  574. .quad sys32_pread /* 180 */
  575. .quad sys32_pwrite
  576. .quad sys_chown16
  577. .quad sys_getcwd
  578. .quad sys_capget
  579. .quad sys_capset
  580. .quad stub32_sigaltstack
  581. .quad sys32_sendfile
  582. .quad quiet_ni_syscall /* streams1 */
  583. .quad quiet_ni_syscall /* streams2 */
  584. .quad stub32_vfork /* 190 */
  585. .quad compat_sys_getrlimit
  586. .quad sys32_mmap2
  587. .quad sys32_truncate64
  588. .quad sys32_ftruncate64
  589. .quad sys32_stat64 /* 195 */
  590. .quad sys32_lstat64
  591. .quad sys32_fstat64
  592. .quad sys_lchown
  593. .quad sys_getuid
  594. .quad sys_getgid /* 200 */
  595. .quad sys_geteuid
  596. .quad sys_getegid
  597. .quad sys_setreuid
  598. .quad sys_setregid
  599. .quad sys_getgroups /* 205 */
  600. .quad sys_setgroups
  601. .quad sys_fchown
  602. .quad sys_setresuid
  603. .quad sys_getresuid
  604. .quad sys_setresgid /* 210 */
  605. .quad sys_getresgid
  606. .quad sys_chown
  607. .quad sys_setuid
  608. .quad sys_setgid
  609. .quad sys_setfsuid /* 215 */
  610. .quad sys_setfsgid
  611. .quad sys_pivot_root
  612. .quad sys_mincore
  613. .quad sys_madvise
  614. .quad compat_sys_getdents64 /* 220 getdents64 */
  615. .quad compat_sys_fcntl64
  616. .quad quiet_ni_syscall /* tux */
  617. .quad quiet_ni_syscall /* security */
  618. .quad sys_gettid
  619. .quad sys32_readahead /* 225 */
  620. .quad sys_setxattr
  621. .quad sys_lsetxattr
  622. .quad sys_fsetxattr
  623. .quad sys_getxattr
  624. .quad sys_lgetxattr /* 230 */
  625. .quad sys_fgetxattr
  626. .quad sys_listxattr
  627. .quad sys_llistxattr
  628. .quad sys_flistxattr
  629. .quad sys_removexattr /* 235 */
  630. .quad sys_lremovexattr
  631. .quad sys_fremovexattr
  632. .quad sys_tkill
  633. .quad sys_sendfile64
  634. .quad compat_sys_futex /* 240 */
  635. .quad compat_sys_sched_setaffinity
  636. .quad compat_sys_sched_getaffinity
  637. .quad sys_set_thread_area
  638. .quad sys_get_thread_area
  639. .quad compat_sys_io_setup /* 245 */
  640. .quad sys_io_destroy
  641. .quad compat_sys_io_getevents
  642. .quad compat_sys_io_submit
  643. .quad sys_io_cancel
  644. .quad sys32_fadvise64 /* 250 */
  645. .quad quiet_ni_syscall /* free_huge_pages */
  646. .quad sys_exit_group
  647. .quad sys32_lookup_dcookie
  648. .quad sys_epoll_create
  649. .quad sys_epoll_ctl /* 255 */
  650. .quad sys_epoll_wait
  651. .quad sys_remap_file_pages
  652. .quad sys_set_tid_address
  653. .quad compat_sys_timer_create
  654. .quad compat_sys_timer_settime /* 260 */
  655. .quad compat_sys_timer_gettime
  656. .quad sys_timer_getoverrun
  657. .quad sys_timer_delete
  658. .quad compat_sys_clock_settime
  659. .quad compat_sys_clock_gettime /* 265 */
  660. .quad compat_sys_clock_getres
  661. .quad compat_sys_clock_nanosleep
  662. .quad compat_sys_statfs64
  663. .quad compat_sys_fstatfs64
  664. .quad sys_tgkill /* 270 */
  665. .quad compat_sys_utimes
  666. .quad sys32_fadvise64_64
  667. .quad quiet_ni_syscall /* sys_vserver */
  668. .quad sys_mbind
  669. .quad compat_sys_get_mempolicy /* 275 */
  670. .quad sys_set_mempolicy
  671. .quad compat_sys_mq_open
  672. .quad sys_mq_unlink
  673. .quad compat_sys_mq_timedsend
  674. .quad compat_sys_mq_timedreceive /* 280 */
  675. .quad compat_sys_mq_notify
  676. .quad compat_sys_mq_getsetattr
  677. .quad compat_sys_kexec_load /* reserved for kexec */
  678. .quad compat_sys_waitid
  679. .quad quiet_ni_syscall /* 285: sys_altroot */
  680. .quad sys_add_key
  681. .quad sys_request_key
  682. .quad sys_keyctl
  683. .quad sys_ioprio_set
  684. .quad sys_ioprio_get /* 290 */
  685. .quad sys_inotify_init
  686. .quad sys_inotify_add_watch
  687. .quad sys_inotify_rm_watch
  688. .quad sys_migrate_pages
  689. .quad compat_sys_openat /* 295 */
  690. .quad sys_mkdirat
  691. .quad sys_mknodat
  692. .quad sys_fchownat
  693. .quad compat_sys_futimesat
  694. .quad sys32_fstatat /* 300 */
  695. .quad sys_unlinkat
  696. .quad sys_renameat
  697. .quad sys_linkat
  698. .quad sys_symlinkat
  699. .quad sys_readlinkat /* 305 */
  700. .quad sys_fchmodat
  701. .quad sys_faccessat
  702. .quad compat_sys_pselect6
  703. .quad compat_sys_ppoll
  704. .quad sys_unshare /* 310 */
  705. .quad compat_sys_set_robust_list
  706. .quad compat_sys_get_robust_list
  707. .quad sys_splice
  708. .quad sys32_sync_file_range
  709. .quad sys_tee /* 315 */
  710. .quad compat_sys_vmsplice
  711. .quad compat_sys_move_pages
  712. .quad sys_getcpu
  713. .quad sys_epoll_pwait
  714. .quad compat_sys_utimensat /* 320 */
  715. .quad compat_sys_signalfd
  716. .quad sys_timerfd_create
  717. .quad sys_eventfd
  718. .quad sys32_fallocate
  719. .quad compat_sys_timerfd_settime /* 325 */
  720. .quad compat_sys_timerfd_gettime
  721. ia32_syscall_end: