mirror of
				git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
				synced 2025-09-04 20:19:47 +08:00 
			
		
		
		
	 969de0988b
			
		
	
	
		969de0988b
		
	
	
	
	
		
			
			Commitbe7635e728("arch, ftrace: for KASAN put hard/soft IRQ entries into separate sections") added a new linker section, SOFTIRQENTRY_TEXT, to the linker scripts for most architectures. It didn't add it to any of the linker scripts for the m68k architecture. This was not really a problem because it is only defined if either of CONFIG_FUNCTION_GRAPH_TRACER or CONFIG_KASAN are enabled - which can never be true for m68k. However commit229a718605("irq: Make the irqentry text section unconditional") means that SOFTIRQENTRY_TEXT is now always defined. So on m68k we now end up with a separate ELF section for .softirqentry.text instead of it being part of the .text section. On some m68k targets in some configurations this can also cause a fatal link error: LD vmlinux /usr/local/bin/../m68k-uclinux/bin/ld.real: section .softirqentry.text loaded at [0000000010de10c0,0000000010de12dd] overlaps section .rodata loaded at [0000000010de10c0,0000000010e0fd67] To fix add in the missing SOFTIRQENTRY_TEXT section into the m68k linker scripts. I noticed that m68k is also missing the IRQENTRY_TEXT section, so this patch also adds an entry for that too. Signed-off-by: Greg Ungerer <gerg@linux-m68k.org>
		
			
				
	
	
		
			68 lines
		
	
	
		
			1.2 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
			
		
		
	
	
			68 lines
		
	
	
		
			1.2 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
| /* SPDX-License-Identifier: GPL-2.0 */
 | |
| /* ld script to make m68k Linux kernel */
 | |
| 
 | |
| #include <asm-generic/vmlinux.lds.h>
 | |
| #include <asm/page.h>
 | |
| #include <asm/thread_info.h>
 | |
| 
 | |
| OUTPUT_FORMAT("elf32-m68k", "elf32-m68k", "elf32-m68k")
 | |
| OUTPUT_ARCH(m68k)
 | |
| ENTRY(_start)
 | |
| jiffies = jiffies_64 + 4;
 | |
| SECTIONS
 | |
| {
 | |
|   . = 0x1000;
 | |
|   _text = .;			/* Text and read-only data */
 | |
|   .text : {
 | |
| 	HEAD_TEXT
 | |
| 	TEXT_TEXT
 | |
| 	IRQENTRY_TEXT
 | |
| 	SOFTIRQENTRY_TEXT
 | |
| 	SCHED_TEXT
 | |
| 	CPUIDLE_TEXT
 | |
| 	LOCK_TEXT
 | |
| 	*(.fixup)
 | |
| 	*(.gnu.warning)
 | |
| 	} :text = 0x4e75
 | |
| 
 | |
|   _etext = .;			/* End of text section */
 | |
| 
 | |
|   EXCEPTION_TABLE(16)
 | |
| 
 | |
|   _sdata = .;			/* Start of data section */
 | |
| 
 | |
|   RODATA
 | |
| 
 | |
|   RW_DATA_SECTION(16, PAGE_SIZE, THREAD_SIZE)
 | |
| 
 | |
|   BSS_SECTION(0, 0, 0)
 | |
| 
 | |
|   _edata = .;			/* End of data section */
 | |
| 
 | |
|   /* will be freed after init */
 | |
|   . = ALIGN(PAGE_SIZE);		/* Init code and data */
 | |
|   __init_begin = .;
 | |
|   INIT_TEXT_SECTION(PAGE_SIZE) :data
 | |
|   INIT_DATA_SECTION(16)
 | |
|   .m68k_fixup : {
 | |
| 	__start_fixup = .;
 | |
| 	*(.m68k_fixup)
 | |
| 	__stop_fixup = .;
 | |
|   }
 | |
|   NOTES
 | |
|   .init_end : {
 | |
| 	/* This ALIGN be in a section so that _end is at the end of the
 | |
| 	   load segment. */
 | |
| 	. = ALIGN(PAGE_SIZE);
 | |
| 	__init_end = .;
 | |
|   }
 | |
| 
 | |
|   _end = . ;
 | |
| 
 | |
|   STABS_DEBUG
 | |
|   .comment 0 : { *(.comment) }
 | |
| 
 | |
|   /* Sections to be discarded */
 | |
|   DISCARDS
 | |
| }
 |