diff options
author | Christoph Lameter <clameter@sgi.com> | 2007-07-16 02:38:14 -0400 |
---|---|---|
committer | Linus Torvalds <torvalds@woody.linux-foundation.org> | 2007-07-16 12:05:36 -0400 |
commit | f0630fff54a239efbbd89faf6a62da071ef1ff78 (patch) | |
tree | 4004adc3adf4dbe1a6188ca0bbd56f7606d4d05f /mm/slub.c | |
parent | fc9a07e7bf1a76e710f5df017abb07628db1781d (diff) |
SLUB: support slub_debug on by default
Add a new configuration variable
CONFIG_SLUB_DEBUG_ON
If set then the kernel will be booted by default with slab debugging
switched on. Similar to CONFIG_SLAB_DEBUG. By default slab debugging
is available but must be enabled by specifying "slub_debug" as a
kernel parameter.
Also add support to switch off slab debugging for a kernel that was
built with CONFIG_SLUB_DEBUG_ON. This works by specifying
slub_debug=-
as a kernel parameter.
Dave Jones wanted this feature.
http://marc.info/?l=linux-kernel&m=118072189913045&w=2
[akpm@linux-foundation.org: clean up switch statement]
Signed-off-by: Christoph Lameter <clameter@sgi.com>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
Diffstat (limited to 'mm/slub.c')
-rw-r--r-- | mm/slub.c | 79 |
1 files changed, 51 insertions, 28 deletions
@@ -323,7 +323,11 @@ static inline int slab_index(void *p, struct kmem_cache *s, void *addr) | |||
323 | /* | 323 | /* |
324 | * Debug settings: | 324 | * Debug settings: |
325 | */ | 325 | */ |
326 | #ifdef CONFIG_SLUB_DEBUG_ON | ||
327 | static int slub_debug = DEBUG_DEFAULT_FLAGS; | ||
328 | #else | ||
326 | static int slub_debug; | 329 | static int slub_debug; |
330 | #endif | ||
327 | 331 | ||
328 | static char *slub_debug_slabs; | 332 | static char *slub_debug_slabs; |
329 | 333 | ||
@@ -888,38 +892,57 @@ fail: | |||
888 | 892 | ||
889 | static int __init setup_slub_debug(char *str) | 893 | static int __init setup_slub_debug(char *str) |
890 | { | 894 | { |
891 | if (!str || *str != '=') | 895 | slub_debug = DEBUG_DEFAULT_FLAGS; |
892 | slub_debug = DEBUG_DEFAULT_FLAGS; | 896 | if (*str++ != '=' || !*str) |
893 | else { | 897 | /* |
894 | str++; | 898 | * No options specified. Switch on full debugging. |
895 | if (*str == 0 || *str == ',') | 899 | */ |
896 | slub_debug = DEBUG_DEFAULT_FLAGS; | 900 | goto out; |
897 | else | 901 | |
898 | for( ;*str && *str != ','; str++) | 902 | if (*str == ',') |
899 | switch (*str) { | 903 | /* |
900 | case 'f' : case 'F' : | 904 | * No options but restriction on slabs. This means full |
901 | slub_debug |= SLAB_DEBUG_FREE; | 905 | * debugging for slabs matching a pattern. |
902 | break; | 906 | */ |
903 | case 'z' : case 'Z' : | 907 | goto check_slabs; |
904 | slub_debug |= SLAB_RED_ZONE; | 908 | |
905 | break; | 909 | slub_debug = 0; |
906 | case 'p' : case 'P' : | 910 | if (*str == '-') |
907 | slub_debug |= SLAB_POISON; | 911 | /* |
908 | break; | 912 | * Switch off all debugging measures. |
909 | case 'u' : case 'U' : | 913 | */ |
910 | slub_debug |= SLAB_STORE_USER; | 914 | goto out; |
911 | break; | 915 | |
912 | case 't' : case 'T' : | 916 | /* |
913 | slub_debug |= SLAB_TRACE; | 917 | * Determine which debug features should be switched on |
914 | break; | 918 | */ |
915 | default: | 919 | for ( ;*str && *str != ','; str++) { |
916 | printk(KERN_ERR "slub_debug option '%c' " | 920 | switch (tolower(*str)) { |
917 | "unknown. skipped\n",*str); | 921 | case 'f': |
918 | } | 922 | slub_debug |= SLAB_DEBUG_FREE; |
923 | break; | ||
924 | case 'z': | ||
925 | slub_debug |= SLAB_RED_ZONE; | ||
926 | break; | ||
927 | case 'p': | ||
928 | slub_debug |= SLAB_POISON; | ||
929 | break; | ||
930 | case 'u': | ||
931 | slub_debug |= SLAB_STORE_USER; | ||
932 | break; | ||
933 | case 't': | ||
934 | slub_debug |= SLAB_TRACE; | ||
935 | break; | ||
936 | default: | ||
937 | printk(KERN_ERR "slub_debug option '%c' " | ||
938 | "unknown. skipped\n",*str); | ||
939 | } | ||
919 | } | 940 | } |
920 | 941 | ||
942 | check_slabs: | ||
921 | if (*str == ',') | 943 | if (*str == ',') |
922 | slub_debug_slabs = str + 1; | 944 | slub_debug_slabs = str + 1; |
945 | out: | ||
923 | return 1; | 946 | return 1; |
924 | } | 947 | } |
925 | 948 | ||