entry.S 34 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150
  1. /* $Id: entry.S,v 1.28 2005/06/20 05:06:30 starvik Exp $
  2. *
  3. * linux/arch/cris/entry.S
  4. *
  5. * Copyright (C) 2000, 2001, 2002 Axis Communications AB
  6. *
  7. * Authors: Bjorn Wesen (bjornw@axis.com)
  8. *
  9. * $Log: entry.S,v $
  10. * Revision 1.28 2005/06/20 05:06:30 starvik
  11. * Remove unnecessary diff to kernel.org tree
  12. *
  13. * Revision 1.27 2005/03/04 08:16:16 starvik
  14. * Merge of Linux 2.6.11.
  15. *
  16. * Revision 1.26 2005/01/11 13:49:47 starvik
  17. * Added NMI handler.
  18. *
  19. * Revision 1.25 2004/12/27 11:18:32 starvik
  20. * Merge of Linux 2.6.10 (not functional yet).
  21. *
  22. * Revision 1.24 2004/12/22 10:41:23 starvik
  23. * Updates to make v10 compile with the latest SMP aware generic code (even
  24. * though v10 will never have SMP).
  25. *
  26. * Revision 1.23 2004/10/19 13:07:37 starvik
  27. * Merge of Linux 2.6.9
  28. *
  29. * Revision 1.22 2004/06/21 10:29:55 starvik
  30. * Merge of Linux 2.6.7
  31. *
  32. * Revision 1.21 2004/06/09 05:30:27 starvik
  33. * Clean up multiple interrupt handling.
  34. * Prevent interrupts from interrupting each other.
  35. * Handle all active interrupts.
  36. *
  37. * Revision 1.20 2004/06/08 08:55:32 starvik
  38. * Removed unused code
  39. *
  40. * Revision 1.19 2004/06/04 11:56:15 starvik
  41. * Implemented page table lookup for refills in assembler for improved performance.
  42. *
  43. * Revision 1.18 2004/05/11 12:28:25 starvik
  44. * Merge of Linux 2.6.6
  45. *
  46. * Revision 1.17 2003/09/11 07:29:49 starvik
  47. * Merge of Linux 2.6.0-test5
  48. *
  49. * Revision 1.16 2003/07/04 08:27:41 starvik
  50. * Merge of Linux 2.5.74
  51. *
  52. * Revision 1.15 2003/04/09 07:32:55 starvik
  53. * resume should return task_struct, not thread_info
  54. *
  55. * Revision 1.14 2003/04/09 05:20:44 starvik
  56. * Merge of Linux 2.5.67
  57. *
  58. * Revision 1.13 2002/12/11 15:42:02 starvik
  59. * Extracted v10 (ETRAX 100LX) specific stuff from arch/cris/kernel/*.c
  60. *
  61. * Revision 1.12 2002/12/10 09:00:10 starvik
  62. * Merge of Linux 2.5.51
  63. *
  64. * Revision 1.11 2002/12/05 07:53:10 starvik
  65. * Corrected constants used with btstq
  66. *
  67. * Revision 1.10 2002/11/27 08:45:10 starvik
  68. * pid is in task_struct, not thread_info
  69. *
  70. * Revision 1.9 2002/11/26 09:52:05 starvik
  71. * Added preemptive kernel scheduling (if CONFIG_PREEMPT)
  72. *
  73. * Revision 1.8 2002/11/20 11:56:11 starvik
  74. * Merge of Linux 2.5.48
  75. *
  76. * Revision 1.7 2002/11/18 13:02:42 starvik
  77. * Added fourth parameter to do_notify_resume
  78. * Minor cleanup
  79. *
  80. * Revision 1.6 2002/11/11 10:37:50 starvik
  81. * Use new asm-offset defines
  82. * Modified for new location of current->work etc
  83. * Removed SYMBOL_NAME from syscalls
  84. * Added some new syscalls
  85. *
  86. * Revision 1.5 2002/11/05 06:45:11 starvik
  87. * Merge of Linux 2.5.45
  88. *
  89. * Revision 1.4 2002/02/05 15:41:31 bjornw
  90. * Rewritten to conform better to current 2.5 code (similar to arch/i386)
  91. *
  92. * Revision 1.3 2002/01/21 15:22:20 bjornw
  93. * NICE_DOGGY fix from 2.4 arch/cris
  94. *
  95. * Revision 1.37 2001/12/07 17:03:55 bjornw
  96. * Call a c-hook called watchdog_bite_hook instead of show_registers directly
  97. *
  98. * Revision 1.36 2001/11/22 13:36:36 bjornw
  99. * * In ret_from_intr, check regs->dccr for usermode reentrance instead of
  100. * DCCR explicitely (because the latter might not reflect current reality)
  101. * * In mmu_bus_fault, set $r9 _after_ calling the C-code instead of before
  102. * since $r9 is call-clobbered and is potentially needed afterwards
  103. *
  104. * Revision 1.35 2001/10/30 17:10:15 bjornw
  105. * Add some syscalls
  106. *
  107. * Revision 1.34 2001/10/01 14:45:03 bjornw
  108. * Removed underscores and added register prefixes
  109. *
  110. * Revision 1.33 2001/08/21 13:48:01 jonashg
  111. * Added fix by HP to avoid oops when doing a hard_reset_now.
  112. *
  113. * Revision 1.32 2001/08/14 04:32:02 hp
  114. * In _resume, add comment why R9 is saved; don't sound like it's call-saved.
  115. *
  116. * Revision 1.31 2001/07/25 16:07:42 bjornw
  117. * softirq_active/mask -> softirq_pending only
  118. *
  119. * Revision 1.30 2001/07/05 01:03:32 hp
  120. * - include asm/errno.h to get ENOSYS.
  121. * - Use ENOSYS, not local constant LENOSYS; tweak comments.
  122. * - Explain why .include, not #include is used.
  123. * - Make oops-register-dump if watchdog bits and it's not expected.
  124. * - Don't jsr, use jump _hard_reset_now, and skip spurious nop.
  125. * - Use correct section attribute for section .rodata.
  126. * - Adjust sys_ni_syscall fill number.
  127. *
  128. * Revision 1.29 2001/06/25 14:07:00 hp
  129. * Fix review comment.
  130. * * head.S: Use IO_STATE, IO_FIELD and IO_MASK constructs instead of
  131. * magic numbers. Add comment that -traditional must not be used.
  132. * * entry.S (SYMBOL_NAME): Change redefinition to use ## concatenation.
  133. * Correct and update comment.
  134. * * Makefile (.S.o): Don't use -traditional. Add comment why the
  135. * toplevel rule can't be used (now that there's a reason).
  136. *
  137. * Revision 1.28 2001/06/21 02:00:40 hp
  138. * * entry.S: Include asm/unistd.h.
  139. * (_sys_call_table): Use section .rodata, not .data.
  140. * (_kernel_thread): Move from...
  141. * * process.c: ... here.
  142. * * entryoffsets.c (VAL): Break out from...
  143. * (OF): Use VAL.
  144. * (LCLONE_VM): New asmified value from CLONE_VM.
  145. *
  146. * Revision 1.27 2001/05/29 11:25:27 markusl
  147. * In case of "spurious_interrupt", do hard_reset instead of hanging system in a loop...
  148. *
  149. * Revision 1.26 2001/05/15 15:46:03 bjornw
  150. * Include config.h now that we use some CONFIG_ options
  151. *
  152. * Revision 1.25 2001/05/15 05:38:47 hp
  153. * Tweaked code in _ret_from_sys_call
  154. *
  155. * Revision 1.24 2001/05/15 05:27:49 hp
  156. * Save r9 in r1 over function call rather than on stack.
  157. *
  158. * Revision 1.23 2001/05/15 05:10:00 hp
  159. * Generate entry.S structure offsets from C
  160. *
  161. * Revision 1.22 2001/04/17 13:58:39 orjanf
  162. * * Renamed CONFIG_KGDB to CONFIG_ETRAX_KGDB.
  163. *
  164. * Revision 1.21 2001/04/17 11:33:29 orjanf
  165. * Updated according to review:
  166. * * Included asm/sv_addr_ag.h to get macro for internal register.
  167. * * Corrected comment regarding system call argument passing.
  168. * * Removed comment about instruction being in a delay slot.
  169. * * Added comment about SYMBOL_NAME macro.
  170. *
  171. * Revision 1.20 2001/04/12 08:51:07 hp
  172. * - Add entry for sys_fcntl64. In fact copy last piece from i386 including ...
  173. * - .rept to fill table to safe state with sys_ni_syscall.
  174. *
  175. * Revision 1.19 2001/04/04 09:43:32 orjanf
  176. * * Moved do_sigtrap from traps.c to entry.S.
  177. * * LTASK_PID need not be global anymore.
  178. *
  179. * Revision 1.18 2001/03/26 09:25:02 markusl
  180. * Updated after review, should now handle USB interrupts correctly.
  181. *
  182. * Revision 1.17 2001/03/21 16:12:55 bjornw
  183. * * Always make room for the cpu status record in the frame, in order to
  184. * use the same framelength and layout for both mmu busfaults and normal
  185. * irqs. No need to check for the explicit CRIS_FRAME_FIXUP type anymore.
  186. * * Fixed bug with using addq for popping the stack in the epilogue - it
  187. * destroyed the flag register. Use instructions that don't affect the
  188. * flag register instead.
  189. * * Removed write to R_PORT_PA_DATA during spurious_interrupt
  190. *
  191. * Revision 1.16 2001/03/20 19:43:02 bjornw
  192. * * Get rid of esp0 setting
  193. * * Give a 7th argument to a systemcall - the stackframe
  194. *
  195. * Revision 1.15 2001/03/05 13:14:30 bjornw
  196. * Spelling fix
  197. *
  198. * Revision 1.14 2001/02/23 08:36:36 perf
  199. * New ABI; syscallnr=r9, arg5=mof, arg6=srp.
  200. * Corrected tracesys call check.
  201. *
  202. * Revision 1.13 2001/02/15 08:40:55 perf
  203. * H-P by way of perf;
  204. * - (_system_call): Don't read system call function address into r1.
  205. * - (RBFExit): There is no such thing as a null pop. Adjust sp by addq.
  206. * - (_system_call): Don't use r10 and don't save and restore it.
  207. * - (THREAD_ESP0): New constant.
  208. * - (_system_call): Inline set_esp0.
  209. *
  210. * Revision 1.12 2001/01/31 17:56:25 orjanf
  211. * Added definition of LTASK_PID and made it global.
  212. *
  213. * Revision 1.11 2001/01/10 21:13:29 bjornw
  214. * SYMBOL_NAME is defined incorrectly for the compiler options we currently use
  215. *
  216. * Revision 1.10 2000/12/18 23:47:56 bjornw
  217. * * Added syscall trace support (ptrace), completely untested of course
  218. * * Removed redundant check for NULL entries in syscall_table
  219. *
  220. * Revision 1.9 2000/11/21 16:40:51 bjornw
  221. * * New frame type used when an SBFS frame needs to be popped without
  222. * actually restarting the instruction
  223. * * Enable interrupts in signal_return (they did so in x86, I hope it's a good
  224. * idea)
  225. *
  226. * Revision 1.8 2000/11/17 16:53:35 bjornw
  227. * Added detection of frame-type in Rexit, so that mmu_bus_fault can
  228. * use ret_from_intr in the return-path to check for signals (like SEGV)
  229. * and other foul things that might have occurred during the fault.
  230. *
  231. * Revision 1.7 2000/10/06 15:04:28 bjornw
  232. * Include mof in register savings
  233. *
  234. * Revision 1.6 2000/09/12 16:02:44 bjornw
  235. * Linux-2.4.0-test7 derived updates
  236. *
  237. * Revision 1.5 2000/08/17 15:35:15 bjornw
  238. * 2.4.0-test6 changed local_irq_count and friends API
  239. *
  240. * Revision 1.4 2000/08/02 13:59:30 bjornw
  241. * Removed olduname and uname from the syscall list
  242. *
  243. * Revision 1.3 2000/07/31 13:32:58 bjornw
  244. * * Export ret_from_intr
  245. * * _resume updated (prev/last tjohejsan)
  246. * * timer_interrupt obsolete
  247. * * SIGSEGV detection in mmu_bus_fault temporarily disabled
  248. *
  249. *
  250. */
  251. /*
  252. * entry.S contains the system-call and fault low-level handling routines.
  253. *
  254. * NOTE: This code handles signal-recognition, which happens every time
  255. * after a timer-interrupt and after each system call.
  256. *
  257. * Stack layout in 'ret_from_system_call':
  258. * ptrace needs to have all regs on the stack.
  259. * if the order here is changed, it needs to be
  260. * updated in fork.c:copy_process, signal.c:do_signal,
  261. * ptrace.c and ptrace.h
  262. *
  263. */
  264. #include <linux/config.h>
  265. #include <linux/linkage.h>
  266. #include <linux/sys.h>
  267. #include <asm/unistd.h>
  268. #include <asm/arch/sv_addr_ag.h>
  269. #include <asm/errno.h>
  270. #include <asm/thread_info.h>
  271. #include <asm/arch/offset.h>
  272. #include <asm/page.h>
  273. #include <asm/pgtable.h>
  274. ;; functions exported from this file
  275. .globl system_call
  276. .globl ret_from_intr
  277. .globl ret_from_fork
  278. .globl resume
  279. .globl multiple_interrupt
  280. .globl hwbreakpoint
  281. .globl IRQ1_interrupt
  282. .globl spurious_interrupt
  283. .globl hw_bp_trigs
  284. .globl mmu_bus_fault
  285. .globl do_sigtrap
  286. .globl gdb_handle_breakpoint
  287. .globl sys_call_table
  288. ;; below are various parts of system_call which are not in the fast-path
  289. #ifdef CONFIG_PREEMPT
  290. ; Check if preemptive kernel scheduling should be done
  291. _resume_kernel:
  292. di
  293. ; Load current task struct
  294. movs.w -8192, $r0 ; THREAD_SIZE = 8192
  295. and.d $sp, $r0
  296. move.d [$r0+TI_preempt_count], $r10 ; Preemption disabled?
  297. bne _Rexit
  298. nop
  299. _need_resched:
  300. move.d [$r0+TI_flags], $r10
  301. btstq TIF_NEED_RESCHED, $r10 ; Check if need_resched is set
  302. bpl _Rexit
  303. nop
  304. ; Ok, lets's do some preemptive kernel scheduling
  305. jsr preempt_schedule_irq
  306. ; Load new task struct
  307. movs.w -8192, $r0 ; THREAD_SIZE = 8192
  308. and.d $sp, $r0
  309. ; One more time (with new task)
  310. ba _need_resched
  311. nop
  312. #else
  313. #define _resume_kernel _Rexit
  314. #endif
  315. ; Called at exit from fork. schedule_tail must be called to drop
  316. ; spinlock if CONFIG_PREEMPT
  317. ret_from_fork:
  318. jsr schedule_tail
  319. ba ret_from_sys_call
  320. nop
  321. ret_from_intr:
  322. ;; check for resched if preemptive kernel or if we're going back to user-mode
  323. ;; this test matches the user_regs(regs) macro
  324. ;; we cannot simply test $dccr, because that does not necessarily
  325. ;; reflect what mode we'll return into.
  326. move.d [$sp + PT_dccr], $r0; regs->dccr
  327. btstq 8, $r0 ; U-flag
  328. bpl _resume_kernel
  329. ; Note that di below is in delay slot
  330. _resume_userspace:
  331. di ; so need_resched and sigpending don't change
  332. movs.w -8192, $r0 ; THREAD_SIZE == 8192
  333. and.d $sp, $r0
  334. move.d [$r0+TI_flags], $r10 ; current->work
  335. and.d _TIF_WORK_MASK, $r10 ; is there any work to be done on return
  336. bne _work_pending
  337. nop
  338. ba _Rexit
  339. nop
  340. ;; The system_call is called by a BREAK instruction, which works like
  341. ;; an interrupt call but it stores the return PC in BRP instead of IRP.
  342. ;; Since we dont really want to have two epilogues (one for system calls
  343. ;; and one for interrupts) we push the contents of BRP instead of IRP in the
  344. ;; system call prologue, to make it look like an ordinary interrupt on the
  345. ;; stackframe.
  346. ;;
  347. ;; Since we can't have system calls inside interrupts, it should not matter
  348. ;; that we don't stack IRP.
  349. ;;
  350. ;; In r9 we have the wanted syscall number. Arguments come in r10,r11,r12,r13,mof,srp
  351. ;;
  352. ;; This function looks on the _surface_ like spaghetti programming, but it's
  353. ;; really designed so that the fast-path does not force cache-loading of non-used
  354. ;; instructions. Only the non-common cases cause the outlined code to run..
  355. system_call:
  356. ;; stack-frame similar to the irq heads, which is reversed in ret_from_sys_call
  357. move $brp,[$sp=$sp-16]; instruction pointer and room for a fake SBFS frame
  358. push $srp
  359. push $dccr
  360. push $mof
  361. subq 14*4, $sp ; make room for r0-r13
  362. movem $r13, [$sp] ; push r0-r13
  363. push $r10 ; push orig_r10
  364. clear.d [$sp=$sp-4] ; frametype == 0, normal stackframe
  365. movs.w -ENOSYS, $r0
  366. move.d $r0, [$sp+PT_r10] ; put the default return value in r10 in the frame
  367. ;; check if this process is syscall-traced
  368. movs.w -8192, $r0 ; THREAD_SIZE == 8192
  369. and.d $sp, $r0
  370. move.d [$r0+TI_flags], $r0
  371. btstq TIF_SYSCALL_TRACE, $r0
  372. bmi _syscall_trace_entry
  373. nop
  374. _syscall_traced:
  375. ;; check for sanity in the requested syscall number
  376. cmpu.w NR_syscalls, $r9
  377. bcc ret_from_sys_call
  378. lslq 2, $r9 ; multiply by 4, in the delay slot
  379. ;; as a bonus 7th parameter, we give the location on the stack
  380. ;; of the register structure itself. some syscalls need this.
  381. push $sp
  382. ;; the parameter carrying registers r10, r11, r12 and 13 are intact.
  383. ;; the fifth and sixth parameters (if any) was in mof and srp
  384. ;; respectively, and we need to put them on the stack.
  385. push $srp
  386. push $mof
  387. jsr [$r9+sys_call_table] ; actually do the system call
  388. addq 3*4, $sp ; pop the mof, srp and regs parameters
  389. move.d $r10, [$sp+PT_r10] ; save the return value
  390. moveq 1, $r9 ; "parameter" to ret_from_sys_call to show it was a sys call
  391. ;; fall through into ret_from_sys_call to return
  392. ret_from_sys_call:
  393. ;; r9 is a parameter - if >=1 we came from a syscall, if 0, from an irq
  394. ;; get the current task-struct pointer (see top for defs)
  395. movs.w -8192, $r0 ; THREAD_SIZE == 8192
  396. and.d $sp, $r0
  397. di ; make sure need_resched and sigpending don't change
  398. move.d [$r0+TI_flags],$r1
  399. and.d _TIF_ALLWORK_MASK, $r1
  400. bne _syscall_exit_work
  401. nop
  402. _Rexit:
  403. ;; this epilogue MUST match the prologues in multiple_interrupt, irq.h and ptregs.h
  404. pop $r10 ; frametype
  405. bne _RBFexit ; was not CRIS_FRAME_NORMAL, handle otherwise
  406. addq 4, $sp ; skip orig_r10, in delayslot
  407. movem [$sp+], $r13 ; registers r0-r13
  408. pop $mof ; multiply overflow register
  409. pop $dccr ; condition codes
  410. pop $srp ; subroutine return pointer
  411. ;; now we have a 4-word SBFS frame which we do not want to restore
  412. ;; using RBF since it was not stacked with SBFS. instead we would like to
  413. ;; just get the PC value to restart it with, and skip the rest of
  414. ;; the frame.
  415. ;; Also notice that it's important to use instructions here that
  416. ;; keep the interrupts disabled (since we've already popped DCCR)
  417. move [$sp=$sp+16], $p8; pop the SBFS frame from the sp
  418. jmpu [$sp-16] ; return through the irp field in the sbfs frame
  419. _RBFexit:
  420. movem [$sp+], $r13 ; registers r0-r13, in delay slot
  421. pop $mof ; multiply overflow register
  422. pop $dccr ; condition codes
  423. pop $srp ; subroutine return pointer
  424. rbf [$sp+] ; return by popping the CPU status
  425. ;; We get here after doing a syscall if extra work might need to be done
  426. ;; perform syscall exit tracing if needed
  427. _syscall_exit_work:
  428. ;; $r0 contains current at this point and irq's are disabled
  429. move.d [$r0+TI_flags], $r1
  430. btstq TIF_SYSCALL_TRACE, $r1
  431. bpl _work_pending
  432. nop
  433. ei
  434. move.d $r9, $r1 ; preserve r9
  435. jsr do_syscall_trace
  436. move.d $r1, $r9
  437. ba _resume_userspace
  438. nop
  439. _work_pending:
  440. move.d [$r0+TI_flags], $r1
  441. btstq TIF_NEED_RESCHED, $r1
  442. bpl _work_notifysig ; was neither trace nor sched, must be signal/notify
  443. nop
  444. _work_resched:
  445. move.d $r9, $r1 ; preserve r9
  446. jsr schedule
  447. move.d $r1, $r9
  448. di
  449. move.d [$r0+TI_flags], $r1
  450. and.d _TIF_WORK_MASK, $r1; ignore the syscall trace counter
  451. beq _Rexit
  452. nop
  453. btstq TIF_NEED_RESCHED, $r1
  454. bmi _work_resched ; current->work.need_resched
  455. nop
  456. _work_notifysig:
  457. ;; deal with pending signals and notify-resume requests
  458. move.d $r9, $r10 ; do_notify_resume syscall/irq param
  459. moveq 0, $r11 ; oldset param - 0 in this case
  460. move.d $sp, $r12 ; the regs param
  461. move.d $r1, $r13 ; the thread_info_flags parameter
  462. jsr do_notify_resume
  463. ba _Rexit
  464. nop
  465. ;; We get here as a sidetrack when we've entered a syscall with the
  466. ;; trace-bit set. We need to call do_syscall_trace and then continue
  467. ;; with the call.
  468. _syscall_trace_entry:
  469. ;; PT_r10 in the frame contains -ENOSYS as required, at this point
  470. jsr do_syscall_trace
  471. ;; now re-enter the syscall code to do the syscall itself
  472. ;; we need to restore $r9 here to contain the wanted syscall, and
  473. ;; the other parameter-bearing registers
  474. move.d [$sp+PT_r9], $r9
  475. move.d [$sp+PT_orig_r10], $r10 ; PT_r10 is already filled with -ENOSYS.
  476. move.d [$sp+PT_r11], $r11
  477. move.d [$sp+PT_r12], $r12
  478. move.d [$sp+PT_r13], $r13
  479. move [$sp+PT_mof], $mof
  480. move [$sp+PT_srp], $srp
  481. ba _syscall_traced
  482. nop
  483. ;; resume performs the actual task-switching, by switching stack pointers
  484. ;; input arguments: r10 = prev, r11 = next, r12 = thread offset in task struct
  485. ;; returns old current in r10
  486. ;;
  487. ;; TODO: see the i386 version. The switch_to which calls resume in our version
  488. ;; could really be an inline asm of this.
  489. resume:
  490. push $srp ; we keep the old/new PC on the stack
  491. add.d $r12, $r10 ; r10 = current tasks tss
  492. move $dccr, [$r10+THREAD_dccr]; save irq enable state
  493. di
  494. move $usp, [$r10+ THREAD_usp] ; save user-mode stackpointer
  495. ;; See copy_thread for the reason why register R9 is saved.
  496. subq 10*4, $sp
  497. movem $r9, [$sp] ; save non-scratch registers and R9.
  498. move.d $sp, [$r10+THREAD_ksp] ; save the kernel stack pointer for the old task
  499. move.d $sp, $r10 ; return last running task in r10
  500. and.d -8192, $r10 ; get thread_info from stackpointer
  501. move.d [$r10+TI_task], $r10 ; get task
  502. add.d $r12, $r11 ; find the new tasks tss
  503. move.d [$r11+THREAD_ksp], $sp ; switch into the new stackframe by restoring kernel sp
  504. movem [$sp+], $r9 ; restore non-scratch registers and R9.
  505. move [$r11+THREAD_usp], $usp ; restore user-mode stackpointer
  506. move [$r11+THREAD_dccr], $dccr ; restore irq enable status
  507. jump [$sp+] ; restore PC
  508. ;; This is the MMU bus fault handler.
  509. ;; It needs to stack the CPU status and overall is different
  510. ;; from the other interrupt handlers.
  511. mmu_bus_fault:
  512. ;; For refills we try to do a quick page table lookup. If it is
  513. ;; a real fault we let the mm subsystem handle it.
  514. ;; the first longword in the sbfs frame was the interrupted PC
  515. ;; which fits nicely with the "IRP" slot in pt_regs normally used to
  516. ;; contain the return address. used by Oops to print kernel errors.
  517. sbfs [$sp=$sp-16] ; push the internal CPU status
  518. push $dccr
  519. di
  520. subq 2*4, $sp
  521. movem $r1, [$sp]
  522. move.d [R_MMU_CAUSE], $r1
  523. ;; ETRAX 100LX TR89 bugfix: if the second half of an unaligned
  524. ;; write causes a MMU-fault, it will not be restarted correctly.
  525. ;; This could happen if a write crosses a page-boundary and the
  526. ;; second page is not yet COW'ed or even loaded. The workaround
  527. ;; is to clear the unaligned bit in the CPU status record, so
  528. ;; that the CPU will rerun both the first and second halves of
  529. ;; the instruction. This will not have any sideeffects unless
  530. ;; the first half goes to any device or memory that can't be
  531. ;; written twice, and which is mapped through the MMU.
  532. ;;
  533. ;; We only need to do this for writes.
  534. btstq 8, $r1 ; Write access?
  535. bpl 1f
  536. nop
  537. move.d [$sp+16], $r0 ; Clear unaligned bit in csrinstr
  538. and.d ~(1<<5), $r0
  539. move.d $r0, [$sp+16]
  540. 1: btstq 12, $r1 ; Refill?
  541. bpl 2f
  542. lsrq 24, $r1 ; Get PGD index (bit 24-31)
  543. move.d [per_cpu__current_pgd], $r0 ; PGD for the current process
  544. move.d [$r0+$r1.d], $r0 ; Get PMD
  545. beq 2f
  546. nop
  547. and.w PAGE_MASK, $r0 ; Remove PMD flags
  548. move.d [R_MMU_CAUSE], $r1
  549. lsrq PAGE_SHIFT, $r1
  550. and.d 0x7ff, $r1 ; Get PTE index into PGD (bit 13-23)
  551. move.d [$r0+$r1.d], $r1 ; Get PTE
  552. beq 2f
  553. nop
  554. ;; Store in TLB
  555. move.d $r1, [R_TLB_LO]
  556. ;; Return
  557. movem [$sp+], $r1
  558. pop $dccr
  559. rbf [$sp+] ; return by popping the CPU status
  560. 2: ; PMD or PTE missing, let the mm subsystem fix it up.
  561. movem [$sp+], $r1
  562. pop $dccr
  563. ; Ok, not that easy, pass it on to the mm subsystem
  564. ; The MMU status record is now on the stack
  565. push $srp ; make a stackframe similar to pt_regs
  566. push $dccr
  567. push $mof
  568. di
  569. subq 14*4, $sp
  570. movem $r13, [$sp]
  571. push $r10 ; dummy orig_r10
  572. moveq 1, $r10
  573. push $r10 ; frametype == 1, BUSFAULT frame type
  574. move.d $sp, $r10 ; pt_regs argument to handle_mmu_bus_fault
  575. jsr handle_mmu_bus_fault ; in arch/cris/arch-v10/mm/fault.c
  576. ;; now we need to return through the normal path, we cannot just
  577. ;; do the RBFexit since we might have killed off the running
  578. ;; process due to a SEGV, scheduled due to a page blocking or
  579. ;; whatever.
  580. moveq 0, $r9 ; busfault is equivalent to an irq
  581. ba ret_from_intr
  582. nop
  583. ;; special handlers for breakpoint and NMI
  584. hwbreakpoint:
  585. push $dccr
  586. di
  587. push $r10
  588. push $r11
  589. move.d [hw_bp_trig_ptr],$r10
  590. move $brp,$r11
  591. move.d $r11,[$r10+]
  592. move.d $r10,[hw_bp_trig_ptr]
  593. 1: pop $r11
  594. pop $r10
  595. pop $dccr
  596. retb
  597. nop
  598. IRQ1_interrupt:
  599. ;; this prologue MUST match the one in irq.h and the struct in ptregs.h!!!
  600. move $brp,[$sp=$sp-16]; instruction pointer and room for a fake SBFS frame
  601. push $srp
  602. push $dccr
  603. push $mof
  604. di
  605. subq 14*4, $sp
  606. movem $r13, [$sp]
  607. push $r10 ; push orig_r10
  608. clear.d [$sp=$sp-4] ; frametype == 0, normal frame
  609. move.d [R_IRQ_MASK0_RD], $r1 ; External NMI or watchdog?
  610. and.d 0x80000000, $r1
  611. beq wdog
  612. move.d $sp, $r10
  613. jsr handle_nmi
  614. setf m ; Enable NMI again
  615. retb ; Return from NMI
  616. nop
  617. wdog:
  618. #if defined(CONFIG_ETRAX_WATCHDOG) && !defined(CONFIG_SVINTO_SIM)
  619. ;; Check if we're waiting for reset to happen, as signalled by
  620. ;; hard_reset_now setting cause_of_death to a magic value. If so, just
  621. ;; get stuck until reset happens.
  622. .comm cause_of_death, 4 ;; Don't declare this anywhere.
  623. move.d [cause_of_death], $r10
  624. cmp.d 0xbedead, $r10
  625. _killed_by_death:
  626. beq _killed_by_death
  627. nop
  628. ;; We'll see this in ksymoops dumps.
  629. Watchdog_bite:
  630. #ifdef CONFIG_ETRAX_WATCHDOG_NICE_DOGGY
  631. ;; We just restart the watchdog here to be sure we dont get
  632. ;; hit while printing the watchdogmsg below
  633. ;; This restart is compatible with the rest of the C-code, so
  634. ;; the C-code can keep restarting the watchdog after this point.
  635. ;; The non-NICE_DOGGY code below though, disables the possibility
  636. ;; to restart since it changes the watchdog key, to avoid any
  637. ;; buggy loops etc. keeping the watchdog alive after this.
  638. jsr reset_watchdog
  639. #else
  640. ;; We need to extend the 3.3ms after the NMI at watchdog bite, so we have
  641. ;; time for an oops-dump over a 115k2 serial wire. Another 100ms should do.
  642. ;; Change the watchdog key to an arbitrary 3-bit value and restart the
  643. ;; watchdog.
  644. #define WD_INIT 2
  645. moveq IO_FIELD (R_WATCHDOG, key, WD_INIT), $r10
  646. move.d R_WATCHDOG, $r11
  647. move.d $r10, [$r11]
  648. moveq IO_FIELD (R_WATCHDOG, key, \
  649. IO_EXTRACT (R_WATCHDOG, key, \
  650. IO_MASK (R_WATCHDOG, key)) \
  651. ^ WD_INIT) \
  652. | IO_STATE (R_WATCHDOG, enable, start), $r10
  653. move.d $r10, [$r11]
  654. #endif
  655. ;; Note that we don't do "setf m" here (or after two necessary NOPs),
  656. ;; since *not* doing that saves us from re-entrancy checks. We don't want
  657. ;; to get here again due to possible subsequent NMIs; we want the watchdog
  658. ;; to reset us.
  659. move.d _watchdogmsg,$r10
  660. jsr printk
  661. move.d $sp, $r10
  662. jsr watchdog_bite_hook
  663. ;; This nop is here so we see the "Watchdog_bite" label in ksymoops dumps
  664. ;; rather than "spurious_interrupt".
  665. nop
  666. ;; At this point we drop down into spurious_interrupt, which will do a
  667. ;; hard reset.
  668. .section .rodata,"a"
  669. _watchdogmsg:
  670. .ascii "Oops: bitten by watchdog\n\0"
  671. .previous
  672. #endif /* CONFIG_ETRAX_WATCHDOG and not CONFIG_SVINTO_SIM */
  673. spurious_interrupt:
  674. di
  675. jump hard_reset_now
  676. ;; this handles the case when multiple interrupts arrive at the same time
  677. ;; we jump to the first set interrupt bit in a priority fashion
  678. ;; the hardware will call the unserved interrupts after the handler finishes
  679. multiple_interrupt:
  680. ;; this prologue MUST match the one in irq.h and the struct in ptregs.h!!!
  681. move $irp,[$sp=$sp-16]; instruction pointer and room for a fake SBFS frame
  682. push $srp
  683. push $dccr
  684. push $mof
  685. di
  686. subq 14*4, $sp
  687. movem $r13, [$sp]
  688. push $r10 ; push orig_r10
  689. clear.d [$sp=$sp-4] ; frametype == 0, normal frame
  690. moveq 2, $r2 ; first bit we care about is the timer0 irq
  691. move.d [R_VECT_MASK_RD], $r0; read the irq bits that triggered the multiple irq
  692. move.d $r0, [R_VECT_MASK_CLR] ; Block all active IRQs
  693. 1:
  694. btst $r2, $r0 ; check for the irq given by bit r2
  695. bpl 2f
  696. move.d $r2, $r10 ; First argument to do_IRQ
  697. move.d $sp, $r11 ; second argument to do_IRQ
  698. jsr do_IRQ
  699. 2:
  700. addq 1, $r2 ; next vector bit
  701. cmp.b 32, $r2
  702. bne 1b ; process all irq's up to and including number 31
  703. moveq 0, $r9 ; make ret_from_intr realise we came from an ir
  704. move.d $r0, [R_VECT_MASK_SET] ; Unblock all the IRQs
  705. jump ret_from_intr
  706. do_sigtrap:
  707. ;;
  708. ;; SIGTRAP the process that executed the break instruction.
  709. ;; Make a frame that Rexit in entry.S expects.
  710. ;;
  711. move $brp, [$sp=$sp-16] ; Push BRP while faking a cpu status record.
  712. push $srp ; Push subroutine return pointer.
  713. push $dccr ; Push condition codes.
  714. push $mof ; Push multiply overflow reg.
  715. di ; Need to disable irq's at this point.
  716. subq 14*4, $sp ; Make room for r0-r13.
  717. movem $r13, [$sp] ; Push the r0-r13 registers.
  718. push $r10 ; Push orig_r10.
  719. clear.d [$sp=$sp-4] ; Frametype - this is a normal stackframe.
  720. movs.w -8192,$r9 ; THREAD_SIZE == 8192
  721. and.d $sp, $r9
  722. move.d [$r9+TI_task], $r10
  723. move.d [$r10+TASK_pid], $r10 ; current->pid as arg1.
  724. moveq 5, $r11 ; SIGTRAP as arg2.
  725. jsr sys_kill
  726. jump ret_from_intr ; Use the return routine for interrupts.
  727. gdb_handle_breakpoint:
  728. push $dccr
  729. push $r0
  730. #ifdef CONFIG_ETRAX_KGDB
  731. move $dccr, $r0 ; U-flag not affected by previous insns.
  732. btstq 8, $r0 ; Test the U-flag.
  733. bmi _ugdb_handle_breakpoint ; Go to user mode debugging.
  734. nop ; Empty delay slot (cannot pop r0 here).
  735. pop $r0 ; Restore r0.
  736. ba kgdb_handle_breakpoint ; Go to kernel debugging.
  737. pop $dccr ; Restore dccr in delay slot.
  738. #endif
  739. _ugdb_handle_breakpoint:
  740. move $brp, $r0 ; Use r0 temporarily for calculation.
  741. subq 2, $r0 ; Set to address of previous instruction.
  742. move $r0, $brp
  743. pop $r0 ; Restore r0.
  744. ba do_sigtrap ; SIGTRAP the offending process.
  745. pop $dccr ; Restore dccr in delay slot.
  746. .data
  747. hw_bp_trigs:
  748. .space 64*4
  749. hw_bp_trig_ptr:
  750. .dword hw_bp_trigs
  751. .section .rodata,"a"
  752. sys_call_table:
  753. .long sys_restart_syscall /* 0 - old "setup()" system call, used for restarting */
  754. .long sys_exit
  755. .long sys_fork
  756. .long sys_read
  757. .long sys_write
  758. .long sys_open /* 5 */
  759. .long sys_close
  760. .long sys_waitpid
  761. .long sys_creat
  762. .long sys_link
  763. .long sys_unlink /* 10 */
  764. .long sys_execve
  765. .long sys_chdir
  766. .long sys_time
  767. .long sys_mknod
  768. .long sys_chmod /* 15 */
  769. .long sys_lchown16
  770. .long sys_ni_syscall /* old break syscall holder */
  771. .long sys_stat
  772. .long sys_lseek
  773. .long sys_getpid /* 20 */
  774. .long sys_mount
  775. .long sys_oldumount
  776. .long sys_setuid16
  777. .long sys_getuid16
  778. .long sys_stime /* 25 */
  779. .long sys_ptrace
  780. .long sys_alarm
  781. .long sys_fstat
  782. .long sys_pause
  783. .long sys_utime /* 30 */
  784. .long sys_ni_syscall /* old stty syscall holder */
  785. .long sys_ni_syscall /* old gtty syscall holder */
  786. .long sys_access
  787. .long sys_nice
  788. .long sys_ni_syscall /* 35 old ftime syscall holder */
  789. .long sys_sync
  790. .long sys_kill
  791. .long sys_rename
  792. .long sys_mkdir
  793. .long sys_rmdir /* 40 */
  794. .long sys_dup
  795. .long sys_pipe
  796. .long sys_times
  797. .long sys_ni_syscall /* old prof syscall holder */
  798. .long sys_brk /* 45 */
  799. .long sys_setgid16
  800. .long sys_getgid16
  801. .long sys_signal
  802. .long sys_geteuid16
  803. .long sys_getegid16 /* 50 */
  804. .long sys_acct
  805. .long sys_umount /* recycled never used phys( */
  806. .long sys_ni_syscall /* old lock syscall holder */
  807. .long sys_ioctl
  808. .long sys_fcntl /* 55 */
  809. .long sys_ni_syscall /* old mpx syscall holder */
  810. .long sys_setpgid
  811. .long sys_ni_syscall /* old ulimit syscall holder */
  812. .long sys_ni_syscall /* old sys_olduname holder */
  813. .long sys_umask /* 60 */
  814. .long sys_chroot
  815. .long sys_ustat
  816. .long sys_dup2
  817. .long sys_getppid
  818. .long sys_getpgrp /* 65 */
  819. .long sys_setsid
  820. .long sys_sigaction
  821. .long sys_sgetmask
  822. .long sys_ssetmask
  823. .long sys_setreuid16 /* 70 */
  824. .long sys_setregid16
  825. .long sys_sigsuspend
  826. .long sys_sigpending
  827. .long sys_sethostname
  828. .long sys_setrlimit /* 75 */
  829. .long sys_old_getrlimit
  830. .long sys_getrusage
  831. .long sys_gettimeofday
  832. .long sys_settimeofday
  833. .long sys_getgroups16 /* 80 */
  834. .long sys_setgroups16
  835. .long sys_select /* was old_select in Linux/E100 */
  836. .long sys_symlink
  837. .long sys_lstat
  838. .long sys_readlink /* 85 */
  839. .long sys_uselib
  840. .long sys_swapon
  841. .long sys_reboot
  842. .long old_readdir
  843. .long old_mmap /* 90 */
  844. .long sys_munmap
  845. .long sys_truncate
  846. .long sys_ftruncate
  847. .long sys_fchmod
  848. .long sys_fchown16 /* 95 */
  849. .long sys_getpriority
  850. .long sys_setpriority
  851. .long sys_ni_syscall /* old profil syscall holder */
  852. .long sys_statfs
  853. .long sys_fstatfs /* 100 */
  854. .long sys_ni_syscall /* sys_ioperm in i386 */
  855. .long sys_socketcall
  856. .long sys_syslog
  857. .long sys_setitimer
  858. .long sys_getitimer /* 105 */
  859. .long sys_newstat
  860. .long sys_newlstat
  861. .long sys_newfstat
  862. .long sys_ni_syscall /* old sys_uname holder */
  863. .long sys_ni_syscall /* sys_iopl in i386 */
  864. .long sys_vhangup
  865. .long sys_ni_syscall /* old "idle" system call */
  866. .long sys_ni_syscall /* vm86old in i386 */
  867. .long sys_wait4
  868. .long sys_swapoff /* 115 */
  869. .long sys_sysinfo
  870. .long sys_ipc
  871. .long sys_fsync
  872. .long sys_sigreturn
  873. .long sys_clone /* 120 */
  874. .long sys_setdomainname
  875. .long sys_newuname
  876. .long sys_ni_syscall /* sys_modify_ldt */
  877. .long sys_adjtimex
  878. .long sys_mprotect /* 125 */
  879. .long sys_sigprocmask
  880. .long sys_ni_syscall /* old "create_module" */
  881. .long sys_init_module
  882. .long sys_delete_module
  883. .long sys_ni_syscall /* 130: old "get_kernel_syms" */
  884. .long sys_quotactl
  885. .long sys_getpgid
  886. .long sys_fchdir
  887. .long sys_bdflush
  888. .long sys_sysfs /* 135 */
  889. .long sys_personality
  890. .long sys_ni_syscall /* for afs_syscall */
  891. .long sys_setfsuid16
  892. .long sys_setfsgid16
  893. .long sys_llseek /* 140 */
  894. .long sys_getdents
  895. .long sys_select
  896. .long sys_flock
  897. .long sys_msync
  898. .long sys_readv /* 145 */
  899. .long sys_writev
  900. .long sys_getsid
  901. .long sys_fdatasync
  902. .long sys_sysctl
  903. .long sys_mlock /* 150 */
  904. .long sys_munlock
  905. .long sys_mlockall
  906. .long sys_munlockall
  907. .long sys_sched_setparam
  908. .long sys_sched_getparam /* 155 */
  909. .long sys_sched_setscheduler
  910. .long sys_sched_getscheduler
  911. .long sys_sched_yield
  912. .long sys_sched_get_priority_max
  913. .long sys_sched_get_priority_min /* 160 */
  914. .long sys_sched_rr_get_interval
  915. .long sys_nanosleep
  916. .long sys_mremap
  917. .long sys_setresuid16
  918. .long sys_getresuid16 /* 165 */
  919. .long sys_ni_syscall /* sys_vm86 */
  920. .long sys_ni_syscall /* Old sys_query_module */
  921. .long sys_poll
  922. .long sys_nfsservctl
  923. .long sys_setresgid16 /* 170 */
  924. .long sys_getresgid16
  925. .long sys_prctl
  926. .long sys_rt_sigreturn
  927. .long sys_rt_sigaction
  928. .long sys_rt_sigprocmask /* 175 */
  929. .long sys_rt_sigpending
  930. .long sys_rt_sigtimedwait
  931. .long sys_rt_sigqueueinfo
  932. .long sys_rt_sigsuspend
  933. .long sys_pread64 /* 180 */
  934. .long sys_pwrite64
  935. .long sys_chown16
  936. .long sys_getcwd
  937. .long sys_capget
  938. .long sys_capset /* 185 */
  939. .long sys_sigaltstack
  940. .long sys_sendfile
  941. .long sys_ni_syscall /* streams1 */
  942. .long sys_ni_syscall /* streams2 */
  943. .long sys_vfork /* 190 */
  944. .long sys_getrlimit
  945. .long sys_mmap2
  946. .long sys_truncate64
  947. .long sys_ftruncate64
  948. .long sys_stat64 /* 195 */
  949. .long sys_lstat64
  950. .long sys_fstat64
  951. .long sys_lchown
  952. .long sys_getuid
  953. .long sys_getgid /* 200 */
  954. .long sys_geteuid
  955. .long sys_getegid
  956. .long sys_setreuid
  957. .long sys_setregid
  958. .long sys_getgroups /* 205 */
  959. .long sys_setgroups
  960. .long sys_fchown
  961. .long sys_setresuid
  962. .long sys_getresuid
  963. .long sys_setresgid /* 210 */
  964. .long sys_getresgid
  965. .long sys_chown
  966. .long sys_setuid
  967. .long sys_setgid
  968. .long sys_setfsuid /* 215 */
  969. .long sys_setfsgid
  970. .long sys_pivot_root
  971. .long sys_mincore
  972. .long sys_madvise
  973. .long sys_getdents64 /* 220 */
  974. .long sys_fcntl64
  975. .long sys_ni_syscall /* reserved for TUX */
  976. .long sys_ni_syscall
  977. .long sys_gettid
  978. .long sys_readahead /* 225 */
  979. .long sys_setxattr
  980. .long sys_lsetxattr
  981. .long sys_fsetxattr
  982. .long sys_getxattr
  983. .long sys_lgetxattr /* 230 */
  984. .long sys_fgetxattr
  985. .long sys_listxattr
  986. .long sys_llistxattr
  987. .long sys_flistxattr
  988. .long sys_removexattr /* 235 */
  989. .long sys_lremovexattr
  990. .long sys_fremovexattr
  991. .long sys_tkill
  992. .long sys_sendfile64
  993. .long sys_futex /* 240 */
  994. .long sys_sched_setaffinity
  995. .long sys_sched_getaffinity
  996. .long sys_ni_syscall /* sys_set_thread_area */
  997. .long sys_ni_syscall /* sys_get_thread_area */
  998. .long sys_io_setup /* 245 */
  999. .long sys_io_destroy
  1000. .long sys_io_getevents
  1001. .long sys_io_submit
  1002. .long sys_io_cancel
  1003. .long sys_fadvise64 /* 250 */
  1004. .long sys_ni_syscall
  1005. .long sys_exit_group
  1006. .long sys_lookup_dcookie
  1007. .long sys_epoll_create
  1008. .long sys_epoll_ctl /* 255 */
  1009. .long sys_epoll_wait
  1010. .long sys_remap_file_pages
  1011. .long sys_set_tid_address
  1012. .long sys_timer_create
  1013. .long sys_timer_settime /* 260 */
  1014. .long sys_timer_gettime
  1015. .long sys_timer_getoverrun
  1016. .long sys_timer_delete
  1017. .long sys_clock_settime
  1018. .long sys_clock_gettime /* 265 */
  1019. .long sys_clock_getres
  1020. .long sys_clock_nanosleep
  1021. .long sys_statfs64
  1022. .long sys_fstatfs64
  1023. .long sys_tgkill /* 270 */
  1024. .long sys_utimes
  1025. .long sys_fadvise64_64
  1026. .long sys_ni_syscall /* sys_vserver */
  1027. .long sys_ni_syscall /* sys_mbind */
  1028. .long sys_ni_syscall /* 275 sys_get_mempolicy */
  1029. .long sys_ni_syscall /* sys_set_mempolicy */
  1030. .long sys_mq_open
  1031. .long sys_mq_unlink
  1032. .long sys_mq_timedsend
  1033. .long sys_mq_timedreceive /* 280 */
  1034. .long sys_mq_notify
  1035. .long sys_mq_getsetattr
  1036. .long sys_ni_syscall /* reserved for kexec */
  1037. .long sys_waitid
  1038. .long sys_ni_syscall /* 285 */ /* available */
  1039. .long sys_add_key
  1040. .long sys_request_key
  1041. .long sys_keyctl
  1042. /*
  1043. * NOTE!! This doesn't have to be exact - we just have
  1044. * to make sure we have _enough_ of the "sys_ni_syscall"
  1045. * entries. Don't panic if you notice that this hasn't
  1046. * been shrunk every time we add a new system call.
  1047. */
  1048. .rept NR_syscalls-(.-sys_call_table)/4
  1049. .long sys_ni_syscall
  1050. .endr