1b2441318SGreg Kroah-Hartman /* SPDX-License-Identifier: GPL-2.0 */ 2b8b572e1SStephen Rothwell #ifndef _ASM_POWERPC_SECTIONS_H 3b8b572e1SStephen Rothwell #define _ASM_POWERPC_SECTIONS_H 4b8b572e1SStephen Rothwell #ifdef __KERNEL__ 5b8b572e1SStephen Rothwell 62d291e90SJames Bottomley #include <linux/elf.h> 72d291e90SJames Bottomley #include <linux/uaccess.h> 86f07048cSMichael Ellerman 90dc690e4SChristophe Leroy #ifdef CONFIG_HAVE_FUNCTION_DESCRIPTORS 100dc690e4SChristophe Leroy typedef struct func_desc func_desc_t; 110dc690e4SChristophe Leroy #endif 120dc690e4SChristophe Leroy 13b8b572e1SStephen Rothwell #include <asm-generic/sections.h> 14b8b572e1SStephen Rothwell 157aa5b018SNaveen N. Rao extern char __head_end[]; 16b150a4d1SMichael Ellerman extern char __srwx_boundary[]; 17*6355b468SNaveen N Rao extern char __exittext_begin[], __exittext_end[]; 187aa5b018SNaveen N. Rao 19eb316ae7SMichael Ellerman /* Patch sites */ 20eb316ae7SMichael Ellerman extern s32 patch__call_flush_branch_caches1; 21eb316ae7SMichael Ellerman extern s32 patch__call_flush_branch_caches2; 22eb316ae7SMichael Ellerman extern s32 patch__call_flush_branch_caches3; 23eb316ae7SMichael Ellerman extern s32 patch__flush_count_cache_return; 24eb316ae7SMichael Ellerman extern s32 patch__flush_link_stack_return; 25eb316ae7SMichael Ellerman extern s32 patch__call_kvm_flush_link_stack; 26eb316ae7SMichael Ellerman extern s32 patch__call_kvm_flush_link_stack_p9; 27eb316ae7SMichael Ellerman extern s32 patch__memset_nocache, patch__memcpy_nocache; 28eb316ae7SMichael Ellerman 29eb316ae7SMichael Ellerman extern long flush_branch_caches; 30eb316ae7SMichael Ellerman extern long kvm_flush_link_stack; 31eb316ae7SMichael Ellerman 32b8b572e1SStephen Rothwell #ifdef __powerpc64__ 33b8b572e1SStephen Rothwell 34429d2e83SMahesh Salgaonkar extern char __start_interrupts[]; 35d715e433SAnton Blanchard extern char __end_interrupts[]; 36b8b572e1SStephen Rothwell 37bd3524feSNicholas Piggin #ifdef CONFIG_PPC_POWERNV 38bd3524feSNicholas Piggin extern char start_real_trampolines[]; 39bd3524feSNicholas Piggin extern char end_real_trampolines[]; 40bd3524feSNicholas Piggin extern char start_virt_trampolines[]; 41bd3524feSNicholas Piggin extern char end_virt_trampolines[]; 42bd3524feSNicholas Piggin #endif 43bd3524feSNicholas Piggin 44a3ad84daSAlan Modra /* 45a3ad84daSAlan Modra * This assumes the kernel is never compiled -mcmodel=small or 46a3ad84daSAlan Modra * the total .toc is always less than 64k. 47a3ad84daSAlan Modra */ kernel_toc_addr(void)48a5cab83cSMichael Ellermanstatic inline unsigned long kernel_toc_addr(void) 49a5cab83cSMichael Ellerman { 507e3a68beSNicholas Piggin #ifdef CONFIG_PPC_KERNEL_PCREL 517e3a68beSNicholas Piggin BUILD_BUG(); 527e3a68beSNicholas Piggin return -1UL; 537e3a68beSNicholas Piggin #else 54a3ad84daSAlan Modra unsigned long toc_ptr; 55a5cab83cSMichael Ellerman 56a3ad84daSAlan Modra asm volatile("mr %0, 2" : "=r" (toc_ptr)); 57a3ad84daSAlan Modra return toc_ptr; 587e3a68beSNicholas Piggin #endif 59a5cab83cSMichael Ellerman } 60a5cab83cSMichael Ellerman overlaps_interrupt_vector_text(unsigned long start,unsigned long end)61429d2e83SMahesh Salgaonkarstatic inline int overlaps_interrupt_vector_text(unsigned long start, 62429d2e83SMahesh Salgaonkar unsigned long end) 63429d2e83SMahesh Salgaonkar { 64429d2e83SMahesh Salgaonkar unsigned long real_start, real_end; 65429d2e83SMahesh Salgaonkar real_start = __start_interrupts - _stext; 66429d2e83SMahesh Salgaonkar real_end = __end_interrupts - _stext; 67429d2e83SMahesh Salgaonkar 68429d2e83SMahesh Salgaonkar return start < (unsigned long)__va(real_end) && 69429d2e83SMahesh Salgaonkar (unsigned long)__va(real_start) < end; 70429d2e83SMahesh Salgaonkar } 71429d2e83SMahesh Salgaonkar overlaps_kernel_text(unsigned long start,unsigned long end)72549e8152SPaul Mackerrasstatic inline int overlaps_kernel_text(unsigned long start, unsigned long end) 73549e8152SPaul Mackerras { 74549e8152SPaul Mackerras return start < (unsigned long)__init_end && 75549e8152SPaul Mackerras (unsigned long)_stext < end; 76549e8152SPaul Mackerras } 77549e8152SPaul Mackerras 78f3993a03SNaveen N Rao #else kernel_toc_addr(void)79f3993a03SNaveen N Raostatic inline unsigned long kernel_toc_addr(void) { BUILD_BUG(); return -1UL; } 80b8b572e1SStephen Rothwell #endif 81b8b572e1SStephen Rothwell 82b8b572e1SStephen Rothwell #endif /* __KERNEL__ */ 83b8b572e1SStephen Rothwell #endif /* _ASM_POWERPC_SECTIONS_H */ 84