lists.openwall.net   lists  /  announce  owl-users  owl-dev  john-users  john-dev  passwdqc-users  yescrypt  popa3d-users  /  oss-security  kernel-hardening  musl  sabotage  tlsify  passwords  /  crypt-dev  xvendor  /  Bugtraq  Full-Disclosure  linux-kernel  linux-netdev  linux-ext4  linux-hardening  linux-cve-announce  PHC 
Open Source and information security mailing list archives
 
Hash Suite: Windows password security audit tool. GUI, reports in PDF.
[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <50399556C9727B4D88A595C8584AAB37525215DD@GSjpTKYDCembx32.service.hitachi.net>
Date:	Thu, 10 Sep 2015 12:56:58 +0000
From:	平松雅巳 / HIRAMATU,MASAMI 
	<masami.hiramatsu.pt@...achi.com>
To:	"'Namhyung Kim'" <namhyung@...nel.org>,
	Arnaldo Carvalho de Melo <acme@...nel.org>
CC:	Ingo Molnar <mingo@...nel.org>,
	Peter Zijlstra <a.p.zijlstra@...llo.nl>,
	Jiri Olsa <jolsa@...hat.com>,
	LKML <linux-kernel@...r.kernel.org>,
	Wang Nan <wangnan0@...wei.com>
Subject: RE: [PATCH 2/3] perf probe: Export init/exit_probe_symbol_maps()

>From: Namhyung Kim [mailto:namhyung@...il.com] On Behalf Of Namhyung Kim
>
>The init/exit_symbols_maps() functions are to setup and cleanup
>necessary info for probe events.  But they need to be called from out of
>the probe code now, so this patch exports them.
>
>However the names are too generic, so change them to have 'probe'. :)

Changing name is OK, but why are they exposed??

Thanks,

>
>Cc: Masami Hiramatsu <masami.hiramatsu.pt@...achi.com>
>Cc: Wang Nan <wangnan0@...wei.com>
>Signed-off-by: Namhyung Kim <namhyung@...nel.org>
>---
> tools/perf/util/probe-event.c | 24 ++++++++++++------------
> tools/perf/util/probe-event.h |  2 ++
> 2 files changed, 14 insertions(+), 12 deletions(-)
>
>diff --git a/tools/perf/util/probe-event.c b/tools/perf/util/probe-event.c
>index 3d7d60cc6f16..64e15cba7223 100644
>--- a/tools/perf/util/probe-event.c
>+++ b/tools/perf/util/probe-event.c
>@@ -71,7 +71,7 @@ static char *synthesize_perf_probe_point(struct perf_probe_point *pp);
> static struct machine *host_machine;
>
> /* Initialize symbol maps and path of vmlinux/modules */
>-static int init_symbol_maps(bool user_only)
>+int init_probe_symbol_maps(bool user_only)
> {
> 	int ret;
>
>@@ -101,7 +101,7 @@ out:
> 	return ret;
> }
>
>-static void exit_symbol_maps(void)
>+void exit_probe_symbol_maps(void)
> {
> 	if (host_machine) {
> 		machine__delete(host_machine);
>@@ -859,11 +859,11 @@ int show_line_range(struct line_range *lr, const char *module, bool user)
> {
> 	int ret;
>
>-	ret = init_symbol_maps(user);
>+	ret = init_probe_symbol_maps(user);
> 	if (ret < 0)
> 		return ret;
> 	ret = __show_line_range(lr, module, user);
>-	exit_symbol_maps();
>+	exit_probe_symbol_maps();
>
> 	return ret;
> }
>@@ -941,7 +941,7 @@ int show_available_vars(struct perf_probe_event *pevs, int npevs,
> 	int i, ret = 0;
> 	struct debuginfo *dinfo;
>
>-	ret = init_symbol_maps(pevs->uprobes);
>+	ret = init_probe_symbol_maps(pevs->uprobes);
> 	if (ret < 0)
> 		return ret;
>
>@@ -958,7 +958,7 @@ int show_available_vars(struct perf_probe_event *pevs, int npevs,
>
> 	debuginfo__delete(dinfo);
> out:
>-	exit_symbol_maps();
>+	exit_probe_symbol_maps();
> 	return ret;
> }
>
>@@ -2262,7 +2262,7 @@ int show_perf_probe_events(struct strfilter *filter)
>
> 	setup_pager();
>
>-	ret = init_symbol_maps(false);
>+	ret = init_probe_symbol_maps(false);
> 	if (ret < 0)
> 		return ret;
>
>@@ -2278,7 +2278,7 @@ int show_perf_probe_events(struct strfilter *filter)
> 		close(kp_fd);
> 	if (up_fd > 0)
> 		close(up_fd);
>-	exit_symbol_maps();
>+	exit_probe_symbol_maps();
>
> 	return ret;
> }
>@@ -2746,7 +2746,7 @@ int convert_perf_probe_events(struct perf_probe_event *pevs, int npevs)
> {
> 	int i, ret;
>
>-	ret = init_symbol_maps(pevs->uprobes);
>+	ret = init_probe_symbol_maps(pevs->uprobes);
> 	if (ret < 0)
> 		return ret;
>
>@@ -2795,7 +2795,7 @@ void cleanup_perf_probe_events(struct perf_probe_event *pevs, int npevs)
> 		clear_perf_probe_event(&pevs[i]);
> 	}
>
>-	exit_symbol_maps();
>+	exit_probe_symbol_maps();
> }
>
> int add_perf_probe_events(struct perf_probe_event *pevs, int npevs)
>@@ -2867,7 +2867,7 @@ int show_available_funcs(const char *target, struct strfilter *_filter,
> 	struct map *map;
> 	int ret;
>
>-	ret = init_symbol_maps(user);
>+	ret = init_probe_symbol_maps(user);
> 	if (ret < 0)
> 		return ret;
>
>@@ -2897,7 +2897,7 @@ end:
> 	if (user) {
> 		map__put(map);
> 	}
>-	exit_symbol_maps();
>+	exit_probe_symbol_maps();
>
> 	return ret;
> }
>diff --git a/tools/perf/util/probe-event.h b/tools/perf/util/probe-event.h
>index 9bcea36359f2..ba926c30f8cd 100644
>--- a/tools/perf/util/probe-event.h
>+++ b/tools/perf/util/probe-event.h
>@@ -110,6 +110,8 @@ struct variable_list {
> };
>
> struct map;
>+int init_probe_symbol_maps(bool user_only);
>+void exit_probe_symbol_maps(void);
>
> /* Command string to events */
> extern int parse_perf_probe_command(const char *cmd,
>--
>2.5.0

Powered by blists - more mailing lists

Powered by Openwall GNU/*/Linux Powered by OpenVZ