entry.S 34 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149
  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/linkage.h>
  265. #include <linux/sys.h>
  266. #include <asm/unistd.h>
  267. #include <asm/arch/sv_addr_ag.h>
  268. #include <asm/errno.h>
  269. #include <asm/thread_info.h>
  270. #include <asm/asm-offsets.h>
  271. #include <asm/page.h>
  272. #include <asm/pgtable.h>
  273. ;; functions exported from this file
  274. .globl system_call
  275. .globl ret_from_intr
  276. .globl ret_from_fork
  277. .globl resume
  278. .globl multiple_interrupt
  279. .globl hwbreakpoint
  280. .globl IRQ1_interrupt
  281. .globl spurious_interrupt
  282. .globl hw_bp_trigs
  283. .globl mmu_bus_fault
  284. .globl do_sigtrap
  285. .globl gdb_handle_breakpoint
  286. .globl sys_call_table
  287. ;; below are various parts of system_call which are not in the fast-path
  288. #ifdef CONFIG_PREEMPT
  289. ; Check if preemptive kernel scheduling should be done
  290. _resume_kernel:
  291. di
  292. ; Load current task struct
  293. movs.w -8192, $r0 ; THREAD_SIZE = 8192
  294. and.d $sp, $r0
  295. move.d [$r0+TI_preempt_count], $r10 ; Preemption disabled?
  296. bne _Rexit
  297. nop
  298. _need_resched:
  299. move.d [$r0+TI_flags], $r10
  300. btstq TIF_NEED_RESCHED, $r10 ; Check if need_resched is set
  301. bpl _Rexit
  302. nop
  303. ; Ok, lets's do some preemptive kernel scheduling
  304. jsr preempt_schedule_irq
  305. ; Load new task struct
  306. movs.w -8192, $r0 ; THREAD_SIZE = 8192
  307. and.d $sp, $r0
  308. ; One more time (with new task)
  309. ba _need_resched
  310. nop
  311. #else
  312. #define _resume_kernel _Rexit
  313. #endif
  314. ; Called at exit from fork. schedule_tail must be called to drop
  315. ; spinlock if CONFIG_PREEMPT
  316. ret_from_fork:
  317. jsr schedule_tail
  318. ba ret_from_sys_call
  319. nop
  320. ret_from_intr:
  321. ;; check for resched if preemptive kernel or if we're going back to user-mode
  322. ;; this test matches the user_regs(regs) macro
  323. ;; we cannot simply test $dccr, because that does not necessarily
  324. ;; reflect what mode we'll return into.
  325. move.d [$sp + PT_dccr], $r0; regs->dccr
  326. btstq 8, $r0 ; U-flag
  327. bpl _resume_kernel
  328. ; Note that di below is in delay slot
  329. _resume_userspace:
  330. di ; so need_resched and sigpending don't change
  331. movs.w -8192, $r0 ; THREAD_SIZE == 8192
  332. and.d $sp, $r0
  333. move.d [$r0+TI_flags], $r10 ; current->work
  334. and.d _TIF_WORK_MASK, $r10 ; is there any work to be done on return
  335. bne _work_pending
  336. nop
  337. ba _Rexit
  338. nop
  339. ;; The system_call is called by a BREAK instruction, which works like
  340. ;; an interrupt call but it stores the return PC in BRP instead of IRP.
  341. ;; Since we dont really want to have two epilogues (one for system calls
  342. ;; and one for interrupts) we push the contents of BRP instead of IRP in the
  343. ;; system call prologue, to make it look like an ordinary interrupt on the
  344. ;; stackframe.
  345. ;;
  346. ;; Since we can't have system calls inside interrupts, it should not matter
  347. ;; that we don't stack IRP.
  348. ;;
  349. ;; In r9 we have the wanted syscall number. Arguments come in r10,r11,r12,r13,mof,srp
  350. ;;
  351. ;; This function looks on the _surface_ like spaghetti programming, but it's
  352. ;; really designed so that the fast-path does not force cache-loading of non-used
  353. ;; instructions. Only the non-common cases cause the outlined code to run..
  354. system_call:
  355. ;; stack-frame similar to the irq heads, which is reversed in ret_from_sys_call
  356. move $brp,[$sp=$sp-16]; instruction pointer and room for a fake SBFS frame
  357. push $srp
  358. push $dccr
  359. push $mof
  360. subq 14*4, $sp ; make room for r0-r13
  361. movem $r13, [$sp] ; push r0-r13
  362. push $r10 ; push orig_r10
  363. clear.d [$sp=$sp-4] ; frametype == 0, normal stackframe
  364. movs.w -ENOSYS, $r0
  365. move.d $r0, [$sp+PT_r10] ; put the default return value in r10 in the frame
  366. ;; check if this process is syscall-traced
  367. movs.w -8192, $r0 ; THREAD_SIZE == 8192
  368. and.d $sp, $r0
  369. move.d [$r0+TI_flags], $r0
  370. btstq TIF_SYSCALL_TRACE, $r0
  371. bmi _syscall_trace_entry
  372. nop
  373. _syscall_traced:
  374. ;; check for sanity in the requested syscall number
  375. cmpu.w NR_syscalls, $r9
  376. bcc ret_from_sys_call
  377. lslq 2, $r9 ; multiply by 4, in the delay slot
  378. ;; as a bonus 7th parameter, we give the location on the stack
  379. ;; of the register structure itself. some syscalls need this.
  380. push $sp
  381. ;; the parameter carrying registers r10, r11, r12 and 13 are intact.
  382. ;; the fifth and sixth parameters (if any) was in mof and srp
  383. ;; respectively, and we need to put them on the stack.
  384. push $srp
  385. push $mof
  386. jsr [$r9+sys_call_table] ; actually do the system call
  387. addq 3*4, $sp ; pop the mof, srp and regs parameters
  388. move.d $r10, [$sp+PT_r10] ; save the return value
  389. moveq 1, $r9 ; "parameter" to ret_from_sys_call to show it was a sys call
  390. ;; fall through into ret_from_sys_call to return
  391. ret_from_sys_call:
  392. ;; r9 is a parameter - if >=1 we came from a syscall, if 0, from an irq
  393. ;; get the current task-struct pointer (see top for defs)
  394. movs.w -8192, $r0 ; THREAD_SIZE == 8192
  395. and.d $sp, $r0
  396. di ; make sure need_resched and sigpending don't change
  397. move.d [$r0+TI_flags],$r1
  398. and.d _TIF_ALLWORK_MASK, $r1
  399. bne _syscall_exit_work
  400. nop
  401. _Rexit:
  402. ;; this epilogue MUST match the prologues in multiple_interrupt, irq.h and ptregs.h
  403. pop $r10 ; frametype
  404. bne _RBFexit ; was not CRIS_FRAME_NORMAL, handle otherwise
  405. addq 4, $sp ; skip orig_r10, in delayslot
  406. movem [$sp+], $r13 ; registers r0-r13
  407. pop $mof ; multiply overflow register
  408. pop $dccr ; condition codes
  409. pop $srp ; subroutine return pointer
  410. ;; now we have a 4-word SBFS frame which we do not want to restore
  411. ;; using RBF since it was not stacked with SBFS. instead we would like to
  412. ;; just get the PC value to restart it with, and skip the rest of
  413. ;; the frame.
  414. ;; Also notice that it's important to use instructions here that
  415. ;; keep the interrupts disabled (since we've already popped DCCR)
  416. move [$sp=$sp+16], $p8; pop the SBFS frame from the sp
  417. jmpu [$sp-16] ; return through the irp field in the sbfs frame
  418. _RBFexit:
  419. movem [$sp+], $r13 ; registers r0-r13, in delay slot
  420. pop $mof ; multiply overflow register
  421. pop $dccr ; condition codes
  422. pop $srp ; subroutine return pointer
  423. rbf [$sp+] ; return by popping the CPU status
  424. ;; We get here after doing a syscall if extra work might need to be done
  425. ;; perform syscall exit tracing if needed
  426. _syscall_exit_work:
  427. ;; $r0 contains current at this point and irq's are disabled
  428. move.d [$r0+TI_flags], $r1
  429. btstq TIF_SYSCALL_TRACE, $r1
  430. bpl _work_pending
  431. nop
  432. ei
  433. move.d $r9, $r1 ; preserve r9
  434. jsr do_syscall_trace
  435. move.d $r1, $r9
  436. ba _resume_userspace
  437. nop
  438. _work_pending:
  439. move.d [$r0+TI_flags], $r1
  440. btstq TIF_NEED_RESCHED, $r1
  441. bpl _work_notifysig ; was neither trace nor sched, must be signal/notify
  442. nop
  443. _work_resched:
  444. move.d $r9, $r1 ; preserve r9
  445. jsr schedule
  446. move.d $r1, $r9
  447. di
  448. move.d [$r0+TI_flags], $r1
  449. and.d _TIF_WORK_MASK, $r1; ignore the syscall trace counter
  450. beq _Rexit
  451. nop
  452. btstq TIF_NEED_RESCHED, $r1
  453. bmi _work_resched ; current->work.need_resched
  454. nop
  455. _work_notifysig:
  456. ;; deal with pending signals and notify-resume requests
  457. move.d $r9, $r10 ; do_notify_resume syscall/irq param
  458. moveq 0, $r11 ; oldset param - 0 in this case
  459. move.d $sp, $r12 ; the regs param
  460. move.d $r1, $r13 ; the thread_info_flags parameter
  461. jsr do_notify_resume
  462. ba _Rexit
  463. nop
  464. ;; We get here as a sidetrack when we've entered a syscall with the
  465. ;; trace-bit set. We need to call do_syscall_trace and then continue
  466. ;; with the call.
  467. _syscall_trace_entry:
  468. ;; PT_r10 in the frame contains -ENOSYS as required, at this point
  469. jsr do_syscall_trace
  470. ;; now re-enter the syscall code to do the syscall itself
  471. ;; we need to restore $r9 here to contain the wanted syscall, and
  472. ;; the other parameter-bearing registers
  473. move.d [$sp+PT_r9], $r9
  474. move.d [$sp+PT_orig_r10], $r10 ; PT_r10 is already filled with -ENOSYS.
  475. move.d [$sp+PT_r11], $r11
  476. move.d [$sp+PT_r12], $r12
  477. move.d [$sp+PT_r13], $r13
  478. move [$sp+PT_mof], $mof
  479. move [$sp+PT_srp], $srp
  480. ba _syscall_traced
  481. nop
  482. ;; resume performs the actual task-switching, by switching stack pointers
  483. ;; input arguments: r10 = prev, r11 = next, r12 = thread offset in task struct
  484. ;; returns old current in r10
  485. ;;
  486. ;; TODO: see the i386 version. The switch_to which calls resume in our version
  487. ;; could really be an inline asm of this.
  488. resume:
  489. push $srp ; we keep the old/new PC on the stack
  490. add.d $r12, $r10 ; r10 = current tasks tss
  491. move $dccr, [$r10+THREAD_dccr]; save irq enable state
  492. di
  493. move $usp, [$r10+ THREAD_usp] ; save user-mode stackpointer
  494. ;; See copy_thread for the reason why register R9 is saved.
  495. subq 10*4, $sp
  496. movem $r9, [$sp] ; save non-scratch registers and R9.
  497. move.d $sp, [$r10+THREAD_ksp] ; save the kernel stack pointer for the old task
  498. move.d $sp, $r10 ; return last running task in r10
  499. and.d -8192, $r10 ; get thread_info from stackpointer
  500. move.d [$r10+TI_task], $r10 ; get task
  501. add.d $r12, $r11 ; find the new tasks tss
  502. move.d [$r11+THREAD_ksp], $sp ; switch into the new stackframe by restoring kernel sp
  503. movem [$sp+], $r9 ; restore non-scratch registers and R9.
  504. move [$r11+THREAD_usp], $usp ; restore user-mode stackpointer
  505. move [$r11+THREAD_dccr], $dccr ; restore irq enable status
  506. jump [$sp+] ; restore PC
  507. ;; This is the MMU bus fault handler.
  508. ;; It needs to stack the CPU status and overall is different
  509. ;; from the other interrupt handlers.
  510. mmu_bus_fault:
  511. ;; For refills we try to do a quick page table lookup. If it is
  512. ;; a real fault we let the mm subsystem handle it.
  513. ;; the first longword in the sbfs frame was the interrupted PC
  514. ;; which fits nicely with the "IRP" slot in pt_regs normally used to
  515. ;; contain the return address. used by Oops to print kernel errors.
  516. sbfs [$sp=$sp-16] ; push the internal CPU status
  517. push $dccr
  518. di
  519. subq 2*4, $sp
  520. movem $r1, [$sp]
  521. move.d [R_MMU_CAUSE], $r1
  522. ;; ETRAX 100LX TR89 bugfix: if the second half of an unaligned
  523. ;; write causes a MMU-fault, it will not be restarted correctly.
  524. ;; This could happen if a write crosses a page-boundary and the
  525. ;; second page is not yet COW'ed or even loaded. The workaround
  526. ;; is to clear the unaligned bit in the CPU status record, so
  527. ;; that the CPU will rerun both the first and second halves of
  528. ;; the instruction. This will not have any sideeffects unless
  529. ;; the first half goes to any device or memory that can't be
  530. ;; written twice, and which is mapped through the MMU.
  531. ;;
  532. ;; We only need to do this for writes.
  533. btstq 8, $r1 ; Write access?
  534. bpl 1f
  535. nop
  536. move.d [$sp+16], $r0 ; Clear unaligned bit in csrinstr
  537. and.d ~(1<<5), $r0
  538. move.d $r0, [$sp+16]
  539. 1: btstq 12, $r1 ; Refill?
  540. bpl 2f
  541. lsrq 24, $r1 ; Get PGD index (bit 24-31)
  542. move.d [per_cpu__current_pgd], $r0 ; PGD for the current process
  543. move.d [$r0+$r1.d], $r0 ; Get PMD
  544. beq 2f
  545. nop
  546. and.w PAGE_MASK, $r0 ; Remove PMD flags
  547. move.d [R_MMU_CAUSE], $r1
  548. lsrq PAGE_SHIFT, $r1
  549. and.d 0x7ff, $r1 ; Get PTE index into PGD (bit 13-23)
  550. move.d [$r0+$r1.d], $r1 ; Get PTE
  551. beq 2f
  552. nop
  553. ;; Store in TLB
  554. move.d $r1, [R_TLB_LO]
  555. ;; Return
  556. movem [$sp+], $r1
  557. pop $dccr
  558. rbf [$sp+] ; return by popping the CPU status
  559. 2: ; PMD or PTE missing, let the mm subsystem fix it up.
  560. movem [$sp+], $r1
  561. pop $dccr
  562. ; Ok, not that easy, pass it on to the mm subsystem
  563. ; The MMU status record is now on the stack
  564. push $srp ; make a stackframe similar to pt_regs
  565. push $dccr
  566. push $mof
  567. di
  568. subq 14*4, $sp
  569. movem $r13, [$sp]
  570. push $r10 ; dummy orig_r10
  571. moveq 1, $r10
  572. push $r10 ; frametype == 1, BUSFAULT frame type
  573. move.d $sp, $r10 ; pt_regs argument to handle_mmu_bus_fault
  574. jsr handle_mmu_bus_fault ; in arch/cris/arch-v10/mm/fault.c
  575. ;; now we need to return through the normal path, we cannot just
  576. ;; do the RBFexit since we might have killed off the running
  577. ;; process due to a SEGV, scheduled due to a page blocking or
  578. ;; whatever.
  579. moveq 0, $r9 ; busfault is equivalent to an irq
  580. ba ret_from_intr
  581. nop
  582. ;; special handlers for breakpoint and NMI
  583. hwbreakpoint:
  584. push $dccr
  585. di
  586. push $r10
  587. push $r11
  588. move.d [hw_bp_trig_ptr],$r10
  589. move $brp,$r11
  590. move.d $r11,[$r10+]
  591. move.d $r10,[hw_bp_trig_ptr]
  592. 1: pop $r11
  593. pop $r10
  594. pop $dccr
  595. retb
  596. nop
  597. IRQ1_interrupt:
  598. ;; this prologue MUST match the one in irq.h and the struct in ptregs.h!!!
  599. move $brp,[$sp=$sp-16]; instruction pointer and room for a fake SBFS frame
  600. push $srp
  601. push $dccr
  602. push $mof
  603. di
  604. subq 14*4, $sp
  605. movem $r13, [$sp]
  606. push $r10 ; push orig_r10
  607. clear.d [$sp=$sp-4] ; frametype == 0, normal frame
  608. move.d [R_IRQ_MASK0_RD], $r1 ; External NMI or watchdog?
  609. and.d 0x80000000, $r1
  610. beq wdog
  611. move.d $sp, $r10
  612. jsr handle_nmi
  613. setf m ; Enable NMI again
  614. retb ; Return from NMI
  615. nop
  616. wdog:
  617. #if defined(CONFIG_ETRAX_WATCHDOG) && !defined(CONFIG_SVINTO_SIM)
  618. ;; Check if we're waiting for reset to happen, as signalled by
  619. ;; hard_reset_now setting cause_of_death to a magic value. If so, just
  620. ;; get stuck until reset happens.
  621. .comm cause_of_death, 4 ;; Don't declare this anywhere.
  622. move.d [cause_of_death], $r10
  623. cmp.d 0xbedead, $r10
  624. _killed_by_death:
  625. beq _killed_by_death
  626. nop
  627. ;; We'll see this in ksymoops dumps.
  628. Watchdog_bite:
  629. #ifdef CONFIG_ETRAX_WATCHDOG_NICE_DOGGY
  630. ;; We just restart the watchdog here to be sure we dont get
  631. ;; hit while printing the watchdogmsg below
  632. ;; This restart is compatible with the rest of the C-code, so
  633. ;; the C-code can keep restarting the watchdog after this point.
  634. ;; The non-NICE_DOGGY code below though, disables the possibility
  635. ;; to restart since it changes the watchdog key, to avoid any
  636. ;; buggy loops etc. keeping the watchdog alive after this.
  637. jsr reset_watchdog
  638. #else
  639. ;; We need to extend the 3.3ms after the NMI at watchdog bite, so we have
  640. ;; time for an oops-dump over a 115k2 serial wire. Another 100ms should do.
  641. ;; Change the watchdog key to an arbitrary 3-bit value and restart the
  642. ;; watchdog.
  643. #define WD_INIT 2
  644. moveq IO_FIELD (R_WATCHDOG, key, WD_INIT), $r10
  645. move.d R_WATCHDOG, $r11
  646. move.d $r10, [$r11]
  647. moveq IO_FIELD (R_WATCHDOG, key, \
  648. IO_EXTRACT (R_WATCHDOG, key, \
  649. IO_MASK (R_WATCHDOG, key)) \
  650. ^ WD_INIT) \
  651. | IO_STATE (R_WATCHDOG, enable, start), $r10
  652. move.d $r10, [$r11]
  653. #endif
  654. ;; Note that we don't do "setf m" here (or after two necessary NOPs),
  655. ;; since *not* doing that saves us from re-entrancy checks. We don't want
  656. ;; to get here again due to possible subsequent NMIs; we want the watchdog
  657. ;; to reset us.
  658. move.d _watchdogmsg,$r10
  659. jsr printk
  660. move.d $sp, $r10
  661. jsr watchdog_bite_hook
  662. ;; This nop is here so we see the "Watchdog_bite" label in ksymoops dumps
  663. ;; rather than "spurious_interrupt".
  664. nop
  665. ;; At this point we drop down into spurious_interrupt, which will do a
  666. ;; hard reset.
  667. .section .rodata,"a"
  668. _watchdogmsg:
  669. .ascii "Oops: bitten by watchdog\n\0"
  670. .previous
  671. #endif /* CONFIG_ETRAX_WATCHDOG and not CONFIG_SVINTO_SIM */
  672. spurious_interrupt:
  673. di
  674. jump hard_reset_now
  675. ;; this handles the case when multiple interrupts arrive at the same time
  676. ;; we jump to the first set interrupt bit in a priority fashion
  677. ;; the hardware will call the unserved interrupts after the handler finishes
  678. multiple_interrupt:
  679. ;; this prologue MUST match the one in irq.h and the struct in ptregs.h!!!
  680. move $irp,[$sp=$sp-16]; instruction pointer and room for a fake SBFS frame
  681. push $srp
  682. push $dccr
  683. push $mof
  684. di
  685. subq 14*4, $sp
  686. movem $r13, [$sp]
  687. push $r10 ; push orig_r10
  688. clear.d [$sp=$sp-4] ; frametype == 0, normal frame
  689. moveq 2, $r2 ; first bit we care about is the timer0 irq
  690. move.d [R_VECT_MASK_RD], $r0; read the irq bits that triggered the multiple irq
  691. move.d $r0, [R_VECT_MASK_CLR] ; Block all active IRQs
  692. 1:
  693. btst $r2, $r0 ; check for the irq given by bit r2
  694. bpl 2f
  695. move.d $r2, $r10 ; First argument to do_IRQ
  696. move.d $sp, $r11 ; second argument to do_IRQ
  697. jsr do_IRQ
  698. 2:
  699. addq 1, $r2 ; next vector bit
  700. cmp.b 32, $r2
  701. bne 1b ; process all irq's up to and including number 31
  702. moveq 0, $r9 ; make ret_from_intr realise we came from an ir
  703. move.d $r0, [R_VECT_MASK_SET] ; Unblock all the IRQs
  704. jump ret_from_intr
  705. do_sigtrap:
  706. ;;
  707. ;; SIGTRAP the process that executed the break instruction.
  708. ;; Make a frame that Rexit in entry.S expects.
  709. ;;
  710. move $brp, [$sp=$sp-16] ; Push BRP while faking a cpu status record.
  711. push $srp ; Push subroutine return pointer.
  712. push $dccr ; Push condition codes.
  713. push $mof ; Push multiply overflow reg.
  714. di ; Need to disable irq's at this point.
  715. subq 14*4, $sp ; Make room for r0-r13.
  716. movem $r13, [$sp] ; Push the r0-r13 registers.
  717. push $r10 ; Push orig_r10.
  718. clear.d [$sp=$sp-4] ; Frametype - this is a normal stackframe.
  719. movs.w -8192,$r9 ; THREAD_SIZE == 8192
  720. and.d $sp, $r9
  721. move.d [$r9+TI_task], $r10
  722. move.d [$r10+TASK_pid], $r10 ; current->pid as arg1.
  723. moveq 5, $r11 ; SIGTRAP as arg2.
  724. jsr sys_kill
  725. jump ret_from_intr ; Use the return routine for interrupts.
  726. gdb_handle_breakpoint:
  727. push $dccr
  728. push $r0
  729. #ifdef CONFIG_ETRAX_KGDB
  730. move $dccr, $r0 ; U-flag not affected by previous insns.
  731. btstq 8, $r0 ; Test the U-flag.
  732. bmi _ugdb_handle_breakpoint ; Go to user mode debugging.
  733. nop ; Empty delay slot (cannot pop r0 here).
  734. pop $r0 ; Restore r0.
  735. ba kgdb_handle_breakpoint ; Go to kernel debugging.
  736. pop $dccr ; Restore dccr in delay slot.
  737. #endif
  738. _ugdb_handle_breakpoint:
  739. move $brp, $r0 ; Use r0 temporarily for calculation.
  740. subq 2, $r0 ; Set to address of previous instruction.
  741. move $r0, $brp
  742. pop $r0 ; Restore r0.
  743. ba do_sigtrap ; SIGTRAP the offending process.
  744. pop $dccr ; Restore dccr in delay slot.
  745. .data
  746. hw_bp_trigs:
  747. .space 64*4
  748. hw_bp_trig_ptr:
  749. .dword hw_bp_trigs
  750. .section .rodata,"a"
  751. sys_call_table:
  752. .long sys_restart_syscall /* 0 - old "setup()" system call, used for restarting */
  753. .long sys_exit
  754. .long sys_fork
  755. .long sys_read
  756. .long sys_write
  757. .long sys_open /* 5 */
  758. .long sys_close
  759. .long sys_waitpid
  760. .long sys_creat
  761. .long sys_link
  762. .long sys_unlink /* 10 */
  763. .long sys_execve
  764. .long sys_chdir
  765. .long sys_time
  766. .long sys_mknod
  767. .long sys_chmod /* 15 */
  768. .long sys_lchown16
  769. .long sys_ni_syscall /* old break syscall holder */
  770. .long sys_stat
  771. .long sys_lseek
  772. .long sys_getpid /* 20 */
  773. .long sys_mount
  774. .long sys_oldumount
  775. .long sys_setuid16
  776. .long sys_getuid16
  777. .long sys_stime /* 25 */
  778. .long sys_ptrace
  779. .long sys_alarm
  780. .long sys_fstat
  781. .long sys_pause
  782. .long sys_utime /* 30 */
  783. .long sys_ni_syscall /* old stty syscall holder */
  784. .long sys_ni_syscall /* old gtty syscall holder */
  785. .long sys_access
  786. .long sys_nice
  787. .long sys_ni_syscall /* 35 old ftime syscall holder */
  788. .long sys_sync
  789. .long sys_kill
  790. .long sys_rename
  791. .long sys_mkdir
  792. .long sys_rmdir /* 40 */
  793. .long sys_dup
  794. .long sys_pipe
  795. .long sys_times
  796. .long sys_ni_syscall /* old prof syscall holder */
  797. .long sys_brk /* 45 */
  798. .long sys_setgid16
  799. .long sys_getgid16
  800. .long sys_signal
  801. .long sys_geteuid16
  802. .long sys_getegid16 /* 50 */
  803. .long sys_acct
  804. .long sys_umount /* recycled never used phys( */
  805. .long sys_ni_syscall /* old lock syscall holder */
  806. .long sys_ioctl
  807. .long sys_fcntl /* 55 */
  808. .long sys_ni_syscall /* old mpx syscall holder */
  809. .long sys_setpgid
  810. .long sys_ni_syscall /* old ulimit syscall holder */
  811. .long sys_ni_syscall /* old sys_olduname holder */
  812. .long sys_umask /* 60 */
  813. .long sys_chroot
  814. .long sys_ustat
  815. .long sys_dup2
  816. .long sys_getppid
  817. .long sys_getpgrp /* 65 */
  818. .long sys_setsid
  819. .long sys_sigaction
  820. .long sys_sgetmask
  821. .long sys_ssetmask
  822. .long sys_setreuid16 /* 70 */
  823. .long sys_setregid16
  824. .long sys_sigsuspend
  825. .long sys_sigpending
  826. .long sys_sethostname
  827. .long sys_setrlimit /* 75 */
  828. .long sys_old_getrlimit
  829. .long sys_getrusage
  830. .long sys_gettimeofday
  831. .long sys_settimeofday
  832. .long sys_getgroups16 /* 80 */
  833. .long sys_setgroups16
  834. .long sys_select /* was old_select in Linux/E100 */
  835. .long sys_symlink
  836. .long sys_lstat
  837. .long sys_readlink /* 85 */
  838. .long sys_uselib
  839. .long sys_swapon
  840. .long sys_reboot
  841. .long old_readdir
  842. .long old_mmap /* 90 */
  843. .long sys_munmap
  844. .long sys_truncate
  845. .long sys_ftruncate
  846. .long sys_fchmod
  847. .long sys_fchown16 /* 95 */
  848. .long sys_getpriority
  849. .long sys_setpriority
  850. .long sys_ni_syscall /* old profil syscall holder */
  851. .long sys_statfs
  852. .long sys_fstatfs /* 100 */
  853. .long sys_ni_syscall /* sys_ioperm in i386 */
  854. .long sys_socketcall
  855. .long sys_syslog
  856. .long sys_setitimer
  857. .long sys_getitimer /* 105 */
  858. .long sys_newstat
  859. .long sys_newlstat
  860. .long sys_newfstat
  861. .long sys_ni_syscall /* old sys_uname holder */
  862. .long sys_ni_syscall /* sys_iopl in i386 */
  863. .long sys_vhangup
  864. .long sys_ni_syscall /* old "idle" system call */
  865. .long sys_ni_syscall /* vm86old in i386 */
  866. .long sys_wait4
  867. .long sys_swapoff /* 115 */
  868. .long sys_sysinfo
  869. .long sys_ipc
  870. .long sys_fsync
  871. .long sys_sigreturn
  872. .long sys_clone /* 120 */
  873. .long sys_setdomainname
  874. .long sys_newuname
  875. .long sys_ni_syscall /* sys_modify_ldt */
  876. .long sys_adjtimex
  877. .long sys_mprotect /* 125 */
  878. .long sys_sigprocmask
  879. .long sys_ni_syscall /* old "create_module" */
  880. .long sys_init_module
  881. .long sys_delete_module
  882. .long sys_ni_syscall /* 130: old "get_kernel_syms" */
  883. .long sys_quotactl
  884. .long sys_getpgid
  885. .long sys_fchdir
  886. .long sys_bdflush
  887. .long sys_sysfs /* 135 */
  888. .long sys_personality
  889. .long sys_ni_syscall /* for afs_syscall */
  890. .long sys_setfsuid16
  891. .long sys_setfsgid16
  892. .long sys_llseek /* 140 */
  893. .long sys_getdents
  894. .long sys_select
  895. .long sys_flock
  896. .long sys_msync
  897. .long sys_readv /* 145 */
  898. .long sys_writev
  899. .long sys_getsid
  900. .long sys_fdatasync
  901. .long sys_sysctl
  902. .long sys_mlock /* 150 */
  903. .long sys_munlock
  904. .long sys_mlockall
  905. .long sys_munlockall
  906. .long sys_sched_setparam
  907. .long sys_sched_getparam /* 155 */
  908. .long sys_sched_setscheduler
  909. .long sys_sched_getscheduler
  910. .long sys_sched_yield
  911. .long sys_sched_get_priority_max
  912. .long sys_sched_get_priority_min /* 160 */
  913. .long sys_sched_rr_get_interval
  914. .long sys_nanosleep
  915. .long sys_mremap
  916. .long sys_setresuid16
  917. .long sys_getresuid16 /* 165 */
  918. .long sys_ni_syscall /* sys_vm86 */
  919. .long sys_ni_syscall /* Old sys_query_module */
  920. .long sys_poll
  921. .long sys_nfsservctl
  922. .long sys_setresgid16 /* 170 */
  923. .long sys_getresgid16
  924. .long sys_prctl
  925. .long sys_rt_sigreturn
  926. .long sys_rt_sigaction
  927. .long sys_rt_sigprocmask /* 175 */
  928. .long sys_rt_sigpending
  929. .long sys_rt_sigtimedwait
  930. .long sys_rt_sigqueueinfo
  931. .long sys_rt_sigsuspend
  932. .long sys_pread64 /* 180 */
  933. .long sys_pwrite64
  934. .long sys_chown16
  935. .long sys_getcwd
  936. .long sys_capget
  937. .long sys_capset /* 185 */
  938. .long sys_sigaltstack
  939. .long sys_sendfile
  940. .long sys_ni_syscall /* streams1 */
  941. .long sys_ni_syscall /* streams2 */
  942. .long sys_vfork /* 190 */
  943. .long sys_getrlimit
  944. .long sys_mmap2
  945. .long sys_truncate64
  946. .long sys_ftruncate64
  947. .long sys_stat64 /* 195 */
  948. .long sys_lstat64
  949. .long sys_fstat64
  950. .long sys_lchown
  951. .long sys_getuid
  952. .long sys_getgid /* 200 */
  953. .long sys_geteuid
  954. .long sys_getegid
  955. .long sys_setreuid
  956. .long sys_setregid
  957. .long sys_getgroups /* 205 */
  958. .long sys_setgroups
  959. .long sys_fchown
  960. .long sys_setresuid
  961. .long sys_getresuid
  962. .long sys_setresgid /* 210 */
  963. .long sys_getresgid
  964. .long sys_chown
  965. .long sys_setuid
  966. .long sys_setgid
  967. .long sys_setfsuid /* 215 */
  968. .long sys_setfsgid
  969. .long sys_pivot_root
  970. .long sys_mincore
  971. .long sys_madvise
  972. .long sys_getdents64 /* 220 */
  973. .long sys_fcntl64
  974. .long sys_ni_syscall /* reserved for TUX */
  975. .long sys_ni_syscall
  976. .long sys_gettid
  977. .long sys_readahead /* 225 */
  978. .long sys_setxattr
  979. .long sys_lsetxattr
  980. .long sys_fsetxattr
  981. .long sys_getxattr
  982. .long sys_lgetxattr /* 230 */
  983. .long sys_fgetxattr
  984. .long sys_listxattr
  985. .long sys_llistxattr
  986. .long sys_flistxattr
  987. .long sys_removexattr /* 235 */
  988. .long sys_lremovexattr
  989. .long sys_fremovexattr
  990. .long sys_tkill
  991. .long sys_sendfile64
  992. .long sys_futex /* 240 */
  993. .long sys_sched_setaffinity
  994. .long sys_sched_getaffinity
  995. .long sys_ni_syscall /* sys_set_thread_area */
  996. .long sys_ni_syscall /* sys_get_thread_area */
  997. .long sys_io_setup /* 245 */
  998. .long sys_io_destroy
  999. .long sys_io_getevents
  1000. .long sys_io_submit
  1001. .long sys_io_cancel
  1002. .long sys_fadvise64 /* 250 */
  1003. .long sys_ni_syscall
  1004. .long sys_exit_group
  1005. .long sys_lookup_dcookie
  1006. .long sys_epoll_create
  1007. .long sys_epoll_ctl /* 255 */
  1008. .long sys_epoll_wait
  1009. .long sys_remap_file_pages
  1010. .long sys_set_tid_address
  1011. .long sys_timer_create
  1012. .long sys_timer_settime /* 260 */
  1013. .long sys_timer_gettime
  1014. .long sys_timer_getoverrun
  1015. .long sys_timer_delete
  1016. .long sys_clock_settime
  1017. .long sys_clock_gettime /* 265 */
  1018. .long sys_clock_getres
  1019. .long sys_clock_nanosleep
  1020. .long sys_statfs64
  1021. .long sys_fstatfs64
  1022. .long sys_tgkill /* 270 */
  1023. .long sys_utimes
  1024. .long sys_fadvise64_64
  1025. .long sys_ni_syscall /* sys_vserver */
  1026. .long sys_ni_syscall /* sys_mbind */
  1027. .long sys_ni_syscall /* 275 sys_get_mempolicy */
  1028. .long sys_ni_syscall /* sys_set_mempolicy */
  1029. .long sys_mq_open
  1030. .long sys_mq_unlink
  1031. .long sys_mq_timedsend
  1032. .long sys_mq_timedreceive /* 280 */
  1033. .long sys_mq_notify
  1034. .long sys_mq_getsetattr
  1035. .long sys_ni_syscall /* reserved for kexec */
  1036. .long sys_waitid
  1037. .long sys_ni_syscall /* 285 */ /* available */
  1038. .long sys_add_key
  1039. .long sys_request_key
  1040. .long sys_keyctl
  1041. /*
  1042. * NOTE!! This doesn't have to be exact - we just have
  1043. * to make sure we have _enough_ of the "sys_ni_syscall"
  1044. * entries. Don't panic if you notice that this hasn't
  1045. * been shrunk every time we add a new system call.
  1046. */
  1047. .rept NR_syscalls-(.-sys_call_table)/4
  1048. .long sys_ni_syscall
  1049. .endr