syscalls.S 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367
  1. /* Systemcall Entry Table */
  2. #include <linux/sys.h>
  3. #include <asm/linkage.h>
  4. #include <asm/unistd.h>
  5. .globl SYMBOL_NAME(sys_call_table)
  6. #if defined(CONFIG_CPU_H8300H)
  7. .h8300h
  8. #endif
  9. #if defined(CONFIG_CPU_H8S)
  10. .h8300s
  11. #endif
  12. .section .text
  13. .align 2
  14. SYMBOL_NAME_LABEL(sys_call_table)
  15. .long SYMBOL_NAME(sys_ni_syscall) /* 0 - old "setup()" system call*/
  16. .long SYMBOL_NAME(sys_exit)
  17. .long SYMBOL_NAME(sys_fork)
  18. .long SYMBOL_NAME(sys_read)
  19. .long SYMBOL_NAME(sys_write)
  20. .long SYMBOL_NAME(sys_open) /* 5 */
  21. .long SYMBOL_NAME(sys_close)
  22. .long SYMBOL_NAME(sys_waitpid)
  23. .long SYMBOL_NAME(sys_creat)
  24. .long SYMBOL_NAME(sys_link)
  25. .long SYMBOL_NAME(sys_unlink) /* 10 */
  26. .long SYMBOL_NAME(sys_execve)
  27. .long SYMBOL_NAME(sys_chdir)
  28. .long SYMBOL_NAME(sys_time)
  29. .long SYMBOL_NAME(sys_mknod)
  30. .long SYMBOL_NAME(sys_chmod) /* 15 */
  31. .long SYMBOL_NAME(sys_chown16)
  32. .long SYMBOL_NAME(sys_ni_syscall) /* old break syscall holder */
  33. .long SYMBOL_NAME(sys_stat)
  34. .long SYMBOL_NAME(sys_lseek)
  35. .long SYMBOL_NAME(sys_getpid) /* 20 */
  36. .long SYMBOL_NAME(sys_mount)
  37. .long SYMBOL_NAME(sys_oldumount)
  38. .long SYMBOL_NAME(sys_setuid16)
  39. .long SYMBOL_NAME(sys_getuid16)
  40. .long SYMBOL_NAME(sys_stime) /* 25 */
  41. .long SYMBOL_NAME(sys_ptrace)
  42. .long SYMBOL_NAME(sys_alarm)
  43. .long SYMBOL_NAME(sys_fstat)
  44. .long SYMBOL_NAME(sys_pause)
  45. .long SYMBOL_NAME(sys_utime) /* 30 */
  46. .long SYMBOL_NAME(sys_ni_syscall) /* old stty syscall holder */
  47. .long SYMBOL_NAME(sys_ni_syscall) /* old gtty syscall holder */
  48. .long SYMBOL_NAME(sys_access)
  49. .long SYMBOL_NAME(sys_nice)
  50. .long SYMBOL_NAME(sys_ni_syscall) /* 35 old ftime syscall holder */
  51. .long SYMBOL_NAME(sys_sync)
  52. .long SYMBOL_NAME(sys_kill)
  53. .long SYMBOL_NAME(sys_rename)
  54. .long SYMBOL_NAME(sys_mkdir)
  55. .long SYMBOL_NAME(sys_rmdir) /* 40 */
  56. .long SYMBOL_NAME(sys_dup)
  57. .long SYMBOL_NAME(sys_pipe)
  58. .long SYMBOL_NAME(sys_times)
  59. .long SYMBOL_NAME(sys_ni_syscall) /* old prof syscall holder */
  60. .long SYMBOL_NAME(sys_brk) /* 45 */
  61. .long SYMBOL_NAME(sys_setgid16)
  62. .long SYMBOL_NAME(sys_getgid16)
  63. .long SYMBOL_NAME(sys_signal)
  64. .long SYMBOL_NAME(sys_geteuid16)
  65. .long SYMBOL_NAME(sys_getegid16) /* 50 */
  66. .long SYMBOL_NAME(sys_acct)
  67. .long SYMBOL_NAME(sys_umount) /* recycled never used phys() */
  68. .long SYMBOL_NAME(sys_ni_syscall) /* old lock syscall holder */
  69. .long SYMBOL_NAME(sys_ioctl)
  70. .long SYMBOL_NAME(sys_fcntl) /* 55 */
  71. .long SYMBOL_NAME(sys_ni_syscall) /* old mpx syscall holder */
  72. .long SYMBOL_NAME(sys_setpgid)
  73. .long SYMBOL_NAME(sys_ni_syscall) /* old ulimit syscall holder */
  74. .long SYMBOL_NAME(sys_ni_syscall)
  75. .long SYMBOL_NAME(sys_umask) /* 60 */
  76. .long SYMBOL_NAME(sys_chroot)
  77. .long SYMBOL_NAME(sys_ustat)
  78. .long SYMBOL_NAME(sys_dup2)
  79. .long SYMBOL_NAME(sys_getppid)
  80. .long SYMBOL_NAME(sys_getpgrp) /* 65 */
  81. .long SYMBOL_NAME(sys_setsid)
  82. .long SYMBOL_NAME(sys_sigaction)
  83. .long SYMBOL_NAME(sys_sgetmask)
  84. .long SYMBOL_NAME(sys_ssetmask)
  85. .long SYMBOL_NAME(sys_setreuid16) /* 70 */
  86. .long SYMBOL_NAME(sys_setregid16)
  87. .long SYMBOL_NAME(sys_sigsuspend)
  88. .long SYMBOL_NAME(sys_sigpending)
  89. .long SYMBOL_NAME(sys_sethostname)
  90. .long SYMBOL_NAME(sys_setrlimit) /* 75 */
  91. .long SYMBOL_NAME(sys_old_getrlimit)
  92. .long SYMBOL_NAME(sys_getrusage)
  93. .long SYMBOL_NAME(sys_gettimeofday)
  94. .long SYMBOL_NAME(sys_settimeofday)
  95. .long SYMBOL_NAME(sys_getgroups16) /* 80 */
  96. .long SYMBOL_NAME(sys_setgroups16)
  97. .long SYMBOL_NAME(sys_old_select)
  98. .long SYMBOL_NAME(sys_symlink)
  99. .long SYMBOL_NAME(sys_lstat)
  100. .long SYMBOL_NAME(sys_readlink) /* 85 */
  101. .long SYMBOL_NAME(sys_uselib)
  102. .long SYMBOL_NAME(sys_swapon)
  103. .long SYMBOL_NAME(sys_reboot)
  104. .long SYMBOL_NAME(sys_old_readdir)
  105. .long SYMBOL_NAME(sys_old_mmap) /* 90 */
  106. .long SYMBOL_NAME(sys_munmap)
  107. .long SYMBOL_NAME(sys_truncate)
  108. .long SYMBOL_NAME(sys_ftruncate)
  109. .long SYMBOL_NAME(sys_fchmod)
  110. .long SYMBOL_NAME(sys_fchown16) /* 95 */
  111. .long SYMBOL_NAME(sys_getpriority)
  112. .long SYMBOL_NAME(sys_setpriority)
  113. .long SYMBOL_NAME(sys_ni_syscall) /* old profil syscall holder */
  114. .long SYMBOL_NAME(sys_statfs)
  115. .long SYMBOL_NAME(sys_fstatfs) /* 100 */
  116. .long SYMBOL_NAME(sys_ni_syscall) /* ioperm for i386 */
  117. .long SYMBOL_NAME(sys_socketcall)
  118. .long SYMBOL_NAME(sys_syslog)
  119. .long SYMBOL_NAME(sys_setitimer)
  120. .long SYMBOL_NAME(sys_getitimer) /* 105 */
  121. .long SYMBOL_NAME(sys_newstat)
  122. .long SYMBOL_NAME(sys_newlstat)
  123. .long SYMBOL_NAME(sys_newfstat)
  124. .long SYMBOL_NAME(sys_ni_syscall)
  125. .long SYMBOL_NAME(sys_ni_syscall) /* iopl for i386 */ /* 110 */
  126. .long SYMBOL_NAME(sys_vhangup)
  127. .long SYMBOL_NAME(sys_ni_syscall) /* obsolete idle() syscall */
  128. .long SYMBOL_NAME(sys_ni_syscall) /* vm86old for i386 */
  129. .long SYMBOL_NAME(sys_wait4)
  130. .long SYMBOL_NAME(sys_swapoff) /* 115 */
  131. .long SYMBOL_NAME(sys_sysinfo)
  132. .long SYMBOL_NAME(sys_ipc)
  133. .long SYMBOL_NAME(sys_fsync)
  134. .long SYMBOL_NAME(sys_sigreturn)
  135. .long SYMBOL_NAME(sys_clone) /* 120 */
  136. .long SYMBOL_NAME(sys_setdomainname)
  137. .long SYMBOL_NAME(sys_newuname)
  138. .long SYMBOL_NAME(sys_cacheflush) /* modify_ldt for i386 */
  139. .long SYMBOL_NAME(sys_adjtimex)
  140. .long SYMBOL_NAME(sys_ni_syscall) /* 125 sys_mprotect */
  141. .long SYMBOL_NAME(sys_sigprocmask)
  142. .long SYMBOL_NAME(sys_ni_syscall) /* sys_create_module */
  143. .long SYMBOL_NAME(sys_init_module)
  144. .long SYMBOL_NAME(sys_delete_module)
  145. .long SYMBOL_NAME(sys_ni_syscall) /* 130 sys_get_kernel_syms */
  146. .long SYMBOL_NAME(sys_quotactl)
  147. .long SYMBOL_NAME(sys_getpgid)
  148. .long SYMBOL_NAME(sys_fchdir)
  149. .long SYMBOL_NAME(sys_bdflush)
  150. .long SYMBOL_NAME(sys_sysfs) /* 135 */
  151. .long SYMBOL_NAME(sys_personality)
  152. .long SYMBOL_NAME(sys_ni_syscall) /* for afs_syscall */
  153. .long SYMBOL_NAME(sys_setfsuid16)
  154. .long SYMBOL_NAME(sys_setfsgid16)
  155. .long SYMBOL_NAME(sys_llseek) /* 140 */
  156. .long SYMBOL_NAME(sys_getdents)
  157. .long SYMBOL_NAME(sys_select)
  158. .long SYMBOL_NAME(sys_flock)
  159. .long SYMBOL_NAME(sys_ni_syscall) /* sys_msync */
  160. .long SYMBOL_NAME(sys_readv) /* 145 */
  161. .long SYMBOL_NAME(sys_writev)
  162. .long SYMBOL_NAME(sys_getsid)
  163. .long SYMBOL_NAME(sys_fdatasync)
  164. .long SYMBOL_NAME(sys_sysctl)
  165. .long SYMBOL_NAME(sys_ni_syscall) /* 150 sys_mlock */
  166. .long SYMBOL_NAME(sys_ni_syscall) /* sys_munlock */
  167. .long SYMBOL_NAME(sys_ni_syscall) /* sys_mlockall */
  168. .long SYMBOL_NAME(sys_ni_syscall) /* sys_munlockall */
  169. .long SYMBOL_NAME(sys_sched_setparam)
  170. .long SYMBOL_NAME(sys_sched_getparam) /* 155 */
  171. .long SYMBOL_NAME(sys_sched_setscheduler)
  172. .long SYMBOL_NAME(sys_sched_getscheduler)
  173. .long SYMBOL_NAME(sys_sched_yield)
  174. .long SYMBOL_NAME(sys_sched_get_priority_max)
  175. .long SYMBOL_NAME(sys_sched_get_priority_min) /* 160 */
  176. .long SYMBOL_NAME(sys_sched_rr_get_interval)
  177. .long SYMBOL_NAME(sys_nanosleep)
  178. .long SYMBOL_NAME(sys_ni_syscall) /* sys_mremap */
  179. .long SYMBOL_NAME(sys_setresuid16)
  180. .long SYMBOL_NAME(sys_getresuid16) /* 165 */
  181. .long SYMBOL_NAME(sys_ni_syscall) /* for vm86 */
  182. .long SYMBOL_NAME(sys_ni_syscall) /* sys_query_module */
  183. .long SYMBOL_NAME(sys_poll)
  184. .long SYMBOL_NAME(sys_ni_syscall) /* old nfsservctl */
  185. .long SYMBOL_NAME(sys_setresgid16) /* 170 */
  186. .long SYMBOL_NAME(sys_getresgid16)
  187. .long SYMBOL_NAME(sys_prctl)
  188. .long SYMBOL_NAME(sys_rt_sigreturn)
  189. .long SYMBOL_NAME(sys_rt_sigaction)
  190. .long SYMBOL_NAME(sys_rt_sigprocmask) /* 175 */
  191. .long SYMBOL_NAME(sys_rt_sigpending)
  192. .long SYMBOL_NAME(sys_rt_sigtimedwait)
  193. .long SYMBOL_NAME(sys_rt_sigqueueinfo)
  194. .long SYMBOL_NAME(sys_rt_sigsuspend)
  195. .long SYMBOL_NAME(sys_pread64) /* 180 */
  196. .long SYMBOL_NAME(sys_pwrite64)
  197. .long SYMBOL_NAME(sys_lchown16);
  198. .long SYMBOL_NAME(sys_getcwd)
  199. .long SYMBOL_NAME(sys_capget)
  200. .long SYMBOL_NAME(sys_capset) /* 185 */
  201. .long SYMBOL_NAME(sys_sigaltstack)
  202. .long SYMBOL_NAME(sys_sendfile)
  203. .long SYMBOL_NAME(sys_ni_syscall) /* streams1 */
  204. .long SYMBOL_NAME(sys_ni_syscall) /* streams2 */
  205. .long SYMBOL_NAME(sys_vfork) /* 190 */
  206. .long SYMBOL_NAME(sys_getrlimit)
  207. .long SYMBOL_NAME(sys_mmap_pgoff)
  208. .long SYMBOL_NAME(sys_truncate64)
  209. .long SYMBOL_NAME(sys_ftruncate64)
  210. .long SYMBOL_NAME(sys_stat64) /* 195 */
  211. .long SYMBOL_NAME(sys_lstat64)
  212. .long SYMBOL_NAME(sys_fstat64)
  213. .long SYMBOL_NAME(sys_chown)
  214. .long SYMBOL_NAME(sys_getuid)
  215. .long SYMBOL_NAME(sys_getgid) /* 200 */
  216. .long SYMBOL_NAME(sys_geteuid)
  217. .long SYMBOL_NAME(sys_getegid)
  218. .long SYMBOL_NAME(sys_setreuid)
  219. .long SYMBOL_NAME(sys_setregid)
  220. .long SYMBOL_NAME(sys_getgroups) /* 205 */
  221. .long SYMBOL_NAME(sys_setgroups)
  222. .long SYMBOL_NAME(sys_fchown)
  223. .long SYMBOL_NAME(sys_setresuid)
  224. .long SYMBOL_NAME(sys_getresuid)
  225. .long SYMBOL_NAME(sys_setresgid) /* 210 */
  226. .long SYMBOL_NAME(sys_getresgid)
  227. .long SYMBOL_NAME(sys_lchown)
  228. .long SYMBOL_NAME(sys_setuid)
  229. .long SYMBOL_NAME(sys_setgid)
  230. .long SYMBOL_NAME(sys_setfsuid) /* 215 */
  231. .long SYMBOL_NAME(sys_setfsgid)
  232. .long SYMBOL_NAME(sys_pivot_root)
  233. .long SYMBOL_NAME(sys_ni_syscall)
  234. .long SYMBOL_NAME(sys_ni_syscall)
  235. .long SYMBOL_NAME(sys_getdents64) /* 220 */
  236. .long SYMBOL_NAME(sys_fcntl64)
  237. .long SYMBOL_NAME(sys_ni_syscall) /* reserved TUX */
  238. .long SYMBOL_NAME(sys_ni_syscall) /* reserved Security */
  239. .long SYMBOL_NAME(sys_gettid)
  240. .long SYMBOL_NAME(sys_readahead) /* 225 */
  241. .long SYMBOL_NAME(sys_setxattr)
  242. .long SYMBOL_NAME(sys_lsetxattr)
  243. .long SYMBOL_NAME(sys_fsetxattr)
  244. .long SYMBOL_NAME(sys_getxattr)
  245. .long SYMBOL_NAME(sys_lgetxattr) /* 230 */
  246. .long SYMBOL_NAME(sys_fgetxattr)
  247. .long SYMBOL_NAME(sys_listxattr)
  248. .long SYMBOL_NAME(sys_llistxattr)
  249. .long SYMBOL_NAME(sys_flistxattr)
  250. .long SYMBOL_NAME(sys_removexattr) /* 235 */
  251. .long SYMBOL_NAME(sys_lremovexattr)
  252. .long SYMBOL_NAME(sys_fremovexattr)
  253. .long SYMBOL_NAME(sys_tkill)
  254. .long SYMBOL_NAME(sys_sendfile64)
  255. .long SYMBOL_NAME(sys_futex) /* 240 */
  256. .long SYMBOL_NAME(sys_sched_setaffinity)
  257. .long SYMBOL_NAME(sys_sched_getaffinity)
  258. .long SYMBOL_NAME(sys_ni_syscall)
  259. .long SYMBOL_NAME(sys_ni_syscall)
  260. .long SYMBOL_NAME(sys_io_setup) /* 245 */
  261. .long SYMBOL_NAME(sys_io_destroy)
  262. .long SYMBOL_NAME(sys_io_getevents)
  263. .long SYMBOL_NAME(sys_io_submit)
  264. .long SYMBOL_NAME(sys_io_cancel)
  265. .long SYMBOL_NAME(sys_fadvise64) /* 250 */
  266. .long SYMBOL_NAME(sys_ni_syscall)
  267. .long SYMBOL_NAME(sys_exit_group)
  268. .long SYMBOL_NAME(sys_lookup_dcookie)
  269. .long SYMBOL_NAME(sys_epoll_create)
  270. .long SYMBOL_NAME(sys_epoll_ctl) /* 255 */
  271. .long SYMBOL_NAME(sys_epoll_wait)
  272. .long SYMBOL_NAME(sys_ni_syscall) /* sys_remap_file_pages */
  273. .long SYMBOL_NAME(sys_set_tid_address)
  274. .long SYMBOL_NAME(sys_timer_create)
  275. .long SYMBOL_NAME(sys_timer_settime) /* 260 */
  276. .long SYMBOL_NAME(sys_timer_gettime)
  277. .long SYMBOL_NAME(sys_timer_getoverrun)
  278. .long SYMBOL_NAME(sys_timer_delete)
  279. .long SYMBOL_NAME(sys_clock_settime)
  280. .long SYMBOL_NAME(sys_clock_gettime) /* 265 */
  281. .long SYMBOL_NAME(sys_clock_getres)
  282. .long SYMBOL_NAME(sys_clock_nanosleep)
  283. .long SYMBOL_NAME(sys_statfs64)
  284. .long SYMBOL_NAME(sys_fstatfs64)
  285. .long SYMBOL_NAME(sys_tgkill) /* 270 */
  286. .long SYMBOL_NAME(sys_utimes)
  287. .long SYMBOL_NAME(sys_fadvise64_64)
  288. .long SYMBOL_NAME(sys_ni_syscall) /* sys_vserver */
  289. .long SYMBOL_NAME(sys_ni_syscall)
  290. .long SYMBOL_NAME(sys_get_mempolicy) /* 275 */
  291. .long SYMBOL_NAME(sys_set_mempolicy)
  292. .long SYMBOL_NAME(sys_mq_open)
  293. .long SYMBOL_NAME(sys_mq_unlink)
  294. .long SYMBOL_NAME(sys_mq_timedsend)
  295. .long SYMBOL_NAME(sys_mq_timedreceive) /* 280 */
  296. .long SYMBOL_NAME(sys_mq_notify)
  297. .long SYMBOL_NAME(sys_mq_getsetattr)
  298. .long SYMBOL_NAME(sys_waitid)
  299. .long SYMBOL_NAME(sys_ni_syscall) /* sys_kexec_load */
  300. .long SYMBOL_NAME(sys_add_key) /* 285 */
  301. .long SYMBOL_NAME(sys_request_key)
  302. .long SYMBOL_NAME(sys_keyctl)
  303. .long SYMBOL_NAME(sys_ioprio_set)
  304. .long SYMBOL_NAME(sys_ioprio_get) /* 290 */
  305. .long SYMBOL_NAME(sys_inotify_init)
  306. .long SYMBOL_NAME(sys_inotify_add_watch)
  307. .long SYMBOL_NAME(sys_inotify_rm_watch)
  308. .long SYMBOL_NAME(sys_migrate_pages)
  309. .long SYMBOL_NAME(sys_openat) /* 295 */
  310. .long SYMBOL_NAME(sys_mkdirat)
  311. .long SYMBOL_NAME(sys_mknodat)
  312. .long SYMBOL_NAME(sys_fchownat)
  313. .long SYMBOL_NAME(sys_futimesat)
  314. .long SYMBOL_NAME(sys_fstatat64) /* 300 */
  315. .long SYMBOL_NAME(sys_unlinkat)
  316. .long SYMBOL_NAME(sys_renameat)
  317. .long SYMBOL_NAME(sys_linkat)
  318. .long SYMBOL_NAME(sys_symlinkat)
  319. .long SYMBOL_NAME(sys_readlinkat) /* 305 */
  320. .long SYMBOL_NAME(sys_fchmodat)
  321. .long SYMBOL_NAME(sys_faccessat)
  322. .long SYMBOL_NAME(sys_ni_syscall) /* sys_pselect6 */
  323. .long SYMBOL_NAME(sys_ni_syscall) /* sys_ppoll */
  324. .long SYMBOL_NAME(sys_unshare) /* 310 */
  325. .long SYMBOL_NAME(sys_set_robust_list)
  326. .long SYMBOL_NAME(sys_get_robust_list)
  327. .long SYMBOL_NAME(sys_splice)
  328. .long SYMBOL_NAME(sys_sync_file_range)
  329. .long SYMBOL_NAME(sys_tee) /* 315 */
  330. .long SYMBOL_NAME(sys_vmsplice)
  331. .long SYMBOL_NAME(sys_ni_syscall) /* sys_move_pages */
  332. .long SYMBOL_NAME(sys_getcpu)
  333. .long SYMBOL_NAME(sys_ni_syscall) /* sys_epoll_pwait */
  334. .long SYMBOL_NAME(sys_setns) /* 320 */
  335. .macro call_sp addr
  336. mov.l #SYMBOL_NAME(\addr),er6
  337. bra SYMBOL_NAME(syscall_trampoline):8
  338. .endm
  339. SYMBOL_NAME_LABEL(sys_clone)
  340. call_sp h8300_clone
  341. SYMBOL_NAME_LABEL(sys_sigsuspend)
  342. call_sp do_sigsuspend
  343. SYMBOL_NAME_LABEL(sys_rt_sigsuspend)
  344. call_sp do_rt_sigsuspend
  345. SYMBOL_NAME_LABEL(sys_sigreturn)
  346. call_sp do_sigreturn
  347. SYMBOL_NAME_LABEL(sys_rt_sigreturn)
  348. call_sp do_rt_sigreturn
  349. SYMBOL_NAME_LABEL(sys_fork)
  350. call_sp h8300_fork
  351. SYMBOL_NAME_LABEL(sys_vfork)
  352. call_sp h8300_vfork
  353. SYMBOL_NAME_LABEL(syscall_trampoline)
  354. mov.l sp,er0
  355. jmp @er6