/* * Copyright 2017, Data61 * Commonwealth Scientific and Industrial Research Organisation (CSIRO) * ABN 41 687 119 230. * * This software may be distributed and modified according to the terms of * the GNU General Public License version 2. Note that NO WARRANTY is provided. * See "LICENSE_GPLv2.txt" for details. * * @TAG(DATA61_GPL) */ #include #include #ifdef ENABLE_SMP_SUPPORT nodeInfo_t node_info[CONFIG_MAX_NUM_NODES] ALIGN(L1_CACHE_LINE_SIZE) VISIBLE; char nodeSkimScratch[CONFIG_MAX_NUM_NODES][sizeof(nodeInfo_t)] ALIGN(L1_CACHE_LINE_SIZE); extern char kernel_stack_alloc[CONFIG_MAX_NUM_NODES][BIT(CONFIG_KERNEL_STACK_BITS)]; BOOT_CODE void mode_init_tls(cpu_id_t cpu_index) { node_info[cpu_index].stackTop = kernel_stack_alloc[cpu_index + 1]; node_info[cpu_index].irqStack = &x64KSIRQStack[cpu_index][0]; node_info[cpu_index].index = cpu_index; x86_wrmsr(IA32_KERNEL_GS_BASE_MSR, (word_t)&node_info[cpu_index]); swapgs(); } #endif /* ENABLE_SMP_SUPPORT */