forked from luck/tmp_suning_uos_patched
perf annotate: Fix arch specific ->init() failure errors
They are called from symbol__annotate() and to propagate errors that can help understand the problem make them return what symbol__strerror_disassemble() known, i.e. errno codes and other annotation specific errors in a special, out of errnos, range. Reported-by: Russell King - ARM Linux admin <linux@armlinux.org.uk> Cc: Adrian Hunter <adrian.hunter@intel.com> Cc: Alexander Shishkin <alexander.shishkin@linux.intel.com> Cc: Jiri Olsa <jolsa@kernel.org> Cc: Namhyung Kim <namhyung@kernel.org> Cc: Peter Zijlstra <peterz@infradead.org>, Cc: Will Deacon <will@kernel.org> Link: https://lkml.kernel.org/n/tip-pqx7srcv7tixgid251aeboj6@git.kernel.org Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
This commit is contained in:
parent
211f493b61
commit
42d7a9107d
|
@ -37,7 +37,7 @@ static int arm__annotate_init(struct arch *arch, char *cpuid __maybe_unused)
|
||||||
|
|
||||||
arm = zalloc(sizeof(*arm));
|
arm = zalloc(sizeof(*arm));
|
||||||
if (!arm)
|
if (!arm)
|
||||||
return -1;
|
return ENOMEM;
|
||||||
|
|
||||||
#define ARM_CONDS "(cc|cs|eq|ge|gt|hi|le|ls|lt|mi|ne|pl|vc|vs)"
|
#define ARM_CONDS "(cc|cs|eq|ge|gt|hi|le|ls|lt|mi|ne|pl|vc|vs)"
|
||||||
err = regcomp(&arm->call_insn, "^blx?" ARM_CONDS "?$", REG_EXTENDED);
|
err = regcomp(&arm->call_insn, "^blx?" ARM_CONDS "?$", REG_EXTENDED);
|
||||||
|
@ -59,5 +59,5 @@ static int arm__annotate_init(struct arch *arch, char *cpuid __maybe_unused)
|
||||||
regfree(&arm->call_insn);
|
regfree(&arm->call_insn);
|
||||||
out_free_arm:
|
out_free_arm:
|
||||||
free(arm);
|
free(arm);
|
||||||
return -1;
|
return SYMBOL_ANNOTATE_ERRNO__ARCH_INIT_REGEXP;
|
||||||
}
|
}
|
||||||
|
|
|
@ -95,7 +95,7 @@ static int arm64__annotate_init(struct arch *arch, char *cpuid __maybe_unused)
|
||||||
|
|
||||||
arm = zalloc(sizeof(*arm));
|
arm = zalloc(sizeof(*arm));
|
||||||
if (!arm)
|
if (!arm)
|
||||||
return -1;
|
return ENOMEM;
|
||||||
|
|
||||||
/* bl, blr */
|
/* bl, blr */
|
||||||
err = regcomp(&arm->call_insn, "^blr?$", REG_EXTENDED);
|
err = regcomp(&arm->call_insn, "^blr?$", REG_EXTENDED);
|
||||||
|
@ -118,5 +118,5 @@ static int arm64__annotate_init(struct arch *arch, char *cpuid __maybe_unused)
|
||||||
regfree(&arm->call_insn);
|
regfree(&arm->call_insn);
|
||||||
out_free_arm:
|
out_free_arm:
|
||||||
free(arm);
|
free(arm);
|
||||||
return -1;
|
return SYMBOL_ANNOTATE_ERRNO__ARCH_INIT_REGEXP;
|
||||||
}
|
}
|
||||||
|
|
|
@ -164,8 +164,10 @@ static int s390__annotate_init(struct arch *arch, char *cpuid __maybe_unused)
|
||||||
if (!arch->initialized) {
|
if (!arch->initialized) {
|
||||||
arch->initialized = true;
|
arch->initialized = true;
|
||||||
arch->associate_instruction_ops = s390__associate_ins_ops;
|
arch->associate_instruction_ops = s390__associate_ins_ops;
|
||||||
if (cpuid)
|
if (cpuid) {
|
||||||
err = s390__cpuid_parse(arch, cpuid);
|
if (s390__cpuid_parse(arch, cpuid))
|
||||||
|
err = SYMBOL_ANNOTATE_ERRNO__ARCH_INIT_CPUID_PARSING;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return err;
|
return err;
|
||||||
|
|
|
@ -196,8 +196,10 @@ static int x86__annotate_init(struct arch *arch, char *cpuid)
|
||||||
if (arch->initialized)
|
if (arch->initialized)
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
if (cpuid)
|
if (cpuid) {
|
||||||
err = x86__cpuid_parse(arch, cpuid);
|
if (x86__cpuid_parse(arch, cpuid))
|
||||||
|
err = SYMBOL_ANNOTATE_ERRNO__ARCH_INIT_CPUID_PARSING;
|
||||||
|
}
|
||||||
|
|
||||||
arch->initialized = true;
|
arch->initialized = true;
|
||||||
return err;
|
return err;
|
||||||
|
|
|
@ -1631,6 +1631,12 @@ int symbol__strerror_disassemble(struct symbol *sym __maybe_unused, struct map *
|
||||||
case SYMBOL_ANNOTATE_ERRNO__NO_LIBOPCODES_FOR_BPF:
|
case SYMBOL_ANNOTATE_ERRNO__NO_LIBOPCODES_FOR_BPF:
|
||||||
scnprintf(buf, buflen, "Please link with binutils's libopcode to enable BPF annotation");
|
scnprintf(buf, buflen, "Please link with binutils's libopcode to enable BPF annotation");
|
||||||
break;
|
break;
|
||||||
|
case SYMBOL_ANNOTATE_ERRNO__ARCH_INIT_REGEXP:
|
||||||
|
scnprintf(buf, buflen, "Problems with arch specific instruction name regular expressions.");
|
||||||
|
break;
|
||||||
|
case SYMBOL_ANNOTATE_ERRNO__ARCH_INIT_CPUID_PARSING:
|
||||||
|
scnprintf(buf, buflen, "Problems while parsing the CPUID in the arch specific initialization.");
|
||||||
|
break;
|
||||||
default:
|
default:
|
||||||
scnprintf(buf, buflen, "Internal error: Invalid %d error code\n", errnum);
|
scnprintf(buf, buflen, "Internal error: Invalid %d error code\n", errnum);
|
||||||
break;
|
break;
|
||||||
|
|
|
@ -370,6 +370,8 @@ enum symbol_disassemble_errno {
|
||||||
|
|
||||||
SYMBOL_ANNOTATE_ERRNO__NO_VMLINUX = __SYMBOL_ANNOTATE_ERRNO__START,
|
SYMBOL_ANNOTATE_ERRNO__NO_VMLINUX = __SYMBOL_ANNOTATE_ERRNO__START,
|
||||||
SYMBOL_ANNOTATE_ERRNO__NO_LIBOPCODES_FOR_BPF,
|
SYMBOL_ANNOTATE_ERRNO__NO_LIBOPCODES_FOR_BPF,
|
||||||
|
SYMBOL_ANNOTATE_ERRNO__ARCH_INIT_CPUID_PARSING,
|
||||||
|
SYMBOL_ANNOTATE_ERRNO__ARCH_INIT_REGEXP,
|
||||||
|
|
||||||
__SYMBOL_ANNOTATE_ERRNO__END,
|
__SYMBOL_ANNOTATE_ERRNO__END,
|
||||||
};
|
};
|
||||||
|
|
Loading…
Reference in New Issue
Block a user