1596b0474SMasahiro Yamada/* 2596b0474SMasahiro Yamada * Common module linker script, always used when linking a module. 3596b0474SMasahiro Yamada * Archs are free to supply their own linker scripts. ld will 4596b0474SMasahiro Yamada * combine them automatically. 5596b0474SMasahiro Yamada */ 6*28aad1c2SSami Tolvanen#ifdef CONFIG_CFI_CLANG 7*28aad1c2SSami Tolvanen# include <asm/page.h> 8*28aad1c2SSami Tolvanen# define ALIGN_CFI ALIGN(PAGE_SIZE) 9*28aad1c2SSami Tolvanen# define SANITIZER_DISCARDS *(.eh_frame) 10*28aad1c2SSami Tolvanen#else 11*28aad1c2SSami Tolvanen# define ALIGN_CFI 12*28aad1c2SSami Tolvanen# define SANITIZER_DISCARDS 13*28aad1c2SSami Tolvanen#endif 14*28aad1c2SSami Tolvanen 15596b0474SMasahiro YamadaSECTIONS { 16596b0474SMasahiro Yamada /DISCARD/ : { 17596b0474SMasahiro Yamada *(.discard) 18596b0474SMasahiro Yamada *(.discard.*) 19*28aad1c2SSami Tolvanen SANITIZER_DISCARDS 20596b0474SMasahiro Yamada } 21596b0474SMasahiro Yamada 22596b0474SMasahiro Yamada __ksymtab 0 : { *(SORT(___ksymtab+*)) } 23596b0474SMasahiro Yamada __ksymtab_gpl 0 : { *(SORT(___ksymtab_gpl+*)) } 24596b0474SMasahiro Yamada __kcrctab 0 : { *(SORT(___kcrctab+*)) } 25596b0474SMasahiro Yamada __kcrctab_gpl 0 : { *(SORT(___kcrctab_gpl+*)) } 26596b0474SMasahiro Yamada 27596b0474SMasahiro Yamada .init_array 0 : ALIGN(8) { *(SORT(.init_array.*)) *(.init_array) } 28596b0474SMasahiro Yamada 29596b0474SMasahiro Yamada __jump_table 0 : ALIGN(8) { KEEP(*(__jump_table)) } 30dd277622SSami Tolvanen 31dd277622SSami Tolvanen __patchable_function_entries : { *(__patchable_function_entries) } 32dd277622SSami Tolvanen 336a3193cdSSean Christopherson#ifdef CONFIG_LTO_CLANG 34dd277622SSami Tolvanen /* 35dd277622SSami Tolvanen * With CONFIG_LTO_CLANG, LLD always enables -fdata-sections and 36dd277622SSami Tolvanen * -ffunction-sections, which increases the size of the final module. 37dd277622SSami Tolvanen * Merge the split sections in the final binary. 38dd277622SSami Tolvanen */ 39dd277622SSami Tolvanen .bss : { 40dd277622SSami Tolvanen *(.bss .bss.[0-9a-zA-Z_]*) 41dd277622SSami Tolvanen *(.bss..L*) 42dd277622SSami Tolvanen } 43dd277622SSami Tolvanen 44dd277622SSami Tolvanen .data : { 45dd277622SSami Tolvanen *(.data .data.[0-9a-zA-Z_]*) 46dd277622SSami Tolvanen *(.data..L*) 47dd277622SSami Tolvanen } 48dd277622SSami Tolvanen 49dd277622SSami Tolvanen .rodata : { 50dd277622SSami Tolvanen *(.rodata .rodata.[0-9a-zA-Z_]*) 51dd277622SSami Tolvanen *(.rodata..L*) 52dd277622SSami Tolvanen } 53dd277622SSami Tolvanen 54*28aad1c2SSami Tolvanen /* 55*28aad1c2SSami Tolvanen * With CONFIG_CFI_CLANG, we assume __cfi_check is at the beginning 56*28aad1c2SSami Tolvanen * of the .text section, and is aligned to PAGE_SIZE. 57*28aad1c2SSami Tolvanen */ 58*28aad1c2SSami Tolvanen .text : ALIGN_CFI { 59*28aad1c2SSami Tolvanen *(.text.__cfi_check) 60*28aad1c2SSami Tolvanen *(.text .text.[0-9a-zA-Z_]* .text..L.cfi*) 61*28aad1c2SSami Tolvanen } 626a3193cdSSean Christopherson#endif 63596b0474SMasahiro Yamada} 64596b0474SMasahiro Yamada 65596b0474SMasahiro Yamada/* bring in arch-specific sections */ 66596b0474SMasahiro Yamada#include <asm/module.lds.h> 67