Prev: [PATCH 19/21] x86, mce: Notify about corrected events too
Next: Fan control with kernel module "asus-laptop"
From: Borislav Petkov on 1 Jul 2010 12:00 From: Borislav Petkov <borislav.petkov(a)amd.com> .... into perf-specific and generic part. Signed-off-by: Borislav Petkov <borislav.petkov(a)amd.com> --- tools/lib/perf/build-id.c | 49 -------------------------------------------- tools/lib/perf/build-id.h | 4 +++ tools/perf/Makefile | 1 + tools/perf/util/build-id.c | 48 +++++++++++++++++++++++++++++++++++++++++++ 4 files changed, 53 insertions(+), 49 deletions(-) create mode 100644 tools/perf/util/build-id.c diff --git a/tools/lib/perf/build-id.c b/tools/lib/perf/build-id.c index 5969758..c4c1267 100644 --- a/tools/lib/perf/build-id.c +++ b/tools/lib/perf/build-id.c @@ -60,52 +60,3 @@ char *dso__build_id_filename(struct dso *self, char *bf, size_t size) build_id_hex, build_id_hex + 2); return bf; } - -struct buildid_dir_config { - char *dir; -}; - -static int buildid_dir_command_config(const char *var, const char *value, - void *data) -{ - struct buildid_dir_config *c = data; - const char *v; - - /* same dir for all commands */ - if (!prefixcmp(var, "buildid.") && !strcmp(var + 8, "dir")) { - v = lk_config_dirname(var, value); - if (!v) - return -1; - strncpy(c->dir, v, MAXPATHLEN-1); - c->dir[MAXPATHLEN-1] = '\0'; - } - return 0; -} -static void check_buildid_dir_config(void) -{ - struct buildid_dir_config c; - c.dir = buildid_dir; - perf_config(buildid_dir_command_config, &c); -} - -void set_buildid_dir(void) -{ - buildid_dir[0] = '\0'; - - /* try config file */ - check_buildid_dir_config(); - - /* default to $HOME/.debug */ - if (buildid_dir[0] == '\0') { - char *v = getenv("HOME"); - if (v) { - snprintf(buildid_dir, MAXPATHLEN-1, "%s/%s", - v, DEBUG_CACHE_DIR); - } else { - strncpy(buildid_dir, DEBUG_CACHE_DIR, MAXPATHLEN-1); - } - buildid_dir[MAXPATHLEN-1] = '\0'; - } - /* for communicating with external commands */ - setenv("PERF_BUILDID_DIR", buildid_dir, 1); -} diff --git a/tools/lib/perf/build-id.h b/tools/lib/perf/build-id.h index 1b73726..224c90b 100644 --- a/tools/lib/perf/build-id.h +++ b/tools/lib/perf/build-id.h @@ -6,6 +6,10 @@ extern struct perf_event_ops build_id__mark_dso_hit_ops; +struct buildid_dir_config { + char *dir; +}; + char *dso__build_id_filename(struct dso *self, char *bf, size_t size); extern void set_buildid_dir(void); diff --git a/tools/perf/Makefile b/tools/perf/Makefile index 590c8f6..7d6ee06 100644 --- a/tools/perf/Makefile +++ b/tools/perf/Makefile @@ -387,6 +387,7 @@ LIB_OBJS += $(OUTPUT)util/trace-event-scripting.o LIB_OBJS += $(OUTPUT)util/svghelper.o LIB_OBJS += $(OUTPUT)util/probe-event.o LIB_OBJS += $(OUTPUT)util/config.o +LIB_OBJS += $(OUTPUT)util/build-id.o BUILTIN_OBJS += $(OUTPUT)builtin-annotate.o diff --git a/tools/perf/util/build-id.c b/tools/perf/util/build-id.c new file mode 100644 index 0000000..af2f840 --- /dev/null +++ b/tools/perf/util/build-id.c @@ -0,0 +1,48 @@ +#include <lk/strbuf.h> +#include <perf/build-id.h> + +static int buildid_dir_command_config(const char *var, const char *value, + void *data) +{ + struct buildid_dir_config *c = data; + const char *v; + + /* same dir for all commands */ + if (!prefixcmp(var, "buildid.") && !strcmp(var + 8, "dir")) { + v = lk_config_dirname(var, value); + if (!v) + return -1; + strncpy(c->dir, v, MAXPATHLEN-1); + c->dir[MAXPATHLEN-1] = '\0'; + } + return 0; +} + +static void check_buildid_dir_config(void) +{ + struct buildid_dir_config c; + c.dir = buildid_dir; + perf_config(buildid_dir_command_config, &c); +} + +void set_buildid_dir(void) +{ + buildid_dir[0] = '\0'; + + /* try config file */ + check_buildid_dir_config(); + + /* default to $HOME/.debug */ + if (buildid_dir[0] == '\0') { + char *v = getenv("HOME"); + if (v) { + snprintf(buildid_dir, MAXPATHLEN-1, "%s/%s", + v, DEBUG_CACHE_DIR); + } else { + strncpy(buildid_dir, DEBUG_CACHE_DIR, MAXPATHLEN-1); + } + buildid_dir[MAXPATHLEN-1] = '\0'; + } + /* for communicating with external commands */ + setenv("PERF_BUILDID_DIR", buildid_dir, 1); +} -- 1.7.1 -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo(a)vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/ |