[PATCH] ARM: earlier initialization of vectors page

Nicolas Pitre nico at fluxnic.net
Fri Jan 20 16:27:25 EST 2012


On Fri, 20 Jan 2012, Russell King - ARM Linux wrote:

> Initialize the contents of the vectors page immediately after we
> allocate the page, but before we map it.  This avoids any possible
> aliases with other mappings which may need to be flushed after the
> page has been mapped irrespective of the cache type.
> 
> We follow this later with a flush_cache_all() after all static memory
> mappings have been initialized, which ensures that this is safe from
> any cache effects.
> 
> Tested-by: Catalin Marinas <catalin.marinas at arm.com>
> Reviewed-by: Catalin Marinas <catalin.marinas at arm.com>
> Signed-off-by: Russell King <rmk+kernel at arm.linux.org.uk>

Acked-by: Nicolas Pitre <nico at linaro.org>

Having the data abort handlers available early will certainly help my 
patch to allow debugging across devicemaps_init().

> ---
>  arch/arm/include/asm/traps.h |    2 +-
>  arch/arm/kernel/setup.c      |    1 -
>  arch/arm/kernel/traps.c      |   10 ++++------
>  arch/arm/mm/mmu.c            |    7 +++++--
>  4 files changed, 10 insertions(+), 10 deletions(-)
> 
> diff --git a/arch/arm/include/asm/traps.h b/arch/arm/include/asm/traps.h
> index 5b29a66..f555bb3 100644
> --- a/arch/arm/include/asm/traps.h
> +++ b/arch/arm/include/asm/traps.h
> @@ -46,7 +46,7 @@ static inline int in_exception_text(unsigned long ptr)
>  	return in ? : __in_irqentry_text(ptr);
>  }
>  
> -extern void __init early_trap_init(void);
> +extern void __init early_trap_init(void *);
>  extern void dump_backtrace_entry(unsigned long where, unsigned long from, unsigned long frame);
>  extern void ptrace_break(struct task_struct *tsk, struct pt_regs *regs);
>  
> diff --git a/arch/arm/kernel/setup.c b/arch/arm/kernel/setup.c
> index 129fbd5..9b65cb4 100644
> --- a/arch/arm/kernel/setup.c
> +++ b/arch/arm/kernel/setup.c
> @@ -961,7 +961,6 @@ void __init setup_arch(char **cmdline_p)
>  	conswitchp = &dummy_con;
>  #endif
>  #endif
> -	early_trap_init();
>  
>  	if (mdesc->init_early)
>  		mdesc->init_early();
> diff --git a/arch/arm/kernel/traps.c b/arch/arm/kernel/traps.c
> index 99a5727..be15daf 100644
> --- a/arch/arm/kernel/traps.c
> +++ b/arch/arm/kernel/traps.c
> @@ -781,18 +781,16 @@ static void __init kuser_get_tls_init(unsigned long vectors)
>  		memcpy((void *)vectors + 0xfe0, (void *)vectors + 0xfe8, 4);
>  }
>  
> -void __init early_trap_init(void)
> +void __init early_trap_init(void *vectors_base)
>  {
> -#if defined(CONFIG_CPU_USE_DOMAINS)
> -	unsigned long vectors = CONFIG_VECTORS_BASE;
> -#else
> -	unsigned long vectors = (unsigned long)vectors_page;
> -#endif
> +	unsigned long vectors = (unsigned long)vectors_base;
>  	extern char __stubs_start[], __stubs_end[];
>  	extern char __vectors_start[], __vectors_end[];
>  	extern char __kuser_helper_start[], __kuser_helper_end[];
>  	int kuser_sz = __kuser_helper_end - __kuser_helper_start;
>  
> +	vectors_page = vectors_base;
> +
>  	/*
>  	 * Copy the vectors, stubs and kuser helpers (in entry-armv.S)
>  	 * into the vector page, mapped at 0xffff0000, and ensure these
> diff --git a/arch/arm/mm/mmu.c b/arch/arm/mm/mmu.c
> index 94c5a0c..c1263ad 100644
> --- a/arch/arm/mm/mmu.c
> +++ b/arch/arm/mm/mmu.c
> @@ -997,11 +997,14 @@ static void __init devicemaps_init(struct machine_desc *mdesc)
>  {
>  	struct map_desc map;
>  	unsigned long addr;
> +	void *vectors;
>  
>  	/*
>  	 * Allocate the vector page early.
>  	 */
> -	vectors_page = early_alloc(PAGE_SIZE);
> +	vectors = early_alloc(PAGE_SIZE);
> +
> +	early_trap_init(vectors);
>  
>  	for (addr = VMALLOC_START; addr; addr += PMD_SIZE)
>  		pmd_clear(pmd_off_k(addr));
> @@ -1041,7 +1044,7 @@ static void __init devicemaps_init(struct machine_desc *mdesc)
>  	 * location (0xffff0000).  If we aren't using high-vectors, also
>  	 * create a mapping at the low-vectors virtual address.
>  	 */
> -	map.pfn = __phys_to_pfn(virt_to_phys(vectors_page));
> +	map.pfn = __phys_to_pfn(virt_to_phys(vectors));
>  	map.virtual = 0xffff0000;
>  	map.length = PAGE_SIZE;
>  	map.type = MT_HIGH_VECTORS;
> -- 
> 1.7.4.4
> 
> 
> _______________________________________________
> linux-arm-kernel mailing list
> linux-arm-kernel at lists.infradead.org
> http://lists.infradead.org/mailman/listinfo/linux-arm-kernel
> 



More information about the linux-arm-kernel mailing list