This patch adds support for following config options to ~/.perfconfig file.

  [call-graph]
    record-mode = dwarf
    dump-size = 8192
    print-type = fractal
    order = callee
    threshold = 0.5
    print-limit = 128
    sort-key = function

Signed-off-by: Namhyung Kim <namhy...@kernel.org>
---
 tools/perf/util/callchain.c | 33 +++++++++++++++++++++++++++++++++
 tools/perf/util/callchain.h |  1 +
 tools/perf/util/config.c    |  3 +++
 3 files changed, 37 insertions(+)

diff --git a/tools/perf/util/callchain.c b/tools/perf/util/callchain.c
index ba7297230143..ee489a1e3f4c 100644
--- a/tools/perf/util/callchain.c
+++ b/tools/perf/util/callchain.c
@@ -168,6 +168,39 @@ parse_callchain_report_opt(const char *arg)
        return 0;
 }
 
+int perf_callchain_config(const char *var, const char *value)
+{
+       if (prefixcmp(var, "call-graph."))
+               return 0;
+       var += 11; /* strlen("call-graph.") == 11 */
+
+       if (!strcmp(var, "record-mode"))
+               return parse_callchain_record_opt(value);
+#ifdef HAVE_DWARF_UNWIND_SUPPORT
+       if (!strcmp(var, "dump-size")) {
+               unsigned long size = 0;
+               int ret;
+
+               ret = get_stack_size(value, &size);
+               callchain_param.dump_size = size;
+
+               return ret;
+       }
+#endif
+       if (!strcmp(var, "print-type"))
+               return parse_callchain_report_opt(value);
+       if (!strcmp(var, "order"))
+               return parse_callchain_report_opt(value);
+       if (!strcmp(var, "threshold"))
+               return parse_callchain_report_opt(value);
+       if (!strcmp(var, "print-limit"))
+               return parse_callchain_report_opt(value);
+       if (!strcmp(var, "sort-key"))
+               return parse_callchain_report_opt(value);
+
+       return 0;
+}
+
 static void
 rb_insert_callchain(struct rb_root *root, struct callchain_node *chain,
                    enum chain_mode mode)
diff --git a/tools/perf/util/callchain.h b/tools/perf/util/callchain.h
index 8adfbf0bab5c..2a1f5a46543a 100644
--- a/tools/perf/util/callchain.h
+++ b/tools/perf/util/callchain.h
@@ -170,6 +170,7 @@ int fill_callchain_info(struct addr_location *al, struct 
callchain_cursor_node *
 extern const char record_callchain_help[];
 int parse_callchain_record_opt(const char *arg);
 int parse_callchain_report_opt(const char *arg);
+int perf_callchain_config(const char *var, const char *value);
 
 static inline void callchain_cursor_snapshot(struct callchain_cursor *dest,
                                             struct callchain_cursor *src)
diff --git a/tools/perf/util/config.c b/tools/perf/util/config.c
index 9970b8b0190b..953512ed72ba 100644
--- a/tools/perf/util/config.c
+++ b/tools/perf/util/config.c
@@ -396,6 +396,9 @@ int perf_default_config(const char *var, const char *value,
        if (!prefixcmp(var, "ui."))
                return perf_ui_config(var, value);
 
+       if (!prefixcmp(var, "call-graph."))
+               return perf_callchain_config(var, value);
+
        /* Add other config variables here. */
        return 0;
 }
-- 
2.1.0

--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majord...@vger.kernel.org
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