ia32entry.S 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606
  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/offset.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/vsyscall32.h>
  15. #include <linux/linkage.h>
  16. .macro IA32_ARG_FIXUP noebp=0
  17. movl %edi,%r8d
  18. .if \noebp
  19. .else
  20. movl %ebp,%r9d
  21. .endif
  22. xchg %ecx,%esi
  23. movl %ebx,%edi
  24. movl %edx,%edx /* zero extension */
  25. .endm
  26. /* clobbers %eax */
  27. .macro CLEAR_RREGS
  28. xorl %eax,%eax
  29. movq %rax,R11(%rsp)
  30. movq %rax,R10(%rsp)
  31. movq %rax,R9(%rsp)
  32. movq %rax,R8(%rsp)
  33. .endm
  34. /*
  35. * 32bit SYSENTER instruction entry.
  36. *
  37. * Arguments:
  38. * %eax System call number.
  39. * %ebx Arg1
  40. * %ecx Arg2
  41. * %edx Arg3
  42. * %esi Arg4
  43. * %edi Arg5
  44. * %ebp user stack
  45. * 0(%ebp) Arg6
  46. *
  47. * Interrupts off.
  48. *
  49. * This is purely a fast path. For anything complicated we use the int 0x80
  50. * path below. Set up a complete hardware stack frame to share code
  51. * with the int 0x80 path.
  52. */
  53. ENTRY(ia32_sysenter_target)
  54. CFI_STARTPROC
  55. swapgs
  56. movq %gs:pda_kernelstack, %rsp
  57. addq $(PDA_STACKOFFSET),%rsp
  58. sti
  59. movl %ebp,%ebp /* zero extension */
  60. pushq $__USER32_DS
  61. pushq %rbp
  62. pushfq
  63. movl $VSYSCALL32_SYSEXIT, %r10d
  64. pushq $__USER32_CS
  65. movl %eax, %eax
  66. pushq %r10
  67. pushq %rax
  68. cld
  69. SAVE_ARGS 0,0,1
  70. /* no need to do an access_ok check here because rbp has been
  71. 32bit zero extended */
  72. 1: movl (%rbp),%r9d
  73. .section __ex_table,"a"
  74. .quad 1b,ia32_badarg
  75. .previous
  76. GET_THREAD_INFO(%r10)
  77. testl $(_TIF_SYSCALL_TRACE|_TIF_SYSCALL_AUDIT|_TIF_SECCOMP),threadinfo_flags(%r10)
  78. jnz sysenter_tracesys
  79. sysenter_do_call:
  80. cmpl $(IA32_NR_syscalls),%eax
  81. jae ia32_badsys
  82. IA32_ARG_FIXUP 1
  83. call *ia32_sys_call_table(,%rax,8)
  84. movq %rax,RAX-ARGOFFSET(%rsp)
  85. GET_THREAD_INFO(%r10)
  86. cli
  87. testl $_TIF_ALLWORK_MASK,threadinfo_flags(%r10)
  88. jnz int_ret_from_sys_call
  89. /* clear IF, that popfq doesn't enable interrupts early */
  90. andl $~0x200,EFLAGS-R11(%rsp)
  91. RESTORE_ARGS 1,24,1,1,1,1
  92. popfq
  93. popq %rcx /* User %esp */
  94. movl $VSYSCALL32_SYSEXIT,%edx /* User %eip */
  95. swapgs
  96. sti /* sti only takes effect after the next instruction */
  97. /* sysexit */
  98. .byte 0xf, 0x35
  99. sysenter_tracesys:
  100. SAVE_REST
  101. CLEAR_RREGS
  102. movq $-ENOSYS,RAX(%rsp) /* really needed? */
  103. movq %rsp,%rdi /* &pt_regs -> arg1 */
  104. call syscall_trace_enter
  105. LOAD_ARGS ARGOFFSET /* reload args from stack in case ptrace changed it */
  106. RESTORE_REST
  107. movl %ebp, %ebp
  108. /* no need to do an access_ok check here because rbp has been
  109. 32bit zero extended */
  110. 1: movl (%rbp),%r9d
  111. .section __ex_table,"a"
  112. .quad 1b,ia32_badarg
  113. .previous
  114. jmp sysenter_do_call
  115. CFI_ENDPROC
  116. /*
  117. * 32bit SYSCALL instruction entry.
  118. *
  119. * Arguments:
  120. * %eax System call number.
  121. * %ebx Arg1
  122. * %ecx return EIP
  123. * %edx Arg3
  124. * %esi Arg4
  125. * %edi Arg5
  126. * %ebp Arg2 [note: not saved in the stack frame, should not be touched]
  127. * %esp user stack
  128. * 0(%esp) Arg6
  129. *
  130. * Interrupts off.
  131. *
  132. * This is purely a fast path. For anything complicated we use the int 0x80
  133. * path below. Set up a complete hardware stack frame to share code
  134. * with the int 0x80 path.
  135. */
  136. ENTRY(ia32_cstar_target)
  137. CFI_STARTPROC
  138. swapgs
  139. movl %esp,%r8d
  140. movq %gs:pda_kernelstack,%rsp
  141. sti
  142. SAVE_ARGS 8,1,1
  143. movl %eax,%eax /* zero extension */
  144. movq %rax,ORIG_RAX-ARGOFFSET(%rsp)
  145. movq %rcx,RIP-ARGOFFSET(%rsp)
  146. movq %rbp,RCX-ARGOFFSET(%rsp) /* this lies slightly to ptrace */
  147. movl %ebp,%ecx
  148. movq $__USER32_CS,CS-ARGOFFSET(%rsp)
  149. movq $__USER32_DS,SS-ARGOFFSET(%rsp)
  150. movq %r11,EFLAGS-ARGOFFSET(%rsp)
  151. movq %r8,RSP-ARGOFFSET(%rsp)
  152. /* no need to do an access_ok check here because r8 has been
  153. 32bit zero extended */
  154. /* hardware stack frame is complete now */
  155. 1: movl (%r8),%r9d
  156. .section __ex_table,"a"
  157. .quad 1b,ia32_badarg
  158. .previous
  159. GET_THREAD_INFO(%r10)
  160. testl $(_TIF_SYSCALL_TRACE|_TIF_SYSCALL_AUDIT|_TIF_SECCOMP),threadinfo_flags(%r10)
  161. jnz cstar_tracesys
  162. cstar_do_call:
  163. cmpl $IA32_NR_syscalls,%eax
  164. jae ia32_badsys
  165. IA32_ARG_FIXUP 1
  166. call *ia32_sys_call_table(,%rax,8)
  167. movq %rax,RAX-ARGOFFSET(%rsp)
  168. GET_THREAD_INFO(%r10)
  169. cli
  170. testl $_TIF_ALLWORK_MASK,threadinfo_flags(%r10)
  171. jnz int_ret_from_sys_call
  172. RESTORE_ARGS 1,-ARG_SKIP,1,1,1
  173. movl RIP-ARGOFFSET(%rsp),%ecx
  174. movl EFLAGS-ARGOFFSET(%rsp),%r11d
  175. movl RSP-ARGOFFSET(%rsp),%esp
  176. swapgs
  177. sysretl
  178. cstar_tracesys:
  179. SAVE_REST
  180. CLEAR_RREGS
  181. movq $-ENOSYS,RAX(%rsp) /* really needed? */
  182. movq %rsp,%rdi /* &pt_regs -> arg1 */
  183. call syscall_trace_enter
  184. LOAD_ARGS ARGOFFSET /* reload args from stack in case ptrace changed it */
  185. RESTORE_REST
  186. movl RSP-ARGOFFSET(%rsp), %r8d
  187. /* no need to do an access_ok check here because r8 has been
  188. 32bit zero extended */
  189. 1: movl (%r8),%r9d
  190. .section __ex_table,"a"
  191. .quad 1b,ia32_badarg
  192. .previous
  193. jmp cstar_do_call
  194. ia32_badarg:
  195. movq $-EFAULT,%rax
  196. jmp ia32_sysret
  197. CFI_ENDPROC
  198. /*
  199. * Emulated IA32 system calls via int 0x80.
  200. *
  201. * Arguments:
  202. * %eax System call number.
  203. * %ebx Arg1
  204. * %ecx Arg2
  205. * %edx Arg3
  206. * %esi Arg4
  207. * %edi Arg5
  208. * %ebp Arg6 [note: not saved in the stack frame, should not be touched]
  209. *
  210. * Notes:
  211. * Uses the same stack frame as the x86-64 version.
  212. * All registers except %eax must be saved (but ptrace may violate that)
  213. * Arguments are zero extended. For system calls that want sign extension and
  214. * take long arguments a wrapper is needed. Most calls can just be called
  215. * directly.
  216. * Assumes it is only called from user space and entered with interrupts off.
  217. */
  218. ENTRY(ia32_syscall)
  219. CFI_STARTPROC
  220. swapgs
  221. sti
  222. movl %eax,%eax
  223. pushq %rax
  224. cld
  225. /* note the registers are not zero extended to the sf.
  226. this could be a problem. */
  227. SAVE_ARGS 0,0,1
  228. GET_THREAD_INFO(%r10)
  229. testl $(_TIF_SYSCALL_TRACE|_TIF_SYSCALL_AUDIT|_TIF_SECCOMP),threadinfo_flags(%r10)
  230. jnz ia32_tracesys
  231. ia32_do_syscall:
  232. cmpl $(IA32_NR_syscalls),%eax
  233. jae ia32_badsys
  234. IA32_ARG_FIXUP
  235. call *ia32_sys_call_table(,%rax,8) # xxx: rip relative
  236. ia32_sysret:
  237. movq %rax,RAX-ARGOFFSET(%rsp)
  238. jmp int_ret_from_sys_call
  239. ia32_tracesys:
  240. SAVE_REST
  241. movq $-ENOSYS,RAX(%rsp) /* really needed? */
  242. movq %rsp,%rdi /* &pt_regs -> arg1 */
  243. call syscall_trace_enter
  244. LOAD_ARGS ARGOFFSET /* reload args from stack in case ptrace changed it */
  245. RESTORE_REST
  246. jmp ia32_do_syscall
  247. ia32_badsys:
  248. movq $0,ORIG_RAX-ARGOFFSET(%rsp)
  249. movq $-ENOSYS,RAX-ARGOFFSET(%rsp)
  250. jmp int_ret_from_sys_call
  251. ni_syscall:
  252. movq %rax,%rdi
  253. jmp sys32_ni_syscall
  254. quiet_ni_syscall:
  255. movq $-ENOSYS,%rax
  256. ret
  257. CFI_ENDPROC
  258. .macro PTREGSCALL label, func, arg
  259. .globl \label
  260. \label:
  261. leaq \func(%rip),%rax
  262. leaq -ARGOFFSET+8(%rsp),\arg /* 8 for return address */
  263. jmp ia32_ptregs_common
  264. .endm
  265. PTREGSCALL stub32_rt_sigreturn, sys32_rt_sigreturn, %rdi
  266. PTREGSCALL stub32_sigreturn, sys32_sigreturn, %rdi
  267. PTREGSCALL stub32_sigaltstack, sys32_sigaltstack, %rdx
  268. PTREGSCALL stub32_sigsuspend, sys32_sigsuspend, %rcx
  269. PTREGSCALL stub32_execve, sys32_execve, %rcx
  270. PTREGSCALL stub32_fork, sys_fork, %rdi
  271. PTREGSCALL stub32_clone, sys32_clone, %rdx
  272. PTREGSCALL stub32_vfork, sys_vfork, %rdi
  273. PTREGSCALL stub32_iopl, sys_iopl, %rsi
  274. PTREGSCALL stub32_rt_sigsuspend, sys_rt_sigsuspend, %rdx
  275. ENTRY(ia32_ptregs_common)
  276. CFI_STARTPROC
  277. popq %r11
  278. SAVE_REST
  279. call *%rax
  280. RESTORE_REST
  281. jmp ia32_sysret /* misbalances the return cache */
  282. CFI_ENDPROC
  283. .data
  284. .align 8
  285. .globl ia32_sys_call_table
  286. ia32_sys_call_table:
  287. .quad sys_restart_syscall
  288. .quad sys_exit
  289. .quad stub32_fork
  290. .quad sys_read
  291. .quad sys_write
  292. .quad compat_sys_open /* 5 */
  293. .quad sys_close
  294. .quad sys32_waitpid
  295. .quad sys_creat
  296. .quad sys_link
  297. .quad sys_unlink /* 10 */
  298. .quad stub32_execve
  299. .quad sys_chdir
  300. .quad compat_sys_time
  301. .quad sys_mknod
  302. .quad sys_chmod /* 15 */
  303. .quad sys_lchown16
  304. .quad quiet_ni_syscall /* old break syscall holder */
  305. .quad sys_stat
  306. .quad sys32_lseek
  307. .quad sys_getpid /* 20 */
  308. .quad compat_sys_mount /* mount */
  309. .quad sys_oldumount /* old_umount */
  310. .quad sys_setuid16
  311. .quad sys_getuid16
  312. .quad compat_sys_stime /* stime */ /* 25 */
  313. .quad sys32_ptrace /* ptrace */
  314. .quad sys_alarm
  315. .quad sys_fstat /* (old)fstat */
  316. .quad sys_pause
  317. .quad compat_sys_utime /* 30 */
  318. .quad quiet_ni_syscall /* old stty syscall holder */
  319. .quad quiet_ni_syscall /* old gtty syscall holder */
  320. .quad sys_access
  321. .quad sys_nice
  322. .quad quiet_ni_syscall /* 35 */ /* old ftime syscall holder */
  323. .quad sys_sync
  324. .quad sys32_kill
  325. .quad sys_rename
  326. .quad sys_mkdir
  327. .quad sys_rmdir /* 40 */
  328. .quad sys_dup
  329. .quad sys32_pipe
  330. .quad compat_sys_times
  331. .quad quiet_ni_syscall /* old prof syscall holder */
  332. .quad sys_brk /* 45 */
  333. .quad sys_setgid16
  334. .quad sys_getgid16
  335. .quad sys_signal
  336. .quad sys_geteuid16
  337. .quad sys_getegid16 /* 50 */
  338. .quad sys_acct
  339. .quad sys_umount /* new_umount */
  340. .quad quiet_ni_syscall /* old lock syscall holder */
  341. .quad compat_sys_ioctl
  342. .quad compat_sys_fcntl64 /* 55 */
  343. .quad quiet_ni_syscall /* old mpx syscall holder */
  344. .quad sys_setpgid
  345. .quad quiet_ni_syscall /* old ulimit syscall holder */
  346. .quad sys32_olduname
  347. .quad sys_umask /* 60 */
  348. .quad sys_chroot
  349. .quad sys32_ustat
  350. .quad sys_dup2
  351. .quad sys_getppid
  352. .quad sys_getpgrp /* 65 */
  353. .quad sys_setsid
  354. .quad sys32_sigaction
  355. .quad sys_sgetmask
  356. .quad sys_ssetmask
  357. .quad sys_setreuid16 /* 70 */
  358. .quad sys_setregid16
  359. .quad stub32_sigsuspend
  360. .quad compat_sys_sigpending
  361. .quad sys_sethostname
  362. .quad compat_sys_setrlimit /* 75 */
  363. .quad compat_sys_old_getrlimit /* old_getrlimit */
  364. .quad compat_sys_getrusage
  365. .quad sys32_gettimeofday
  366. .quad sys32_settimeofday
  367. .quad sys_getgroups16 /* 80 */
  368. .quad sys_setgroups16
  369. .quad sys32_old_select
  370. .quad sys_symlink
  371. .quad sys_lstat
  372. .quad sys_readlink /* 85 */
  373. #ifdef CONFIG_IA32_AOUT
  374. .quad sys_uselib
  375. #else
  376. .quad quiet_ni_syscall
  377. #endif
  378. .quad sys_swapon
  379. .quad sys_reboot
  380. .quad compat_sys_old_readdir
  381. .quad sys32_mmap /* 90 */
  382. .quad sys_munmap
  383. .quad sys_truncate
  384. .quad sys_ftruncate
  385. .quad sys_fchmod
  386. .quad sys_fchown16 /* 95 */
  387. .quad sys_getpriority
  388. .quad sys_setpriority
  389. .quad quiet_ni_syscall /* old profil syscall holder */
  390. .quad compat_sys_statfs
  391. .quad compat_sys_fstatfs /* 100 */
  392. .quad sys_ioperm
  393. .quad compat_sys_socketcall
  394. .quad sys_syslog
  395. .quad compat_sys_setitimer
  396. .quad compat_sys_getitimer /* 105 */
  397. .quad compat_sys_newstat
  398. .quad compat_sys_newlstat
  399. .quad compat_sys_newfstat
  400. .quad sys32_uname
  401. .quad stub32_iopl /* 110 */
  402. .quad sys_vhangup
  403. .quad quiet_ni_syscall /* old "idle" system call */
  404. .quad sys32_vm86_warning /* vm86old */
  405. .quad compat_sys_wait4
  406. .quad sys_swapoff /* 115 */
  407. .quad sys32_sysinfo
  408. .quad sys32_ipc
  409. .quad sys_fsync
  410. .quad stub32_sigreturn
  411. .quad stub32_clone /* 120 */
  412. .quad sys_setdomainname
  413. .quad sys_uname
  414. .quad sys_modify_ldt
  415. .quad sys32_adjtimex
  416. .quad sys32_mprotect /* 125 */
  417. .quad compat_sys_sigprocmask
  418. .quad quiet_ni_syscall /* create_module */
  419. .quad sys_init_module
  420. .quad sys_delete_module
  421. .quad quiet_ni_syscall /* 130 get_kernel_syms */
  422. .quad sys_quotactl
  423. .quad sys_getpgid
  424. .quad sys_fchdir
  425. .quad quiet_ni_syscall /* bdflush */
  426. .quad sys_sysfs /* 135 */
  427. .quad sys_personality
  428. .quad quiet_ni_syscall /* for afs_syscall */
  429. .quad sys_setfsuid16
  430. .quad sys_setfsgid16
  431. .quad sys_llseek /* 140 */
  432. .quad compat_sys_getdents
  433. .quad compat_sys_select
  434. .quad sys_flock
  435. .quad sys_msync
  436. .quad compat_sys_readv /* 145 */
  437. .quad compat_sys_writev
  438. .quad sys_getsid
  439. .quad sys_fdatasync
  440. .quad sys32_sysctl /* sysctl */
  441. .quad sys_mlock /* 150 */
  442. .quad sys_munlock
  443. .quad sys_mlockall
  444. .quad sys_munlockall
  445. .quad sys_sched_setparam
  446. .quad sys_sched_getparam /* 155 */
  447. .quad sys_sched_setscheduler
  448. .quad sys_sched_getscheduler
  449. .quad sys_sched_yield
  450. .quad sys_sched_get_priority_max
  451. .quad sys_sched_get_priority_min /* 160 */
  452. .quad sys_sched_rr_get_interval
  453. .quad compat_sys_nanosleep
  454. .quad sys_mremap
  455. .quad sys_setresuid16
  456. .quad sys_getresuid16 /* 165 */
  457. .quad sys32_vm86_warning /* vm86 */
  458. .quad quiet_ni_syscall /* query_module */
  459. .quad sys_poll
  460. .quad compat_sys_nfsservctl
  461. .quad sys_setresgid16 /* 170 */
  462. .quad sys_getresgid16
  463. .quad sys_prctl
  464. .quad stub32_rt_sigreturn
  465. .quad sys32_rt_sigaction
  466. .quad sys32_rt_sigprocmask /* 175 */
  467. .quad sys32_rt_sigpending
  468. .quad compat_sys_rt_sigtimedwait
  469. .quad sys32_rt_sigqueueinfo
  470. .quad stub32_rt_sigsuspend
  471. .quad sys32_pread /* 180 */
  472. .quad sys32_pwrite
  473. .quad sys_chown16
  474. .quad sys_getcwd
  475. .quad sys_capget
  476. .quad sys_capset
  477. .quad stub32_sigaltstack
  478. .quad sys32_sendfile
  479. .quad quiet_ni_syscall /* streams1 */
  480. .quad quiet_ni_syscall /* streams2 */
  481. .quad stub32_vfork /* 190 */
  482. .quad compat_sys_getrlimit
  483. .quad sys32_mmap2
  484. .quad sys32_truncate64
  485. .quad sys32_ftruncate64
  486. .quad sys32_stat64 /* 195 */
  487. .quad sys32_lstat64
  488. .quad sys32_fstat64
  489. .quad sys_lchown
  490. .quad sys_getuid
  491. .quad sys_getgid /* 200 */
  492. .quad sys_geteuid
  493. .quad sys_getegid
  494. .quad sys_setreuid
  495. .quad sys_setregid
  496. .quad sys_getgroups /* 205 */
  497. .quad sys_setgroups
  498. .quad sys_fchown
  499. .quad sys_setresuid
  500. .quad sys_getresuid
  501. .quad sys_setresgid /* 210 */
  502. .quad sys_getresgid
  503. .quad sys_chown
  504. .quad sys_setuid
  505. .quad sys_setgid
  506. .quad sys_setfsuid /* 215 */
  507. .quad sys_setfsgid
  508. .quad sys_pivot_root
  509. .quad sys_mincore
  510. .quad sys_madvise
  511. .quad compat_sys_getdents64 /* 220 getdents64 */
  512. .quad compat_sys_fcntl64
  513. .quad quiet_ni_syscall /* tux */
  514. .quad quiet_ni_syscall /* security */
  515. .quad sys_gettid
  516. .quad sys_readahead /* 225 */
  517. .quad sys_setxattr
  518. .quad sys_lsetxattr
  519. .quad sys_fsetxattr
  520. .quad sys_getxattr
  521. .quad sys_lgetxattr /* 230 */
  522. .quad sys_fgetxattr
  523. .quad sys_listxattr
  524. .quad sys_llistxattr
  525. .quad sys_flistxattr
  526. .quad sys_removexattr /* 235 */
  527. .quad sys_lremovexattr
  528. .quad sys_fremovexattr
  529. .quad sys_tkill
  530. .quad sys_sendfile64
  531. .quad compat_sys_futex /* 240 */
  532. .quad compat_sys_sched_setaffinity
  533. .quad compat_sys_sched_getaffinity
  534. .quad sys32_set_thread_area
  535. .quad sys32_get_thread_area
  536. .quad compat_sys_io_setup /* 245 */
  537. .quad sys_io_destroy
  538. .quad compat_sys_io_getevents
  539. .quad compat_sys_io_submit
  540. .quad sys_io_cancel
  541. .quad sys_fadvise64 /* 250 */
  542. .quad quiet_ni_syscall /* free_huge_pages */
  543. .quad sys_exit_group
  544. .quad sys32_lookup_dcookie
  545. .quad sys_epoll_create
  546. .quad sys_epoll_ctl /* 255 */
  547. .quad sys_epoll_wait
  548. .quad sys_remap_file_pages
  549. .quad sys_set_tid_address
  550. .quad sys32_timer_create
  551. .quad compat_sys_timer_settime /* 260 */
  552. .quad compat_sys_timer_gettime
  553. .quad sys_timer_getoverrun
  554. .quad sys_timer_delete
  555. .quad compat_sys_clock_settime
  556. .quad compat_sys_clock_gettime /* 265 */
  557. .quad compat_sys_clock_getres
  558. .quad compat_sys_clock_nanosleep
  559. .quad compat_sys_statfs64
  560. .quad compat_sys_fstatfs64
  561. .quad sys_tgkill /* 270 */
  562. .quad compat_sys_utimes
  563. .quad sys32_fadvise64_64
  564. .quad quiet_ni_syscall /* sys_vserver */
  565. .quad sys_mbind
  566. .quad compat_sys_get_mempolicy /* 275 */
  567. .quad sys_set_mempolicy
  568. .quad compat_sys_mq_open
  569. .quad sys_mq_unlink
  570. .quad compat_sys_mq_timedsend
  571. .quad compat_sys_mq_timedreceive /* 280 */
  572. .quad compat_sys_mq_notify
  573. .quad compat_sys_mq_getsetattr
  574. .quad compat_sys_kexec_load /* reserved for kexec */
  575. .quad compat_sys_waitid
  576. .quad quiet_ni_syscall /* 285: sys_altroot */
  577. .quad sys_add_key
  578. .quad sys_request_key
  579. .quad sys_keyctl
  580. .quad sys_ioprio_set
  581. .quad sys_ioprio_get /* 290 */
  582. .quad sys_inotify_init
  583. .quad sys_inotify_add_watch
  584. .quad sys_inotify_rm_watch
  585. ia32_syscall_end:
  586. .rept IA32_NR_syscalls-(ia32_syscall_end-ia32_sys_call_table)/8
  587. .quad ni_syscall
  588. .endr