6db4831e98
Android 14
41 lines
900 B
C
41 lines
900 B
C
// SPDX-License-Identifier: GPL-2.0
|
|
/*
|
|
* Shadow Call Stack support.
|
|
*
|
|
* Copyright (C) 2019 Google LLC
|
|
*/
|
|
|
|
#include <linux/percpu.h>
|
|
#include <linux/vmalloc.h>
|
|
#include <asm/pgtable.h>
|
|
#include <asm/scs.h>
|
|
|
|
DEFINE_PER_CPU(unsigned long *, irq_shadow_call_stack_ptr);
|
|
|
|
#ifndef CONFIG_SHADOW_CALL_STACK_VMAP
|
|
DEFINE_PER_CPU(unsigned long [SCS_SIZE/sizeof(long)], irq_shadow_call_stack)
|
|
__aligned(SCS_SIZE);
|
|
#endif
|
|
|
|
void scs_init_irq(void)
|
|
{
|
|
int cpu;
|
|
|
|
for_each_possible_cpu(cpu) {
|
|
#ifdef CONFIG_SHADOW_CALL_STACK_VMAP
|
|
unsigned long *p;
|
|
|
|
p = __vmalloc_node_range(PAGE_SIZE, SCS_SIZE,
|
|
VMALLOC_START, VMALLOC_END,
|
|
GFP_SCS, PAGE_KERNEL,
|
|
0, cpu_to_node(cpu),
|
|
__builtin_return_address(0));
|
|
|
|
per_cpu(irq_shadow_call_stack_ptr, cpu) = p;
|
|
#else
|
|
per_cpu(irq_shadow_call_stack_ptr, cpu) =
|
|
per_cpu(irq_shadow_call_stack, cpu);
|
|
#endif /* CONFIG_SHADOW_CALL_STACK_VMAP */
|
|
}
|
|
}
|