kgdb.h 4.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131
  1. /*
  2. * May be copied or modified under the terms of the GNU General Public
  3. * License. See linux/COPYING for more information.
  4. *
  5. * Based on original code by Glenn Engel, Jim Kingdon,
  6. * David Grothe <dave@gcom.com>, Tigran Aivazian, <tigran@sco.com> and
  7. * Amit S. Kale <akale@veritas.com>
  8. *
  9. * Super-H port based on sh-stub.c (Ben Lee and Steve Chamberlain) by
  10. * Henry Bell <henry.bell@st.com>
  11. *
  12. * Header file for low-level support for remote debug using GDB.
  13. *
  14. */
  15. #ifndef __KGDB_H
  16. #define __KGDB_H
  17. #include <asm/ptrace.h>
  18. struct console;
  19. /* Same as pt_regs but has vbr in place of syscall_nr */
  20. struct kgdb_regs {
  21. unsigned long regs[16];
  22. unsigned long pc;
  23. unsigned long pr;
  24. unsigned long sr;
  25. unsigned long gbr;
  26. unsigned long mach;
  27. unsigned long macl;
  28. unsigned long vbr;
  29. };
  30. /* State info */
  31. extern char kgdb_in_gdb_mode;
  32. extern int kgdb_done_init;
  33. extern int kgdb_enabled;
  34. extern int kgdb_nofault; /* Ignore bus errors (in gdb mem access) */
  35. extern int kgdb_halt; /* Execute initial breakpoint at startup */
  36. extern char in_nmi; /* Debounce flag to prevent NMI reentry*/
  37. /* SCI */
  38. extern int kgdb_portnum;
  39. extern int kgdb_baud;
  40. extern char kgdb_parity;
  41. extern char kgdb_bits;
  42. extern int kgdb_console_setup(struct console *, char *);
  43. /* Init and interface stuff */
  44. extern int kgdb_init(void);
  45. extern int (*kgdb_serial_setup)(void);
  46. extern int (*kgdb_getchar)(void);
  47. extern void (*kgdb_putchar)(int);
  48. struct kgdb_sermap {
  49. char *name;
  50. int namelen;
  51. int (*setup_fn)(struct console *, char *);
  52. struct kgdb_sermap *next;
  53. };
  54. extern void kgdb_register_sermap(struct kgdb_sermap *map);
  55. extern struct kgdb_sermap *kgdb_porttype;
  56. /* Trap functions */
  57. typedef void (kgdb_debug_hook_t)(struct pt_regs *regs);
  58. typedef void (kgdb_bus_error_hook_t)(void);
  59. extern kgdb_debug_hook_t *kgdb_debug_hook;
  60. extern kgdb_bus_error_hook_t *kgdb_bus_err_hook;
  61. extern void breakpoint(void);
  62. /* Console */
  63. struct console;
  64. void kgdb_console_write(struct console *co, const char *s, unsigned count);
  65. void kgdb_console_init(void);
  66. /* Prototypes for jmp fns */
  67. #define _JBLEN 9
  68. typedef int jmp_buf[_JBLEN];
  69. extern void longjmp(jmp_buf __jmpb, int __retval);
  70. extern int setjmp(jmp_buf __jmpb);
  71. /* Variadic macro to print our own message to the console */
  72. #define KGDB_PRINTK(...) printk("KGDB: " __VA_ARGS__)
  73. /* Forced breakpoint */
  74. #define BREAKPOINT() do { \
  75. if (kgdb_enabled) { \
  76. asm volatile("trapa #0xff"); \
  77. } \
  78. } while (0)
  79. /* KGDB should be able to flush all kernel text space */
  80. #if defined(CONFIG_CPU_SH4)
  81. #define kgdb_flush_icache_range(start, end) \
  82. { \
  83. extern void __flush_purge_region(void *, int); \
  84. __flush_purge_region((void*)(start), (int)(end) - (int)(start));\
  85. flush_icache_range((start), (end)); \
  86. }
  87. #else
  88. #define kgdb_flush_icache_range(start, end) do { } while (0)
  89. #endif
  90. /* Kernel assert macros */
  91. #ifdef CONFIG_KGDB_KERNEL_ASSERTS
  92. /* Predefined conditions */
  93. #define KA_VALID_ERRNO(errno) ((errno) > 0 && (errno) <= EMEDIUMTYPE)
  94. #define KA_VALID_PTR_ERR(ptr) KA_VALID_ERRNO(-PTR_ERR(ptr))
  95. #define KA_VALID_KPTR(ptr) (!(ptr) || \
  96. ((void *)(ptr) >= (void *)PAGE_OFFSET && \
  97. (void *)(ptr) < ERR_PTR(-EMEDIUMTYPE)))
  98. #define KA_VALID_PTRORERR(errptr) \
  99. (KA_VALID_KPTR(errptr) || KA_VALID_PTR_ERR(errptr))
  100. #define KA_HELD_GKL() (current->lock_depth >= 0)
  101. /* The actual assert */
  102. #define KGDB_ASSERT(condition, message) do { \
  103. if (!(condition) && (kgdb_enabled)) { \
  104. KGDB_PRINTK("Assertion failed at %s:%d: %s\n", \
  105. __FILE__, __LINE__, message);\
  106. BREAKPOINT(); \
  107. } \
  108. } while (0)
  109. #else
  110. #define KGDB_ASSERT(condition, message)
  111. #endif
  112. #endif