diff options
Diffstat (limited to 'lib/Kconfig.debug')
-rw-r--r-- | lib/Kconfig.debug | 55 |
1 files changed, 55 insertions, 0 deletions
diff --git a/lib/Kconfig.debug b/lib/Kconfig.debug index aa81d2848448..31d784dd80d0 100644 --- a/lib/Kconfig.debug +++ b/lib/Kconfig.debug | |||
@@ -807,6 +807,61 @@ menuconfig BUILD_DOCSRC | |||
807 | 807 | ||
808 | Say N if you are unsure. | 808 | Say N if you are unsure. |
809 | 809 | ||
810 | config DYNAMIC_PRINTK_DEBUG | ||
811 | bool "Enable dynamic printk() call support" | ||
812 | default n | ||
813 | depends on PRINTK | ||
814 | select PRINTK_DEBUG | ||
815 | help | ||
816 | |||
817 | Compiles debug level messages into the kernel, which would not | ||
818 | otherwise be available at runtime. These messages can then be | ||
819 | enabled/disabled on a per module basis. This mechanism implicitly | ||
820 | enables all pr_debug() and dev_dbg() calls. The impact of this | ||
821 | compile option is a larger kernel text size of about 2%. | ||
822 | |||
823 | Usage: | ||
824 | |||
825 | Dynamic debugging is controlled by the debugfs file, | ||
826 | dynamic_printk/modules. This file contains a list of the modules that | ||
827 | can be enabled. The format of the file is the module name, followed | ||
828 | by a set of flags that can be enabled. The first flag is always the | ||
829 | 'enabled' flag. For example: | ||
830 | |||
831 | <module_name> <enabled=0/1> | ||
832 | . | ||
833 | . | ||
834 | . | ||
835 | |||
836 | <module_name> : Name of the module in which the debug call resides | ||
837 | <enabled=0/1> : whether the messages are enabled or not | ||
838 | |||
839 | From a live system: | ||
840 | |||
841 | snd_hda_intel enabled=0 | ||
842 | fixup enabled=0 | ||
843 | driver enabled=0 | ||
844 | |||
845 | Enable a module: | ||
846 | |||
847 | $echo "set enabled=1 <module_name>" > dynamic_printk/modules | ||
848 | |||
849 | Disable a module: | ||
850 | |||
851 | $echo "set enabled=0 <module_name>" > dynamic_printk/modules | ||
852 | |||
853 | Enable all modules: | ||
854 | |||
855 | $echo "set enabled=1 all" > dynamic_printk/modules | ||
856 | |||
857 | Disable all modules: | ||
858 | |||
859 | $echo "set enabled=0 all" > dynamic_printk/modules | ||
860 | |||
861 | Finally, passing "dynamic_printk" at the command line enables | ||
862 | debugging for all modules. This mode can be turned off via the above | ||
863 | disable command. | ||
864 | |||
810 | source "samples/Kconfig" | 865 | source "samples/Kconfig" |
811 | 866 | ||
812 | source "lib/Kconfig.kgdb" | 867 | source "lib/Kconfig.kgdb" |