debug.S 2.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169
  1. /*
  2. * linux/arch/arm/kernel/debug.S
  3. *
  4. * Copyright (C) 1994-1999 Russell King
  5. *
  6. * This program is free software; you can redistribute it and/or modify
  7. * it under the terms of the GNU General Public License version 2 as
  8. * published by the Free Software Foundation.
  9. *
  10. * 32-bit debugging code
  11. */
  12. #include <linux/linkage.h>
  13. .text
  14. /*
  15. * Some debugging routines (useful if you've got MM problems and
  16. * printk isn't working). For DEBUGGING ONLY!!! Do not leave
  17. * references to these in a production kernel!
  18. */
  19. #if defined(CONFIG_DEBUG_ICEDCC)
  20. @@ debug using ARM EmbeddedICE DCC channel
  21. #if defined(CONFIG_CPU_V6)
  22. .macro addruart, rx
  23. .endm
  24. .macro senduart, rd, rx
  25. mcr p14, 0, \rd, c0, c5, 0
  26. .endm
  27. .macro busyuart, rd, rx
  28. 1001:
  29. mrc p14, 0, \rx, c0, c1, 0
  30. tst \rx, #0x20000000
  31. beq 1001b
  32. .endm
  33. .macro waituart, rd, rx
  34. mov \rd, #0x2000000
  35. 1001:
  36. subs \rd, \rd, #1
  37. bmi 1002f
  38. mrc p14, 0, \rx, c0, c1, 0
  39. tst \rx, #0x20000000
  40. bne 1001b
  41. 1002:
  42. .endm
  43. #elif defined(CONFIG_CPU_XSCALE)
  44. .macro addruart, rx
  45. .endm
  46. .macro senduart, rd, rx
  47. mcr p14, 0, \rd, c8, c0, 0
  48. .endm
  49. .macro busyuart, rd, rx
  50. 1001:
  51. mrc p14, 0, \rx, c14, c0, 0
  52. tst \rx, #0x10000000
  53. beq 1001b
  54. .endm
  55. .macro waituart, rd, rx
  56. mov \rd, #0x10000000
  57. 1001:
  58. subs \rd, \rd, #1
  59. bmi 1002f
  60. mrc p14, 0, \rx, c14, c0, 0
  61. tst \rx, #0x10000000
  62. bne 1001b
  63. 1002:
  64. .endm
  65. #else
  66. .macro addruart, rx
  67. .endm
  68. .macro senduart, rd, rx
  69. mcr p14, 0, \rd, c1, c0, 0
  70. .endm
  71. .macro busyuart, rd, rx
  72. 1001:
  73. mrc p14, 0, \rx, c0, c0, 0
  74. tst \rx, #2
  75. beq 1001b
  76. .endm
  77. .macro waituart, rd, rx
  78. mov \rd, #0x2000000
  79. 1001:
  80. subs \rd, \rd, #1
  81. bmi 1002f
  82. mrc p14, 0, \rx, c0, c0, 0
  83. tst \rx, #2
  84. bne 1001b
  85. 1002:
  86. .endm
  87. #endif /* CONFIG_CPU_V6 */
  88. #else
  89. #include <mach/debug-macro.S>
  90. #endif /* CONFIG_DEBUG_ICEDCC */
  91. /*
  92. * Useful debugging routines
  93. */
  94. ENTRY(printhex8)
  95. mov r1, #8
  96. b printhex
  97. ENDPROC(printhex8)
  98. ENTRY(printhex4)
  99. mov r1, #4
  100. b printhex
  101. ENDPROC(printhex4)
  102. ENTRY(printhex2)
  103. mov r1, #2
  104. printhex: adr r2, hexbuf
  105. add r3, r2, r1
  106. mov r1, #0
  107. strb r1, [r3]
  108. 1: and r1, r0, #15
  109. mov r0, r0, lsr #4
  110. cmp r1, #10
  111. addlt r1, r1, #'0'
  112. addge r1, r1, #'a' - 10
  113. strb r1, [r3, #-1]!
  114. teq r3, r2
  115. bne 1b
  116. mov r0, r2
  117. b printascii
  118. ENDPROC(printhex2)
  119. .ltorg
  120. ENTRY(printascii)
  121. addruart r3
  122. b 2f
  123. 1: waituart r2, r3
  124. senduart r1, r3
  125. busyuart r2, r3
  126. teq r1, #'\n'
  127. moveq r1, #'\r'
  128. beq 1b
  129. 2: teq r0, #0
  130. ldrneb r1, [r0], #1
  131. teqne r1, #0
  132. bne 1b
  133. mov pc, lr
  134. ENDPROC(printascii)
  135. ENTRY(printch)
  136. addruart r3
  137. mov r1, r0
  138. mov r0, #0
  139. b 1b
  140. ENDPROC(printch)
  141. hexbuf: .space 16