aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--tools/perf/Documentation/perf-probe.txt5
-rw-r--r--tools/perf/builtin-probe.c1
-rw-r--r--tools/perf/util/probe-event.c24
-rw-r--r--tools/perf/util/probe-event.h2
4 files changed, 24 insertions, 8 deletions
diff --git a/tools/perf/Documentation/perf-probe.txt b/tools/perf/Documentation/perf-probe.txt
index 34202b1be0bb..0f944b3be9e9 100644
--- a/tools/perf/Documentation/perf-probe.txt
+++ b/tools/perf/Documentation/perf-probe.txt
@@ -57,6 +57,11 @@ OPTIONS
57--force:: 57--force::
58 Forcibly add events with existing name. 58 Forcibly add events with existing name.
59 59
60-n::
61--dry-run::
62 Dry run. With this option, --add and --del doesn't execute actual
63 adding and removal operations.
64
60PROBE SYNTAX 65PROBE SYNTAX
61------------ 66------------
62Probe points are defined by following syntax. 67Probe points are defined by following syntax.
diff --git a/tools/perf/builtin-probe.c b/tools/perf/builtin-probe.c
index f577e1410362..a1a2891ca66f 100644
--- a/tools/perf/builtin-probe.c
+++ b/tools/perf/builtin-probe.c
@@ -175,6 +175,7 @@ static const struct option options[] = {
175 "FUNC[:RLN[+NUM|:RLN2]]|SRC:ALN[+NUM|:ALN2]", 175 "FUNC[:RLN[+NUM|:RLN2]]|SRC:ALN[+NUM|:ALN2]",
176 "Show source code lines.", opt_show_lines), 176 "Show source code lines.", opt_show_lines),
177#endif 177#endif
178 OPT__DRY_RUN(&probe_event_dry_run),
178 OPT_END() 179 OPT_END()
179}; 180};
180 181
diff --git a/tools/perf/util/probe-event.c b/tools/perf/util/probe-event.c
index 1e60a659578b..ac41578a3552 100644
--- a/tools/perf/util/probe-event.c
+++ b/tools/perf/util/probe-event.c
@@ -49,6 +49,8 @@
49#define MAX_PROBE_ARGS 128 49#define MAX_PROBE_ARGS 128
50#define PERFPROBE_GROUP "probe" 50#define PERFPROBE_GROUP "probe"
51 51
52bool probe_event_dry_run; /* Dry run flag */
53
52#define semantic_error(msg ...) die("Semantic error :" msg) 54#define semantic_error(msg ...) die("Semantic error :" msg)
53 55
54/* If there is no space to write, returns -E2BIG. */ 56/* If there is no space to write, returns -E2BIG. */
@@ -430,7 +432,7 @@ error:
430 return ret; 432 return ret;
431} 433}
432 434
433static int open_kprobe_events(int flags, int mode) 435static int open_kprobe_events(bool readwrite)
434{ 436{
435 char buf[PATH_MAX]; 437 char buf[PATH_MAX];
436 int ret; 438 int ret;
@@ -439,7 +441,11 @@ static int open_kprobe_events(int flags, int mode)
439 if (ret < 0) 441 if (ret < 0)
440 die("Failed to make kprobe_events path."); 442 die("Failed to make kprobe_events path.");
441 443
442 ret = open(buf, flags, mode); 444 if (readwrite && !probe_event_dry_run)
445 ret = open(buf, O_RDWR, O_APPEND);
446 else
447 ret = open(buf, O_RDONLY, 0);
448
443 if (ret < 0) { 449 if (ret < 0) {
444 if (errno == ENOENT) 450 if (errno == ENOENT)
445 die("kprobe_events file does not exist -" 451 die("kprobe_events file does not exist -"
@@ -535,7 +541,7 @@ void show_perf_probe_events(void)
535 setup_pager(); 541 setup_pager();
536 memset(&pp, 0, sizeof(pp)); 542 memset(&pp, 0, sizeof(pp));
537 543
538 fd = open_kprobe_events(O_RDONLY, 0); 544 fd = open_kprobe_events(false);
539 rawlist = get_trace_kprobe_event_rawlist(fd); 545 rawlist = get_trace_kprobe_event_rawlist(fd);
540 close(fd); 546 close(fd);
541 547
@@ -585,9 +591,11 @@ static void write_trace_kprobe_event(int fd, const char *buf)
585 int ret; 591 int ret;
586 592
587 pr_debug("Writing event: %s\n", buf); 593 pr_debug("Writing event: %s\n", buf);
588 ret = write(fd, buf, strlen(buf)); 594 if (!probe_event_dry_run) {
589 if (ret <= 0) 595 ret = write(fd, buf, strlen(buf));
590 die("Failed to write event: %s", strerror(errno)); 596 if (ret <= 0)
597 die("Failed to write event: %s", strerror(errno));
598 }
591} 599}
592 600
593static void get_new_event_name(char *buf, size_t len, const char *base, 601static void get_new_event_name(char *buf, size_t len, const char *base,
@@ -630,7 +638,7 @@ static void __add_trace_kprobe_events(struct probe_point *probes,
630 struct strlist *namelist; 638 struct strlist *namelist;
631 bool allow_suffix; 639 bool allow_suffix;
632 640
633 fd = open_kprobe_events(O_RDWR, O_APPEND); 641 fd = open_kprobe_events(true);
634 /* Get current event names */ 642 /* Get current event names */
635 namelist = get_perf_event_names(fd, false); 643 namelist = get_perf_event_names(fd, false);
636 644
@@ -814,7 +822,7 @@ void del_trace_kprobe_events(struct strlist *dellist)
814 struct str_node *ent; 822 struct str_node *ent;
815 struct strlist *namelist; 823 struct strlist *namelist;
816 824
817 fd = open_kprobe_events(O_RDWR, O_APPEND); 825 fd = open_kprobe_events(true);
818 /* Get current event names */ 826 /* Get current event names */
819 namelist = get_perf_event_names(fd, true); 827 namelist = get_perf_event_names(fd, true);
820 828
diff --git a/tools/perf/util/probe-event.h b/tools/perf/util/probe-event.h
index 3865e163bb59..703b8876dfb1 100644
--- a/tools/perf/util/probe-event.h
+++ b/tools/perf/util/probe-event.h
@@ -5,6 +5,8 @@
5#include "probe-finder.h" 5#include "probe-finder.h"
6#include "strlist.h" 6#include "strlist.h"
7 7
8extern bool probe_event_dry_run;
9
8extern void parse_line_range_desc(const char *arg, struct line_range *lr); 10extern void parse_line_range_desc(const char *arg, struct line_range *lr);
9extern void parse_perf_probe_event(const char *str, struct probe_point *pp, 11extern void parse_perf_probe_event(const char *str, struct probe_point *pp,
10 bool *need_dwarf); 12 bool *need_dwarf);