Hi James, On Wed, Dec 06, 2017 at 07:01:34PM +0000, James Morse wrote: > Today the arm64 arch code allocates an extra IRQ stack per-cpu. If we > also have SDEI and VMAP stacks we need two extra per-cpu VMAP stacks. > > Move the VMAP stack allocation out to a helper in a new header file. > This avoids missing THREADINFO_GFP, or getting the all-important alignment > wrong. > > Signed-off-by: James Morse <james.morse@xxxxxxx> > Reviewed-by: Catalin Marinas <catalin.marinas@xxxxxxx> > --- > Changes since v4: > * Added gfp.h include > > Changes since v3: > * Added BUILD_BUG() instead of a spooky link error > > arch/arm64/include/asm/vmap_stack.h | 26 ++++++++++++++++++++++++++ > arch/arm64/kernel/irq.c | 13 ++----------- > 2 files changed, 28 insertions(+), 11 deletions(-) > create mode 100644 arch/arm64/include/asm/vmap_stack.h > > diff --git a/arch/arm64/include/asm/vmap_stack.h b/arch/arm64/include/asm/vmap_stack.h > new file mode 100644 > index 000000000000..5465e4e65987 > --- /dev/null > +++ b/arch/arm64/include/asm/vmap_stack.h > @@ -0,0 +1,26 @@ > +// SPDX-License-Identifier: GPL-2.0 > +// Copyright (C) 2017 Arm Ltd. > +#ifndef __ASM_VMAP_STACK_H > +#define __ASM_VMAP_STACK_H > + > +#include <linux/gfp.h> > +#include <linux/vmalloc.h> > +#include <asm/memory.h> > +#include <asm/pgtable.h> > +#include <asm/thread_info.h> I think we also need: #include <linux/bug.h> // for BUILD_BUG_ON() #incldue <linux/kconfig.h> // for IS_ENABLED() Otherwise, this looks good to me. With those includes folded in: Reviewed-by: Mark Rutland <mark.rutland@xxxxxxx> Thanks, Mark. > + > +/* > + * To ensure that VMAP'd stack overflow detection works correctly, all VMAP'd > + * stacks need to have the same alignment. > + */ > +static inline unsigned long *arch_alloc_vmap_stack(size_t stack_size, int node) > +{ > + BUILD_BUG_ON(!IS_ENABLED(CONFIG_VMAP_STACK)); > + > + return __vmalloc_node_range(stack_size, THREAD_ALIGN, > + VMALLOC_START, VMALLOC_END, > + THREADINFO_GFP, PAGE_KERNEL, 0, node, > + __builtin_return_address(0)); > +} > + > +#endif /* __ASM_VMAP_STACK_H */ > diff --git a/arch/arm64/kernel/irq.c b/arch/arm64/kernel/irq.c > index 713561e5bcab..60e5fc661f74 100644 > --- a/arch/arm64/kernel/irq.c > +++ b/arch/arm64/kernel/irq.c > @@ -29,6 +29,7 @@ > #include <linux/irqchip.h> > #include <linux/seq_file.h> > #include <linux/vmalloc.h> > +#include <asm/vmap_stack.h> > > unsigned long irq_err_count; > > @@ -58,17 +59,7 @@ static void init_irq_stacks(void) > unsigned long *p; > > for_each_possible_cpu(cpu) { > - /* > - * To ensure that VMAP'd stack overflow detection works > - * correctly, the IRQ stacks need to have the same > - * alignment as other stacks. > - */ > - p = __vmalloc_node_range(IRQ_STACK_SIZE, THREAD_ALIGN, > - VMALLOC_START, VMALLOC_END, > - THREADINFO_GFP, PAGE_KERNEL, > - 0, cpu_to_node(cpu), > - __builtin_return_address(0)); > - > + p = arch_alloc_vmap_stack(IRQ_STACK_SIZE, cpu_to_node(cpu)); > per_cpu(irq_stack_ptr, cpu) = p; > } > } > -- > 2.15.0 > > -- > To unsubscribe from this list: send the line "unsubscribe devicetree" in > the body of a message to majordomo@xxxxxxxxxxxxxxx > More majordomo info at http://vger.kernel.org/majordomo-info.html -- To unsubscribe from this list: send the line "unsubscribe devicetree" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html