entry.S 26 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006
  1. /*
  2. * linux/arch/m32r/kernel/entry.S
  3. *
  4. * Copyright (c) 2001, 2002 Hirokazu Takata, Hitoshi Yamamoto, H. Kondo
  5. * Copyright (c) 2003 Hitoshi Yamamoto
  6. * Copyright (c) 2004 Hirokazu Takata <takata at linux-m32r.org>
  7. *
  8. * Taken from i386 version.
  9. * Copyright (C) 1991, 1992 Linus Torvalds
  10. */
  11. /*
  12. * entry.S contains the system-call and fault low-level handling routines.
  13. * This also contains the timer-interrupt handler, as well as all interrupts
  14. * and faults that can result in a task-switch.
  15. *
  16. * NOTE: This code handles signal-recognition, which happens every time
  17. * after a timer-interrupt and after each system call.
  18. *
  19. * Stack layout in 'ret_from_system_call':
  20. * ptrace needs to have all regs on the stack.
  21. * if the order here is changed, it needs to be
  22. * updated in fork.c:copy_thread, signal.c:do_signal,
  23. * ptrace.c and ptrace.h
  24. *
  25. * M32Rx/M32R2 M32R
  26. * @(sp) - r4 ditto
  27. * @(0x04,sp) - r5 ditto
  28. * @(0x08,sp) - r6 ditto
  29. * @(0x0c,sp) - *pt_regs ditto
  30. * @(0x10,sp) - r0 ditto
  31. * @(0x14,sp) - r1 ditto
  32. * @(0x18,sp) - r2 ditto
  33. * @(0x1c,sp) - r3 ditto
  34. * @(0x20,sp) - r7 ditto
  35. * @(0x24,sp) - r8 ditto
  36. * @(0x28,sp) - r9 ditto
  37. * @(0x2c,sp) - r10 ditto
  38. * @(0x30,sp) - r11 ditto
  39. * @(0x34,sp) - r12 ditto
  40. * @(0x38,sp) - syscall_nr ditto
  41. * @(0x3c,sp) - acc0h @(0x3c,sp) - acch
  42. * @(0x40,sp) - acc0l @(0x40,sp) - accl
  43. * @(0x44,sp) - acc1h @(0x44,sp) - dummy_acc1h
  44. * @(0x48,sp) - acc1l @(0x48,sp) - dummy_acc1l
  45. * @(0x4c,sp) - psw ditto
  46. * @(0x50,sp) - bpc ditto
  47. * @(0x54,sp) - bbpsw ditto
  48. * @(0x58,sp) - bbpc ditto
  49. * @(0x5c,sp) - spu (cr3) ditto
  50. * @(0x60,sp) - fp (r13) ditto
  51. * @(0x64,sp) - lr (r14) ditto
  52. * @(0x68,sp) - spi (cr2) ditto
  53. * @(0x6c,sp) - orig_r0 ditto
  54. */
  55. #include <linux/linkage.h>
  56. #include <asm/irq.h>
  57. #include <asm/unistd.h>
  58. #include <asm/assembler.h>
  59. #include <asm/thread_info.h>
  60. #include <asm/errno.h>
  61. #include <asm/segment.h>
  62. #include <asm/smp.h>
  63. #include <asm/page.h>
  64. #include <asm/m32r.h>
  65. #include <asm/mmu_context.h>
  66. #if !defined(CONFIG_MMU)
  67. #define sys_madvise sys_ni_syscall
  68. #define sys_readahead sys_ni_syscall
  69. #define sys_mprotect sys_ni_syscall
  70. #define sys_msync sys_ni_syscall
  71. #define sys_mlock sys_ni_syscall
  72. #define sys_munlock sys_ni_syscall
  73. #define sys_mlockall sys_ni_syscall
  74. #define sys_munlockall sys_ni_syscall
  75. #define sys_mremap sys_ni_syscall
  76. #define sys_mincore sys_ni_syscall
  77. #define sys_remap_file_pages sys_ni_syscall
  78. #endif /* CONFIG_MMU */
  79. #define R4(reg) @reg
  80. #define R5(reg) @(0x04,reg)
  81. #define R6(reg) @(0x08,reg)
  82. #define PTREGS(reg) @(0x0C,reg)
  83. #define R0(reg) @(0x10,reg)
  84. #define R1(reg) @(0x14,reg)
  85. #define R2(reg) @(0x18,reg)
  86. #define R3(reg) @(0x1C,reg)
  87. #define R7(reg) @(0x20,reg)
  88. #define R8(reg) @(0x24,reg)
  89. #define R9(reg) @(0x28,reg)
  90. #define R10(reg) @(0x2C,reg)
  91. #define R11(reg) @(0x30,reg)
  92. #define R12(reg) @(0x34,reg)
  93. #define SYSCALL_NR(reg) @(0x38,reg)
  94. #if defined(CONFIG_ISA_M32R2) && defined(CONFIG_ISA_DSP_LEVEL2)
  95. #define ACC0H(reg) @(0x3C,reg)
  96. #define ACC0L(reg) @(0x40,reg)
  97. #define ACC1H(reg) @(0x44,reg)
  98. #define ACC1L(reg) @(0x48,reg)
  99. #elif defined(CONFIG_ISA_M32R2) || defined(CONFIG_ISA_M32R)
  100. #define ACCH(reg) @(0x3C,reg)
  101. #define ACCL(reg) @(0x40,reg)
  102. #else
  103. #error unknown isa configuration
  104. #endif
  105. #define PSW(reg) @(0x4C,reg)
  106. #define BPC(reg) @(0x50,reg)
  107. #define BBPSW(reg) @(0x54,reg)
  108. #define BBPC(reg) @(0x58,reg)
  109. #define SPU(reg) @(0x5C,reg)
  110. #define FP(reg) @(0x60,reg) /* FP = R13 */
  111. #define LR(reg) @(0x64,reg)
  112. #define SP(reg) @(0x68,reg)
  113. #define ORIG_R0(reg) @(0x6C,reg)
  114. CF_MASK = 0x00000001
  115. TF_MASK = 0x00000100
  116. IF_MASK = 0x00000200
  117. DF_MASK = 0x00000400
  118. NT_MASK = 0x00004000
  119. VM_MASK = 0x00020000
  120. #ifdef CONFIG_PREEMPT
  121. #define preempt_stop(x) CLI(x)
  122. #else
  123. #define preempt_stop(x)
  124. #define resume_kernel restore_all
  125. #endif
  126. ENTRY(ret_from_fork)
  127. pop r0
  128. bl schedule_tail
  129. GET_THREAD_INFO(r8)
  130. bra syscall_exit
  131. /*
  132. * Return to user mode is not as complex as all this looks,
  133. * but we want the default path for a system call return to
  134. * go as quickly as possible which is why some of this is
  135. * less clear than it otherwise should be.
  136. */
  137. ; userspace resumption stub bypassing syscall exit tracing
  138. ALIGN
  139. ret_from_exception:
  140. preempt_stop(r4)
  141. ret_from_intr:
  142. ld r4, PSW(sp)
  143. #ifdef CONFIG_ISA_M32R2
  144. and3 r4, r4, #0x8800 ; check BSM and BPM bits
  145. #else
  146. and3 r4, r4, #0x8000 ; check BSM bit
  147. #endif
  148. beqz r4, resume_kernel
  149. ENTRY(resume_userspace)
  150. CLI(r4) ; make sure we don't miss an interrupt
  151. ; setting need_resched or sigpending
  152. ; between sampling and the iret
  153. GET_THREAD_INFO(r8)
  154. ld r9, @(TI_FLAGS, r8)
  155. and3 r4, r9, #_TIF_WORK_MASK ; is there any work to be done on
  156. ; int/exception return?
  157. bnez r4, work_pending
  158. bra restore_all
  159. #ifdef CONFIG_PREEMPT
  160. ENTRY(resume_kernel)
  161. GET_THREAD_INFO(r8)
  162. ld r9, @(TI_PRE_COUNT, r8) ; non-zero preempt_count ?
  163. bnez r9, restore_all
  164. need_resched:
  165. ld r9, @(TI_FLAGS, r8) ; need_resched set ?
  166. and3 r4, r9, #_TIF_NEED_RESCHED
  167. beqz r4, restore_all
  168. ld r4, PSW(sp) ; interrupts off (exception path) ?
  169. and3 r4, r4, #0x4000
  170. beqz r4, restore_all
  171. LDIMM (r4, PREEMPT_ACTIVE)
  172. st r4, @(TI_PRE_COUNT, r8)
  173. STI(r4)
  174. bl schedule
  175. ldi r4, #0
  176. st r4, @(TI_PRE_COUNT, r8)
  177. CLI(r4)
  178. bra need_resched
  179. #endif
  180. ; system call handler stub
  181. ENTRY(system_call)
  182. SWITCH_TO_KERNEL_STACK
  183. SAVE_ALL
  184. STI(r4) ; Enable interrupt
  185. st sp, PTREGS(sp) ; implicit pt_regs parameter
  186. cmpui r7, #NR_syscalls
  187. bnc syscall_badsys
  188. st r7, SYSCALL_NR(sp) ; syscall_nr
  189. ; system call tracing in operation
  190. GET_THREAD_INFO(r8)
  191. ld r9, @(TI_FLAGS, r8)
  192. and3 r4, r9, #_TIF_SYSCALL_TRACE
  193. bnez r4, syscall_trace_entry
  194. syscall_call:
  195. slli r7, #2 ; table jump for the system call
  196. LDIMM (r4, sys_call_table)
  197. add r7, r4
  198. ld r7, @r7
  199. jl r7 ; execute system call
  200. st r0, R0(sp) ; save the return value
  201. syscall_exit:
  202. CLI(r4) ; make sure we don't miss an interrupt
  203. ; setting need_resched or sigpending
  204. ; between sampling and the iret
  205. ld r9, @(TI_FLAGS, r8)
  206. and3 r4, r9, #_TIF_ALLWORK_MASK ; current->work
  207. bnez r4, syscall_exit_work
  208. restore_all:
  209. RESTORE_ALL
  210. # perform work that needs to be done immediately before resumption
  211. # r9 : flags
  212. ALIGN
  213. work_pending:
  214. and3 r4, r9, #_TIF_NEED_RESCHED
  215. beqz r4, work_notifysig
  216. work_resched:
  217. bl schedule
  218. CLI(r4) ; make sure we don't miss an interrupt
  219. ; setting need_resched or sigpending
  220. ; between sampling and the iret
  221. ld r9, @(TI_FLAGS, r8)
  222. and3 r4, r9, #_TIF_WORK_MASK ; is there any work to be done other
  223. ; than syscall tracing?
  224. beqz r4, restore_all
  225. and3 r4, r4, #_TIF_NEED_RESCHED
  226. bnez r4, work_resched
  227. work_notifysig: ; deal with pending signals and
  228. ; notify-resume requests
  229. mv r0, sp ; arg1 : struct pt_regs *regs
  230. ldi r1, #0 ; arg2 : sigset_t *oldset
  231. mv r2, r9 ; arg3 : __u32 thread_info_flags
  232. bl do_notify_resume
  233. bra restore_all
  234. ; perform syscall exit tracing
  235. ALIGN
  236. syscall_trace_entry:
  237. ldi r4, #-ENOSYS
  238. st r4, R0(sp)
  239. bl do_syscall_trace
  240. ld r0, ORIG_R0(sp)
  241. ld r1, R1(sp)
  242. ld r2, R2(sp)
  243. ld r3, R3(sp)
  244. ld r4, R4(sp)
  245. ld r5, R5(sp)
  246. ld r6, R6(sp)
  247. ld r7, SYSCALL_NR(sp)
  248. cmpui r7, #NR_syscalls
  249. bc syscall_call
  250. bra syscall_exit
  251. ; perform syscall exit tracing
  252. ALIGN
  253. syscall_exit_work:
  254. ld r9, @(TI_FLAGS, r8)
  255. and3 r4, r9, #_TIF_SYSCALL_TRACE
  256. beqz r4, work_pending
  257. STI(r4) ; could let do_syscall_trace() call
  258. ; schedule() instead
  259. bl do_syscall_trace
  260. bra resume_userspace
  261. ALIGN
  262. syscall_fault:
  263. SAVE_ALL
  264. GET_THREAD_INFO(r8)
  265. ldi r4, #-EFAULT
  266. st r4, R0(sp)
  267. bra resume_userspace
  268. ALIGN
  269. syscall_badsys:
  270. ldi r4, #-ENOSYS
  271. st r4, R0(sp)
  272. bra resume_userspace
  273. .global eit_vector
  274. .equ ei_vec_table, eit_vector + 0x0200
  275. /*
  276. * EI handler routine
  277. */
  278. ENTRY(ei_handler)
  279. #if defined(CONFIG_CHIP_M32700)
  280. SWITCH_TO_KERNEL_STACK
  281. ; WORKAROUND: force to clear SM bit and use the kernel stack (SPI).
  282. #endif
  283. SAVE_ALL
  284. mv r1, sp ; arg1(regs)
  285. #if defined(CONFIG_CHIP_VDEC2) || defined(CONFIG_CHIP_XNUX2) \
  286. || defined(CONFIG_CHIP_M32700) || defined(CONFIG_CHIP_M32102) \
  287. || defined(CONFIG_CHIP_OPSP) || defined(CONFIG_CHIP_M32104)
  288. ; GET_ICU_STATUS;
  289. seth r0, #shigh(M32R_ICU_ISTS_ADDR)
  290. ld r0, @(low(M32R_ICU_ISTS_ADDR),r0)
  291. push r0
  292. #if defined(CONFIG_SMP)
  293. /*
  294. * If IRQ == 0 --> Nothing to do, Not write IMASK
  295. * If IRQ == IPI --> Do IPI handler, Not write IMASK
  296. * If IRQ != 0, IPI --> Do do_IRQ(), Write IMASK
  297. */
  298. slli r0, #4
  299. srli r0, #24 ; r0(irq_num<<2)
  300. ;; IRQ exist check
  301. #if defined(CONFIG_CHIP_M32700)
  302. /* WORKAROUND: IMASK bug M32700-TS1, TS2 chip. */
  303. beqz r0, 3f ; if (!irq_num) goto exit
  304. #else
  305. beqz r0, 1f ; if (!irq_num) goto exit
  306. #endif /* WORKAROUND */
  307. ;; IPI check
  308. cmpi r0, #(M32R_IRQ_IPI0<<2) ; ISN < IPI0 check
  309. bc 2f
  310. cmpi r0, #((M32R_IRQ_IPI7+1)<<2) ; ISN > IPI7 check
  311. bnc 2f
  312. LDIMM (r2, ei_vec_table)
  313. add r2, r0
  314. ld r2, @r2
  315. beqz r2, 1f ; if (no IPI handler) goto exit
  316. mv r0, r1 ; arg0(regs)
  317. jl r2
  318. .fillinsn
  319. 1:
  320. addi sp, #4
  321. bra ret_to_intr
  322. #if defined(CONFIG_CHIP_M32700)
  323. /* WORKAROUND: IMASK bug M32700-TS1, TS2 chip. */
  324. .fillinsn
  325. 3:
  326. ld24 r14, #0x00070000
  327. seth r0, #shigh(M32R_ICU_IMASK_ADDR)
  328. st r14, @(low(M32R_ICU_IMASK_ADDR), r0)
  329. addi sp, #4
  330. bra ret_to_intr
  331. #endif /* WORKAROUND */
  332. ;; do_IRQ
  333. .fillinsn
  334. 2:
  335. srli r0, #2
  336. #if defined(CONFIG_PLAT_USRV)
  337. add3 r2, r0, #-(M32R_IRQ_INT1) ; INT1# interrupt
  338. bnez r2, 9f
  339. ; read ICU status register of PLD
  340. seth r0, #high(PLD_ICUISTS)
  341. or3 r0, r0, #low(PLD_ICUISTS)
  342. lduh r0, @r0
  343. slli r0, #21
  344. srli r0, #27 ; ISN
  345. addi r0, #(M32700UT_PLD_IRQ_BASE)
  346. .fillinsn
  347. 9:
  348. #elif defined(CONFIG_PLAT_M32700UT)
  349. add3 r2, r0, #-(M32R_IRQ_INT1) ; INT1# interrupt
  350. bnez r2, check_int0
  351. ; read ICU status register of PLD
  352. seth r0, #high(PLD_ICUISTS)
  353. or3 r0, r0, #low(PLD_ICUISTS)
  354. lduh r0, @r0
  355. slli r0, #21
  356. srli r0, #27 ; ISN
  357. addi r0, #(M32700UT_PLD_IRQ_BASE)
  358. bra check_end
  359. .fillinsn
  360. check_int0:
  361. add3 r2, r0, #-(M32R_IRQ_INT0) ; INT0# interrupt
  362. bnez r2, check_int2
  363. ; read ICU status of LAN-board
  364. seth r0, #high(M32700UT_LAN_ICUISTS)
  365. or3 r0, r0, #low(M32700UT_LAN_ICUISTS)
  366. lduh r0, @r0
  367. slli r0, #21
  368. srli r0, #27 ; ISN
  369. add3 r0, r0, #(M32700UT_LAN_PLD_IRQ_BASE)
  370. bra check_end
  371. .fillinsn
  372. check_int2:
  373. add3 r2, r0, #-(M32R_IRQ_INT2) ; INT2# interrupt
  374. bnez r2, check_end
  375. ; read ICU status of LCD-board
  376. seth r0, #high(M32700UT_LCD_ICUISTS)
  377. or3 r0, r0, #low(M32700UT_LCD_ICUISTS)
  378. lduh r0, @r0
  379. slli r0, #21
  380. srli r0, #27 ; ISN
  381. add3 r0, r0, #(M32700UT_LCD_PLD_IRQ_BASE)
  382. bra check_end
  383. .fillinsn
  384. check_end:
  385. #elif defined(CONFIG_PLAT_OPSPUT)
  386. add3 r2, r0, #-(M32R_IRQ_INT1) ; INT1# interrupt
  387. bnez r2, check_int0
  388. ; read ICU status register of PLD
  389. seth r0, #high(PLD_ICUISTS)
  390. or3 r0, r0, #low(PLD_ICUISTS)
  391. lduh r0, @r0
  392. slli r0, #21
  393. srli r0, #27 ; ISN
  394. addi r0, #(OPSPUT_PLD_IRQ_BASE)
  395. bra check_end
  396. .fillinsn
  397. check_int0:
  398. add3 r2, r0, #-(M32R_IRQ_INT0) ; INT0# interrupt
  399. bnez r2, check_int2
  400. ; read ICU status of LAN-board
  401. seth r0, #high(OPSPUT_LAN_ICUISTS)
  402. or3 r0, r0, #low(OPSPUT_LAN_ICUISTS)
  403. lduh r0, @r0
  404. slli r0, #21
  405. srli r0, #27 ; ISN
  406. add3 r0, r0, #(OPSPUT_LAN_PLD_IRQ_BASE)
  407. bra check_end
  408. .fillinsn
  409. check_int2:
  410. add3 r2, r0, #-(M32R_IRQ_INT2) ; INT2# interrupt
  411. bnez r2, check_end
  412. ; read ICU status of LCD-board
  413. seth r0, #high(OPSPUT_LCD_ICUISTS)
  414. or3 r0, r0, #low(OPSPUT_LCD_ICUISTS)
  415. lduh r0, @r0
  416. slli r0, #21
  417. srli r0, #27 ; ISN
  418. add3 r0, r0, #(OPSPUT_LCD_PLD_IRQ_BASE)
  419. bra check_end
  420. .fillinsn
  421. check_end:
  422. #endif /* CONFIG_PLAT_OPSPUT */
  423. bl do_IRQ ; r0(irq), r1(regs)
  424. #else /* not CONFIG_SMP */
  425. srli r0, #22 ; r0(irq)
  426. #if defined(CONFIG_PLAT_USRV)
  427. add3 r2, r0, #-(M32R_IRQ_INT1) ; INT1# interrupt
  428. bnez r2, 1f
  429. ; read ICU status register of PLD
  430. seth r0, #high(PLD_ICUISTS)
  431. or3 r0, r0, #low(PLD_ICUISTS)
  432. lduh r0, @r0
  433. slli r0, #21
  434. srli r0, #27 ; ISN
  435. addi r0, #(M32700UT_PLD_IRQ_BASE)
  436. .fillinsn
  437. 1:
  438. #elif defined(CONFIG_PLAT_M32700UT)
  439. add3 r2, r0, #-(M32R_IRQ_INT1) ; INT1# interrupt
  440. bnez r2, check_int0
  441. ; read ICU status register of PLD
  442. seth r0, #high(PLD_ICUISTS)
  443. or3 r0, r0, #low(PLD_ICUISTS)
  444. lduh r0, @r0
  445. slli r0, #21
  446. srli r0, #27 ; ISN
  447. addi r0, #(M32700UT_PLD_IRQ_BASE)
  448. bra check_end
  449. .fillinsn
  450. check_int0:
  451. add3 r2, r0, #-(M32R_IRQ_INT0) ; INT0# interrupt
  452. bnez r2, check_int2
  453. ; read ICU status of LAN-board
  454. seth r0, #high(M32700UT_LAN_ICUISTS)
  455. or3 r0, r0, #low(M32700UT_LAN_ICUISTS)
  456. lduh r0, @r0
  457. slli r0, #21
  458. srli r0, #27 ; ISN
  459. add3 r0, r0, #(M32700UT_LAN_PLD_IRQ_BASE)
  460. bra check_end
  461. .fillinsn
  462. check_int2:
  463. add3 r2, r0, #-(M32R_IRQ_INT2) ; INT2# interrupt
  464. bnez r2, check_end
  465. ; read ICU status of LCD-board
  466. seth r0, #high(M32700UT_LCD_ICUISTS)
  467. or3 r0, r0, #low(M32700UT_LCD_ICUISTS)
  468. lduh r0, @r0
  469. slli r0, #21
  470. srli r0, #27 ; ISN
  471. add3 r0, r0, #(M32700UT_LCD_PLD_IRQ_BASE)
  472. bra check_end
  473. .fillinsn
  474. check_end:
  475. #elif defined(CONFIG_PLAT_OPSPUT)
  476. add3 r2, r0, #-(M32R_IRQ_INT1) ; INT1# interrupt
  477. bnez r2, check_int0
  478. ; read ICU status register of PLD
  479. seth r0, #high(PLD_ICUISTS)
  480. or3 r0, r0, #low(PLD_ICUISTS)
  481. lduh r0, @r0
  482. slli r0, #21
  483. srli r0, #27 ; ISN
  484. addi r0, #(OPSPUT_PLD_IRQ_BASE)
  485. bra check_end
  486. .fillinsn
  487. check_int0:
  488. add3 r2, r0, #-(M32R_IRQ_INT0) ; INT0# interrupt
  489. bnez r2, check_int2
  490. ; read ICU status of LAN-board
  491. seth r0, #high(OPSPUT_LAN_ICUISTS)
  492. or3 r0, r0, #low(OPSPUT_LAN_ICUISTS)
  493. lduh r0, @r0
  494. slli r0, #21
  495. srli r0, #27 ; ISN
  496. add3 r0, r0, #(OPSPUT_LAN_PLD_IRQ_BASE)
  497. bra check_end
  498. .fillinsn
  499. check_int2:
  500. add3 r2, r0, #-(M32R_IRQ_INT2) ; INT2# interrupt
  501. bnez r2, check_end
  502. ; read ICU status of LCD-board
  503. seth r0, #high(OPSPUT_LCD_ICUISTS)
  504. or3 r0, r0, #low(OPSPUT_LCD_ICUISTS)
  505. lduh r0, @r0
  506. slli r0, #21
  507. srli r0, #27 ; ISN
  508. add3 r0, r0, #(OPSPUT_LCD_PLD_IRQ_BASE)
  509. bra check_end
  510. .fillinsn
  511. check_end:
  512. #elif defined(CONFIG_PLAT_M32104UT)
  513. add3 r2, r0, #-(M32R_IRQ_INT1) ; INT1# interrupt
  514. bnez r2, check_end
  515. ; read ICU status register of PLD
  516. seth r0, #high(PLD_ICUISTS)
  517. or3 r0, r0, #low(PLD_ICUISTS)
  518. lduh r0, @r0
  519. slli r0, #21
  520. srli r0, #27 ; ISN
  521. addi r0, #(M32104UT_PLD_IRQ_BASE)
  522. bra check_end
  523. .fillinsn
  524. check_end:
  525. #endif /* CONFIG_PLAT_M32104UT */
  526. bl do_IRQ
  527. #endif /* CONFIG_SMP */
  528. pop r14
  529. seth r0, #shigh(M32R_ICU_IMASK_ADDR)
  530. st r14, @(low(M32R_ICU_IMASK_ADDR),r0)
  531. #else
  532. #error no chip configuration
  533. #endif
  534. ret_to_intr:
  535. bra ret_from_intr
  536. /*
  537. * Default EIT handler
  538. */
  539. ALIGN
  540. int_msg:
  541. .asciz "Unknown interrupt\n"
  542. .byte 0
  543. ENTRY(default_eit_handler)
  544. push r0
  545. mvfc r0, psw
  546. push r1
  547. push r2
  548. push r3
  549. push r0
  550. LDIMM (r0, __KERNEL_DS)
  551. mv r0, r1
  552. mv r0, r2
  553. LDIMM (r0, int_msg)
  554. bl printk
  555. pop r0
  556. pop r3
  557. pop r2
  558. pop r1
  559. mvtc r0, psw
  560. pop r0
  561. infinit:
  562. bra infinit
  563. #ifdef CONFIG_MMU
  564. /*
  565. * Access Exception handler
  566. */
  567. ENTRY(ace_handler)
  568. SWITCH_TO_KERNEL_STACK
  569. SAVE_ALL
  570. seth r2, #shigh(MMU_REG_BASE) /* Check status register */
  571. ld r4, @(low(MESTS_offset),r2)
  572. st r4, @(low(MESTS_offset),r2)
  573. srl3 r1, r4, #4
  574. #ifdef CONFIG_CHIP_M32700
  575. and3 r1, r1, #0x0000ffff
  576. ; WORKAROUND: ignore TME bit for the M32700(TS1).
  577. #endif /* CONFIG_CHIP_M32700 */
  578. beqz r1, inst
  579. oprand:
  580. ld r2, @(low(MDEVA_offset),r2) ; set address
  581. srli r2, #12
  582. slli r2, #12
  583. srli r1, #1
  584. bra 1f
  585. inst:
  586. and3 r1, r4, #2
  587. srli r1, #1
  588. or3 r1, r1, #8
  589. mvfc r2, bpc ; set address
  590. .fillinsn
  591. 1:
  592. mvfc r3, psw
  593. mv r0, sp
  594. and3 r3, r3, 0x800
  595. srli r3, #9
  596. or r1, r3
  597. /*
  598. * do_page_fault():
  599. * r0 : struct pt_regs *regs
  600. * r1 : unsigned long error-code
  601. * r2 : unsigned long address
  602. * error-code:
  603. * +------+------+------+------+
  604. * | bit3 | bit2 | bit1 | bit0 |
  605. * +------+------+------+------+
  606. * bit 3 == 0:means data, 1:means instruction
  607. * bit 2 == 0:means kernel, 1:means user-mode
  608. * bit 1 == 0:means read, 1:means write
  609. * bit 0 == 0:means no page found 1:means protection fault
  610. *
  611. */
  612. bl do_page_fault
  613. bra ret_from_intr
  614. #endif /* CONFIG_MMU */
  615. ENTRY(alignment_check)
  616. /* void alignment_check(int error_code) */
  617. SWITCH_TO_KERNEL_STACK
  618. SAVE_ALL
  619. ldi r1, #0x30 ; error_code
  620. mv r0, sp ; pt_regs
  621. bl do_alignment_check
  622. error_code:
  623. bra ret_from_exception
  624. ENTRY(rie_handler)
  625. /* void rie_handler(int error_code) */
  626. SWITCH_TO_KERNEL_STACK
  627. SAVE_ALL
  628. ldi r1, #0x20 ; error_code
  629. mv r0, sp ; pt_regs
  630. bl do_rie_handler
  631. bra error_code
  632. ENTRY(pie_handler)
  633. /* void pie_handler(int error_code) */
  634. SWITCH_TO_KERNEL_STACK
  635. SAVE_ALL
  636. ldi r1, #0 ; error_code ; FIXME
  637. mv r0, sp ; pt_regs
  638. bl do_pie_handler
  639. bra error_code
  640. ENTRY(debug_trap)
  641. .global withdraw_debug_trap
  642. /* void debug_trap(void) */
  643. SWITCH_TO_KERNEL_STACK
  644. SAVE_ALL
  645. mv r0, sp ; pt_regs
  646. bl withdraw_debug_trap
  647. ldi r1, #0 ; error_code
  648. mv r0, sp ; pt_regs
  649. bl do_debug_trap
  650. bra error_code
  651. ENTRY(ill_trap)
  652. /* void ill_trap(void) */
  653. SWITCH_TO_KERNEL_STACK
  654. SAVE_ALL
  655. ldi r1, #0 ; error_code ; FIXME
  656. mv r0, sp ; pt_regs
  657. bl do_ill_trap
  658. bra error_code
  659. /* Cache flushing handler */
  660. ENTRY(cache_flushing_handler)
  661. .global _flush_cache_all
  662. /* void _flush_cache_all(void); */
  663. SWITCH_TO_KERNEL_STACK
  664. push r0
  665. push r1
  666. push r2
  667. push r3
  668. push r4
  669. push r5
  670. push r6
  671. push r7
  672. push lr
  673. bl _flush_cache_all
  674. pop lr
  675. pop r7
  676. pop r6
  677. pop r5
  678. pop r4
  679. pop r3
  680. pop r2
  681. pop r1
  682. pop r0
  683. rte
  684. .data
  685. ENTRY(sys_call_table)
  686. .long sys_restart_syscall /* 0 - old "setup()" system call*/
  687. .long sys_exit
  688. .long sys_fork
  689. .long sys_read
  690. .long sys_write
  691. .long sys_open /* 5 */
  692. .long sys_close
  693. .long sys_waitpid
  694. .long sys_creat
  695. .long sys_link
  696. .long sys_unlink /* 10 */
  697. .long sys_execve
  698. .long sys_chdir
  699. .long sys_time
  700. .long sys_mknod
  701. .long sys_chmod /* 15 */
  702. .long sys_ni_syscall /* lchown16 syscall holder */
  703. .long sys_ni_syscall /* old break syscall holder */
  704. .long sys_ni_syscall /* old stat syscall holder */
  705. .long sys_lseek
  706. .long sys_getpid /* 20 */
  707. .long sys_mount
  708. .long sys_oldumount
  709. .long sys_ni_syscall /* setuid16 syscall holder */
  710. .long sys_ni_syscall /* getuid16 syscall holder */
  711. .long sys_stime /* 25 */
  712. .long sys_ptrace
  713. .long sys_alarm
  714. .long sys_ni_syscall /* old fstat syscall holder */
  715. .long sys_pause
  716. .long sys_utime /* 30 */
  717. .long sys_ni_syscall /* old stty syscall holder */
  718. .long sys_cachectl /* for M32R */ /* old gtty syscall holder */
  719. .long sys_access
  720. .long sys_ni_syscall /* nice syscall holder */
  721. .long sys_ni_syscall /* 35 - old ftime syscall holder */
  722. .long sys_sync
  723. .long sys_kill
  724. .long sys_rename
  725. .long sys_mkdir
  726. .long sys_rmdir /* 40 */
  727. .long sys_dup
  728. .long sys_pipe
  729. .long sys_times
  730. .long sys_ni_syscall /* old prof syscall holder */
  731. .long sys_brk /* 45 */
  732. .long sys_ni_syscall /* setgid16 syscall holder */
  733. .long sys_getgid /* will be unused */
  734. .long sys_ni_syscall /* signal syscall holder */
  735. .long sys_ni_syscall /* geteuid16 syscall holder */
  736. .long sys_ni_syscall /* 50 - getegid16 syscall holder */
  737. .long sys_acct
  738. .long sys_umount /* recycled never used phys() */
  739. .long sys_ni_syscall /* old lock syscall holder */
  740. .long sys_ioctl
  741. .long sys_fcntl /* 55 - will be unused */
  742. .long sys_ni_syscall /* mpx syscall holder */
  743. .long sys_setpgid
  744. .long sys_ni_syscall /* old ulimit syscall holder */
  745. .long sys_ni_syscall /* sys_olduname */
  746. .long sys_umask /* 60 */
  747. .long sys_chroot
  748. .long sys_ustat
  749. .long sys_dup2
  750. .long sys_getppid
  751. .long sys_getpgrp /* 65 */
  752. .long sys_setsid
  753. .long sys_ni_syscall /* sigaction syscall holder */
  754. .long sys_ni_syscall /* sgetmask syscall holder */
  755. .long sys_ni_syscall /* ssetmask syscall holder */
  756. .long sys_ni_syscall /* 70 - setreuid16 syscall holder */
  757. .long sys_ni_syscall /* setregid16 syscall holder */
  758. .long sys_ni_syscall /* sigsuspend syscall holder */
  759. .long sys_ni_syscall /* sigpending syscall holder */
  760. .long sys_sethostname
  761. .long sys_setrlimit /* 75 */
  762. .long sys_getrlimit/*will be unused*/
  763. .long sys_getrusage
  764. .long sys_gettimeofday
  765. .long sys_settimeofday
  766. .long sys_ni_syscall /* 80 - getgroups16 syscall holder */
  767. .long sys_ni_syscall /* setgroups16 syscall holder */
  768. .long sys_ni_syscall /* sys_oldselect */
  769. .long sys_symlink
  770. .long sys_ni_syscall /* old lstat syscall holder */
  771. .long sys_readlink /* 85 */
  772. .long sys_uselib
  773. .long sys_swapon
  774. .long sys_reboot
  775. .long sys_ni_syscall /* readdir syscall holder */
  776. .long sys_ni_syscall /* 90 - old_mmap syscall holder */
  777. .long sys_munmap
  778. .long sys_truncate
  779. .long sys_ftruncate
  780. .long sys_fchmod
  781. .long sys_ni_syscall /* 95 - fchwon16 syscall holder */
  782. .long sys_getpriority
  783. .long sys_setpriority
  784. .long sys_ni_syscall /* old profil syscall holder */
  785. .long sys_statfs
  786. .long sys_fstatfs /* 100 */
  787. .long sys_ni_syscall /* ioperm syscall holder */
  788. .long sys_socketcall
  789. .long sys_syslog
  790. .long sys_setitimer
  791. .long sys_getitimer /* 105 */
  792. .long sys_newstat
  793. .long sys_newlstat
  794. .long sys_newfstat
  795. .long sys_ni_syscall /* old uname syscall holder */
  796. .long sys_ni_syscall /* 110 - iopl syscall holder */
  797. .long sys_vhangup
  798. .long sys_ni_syscall /* idle syscall holder */
  799. .long sys_ni_syscall /* vm86old syscall holder */
  800. .long sys_wait4
  801. .long sys_swapoff /* 115 */
  802. .long sys_sysinfo
  803. .long sys_ipc
  804. .long sys_fsync
  805. .long sys_ni_syscall /* sigreturn syscall holder */
  806. .long sys_clone /* 120 */
  807. .long sys_setdomainname
  808. .long sys_newuname
  809. .long sys_ni_syscall /* modify_ldt syscall holder */
  810. .long sys_adjtimex
  811. .long sys_mprotect /* 125 */
  812. .long sys_ni_syscall /* sigprocmask syscall holder */
  813. .long sys_ni_syscall /* create_module syscall holder */
  814. .long sys_init_module
  815. .long sys_delete_module
  816. .long sys_ni_syscall /* 130 - get_kernel_syms */
  817. .long sys_quotactl
  818. .long sys_getpgid
  819. .long sys_fchdir
  820. .long sys_bdflush
  821. .long sys_sysfs /* 135 */
  822. .long sys_personality
  823. .long sys_ni_syscall /* afs_syscall syscall holder */
  824. .long sys_ni_syscall /* setfsuid16 syscall holder */
  825. .long sys_ni_syscall /* setfsgid16 syscall holder */
  826. .long sys_llseek /* 140 */
  827. .long sys_getdents
  828. .long sys_select
  829. .long sys_flock
  830. .long sys_msync
  831. .long sys_readv /* 145 */
  832. .long sys_writev
  833. .long sys_getsid
  834. .long sys_fdatasync
  835. .long sys_sysctl
  836. .long sys_mlock /* 150 */
  837. .long sys_munlock
  838. .long sys_mlockall
  839. .long sys_munlockall
  840. .long sys_sched_setparam
  841. .long sys_sched_getparam /* 155 */
  842. .long sys_sched_setscheduler
  843. .long sys_sched_getscheduler
  844. .long sys_sched_yield
  845. .long sys_sched_get_priority_max
  846. .long sys_sched_get_priority_min /* 160 */
  847. .long sys_sched_rr_get_interval
  848. .long sys_nanosleep
  849. .long sys_mremap
  850. .long sys_ni_syscall /* setresuid16 syscall holder */
  851. .long sys_ni_syscall /* 165 - getresuid16 syscall holder */
  852. .long sys_tas /* vm86 syscall holder */
  853. .long sys_ni_syscall /* query_module syscall holder */
  854. .long sys_poll
  855. .long sys_nfsservctl
  856. .long sys_setresgid /* 170 */
  857. .long sys_getresgid
  858. .long sys_prctl
  859. .long sys_rt_sigreturn
  860. .long sys_rt_sigaction
  861. .long sys_rt_sigprocmask /* 175 */
  862. .long sys_rt_sigpending
  863. .long sys_rt_sigtimedwait
  864. .long sys_rt_sigqueueinfo
  865. .long sys_rt_sigsuspend
  866. .long sys_pread64 /* 180 */
  867. .long sys_pwrite64
  868. .long sys_ni_syscall /* chown16 syscall holder */
  869. .long sys_getcwd
  870. .long sys_capget
  871. .long sys_capset /* 185 */
  872. .long sys_sigaltstack
  873. .long sys_sendfile
  874. .long sys_ni_syscall /* streams1 */
  875. .long sys_ni_syscall /* streams2 */
  876. .long sys_vfork /* 190 */
  877. .long sys_getrlimit
  878. .long sys_mmap2
  879. .long sys_truncate64
  880. .long sys_ftruncate64
  881. .long sys_stat64 /* 195 */
  882. .long sys_lstat64
  883. .long sys_fstat64
  884. .long sys_lchown
  885. .long sys_getuid
  886. .long sys_getgid /* 200 */
  887. .long sys_geteuid
  888. .long sys_getegid
  889. .long sys_setreuid
  890. .long sys_setregid
  891. .long sys_getgroups /* 205 */
  892. .long sys_setgroups
  893. .long sys_fchown
  894. .long sys_setresuid
  895. .long sys_getresuid
  896. .long sys_setresgid /* 210 */
  897. .long sys_getresgid
  898. .long sys_chown
  899. .long sys_setuid
  900. .long sys_setgid
  901. .long sys_setfsuid /* 215 */
  902. .long sys_setfsgid
  903. .long sys_pivot_root
  904. .long sys_mincore
  905. .long sys_madvise
  906. .long sys_getdents64 /* 220 */
  907. .long sys_fcntl64
  908. .long sys_ni_syscall /* reserved for TUX */
  909. .long sys_ni_syscall /* Reserved for Security */
  910. .long sys_gettid
  911. .long sys_readahead /* 225 */
  912. .long sys_setxattr
  913. .long sys_lsetxattr
  914. .long sys_fsetxattr
  915. .long sys_getxattr
  916. .long sys_lgetxattr /* 230 */
  917. .long sys_fgetxattr
  918. .long sys_listxattr
  919. .long sys_llistxattr
  920. .long sys_flistxattr
  921. .long sys_removexattr /* 235 */
  922. .long sys_lremovexattr
  923. .long sys_fremovexattr
  924. .long sys_tkill
  925. .long sys_sendfile64
  926. .long sys_futex /* 240 */
  927. .long sys_sched_setaffinity
  928. .long sys_sched_getaffinity
  929. .long sys_ni_syscall /* reserved for "set_thread_area" system call */
  930. .long sys_ni_syscall /* reserved for "get_thread_area" system call */
  931. .long sys_io_setup /* 245 */
  932. .long sys_io_destroy
  933. .long sys_io_getevents
  934. .long sys_io_submit
  935. .long sys_io_cancel
  936. .long sys_fadvise64 /* 250 */
  937. .long sys_ni_syscall
  938. .long sys_exit_group
  939. .long sys_lookup_dcookie
  940. .long sys_epoll_create
  941. .long sys_epoll_ctl /* 255 */
  942. .long sys_epoll_wait
  943. .long sys_remap_file_pages
  944. .long sys_set_tid_address
  945. .long sys_timer_create
  946. .long sys_timer_settime /* 260 */
  947. .long sys_timer_gettime
  948. .long sys_timer_getoverrun
  949. .long sys_timer_delete
  950. .long sys_clock_settime
  951. .long sys_clock_gettime /* 265 */
  952. .long sys_clock_getres
  953. .long sys_clock_nanosleep
  954. .long sys_statfs64
  955. .long sys_fstatfs64
  956. .long sys_tgkill /* 270 */
  957. .long sys_utimes
  958. .long sys_fadvise64_64
  959. .long sys_ni_syscall /* Reserved for sys_vserver */
  960. .long sys_ni_syscall /* Reserved for sys_mbind */
  961. .long sys_ni_syscall /* Reserved for sys_get_mempolicy */
  962. .long sys_ni_syscall /* Reserved for sys_set_mempolicy */
  963. .long sys_mq_open
  964. .long sys_mq_unlink
  965. .long sys_mq_timedsend
  966. .long sys_mq_timedreceive /* 280 */
  967. .long sys_mq_notify
  968. .long sys_mq_getsetattr
  969. .long sys_ni_syscall /* reserved for kexec */
  970. .long sys_waitid
  971. syscall_table_size=(.-sys_call_table)