risc.gdbinit 4.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152
  1. define r
  2. monitor mips32 cp0 status 0x00400106
  3. monitor reset
  4. end
  5. document r
  6. "reset MIPS"
  7. end
  8. define epc
  9. monitor mips32 cp0 epc
  10. end
  11. define cause
  12. monitor mips32 cp0 cause
  13. end
  14. define status
  15. monitor mips32 cp0 status
  16. end
  17. define pec_b_debug_reg
  18. set *0xb0070040=$arg1 << 24
  19. set $val=*(unsigned int*)0xb0070044
  20. set $val=(($val>>24)&0xFF) | (($val>>8)&0xFF00) | (($val & 0xFF00) << 8) | ((($val) & 0xFF) << 24 )
  21. printf $arg0
  22. printf ": 0x%08X\n",$val
  23. end
  24. define read_pec_b
  25. # unlock
  26. set *0xb0200010=0xffffffff
  27. set *0xb0070154=0xE2C9243A
  28. set *0xb0070150=0xDECD0245
  29. set *0xb0070158=0x0B267835
  30. set *0xb007015C=0xD64F76E4
  31. pec_b_debug_reg "PC " 0x00
  32. pec_b_debug_reg "DPC " 0x04
  33. pec_b_debug_reg "NPC " 0x08
  34. pec_b_debug_reg "EPC " 0x0C
  35. pec_b_debug_reg "EXC " 0x10
  36. pec_b_debug_reg "PSW " 0x14
  37. pec_b_debug_reg "ID " 0x18
  38. pec_b_debug_reg "TMP " 0x1C
  39. pec_b_debug_reg "VTB " 0x20
  40. end
  41. define read_pec_b_all
  42. # unlock
  43. set *0xb0200010=0xffffffff
  44. set *0xb0070154=0xE2C9243A
  45. set *0xb0070150=0xDECD0245
  46. set *0xb0070158=0x0B267835
  47. set *0xb007015C=0xD64F76E4
  48. pec_b_debug_reg "PC " 0x00
  49. pec_b_debug_reg "DPC " 0x04
  50. pec_b_debug_reg "NPC " 0x08
  51. pec_b_debug_reg "EPC " 0x0C
  52. pec_b_debug_reg "EXC " 0x10
  53. pec_b_debug_reg "PSW " 0x14
  54. pec_b_debug_reg "ID " 0x18
  55. pec_b_debug_reg "TMP " 0x1C
  56. pec_b_debug_reg "VTB " 0x20
  57. pec_b_debug_reg "IMB " 0x24
  58. pec_b_debug_reg "ICR0" 0x28
  59. pec_b_debug_reg "ICR1" 0x2C
  60. pec_b_debug_reg "ICR2" 0x30
  61. pec_b_debug_reg "ICR3" 0x34
  62. pec_b_debug_reg "DMB " 0x38
  63. pec_b_debug_reg "DCR0" 0x3C
  64. pec_b_debug_reg "DCR1" 0x40
  65. pec_b_debug_reg "DCR2" 0x44
  66. pec_b_debug_reg "DCR3" 0x48
  67. pec_b_debug_reg "ICB " 0x4C
  68. pec_b_debug_reg "CDR0" 0x50
  69. pec_b_debug_reg "CDR1" 0x54
  70. pec_b_debug_reg "CDR2" 0x58
  71. pec_b_debug_reg "CDR3" 0x5C
  72. pec_b_debug_reg "CDR4" 0x60
  73. pec_b_debug_reg "CDR5" 0x64
  74. pec_b_debug_reg "CDR6" 0x68
  75. pec_b_debug_reg "CDR7" 0x6C
  76. pec_b_debug_reg "DBG0" 0x70
  77. pec_b_debug_reg "DBG1" 0x74
  78. pec_b_debug_reg "DBG2" 0x78
  79. end
  80. define pec_c_debug_reg
  81. set *0xb0070080=$arg1 << 24
  82. set $val=*(unsigned int*)0xb0070084
  83. set $val=(($val>>24)&0xFF) | (($val>>8)&0xFF00) | (($val & 0xFF00) << 8) | ((($val) & 0xFF) << 24 )
  84. printf $arg0
  85. printf ": 0x%08X\n",$val
  86. end
  87. define read_pec_c
  88. # unlock
  89. set *0xb0200010=0xffffffff
  90. set *0xb007016c=0xC77C3712
  91. set *0xb0070164=0x72373A81
  92. set *0xb0070168=0x60AA2514
  93. set *0xb0070160=0x4AEF5DC6
  94. pec_c_debug_reg "PC " 0x00
  95. pec_c_debug_reg "DPC " 0x04
  96. pec_c_debug_reg "NPC " 0x08
  97. pec_c_debug_reg "EPC " 0x0C
  98. pec_c_debug_reg "EXC " 0x10
  99. pec_c_debug_reg "PSW " 0x14
  100. pec_c_debug_reg "VTB " 0x20
  101. end
  102. define read_pec_c_all
  103. # unlock
  104. set *0xb0200010=0xffffffff
  105. set *0xb007016c=0xC77C3712
  106. set *0xb0070164=0x72373A81
  107. set *0xb0070168=0x60AA2514
  108. set *0xb0070160=0x4AEF5DC6
  109. pec_c_debug_reg "PC " 0x00
  110. pec_c_debug_reg "DPC " 0x04
  111. pec_c_debug_reg "NPC " 0x08
  112. pec_c_debug_reg "EPC " 0x0C
  113. pec_c_debug_reg "EXC " 0x10
  114. pec_c_debug_reg "PSW " 0x14
  115. pec_c_debug_reg "ID " 0x18
  116. pec_c_debug_reg "TMP " 0x1C
  117. pec_c_debug_reg "VTB " 0x20
  118. pec_c_debug_reg "IMB " 0x24
  119. pec_c_debug_reg "ICR0" 0x28
  120. pec_c_debug_reg "ICR1" 0x2C
  121. pec_c_debug_reg "ICR2" 0x30
  122. pec_c_debug_reg "ICR3" 0x34
  123. pec_c_debug_reg "DMB " 0x38
  124. pec_c_debug_reg "DCR0" 0x3C
  125. pec_c_debug_reg "DCR1" 0x40
  126. pec_c_debug_reg "DCR2" 0x44
  127. pec_c_debug_reg "DCR3" 0x48
  128. pec_c_debug_reg "ICB " 0x4C
  129. pec_c_debug_reg "CDR0" 0x50
  130. pec_c_debug_reg "CDR1" 0x54
  131. pec_c_debug_reg "CDR2" 0x58
  132. pec_c_debug_reg "CDR3" 0x5C
  133. pec_c_debug_reg "CDR4" 0x60
  134. pec_c_debug_reg "CDR5" 0x64
  135. pec_c_debug_reg "CDR6" 0x68
  136. pec_c_debug_reg "CDR7" 0x6C
  137. pec_c_debug_reg "DBG0" 0x70
  138. pec_c_debug_reg "DBG1" 0x74
  139. pec_c_debug_reg "DBG2" 0x78
  140. end