162306a36Sopenharmony_ci/* SPDX-License-Identifier: GPL-2.0-only */
262306a36Sopenharmony_ci/*
362306a36Sopenharmony_ci * arch/arm/include/asm/kprobes.h
462306a36Sopenharmony_ci *
562306a36Sopenharmony_ci * Copyright (C) 2006, 2007 Motorola Inc.
662306a36Sopenharmony_ci */
762306a36Sopenharmony_ci
862306a36Sopenharmony_ci#ifndef _ARM_KPROBES_H
962306a36Sopenharmony_ci#define _ARM_KPROBES_H
1062306a36Sopenharmony_ci
1162306a36Sopenharmony_ci#include <asm-generic/kprobes.h>
1262306a36Sopenharmony_ci
1362306a36Sopenharmony_ci#ifdef CONFIG_KPROBES
1462306a36Sopenharmony_ci#include <linux/types.h>
1562306a36Sopenharmony_ci#include <linux/ptrace.h>
1662306a36Sopenharmony_ci#include <linux/notifier.h>
1762306a36Sopenharmony_ci
1862306a36Sopenharmony_ci#define __ARCH_WANT_KPROBES_INSN_SLOT
1962306a36Sopenharmony_ci#define MAX_INSN_SIZE			2
2062306a36Sopenharmony_ci
2162306a36Sopenharmony_ci#define flush_insn_slot(p)		do { } while (0)
2262306a36Sopenharmony_ci#define kretprobe_blacklist_size	0
2362306a36Sopenharmony_ci
2462306a36Sopenharmony_citypedef u32 kprobe_opcode_t;
2562306a36Sopenharmony_cistruct kprobe;
2662306a36Sopenharmony_ci#include <asm/probes.h>
2762306a36Sopenharmony_ci
2862306a36Sopenharmony_ci#define	arch_specific_insn	arch_probes_insn
2962306a36Sopenharmony_ci
3062306a36Sopenharmony_cistruct prev_kprobe {
3162306a36Sopenharmony_ci	struct kprobe *kp;
3262306a36Sopenharmony_ci	unsigned int status;
3362306a36Sopenharmony_ci};
3462306a36Sopenharmony_ci
3562306a36Sopenharmony_ci/* per-cpu kprobe control block */
3662306a36Sopenharmony_cistruct kprobe_ctlblk {
3762306a36Sopenharmony_ci	unsigned int kprobe_status;
3862306a36Sopenharmony_ci	struct prev_kprobe prev_kprobe;
3962306a36Sopenharmony_ci};
4062306a36Sopenharmony_ci
4162306a36Sopenharmony_civoid arch_remove_kprobe(struct kprobe *);
4262306a36Sopenharmony_ciint kprobe_fault_handler(struct pt_regs *regs, unsigned int fsr);
4362306a36Sopenharmony_ciint kprobe_exceptions_notify(struct notifier_block *self,
4462306a36Sopenharmony_ci			     unsigned long val, void *data);
4562306a36Sopenharmony_ci
4662306a36Sopenharmony_ci/* optinsn template addresses */
4762306a36Sopenharmony_ciextern __visible kprobe_opcode_t optprobe_template_entry[];
4862306a36Sopenharmony_ciextern __visible kprobe_opcode_t optprobe_template_val[];
4962306a36Sopenharmony_ciextern __visible kprobe_opcode_t optprobe_template_call[];
5062306a36Sopenharmony_ciextern __visible kprobe_opcode_t optprobe_template_end[];
5162306a36Sopenharmony_ciextern __visible kprobe_opcode_t optprobe_template_sub_sp[];
5262306a36Sopenharmony_ciextern __visible kprobe_opcode_t optprobe_template_add_sp[];
5362306a36Sopenharmony_ciextern __visible kprobe_opcode_t optprobe_template_restore_begin[];
5462306a36Sopenharmony_ciextern __visible kprobe_opcode_t optprobe_template_restore_orig_insn[];
5562306a36Sopenharmony_ciextern __visible kprobe_opcode_t optprobe_template_restore_end[];
5662306a36Sopenharmony_ci
5762306a36Sopenharmony_ci#define MAX_OPTIMIZED_LENGTH	4
5862306a36Sopenharmony_ci#define MAX_OPTINSN_SIZE				\
5962306a36Sopenharmony_ci	((unsigned long)optprobe_template_end -	\
6062306a36Sopenharmony_ci	 (unsigned long)optprobe_template_entry)
6162306a36Sopenharmony_ci#define RELATIVEJUMP_SIZE	4
6262306a36Sopenharmony_ci
6362306a36Sopenharmony_cistruct arch_optimized_insn {
6462306a36Sopenharmony_ci	/*
6562306a36Sopenharmony_ci	 * copy of the original instructions.
6662306a36Sopenharmony_ci	 * Different from x86, ARM kprobe_opcode_t is u32.
6762306a36Sopenharmony_ci	 */
6862306a36Sopenharmony_ci#define MAX_COPIED_INSN	DIV_ROUND_UP(RELATIVEJUMP_SIZE, sizeof(kprobe_opcode_t))
6962306a36Sopenharmony_ci	kprobe_opcode_t copied_insn[MAX_COPIED_INSN];
7062306a36Sopenharmony_ci	/* detour code buffer */
7162306a36Sopenharmony_ci	kprobe_opcode_t *insn;
7262306a36Sopenharmony_ci	/*
7362306a36Sopenharmony_ci	 * We always copy one instruction on ARM,
7462306a36Sopenharmony_ci	 * so size will always be 4, and unlike x86, there is no
7562306a36Sopenharmony_ci	 * need for a size field.
7662306a36Sopenharmony_ci	 */
7762306a36Sopenharmony_ci};
7862306a36Sopenharmony_ci
7962306a36Sopenharmony_ci#endif /* CONFIG_KPROBES */
8062306a36Sopenharmony_ci#endif /* _ARM_KPROBES_H */
81