gdb-low.S 8.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394
  1. /*
  2. * gdb-low.S contains the low-level trap handler for the GDB stub.
  3. *
  4. * Copyright (C) 1995 Andreas Busse
  5. */
  6. #include <linux/sys.h>
  7. #include <asm/asm.h>
  8. #include <asm/errno.h>
  9. #include <asm/irqflags.h>
  10. #include <asm/mipsregs.h>
  11. #include <asm/regdef.h>
  12. #include <asm/stackframe.h>
  13. #include <asm/gdb-stub.h>
  14. #ifdef CONFIG_32BIT
  15. #define DMFC0 mfc0
  16. #define DMTC0 mtc0
  17. #define LDC1 lwc1
  18. #define SDC1 lwc1
  19. #endif
  20. #ifdef CONFIG_64BIT
  21. #define DMFC0 dmfc0
  22. #define DMTC0 dmtc0
  23. #define LDC1 ldc1
  24. #define SDC1 ldc1
  25. #endif
  26. /*
  27. * [jsun] We reserves about 2x GDB_FR_SIZE in stack. The lower (addressed)
  28. * part is used to store registers and passed to exception handler.
  29. * The upper part is reserved for "call func" feature where gdb client
  30. * saves some of the regs, setups call frame and passes args.
  31. *
  32. * A trace shows about 200 bytes are used to store about half of all regs.
  33. * The rest should be big enough for frame setup and passing args.
  34. */
  35. /*
  36. * The low level trap handler
  37. */
  38. .align 5
  39. NESTED(trap_low, GDB_FR_SIZE, sp)
  40. .set noat
  41. .set noreorder
  42. mfc0 k0, CP0_STATUS
  43. sll k0, 3 /* extract cu0 bit */
  44. bltz k0, 1f
  45. move k1, sp
  46. /*
  47. * Called from user mode, go somewhere else.
  48. */
  49. mfc0 k0, CP0_CAUSE
  50. andi k0, k0, 0x7c
  51. #ifdef CONFIG_64BIT
  52. dsll k0, k0, 1
  53. #endif
  54. PTR_L k1, saved_vectors(k0)
  55. jr k1
  56. nop
  57. 1:
  58. move k0, sp
  59. PTR_SUBU sp, k1, GDB_FR_SIZE*2 # see comment above
  60. LONG_S k0, GDB_FR_REG29(sp)
  61. LONG_S $2, GDB_FR_REG2(sp)
  62. /*
  63. * First save the CP0 and special registers
  64. */
  65. mfc0 v0, CP0_STATUS
  66. LONG_S v0, GDB_FR_STATUS(sp)
  67. mfc0 v0, CP0_CAUSE
  68. LONG_S v0, GDB_FR_CAUSE(sp)
  69. DMFC0 v0, CP0_EPC
  70. LONG_S v0, GDB_FR_EPC(sp)
  71. DMFC0 v0, CP0_BADVADDR
  72. LONG_S v0, GDB_FR_BADVADDR(sp)
  73. mfhi v0
  74. LONG_S v0, GDB_FR_HI(sp)
  75. mflo v0
  76. LONG_S v0, GDB_FR_LO(sp)
  77. /*
  78. * Now the integer registers
  79. */
  80. LONG_S zero, GDB_FR_REG0(sp) /* I know... */
  81. LONG_S $1, GDB_FR_REG1(sp)
  82. /* v0 already saved */
  83. LONG_S $3, GDB_FR_REG3(sp)
  84. LONG_S $4, GDB_FR_REG4(sp)
  85. LONG_S $5, GDB_FR_REG5(sp)
  86. LONG_S $6, GDB_FR_REG6(sp)
  87. LONG_S $7, GDB_FR_REG7(sp)
  88. LONG_S $8, GDB_FR_REG8(sp)
  89. LONG_S $9, GDB_FR_REG9(sp)
  90. LONG_S $10, GDB_FR_REG10(sp)
  91. LONG_S $11, GDB_FR_REG11(sp)
  92. LONG_S $12, GDB_FR_REG12(sp)
  93. LONG_S $13, GDB_FR_REG13(sp)
  94. LONG_S $14, GDB_FR_REG14(sp)
  95. LONG_S $15, GDB_FR_REG15(sp)
  96. LONG_S $16, GDB_FR_REG16(sp)
  97. LONG_S $17, GDB_FR_REG17(sp)
  98. LONG_S $18, GDB_FR_REG18(sp)
  99. LONG_S $19, GDB_FR_REG19(sp)
  100. LONG_S $20, GDB_FR_REG20(sp)
  101. LONG_S $21, GDB_FR_REG21(sp)
  102. LONG_S $22, GDB_FR_REG22(sp)
  103. LONG_S $23, GDB_FR_REG23(sp)
  104. LONG_S $24, GDB_FR_REG24(sp)
  105. LONG_S $25, GDB_FR_REG25(sp)
  106. LONG_S $26, GDB_FR_REG26(sp)
  107. LONG_S $27, GDB_FR_REG27(sp)
  108. LONG_S $28, GDB_FR_REG28(sp)
  109. /* sp already saved */
  110. LONG_S $30, GDB_FR_REG30(sp)
  111. LONG_S $31, GDB_FR_REG31(sp)
  112. CLI /* disable interrupts */
  113. TRACE_IRQS_OFF
  114. /*
  115. * Followed by the floating point registers
  116. */
  117. mfc0 v0, CP0_STATUS /* FPU enabled? */
  118. srl v0, v0, 16
  119. andi v0, v0, (ST0_CU1 >> 16)
  120. beqz v0,2f /* disabled, skip */
  121. nop
  122. SDC1 $0, GDB_FR_FPR0(sp)
  123. SDC1 $1, GDB_FR_FPR1(sp)
  124. SDC1 $2, GDB_FR_FPR2(sp)
  125. SDC1 $3, GDB_FR_FPR3(sp)
  126. SDC1 $4, GDB_FR_FPR4(sp)
  127. SDC1 $5, GDB_FR_FPR5(sp)
  128. SDC1 $6, GDB_FR_FPR6(sp)
  129. SDC1 $7, GDB_FR_FPR7(sp)
  130. SDC1 $8, GDB_FR_FPR8(sp)
  131. SDC1 $9, GDB_FR_FPR9(sp)
  132. SDC1 $10, GDB_FR_FPR10(sp)
  133. SDC1 $11, GDB_FR_FPR11(sp)
  134. SDC1 $12, GDB_FR_FPR12(sp)
  135. SDC1 $13, GDB_FR_FPR13(sp)
  136. SDC1 $14, GDB_FR_FPR14(sp)
  137. SDC1 $15, GDB_FR_FPR15(sp)
  138. SDC1 $16, GDB_FR_FPR16(sp)
  139. SDC1 $17, GDB_FR_FPR17(sp)
  140. SDC1 $18, GDB_FR_FPR18(sp)
  141. SDC1 $19, GDB_FR_FPR19(sp)
  142. SDC1 $20, GDB_FR_FPR20(sp)
  143. SDC1 $21, GDB_FR_FPR21(sp)
  144. SDC1 $22, GDB_FR_FPR22(sp)
  145. SDC1 $23, GDB_FR_FPR23(sp)
  146. SDC1 $24, GDB_FR_FPR24(sp)
  147. SDC1 $25, GDB_FR_FPR25(sp)
  148. SDC1 $26, GDB_FR_FPR26(sp)
  149. SDC1 $27, GDB_FR_FPR27(sp)
  150. SDC1 $28, GDB_FR_FPR28(sp)
  151. SDC1 $29, GDB_FR_FPR29(sp)
  152. SDC1 $30, GDB_FR_FPR30(sp)
  153. SDC1 $31, GDB_FR_FPR31(sp)
  154. /*
  155. * FPU control registers
  156. */
  157. cfc1 v0, CP1_STATUS
  158. LONG_S v0, GDB_FR_FSR(sp)
  159. cfc1 v0, CP1_REVISION
  160. LONG_S v0, GDB_FR_FIR(sp)
  161. /*
  162. * Current stack frame ptr
  163. */
  164. 2:
  165. LONG_S sp, GDB_FR_FRP(sp)
  166. /*
  167. * CP0 registers (R4000/R4400 unused registers skipped)
  168. */
  169. mfc0 v0, CP0_INDEX
  170. LONG_S v0, GDB_FR_CP0_INDEX(sp)
  171. mfc0 v0, CP0_RANDOM
  172. LONG_S v0, GDB_FR_CP0_RANDOM(sp)
  173. DMFC0 v0, CP0_ENTRYLO0
  174. LONG_S v0, GDB_FR_CP0_ENTRYLO0(sp)
  175. DMFC0 v0, CP0_ENTRYLO1
  176. LONG_S v0, GDB_FR_CP0_ENTRYLO1(sp)
  177. DMFC0 v0, CP0_CONTEXT
  178. LONG_S v0, GDB_FR_CP0_CONTEXT(sp)
  179. mfc0 v0, CP0_PAGEMASK
  180. LONG_S v0, GDB_FR_CP0_PAGEMASK(sp)
  181. mfc0 v0, CP0_WIRED
  182. LONG_S v0, GDB_FR_CP0_WIRED(sp)
  183. DMFC0 v0, CP0_ENTRYHI
  184. LONG_S v0, GDB_FR_CP0_ENTRYHI(sp)
  185. mfc0 v0, CP0_PRID
  186. LONG_S v0, GDB_FR_CP0_PRID(sp)
  187. .set at
  188. /*
  189. * Continue with the higher level handler
  190. */
  191. move a0,sp
  192. jal handle_exception
  193. nop
  194. /*
  195. * Restore all writable registers, in reverse order
  196. */
  197. .set noat
  198. LONG_L v0, GDB_FR_CP0_ENTRYHI(sp)
  199. LONG_L v1, GDB_FR_CP0_WIRED(sp)
  200. DMTC0 v0, CP0_ENTRYHI
  201. mtc0 v1, CP0_WIRED
  202. LONG_L v0, GDB_FR_CP0_PAGEMASK(sp)
  203. LONG_L v1, GDB_FR_CP0_ENTRYLO1(sp)
  204. mtc0 v0, CP0_PAGEMASK
  205. DMTC0 v1, CP0_ENTRYLO1
  206. LONG_L v0, GDB_FR_CP0_ENTRYLO0(sp)
  207. LONG_L v1, GDB_FR_CP0_INDEX(sp)
  208. DMTC0 v0, CP0_ENTRYLO0
  209. LONG_L v0, GDB_FR_CP0_CONTEXT(sp)
  210. mtc0 v1, CP0_INDEX
  211. DMTC0 v0, CP0_CONTEXT
  212. /*
  213. * Next, the floating point registers
  214. */
  215. mfc0 v0, CP0_STATUS /* check if the FPU is enabled */
  216. srl v0, v0, 16
  217. andi v0, v0, (ST0_CU1 >> 16)
  218. beqz v0, 3f /* disabled, skip */
  219. nop
  220. LDC1 $31, GDB_FR_FPR31(sp)
  221. LDC1 $30, GDB_FR_FPR30(sp)
  222. LDC1 $29, GDB_FR_FPR29(sp)
  223. LDC1 $28, GDB_FR_FPR28(sp)
  224. LDC1 $27, GDB_FR_FPR27(sp)
  225. LDC1 $26, GDB_FR_FPR26(sp)
  226. LDC1 $25, GDB_FR_FPR25(sp)
  227. LDC1 $24, GDB_FR_FPR24(sp)
  228. LDC1 $23, GDB_FR_FPR23(sp)
  229. LDC1 $22, GDB_FR_FPR22(sp)
  230. LDC1 $21, GDB_FR_FPR21(sp)
  231. LDC1 $20, GDB_FR_FPR20(sp)
  232. LDC1 $19, GDB_FR_FPR19(sp)
  233. LDC1 $18, GDB_FR_FPR18(sp)
  234. LDC1 $17, GDB_FR_FPR17(sp)
  235. LDC1 $16, GDB_FR_FPR16(sp)
  236. LDC1 $15, GDB_FR_FPR15(sp)
  237. LDC1 $14, GDB_FR_FPR14(sp)
  238. LDC1 $13, GDB_FR_FPR13(sp)
  239. LDC1 $12, GDB_FR_FPR12(sp)
  240. LDC1 $11, GDB_FR_FPR11(sp)
  241. LDC1 $10, GDB_FR_FPR10(sp)
  242. LDC1 $9, GDB_FR_FPR9(sp)
  243. LDC1 $8, GDB_FR_FPR8(sp)
  244. LDC1 $7, GDB_FR_FPR7(sp)
  245. LDC1 $6, GDB_FR_FPR6(sp)
  246. LDC1 $5, GDB_FR_FPR5(sp)
  247. LDC1 $4, GDB_FR_FPR4(sp)
  248. LDC1 $3, GDB_FR_FPR3(sp)
  249. LDC1 $2, GDB_FR_FPR2(sp)
  250. LDC1 $1, GDB_FR_FPR1(sp)
  251. LDC1 $0, GDB_FR_FPR0(sp)
  252. /*
  253. * Now the CP0 and integer registers
  254. */
  255. 3:
  256. #ifdef CONFIG_MIPS_MT_SMTC
  257. /* Read-modify write of Status must be atomic */
  258. mfc0 t2, CP0_TCSTATUS
  259. ori t1, t2, TCSTATUS_IXMT
  260. mtc0 t1, CP0_TCSTATUS
  261. andi t2, t2, TCSTATUS_IXMT
  262. _ehb
  263. DMT 9 # dmt t1
  264. jal mips_ihb
  265. nop
  266. #endif /* CONFIG_MIPS_MT_SMTC */
  267. mfc0 t0, CP0_STATUS
  268. ori t0, 0x1f
  269. xori t0, 0x1f
  270. mtc0 t0, CP0_STATUS
  271. #ifdef CONFIG_MIPS_MT_SMTC
  272. andi t1, t1, VPECONTROL_TE
  273. beqz t1, 9f
  274. nop
  275. EMT # emt
  276. 9:
  277. mfc0 t1, CP0_TCSTATUS
  278. xori t1, t1, TCSTATUS_IXMT
  279. or t1, t1, t2
  280. mtc0 t1, CP0_TCSTATUS
  281. _ehb
  282. #endif /* CONFIG_MIPS_MT_SMTC */
  283. LONG_L v0, GDB_FR_STATUS(sp)
  284. LONG_L v1, GDB_FR_EPC(sp)
  285. mtc0 v0, CP0_STATUS
  286. DMTC0 v1, CP0_EPC
  287. LONG_L v0, GDB_FR_HI(sp)
  288. LONG_L v1, GDB_FR_LO(sp)
  289. mthi v0
  290. mtlo v1
  291. LONG_L $31, GDB_FR_REG31(sp)
  292. LONG_L $30, GDB_FR_REG30(sp)
  293. LONG_L $28, GDB_FR_REG28(sp)
  294. LONG_L $27, GDB_FR_REG27(sp)
  295. LONG_L $26, GDB_FR_REG26(sp)
  296. LONG_L $25, GDB_FR_REG25(sp)
  297. LONG_L $24, GDB_FR_REG24(sp)
  298. LONG_L $23, GDB_FR_REG23(sp)
  299. LONG_L $22, GDB_FR_REG22(sp)
  300. LONG_L $21, GDB_FR_REG21(sp)
  301. LONG_L $20, GDB_FR_REG20(sp)
  302. LONG_L $19, GDB_FR_REG19(sp)
  303. LONG_L $18, GDB_FR_REG18(sp)
  304. LONG_L $17, GDB_FR_REG17(sp)
  305. LONG_L $16, GDB_FR_REG16(sp)
  306. LONG_L $15, GDB_FR_REG15(sp)
  307. LONG_L $14, GDB_FR_REG14(sp)
  308. LONG_L $13, GDB_FR_REG13(sp)
  309. LONG_L $12, GDB_FR_REG12(sp)
  310. LONG_L $11, GDB_FR_REG11(sp)
  311. LONG_L $10, GDB_FR_REG10(sp)
  312. LONG_L $9, GDB_FR_REG9(sp)
  313. LONG_L $8, GDB_FR_REG8(sp)
  314. LONG_L $7, GDB_FR_REG7(sp)
  315. LONG_L $6, GDB_FR_REG6(sp)
  316. LONG_L $5, GDB_FR_REG5(sp)
  317. LONG_L $4, GDB_FR_REG4(sp)
  318. LONG_L $3, GDB_FR_REG3(sp)
  319. LONG_L $2, GDB_FR_REG2(sp)
  320. LONG_L $1, GDB_FR_REG1(sp)
  321. #if defined(CONFIG_CPU_R3000) || defined(CONFIG_CPU_TX39XX)
  322. LONG_L k0, GDB_FR_EPC(sp)
  323. LONG_L $29, GDB_FR_REG29(sp) /* Deallocate stack */
  324. jr k0
  325. rfe
  326. #else
  327. LONG_L sp, GDB_FR_REG29(sp) /* Deallocate stack */
  328. .set mips3
  329. eret
  330. .set mips0
  331. #endif
  332. .set at
  333. .set reorder
  334. END(trap_low)
  335. LEAF(kgdb_read_byte)
  336. 4: lb t0, (a0)
  337. sb t0, (a1)
  338. li v0, 0
  339. jr ra
  340. .section __ex_table,"a"
  341. PTR 4b, kgdbfault
  342. .previous
  343. END(kgdb_read_byte)
  344. LEAF(kgdb_write_byte)
  345. 5: sb a0, (a1)
  346. li v0, 0
  347. jr ra
  348. .section __ex_table,"a"
  349. PTR 5b, kgdbfault
  350. .previous
  351. END(kgdb_write_byte)
  352. .type kgdbfault@function
  353. .ent kgdbfault
  354. kgdbfault: li v0, -EFAULT
  355. jr ra
  356. .end kgdbfault