Branch data Line data Source code
1 : : /*
2 : : * Kernel Debugger Architecture Independent Support Functions
3 : : *
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
6 : : * for more details.
7 : : *
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>
11 : : */
12 : :
13 : : #include <stdarg.h>
14 : : #include <linux/types.h>
15 : : #include <linux/sched.h>
16 : : #include <linux/mm.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"
29 : :
30 : : /*
31 : : * kdbgetsymval - Return the address of the given symbol.
32 : : *
33 : : * Parameters:
34 : : * symname Character string containing symbol name
35 : : * symtab Structure to receive results
36 : : * Returns:
37 : : * 0 Symbol not found, symtab zero filled
38 : : * 1 Symbol mapped to module/symbol/section, data in symtab
39 : : */
40 : 0 : int kdbgetsymval(const char *symname, kdb_symtab_t *symtab)
41 : : {
42 [ # # ]: 0 : if (KDB_DEBUG(AR))
43 : 0 : kdb_printf("kdbgetsymval: symname=%s, symtab=%px\n", symname,
44 : : symtab);
45 : 0 : memset(symtab, 0, sizeof(*symtab));
46 : 0 : symtab->sym_start = kallsyms_lookup_name(symname);
47 [ # # ]: 0 : if (symtab->sym_start) {
48 [ # # ]: 0 : if (KDB_DEBUG(AR))
49 : 0 : kdb_printf("kdbgetsymval: returns 1, "
50 : : "symtab->sym_start=0x%lx\n",
51 : : symtab->sym_start);
52 : : return 1;
53 : : }
54 [ # # ]: 0 : if (KDB_DEBUG(AR))
55 : 0 : kdb_printf("kdbgetsymval: returns 0\n");
56 : : return 0;
57 : : }
58 : : EXPORT_SYMBOL(kdbgetsymval);
59 : :
60 : : static char *kdb_name_table[100]; /* arbitrary size */
61 : :
62 : : /*
63 : : * kdbnearsym - Return the name of the symbol with the nearest address
64 : : * less than 'addr'.
65 : : *
66 : : * Parameters:
67 : : * addr Address to check for symbol near
68 : : * symtab Structure to receive results
69 : : * Returns:
70 : : * 0 No sections contain this address, symtab zero filled
71 : : * 1 Address mapped to module/symbol/section, data in symtab
72 : : * Remarks:
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.
81 : : */
82 : 0 : int kdbnearsym(unsigned long addr, kdb_symtab_t *symtab)
83 : : {
84 : : int ret = 0;
85 : 0 : unsigned long symbolsize = 0;
86 : 0 : unsigned long offset = 0;
87 : : #define knt1_size 128 /* must be >= kallsyms table size */
88 : : char *knt1 = NULL;
89 : :
90 [ # # ]: 0 : if (KDB_DEBUG(AR))
91 : 0 : kdb_printf("kdbnearsym: addr=0x%lx, symtab=%px\n", addr, symtab);
92 : 0 : memset(symtab, 0, sizeof(*symtab));
93 : :
94 [ # # ]: 0 : if (addr < 4096)
95 : : goto out;
96 : 0 : knt1 = debug_kmalloc(knt1_size, GFP_ATOMIC);
97 [ # # ]: 0 : if (!knt1) {
98 : 0 : kdb_printf("kdbnearsym: addr=0x%lx cannot kmalloc knt1\n",
99 : : addr);
100 : 0 : goto out;
101 : : }
102 : 0 : symtab->sym_name = kallsyms_lookup(addr, &symbolsize , &offset,
103 : 0 : (char **)(&symtab->mod_name), knt1);
104 [ # # ]: 0 : if (offset > 8*1024*1024) {
105 : 0 : symtab->sym_name = NULL;
106 : 0 : addr = offset = symbolsize = 0;
107 : : }
108 : 0 : symtab->sym_start = addr - offset;
109 : 0 : symtab->sym_end = symtab->sym_start + symbolsize;
110 [ # # # # ]: 0 : ret = symtab->sym_name != NULL && *(symtab->sym_name) != '\0';
111 : :
112 [ # # ]: 0 : if (ret) {
113 : : int i;
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.
118 : : *
119 : : * What was Rusty smoking when he wrote that code?
120 : : */
121 [ # # ]: 0 : if (symtab->sym_name != knt1) {
122 : 0 : strncpy(knt1, symtab->sym_name, knt1_size);
123 : 0 : knt1[knt1_size-1] = '\0';
124 : : }
125 [ # # ]: 0 : for (i = 0; i < ARRAY_SIZE(kdb_name_table); ++i) {
126 [ # # # # ]: 0 : if (kdb_name_table[i] &&
127 : 0 : strcmp(kdb_name_table[i], knt1) == 0)
128 : : break;
129 : : }
130 [ # # ]: 0 : if (i >= ARRAY_SIZE(kdb_name_table)) {
131 : 0 : debug_kfree(kdb_name_table[0]);
132 : 0 : memmove(kdb_name_table, kdb_name_table+1,
133 : : sizeof(kdb_name_table[0]) *
134 : : (ARRAY_SIZE(kdb_name_table)-1));
135 : : } else {
136 : 0 : debug_kfree(knt1);
137 : 0 : knt1 = kdb_name_table[i];
138 : 0 : memmove(kdb_name_table+i, kdb_name_table+i+1,
139 : : sizeof(kdb_name_table[0]) *
140 : : (ARRAY_SIZE(kdb_name_table)-i-1));
141 : : }
142 : : i = ARRAY_SIZE(kdb_name_table) - 1;
143 : 0 : kdb_name_table[i] = knt1;
144 : 0 : symtab->sym_name = kdb_name_table[i];
145 : : knt1 = NULL;
146 : : }
147 : :
148 [ # # ]: 0 : if (symtab->mod_name == NULL)
149 : 0 : symtab->mod_name = "kernel";
150 [ # # ]: 0 : if (KDB_DEBUG(AR))
151 : 0 : 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,
154 : : symtab->sym_name);
155 : :
156 : : out:
157 : 0 : debug_kfree(knt1);
158 : 0 : return ret;
159 : : }
160 : :
161 : 0 : void kdbnearsym_cleanup(void)
162 : : {
163 : : int i;
164 [ # # ]: 0 : for (i = 0; i < ARRAY_SIZE(kdb_name_table); ++i) {
165 [ # # ]: 0 : if (kdb_name_table[i]) {
166 : 0 : debug_kfree(kdb_name_table[i]);
167 : 0 : kdb_name_table[i] = NULL;
168 : : }
169 : : }
170 : 0 : }
171 : :
172 : : static char ks_namebuf[KSYM_NAME_LEN+1], ks_namebuf_prev[KSYM_NAME_LEN+1];
173 : :
174 : : /*
175 : : * kallsyms_symbol_complete
176 : : *
177 : : * Parameters:
178 : : * prefix_name prefix of a symbol name to lookup
179 : : * max_len maximum length that can be returned
180 : : * Returns:
181 : : * Number of symbols which match the given prefix.
182 : : * Notes:
183 : : * prefix_name is changed to contain the longest unique prefix that
184 : : * starts with this prefix (tab completion).
185 : : */
186 : 0 : int kallsyms_symbol_complete(char *prefix_name, int max_len)
187 : : {
188 : 0 : loff_t pos = 0;
189 : 0 : int prefix_len = strlen(prefix_name), prev_len = 0;
190 : : int i, number = 0;
191 : : const char *name;
192 : :
193 [ # # ]: 0 : while ((name = kdb_walk_kallsyms(&pos))) {
194 [ # # ]: 0 : if (strncmp(name, prefix_name, prefix_len) == 0) {
195 : 0 : strscpy(ks_namebuf, name, sizeof(ks_namebuf));
196 : : /* Work out the longest name that matches the prefix */
197 [ # # ]: 0 : if (++number == 1) {
198 : 0 : prev_len = min_t(int, max_len-1,
199 : : strlen(ks_namebuf));
200 : 0 : memcpy(ks_namebuf_prev, ks_namebuf, prev_len);
201 : 0 : ks_namebuf_prev[prev_len] = '\0';
202 : 0 : continue;
203 : : }
204 [ # # ]: 0 : for (i = 0; i < prev_len; i++) {
205 [ # # ]: 0 : if (ks_namebuf[i] != ks_namebuf_prev[i]) {
206 : 0 : prev_len = i;
207 : 0 : ks_namebuf_prev[i] = '\0';
208 : 0 : break;
209 : : }
210 : : }
211 : : }
212 : : }
213 [ # # ]: 0 : if (prev_len > prefix_len)
214 : 0 : memcpy(prefix_name, ks_namebuf_prev, prev_len+1);
215 : 0 : return number;
216 : : }
217 : :
218 : : /*
219 : : * kallsyms_symbol_next
220 : : *
221 : : * Parameters:
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
225 : : * buffer
226 : : * Returns:
227 : : * 1 if a symbol matches the given prefix.
228 : : * 0 if no string found
229 : : */
230 : 0 : int kallsyms_symbol_next(char *prefix_name, int flag, int buf_size)
231 : : {
232 : 0 : int prefix_len = strlen(prefix_name);
233 : : static loff_t pos;
234 : : const char *name;
235 : :
236 [ # # ]: 0 : if (!flag)
237 : 0 : pos = 0;
238 : :
239 [ # # ]: 0 : while ((name = kdb_walk_kallsyms(&pos))) {
240 [ # # ]: 0 : if (!strncmp(name, prefix_name, prefix_len))
241 : 0 : return strscpy(prefix_name, name, buf_size);
242 : : }
243 : : return 0;
244 : : }
245 : :
246 : : /*
247 : : * kdb_symbol_print - Standard method for printing a symbol name and offset.
248 : : * Inputs:
249 : : * addr Address to be printed.
250 : : * symtab Address of symbol data, if NULL this routine does its
251 : : * own lookup.
252 : : * punc Punctuation for string, bit field.
253 : : * Remarks:
254 : : * The string and its punctuation is only printed if the address
255 : : * is inside the kernel, except that the value is always printed
256 : : * when requested.
257 : : */
258 : 0 : void kdb_symbol_print(unsigned long addr, const kdb_symtab_t *symtab_p,
259 : : unsigned int punc)
260 : : {
261 : : kdb_symtab_t symtab, *symtab_p2;
262 [ # # ]: 0 : if (symtab_p) {
263 : : symtab_p2 = (kdb_symtab_t *)symtab_p;
264 : : } else {
265 : : symtab_p2 = &symtab;
266 : 0 : kdbnearsym(addr, symtab_p2);
267 : : }
268 [ # # # # ]: 0 : if (!(symtab_p2->sym_name || (punc & KDB_SP_VALUE)))
269 : 0 : return;
270 [ # # ]: 0 : if (punc & KDB_SP_SPACEB)
271 : 0 : kdb_printf(" ");
272 [ # # ]: 0 : if (punc & KDB_SP_VALUE)
273 : 0 : kdb_printf(kdb_machreg_fmt0, addr);
274 [ # # ]: 0 : if (symtab_p2->sym_name) {
275 [ # # ]: 0 : if (punc & KDB_SP_VALUE)
276 : 0 : kdb_printf(" ");
277 [ # # ]: 0 : if (punc & KDB_SP_PAREN)
278 : 0 : kdb_printf("(");
279 [ # # ]: 0 : if (strcmp(symtab_p2->mod_name, "kernel"))
280 : 0 : kdb_printf("[%s]", symtab_p2->mod_name);
281 : 0 : kdb_printf("%s", symtab_p2->sym_name);
282 [ # # ]: 0 : if (addr != symtab_p2->sym_start)
283 : 0 : kdb_printf("+0x%lx", addr - symtab_p2->sym_start);
284 [ # # ]: 0 : if (punc & KDB_SP_SYMSIZE)
285 : 0 : kdb_printf("/0x%lx",
286 : 0 : symtab_p2->sym_end - symtab_p2->sym_start);
287 [ # # ]: 0 : if (punc & KDB_SP_PAREN)
288 : 0 : kdb_printf(")");
289 : : }
290 [ # # ]: 0 : if (punc & KDB_SP_SPACEA)
291 : 0 : kdb_printf(" ");
292 [ # # ]: 0 : if (punc & KDB_SP_NEWLINE)
293 : 0 : kdb_printf("\n");
294 : : }
295 : :
296 : : /*
297 : : * kdb_strdup - kdb equivalent of strdup, for disasm code.
298 : : * Inputs:
299 : : * str The string to duplicate.
300 : : * type Flags to kmalloc for the new string.
301 : : * Returns:
302 : : * Address of the new string, NULL if storage could not be allocated.
303 : : * Remarks:
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.
306 : : */
307 : 4554 : char *kdb_strdup(const char *str, gfp_t type)
308 : : {
309 : 4554 : int n = strlen(str)+1;
310 : : char *s = kmalloc(n, type);
311 [ + - ]: 4554 : if (!s)
312 : : return NULL;
313 : 4554 : return strcpy(s, str);
314 : : }
315 : :
316 : : /*
317 : : * kdb_getarea_size - Read an area of data. The kdb equivalent of
318 : : * copy_from_user, with kdb messages for invalid addresses.
319 : : * Inputs:
320 : : * res Pointer to the area to receive the result.
321 : : * addr Address of the area to copy.
322 : : * size Size of the area.
323 : : * Returns:
324 : : * 0 for success, < 0 for error.
325 : : */
326 : 0 : int kdb_getarea_size(void *res, unsigned long addr, size_t size)
327 : : {
328 : 0 : int ret = probe_kernel_read((char *)res, (char *)addr, size);
329 [ # # ]: 0 : if (ret) {
330 [ # # ]: 0 : if (!KDB_STATE(SUPPRESS)) {
331 : 0 : kdb_printf("kdb_getarea: Bad address 0x%lx\n", addr);
332 : 0 : KDB_STATE_SET(SUPPRESS);
333 : : }
334 : : ret = KDB_BADADDR;
335 : : } else {
336 : 0 : KDB_STATE_CLEAR(SUPPRESS);
337 : : }
338 : 0 : return ret;
339 : : }
340 : :
341 : : /*
342 : : * kdb_putarea_size - Write an area of data. The kdb equivalent of
343 : : * copy_to_user, with kdb messages for invalid addresses.
344 : : * Inputs:
345 : : * addr Address of the area to write to.
346 : : * res Pointer to the area holding the data.
347 : : * size Size of the area.
348 : : * Returns:
349 : : * 0 for success, < 0 for error.
350 : : */
351 : 0 : int kdb_putarea_size(unsigned long addr, void *res, size_t size)
352 : : {
353 : 0 : int ret = probe_kernel_read((char *)addr, (char *)res, size);
354 [ # # ]: 0 : if (ret) {
355 [ # # ]: 0 : if (!KDB_STATE(SUPPRESS)) {
356 : 0 : kdb_printf("kdb_putarea: Bad address 0x%lx\n", addr);
357 : 0 : KDB_STATE_SET(SUPPRESS);
358 : : }
359 : : ret = KDB_BADADDR;
360 : : } else {
361 : 0 : KDB_STATE_CLEAR(SUPPRESS);
362 : : }
363 : 0 : return ret;
364 : : }
365 : :
366 : : /*
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
370 : : * Inputs:
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
374 : : * Returns:
375 : : * 0 for success, < 0 for error.
376 : : */
377 : 0 : static int kdb_getphys(void *res, unsigned long addr, size_t size)
378 : : {
379 : : unsigned long pfn;
380 : : void *vaddr;
381 : : struct page *page;
382 : :
383 : 0 : pfn = (addr >> PAGE_SHIFT);
384 [ # # ]: 0 : if (!pfn_valid(pfn))
385 : : return 1;
386 : 0 : page = pfn_to_page(pfn);
387 : 0 : vaddr = kmap_atomic(page);
388 : 0 : memcpy(res, vaddr + (addr & (PAGE_SIZE - 1)), size);
389 : : kunmap_atomic(vaddr);
390 : :
391 : 0 : return 0;
392 : : }
393 : :
394 : : /*
395 : : * kdb_getphysword
396 : : * Inputs:
397 : : * word Pointer to the word to receive the result.
398 : : * addr Address of the area to copy.
399 : : * size Size of the area.
400 : : * Returns:
401 : : * 0 for success, < 0 for error.
402 : : */
403 : 0 : int kdb_getphysword(unsigned long *word, unsigned long addr, size_t size)
404 : : {
405 : : int diag;
406 : : __u8 w1;
407 : : __u16 w2;
408 : : __u32 w4;
409 : : __u64 w8;
410 : 0 : *word = 0; /* Default value if addr or size is invalid */
411 : :
412 [ # # # # : 0 : switch (size) {
# ]
413 : : case 1:
414 : 0 : diag = kdb_getphys(&w1, addr, sizeof(w1));
415 [ # # ]: 0 : if (!diag)
416 : 0 : *word = w1;
417 : : break;
418 : : case 2:
419 : 0 : diag = kdb_getphys(&w2, addr, sizeof(w2));
420 [ # # ]: 0 : if (!diag)
421 : 0 : *word = w2;
422 : : break;
423 : : case 4:
424 : 0 : diag = kdb_getphys(&w4, addr, sizeof(w4));
425 [ # # ]: 0 : if (!diag)
426 : 0 : *word = w4;
427 : : break;
428 : : case 8:
429 [ # # ]: 0 : if (size <= sizeof(*word)) {
430 : 0 : diag = kdb_getphys(&w8, addr, sizeof(w8));
431 [ # # ]: 0 : if (!diag)
432 : 0 : *word = w8;
433 : : break;
434 : : }
435 : : /* fall through */
436 : : default:
437 : : diag = KDB_BADWIDTH;
438 : 0 : kdb_printf("kdb_getphysword: bad width %ld\n", (long) size);
439 : : }
440 : 0 : return diag;
441 : : }
442 : :
443 : : /*
444 : : * kdb_getword - Read a binary value. Unlike kdb_getarea, this treats
445 : : * data as numbers.
446 : : * Inputs:
447 : : * word Pointer to the word to receive the result.
448 : : * addr Address of the area to copy.
449 : : * size Size of the area.
450 : : * Returns:
451 : : * 0 for success, < 0 for error.
452 : : */
453 : 0 : int kdb_getword(unsigned long *word, unsigned long addr, size_t size)
454 : : {
455 : : int diag;
456 : : __u8 w1;
457 : : __u16 w2;
458 : : __u32 w4;
459 : : __u64 w8;
460 : 0 : *word = 0; /* Default value if addr or size is invalid */
461 [ # # # # : 0 : switch (size) {
# ]
462 : : case 1:
463 : 0 : diag = kdb_getarea(w1, addr);
464 [ # # ]: 0 : if (!diag)
465 : 0 : *word = w1;
466 : : break;
467 : : case 2:
468 : 0 : diag = kdb_getarea(w2, addr);
469 [ # # ]: 0 : if (!diag)
470 : 0 : *word = w2;
471 : : break;
472 : : case 4:
473 : 0 : diag = kdb_getarea(w4, addr);
474 [ # # ]: 0 : if (!diag)
475 : 0 : *word = w4;
476 : : break;
477 : : case 8:
478 [ # # ]: 0 : if (size <= sizeof(*word)) {
479 : 0 : diag = kdb_getarea(w8, addr);
480 [ # # ]: 0 : if (!diag)
481 : 0 : *word = w8;
482 : : break;
483 : : }
484 : : /* fall through */
485 : : default:
486 : : diag = KDB_BADWIDTH;
487 : 0 : kdb_printf("kdb_getword: bad width %ld\n", (long) size);
488 : : }
489 : 0 : return diag;
490 : : }
491 : :
492 : : /*
493 : : * kdb_putword - Write a binary value. Unlike kdb_putarea, this
494 : : * treats data as numbers.
495 : : * Inputs:
496 : : * addr Address of the area to write to..
497 : : * word The value to set.
498 : : * size Size of the area.
499 : : * Returns:
500 : : * 0 for success, < 0 for error.
501 : : */
502 : 0 : int kdb_putword(unsigned long addr, unsigned long word, size_t size)
503 : : {
504 : : int diag;
505 : : __u8 w1;
506 : : __u16 w2;
507 : : __u32 w4;
508 : : __u64 w8;
509 [ # # # # : 0 : switch (size) {
# ]
510 : : case 1:
511 : 0 : w1 = word;
512 : 0 : diag = kdb_putarea(addr, w1);
513 : 0 : break;
514 : : case 2:
515 : 0 : w2 = word;
516 : 0 : diag = kdb_putarea(addr, w2);
517 : 0 : break;
518 : : case 4:
519 : 0 : w4 = word;
520 : 0 : diag = kdb_putarea(addr, w4);
521 : 0 : break;
522 : : case 8:
523 [ # # ]: 0 : if (size <= sizeof(word)) {
524 : 0 : w8 = word;
525 : 0 : diag = kdb_putarea(addr, w8);
526 : 0 : break;
527 : : }
528 : : /* fall through */
529 : : default:
530 : : diag = KDB_BADWIDTH;
531 : 0 : kdb_printf("kdb_putword: bad width %ld\n", (long) size);
532 : : }
533 : 0 : return diag;
534 : : }
535 : :
536 : : /*
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
541 : : * default.
542 : : * Inputs:
543 : : * s String to convert
544 : : * Returns:
545 : : * Mask for process state.
546 : : * Notes:
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
552 : : * the mask.
553 : : */
554 : :
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))
560 : :
561 : 0 : unsigned long kdb_task_state_string(const char *s)
562 : : {
563 : : long res = 0;
564 [ # # ]: 0 : if (!s) {
565 : 0 : s = kdbgetenv("PS");
566 [ # # ]: 0 : if (!s)
567 : : s = "DRSTCZEU"; /* default value for ps */
568 : : }
569 [ # # ]: 0 : while (*s) {
570 [ # # # # : 0 : switch (*s) {
# # # # #
# # # ]
571 : : case 'D':
572 : 0 : res |= TASK_UNINTERRUPTIBLE;
573 : 0 : break;
574 : : case 'R':
575 : 0 : res |= RUNNING;
576 : 0 : break;
577 : : case 'S':
578 : 0 : res |= TASK_INTERRUPTIBLE;
579 : 0 : break;
580 : : case 'T':
581 : 0 : res |= TASK_STOPPED;
582 : 0 : break;
583 : : case 'C':
584 : 0 : res |= TASK_TRACED;
585 : 0 : break;
586 : : case 'Z':
587 : 0 : res |= EXIT_ZOMBIE << 16;
588 : 0 : break;
589 : : case 'E':
590 : 0 : res |= EXIT_DEAD << 16;
591 : 0 : break;
592 : : case 'U':
593 : 0 : res |= UNRUNNABLE;
594 : 0 : break;
595 : : case 'I':
596 : 0 : res |= IDLE;
597 : 0 : break;
598 : : case 'M':
599 : 0 : res |= DAEMON;
600 : 0 : break;
601 : : case 'A':
602 : : res = ~0UL;
603 : : break;
604 : : default:
605 : 0 : kdb_printf("%s: unknown flag '%c' ignored\n",
606 : : __func__, *s);
607 : 0 : break;
608 : : }
609 : 0 : ++s;
610 : : }
611 : 0 : return res;
612 : : }
613 : :
614 : : /*
615 : : * kdb_task_state_char - Return the character that represents the task state.
616 : : * Inputs:
617 : : * p struct task for the process
618 : : * Returns:
619 : : * One character to represent the task state.
620 : : */
621 : 0 : char kdb_task_state_char (const struct task_struct *p)
622 : : {
623 : : int cpu;
624 : : char state;
625 : : unsigned long tmp;
626 : :
627 [ # # # # ]: 0 : if (!p || probe_kernel_read(&tmp, (char *)p, sizeof(unsigned long)))
628 : : return 'E';
629 : :
630 : : cpu = kdb_process_cpu(p);
631 [ # # # # : 0 : state = (p->state == 0) ? 'R' :
# # # # #
# # # # #
# # ]
632 : 0 : (p->state < 0) ? 'U' :
633 : 0 : (p->state & TASK_UNINTERRUPTIBLE) ? 'D' :
634 : 0 : (p->state & TASK_STOPPED) ? 'T' :
635 : 0 : (p->state & TASK_TRACED) ? 'C' :
636 : 0 : (p->exit_state & EXIT_ZOMBIE) ? 'Z' :
637 : 0 : (p->exit_state & EXIT_DEAD) ? 'E' :
638 : 0 : (p->state & TASK_INTERRUPTIBLE) ? 'S' : '?';
639 [ # # ]: 0 : if (is_idle_task(p)) {
640 : : /* Idle task. Is it really idle, apart from the kdb
641 : : * interrupt? */
642 [ # # # # ]: 0 : if (!kdb_task_has_cpu(p) || kgdb_info[cpu].irq_depth == 1) {
643 [ # # ]: 0 : if (cpu != kdb_initial_cpu)
644 : : state = 'I'; /* idle task */
645 : : }
646 [ # # # # ]: 0 : } else if (!p->mm && state == 'S') {
647 : : state = 'M'; /* sleeping system daemon */
648 : : }
649 : 0 : return state;
650 : : }
651 : :
652 : : /*
653 : : * kdb_task_state - Return true if a process has the desired state
654 : : * given by the mask.
655 : : * Inputs:
656 : : * p struct task for the process
657 : : * mask mask from kdb_task_state_string to select processes
658 : : * Returns:
659 : : * True if the process matches at least one criteria defined by the mask.
660 : : */
661 : 0 : unsigned long kdb_task_state(const struct task_struct *p, unsigned long mask)
662 : : {
663 : 0 : char state[] = { kdb_task_state_char(p), '\0' };
664 : 0 : return (mask & kdb_task_state_string(state)) != 0;
665 : : }
666 : :
667 : : /*
668 : : * kdb_print_nameval - Print a name and its value, converting the
669 : : * value to a symbol lookup if possible.
670 : : * Inputs:
671 : : * name field name to print
672 : : * val value of field
673 : : */
674 : 0 : void kdb_print_nameval(const char *name, unsigned long val)
675 : : {
676 : : kdb_symtab_t symtab;
677 : 0 : kdb_printf(" %-11.11s ", name);
678 [ # # ]: 0 : if (kdbnearsym(val, &symtab))
679 : 0 : kdb_symbol_print(val, &symtab,
680 : : KDB_SP_VALUE|KDB_SP_SYMSIZE|KDB_SP_NEWLINE);
681 : : else
682 : 0 : kdb_printf("0x%lx\n", val);
683 : 0 : }
684 : :
685 : : /* Last ditch allocator for debugging, so we can still debug even when
686 : : * the GFP_ATOMIC pool has been exhausted. The algorithms are tuned
687 : : * for space usage, not for speed. One smallish memory pool, the free
688 : : * chain is always in ascending address order to allow coalescing,
689 : : * allocations are done in brute force best fit.
690 : : */
691 : :
692 : : struct debug_alloc_header {
693 : : u32 next; /* offset of next header from start of pool */
694 : : u32 size;
695 : : void *caller;
696 : : };
697 : :
698 : : /* The memory returned by this allocator must be aligned, which means
699 : : * so must the header size. Do not assume that sizeof(struct
700 : : * debug_alloc_header) is a multiple of the alignment, explicitly
701 : : * calculate the overhead of this header, including the alignment.
702 : : * The rest of this code must not use sizeof() on any header or
703 : : * pointer to a header.
704 : : */
705 : : #define dah_align 8
706 : : #define dah_overhead ALIGN(sizeof(struct debug_alloc_header), dah_align)
707 : :
708 : : static u64 debug_alloc_pool_aligned[256*1024/dah_align]; /* 256K pool */
709 : : static char *debug_alloc_pool = (char *)debug_alloc_pool_aligned;
710 : : static u32 dah_first, dah_first_call = 1, dah_used, dah_used_max;
711 : :
712 : : /* Locking is awkward. The debug code is called from all contexts,
713 : : * including non maskable interrupts. A normal spinlock is not safe
714 : : * in NMI context. Try to get the debug allocator lock, if it cannot
715 : : * be obtained after a second then give up. If the lock could not be
716 : : * previously obtained on this cpu then only try once.
717 : : *
718 : : * sparse has no annotation for "this function _sometimes_ acquires a
719 : : * lock", so fudge the acquire/release notation.
720 : : */
721 : : static DEFINE_SPINLOCK(dap_lock);
722 : 0 : static int get_dap_lock(void)
723 : : __acquires(dap_lock)
724 : : {
725 : : static int dap_locked = -1;
726 : : int count;
727 [ # # ]: 0 : if (dap_locked == smp_processor_id())
728 : : count = 1;
729 : : else
730 : : count = 1000;
731 : : while (1) {
732 [ # # ]: 0 : if (spin_trylock(&dap_lock)) {
733 : 0 : dap_locked = -1;
734 : 0 : return 1;
735 : : }
736 [ # # ]: 0 : if (!count--)
737 : : break;
738 : 0 : udelay(1000);
739 : 0 : }
740 : 0 : dap_locked = smp_processor_id();
741 : : __acquire(dap_lock);
742 : 0 : return 0;
743 : : }
744 : :
745 : 0 : void *debug_kmalloc(size_t size, gfp_t flags)
746 : : {
747 : : unsigned int rem, h_offset;
748 : : struct debug_alloc_header *best, *bestprev, *prev, *h;
749 : : void *p = NULL;
750 [ # # ]: 0 : if (!get_dap_lock()) {
751 : : __release(dap_lock); /* we never actually got it */
752 : : return NULL;
753 : : }
754 : 0 : h = (struct debug_alloc_header *)(debug_alloc_pool + dah_first);
755 [ # # ]: 0 : if (dah_first_call) {
756 : 0 : h->size = sizeof(debug_alloc_pool_aligned) - dah_overhead;
757 : 0 : dah_first_call = 0;
758 : : }
759 : 0 : size = ALIGN(size, dah_align);
760 : : prev = best = bestprev = NULL;
761 : : while (1) {
762 [ # # # # : 0 : if (h->size >= size && (!best || h->size < best->size)) {
# # ]
763 : : best = h;
764 : : bestprev = prev;
765 [ # # ]: 0 : if (h->size == size)
766 : : break;
767 : : }
768 [ # # ]: 0 : if (!h->next)
769 : : break;
770 : : prev = h;
771 : 0 : h = (struct debug_alloc_header *)(debug_alloc_pool + h->next);
772 : 0 : }
773 [ # # ]: 0 : if (!best)
774 : : goto out;
775 : 0 : rem = best->size - size;
776 : : /* The pool must always contain at least one header */
777 [ # # # # ]: 0 : if (best->next == 0 && bestprev == NULL && rem < dah_overhead)
778 : : goto out;
779 [ # # ]: 0 : if (rem >= dah_overhead) {
780 : 0 : best->size = size;
781 : 0 : h_offset = ((char *)best - debug_alloc_pool) +
782 : 0 : dah_overhead + best->size;
783 : 0 : h = (struct debug_alloc_header *)(debug_alloc_pool + h_offset);
784 : 0 : h->size = rem - dah_overhead;
785 : 0 : h->next = best->next;
786 : : } else
787 : : h_offset = best->next;
788 : 0 : best->caller = __builtin_return_address(0);
789 : 0 : dah_used += best->size;
790 : 0 : dah_used_max = max(dah_used, dah_used_max);
791 [ # # ]: 0 : if (bestprev)
792 : 0 : bestprev->next = h_offset;
793 : : else
794 : 0 : dah_first = h_offset;
795 : 0 : p = (char *)best + dah_overhead;
796 : 0 : memset(p, POISON_INUSE, best->size - 1);
797 : 0 : *((char *)p + best->size - 1) = POISON_END;
798 : : out:
799 : : spin_unlock(&dap_lock);
800 : 0 : return p;
801 : : }
802 : :
803 : 0 : void debug_kfree(void *p)
804 : : {
805 : : struct debug_alloc_header *h;
806 : : unsigned int h_offset;
807 [ # # ]: 0 : if (!p)
808 : : return;
809 [ # # # # ]: 0 : if ((char *)p < debug_alloc_pool ||
810 : 0 : (char *)p >= debug_alloc_pool + sizeof(debug_alloc_pool_aligned)) {
811 : 0 : kfree(p);
812 : 0 : return;
813 : : }
814 [ # # ]: 0 : if (!get_dap_lock()) {
815 : : __release(dap_lock); /* we never actually got it */
816 : : return; /* memory leak, cannot be helped */
817 : : }
818 : 0 : h = (struct debug_alloc_header *)((char *)p - dah_overhead);
819 : 0 : memset(p, POISON_FREE, h->size - 1);
820 : 0 : *((char *)p + h->size - 1) = POISON_END;
821 : 0 : h->caller = NULL;
822 : 0 : dah_used -= h->size;
823 : 0 : h_offset = (char *)h - debug_alloc_pool;
824 [ # # ]: 0 : if (h_offset < dah_first) {
825 : 0 : h->next = dah_first;
826 : 0 : dah_first = h_offset;
827 : : } else {
828 : : struct debug_alloc_header *prev;
829 : : unsigned int prev_offset;
830 : 0 : prev = (struct debug_alloc_header *)(debug_alloc_pool +
831 : : dah_first);
832 : : while (1) {
833 [ # # # # ]: 0 : if (!prev->next || prev->next > h_offset)
834 : : break;
835 : 0 : prev = (struct debug_alloc_header *)
836 : : (debug_alloc_pool + prev->next);
837 : 0 : }
838 : 0 : prev_offset = (char *)prev - debug_alloc_pool;
839 [ # # ]: 0 : if (prev_offset + dah_overhead + prev->size == h_offset) {
840 : 0 : prev->size += dah_overhead + h->size;
841 : 0 : memset(h, POISON_FREE, dah_overhead - 1);
842 : 0 : *((char *)h + dah_overhead - 1) = POISON_END;
843 : 0 : h = prev;
844 : : h_offset = prev_offset;
845 : : } else {
846 : 0 : h->next = prev->next;
847 : 0 : prev->next = h_offset;
848 : : }
849 : : }
850 [ # # ]: 0 : if (h_offset + dah_overhead + h->size == h->next) {
851 : : struct debug_alloc_header *next;
852 : 0 : next = (struct debug_alloc_header *)
853 : 0 : (debug_alloc_pool + h->next);
854 : 0 : h->size += dah_overhead + next->size;
855 : 0 : h->next = next->next;
856 : 0 : memset(next, POISON_FREE, dah_overhead - 1);
857 : 0 : *((char *)next + dah_overhead - 1) = POISON_END;
858 : : }
859 : : spin_unlock(&dap_lock);
860 : : }
861 : :
862 : 0 : void debug_kusage(void)
863 : : {
864 : : struct debug_alloc_header *h_free, *h_used;
865 : : #ifdef CONFIG_IA64
866 : : /* FIXME: using dah for ia64 unwind always results in a memory leak.
867 : : * Fix that memory leak first, then set debug_kusage_one_time = 1 for
868 : : * all architectures.
869 : : */
870 : : static int debug_kusage_one_time;
871 : : #else
872 : : static int debug_kusage_one_time = 1;
873 : : #endif
874 [ # # ]: 0 : if (!get_dap_lock()) {
875 : : __release(dap_lock); /* we never actually got it */
876 : 0 : return;
877 : : }
878 : 0 : h_free = (struct debug_alloc_header *)(debug_alloc_pool + dah_first);
879 [ # # # # ]: 0 : if (dah_first == 0 &&
880 [ # # ]: 0 : (h_free->size == sizeof(debug_alloc_pool_aligned) - dah_overhead ||
881 : : dah_first_call))
882 : : goto out;
883 [ # # ]: 0 : if (!debug_kusage_one_time)
884 : : goto out;
885 : 0 : debug_kusage_one_time = 0;
886 : 0 : kdb_printf("%s: debug_kmalloc memory leak dah_first %d\n",
887 : : __func__, dah_first);
888 [ # # ]: 0 : if (dah_first) {
889 : 0 : h_used = (struct debug_alloc_header *)debug_alloc_pool;
890 : 0 : kdb_printf("%s: h_used %px size %d\n", __func__, h_used,
891 : : h_used->size);
892 : : }
893 : : do {
894 : 0 : h_used = (struct debug_alloc_header *)
895 : 0 : ((char *)h_free + dah_overhead + h_free->size);
896 : 0 : kdb_printf("%s: h_used %px size %d caller %px\n",
897 : : __func__, h_used, h_used->size, h_used->caller);
898 : 0 : h_free = (struct debug_alloc_header *)
899 : 0 : (debug_alloc_pool + h_free->next);
900 [ # # ]: 0 : } while (h_free->next);
901 : 0 : h_used = (struct debug_alloc_header *)
902 : 0 : ((char *)h_free + dah_overhead + h_free->size);
903 [ # # ]: 0 : if ((char *)h_used - debug_alloc_pool !=
904 : : sizeof(debug_alloc_pool_aligned))
905 : 0 : kdb_printf("%s: h_used %px size %d caller %px\n",
906 : : __func__, h_used, h_used->size, h_used->caller);
907 : : out:
908 : : spin_unlock(&dap_lock);
909 : : }
910 : :
911 : : /* Maintain a small stack of kdb_flags to allow recursion without disturbing
912 : : * the global kdb state.
913 : : */
914 : :
915 : : static int kdb_flags_stack[4], kdb_flags_index;
916 : :
917 : 0 : void kdb_save_flags(void)
918 : : {
919 [ # # ]: 0 : BUG_ON(kdb_flags_index >= ARRAY_SIZE(kdb_flags_stack));
920 : 0 : kdb_flags_stack[kdb_flags_index++] = kdb_flags;
921 : 0 : }
922 : :
923 : 0 : void kdb_restore_flags(void)
924 : : {
925 [ # # ]: 0 : BUG_ON(kdb_flags_index <= 0);
926 : 0 : kdb_flags = kdb_flags_stack[--kdb_flags_index];
927 : 0 : }
|