mirror of
https://github.com/edk2-porting/linux-next.git
synced 2025-01-06 12:44:14 +08:00
55bdd69411
This patch adds the base support for the ARMv7-M architecture. It consists of the corresponding arch/arm/mm/ files and various #ifdef's around the kernel. Exception handling is implemented by a subsequent patch. [ukleinek: squash in some changes originating from commit b5717ba (Cortex-M3: Add support for the Microcontroller Prototyping System) from the v2.6.33-arm1 patch stack, port to post 3.6, drop zImage support, drop reorganisation of pt_regs, assert CONFIG_CPU_V7M doesn't leak into installed headers and a few cosmetic changes] Signed-off-by: Catalin Marinas <catalin.marinas@arm.com> Reviewed-by: Jonathan Austin <jonathan.austin@arm.com> Tested-by: Jonathan Austin <jonathan.austin@arm.com> Signed-off-by: Uwe Kleine-König <u.kleine-koenig@pengutronix.de>
111 lines
2.4 KiB
C
111 lines
2.4 KiB
C
/*
|
|
* arch/arm/include/asm/glue-df.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.
|
|
*/
|
|
#ifndef ASM_GLUE_DF_H
|
|
#define ASM_GLUE_DF_H
|
|
|
|
#include <asm/glue.h>
|
|
|
|
/*
|
|
* Data Abort Model
|
|
* ================
|
|
*
|
|
* We have the following to choose from:
|
|
* 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
|
|
* v5t_early - ARMv5 with Thumb early abort handler
|
|
* v5tj_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_ARM710)
|
|
# ifdef CPU_DABORT_HANDLER
|
|
# define MULTI_DABORT 1
|
|
# else
|
|
# define CPU_DABORT_HANDLER cpu_arm7_data_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_LV4T
|
|
# ifdef CPU_DABORT_HANDLER
|
|
# define MULTI_DABORT 1
|
|
# else
|
|
# define CPU_DABORT_HANDLER v4t_late_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_EV5T
|
|
# ifdef CPU_DABORT_HANDLER
|
|
# define MULTI_DABORT 1
|
|
# else
|
|
# define CPU_DABORT_HANDLER v5t_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_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
|
|
|
|
#ifdef CONFIG_CPU_ABRT_NOMMU
|
|
# ifdef CPU_DABORT_HANDLER
|
|
# define MULTI_DABORT 1
|
|
# else
|
|
# define CPU_DABORT_HANDLER nommu_early_abort
|
|
# endif
|
|
#endif
|
|
|
|
#ifndef CPU_DABORT_HANDLER
|
|
#error Unknown data abort handler type
|
|
#endif
|
|
|
|
#endif
|