forked from ~ljy/RK356X_SDK_RELEASE

hc
2023-12-08 01573e231f18eb2d99162747186f59511f56b64d
kernel/arch/arm64/include/asm/exception.h
....@@ -1,32 +1,22 @@
1
+/* SPDX-License-Identifier: GPL-2.0-only */
12 /*
23 * Based on arch/arm/include/asm/exception.h
34 *
45 * Copyright (C) 2012 ARM Ltd.
5
- *
6
- * This program is free software; you can redistribute it and/or modify
7
- * it under the terms of the GNU General Public License version 2 as
8
- * published by the Free Software Foundation.
9
- *
10
- * This program is distributed in the hope that it will be useful,
11
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
12
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13
- * GNU General Public License for more details.
14
- *
15
- * You should have received a copy of the GNU General Public License
16
- * along with this program. If not, see <http://www.gnu.org/licenses/>.
176 */
187 #ifndef __ASM_EXCEPTION_H
198 #define __ASM_EXCEPTION_H
209
2110 #include <asm/esr.h>
11
+#include <asm/kprobes.h>
12
+#include <asm/ptrace.h>
2213
2314 #include <linux/interrupt.h>
2415
25
-#define __exception __attribute__((section(".exception.text")))
2616 #ifdef CONFIG_FUNCTION_GRAPH_TRACER
2717 #define __exception_irq_entry __irq_entry
2818 #else
29
-#define __exception_irq_entry __exception
19
+#define __exception_irq_entry __kprobes
3020 #endif
3121
3222 static inline u32 disr_to_esr(u64 disr)
....@@ -41,4 +31,26 @@
4131 return esr;
4232 }
4333
34
+asmlinkage void noinstr enter_el1_irq_or_nmi(struct pt_regs *regs);
35
+asmlinkage void noinstr exit_el1_irq_or_nmi(struct pt_regs *regs);
36
+asmlinkage void enter_from_user_mode(void);
37
+asmlinkage void exit_to_user_mode(void);
38
+void arm64_enter_nmi(struct pt_regs *regs);
39
+void arm64_exit_nmi(struct pt_regs *regs);
40
+void do_mem_abort(unsigned long far, unsigned int esr, struct pt_regs *regs);
41
+void do_undefinstr(struct pt_regs *regs);
42
+void do_bti(struct pt_regs *regs);
43
+asmlinkage void bad_mode(struct pt_regs *regs, int reason, unsigned int esr);
44
+void do_debug_exception(unsigned long addr_if_watchpoint, unsigned int esr,
45
+ struct pt_regs *regs);
46
+void do_fpsimd_acc(unsigned int esr, struct pt_regs *regs);
47
+void do_sve_acc(unsigned int esr, struct pt_regs *regs);
48
+void do_fpsimd_exc(unsigned int esr, struct pt_regs *regs);
49
+void do_sysinstr(unsigned int esr, struct pt_regs *regs);
50
+void do_sp_pc_abort(unsigned long addr, unsigned int esr, struct pt_regs *regs);
51
+void bad_el0_sync(struct pt_regs *regs, int reason, unsigned int esr);
52
+void do_cp15instr(unsigned int esr, struct pt_regs *regs);
53
+void do_el0_svc(struct pt_regs *regs);
54
+void do_el0_svc_compat(struct pt_regs *regs);
55
+void do_ptrauth_fault(struct pt_regs *regs, unsigned int esr);
4456 #endif /* __ASM_EXCEPTION_H */