2 * Kernel Debugger Architecture Independent Support Functions
4 * This file is subject to the terms and conditions of the GNU General Public
5 * License. See the file "COPYING" in the main directory of this archive
8 * Copyright (c) 1999-2004 Silicon Graphics, Inc. All Rights Reserved.
9 * Copyright (c) 2009 Wind River Systems, Inc. All Rights Reserved.
10 * 03/02/13 added new 2.5 kallsyms <xavier.bru@bull.net>
14 #include <linux/types.h>
15 #include <linux/sched.h>
17 #include <linux/kallsyms.h>
18 #include <linux/stddef.h>
19 #include <linux/vmalloc.h>
20 #include <linux/ptrace.h>
21 #include <linux/module.h>
22 #include <linux/highmem.h>
23 #include <linux/hardirq.h>
24 #include <linux/delay.h>
25 #include <linux/uaccess.h>
26 #include <linux/kdb.h>
27 #include <linux/slab.h>
28 #include "kdb_private.h"
31 * kdbgetsymval - Return the address of the given symbol.
34 * symname Character string containing symbol name
35 * symtab Structure to receive results
37 * 0 Symbol not found, symtab zero filled
38 * 1 Symbol mapped to module/symbol/section, data in symtab
40 int kdbgetsymval(const char *symname
, kdb_symtab_t
*symtab
)
43 kdb_printf("kdbgetsymval: symname=%s, symtab=%px\n", symname
,
45 memset(symtab
, 0, sizeof(*symtab
));
46 symtab
->sym_start
= kallsyms_lookup_name(symname
);
47 if (symtab
->sym_start
) {
49 kdb_printf("kdbgetsymval: returns 1, "
50 "symtab->sym_start=0x%lx\n",
55 kdb_printf("kdbgetsymval: returns 0\n");
58 EXPORT_SYMBOL(kdbgetsymval
);
60 static char *kdb_name_table
[100]; /* arbitrary size */
63 * kdbnearsym - Return the name of the symbol with the nearest address
67 * addr Address to check for symbol near
68 * symtab Structure to receive results
70 * 0 No sections contain this address, symtab zero filled
71 * 1 Address mapped to module/symbol/section, data in symtab
73 * 2.6 kallsyms has a "feature" where it unpacks the name into a
74 * string. If that string is reused before the caller expects it
75 * then the caller sees its string change without warning. To
76 * avoid cluttering up the main kdb code with lots of kdb_strdup,
77 * tests and kfree calls, kdbnearsym maintains an LRU list of the
78 * last few unique strings. The list is sized large enough to
79 * hold active strings, no kdb caller of kdbnearsym makes more
80 * than ~20 later calls before using a saved value.
82 int kdbnearsym(unsigned long addr
, kdb_symtab_t
*symtab
)
85 unsigned long symbolsize
= 0;
86 unsigned long offset
= 0;
87 #define knt1_size 128 /* must be >= kallsyms table size */
91 kdb_printf("kdbnearsym: addr=0x%lx, symtab=%px\n", addr
, symtab
);
92 memset(symtab
, 0, sizeof(*symtab
));
96 knt1
= debug_kmalloc(knt1_size
, GFP_ATOMIC
);
98 kdb_printf("kdbnearsym: addr=0x%lx cannot kmalloc knt1\n",
102 symtab
->sym_name
= kallsyms_lookup(addr
, &symbolsize
, &offset
,
103 (char **)(&symtab
->mod_name
), knt1
);
104 if (offset
> 8*1024*1024) {
105 symtab
->sym_name
= NULL
;
106 addr
= offset
= symbolsize
= 0;
108 symtab
->sym_start
= addr
- offset
;
109 symtab
->sym_end
= symtab
->sym_start
+ symbolsize
;
110 ret
= symtab
->sym_name
!= NULL
&& *(symtab
->sym_name
) != '\0';
114 /* Another 2.6 kallsyms "feature". Sometimes the sym_name is
115 * set but the buffer passed into kallsyms_lookup is not used,
116 * so it contains garbage. The caller has to work out which
117 * buffer needs to be saved.
119 * What was Rusty smoking when he wrote that code?
121 if (symtab
->sym_name
!= knt1
) {
122 strncpy(knt1
, symtab
->sym_name
, knt1_size
);
123 knt1
[knt1_size
-1] = '\0';
125 for (i
= 0; i
< ARRAY_SIZE(kdb_name_table
); ++i
) {
126 if (kdb_name_table
[i
] &&
127 strcmp(kdb_name_table
[i
], knt1
) == 0)
130 if (i
>= ARRAY_SIZE(kdb_name_table
)) {
131 debug_kfree(kdb_name_table
[0]);
132 memmove(kdb_name_table
, kdb_name_table
+1,
133 sizeof(kdb_name_table
[0]) *
134 (ARRAY_SIZE(kdb_name_table
)-1));
137 knt1
= kdb_name_table
[i
];
138 memmove(kdb_name_table
+i
, kdb_name_table
+i
+1,
139 sizeof(kdb_name_table
[0]) *
140 (ARRAY_SIZE(kdb_name_table
)-i
-1));
142 i
= ARRAY_SIZE(kdb_name_table
) - 1;
143 kdb_name_table
[i
] = knt1
;
144 symtab
->sym_name
= kdb_name_table
[i
];
148 if (symtab
->mod_name
== NULL
)
149 symtab
->mod_name
= "kernel";
151 kdb_printf("kdbnearsym: returns %d symtab->sym_start=0x%lx, "
152 "symtab->mod_name=%px, symtab->sym_name=%px (%s)\n", ret
,
153 symtab
->sym_start
, symtab
->mod_name
, symtab
->sym_name
,
161 void kdbnearsym_cleanup(void)
164 for (i
= 0; i
< ARRAY_SIZE(kdb_name_table
); ++i
) {
165 if (kdb_name_table
[i
]) {
166 debug_kfree(kdb_name_table
[i
]);
167 kdb_name_table
[i
] = NULL
;
172 static char ks_namebuf
[KSYM_NAME_LEN
+1], ks_namebuf_prev
[KSYM_NAME_LEN
+1];
175 * kallsyms_symbol_complete
178 * prefix_name prefix of a symbol name to lookup
179 * max_len maximum length that can be returned
181 * Number of symbols which match the given prefix.
183 * prefix_name is changed to contain the longest unique prefix that
184 * starts with this prefix (tab completion).
186 int kallsyms_symbol_complete(char *prefix_name
, int max_len
)
189 int prefix_len
= strlen(prefix_name
), prev_len
= 0;
193 while ((name
= kdb_walk_kallsyms(&pos
))) {
194 if (strncmp(name
, prefix_name
, prefix_len
) == 0) {
195 strscpy(ks_namebuf
, name
, sizeof(ks_namebuf
));
196 /* Work out the longest name that matches the prefix */
198 prev_len
= min_t(int, max_len
-1,
200 memcpy(ks_namebuf_prev
, ks_namebuf
, prev_len
);
201 ks_namebuf_prev
[prev_len
] = '\0';
204 for (i
= 0; i
< prev_len
; i
++) {
205 if (ks_namebuf
[i
] != ks_namebuf_prev
[i
]) {
207 ks_namebuf_prev
[i
] = '\0';
213 if (prev_len
> prefix_len
)
214 memcpy(prefix_name
, ks_namebuf_prev
, prev_len
+1);
219 * kallsyms_symbol_next
222 * prefix_name prefix of a symbol name to lookup
223 * flag 0 means search from the head, 1 means continue search.
224 * buf_size maximum length that can be written to prefix_name
227 * 1 if a symbol matches the given prefix.
228 * 0 if no string found
230 int kallsyms_symbol_next(char *prefix_name
, int flag
, int buf_size
)
232 int prefix_len
= strlen(prefix_name
);
239 while ((name
= kdb_walk_kallsyms(&pos
))) {
240 if (!strncmp(name
, prefix_name
, prefix_len
))
241 return strscpy(prefix_name
, name
, buf_size
);
247 * kdb_symbol_print - Standard method for printing a symbol name and offset.
249 * addr Address to be printed.
250 * symtab Address of symbol data, if NULL this routine does its
252 * punc Punctuation for string, bit field.
254 * The string and its punctuation is only printed if the address
255 * is inside the kernel, except that the value is always printed
258 void kdb_symbol_print(unsigned long addr
, const kdb_symtab_t
*symtab_p
,
261 kdb_symtab_t symtab
, *symtab_p2
;
263 symtab_p2
= (kdb_symtab_t
*)symtab_p
;
266 kdbnearsym(addr
, symtab_p2
);
268 if (!(symtab_p2
->sym_name
|| (punc
& KDB_SP_VALUE
)))
270 if (punc
& KDB_SP_SPACEB
)
272 if (punc
& KDB_SP_VALUE
)
273 kdb_printf(kdb_machreg_fmt0
, addr
);
274 if (symtab_p2
->sym_name
) {
275 if (punc
& KDB_SP_VALUE
)
277 if (punc
& KDB_SP_PAREN
)
279 if (strcmp(symtab_p2
->mod_name
, "kernel"))
280 kdb_printf("[%s]", symtab_p2
->mod_name
);
281 kdb_printf("%s", symtab_p2
->sym_name
);
282 if (addr
!= symtab_p2
->sym_start
)
283 kdb_printf("+0x%lx", addr
- symtab_p2
->sym_start
);
284 if (punc
& KDB_SP_SYMSIZE
)
286 symtab_p2
->sym_end
- symtab_p2
->sym_start
);
287 if (punc
& KDB_SP_PAREN
)
290 if (punc
& KDB_SP_SPACEA
)
292 if (punc
& KDB_SP_NEWLINE
)
297 * kdb_strdup - kdb equivalent of strdup, for disasm code.
299 * str The string to duplicate.
300 * type Flags to kmalloc for the new string.
302 * Address of the new string, NULL if storage could not be allocated.
304 * This is not in lib/string.c because it uses kmalloc which is not
305 * available when string.o is used in boot loaders.
307 char *kdb_strdup(const char *str
, gfp_t type
)
309 int n
= strlen(str
)+1;
310 char *s
= kmalloc(n
, type
);
313 return strcpy(s
, str
);
317 * kdb_getarea_size - Read an area of data. The kdb equivalent of
318 * copy_from_user, with kdb messages for invalid addresses.
320 * res Pointer to the area to receive the result.
321 * addr Address of the area to copy.
322 * size Size of the area.
324 * 0 for success, < 0 for error.
326 int kdb_getarea_size(void *res
, unsigned long addr
, size_t size
)
328 int ret
= copy_from_kernel_nofault((char *)res
, (char *)addr
, size
);
330 if (!KDB_STATE(SUPPRESS
)) {
331 kdb_printf("kdb_getarea: Bad address 0x%lx\n", addr
);
332 KDB_STATE_SET(SUPPRESS
);
336 KDB_STATE_CLEAR(SUPPRESS
);
342 * kdb_putarea_size - Write an area of data. The kdb equivalent of
343 * copy_to_user, with kdb messages for invalid addresses.
345 * addr Address of the area to write to.
346 * res Pointer to the area holding the data.
347 * size Size of the area.
349 * 0 for success, < 0 for error.
351 int kdb_putarea_size(unsigned long addr
, void *res
, size_t size
)
353 int ret
= copy_from_kernel_nofault((char *)addr
, (char *)res
, size
);
355 if (!KDB_STATE(SUPPRESS
)) {
356 kdb_printf("kdb_putarea: Bad address 0x%lx\n", addr
);
357 KDB_STATE_SET(SUPPRESS
);
361 KDB_STATE_CLEAR(SUPPRESS
);
367 * kdb_getphys - Read data from a physical address. Validate the
368 * address is in range, use kmap_atomic() to get data
369 * similar to kdb_getarea() - but for phys addresses
371 * res Pointer to the word to receive the result
372 * addr Physical address of the area to copy
373 * size Size of the area
375 * 0 for success, < 0 for error.
377 static int kdb_getphys(void *res
, unsigned long addr
, size_t size
)
383 pfn
= (addr
>> PAGE_SHIFT
);
386 page
= pfn_to_page(pfn
);
387 vaddr
= kmap_atomic(page
);
388 memcpy(res
, vaddr
+ (addr
& (PAGE_SIZE
- 1)), size
);
389 kunmap_atomic(vaddr
);
397 * word Pointer to the word to receive the result.
398 * addr Address of the area to copy.
399 * size Size of the area.
401 * 0 for success, < 0 for error.
403 int kdb_getphysword(unsigned long *word
, unsigned long addr
, size_t size
)
410 *word
= 0; /* Default value if addr or size is invalid */
414 diag
= kdb_getphys(&w1
, addr
, sizeof(w1
));
419 diag
= kdb_getphys(&w2
, addr
, sizeof(w2
));
424 diag
= kdb_getphys(&w4
, addr
, sizeof(w4
));
429 if (size
<= sizeof(*word
)) {
430 diag
= kdb_getphys(&w8
, addr
, sizeof(w8
));
438 kdb_printf("kdb_getphysword: bad width %ld\n", (long) size
);
444 * kdb_getword - Read a binary value. Unlike kdb_getarea, this treats
447 * word Pointer to the word to receive the result.
448 * addr Address of the area to copy.
449 * size Size of the area.
451 * 0 for success, < 0 for error.
453 int kdb_getword(unsigned long *word
, unsigned long addr
, size_t size
)
460 *word
= 0; /* Default value if addr or size is invalid */
463 diag
= kdb_getarea(w1
, addr
);
468 diag
= kdb_getarea(w2
, addr
);
473 diag
= kdb_getarea(w4
, addr
);
478 if (size
<= sizeof(*word
)) {
479 diag
= kdb_getarea(w8
, addr
);
487 kdb_printf("kdb_getword: bad width %ld\n", (long) size
);
493 * kdb_putword - Write a binary value. Unlike kdb_putarea, this
494 * treats data as numbers.
496 * addr Address of the area to write to..
497 * word The value to set.
498 * size Size of the area.
500 * 0 for success, < 0 for error.
502 int kdb_putword(unsigned long addr
, unsigned long word
, size_t size
)
512 diag
= kdb_putarea(addr
, w1
);
516 diag
= kdb_putarea(addr
, w2
);
520 diag
= kdb_putarea(addr
, w4
);
523 if (size
<= sizeof(word
)) {
525 diag
= kdb_putarea(addr
, w8
);
531 kdb_printf("kdb_putword: bad width %ld\n", (long) size
);
537 * kdb_task_state_string - Convert a string containing any of the
538 * letters DRSTCZEUIMA to a mask for the process state field and
539 * return the value. If no argument is supplied, return the mask
540 * that corresponds to environment variable PS, DRSTCZEU by
543 * s String to convert
545 * Mask for process state.
547 * The mask folds data from several sources into a single long value, so
548 * be careful not to overlap the bits. TASK_* bits are in the LSB,
549 * special cases like UNRUNNABLE are in the MSB. As of 2.6.10-rc1 there
550 * is no overlap between TASK_* and EXIT_* but that may not always be
551 * true, so EXIT_* bits are shifted left 16 bits before being stored in
555 /* unrunnable is < 0 */
556 #define UNRUNNABLE (1UL << (8*sizeof(unsigned long) - 1))
557 #define RUNNING (1UL << (8*sizeof(unsigned long) - 2))
558 #define IDLE (1UL << (8*sizeof(unsigned long) - 3))
559 #define DAEMON (1UL << (8*sizeof(unsigned long) - 4))
561 unsigned long kdb_task_state_string(const char *s
)
567 s
= "DRSTCZEU"; /* default value for ps */
572 res
|= TASK_UNINTERRUPTIBLE
;
578 res
|= TASK_INTERRUPTIBLE
;
587 res
|= EXIT_ZOMBIE
<< 16;
590 res
|= EXIT_DEAD
<< 16;
605 kdb_printf("%s: unknown flag '%c' ignored\n",
615 * kdb_task_state_char - Return the character that represents the task state.
617 * p struct task for the process
619 * One character to represent the task state.
621 char kdb_task_state_char (const struct task_struct
*p
)
628 copy_from_kernel_nofault(&tmp
, (char *)p
, sizeof(unsigned long)))
631 cpu
= kdb_process_cpu(p
);
632 state
= (p
->state
== 0) ? 'R' :
633 (p
->state
< 0) ? 'U' :
634 (p
->state
& TASK_UNINTERRUPTIBLE
) ? 'D' :
635 (p
->state
& TASK_STOPPED
) ? 'T' :
636 (p
->state
& TASK_TRACED
) ? 'C' :
637 (p
->exit_state
& EXIT_ZOMBIE
) ? 'Z' :
638 (p
->exit_state
& EXIT_DEAD
) ? 'E' :
639 (p
->state
& TASK_INTERRUPTIBLE
) ? 'S' : '?';
640 if (is_idle_task(p
)) {
641 /* Idle task. Is it really idle, apart from the kdb
643 if (!kdb_task_has_cpu(p
) || kgdb_info
[cpu
].irq_depth
== 1) {
644 if (cpu
!= kdb_initial_cpu
)
645 state
= 'I'; /* idle task */
647 } else if (!p
->mm
&& state
== 'S') {
648 state
= 'M'; /* sleeping system daemon */
654 * kdb_task_state - Return true if a process has the desired state
657 * p struct task for the process
658 * mask mask from kdb_task_state_string to select processes
660 * True if the process matches at least one criteria defined by the mask.
662 unsigned long kdb_task_state(const struct task_struct
*p
, unsigned long mask
)
664 char state
[] = { kdb_task_state_char(p
), '\0' };
665 return (mask
& kdb_task_state_string(state
)) != 0;
669 * kdb_print_nameval - Print a name and its value, converting the
670 * value to a symbol lookup if possible.
672 * name field name to print
675 void kdb_print_nameval(const char *name
, unsigned long val
)
678 kdb_printf(" %-11.11s ", name
);
679 if (kdbnearsym(val
, &symtab
))
680 kdb_symbol_print(val
, &symtab
,
681 KDB_SP_VALUE
|KDB_SP_SYMSIZE
|KDB_SP_NEWLINE
);
683 kdb_printf("0x%lx\n", val
);
686 /* Last ditch allocator for debugging, so we can still debug even when
687 * the GFP_ATOMIC pool has been exhausted. The algorithms are tuned
688 * for space usage, not for speed. One smallish memory pool, the free
689 * chain is always in ascending address order to allow coalescing,
690 * allocations are done in brute force best fit.
693 struct debug_alloc_header
{
694 u32 next
; /* offset of next header from start of pool */
699 /* The memory returned by this allocator must be aligned, which means
700 * so must the header size. Do not assume that sizeof(struct
701 * debug_alloc_header) is a multiple of the alignment, explicitly
702 * calculate the overhead of this header, including the alignment.
703 * The rest of this code must not use sizeof() on any header or
704 * pointer to a header.
707 #define dah_overhead ALIGN(sizeof(struct debug_alloc_header), dah_align)
709 static u64 debug_alloc_pool_aligned
[256*1024/dah_align
]; /* 256K pool */
710 static char *debug_alloc_pool
= (char *)debug_alloc_pool_aligned
;
711 static u32 dah_first
, dah_first_call
= 1, dah_used
, dah_used_max
;
713 /* Locking is awkward. The debug code is called from all contexts,
714 * including non maskable interrupts. A normal spinlock is not safe
715 * in NMI context. Try to get the debug allocator lock, if it cannot
716 * be obtained after a second then give up. If the lock could not be
717 * previously obtained on this cpu then only try once.
719 * sparse has no annotation for "this function _sometimes_ acquires a
720 * lock", so fudge the acquire/release notation.
722 static DEFINE_SPINLOCK(dap_lock
);
723 static int get_dap_lock(void)
726 static int dap_locked
= -1;
728 if (dap_locked
== smp_processor_id())
733 if (spin_trylock(&dap_lock
)) {
741 dap_locked
= smp_processor_id();
746 void *debug_kmalloc(size_t size
, gfp_t flags
)
748 unsigned int rem
, h_offset
;
749 struct debug_alloc_header
*best
, *bestprev
, *prev
, *h
;
751 if (!get_dap_lock()) {
752 __release(dap_lock
); /* we never actually got it */
755 h
= (struct debug_alloc_header
*)(debug_alloc_pool
+ dah_first
);
756 if (dah_first_call
) {
757 h
->size
= sizeof(debug_alloc_pool_aligned
) - dah_overhead
;
760 size
= ALIGN(size
, dah_align
);
761 prev
= best
= bestprev
= NULL
;
763 if (h
->size
>= size
&& (!best
|| h
->size
< best
->size
)) {
772 h
= (struct debug_alloc_header
*)(debug_alloc_pool
+ h
->next
);
776 rem
= best
->size
- size
;
777 /* The pool must always contain at least one header */
778 if (best
->next
== 0 && bestprev
== NULL
&& rem
< dah_overhead
)
780 if (rem
>= dah_overhead
) {
782 h_offset
= ((char *)best
- debug_alloc_pool
) +
783 dah_overhead
+ best
->size
;
784 h
= (struct debug_alloc_header
*)(debug_alloc_pool
+ h_offset
);
785 h
->size
= rem
- dah_overhead
;
786 h
->next
= best
->next
;
788 h_offset
= best
->next
;
789 best
->caller
= __builtin_return_address(0);
790 dah_used
+= best
->size
;
791 dah_used_max
= max(dah_used
, dah_used_max
);
793 bestprev
->next
= h_offset
;
795 dah_first
= h_offset
;
796 p
= (char *)best
+ dah_overhead
;
797 memset(p
, POISON_INUSE
, best
->size
- 1);
798 *((char *)p
+ best
->size
- 1) = POISON_END
;
800 spin_unlock(&dap_lock
);
804 void debug_kfree(void *p
)
806 struct debug_alloc_header
*h
;
807 unsigned int h_offset
;
810 if ((char *)p
< debug_alloc_pool
||
811 (char *)p
>= debug_alloc_pool
+ sizeof(debug_alloc_pool_aligned
)) {
815 if (!get_dap_lock()) {
816 __release(dap_lock
); /* we never actually got it */
817 return; /* memory leak, cannot be helped */
819 h
= (struct debug_alloc_header
*)((char *)p
- dah_overhead
);
820 memset(p
, POISON_FREE
, h
->size
- 1);
821 *((char *)p
+ h
->size
- 1) = POISON_END
;
824 h_offset
= (char *)h
- debug_alloc_pool
;
825 if (h_offset
< dah_first
) {
827 dah_first
= h_offset
;
829 struct debug_alloc_header
*prev
;
830 unsigned int prev_offset
;
831 prev
= (struct debug_alloc_header
*)(debug_alloc_pool
+
834 if (!prev
->next
|| prev
->next
> h_offset
)
836 prev
= (struct debug_alloc_header
*)
837 (debug_alloc_pool
+ prev
->next
);
839 prev_offset
= (char *)prev
- debug_alloc_pool
;
840 if (prev_offset
+ dah_overhead
+ prev
->size
== h_offset
) {
841 prev
->size
+= dah_overhead
+ h
->size
;
842 memset(h
, POISON_FREE
, dah_overhead
- 1);
843 *((char *)h
+ dah_overhead
- 1) = POISON_END
;
845 h_offset
= prev_offset
;
847 h
->next
= prev
->next
;
848 prev
->next
= h_offset
;
851 if (h_offset
+ dah_overhead
+ h
->size
== h
->next
) {
852 struct debug_alloc_header
*next
;
853 next
= (struct debug_alloc_header
*)
854 (debug_alloc_pool
+ h
->next
);
855 h
->size
+= dah_overhead
+ next
->size
;
856 h
->next
= next
->next
;
857 memset(next
, POISON_FREE
, dah_overhead
- 1);
858 *((char *)next
+ dah_overhead
- 1) = POISON_END
;
860 spin_unlock(&dap_lock
);
863 void debug_kusage(void)
865 struct debug_alloc_header
*h_free
, *h_used
;
867 /* FIXME: using dah for ia64 unwind always results in a memory leak.
868 * Fix that memory leak first, then set debug_kusage_one_time = 1 for
871 static int debug_kusage_one_time
;
873 static int debug_kusage_one_time
= 1;
875 if (!get_dap_lock()) {
876 __release(dap_lock
); /* we never actually got it */
879 h_free
= (struct debug_alloc_header
*)(debug_alloc_pool
+ dah_first
);
880 if (dah_first
== 0 &&
881 (h_free
->size
== sizeof(debug_alloc_pool_aligned
) - dah_overhead
||
884 if (!debug_kusage_one_time
)
886 debug_kusage_one_time
= 0;
887 kdb_printf("%s: debug_kmalloc memory leak dah_first %d\n",
888 __func__
, dah_first
);
890 h_used
= (struct debug_alloc_header
*)debug_alloc_pool
;
891 kdb_printf("%s: h_used %px size %d\n", __func__
, h_used
,
895 h_used
= (struct debug_alloc_header
*)
896 ((char *)h_free
+ dah_overhead
+ h_free
->size
);
897 kdb_printf("%s: h_used %px size %d caller %px\n",
898 __func__
, h_used
, h_used
->size
, h_used
->caller
);
899 h_free
= (struct debug_alloc_header
*)
900 (debug_alloc_pool
+ h_free
->next
);
901 } while (h_free
->next
);
902 h_used
= (struct debug_alloc_header
*)
903 ((char *)h_free
+ dah_overhead
+ h_free
->size
);
904 if ((char *)h_used
- debug_alloc_pool
!=
905 sizeof(debug_alloc_pool_aligned
))
906 kdb_printf("%s: h_used %px size %d caller %px\n",
907 __func__
, h_used
, h_used
->size
, h_used
->caller
);
909 spin_unlock(&dap_lock
);
912 /* Maintain a small stack of kdb_flags to allow recursion without disturbing
913 * the global kdb state.
916 static int kdb_flags_stack
[4], kdb_flags_index
;
918 void kdb_save_flags(void)
920 BUG_ON(kdb_flags_index
>= ARRAY_SIZE(kdb_flags_stack
));
921 kdb_flags_stack
[kdb_flags_index
++] = kdb_flags
;
924 void kdb_restore_flags(void)
926 BUG_ON(kdb_flags_index
<= 0);
927 kdb_flags
= kdb_flags_stack
[--kdb_flags_index
];