xref: /openbmc/linux/arch/arm/include/asm/glue.h (revision baa7eb025ab14f3cba2e35c0a8648f9c9f01d24f)
1 /*
2  *  arch/arm/include/asm/glue.h
3  *
4  *  Copyright (C) 1997-1999 Russell King
5  *  Copyright (C) 2000-2002 Deep Blue Solutions Ltd.
6  *
7  * This program is free software; you can redistribute it and/or modify
8  * it under the terms of the GNU General Public License version 2 as
9  * published by the Free Software Foundation.
10  *
11  *  This file provides the glue to stick the processor-specific bits
12  *  into the kernel in an efficient manner.  The idea is to use branches
13  *  when we're only targetting one class of TLB, or indirect calls
14  *  when we're targetting multiple classes of TLBs.
15  */
16 #ifdef __KERNEL__
17 
18 
19 #ifdef __STDC__
20 #define ____glue(name,fn)	name##fn
21 #else
22 #define ____glue(name,fn)	name/**/fn
23 #endif
24 #define __glue(name,fn)		____glue(name,fn)
25 
26 
27 
28 /*
29  *	Data Abort Model
30  *	================
31  *
32  *	We have the following to choose from:
33  *	  arm6          - ARM6 style
34  *	  arm7		- ARM7 style
35  *	  v4_early	- ARMv4 without Thumb early abort handler
36  *	  v4t_late	- ARMv4 with Thumb late abort handler
37  *	  v4t_early	- ARMv4 with Thumb early abort handler
38  *	  v5tej_early	- ARMv5 with Thumb and Java early abort handler
39  *	  xscale	- ARMv5 with Thumb with Xscale extensions
40  *	  v6_early	- ARMv6 generic early abort handler
41  *	  v7_early	- ARMv7 generic early abort handler
42  */
43 #undef CPU_DABORT_HANDLER
44 #undef MULTI_DABORT
45 
46 #if defined(CONFIG_CPU_ARM610)
47 # ifdef CPU_DABORT_HANDLER
48 #  define MULTI_DABORT 1
49 # else
50 #  define CPU_DABORT_HANDLER cpu_arm6_data_abort
51 # endif
52 #endif
53 
54 #if defined(CONFIG_CPU_ARM710)
55 # ifdef CPU_DABORT_HANDLER
56 #  define MULTI_DABORT 1
57 # else
58 #  define CPU_DABORT_HANDLER cpu_arm7_data_abort
59 # endif
60 #endif
61 
62 #ifdef CONFIG_CPU_ABRT_LV4T
63 # ifdef CPU_DABORT_HANDLER
64 #  define MULTI_DABORT 1
65 # else
66 #  define CPU_DABORT_HANDLER v4t_late_abort
67 # endif
68 #endif
69 
70 #ifdef CONFIG_CPU_ABRT_EV4
71 # ifdef CPU_DABORT_HANDLER
72 #  define MULTI_DABORT 1
73 # else
74 #  define CPU_DABORT_HANDLER v4_early_abort
75 # endif
76 #endif
77 
78 #ifdef CONFIG_CPU_ABRT_EV4T
79 # ifdef CPU_DABORT_HANDLER
80 #  define MULTI_DABORT 1
81 # else
82 #  define CPU_DABORT_HANDLER v4t_early_abort
83 # endif
84 #endif
85 
86 #ifdef CONFIG_CPU_ABRT_EV5TJ
87 # ifdef CPU_DABORT_HANDLER
88 #  define MULTI_DABORT 1
89 # else
90 #  define CPU_DABORT_HANDLER v5tj_early_abort
91 # endif
92 #endif
93 
94 #ifdef CONFIG_CPU_ABRT_EV5T
95 # ifdef CPU_DABORT_HANDLER
96 #  define MULTI_DABORT 1
97 # else
98 #  define CPU_DABORT_HANDLER v5t_early_abort
99 # endif
100 #endif
101 
102 #ifdef CONFIG_CPU_ABRT_EV6
103 # ifdef CPU_DABORT_HANDLER
104 #  define MULTI_DABORT 1
105 # else
106 #  define CPU_DABORT_HANDLER v6_early_abort
107 # endif
108 #endif
109 
110 #ifdef CONFIG_CPU_ABRT_EV7
111 # ifdef CPU_DABORT_HANDLER
112 #  define MULTI_DABORT 1
113 # else
114 #  define CPU_DABORT_HANDLER v7_early_abort
115 # endif
116 #endif
117 
118 #ifndef CPU_DABORT_HANDLER
119 #error Unknown data abort handler type
120 #endif
121 
122 /*
123  *	Prefetch Abort Model
124  *	================
125  *
126  *	We have the following to choose from:
127  *	  legacy	- no IFSR, no IFAR
128  *	  v6		- ARMv6: IFSR, no IFAR
129  *	  v7		- ARMv7: IFSR and IFAR
130  */
131 
132 #undef CPU_PABORT_HANDLER
133 #undef MULTI_PABORT
134 
135 #ifdef CONFIG_CPU_PABRT_LEGACY
136 # ifdef CPU_PABORT_HANDLER
137 #  define MULTI_PABORT 1
138 # else
139 #  define CPU_PABORT_HANDLER legacy_pabort
140 # endif
141 #endif
142 
143 #ifdef CONFIG_CPU_PABRT_V6
144 # ifdef CPU_PABORT_HANDLER
145 #  define MULTI_PABORT 1
146 # else
147 #  define CPU_PABORT_HANDLER v6_pabort
148 # endif
149 #endif
150 
151 #ifdef CONFIG_CPU_PABRT_V7
152 # ifdef CPU_PABORT_HANDLER
153 #  define MULTI_PABORT 1
154 # else
155 #  define CPU_PABORT_HANDLER v7_pabort
156 # endif
157 #endif
158 
159 #ifndef CPU_PABORT_HANDLER
160 #error Unknown prefetch abort handler type
161 #endif
162 
163 #endif
164