123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149 |
- /*
- * arch/arm/include/asm/glue.h
- *
- * Copyright (C) 1997-1999 Russell King
- * Copyright (C) 2000-2002 Deep Blue Solutions Ltd.
- *
- * This program is free software; you can redistribute it and/or modify
- * it under the terms of the GNU General Public License version 2 as
- * published by the Free Software Foundation.
- *
- * This file provides the glue to stick the processor-specific bits
- * into the kernel in an efficient manner. The idea is to use branches
- * when we're only targetting one class of TLB, or indirect calls
- * when we're targetting multiple classes of TLBs.
- */
- #ifdef __KERNEL__
- #ifdef __STDC__
- #define ____glue(name,fn) name##fn
- #else
- #define ____glue(name,fn) name/**/fn
- #endif
- #define __glue(name,fn) ____glue(name,fn)
- /*
- * Data Abort Model
- * ================
- *
- * We have the following to choose from:
- * arm6 - ARM6 style
- * arm7 - ARM7 style
- * v4_early - ARMv4 without Thumb early abort handler
- * v4t_late - ARMv4 with Thumb late abort handler
- * v4t_early - ARMv4 with Thumb early abort handler
- * v5tej_early - ARMv5 with Thumb and Java early abort handler
- * xscale - ARMv5 with Thumb with Xscale extensions
- * v6_early - ARMv6 generic early abort handler
- * v7_early - ARMv7 generic early abort handler
- */
- #undef CPU_DABORT_HANDLER
- #undef MULTI_DABORT
- #if defined(CONFIG_CPU_ARM610)
- # ifdef CPU_DABORT_HANDLER
- # define MULTI_DABORT 1
- # else
- # define CPU_DABORT_HANDLER cpu_arm6_data_abort
- # endif
- #endif
- #if defined(CONFIG_CPU_ARM710)
- # ifdef CPU_DABORT_HANDLER
- # define MULTI_DABORT 1
- # else
- # define CPU_DABORT_HANDLER cpu_arm7_data_abort
- # endif
- #endif
- #ifdef CONFIG_CPU_ABRT_LV4T
- # ifdef CPU_DABORT_HANDLER
- # define MULTI_DABORT 1
- # else
- # define CPU_DABORT_HANDLER v4t_late_abort
- # endif
- #endif
- #ifdef CONFIG_CPU_ABRT_EV4
- # ifdef CPU_DABORT_HANDLER
- # define MULTI_DABORT 1
- # else
- # define CPU_DABORT_HANDLER v4_early_abort
- # endif
- #endif
- #ifdef CONFIG_CPU_ABRT_EV4T
- # ifdef CPU_DABORT_HANDLER
- # define MULTI_DABORT 1
- # else
- # define CPU_DABORT_HANDLER v4t_early_abort
- # endif
- #endif
- #ifdef CONFIG_CPU_ABRT_EV5TJ
- # ifdef CPU_DABORT_HANDLER
- # define MULTI_DABORT 1
- # else
- # define CPU_DABORT_HANDLER v5tj_early_abort
- # endif
- #endif
- #ifdef CONFIG_CPU_ABRT_EV5T
- # ifdef CPU_DABORT_HANDLER
- # define MULTI_DABORT 1
- # else
- # define CPU_DABORT_HANDLER v5t_early_abort
- # endif
- #endif
- #ifdef CONFIG_CPU_ABRT_EV6
- # ifdef CPU_DABORT_HANDLER
- # define MULTI_DABORT 1
- # else
- # define CPU_DABORT_HANDLER v6_early_abort
- # endif
- #endif
- #ifdef CONFIG_CPU_ABRT_EV7
- # ifdef CPU_DABORT_HANDLER
- # define MULTI_DABORT 1
- # else
- # define CPU_DABORT_HANDLER v7_early_abort
- # endif
- #endif
- #ifndef CPU_DABORT_HANDLER
- #error Unknown data abort handler type
- #endif
- /*
- * Prefetch abort handler. If the CPU has an IFAR use that, otherwise
- * use the address of the aborted instruction
- */
- #undef CPU_PABORT_HANDLER
- #undef MULTI_PABORT
- #ifdef CONFIG_CPU_PABRT_IFAR
- # ifdef CPU_PABORT_HANDLER
- # define MULTI_PABORT 1
- # else
- # define CPU_PABORT_HANDLER(reg, insn) mrc p15, 0, reg, cr6, cr0, 2
- # endif
- #endif
- #ifdef CONFIG_CPU_PABRT_NOIFAR
- # ifdef CPU_PABORT_HANDLER
- # define MULTI_PABORT 1
- # else
- # define CPU_PABORT_HANDLER(reg, insn) mov reg, insn
- # endif
- #endif
- #ifndef CPU_PABORT_HANDLER
- #error Unknown prefetch abort handler type
- #endif
- #endif
|