diff options
author | Hendrik Brueckner <brueckner@linux.vnet.ibm.com> | 2018-02-08 06:47:50 -0500 |
---|---|---|
committer | Arnaldo Carvalho de Melo <acme@redhat.com> | 2018-02-15 08:06:08 -0500 |
commit | 690d22d9d4423b4522fb44a71145403eef2df834 (patch) | |
tree | af3def762a527c2972df09f0a8b47c51905604cf | |
parent | baa676103037e0dd145bb905eb51bc0b2f48fd49 (diff) |
perf s390: Rework system call table creation by using syscall.tbl
Recently, s390 uses a syscall.tbl input file to generate its system call
table and unistd uapi header files. Hence, update mksyscalltbl to use
it as input to create the system table for perf.
Signed-off-by: Hendrik Brueckner <brueckner@linux.vnet.ibm.com>
Cc: Jiri Olsa <jolsa@redhat.com>
Cc: Michael Petlan <mpetlan@redhat.com>
Cc: Thomas Richter <tmricht@linux.vnet.ibm.com>
Cc: linux-s390@vger.kernel.org
LPU-Reference: 1518090470-2899-4-git-send-email-brueckner@linux.vnet.ibm.com
Link: https://lkml.kernel.org/n/tip-bdyhllhsq1zgxv2qx4m377y6@git.kernel.org
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
-rw-r--r-- | tools/perf/arch/s390/Makefile | 10 | ||||
-rwxr-xr-x | tools/perf/arch/s390/entry/syscalls/mksyscalltbl | 18 |
2 files changed, 14 insertions, 14 deletions
diff --git a/tools/perf/arch/s390/Makefile b/tools/perf/arch/s390/Makefile index 48228de415d0..dfa6e3103437 100644 --- a/tools/perf/arch/s390/Makefile +++ b/tools/perf/arch/s390/Makefile | |||
@@ -10,15 +10,19 @@ PERF_HAVE_ARCH_REGS_QUERY_REGISTER_OFFSET := 1 | |||
10 | 10 | ||
11 | out := $(OUTPUT)arch/s390/include/generated/asm | 11 | out := $(OUTPUT)arch/s390/include/generated/asm |
12 | header := $(out)/syscalls_64.c | 12 | header := $(out)/syscalls_64.c |
13 | sysdef := $(srctree)/tools/arch/s390/include/uapi/asm/unistd.h | 13 | syskrn := $(srctree)/arch/s390/kernel/syscalls/syscall.tbl |
14 | sysprf := $(srctree)/tools/perf/arch/s390/entry/syscalls/ | 14 | sysprf := $(srctree)/tools/perf/arch/s390/entry/syscalls |
15 | sysdef := $(sysprf)/syscall.tbl | ||
15 | systbl := $(sysprf)/mksyscalltbl | 16 | systbl := $(sysprf)/mksyscalltbl |
16 | 17 | ||
17 | # Create output directory if not already present | 18 | # Create output directory if not already present |
18 | _dummy := $(shell [ -d '$(out)' ] || mkdir -p '$(out)') | 19 | _dummy := $(shell [ -d '$(out)' ] || mkdir -p '$(out)') |
19 | 20 | ||
20 | $(header): $(sysdef) $(systbl) | 21 | $(header): $(sysdef) $(systbl) |
21 | $(Q)$(SHELL) '$(systbl)' '$(CC)' $(sysdef) > $@ | 22 | @(test -d ../../kernel -a -d ../../tools -a -d ../perf && ( \ |
23 | (diff -B $(sysdef) $(syskrn) >/dev/null) \ | ||
24 | || echo "Warning: Kernel ABI header at '$(sysdef)' differs from latest version at '$(syskrn)'" >&2 )) || true | ||
25 | $(Q)$(SHELL) '$(systbl)' $(sysdef) > $@ | ||
22 | 26 | ||
23 | clean:: | 27 | clean:: |
24 | $(call QUIET_CLEAN, s390) $(RM) $(header) | 28 | $(call QUIET_CLEAN, s390) $(RM) $(header) |
diff --git a/tools/perf/arch/s390/entry/syscalls/mksyscalltbl b/tools/perf/arch/s390/entry/syscalls/mksyscalltbl index 7fa0d0abd419..72ecbb676370 100755 --- a/tools/perf/arch/s390/entry/syscalls/mksyscalltbl +++ b/tools/perf/arch/s390/entry/syscalls/mksyscalltbl | |||
@@ -3,25 +3,23 @@ | |||
3 | # | 3 | # |
4 | # Generate system call table for perf | 4 | # Generate system call table for perf |
5 | # | 5 | # |
6 | # | 6 | # Copyright IBM Corp. 2017, 2018 |
7 | # Copyright IBM Corp. 2017 | ||
8 | # Author(s): Hendrik Brueckner <brueckner@linux.vnet.ibm.com> | 7 | # Author(s): Hendrik Brueckner <brueckner@linux.vnet.ibm.com> |
9 | # | 8 | # |
10 | 9 | ||
11 | gcc=$1 | 10 | SYSCALL_TBL=$1 |
12 | input=$2 | ||
13 | 11 | ||
14 | if ! test -r $input; then | 12 | if ! test -r $SYSCALL_TBL; then |
15 | echo "Could not read input file" >&2 | 13 | echo "Could not read input file" >&2 |
16 | exit 1 | 14 | exit 1 |
17 | fi | 15 | fi |
18 | 16 | ||
19 | create_table() | 17 | create_table() |
20 | { | 18 | { |
21 | local max_nr | 19 | local max_nr nr abi sc discard |
22 | 20 | ||
23 | echo 'static const char *syscalltbl_s390_64[] = {' | 21 | echo 'static const char *syscalltbl_s390_64[] = {' |
24 | while read sc nr; do | 22 | while read nr abi sc discard; do |
25 | printf '\t[%d] = "%s",\n' $nr $sc | 23 | printf '\t[%d] = "%s",\n' $nr $sc |
26 | max_nr=$nr | 24 | max_nr=$nr |
27 | done | 25 | done |
@@ -29,8 +27,6 @@ create_table() | |||
29 | echo "#define SYSCALLTBL_S390_64_MAX_ID $max_nr" | 27 | echo "#define SYSCALLTBL_S390_64_MAX_ID $max_nr" |
30 | } | 28 | } |
31 | 29 | ||
32 | 30 | grep -E "^[[:digit:]]+[[:space:]]+(common|64)" $SYSCALL_TBL \ | |
33 | $gcc -m64 -E -dM -x c $input \ | 31 | |sort -k1 -n \ |
34 | |sed -ne 's/^#define __NR_//p' \ | ||
35 | |sort -t' ' -k2 -nu \ | ||
36 | |create_table | 32 | |create_table |