diff options
Diffstat (limited to 'tools/perf/util/probe-event.c')
-rw-r--r-- | tools/perf/util/probe-event.c | 52 |
1 files changed, 39 insertions, 13 deletions
diff --git a/tools/perf/util/probe-event.c b/tools/perf/util/probe-event.c index 3e30be928101..5e99e52b0179 100644 --- a/tools/perf/util/probe-event.c +++ b/tools/perf/util/probe-event.c | |||
@@ -532,26 +532,50 @@ void add_trace_kprobe_events(struct probe_point *probes, int nr_probes) | |||
532 | close(fd); | 532 | close(fd); |
533 | } | 533 | } |
534 | 534 | ||
535 | static void __del_trace_kprobe_event(int fd, struct str_node *ent) | ||
536 | { | ||
537 | char *p; | ||
538 | char buf[128]; | ||
539 | |||
540 | /* Convert from perf-probe event to trace-kprobe event */ | ||
541 | if (e_snprintf(buf, 128, "-:%s", ent->s) < 0) | ||
542 | die("Failed to copy event."); | ||
543 | p = strchr(buf + 2, ':'); | ||
544 | if (!p) | ||
545 | die("Internal error: %s should have ':' but not.", ent->s); | ||
546 | *p = '/'; | ||
547 | |||
548 | write_trace_kprobe_event(fd, buf); | ||
549 | printf("Remove event: %s\n", ent->s); | ||
550 | } | ||
551 | |||
535 | static void del_trace_kprobe_event(int fd, const char *group, | 552 | static void del_trace_kprobe_event(int fd, const char *group, |
536 | const char *event, struct strlist *namelist) | 553 | const char *event, struct strlist *namelist) |
537 | { | 554 | { |
538 | char buf[128]; | 555 | char buf[128]; |
539 | struct str_node *ent; | 556 | struct str_node *ent, *n; |
557 | int found = 0; | ||
540 | 558 | ||
541 | if (e_snprintf(buf, 128, "%s:%s", group, event) < 0) | 559 | if (e_snprintf(buf, 128, "%s:%s", group, event) < 0) |
542 | die("Failed to copy event."); | 560 | die("Failed to copy event."); |
543 | ent = strlist__find(namelist, buf); | ||
544 | if (!ent) { | ||
545 | pr_info("Info: event \"%s\" does not exist, could not remove it.\n", buf); | ||
546 | return; | ||
547 | } | ||
548 | /* Convert from perf-probe event to trace-kprobe event */ | ||
549 | if (e_snprintf(buf, 128, "-:%s/%s", group, event) < 0) | ||
550 | die("Failed to copy event."); | ||
551 | 561 | ||
552 | write_trace_kprobe_event(fd, buf); | 562 | if (strpbrk(buf, "*?")) { /* Glob-exp */ |
553 | printf("Remove event: %s:%s\n", group, event); | 563 | strlist__for_each_safe(ent, n, namelist) |
554 | strlist__remove(namelist, ent); | 564 | if (strglobmatch(ent->s, buf)) { |
565 | found++; | ||
566 | __del_trace_kprobe_event(fd, ent); | ||
567 | strlist__remove(namelist, ent); | ||
568 | } | ||
569 | } else { | ||
570 | ent = strlist__find(namelist, buf); | ||
571 | if (ent) { | ||
572 | found++; | ||
573 | __del_trace_kprobe_event(fd, ent); | ||
574 | strlist__remove(namelist, ent); | ||
575 | } | ||
576 | } | ||
577 | if (found == 0) | ||
578 | pr_info("Info: event \"%s\" does not exist, could not remove it.\n", buf); | ||
555 | } | 579 | } |
556 | 580 | ||
557 | void del_trace_kprobe_events(struct strlist *dellist) | 581 | void del_trace_kprobe_events(struct strlist *dellist) |
@@ -570,15 +594,17 @@ void del_trace_kprobe_events(struct strlist *dellist) | |||
570 | str = strdup(ent->s); | 594 | str = strdup(ent->s); |
571 | if (!str) | 595 | if (!str) |
572 | die("Failed to copy event."); | 596 | die("Failed to copy event."); |
597 | pr_debug("Parsing: %s\n", str); | ||
573 | p = strchr(str, ':'); | 598 | p = strchr(str, ':'); |
574 | if (p) { | 599 | if (p) { |
575 | group = str; | 600 | group = str; |
576 | *p = '\0'; | 601 | *p = '\0'; |
577 | event = p + 1; | 602 | event = p + 1; |
578 | } else { | 603 | } else { |
579 | group = PERFPROBE_GROUP; | 604 | group = "*"; |
580 | event = str; | 605 | event = str; |
581 | } | 606 | } |
607 | pr_debug("Group: %s, Event: %s\n", group, event); | ||
582 | del_trace_kprobe_event(fd, group, event, namelist); | 608 | del_trace_kprobe_event(fd, group, event, namelist); |
583 | free(str); | 609 | free(str); |
584 | } | 610 | } |