• Home
  • History
  • Annotate
  • Line#
  • Navigate
  • Raw
  • Download
  • only in /netgear-R7000-V1.0.7.12_1.2.5/components/opensource/linux/linux-2.6.36/arch/arm/include/asm/
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