ff382c1ce8
util/perf_regs.h includes another perf_regs.h: #include <perf_regs.h> Here it includes architecture specific header, for example, if we build arm64 target, the header tools/perf/arch/arm64/include/perf_regs.h is included. We use this implicit way to include architecture specific header, which is not directive; furthermore, util/perf_regs.c is coupled with the architecture specific definitions. This patch moves out arch specific header from util/perf_regs.h for generalizing the 'util' folder, as a result, the source files in 'arch' folder explicitly include architecture's perf_regs.h. Signed-off-by: Leo Yan <leo.yan@linaro.org> Acked-by: Ian Rogers <irogers@google.com> Cc: Adrian Hunter <adrian.hunter@intel.com> Cc: Albert Ou <aou@eecs.berkeley.edu> Cc: Alexander Shishkin <alexander.shishkin@linux.intel.com> Cc: Eric Lin <eric.lin@sifive.com> Cc: Fangrui Song <maskray@google.com> Cc: Guo Ren <guoren@kernel.org> Cc: Huacai Chen <chenhuacai@kernel.org> Cc: Ingo Molnar <mingo@redhat.com> Cc: Ivan Babrou <ivan@cloudflare.com> Cc: James Clark <james.clark@arm.com> Cc: Jiri Olsa <jolsa@kernel.org> Cc: John Garry <john.g.garry@oracle.com> Cc: Kan Liang <kan.liang@linux.intel.com> Cc: Mark Rutland <mark.rutland@arm.com> Cc: Mike Leach <mike.leach@linaro.org> Cc: Ming Wang <wangming01@loongson.cn> Cc: Namhyung Kim <namhyung@kernel.org> Cc: Palmer Dabbelt <palmer@dabbelt.com> Cc: Paul Walmsley <paul.walmsley@sifive.com> Cc: Peter Zijlstra <peterz@infradead.org> Cc: Sandipan Das <sandipan.das@amd.com> Cc: Will Deacon <will@kernel.org> Cc: linux-arm-kernel@lists.infradead.org Cc: linux-csky@vger.kernel.org Cc: linux-riscv@lists.infradead.org Link: https://lore.kernel.org/r/20230606014559.21783-7-leo.yan@linaro.org Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
55 lines
1.4 KiB
C
55 lines
1.4 KiB
C
// SPDX-License-Identifier: GPL-2.0
|
|
#include <elfutils/libdwfl.h>
|
|
#include "perf_regs.h"
|
|
#include "../../../util/unwind-libdw.h"
|
|
#include "../../../util/perf_regs.h"
|
|
#include "util/sample.h"
|
|
|
|
bool libdw__arch_set_initial_registers(Dwfl_Thread *thread, void *arg)
|
|
{
|
|
struct unwind_info *ui = arg;
|
|
struct regs_dump *user_regs = &ui->sample->user_regs;
|
|
Dwarf_Word dwarf_regs[17];
|
|
unsigned nregs;
|
|
|
|
#define REG(r) ({ \
|
|
Dwarf_Word val = 0; \
|
|
perf_reg_value(&val, user_regs, PERF_REG_X86_##r); \
|
|
val; \
|
|
})
|
|
|
|
if (user_regs->abi == PERF_SAMPLE_REGS_ABI_32) {
|
|
dwarf_regs[0] = REG(AX);
|
|
dwarf_regs[1] = REG(CX);
|
|
dwarf_regs[2] = REG(DX);
|
|
dwarf_regs[3] = REG(BX);
|
|
dwarf_regs[4] = REG(SP);
|
|
dwarf_regs[5] = REG(BP);
|
|
dwarf_regs[6] = REG(SI);
|
|
dwarf_regs[7] = REG(DI);
|
|
dwarf_regs[8] = REG(IP);
|
|
nregs = 9;
|
|
} else {
|
|
dwarf_regs[0] = REG(AX);
|
|
dwarf_regs[1] = REG(DX);
|
|
dwarf_regs[2] = REG(CX);
|
|
dwarf_regs[3] = REG(BX);
|
|
dwarf_regs[4] = REG(SI);
|
|
dwarf_regs[5] = REG(DI);
|
|
dwarf_regs[6] = REG(BP);
|
|
dwarf_regs[7] = REG(SP);
|
|
dwarf_regs[8] = REG(R8);
|
|
dwarf_regs[9] = REG(R9);
|
|
dwarf_regs[10] = REG(R10);
|
|
dwarf_regs[11] = REG(R11);
|
|
dwarf_regs[12] = REG(R12);
|
|
dwarf_regs[13] = REG(R13);
|
|
dwarf_regs[14] = REG(R14);
|
|
dwarf_regs[15] = REG(R15);
|
|
dwarf_regs[16] = REG(IP);
|
|
nregs = 17;
|
|
}
|
|
|
|
return dwfl_thread_state_registers(thread, 0, nregs, dwarf_regs);
|
|
}
|