mirror of
https://github.com/Fishwaldo/linux-bl808.git
synced 2025-06-17 20:25:19 +00:00
Relative path include works in the regular build due to -I paths but may fail in other situations. v2. Rebase. Comments on v1 were that we should handle include paths differently and it is agreed that can be a sensible refactor but beyond the scope of this change. https://lore.kernel.org/lkml/20210504191227.793712-1-irogers@google.com/ Signed-off-by: Ian Rogers <irogers@google.com> Cc: Alexander Shishkin <alexander.shishkin@linux.intel.com> Cc: Jiri Olsa <jolsa@redhat.com> Cc: John Garry <john.garry@huawei.com> Cc: Leo Yan <leo.yan@linaro.org> Cc: Mark Rutland <mark.rutland@arm.com> Cc: Mathieu Poirier <mathieu.poirier@linaro.org> Cc: Namhyung Kim <namhyung@kernel.org> Cc: Peter Zijlstra <peterz@infradead.org> Cc: Sergey Senozhatsky <sergey.senozhatsky@gmail.com> Cc: Stephane Eranian <eranian@google.com> Cc: Will Deacon <will@kernel.org> Cc: linux-arm-kernel@lists.infradead.org Link: http://lore.kernel.org/lkml/20210923154254.737657-1-irogers@google.com Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
50 lines
1 KiB
C
50 lines
1 KiB
C
// SPDX-License-Identifier: GPL-2.0
|
|
|
|
#include <errno.h>
|
|
#include <libunwind.h>
|
|
#include "perf_regs.h"
|
|
#include "../../../util/unwind.h"
|
|
#include "../../../util/debug.h"
|
|
|
|
int libunwind__arch_reg_id(int regnum)
|
|
{
|
|
switch (regnum) {
|
|
case UNW_ARM_R0:
|
|
return PERF_REG_ARM_R0;
|
|
case UNW_ARM_R1:
|
|
return PERF_REG_ARM_R1;
|
|
case UNW_ARM_R2:
|
|
return PERF_REG_ARM_R2;
|
|
case UNW_ARM_R3:
|
|
return PERF_REG_ARM_R3;
|
|
case UNW_ARM_R4:
|
|
return PERF_REG_ARM_R4;
|
|
case UNW_ARM_R5:
|
|
return PERF_REG_ARM_R5;
|
|
case UNW_ARM_R6:
|
|
return PERF_REG_ARM_R6;
|
|
case UNW_ARM_R7:
|
|
return PERF_REG_ARM_R7;
|
|
case UNW_ARM_R8:
|
|
return PERF_REG_ARM_R8;
|
|
case UNW_ARM_R9:
|
|
return PERF_REG_ARM_R9;
|
|
case UNW_ARM_R10:
|
|
return PERF_REG_ARM_R10;
|
|
case UNW_ARM_R11:
|
|
return PERF_REG_ARM_FP;
|
|
case UNW_ARM_R12:
|
|
return PERF_REG_ARM_IP;
|
|
case UNW_ARM_R13:
|
|
return PERF_REG_ARM_SP;
|
|
case UNW_ARM_R14:
|
|
return PERF_REG_ARM_LR;
|
|
case UNW_ARM_R15:
|
|
return PERF_REG_ARM_PC;
|
|
default:
|
|
pr_err("unwind: invalid reg id %d\n", regnum);
|
|
return -EINVAL;
|
|
}
|
|
|
|
return -EINVAL;
|
|
}
|