mirror of
				https://git.kernel.org/pub/scm/linux/kernel/git/chenhuacai/linux-loongson
				synced 2025-10-26 15:13:26 +00:00 
			
		
		
		
	 a7dfa9403b
			
		
	
	
		a7dfa9403b
		
	
	
	
	
		
			
			This patch includes page.h header into linker scripts that allow us to use PAGE_SIZE macro instead of numeric constant. To be able to include page.h into linker scripts page.h is needed for some modification - i.e. we need to use __ASSEMBLY__ and _AC macro [jdike@linux.intel.com - fixed conflict with as-layout.h] Signed-off-by: Cyrill Gorcunov <gorcunov@gmail.com> Signed-off-by: Jeff Dike <jdike@linux.intel.com> Cc: WANG Cong <xiyou.wangcong@gmail.com> Signed-off-by: Andrew Morton <akpm@linux-foundation.org> Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
		
			
				
	
	
		
			104 lines
		
	
	
		
			2.1 KiB
		
	
	
	
		
			ArmAsm
		
	
	
	
	
	
			
		
		
	
	
			104 lines
		
	
	
		
			2.1 KiB
		
	
	
	
		
			ArmAsm
		
	
	
	
	
	
| #include <asm-generic/vmlinux.lds.h>
 | |
| #include <asm/page.h>
 | |
| 
 | |
| OUTPUT_FORMAT(ELF_FORMAT)
 | |
| OUTPUT_ARCH(ELF_ARCH)
 | |
| ENTRY(_start)
 | |
| jiffies = jiffies_64;
 | |
| 
 | |
| SECTIONS
 | |
| {
 | |
|   /* This must contain the right address - not quite the default ELF one.*/
 | |
|   PROVIDE (__executable_start = START);
 | |
|   /* Static binaries stick stuff here, like the sigreturn trampoline,
 | |
|    * invisibly to objdump.  So, just make __binary_start equal to the very
 | |
|    * beginning of the executable, and if there are unmapped pages after this,
 | |
|    * they are forever unusable.
 | |
|    */
 | |
|   __binary_start = START;
 | |
| 
 | |
|   . = START + SIZEOF_HEADERS;
 | |
| 
 | |
|   _text = .;
 | |
|   _stext = .;
 | |
|   __init_begin = .;
 | |
|   .init.text : {
 | |
| 	_sinittext = .;
 | |
| 	INIT_TEXT
 | |
| 	_einittext = .;
 | |
|   }
 | |
|   . = ALIGN(PAGE_SIZE);
 | |
| 
 | |
|   .text      :
 | |
|   {
 | |
|     TEXT_TEXT
 | |
|     SCHED_TEXT
 | |
|     LOCK_TEXT
 | |
|     *(.fixup)
 | |
|     /* .gnu.warning sections are handled specially by elf32.em.  */
 | |
|     *(.gnu.warning)
 | |
|     *(.gnu.linkonce.t*)
 | |
|   }
 | |
| 
 | |
|   . = ALIGN(PAGE_SIZE);
 | |
|   .syscall_stub : {
 | |
| 	__syscall_stub_start = .;
 | |
| 	*(.__syscall_stub*)
 | |
| 	__syscall_stub_end = .;
 | |
|   }
 | |
| 
 | |
|   #include "asm/common.lds.S"
 | |
| 
 | |
|   init.data : { INIT_DATA }
 | |
|   .data    :
 | |
|   {
 | |
|     . = ALIGN(KERNEL_STACK_SIZE);		/* init_task */
 | |
|     *(.data.init_task)
 | |
|     . = ALIGN(KERNEL_STACK_SIZE);
 | |
|     *(.data.init_irqstack)
 | |
|     DATA_DATA
 | |
|     *(.gnu.linkonce.d*)
 | |
|     CONSTRUCTORS
 | |
|   }
 | |
|   .data1   : { *(.data1) }
 | |
|   .ctors         :
 | |
|   {
 | |
|     *(.ctors)
 | |
|   }
 | |
|   .dtors         :
 | |
|   {
 | |
|     *(.dtors)
 | |
|   }
 | |
| 
 | |
|   .got           : { *(.got.plt) *(.got) }
 | |
|   .dynamic       : { *(.dynamic) }
 | |
|   .tdata	  : { *(.tdata .tdata.* .gnu.linkonce.td.*) }
 | |
|   .tbss		  : { *(.tbss .tbss.* .gnu.linkonce.tb.*) *(.tcommon) }
 | |
|   /* We want the small data sections together, so single-instruction offsets
 | |
|      can access them all, and initialized data all before uninitialized, so
 | |
|      we can shorten the on-disk segment size.  */
 | |
|   .sdata     : { *(.sdata) }
 | |
|   _edata  =  .;
 | |
|   PROVIDE (edata = .);
 | |
|   . = ALIGN(PAGE_SIZE);
 | |
|   .sbss      :
 | |
|   {
 | |
|    __bss_start = .;
 | |
|    PROVIDE(_bss_start = .);
 | |
|    *(.sbss)
 | |
|    *(.scommon)
 | |
|   }
 | |
|   .bss       :
 | |
|   {
 | |
|    *(.dynbss)
 | |
|    *(.bss)
 | |
|    *(COMMON)
 | |
|   }
 | |
|   _end = .;
 | |
|   PROVIDE (end = .);
 | |
| 
 | |
|   STABS_DEBUG
 | |
| 
 | |
|   DWARF_DEBUG
 | |
| }
 |