From: Namhyung Kim <[email protected]>

The ftrace sub-commands share some common code so that factor it out
to ftrace_setup() and ftrace_teardown() helpers.

Cc: Steven Rostedt <[email protected]>
Cc: Frederic Weisbecker <[email protected]>
Signed-off-by: Namhyung Kim <[email protected]>
---
 tools/perf/builtin-ftrace.c | 168 +++++++++++++++++---------------------------
 1 file changed, 64 insertions(+), 104 deletions(-)

diff --git a/tools/perf/builtin-ftrace.c b/tools/perf/builtin-ftrace.c
index 8bb2604517cc..698dd0b5cecf 100644
--- a/tools/perf/builtin-ftrace.c
+++ b/tools/perf/builtin-ftrace.c
@@ -1363,10 +1363,59 @@ out:
        return ret;
 }
 
+static int ftrace_setup(struct perf_ftrace *ftrace, int argc, const char 
**argv)
+{
+       int ret;
+       char errbuf[512];
+
+       ret = perf_target__validate(&ftrace->target);
+       if (ret) {
+               perf_target__strerror(&ftrace->target, ret, errbuf, 512);
+               pr_err("%s\n", errbuf);
+               return -EINVAL;
+       }
+
+       ftrace->evlist = perf_evlist__new();
+       if (ftrace->evlist == NULL)
+               return -ENOMEM;
+
+       ret = perf_evlist__create_maps(ftrace->evlist, &ftrace->target);
+       if (ret < 0)
+               goto out;
+
+       if (ftrace->tracer == NULL)
+               ftrace->tracer = DEFAULT_TRACER;
+
+       if (ftrace->dirname == NULL)
+               ftrace->dirname = DEFAULT_DIRNAME;
+
+       if (argc) {
+               ret = perf_evlist__prepare_workload(ftrace->evlist,
+                                                   &ftrace->target,
+                                                   argv, false, true);
+               if (ret < 0)
+                       goto out_maps;
+       }
+       return 0;
+
+out_maps:
+       perf_evlist__delete_maps(ftrace->evlist);
+out:
+       perf_evlist__delete(ftrace->evlist);
+
+       return ret;
+}
+
+static void ftrace_teardown(struct perf_ftrace *ftrace)
+{
+       perf_evlist__delete_maps(ftrace->evlist);
+       perf_evlist__delete(ftrace->evlist);
+}
+
 static int
 __cmd_ftrace_live(struct perf_ftrace *ftrace, int argc, const char **argv)
 {
-       int ret = -1;
+       int ret;
        const char * const live_usage[] = {
                "perf ftrace live [<options>] [<command>]",
                "perf ftrace live [<options>] -- <command> [<options>]",
@@ -1391,47 +1440,22 @@ __cmd_ftrace_live(struct perf_ftrace *ftrace, int argc, 
const char **argv)
        if (!argc && perf_target__none(&ftrace->target))
                usage_with_options(live_usage, live_options);
 
-       ret = perf_target__validate(&ftrace->target);
-       if (ret) {
-               char errbuf[512];
-
-               perf_target__strerror(&ftrace->target, ret, errbuf, 512);
-               pr_err("%s\n", errbuf);
-               return -EINVAL;
-       }
-
-       ftrace->evlist = perf_evlist__new();
-       if (ftrace->evlist == NULL)
-               return -ENOMEM;
-
-       ret = perf_evlist__create_maps(ftrace->evlist, &ftrace->target);
+       ret = ftrace_setup(ftrace, argc, argv);
        if (ret < 0)
-               goto out;
-
-       if (ftrace->tracer == NULL)
-               ftrace->tracer = DEFAULT_TRACER;
-
-       if (argc && perf_evlist__prepare_workload(ftrace->evlist,
-                                                 &ftrace->target,
-                                                 argv, false, true) < 0)
-               goto out_maps;
+               return ret;
 
        setup_pager();
 
        ret = do_ftrace_live(ftrace);
 
-out_maps:
-       perf_evlist__delete_maps(ftrace->evlist);
-out:
-       perf_evlist__delete(ftrace->evlist);
-
+       ftrace_teardown(ftrace);
        return ret;
 }
 
 static int
 __cmd_ftrace_record(struct perf_ftrace *ftrace, int argc, const char **argv)
 {
-       int ret = -1;
+       int ret;
        const char * const record_usage[] = {
                "perf ftrace record [<options>] [<command>]",
                "perf ftrace record [<options>] -- <command> [<options>]",
@@ -1458,39 +1482,13 @@ __cmd_ftrace_record(struct perf_ftrace *ftrace, int 
argc, const char **argv)
        if (!argc && perf_target__none(&ftrace->target))
                usage_with_options(record_usage, record_options);
 
-       ret = perf_target__validate(&ftrace->target);
-       if (ret) {
-               char errbuf[512];
-
-               perf_target__strerror(&ftrace->target, ret, errbuf, 512);
-               pr_err("%s\n", errbuf);
-               return -EINVAL;
-       }
-
-       ftrace->evlist = perf_evlist__new();
-       if (ftrace->evlist == NULL)
-               return -ENOMEM;
-
-       ret = perf_evlist__create_maps(ftrace->evlist, &ftrace->target);
+       ret = ftrace_setup(ftrace, argc, argv);
        if (ret < 0)
-               goto out;
-
-       if (ftrace->tracer == NULL)
-               ftrace->tracer = DEFAULT_TRACER;
-
-       if (ftrace->dirname == NULL)
-               ftrace->dirname = DEFAULT_DIRNAME;
-
-       if (argc && perf_evlist__prepare_workload(ftrace->evlist,
-                                                 &ftrace->target,
-                                                 argv, false, true) < 0)
-               goto out_maps;
+               return ret;
 
        ret = do_ftrace_record(ftrace);
 
-out_maps:
        perf_evlist__delete_maps(ftrace->evlist);
-out:
        perf_evlist__delete(ftrace->evlist);
 
        return ret;
@@ -1499,7 +1497,7 @@ out:
 static int
 __cmd_ftrace_show(struct perf_ftrace *ftrace, int argc, const char **argv)
 {
-       int ret = -1;
+       int ret;
        const char * const show_usage[] = {
                "perf ftrace show [<options>]",
                NULL
@@ -1519,41 +1517,22 @@ __cmd_ftrace_show(struct perf_ftrace *ftrace, int argc, 
const char **argv)
        if (argc)
                usage_with_options(show_usage, show_options);
 
-       ret = perf_target__validate(&ftrace->target);
-       if (ret) {
-               char errbuf[512];
-
-               perf_target__strerror(&ftrace->target, ret, errbuf, 512);
-               pr_err("%s\n", errbuf);
-               return -EINVAL;
-       }
-
-       ftrace->evlist = perf_evlist__new();
-       if (ftrace->evlist == NULL)
-               return -ENOMEM;
-
-       ret = perf_evlist__create_maps(ftrace->evlist, &ftrace->target);
+       ret = ftrace_setup(ftrace, argc, argv);
        if (ret < 0)
-               goto out;
-
-       if (ftrace->dirname == NULL)
-               ftrace->dirname = DEFAULT_DIRNAME;
+               return ret;
 
        setup_pager();
 
        ret = do_ftrace_show(ftrace);
 
-       perf_evlist__delete_maps(ftrace->evlist);
-out:
-       perf_evlist__delete(ftrace->evlist);
-
+       ftrace_teardown(ftrace);
        return ret;
 }
 
 static int
 __cmd_ftrace_report(struct perf_ftrace *ftrace, int argc, const char **argv)
 {
-       int ret = -1;
+       int ret;
        const char * const report_usage[] = {
                "perf ftrace report [<options>]",
                NULL
@@ -1579,25 +1558,9 @@ __cmd_ftrace_report(struct perf_ftrace *ftrace, int 
argc, const char **argv)
        if (argc)
                usage_with_options(report_usage, report_options);
 
-       ret = perf_target__validate(&ftrace->target);
-       if (ret) {
-               char errbuf[512];
-
-               perf_target__strerror(&ftrace->target, ret, errbuf, 512);
-               pr_err("%s\n", errbuf);
-               return -EINVAL;
-       }
-
-       ftrace->evlist = perf_evlist__new();
-       if (ftrace->evlist == NULL)
-               return -ENOMEM;
-
-       ret = perf_evlist__create_maps(ftrace->evlist, &ftrace->target);
+       ret = ftrace_setup(ftrace, argc, argv);
        if (ret < 0)
-               goto out;
-
-       if (ftrace->dirname == NULL)
-               ftrace->dirname = DEFAULT_DIRNAME;
+               return ret;
 
        perf_hpp__column_enable(PERF_HPP__OVERHEAD);
        perf_hpp__init();
@@ -1611,10 +1574,7 @@ __cmd_ftrace_report(struct perf_ftrace *ftrace, int 
argc, const char **argv)
 
        ret = do_ftrace_report(ftrace);
 
-       perf_evlist__delete_maps(ftrace->evlist);
-out:
-       perf_evlist__delete(ftrace->evlist);
-
+       ftrace_teardown(ftrace);
        return ret;
 }
 
-- 
1.7.11.7

--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to [email protected]
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Please read the FAQ at  http://www.tux.org/lkml/

Reply via email to