Home | History | Annotate | Line # | Download | only in conf
ldscript.evbarm revision 1.8
      1 /*	$NetBSD: ldscript.evbarm,v 1.8 2014/01/30 15:36:44 matt Exp $	*/
      2 
      3 OUTPUT_ARCH(arm)
      4 ENTRY(KERNEL_BASE_phys)
      5 SECTIONS
      6 {
      7   KERNEL_BASE_phys = @KERNEL_BASE_PHYS@;
      8   KERNEL_BASE_virt = @KERNEL_BASE_VIRT@;
      9 
     10   /* Kernel start: */
     11   .start (KERNEL_BASE_phys) :
     12   {
     13     *(.start)
     14   } =0
     15 
     16   /* Read-only sections, merged into text segment: */
     17   .text (KERNEL_BASE_virt + SIZEOF(.start)) :
     18   AT (LOADADDR(.start) + SIZEOF(.start))
     19   {
     20     *(.text)
     21     *(.text.*)
     22     *(.stub)
     23     *(.glue_7t) *(.glue_7)
     24     *(.rodata) *(.rodata.*)
     25   } =0
     26   .ARM.extab   : { *(.ARM.extab* .gnu.linkonce.armextab.*) }
     27   PROVIDE (__exidx_start = .);
     28   .ARM.exidx   : { *(.ARM.exidx* .gnu.linkonce.armexidx.*) }
     29   PROVIDE (__exidx_end = .);
     30   PROVIDE (__etext = .);
     31   PROVIDE (_etext = .);
     32   PROVIDE (etext = .);
     33   /* Adjust the address for the data segment to start on the next large page
     34      boundary.  */
     35   . = ALIGN(0x10000);
     36   .data    :
     37   AT (LOADADDR(.text) + (ADDR(.data) - ADDR(.text)))
     38   {
     39     __data_start = . ;
     40     *(.data)
     41     *(.data.*)
     42   }
     43   .sdata     :
     44   AT (LOADADDR(.data) + (ADDR(.sdata) - ADDR(.data)))
     45   {
     46     *(.sdata)
     47     *(.sdata.*)
     48   }
     49   . = ALIGN(8);
     50   _edata = .;
     51   PROVIDE (edata = .);
     52   __bss_start = .;
     53   __bss_start__ = .;
     54   .sbss      :
     55   AT (LOADADDR(.sdata) + (ADDR(.sbss) - ADDR(.sdata)))
     56   {
     57     PROVIDE (__sbss_start = .);
     58     PROVIDE (___sbss_start = .);
     59     *(.dynsbss)
     60     *(.sbss)
     61     *(.sbss.*)
     62     *(.scommon)
     63     PROVIDE (__sbss_end = .);
     64     PROVIDE (___sbss_end = .);
     65   }
     66   .bss       :
     67   AT (LOADADDR(.sbss) + (ADDR(.bss) - ADDR(.sbss)))
     68   {
     69    *(.dynbss)
     70    *(.bss)
     71    *(.bss.*)
     72    *(COMMON)
     73    /* Align here to ensure that the .bss section occupies space up to
     74       _end.  Align after .bss to ensure correct alignment even if the
     75       .bss section disappears because there are no input sections.  */
     76    . = ALIGN(32 / 8);
     77   }
     78   . = ALIGN(32 / 8);
     79   _end = .;
     80   _bss_end__ = . ; __bss_end__ = . ; __end__ = . ;
     81   PROVIDE (end = .);
     82 }
     83