mirror of
				git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
				synced 2025-09-04 20:19:47 +08:00 
			
		
		
		
	 b5effd3815
			
		
	
	
		b5effd3815
		
	
	
	
	
		
			
			The kbuild test robot reported this build failure on a number
of architectures:
 >         make.cross ARCH=arm
 >    lib/lib.a(bug.o): In function `find_bug':
 > >> lib/bug.c:135: undefined reference to `__start___bug_table'
 > >> lib/bug.c:135: undefined reference to `__stop___bug_table'
Caused by:
  19d436268d ("debug: Add _ONCE() logic to report_bug()")
Which moved the BUG_TABLE from RO_DATA_SECTION() to RW_DATA_SECTION(),
but a number of architectures don't use RW_DATA_SECTION(), so they
ended up with no __bug_table[] ...
Ideally all those would use RW_DATA_SECTION() in their linker scripts,
but that's for another day.
Signed-off-by: Peter Zijlstra <peterz@infradead.org>
Cc: Linus Torvalds <torvalds@linux-foundation.org>
Cc: Thomas Gleixner <tglx@linutronix.de>
Cc: kbuild test robot <fengguang.wu@intel.com>
Cc: kbuild-all@01.org
Cc: tipbuild@zytor.com
Link: http://lkml.kernel.org/r/20170330154927.o6qmgfp4bdhrajbm@hirez.programming.kicks-ass.net
Signed-off-by: Ingo Molnar <mingo@kernel.org>
		
	
			
		
			
				
	
	
		
			161 lines
		
	
	
		
			2.4 KiB
		
	
	
	
		
			ArmAsm
		
	
	
	
	
	
			
		
		
	
	
			161 lines
		
	
	
		
			2.4 KiB
		
	
	
	
		
			ArmAsm
		
	
	
	
	
	
| /*
 | |
|  * ld script for the c6x kernel
 | |
|  *
 | |
|  *  Copyright (C) 2010, 2011 Texas Instruments Incorporated
 | |
|  *  Mark Salter <msalter@redhat.com>
 | |
|  */
 | |
| #include <asm-generic/vmlinux.lds.h>
 | |
| #include <asm/thread_info.h>
 | |
| #include <asm/page.h>
 | |
| 
 | |
| ENTRY(_c_int00)
 | |
| 
 | |
| #if defined(CONFIG_CPU_BIG_ENDIAN)
 | |
| jiffies = jiffies_64 + 4;
 | |
| #else
 | |
| jiffies = jiffies_64;
 | |
| #endif
 | |
| 
 | |
| #define	READONLY_SEGMENT_START	\
 | |
| 	. = PAGE_OFFSET;
 | |
| #define	READWRITE_SEGMENT_START	\
 | |
| 	. = ALIGN(128);		\
 | |
| 	_data_lma = .;
 | |
| 
 | |
| SECTIONS
 | |
| {
 | |
| 	/*
 | |
| 	 * Start kernel read only segment
 | |
| 	 */
 | |
| 	READONLY_SEGMENT_START
 | |
| 
 | |
| 	.vectors :
 | |
| 	{
 | |
| 		_vectors_start = .;
 | |
| 		*(.vectors)
 | |
| 		. = ALIGN(0x400);
 | |
| 		_vectors_end = .;
 | |
| 	}
 | |
| 
 | |
| 	/*
 | |
| 	 * This section contains data which may be shared with other
 | |
| 	 * cores. It needs to be a fixed offset from PAGE_OFFSET
 | |
| 	 * regardless of kernel configuration.
 | |
| 	 */
 | |
| 	.virtio_ipc_dev :
 | |
| 	{
 | |
| 		*(.virtio_ipc_dev)
 | |
| 	}
 | |
| 
 | |
| 	. = ALIGN(PAGE_SIZE);
 | |
| 	__init_begin = .;
 | |
| 	.init :
 | |
| 	{
 | |
| 		_sinittext = .;
 | |
| 		HEAD_TEXT
 | |
| 		INIT_TEXT
 | |
| 		_einittext = .;
 | |
| 	}
 | |
| 
 | |
| 	INIT_DATA_SECTION(16)
 | |
| 
 | |
| 	PERCPU_SECTION(128)
 | |
| 
 | |
| 	. = ALIGN(PAGE_SIZE);
 | |
| 	__init_end = .;
 | |
| 
 | |
| 	.text :
 | |
| 	{
 | |
| 		_text = .;
 | |
| 		_stext = .;
 | |
| 		TEXT_TEXT
 | |
| 		SCHED_TEXT
 | |
| 		CPUIDLE_TEXT
 | |
| 		LOCK_TEXT
 | |
| 		IRQENTRY_TEXT
 | |
| 		SOFTIRQENTRY_TEXT
 | |
| 		KPROBES_TEXT
 | |
| 		*(.fixup)
 | |
| 		*(.gnu.warning)
 | |
| 	}
 | |
| 
 | |
| 	EXCEPTION_TABLE(16)
 | |
| 	NOTES
 | |
| 
 | |
| 	RO_DATA_SECTION(PAGE_SIZE)
 | |
| 	.const :
 | |
| 	{
 | |
| 		*(.const .const.* .gnu.linkonce.r.*)
 | |
| 		*(.switch)
 | |
| 	}
 | |
| 
 | |
| 	. = ALIGN (8) ;
 | |
| 	__fdt_blob : AT(ADDR(__fdt_blob) - LOAD_OFFSET)
 | |
| 	{
 | |
| 		_fdt_start = . ;	/* place for fdt blob */
 | |
| 		*(__fdt_blob) ;		/* Any link-placed DTB */
 | |
| 		BYTE(0);		/* section always has contents */
 | |
| 	        . = _fdt_start + 0x4000;	/* Pad up to 16kbyte */
 | |
| 		_fdt_end = . ;
 | |
| 	}
 | |
| 
 | |
| 	_etext = .;
 | |
| 
 | |
| 	/*
 | |
| 	 * Start kernel read-write segment.
 | |
| 	 */
 | |
| 	READWRITE_SEGMENT_START
 | |
| 	_sdata = .;
 | |
| 
 | |
| 	.fardata : AT(ADDR(.fardata) - LOAD_OFFSET)
 | |
| 	{
 | |
| 		INIT_TASK_DATA(THREAD_SIZE)
 | |
| 		NOSAVE_DATA
 | |
| 		PAGE_ALIGNED_DATA(PAGE_SIZE)
 | |
| 		CACHELINE_ALIGNED_DATA(128)
 | |
| 		READ_MOSTLY_DATA(128)
 | |
| 		DATA_DATA
 | |
| 		CONSTRUCTORS
 | |
| 		*(.data1)
 | |
| 		*(.fardata .fardata.*)
 | |
| 		*(.data.debug_bpt)
 | |
| 	}
 | |
| 
 | |
| 	.neardata ALIGN(8) : AT(ADDR(.neardata) - LOAD_OFFSET)
 | |
| 	{
 | |
| 		*(.neardata2 .neardata2.* .gnu.linkonce.s2.*)
 | |
| 		*(.neardata .neardata.* .gnu.linkonce.s.*)
 | |
| 		. = ALIGN(8);
 | |
| 	}
 | |
| 
 | |
| 	BUG_TABLE
 | |
| 
 | |
| 	_edata = .;
 | |
| 
 | |
| 	__bss_start = .;
 | |
| 	SBSS(8)
 | |
| 	BSS(8)
 | |
| 	.far :
 | |
| 	{
 | |
| 		. = ALIGN(8);
 | |
| 		*(.dynfar)
 | |
| 		*(.far .far.* .gnu.linkonce.b.*)
 | |
| 		. = ALIGN(8);
 | |
| 	}
 | |
| 	__bss_stop = .;
 | |
| 
 | |
| 	_end = .;
 | |
| 
 | |
| 	DWARF_DEBUG
 | |
| 
 | |
| 	/DISCARD/ :
 | |
| 	{
 | |
| 		  EXIT_TEXT
 | |
| 		  EXIT_DATA
 | |
| 		  EXIT_CALL
 | |
| 		  *(.discard)
 | |
| 		  *(.discard.*)
 | |
| 		  *(.interp)
 | |
| 	}
 | |
| }
 |