提交 e8c328d7 编写于 作者: M Mark Rutland 提交者: Will Deacon

arm64: extable: make fixup_exception() return bool

The return values of fixup_exception() and arm64_bpf_fixup_exception()
represent a boolean condition rather than an error code, so for clarity
it would be better to return `bool` rather than `int`.

This patch adjusts the code accordingly. While we're modifying the
prototype, we also remove the unnecessary `extern` keyword, so that this
won't look out of place when we make subsequent additions to the header.

There should be no functional change as a result of this patch.
Signed-off-by: NMark Rutland <mark.rutland@arm.com>
Reviewed-by: NArd Biesheuvel <ardb@kernel.org>
Cc: Alexei Starovoitov <ast@kernel.org>
Cc: Andrii Nakryiko <andrii@kernel.org>
Cc: Catalin Marinas <catalin.marinas@arm.com>
Cc: Daniel Borkmann <daniel@iogearbox.net>
Cc: James Morse <james.morse@arm.com>
Cc: Jean-Philippe Brucker <jean-philippe@linaro.org>
Cc: Robin Murphy <robin.murphy@arm.com>
Cc: Will Deacon <will@kernel.org>
Link: https://lore.kernel.org/r/20211019160219.5202-9-mark.rutland@arm.comSigned-off-by: NWill Deacon <will@kernel.org>
上级 819771cc
...@@ -32,16 +32,16 @@ static inline bool in_bpf_jit(struct pt_regs *regs) ...@@ -32,16 +32,16 @@ static inline bool in_bpf_jit(struct pt_regs *regs)
} }
#ifdef CONFIG_BPF_JIT #ifdef CONFIG_BPF_JIT
int arm64_bpf_fixup_exception(const struct exception_table_entry *ex, bool arm64_bpf_fixup_exception(const struct exception_table_entry *ex,
struct pt_regs *regs); struct pt_regs *regs);
#else /* !CONFIG_BPF_JIT */ #else /* !CONFIG_BPF_JIT */
static inline static inline
int arm64_bpf_fixup_exception(const struct exception_table_entry *ex, bool arm64_bpf_fixup_exception(const struct exception_table_entry *ex,
struct pt_regs *regs) struct pt_regs *regs)
{ {
return 0; return false;
} }
#endif /* !CONFIG_BPF_JIT */ #endif /* !CONFIG_BPF_JIT */
extern int fixup_exception(struct pt_regs *regs); bool fixup_exception(struct pt_regs *regs);
#endif #endif
...@@ -6,17 +6,17 @@ ...@@ -6,17 +6,17 @@
#include <linux/extable.h> #include <linux/extable.h>
#include <linux/uaccess.h> #include <linux/uaccess.h>
int fixup_exception(struct pt_regs *regs) bool fixup_exception(struct pt_regs *regs)
{ {
const struct exception_table_entry *fixup; const struct exception_table_entry *fixup;
fixup = search_exception_tables(instruction_pointer(regs)); fixup = search_exception_tables(instruction_pointer(regs));
if (!fixup) if (!fixup)
return 0; return false;
if (in_bpf_jit(regs)) if (in_bpf_jit(regs))
return arm64_bpf_fixup_exception(fixup, regs); return arm64_bpf_fixup_exception(fixup, regs);
regs->pc = (unsigned long)&fixup->fixup + fixup->fixup; regs->pc = (unsigned long)&fixup->fixup + fixup->fixup;
return 1; return true;
} }
...@@ -358,15 +358,15 @@ static void build_epilogue(struct jit_ctx *ctx) ...@@ -358,15 +358,15 @@ static void build_epilogue(struct jit_ctx *ctx)
#define BPF_FIXUP_OFFSET_MASK GENMASK(26, 0) #define BPF_FIXUP_OFFSET_MASK GENMASK(26, 0)
#define BPF_FIXUP_REG_MASK GENMASK(31, 27) #define BPF_FIXUP_REG_MASK GENMASK(31, 27)
int arm64_bpf_fixup_exception(const struct exception_table_entry *ex, bool arm64_bpf_fixup_exception(const struct exception_table_entry *ex,
struct pt_regs *regs) struct pt_regs *regs)
{ {
off_t offset = FIELD_GET(BPF_FIXUP_OFFSET_MASK, ex->fixup); off_t offset = FIELD_GET(BPF_FIXUP_OFFSET_MASK, ex->fixup);
int dst_reg = FIELD_GET(BPF_FIXUP_REG_MASK, ex->fixup); int dst_reg = FIELD_GET(BPF_FIXUP_REG_MASK, ex->fixup);
regs->regs[dst_reg] = 0; regs->regs[dst_reg] = 0;
regs->pc = (unsigned long)&ex->fixup - offset; regs->pc = (unsigned long)&ex->fixup - offset;
return 1; return true;
} }
/* For accesses to BTF pointers, add an entry to the exception table */ /* For accesses to BTF pointers, add an entry to the exception table */
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册