diff options
author | Uwe Kleine-König <uwe@kleine-koenig.org> | 2013-03-22 11:25:32 +0100 |
---|---|---|
committer | Uwe Kleine-König <uwe@kleine-koenig.org> | 2013-03-22 11:25:32 +0100 |
commit | 8ed96aa1c250ffe87fe01ad5315762dcfbcfa892 (patch) | |
tree | be6eee75a0f44dd7eb53be733679c078f6f67b79 /configs/platform-energymicro-efm32gg-dk3750/patches/linux-3.9-rc1/rmk-devel-stable-20130309.patch | |
parent | f9c1a22b24bf7648e8d77002e517e439605cec14 (diff) | |
parent | 638f634c3b016e3a200433ef1ca7127a5543e799 (diff) | |
download | OSELAS.BSP-EnergyMicro-Gecko-8ed96aa1c250ffe87fe01ad5315762dcfbcfa892.tar.gz OSELAS.BSP-EnergyMicro-Gecko-8ed96aa1c250ffe87fe01ad5315762dcfbcfa892.tar.xz |
Merge branch 'platform-efm32gg-dk3750/master' of git-public.pengutronix.de:/OSELAS.BSP-EnergyMicro-Gecko
Diffstat (limited to 'configs/platform-energymicro-efm32gg-dk3750/patches/linux-3.9-rc1/rmk-devel-stable-20130309.patch')
-rw-r--r-- | configs/platform-energymicro-efm32gg-dk3750/patches/linux-3.9-rc1/rmk-devel-stable-20130309.patch | 412 |
1 files changed, 412 insertions, 0 deletions
diff --git a/configs/platform-energymicro-efm32gg-dk3750/patches/linux-3.9-rc1/rmk-devel-stable-20130309.patch b/configs/platform-energymicro-efm32gg-dk3750/patches/linux-3.9-rc1/rmk-devel-stable-20130309.patch new file mode 100644 index 0000000..ecba6ed --- /dev/null +++ b/configs/platform-energymicro-efm32gg-dk3750/patches/linux-3.9-rc1/rmk-devel-stable-20130309.patch @@ -0,0 +1,412 @@ +diff --git a/arch/arm/Kconfig b/arch/arm/Kconfig +index 5b71469..dedf02b 100644 +--- a/arch/arm/Kconfig ++++ b/arch/arm/Kconfig +@@ -1684,8 +1684,9 @@ config SCHED_HRTICK + def_bool HIGH_RES_TIMERS + + config THUMB2_KERNEL +- bool "Compile the kernel in Thumb-2 mode" ++ bool "Compile the kernel in Thumb-2 mode" if !CPU_THUMBONLY + depends on CPU_V7 && !CPU_V6 && !CPU_V6K ++ default y if CPU_THUMBONLY + select AEABI + select ARM_ASM_UNIFIED + select ARM_UNWIND +diff --git a/arch/arm/include/asm/cp15.h b/arch/arm/include/asm/cp15.h +index 5ef4d80..1f3262e 100644 +--- a/arch/arm/include/asm/cp15.h ++++ b/arch/arm/include/asm/cp15.h +@@ -42,6 +42,8 @@ + #define vectors_high() (0) + #endif + ++#ifdef CONFIG_CPU_CP15 ++ + extern unsigned long cr_no_alignment; /* defined in entry-armv.S */ + extern unsigned long cr_alignment; /* defined in entry-armv.S */ + +@@ -82,6 +84,18 @@ static inline void set_copro_access(unsigned int val) + isb(); + } + +-#endif ++#else /* ifdef CONFIG_CPU_CP15 */ ++ ++/* ++ * cr_alignment and cr_no_alignment are tightly coupled to cp15 (at least in the ++ * minds of the developers). Yielding 0 for machines without a cp15 (and making ++ * it read-only) is fine for most cases and saves quite some #ifdeffery. ++ */ ++#define cr_no_alignment UL(0) ++#define cr_alignment UL(0) ++ ++#endif /* ifdef CONFIG_CPU_CP15 / else */ ++ ++#endif /* ifndef __ASSEMBLY__ */ + + #endif +diff --git a/arch/arm/include/asm/cputype.h b/arch/arm/include/asm/cputype.h +index ad41ec2..7652712 100644 +--- a/arch/arm/include/asm/cputype.h ++++ b/arch/arm/include/asm/cputype.h +@@ -38,6 +38,24 @@ + #define MPIDR_AFFINITY_LEVEL(mpidr, level) \ + ((mpidr >> (MPIDR_LEVEL_BITS * level)) & MPIDR_LEVEL_MASK) + ++#define ARM_CPU_IMP_ARM 0x41 ++#define ARM_CPU_IMP_INTEL 0x69 ++ ++#define ARM_CPU_PART_ARM1136 0xB360 ++#define ARM_CPU_PART_ARM1156 0xB560 ++#define ARM_CPU_PART_ARM1176 0xB760 ++#define ARM_CPU_PART_ARM11MPCORE 0xB020 ++#define ARM_CPU_PART_CORTEX_A8 0xC080 ++#define ARM_CPU_PART_CORTEX_A9 0xC090 ++#define ARM_CPU_PART_CORTEX_A5 0xC050 ++#define ARM_CPU_PART_CORTEX_A15 0xC0F0 ++#define ARM_CPU_PART_CORTEX_A7 0xC070 ++ ++#define ARM_CPU_XSCALE_ARCH_MASK 0xe000 ++#define ARM_CPU_XSCALE_ARCH_V1 0x2000 ++#define ARM_CPU_XSCALE_ARCH_V2 0x4000 ++#define ARM_CPU_XSCALE_ARCH_V3 0x6000 ++ + extern unsigned int processor_id; + + #ifdef CONFIG_CPU_CP15 +@@ -50,6 +68,7 @@ extern unsigned int processor_id; + : "cc"); \ + __val; \ + }) ++ + #define read_cpuid_ext(ext_reg) \ + ({ \ + unsigned int __val; \ +@@ -59,29 +78,24 @@ extern unsigned int processor_id; + : "cc"); \ + __val; \ + }) +-#else +-#define read_cpuid(reg) (processor_id) +-#define read_cpuid_ext(reg) 0 +-#endif + +-#define ARM_CPU_IMP_ARM 0x41 +-#define ARM_CPU_IMP_INTEL 0x69 ++#else /* ifdef CONFIG_CPU_CP15 */ + +-#define ARM_CPU_PART_ARM1136 0xB360 +-#define ARM_CPU_PART_ARM1156 0xB560 +-#define ARM_CPU_PART_ARM1176 0xB760 +-#define ARM_CPU_PART_ARM11MPCORE 0xB020 +-#define ARM_CPU_PART_CORTEX_A8 0xC080 +-#define ARM_CPU_PART_CORTEX_A9 0xC090 +-#define ARM_CPU_PART_CORTEX_A5 0xC050 +-#define ARM_CPU_PART_CORTEX_A15 0xC0F0 +-#define ARM_CPU_PART_CORTEX_A7 0xC070 ++/* ++ * read_cpuid and read_cpuid_ext should only ever be called on machines that ++ * have cp15 so warn on other usages. ++ */ ++#define read_cpuid(reg) \ ++ ({ \ ++ WARN_ON_ONCE(1); \ ++ 0; \ ++ }) + +-#define ARM_CPU_XSCALE_ARCH_MASK 0xe000 +-#define ARM_CPU_XSCALE_ARCH_V1 0x2000 +-#define ARM_CPU_XSCALE_ARCH_V2 0x4000 +-#define ARM_CPU_XSCALE_ARCH_V3 0x6000 ++#define read_cpuid_ext(reg) read_cpuid(reg) ++ ++#endif /* ifdef CONFIG_CPU_CP15 / else */ + ++#ifdef CONFIG_CPU_CP15 + /* + * The CPU ID never changes at run time, so we might as well tell the + * compiler that it's constant. Use this function to read the CPU ID +@@ -92,6 +106,15 @@ static inline unsigned int __attribute_const__ read_cpuid_id(void) + return read_cpuid(CPUID_ID); + } + ++#else /* ifdef CONFIG_CPU_CP15 */ ++ ++static inline unsigned int __attribute_const__ read_cpuid_id(void) ++{ ++ return processor_id; ++} ++ ++#endif /* ifdef CONFIG_CPU_CP15 / else */ ++ + static inline unsigned int __attribute_const__ read_cpuid_implementor(void) + { + return (read_cpuid_id() & 0xFF000000) >> 24; +diff --git a/arch/arm/include/asm/glue-df.h b/arch/arm/include/asm/glue-df.h +index 8cacbcd..b6e9f2c 100644 +--- a/arch/arm/include/asm/glue-df.h ++++ b/arch/arm/include/asm/glue-df.h +@@ -18,12 +18,12 @@ + * ================ + * + * 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 ++ * 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 +@@ -39,19 +39,19 @@ + # endif + #endif + +-#ifdef CONFIG_CPU_ABRT_LV4T ++#ifdef CONFIG_CPU_ABRT_EV4 + # ifdef CPU_DABORT_HANDLER + # define MULTI_DABORT 1 + # else +-# define CPU_DABORT_HANDLER v4t_late_abort ++# define CPU_DABORT_HANDLER v4_early_abort + # endif + #endif + +-#ifdef CONFIG_CPU_ABRT_EV4 ++#ifdef CONFIG_CPU_ABRT_LV4T + # ifdef CPU_DABORT_HANDLER + # define MULTI_DABORT 1 + # else +-# define CPU_DABORT_HANDLER v4_early_abort ++# define CPU_DABORT_HANDLER v4t_late_abort + # endif + #endif + +@@ -63,19 +63,19 @@ + # endif + #endif + +-#ifdef CONFIG_CPU_ABRT_EV5TJ ++#ifdef CONFIG_CPU_ABRT_EV5T + # ifdef CPU_DABORT_HANDLER + # define MULTI_DABORT 1 + # else +-# define CPU_DABORT_HANDLER v5tj_early_abort ++# define CPU_DABORT_HANDLER v5t_early_abort + # endif + #endif + +-#ifdef CONFIG_CPU_ABRT_EV5T ++#ifdef CONFIG_CPU_ABRT_EV5TJ + # ifdef CPU_DABORT_HANDLER + # define MULTI_DABORT 1 + # else +-# define CPU_DABORT_HANDLER v5t_early_abort ++# define CPU_DABORT_HANDLER v5tj_early_abort + # endif + #endif + +diff --git a/arch/arm/kernel/head-common.S b/arch/arm/kernel/head-common.S +index 854bd22..5b391a6 100644 +--- a/arch/arm/kernel/head-common.S ++++ b/arch/arm/kernel/head-common.S +@@ -98,8 +98,9 @@ __mmap_switched: + str r9, [r4] @ Save processor ID + str r1, [r5] @ Save machine type + str r2, [r6] @ Save atags pointer +- bic r4, r0, #CR_A @ Clear 'A' bit +- stmia r7, {r0, r4} @ Save control register values ++ cmp r7, #0 ++ bicne r4, r0, #CR_A @ Clear 'A' bit ++ stmneia r7, {r0, r4} @ Save control register values + b start_kernel + ENDPROC(__mmap_switched) + +@@ -113,7 +114,11 @@ __mmap_switched_data: + .long processor_id @ r4 + .long __machine_arch_type @ r5 + .long __atags_pointer @ r6 ++#ifdef CONFIG_CPU_CP15 + .long cr_alignment @ r7 ++#else ++ .long 0 @ r7 ++#endif + .long init_thread_union + THREAD_START_SP @ sp + .size __mmap_switched_data, . - __mmap_switched_data + +diff --git a/arch/arm/kernel/head-nommu.S b/arch/arm/kernel/head-nommu.S +index 2c228a0..6a2e09c 100644 +--- a/arch/arm/kernel/head-nommu.S ++++ b/arch/arm/kernel/head-nommu.S +@@ -32,15 +32,21 @@ + * numbers for r1. + * + */ +- .arm + + __HEAD ++ ++#ifdef CONFIG_CPU_THUMBONLY ++ .thumb ++ENTRY(stext) ++#else ++ .arm + ENTRY(stext) + + THUMB( adr r9, BSYM(1f) ) @ Kernel is always entered in ARM. + THUMB( bx r9 ) @ If this is a Thumb-2 kernel, + THUMB( .thumb ) @ switch to Thumb now. + THUMB(1: ) ++#endif + + setmode PSR_F_BIT | PSR_I_BIT | SVC_MODE, r9 @ ensure svc mode + @ and irqs disabled +diff --git a/arch/arm/kernel/setup.c b/arch/arm/kernel/setup.c +index 3f6cbb2..1cc9e17 100644 +--- a/arch/arm/kernel/setup.c ++++ b/arch/arm/kernel/setup.c +@@ -291,10 +291,10 @@ static int cpu_has_aliasing_icache(unsigned int arch) + + static void __init cacheid_init(void) + { +- unsigned int cachetype = read_cpuid_cachetype(); + unsigned int arch = cpu_architecture(); + + if (arch >= CPU_ARCH_ARMv6) { ++ unsigned int cachetype = read_cpuid_cachetype(); + if ((cachetype & (7 << 29)) == 4 << 29) { + /* ARMv7 register format */ + arch = CPU_ARCH_ARMv7; +diff --git a/arch/arm/kernel/smp_scu.c b/arch/arm/kernel/smp_scu.c +index 45eac87..5bc1a63 100644 +--- a/arch/arm/kernel/smp_scu.c ++++ b/arch/arm/kernel/smp_scu.c +@@ -41,7 +41,7 @@ void scu_enable(void __iomem *scu_base) + + #ifdef CONFIG_ARM_ERRATA_764369 + /* Cortex-A9 only */ +- if ((read_cpuid(CPUID_ID) & 0xff0ffff0) == 0x410fc090) { ++ if ((read_cpuid_id() & 0xff0ffff0) == 0x410fc090) { + scu_ctrl = __raw_readl(scu_base + 0x30); + if (!(scu_ctrl & 1)) + __raw_writel(scu_ctrl | 0x1, scu_base + 0x30); +diff --git a/arch/arm/mach-omap2/id.c b/arch/arm/mach-omap2/id.c +index 8a68f1e..577298e 100644 +--- a/arch/arm/mach-omap2/id.c ++++ b/arch/arm/mach-omap2/id.c +@@ -300,7 +300,7 @@ void __init omap3xxx_check_revision(void) + * If the processor type is Cortex-A8 and the revision is 0x0 + * it means its Cortex r0p0 which is 3430 ES1.0. + */ +- cpuid = read_cpuid(CPUID_ID); ++ cpuid = read_cpuid_id(); + if ((((cpuid >> 4) & 0xfff) == 0xc08) && ((cpuid & 0xf) == 0x0)) { + omap_revision = OMAP3430_REV_ES1_0; + cpu_rev = "1.0"; +@@ -460,7 +460,7 @@ void __init omap4xxx_check_revision(void) + * Use ARM register to detect the correct ES version + */ + if (!rev && (hawkeye != 0xb94e) && (hawkeye != 0xb975)) { +- idcode = read_cpuid(CPUID_ID); ++ idcode = read_cpuid_id(); + rev = (idcode & 0xf) - 1; + } + +diff --git a/arch/arm/mach-omap2/omap-smp.c b/arch/arm/mach-omap2/omap-smp.c +index d972721..7f5626d 100644 +--- a/arch/arm/mach-omap2/omap-smp.c ++++ b/arch/arm/mach-omap2/omap-smp.c +@@ -209,7 +209,7 @@ static void __init omap4_smp_init_cpus(void) + unsigned int i = 0, ncores = 1, cpu_id; + + /* Use ARM cpuid check here, as SoC detection will not work so early */ +- cpu_id = read_cpuid(CPUID_ID) & CPU_MASK; ++ cpu_id = read_cpuid_id() & CPU_MASK; + if (cpu_id == CPU_CORTEX_A9) { + /* + * Currently we can't call ioremap here because +diff --git a/arch/arm/mm/Kconfig b/arch/arm/mm/Kconfig +index 025d173..cb812a1 100644 +--- a/arch/arm/mm/Kconfig ++++ b/arch/arm/mm/Kconfig +@@ -397,6 +397,13 @@ config CPU_V7 + select CPU_PABRT_V7 + select CPU_TLB_V7 if MMU + ++config CPU_THUMBONLY ++ bool ++ # There are no CPUs available with MMU that don't implement an ARM ISA: ++ depends on !MMU ++ help ++ Select this if your CPU doesn't support the 32 bit ARM instructions. ++ + # Figure out what processor architecture version we should be using. + # This defines the compiler instruction set which depends on the machine type. + config CPU_32v3 +@@ -608,7 +615,7 @@ config ARCH_DMA_ADDR_T_64BIT + bool + + config ARM_THUMB +- bool "Support Thumb user binaries" ++ bool "Support Thumb user binaries" if !CPU_THUMBONLY + depends on CPU_ARM720T || CPU_ARM740T || CPU_ARM920T || CPU_ARM922T || CPU_ARM925T || CPU_ARM926T || CPU_ARM940T || CPU_ARM946E || CPU_ARM1020 || CPU_ARM1020E || CPU_ARM1022 || CPU_ARM1026 || CPU_XSCALE || CPU_XSC3 || CPU_MOHAWK || CPU_V6 || CPU_V6K || CPU_V7 || CPU_FEROCEON + default y + help +diff --git a/arch/arm/mm/alignment.c b/arch/arm/mm/alignment.c +index db26e2e..6f4585b 100644 +--- a/arch/arm/mm/alignment.c ++++ b/arch/arm/mm/alignment.c +@@ -961,12 +961,14 @@ static int __init alignment_init(void) + return -ENOMEM; + #endif + ++#ifdef CONFIG_CPU_CP15 + if (cpu_is_v6_unaligned()) { + cr_alignment &= ~CR_A; + cr_no_alignment &= ~CR_A; + set_cr(cr_alignment); + ai_usermode = safe_usermode(ai_usermode, false); + } ++#endif + + hook_fault_code(FAULT_CODE_ALIGNMENT, do_alignment, SIGBUS, BUS_ADRALN, + "alignment exception"); +diff --git a/arch/arm/mm/mmu.c b/arch/arm/mm/mmu.c +index e95a996..c6d45c8 100644 +--- a/arch/arm/mm/mmu.c ++++ b/arch/arm/mm/mmu.c +@@ -112,6 +112,7 @@ static struct cachepolicy cache_policies[] __initdata = { + } + }; + ++#ifdef CONFIG_CPU_CP15 + /* + * These are useful for identifying cache coherency + * problems by allowing the cache or the cache and +@@ -210,6 +211,22 @@ void adjust_cr(unsigned long mask, unsigned long set) + } + #endif + ++#else /* ifdef CONFIG_CPU_CP15 */ ++ ++static int __init early_cachepolicy(char *p) ++{ ++ pr_warning("cachepolicy kernel parameter not supported without cp15\n"); ++} ++early_param("cachepolicy", early_cachepolicy); ++ ++static int __init noalign_setup(char *__unused) ++{ ++ pr_warning("noalign kernel parameter not supported without cp15\n"); ++} ++__setup("noalign", noalign_setup); ++ ++#endif /* ifdef CONFIG_CPU_CP15 / else */ ++ + #define PROT_PTE_DEVICE L_PTE_PRESENT|L_PTE_YOUNG|L_PTE_DIRTY|L_PTE_XN + #define PROT_SECT_DEVICE PMD_TYPE_SECT|PMD_SECT_AP_WRITE + |