ia32entry.S 22 KB

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