perf env: Cache the arch specific strerrno function in perf_env__arch_strerrno()
authorArnaldo Carvalho de Melo <acme@redhat.com>
Fri, 1 Dec 2023 20:07:34 +0000 (17:07 -0300)
committerArnaldo Carvalho de Melo <acme@redhat.com>
Mon, 4 Dec 2023 19:42:15 +0000 (16:42 -0300)
So that we don't have to go thru the series of strcmp(arch) calls for
each id -> string translation.

Reviewed-by: Ian Rogers <irogers@google.com>
Cc: Adrian Hunter <adrian.hunter@intel.com>
Cc: David Laight <David.Laight@ACULAB.COM>
Cc: Jiri Olsa <jolsa@kernel.org>
Cc: Namhyung Kim <namhyung@kernel.org>
Link: https://lore.kernel.org/lkml/20231201203046.486596-3-acme@kernel.org
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
tools/perf/trace/beauty/arch_errno_names.sh
tools/perf/trace/beauty/beauty.h
tools/perf/util/env.c
tools/perf/util/env.h

index b6e0767b4b34e46a187c3542af8b7cc31269ac17..7df4bf5b55a3cc2a8c5a31462129e8ac829a4e59 100755 (executable)
@@ -57,13 +57,13 @@ create_arch_errno_table_func()
        archlist="$1"
        default="$2"
 
-       printf 'const char *arch_syscalls__strerrno(const char *arch, int err)\n'
+       printf 'arch_syscalls__strerrno_t *arch_syscalls__strerrno_function(const char *arch)\n'
        printf '{\n'
        for arch in $archlist; do
                printf '\tif (!strcmp(arch, "%s"))\n' $(arch_string "$arch")
-               printf '\t\treturn errno_to_name__%s(err);\n' $(arch_string "$arch")
+               printf '\t\treturn errno_to_name__%s;\n' $(arch_string "$arch")
        done
-       printf '\treturn errno_to_name__%s(err);\n' $(arch_string "$default")
+       printf '\treturn errno_to_name__%s;\n' $(arch_string "$default")
        printf '}\n'
 }
 
index 788e8f6bd90eb753af7b7e2928831837c99ff789..9feb794f5c6e15f408a372665f537df5a630e5a0 100644 (file)
@@ -251,6 +251,4 @@ size_t open__scnprintf_flags(unsigned long flags, char *bf, size_t size, bool sh
 void syscall_arg__set_ret_scnprintf(struct syscall_arg *arg,
                                    size_t (*ret_scnprintf)(char *bf, size_t size, struct syscall_arg *arg));
 
-const char *arch_syscalls__strerrno(const char *arch, int err);
-
 #endif /* _PERF_TRACE_BEAUTY_H */
index a632f33646bb3afbca5d8f168dff78f918a269f6..c68b7a004f2948c081712761c95383cb5d52d69a 100644 (file)
@@ -458,8 +458,10 @@ const char *perf_env__arch(struct perf_env *env)
 const char *perf_env__arch_strerrno(struct perf_env *env __maybe_unused, int err __maybe_unused)
 {
 #if defined(HAVE_SYSCALL_TABLE_SUPPORT) && defined(HAVE_LIBTRACEEVENT)
-       const char *arch_name = perf_env__arch(env);
-       return arch_syscalls__strerrno(arch_name, err);
+       if (env->arch_strerrno == NULL)
+               env->arch_strerrno = arch_syscalls__strerrno_function(perf_env__arch(env));
+
+       return env->arch_strerrno ? env->arch_strerrno(err) : "no arch specific strerrno function";
 #else
        return "!(HAVE_SYSCALL_TABLE_SUPPORT && HAVE_LIBTRACEEVENT)";
 #endif
index 79f371879f45bafc24309b884e6129fce6c781c1..bf7e3c4c211f971e9ee63097dbaea42babbcc35d 100644 (file)
@@ -53,6 +53,10 @@ struct pmu_caps {
        char            *pmu_name;
 };
 
+typedef const char *(arch_syscalls__strerrno_t)(int err);
+
+arch_syscalls__strerrno_t *arch_syscalls__strerrno_function(const char *arch);
+
 struct perf_env {
        char                    *hostname;
        char                    *os_release;
@@ -135,6 +139,7 @@ struct perf_env {
                 */
                bool    enabled;
        } clock;
+       arch_syscalls__strerrno_t *arch_strerrno;
 };
 
 enum perf_compress_type {