Kconfig.debug 5.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148
  1. menu "Kernel hacking"
  2. config TRACE_IRQFLAGS_SUPPORT
  3. def_bool y
  4. source "lib/Kconfig.debug"
  5. config SH_STANDARD_BIOS
  6. bool "Use LinuxSH standard BIOS"
  7. depends on SUPERH32
  8. help
  9. Say Y here if your target has the gdb-sh-stub
  10. package from www.m17n.org (or any conforming standard LinuxSH BIOS)
  11. in FLASH or EPROM. The kernel will use standard BIOS calls during
  12. boot for various housekeeping tasks (including calls to read and
  13. write characters to a system console, get a MAC address from an
  14. on-board Ethernet interface, and shut down the hardware). Note this
  15. does not work with machines with an existing operating system in
  16. mask ROM and no flash (WindowsCE machines fall in this category).
  17. If unsure, say N.
  18. config EARLY_SCIF_CONSOLE
  19. bool "Use early SCIF console"
  20. help
  21. This enables an early console using a fixed SCIF port. This can
  22. be used by platforms that are either not running the SH
  23. standard BIOS, or do not wish to use the BIOS callbacks for the
  24. serial I/O.
  25. config EARLY_SCIF_CONSOLE_PORT
  26. hex
  27. depends on EARLY_SCIF_CONSOLE
  28. default "0xa4400000" if CPU_SUBTYPE_SH7712 || CPU_SUBTYPE_SH7705
  29. default "0xa4430000" if CPU_SUBTYPE_SH7720 || CPU_SUBTYPE_SH7721
  30. default "0xf8420000" if CPU_SUBTYPE_SH7619
  31. default "0xff804000" if CPU_SUBTYPE_MXG
  32. default "0xffc30000" if CPU_SUBTYPE_SHX3
  33. default "0xffe00000" if CPU_SUBTYPE_SH7780 || CPU_SUBTYPE_SH7763 || \
  34. CPU_SUBTYPE_SH7722 || CPU_SUBTYPE_SH7366 || \
  35. CPU_SUBTYPE_SH7343
  36. default "0xffe80000" if CPU_SH4
  37. default "0xffea0000" if CPU_SUBTYPE_SH7785
  38. default "0xfffe8000" if CPU_SUBTYPE_SH7203
  39. default "0xfffe9800" if CPU_SUBTYPE_SH7206 || CPU_SUBTYPE_SH7263
  40. default "0x00000000"
  41. config EARLY_PRINTK
  42. bool "Early printk support"
  43. depends on SH_STANDARD_BIOS || EARLY_SCIF_CONSOLE
  44. help
  45. Say Y here to redirect kernel printk messages to the serial port
  46. used by the SH-IPL bootloader, starting very early in the boot
  47. process and ending when the kernel's serial console is initialised.
  48. This option is only useful porting the kernel to a new machine,
  49. when the kernel may crash or hang before the serial console is
  50. initialised. If unsure, say N.
  51. On devices that are running SH-IPL and want to keep the port
  52. initialization consistent while not using the BIOS callbacks,
  53. select both the EARLY_SCIF_CONSOLE and SH_STANDARD_BIOS, using
  54. the kernel command line option to toggle back and forth.
  55. config DEBUG_BOOTMEM
  56. depends on DEBUG_KERNEL
  57. bool "Debug BOOTMEM initialization"
  58. config DEBUG_STACKOVERFLOW
  59. bool "Check for stack overflows"
  60. depends on DEBUG_KERNEL && SUPERH32
  61. help
  62. This option will cause messages to be printed if free stack space
  63. drops below a certain limit.
  64. config DEBUG_STACK_USAGE
  65. bool "Stack utilization instrumentation"
  66. depends on DEBUG_KERNEL
  67. help
  68. Enables the display of the minimum amount of free stack which each
  69. task has ever had available in the sysrq-T and sysrq-P debug output.
  70. This option will slow down process creation somewhat.
  71. config 4KSTACKS
  72. bool "Use 4Kb for kernel stacks instead of 8Kb"
  73. depends on DEBUG_KERNEL && (MMU || BROKEN) && !PAGE_SIZE_64KB
  74. help
  75. If you say Y here the kernel will use a 4Kb stacksize for the
  76. kernel stack attached to each process/thread. This facilitates
  77. running more threads on a system and also reduces the pressure
  78. on the VM subsystem for higher order allocations. This option
  79. will also use IRQ stacks to compensate for the reduced stackspace.
  80. config IRQSTACKS
  81. bool "Use separate kernel stacks when processing interrupts"
  82. depends on DEBUG_KERNEL && SUPERH32
  83. help
  84. If you say Y here the kernel will use separate kernel stacks
  85. for handling hard and soft interrupts. This can help avoid
  86. overflowing the process kernel stacks.
  87. config DUMP_CODE
  88. bool "Show disassembly of nearby code in register dumps"
  89. depends on DEBUG_KERNEL && SUPERH32
  90. default y if DEBUG_BUGVERBOSE
  91. default n
  92. help
  93. This prints out a code trace of the instructions leading up to
  94. the faulting instruction as a debugging aid. As this does grow
  95. the kernel in size a bit, most users will want to say N here.
  96. Those looking for more verbose debugging output should say Y.
  97. config SH_NO_BSS_INIT
  98. bool "Avoid zeroing BSS (to speed-up startup on suitable platforms)"
  99. depends on DEBUG_KERNEL
  100. default n
  101. help
  102. If running in painfully slow environments, such as an RTL
  103. simulation or from remote memory via SHdebug, where the memory
  104. can already be gauranteed to ber zeroed on boot, say Y.
  105. For all other cases, say N. If this option seems perplexing, or
  106. you aren't sure, say N.
  107. config MORE_COMPILE_OPTIONS
  108. bool "Add any additional compile options"
  109. help
  110. If you want to add additional CFLAGS to the kernel build, enable this
  111. option and then enter what you would like to add in the next question.
  112. Note however that -g is already appended with the selection of KGDB.
  113. config COMPILE_OPTIONS
  114. string "Additional compile arguments"
  115. depends on MORE_COMPILE_OPTIONS
  116. config SH64_SR_WATCH
  117. bool "Debug: set SR.WATCH to enable hardware watchpoints and trace"
  118. depends on SUPERH64
  119. config POOR_MANS_STRACE
  120. bool "Debug: enable rudimentary strace facility"
  121. depends on SUPERH64
  122. help
  123. This option allows system calls to be traced to the console. It also
  124. aids in detecting kernel stack underflow. It is useful for debugging
  125. early-userland problems (e.g. init incurring fatal exceptions.)
  126. endmenu