aboutsummaryrefslogtreecommitdiffstats
path: root/Documentation/perf_counter
diff options
context:
space:
mode:
Diffstat (limited to 'Documentation/perf_counter')
-rw-r--r--Documentation/perf_counter/builtin-report.c30
1 files changed, 18 insertions, 12 deletions
diff --git a/Documentation/perf_counter/builtin-report.c b/Documentation/perf_counter/builtin-report.c
index a55f15d7651d..ed3da9d61985 100644
--- a/Documentation/perf_counter/builtin-report.c
+++ b/Documentation/perf_counter/builtin-report.c
@@ -384,21 +384,26 @@ int hex2long(char *ptr, unsigned long *long_val)
384 384
385static int load_kallsyms(void) 385static int load_kallsyms(void)
386{ 386{
387 struct rb_node *nd, *prevnd;
388 char *line = NULL;
389 FILE *file;
390 size_t n;
391
387 kernel_dso = dso__new("[kernel]"); 392 kernel_dso = dso__new("[kernel]");
388 if (kernel_dso == NULL) 393 if (kernel_dso == NULL)
389 return -1; 394 return -1;
390 395
391 FILE *file = fopen("/proc/kallsyms", "r"); 396 file = fopen("/proc/kallsyms", "r");
392
393 if (file == NULL) 397 if (file == NULL)
394 goto out_delete_dso; 398 goto out_delete_dso;
395 399
396 char *line = NULL;
397 size_t n;
398
399 while (!feof(file)) { 400 while (!feof(file)) {
400 unsigned long start; 401 unsigned long start;
401 int line_len = getline(&line, &n, file); 402 struct symbol *sym;
403 int line_len, len;
404 char symbol_type;
405
406 line_len = getline(&line, &n, file);
402 if (line_len < 0) 407 if (line_len < 0)
403 break; 408 break;
404 409
@@ -407,22 +412,22 @@ static int load_kallsyms(void)
407 412
408 line[--line_len] = '\0'; /* \n */ 413 line[--line_len] = '\0'; /* \n */
409 414
410 int len = hex2long(line, &start); 415 len = hex2long(line, &start);
411 416
412 len++; 417 len++;
413 if (len + 2 >= line_len) 418 if (len + 2 >= line_len)
414 continue; 419 continue;
415 420
416 char symbol_type = line[len]; 421 symbol_type = toupper(line[len]);
417 /* 422 /*
418 * We're interested only in code ('T'ext) 423 * We're interested only in code ('T'ext)
419 */ 424 */
420 if (toupper(symbol_type) != 'T') 425 if (symbol_type != 'T' && symbol_type != 'W')
421 continue; 426 continue;
422 /* 427 /*
423 * Well fix up the end later, when we have all sorted. 428 * Well fix up the end later, when we have all sorted.
424 */ 429 */
425 struct symbol *sym = symbol__new(start, 0xdead, line + len + 2); 430 sym = symbol__new(start, 0xdead, line + len + 2);
426 431
427 if (sym == NULL) 432 if (sym == NULL)
428 goto out_delete_dso; 433 goto out_delete_dso;
@@ -434,7 +439,7 @@ static int load_kallsyms(void)
434 * Now that we have all sorted out, just set the ->end of all 439 * Now that we have all sorted out, just set the ->end of all
435 * symbols 440 * symbols
436 */ 441 */
437 struct rb_node *nd, *prevnd = rb_first(&kernel_dso->syms); 442 prevnd = rb_first(&kernel_dso->syms);
438 443
439 if (prevnd == NULL) 444 if (prevnd == NULL)
440 goto out_delete_line; 445 goto out_delete_line;
@@ -450,6 +455,7 @@ static int load_kallsyms(void)
450 dsos__add(kernel_dso); 455 dsos__add(kernel_dso);
451 free(line); 456 free(line);
452 fclose(file); 457 fclose(file);
458
453 return 0; 459 return 0;
454 460
455out_delete_line: 461out_delete_line: