mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2025-01-17 02:15:57 +00:00
perf tools: Make find_vdso_map() more modular
In preparation for checking that the vectors page on the ARM architecture, refactor the find_vdso_map() function to accept finding an arbitrary string and create a dedicated helper function for that under util/find-map.c and update the filename to find-map.c and all references to it: perf-read-vdso.c and util/vdso.c. Signed-off-by: Florian Fainelli <f.fainelli@gmail.com> Acked-by: Jiri Olsa <jolsa@kernel.org> Cc: Alexander Shishkin <alexander.shishkin@linux.intel.com> Cc: Chris Healy <cphealy@gmail.com> Cc: Greg Kroah-Hartman <gregkh@linuxfoundation.org> Cc: Kim Phillips <kim.phillips@arm.com> Cc: Lucas Stach <l.stach@pengutronix.de> Cc: Namhyung Kim <namhyung@kernel.org> Cc: Peter Zijlstra <peterz@infradead.org> Cc: Ravi Bangoria <ravi.bangoria@linux.ibm.com> Cc: Russell King <rmk+kernel@armlinux.org.uk> Cc: Thomas Gleixner <tglx@linutronix.de> Cc: Thomas Richter <tmricht@linux.ibm.com> Link: http://lkml.kernel.org/r/20181221034337.26663-2-f.fainelli@gmail.com Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
This commit is contained in:
parent
ac6e022cbf
commit
011532379b
@ -662,12 +662,12 @@ $(OUTPUT)perf-%: %.o $(PERFLIBS)
|
|||||||
$(QUIET_LINK)$(CC) $(CFLAGS) -o $@ $(LDFLAGS) $(filter %.o,$^) $(LIBS)
|
$(QUIET_LINK)$(CC) $(CFLAGS) -o $@ $(LDFLAGS) $(filter %.o,$^) $(LIBS)
|
||||||
|
|
||||||
ifndef NO_PERF_READ_VDSO32
|
ifndef NO_PERF_READ_VDSO32
|
||||||
$(OUTPUT)perf-read-vdso32: perf-read-vdso.c util/find-vdso-map.c
|
$(OUTPUT)perf-read-vdso32: perf-read-vdso.c util/find-map.c
|
||||||
$(QUIET_CC)$(CC) -m32 $(filter -static,$(LDFLAGS)) -Wall -Werror -o $@ perf-read-vdso.c
|
$(QUIET_CC)$(CC) -m32 $(filter -static,$(LDFLAGS)) -Wall -Werror -o $@ perf-read-vdso.c
|
||||||
endif
|
endif
|
||||||
|
|
||||||
ifndef NO_PERF_READ_VDSOX32
|
ifndef NO_PERF_READ_VDSOX32
|
||||||
$(OUTPUT)perf-read-vdsox32: perf-read-vdso.c util/find-vdso-map.c
|
$(OUTPUT)perf-read-vdsox32: perf-read-vdso.c util/find-map.c
|
||||||
$(QUIET_CC)$(CC) -mx32 $(filter -static,$(LDFLAGS)) -Wall -Werror -o $@ perf-read-vdso.c
|
$(QUIET_CC)$(CC) -mx32 $(filter -static,$(LDFLAGS)) -Wall -Werror -o $@ perf-read-vdso.c
|
||||||
endif
|
endif
|
||||||
|
|
||||||
|
@ -5,17 +5,17 @@
|
|||||||
#define VDSO__MAP_NAME "[vdso]"
|
#define VDSO__MAP_NAME "[vdso]"
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Include definition of find_vdso_map() also used in util/vdso.c for
|
* Include definition of find_map() also used in util/vdso.c for
|
||||||
* building perf.
|
* building perf.
|
||||||
*/
|
*/
|
||||||
#include "util/find-vdso-map.c"
|
#include "util/find-map.c"
|
||||||
|
|
||||||
int main(void)
|
int main(void)
|
||||||
{
|
{
|
||||||
void *start, *end;
|
void *start, *end;
|
||||||
size_t size, written;
|
size_t size, written;
|
||||||
|
|
||||||
if (find_vdso_map(&start, &end))
|
if (find_map(&start, &end, VDSO__MAP_NAME))
|
||||||
return 1;
|
return 1;
|
||||||
|
|
||||||
size = end - start;
|
size = end - start;
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
// SPDX-License-Identifier: GPL-2.0
|
// SPDX-License-Identifier: GPL-2.0
|
||||||
static int find_vdso_map(void **start, void **end)
|
static int find_map(void **start, void **end, const char *name)
|
||||||
{
|
{
|
||||||
FILE *maps;
|
FILE *maps;
|
||||||
char line[128];
|
char line[128];
|
||||||
@ -7,7 +7,7 @@ static int find_vdso_map(void **start, void **end)
|
|||||||
|
|
||||||
maps = fopen("/proc/self/maps", "r");
|
maps = fopen("/proc/self/maps", "r");
|
||||||
if (!maps) {
|
if (!maps) {
|
||||||
fprintf(stderr, "vdso: cannot open maps\n");
|
fprintf(stderr, "cannot open maps\n");
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -21,8 +21,7 @@ static int find_vdso_map(void **start, void **end)
|
|||||||
if (m < 0)
|
if (m < 0)
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
if (!strncmp(&line[m], VDSO__MAP_NAME,
|
if (!strncmp(&line[m], name, strlen(name)))
|
||||||
sizeof(VDSO__MAP_NAME) - 1))
|
|
||||||
found = 1;
|
found = 1;
|
||||||
}
|
}
|
||||||
|
|
@ -18,10 +18,10 @@
|
|||||||
#include "debug.h"
|
#include "debug.h"
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Include definition of find_vdso_map() also used in perf-read-vdso.c for
|
* Include definition of find_map() also used in perf-read-vdso.c for
|
||||||
* building perf-read-vdso32 and perf-read-vdsox32.
|
* building perf-read-vdso32 and perf-read-vdsox32.
|
||||||
*/
|
*/
|
||||||
#include "find-vdso-map.c"
|
#include "find-map.c"
|
||||||
|
|
||||||
#define VDSO__TEMP_FILE_NAME "/tmp/perf-vdso.so-XXXXXX"
|
#define VDSO__TEMP_FILE_NAME "/tmp/perf-vdso.so-XXXXXX"
|
||||||
|
|
||||||
@ -76,7 +76,7 @@ static char *get_file(struct vdso_file *vdso_file)
|
|||||||
if (vdso_file->found)
|
if (vdso_file->found)
|
||||||
return vdso_file->temp_file_name;
|
return vdso_file->temp_file_name;
|
||||||
|
|
||||||
if (vdso_file->error || find_vdso_map(&start, &end))
|
if (vdso_file->error || find_map(&start, &end, VDSO__MAP_NAME))
|
||||||
return NULL;
|
return NULL;
|
||||||
|
|
||||||
size = end - start;
|
size = end - start;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user