xref: /linux/arch/arm/include/asm/glue-pf.h (revision 24168c5e6dfbdd5b414f048f47f75d64533296ca)
1 /* SPDX-License-Identifier: GPL-2.0-only */
2 /*
3  *  arch/arm/include/asm/glue-pf.h
4  *
5  *  Copyright (C) 1997-1999 Russell King
6  *  Copyright (C) 2000-2002 Deep Blue Solutions Ltd.
7  */
8 #ifndef ASM_GLUE_PF_H
9 #define ASM_GLUE_PF_H
10 
11 #include <asm/glue.h>
12 
13 /*
14  *	Prefetch Abort Model
15  *	================
16  *
17  *	We have the following to choose from:
18  *	  legacy	- no IFSR, no IFAR
19  *	  v6		- ARMv6: IFSR, no IFAR
20  *	  v7		- ARMv7: IFSR and IFAR
21  */
22 
23 #undef CPU_PABORT_HANDLER
24 #undef MULTI_PABORT
25 
26 #ifdef CONFIG_CPU_PABRT_LEGACY
27 # ifdef CPU_PABORT_HANDLER
28 #  define MULTI_PABORT 1
29 # else
30 #  define CPU_PABORT_HANDLER legacy_pabort
31 # endif
32 #endif
33 
34 #ifdef CONFIG_CPU_PABRT_V6
35 # ifdef CPU_PABORT_HANDLER
36 #  define MULTI_PABORT 1
37 # else
38 #  define CPU_PABORT_HANDLER v6_pabort
39 # endif
40 #endif
41 
42 #ifdef CONFIG_CPU_PABRT_V7
43 # ifdef CPU_PABORT_HANDLER
44 #  define MULTI_PABORT 1
45 # else
46 #  define CPU_PABORT_HANDLER v7_pabort
47 # endif
48 #endif
49 
50 #ifndef CPU_PABORT_HANDLER
51 #error Unknown prefetch abort handler type
52 #endif
53 
54 #endif
55