mirror of
git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2025-08-05 16:54:27 +00:00

The probe_opcode_t typedef for u32 isn't necessary, and is a source of confusion as it is easily confused with kprobe_opcode_t, which is a typedef for __le32. The typedef is only used within arch/arm64, and all of arm64's commn insn code uses u32 for the endian-agnostic value of an instruction, so it'd be clearer to use u32 consistently. Remove probe_opcode_t and use u32 directly. There should be no functional change as a result of this patch. Signed-off-by: Mark Rutland <mark.rutland@arm.com> Cc: Catalin Marinas <catalin.marnias@arm.com> Cc: Will Deacon <will@kernel.org> Link: https://lore.kernel.org/r/20241008155851.801546-7-mark.rutland@arm.com Signed-off-by: Catalin Marinas <catalin.marinas@arm.com>
33 lines
814 B
C
33 lines
814 B
C
/* SPDX-License-Identifier: GPL-2.0-only */
|
|
/*
|
|
* arch/arm64/kernel/probes/decode-insn.h
|
|
*
|
|
* Copyright (C) 2013 Linaro Limited.
|
|
*/
|
|
|
|
#ifndef _ARM_KERNEL_KPROBES_ARM64_H
|
|
#define _ARM_KERNEL_KPROBES_ARM64_H
|
|
|
|
#include <asm/kprobes.h>
|
|
|
|
/*
|
|
* ARM strongly recommends a limit of 128 bytes between LoadExcl and
|
|
* StoreExcl instructions in a single thread of execution. So keep the
|
|
* max atomic context size as 32.
|
|
*/
|
|
#define MAX_ATOMIC_CONTEXT_SIZE (128 / sizeof(kprobe_opcode_t))
|
|
|
|
enum probe_insn {
|
|
INSN_REJECTED,
|
|
INSN_GOOD_NO_SLOT,
|
|
INSN_GOOD,
|
|
};
|
|
|
|
#ifdef CONFIG_KPROBES
|
|
enum probe_insn __kprobes
|
|
arm_kprobe_decode_insn(kprobe_opcode_t *addr, struct arch_specific_insn *asi);
|
|
#endif
|
|
enum probe_insn __kprobes
|
|
arm_probe_decode_insn(u32 insn, struct arch_probe_insn *asi);
|
|
|
|
#endif /* _ARM_KERNEL_KPROBES_ARM64_H */
|