xref: /netbsd-src/sys/arch/evbarm/conf/ldscript.evbarm (revision 09afef20633f5fe63d92dfe43ee3a9380dc06883)
1/*	$NetBSD: ldscript.evbarm,v 1.5 2008/11/07 16:23:58 rafal Exp $	*/
2
3OUTPUT_ARCH(arm)
4ENTRY(KERNEL_BASE_phys)
5SECTIONS
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  PROVIDE (__etext = .);
27  PROVIDE (_etext = .);
28  PROVIDE (etext = .);
29  /* Adjust the address for the data segment to start on the next large page
30     boundary.  */
31  . = ALIGN(0x10000);
32  .data    :
33  AT (LOADADDR(.text) + (ADDR(.data) - ADDR(.text)))
34  {
35    __data_start = . ;
36    *(.data)
37    *(.data.*)
38  }
39  .sdata     :
40  AT (LOADADDR(.data) + (ADDR(.sdata) - ADDR(.data)))
41  {
42    *(.sdata)
43    *(.sdata.*)
44  }
45  _edata = .;
46  PROVIDE (edata = .);
47  __bss_start = .;
48  __bss_start__ = .;
49  .sbss      :
50  AT (LOADADDR(.sdata) + (ADDR(.sbss) - ADDR(.sdata)))
51  {
52    PROVIDE (__sbss_start = .);
53    PROVIDE (___sbss_start = .);
54    *(.dynsbss)
55    *(.sbss)
56    *(.sbss.*)
57    *(.scommon)
58    PROVIDE (__sbss_end = .);
59    PROVIDE (___sbss_end = .);
60  }
61  .bss       :
62  AT (LOADADDR(.sbss) + (ADDR(.bss) - ADDR(.sbss)))
63  {
64   *(.dynbss)
65   *(.bss)
66   *(.bss.*)
67   *(COMMON)
68   /* Align here to ensure that the .bss section occupies space up to
69      _end.  Align after .bss to ensure correct alignment even if the
70      .bss section disappears because there are no input sections.  */
71   . = ALIGN(32 / 8);
72  }
73  . = ALIGN(32 / 8);
74  _end = .;
75  _bss_end__ = . ; __bss_end__ = . ; __end__ = . ;
76  PROVIDE (end = .);
77}
78