Atomics rewrite (XCC)
[akaros.git] / kern / arch / riscv / kernel.ld
1 /* Simple linker script for the ROS kernel.
2    See the GNU ld 'info' manual ("info ld") to learn the syntax. */
3
4 OUTPUT_ARCH("mips:riscv")
5 ENTRY(_start)
6
7 SECTIONS
8 {
9         /* Link the kernel for 0xC01000C0, but load it at 0x001000C0) */
10
11         .text 0xFFFFFFFF80000000 : AT(0) {
12           *(.boottext)
13                 *(.text .stub .text.* .gnu.linkonce.t.*)
14         }
15
16         PROVIDE(etext = .);     /* Define the 'etext' symbol to this value */
17
18         .rodata : {
19                 *(.rodata .rodata.* .gnu.linkonce.r.*)
20         }
21
22         /* Include debugging information in kernel memory */
23         .stab : {
24                 PROVIDE(stab = .);
25                 PROVIDE(__STAB_BEGIN__ = .);
26                 *(.stab);
27                 PROVIDE(estab = .);
28                 PROVIDE(__STAB_END__ = .);
29                 BYTE(0)         /* Force the linker to allocate space
30                                    for this section */
31         }
32
33         .stabstr : {
34                 PROVIDE(stabstr = .);
35                 PROVIDE(__STABSTR_BEGIN__ = .);
36                 *(.stabstr);
37                 PROVIDE(estabstr = .);
38                 PROVIDE(__STABSTR_END__ = .);
39                 BYTE(0)         /* Force the linker to allocate space
40                                    for this section */
41         }
42
43         /* Adjust the address for the data segment to the next page */
44         . = ALIGN(0x1000);
45
46         /* The data segment */
47         .data : {
48                 *(.data)
49                 *(.sdata)
50         }
51
52         PROVIDE(edata = .);
53
54         .bss : {
55                 *(.bss)
56                 *(.sbss)
57         }
58
59         PROVIDE(end = .);
60
61         /DISCARD/ : {
62                 *(.eh_frame .note.GNU-stack)
63         }
64 }