1/* ld script to make M32R Linux kernel
2 */
3
4#include <asm-generic/vmlinux.lds.h>
5#include <asm/addrspace.h>
6#include <asm/page.h>
7#include <asm/thread_info.h>
8
9OUTPUT_ARCH(m32r)
10#if defined(__LITTLE_ENDIAN__)
11       jiffies = jiffies_64;
12#else
13       jiffies = jiffies_64 + 4;
14#endif
15
16kernel_entry = boot - 0x80000000;
17ENTRY(kernel_entry)
18
19SECTIONS
20{
21  . = CONFIG_MEMORY_START + __PAGE_OFFSET;
22  eit_vector = .;
23
24  . = . + 0x1000;
25  .empty_zero_page : { *(.empty_zero_page) } = 0
26
27  /* read-only */
28  _text = .;			/* Text and read-only data */
29  .boot : { *(.boot) } = 0
30  .text : {
31	HEAD_TEXT
32	TEXT_TEXT
33	SCHED_TEXT
34	LOCK_TEXT
35	*(.fixup)
36	*(.gnu.warning)
37	} = 0x9090
38#ifdef CONFIG_SMP
39  . = ALIGN(65536);
40  .eit_vector4 : { *(.eit_vector4) }
41#endif
42  _etext = .;			/* End of text section */
43
44  EXCEPTION_TABLE(16)
45  NOTES
46
47  _sdata = .;			/* Start of data section */
48  RODATA
49  RW_DATA_SECTION(32, PAGE_SIZE, THREAD_SIZE)
50  _edata = .;			/* End of data section */
51
52  /* will be freed after init */
53  . = ALIGN(PAGE_SIZE);		/* Init code and data */
54  __init_begin = .;
55  INIT_TEXT_SECTION(PAGE_SIZE)
56  INIT_DATA_SECTION(16)
57  PERCPU_SECTION(32)
58  . = ALIGN(PAGE_SIZE);
59  __init_end = .;
60  /* freed after init ends here */
61
62  BSS_SECTION(0, 0, 4)
63
64  _end = . ;
65
66  /* Stabs debugging sections.  */
67  .stab 0 : { *(.stab) }
68  .stabstr 0 : { *(.stabstr) }
69  .stab.excl 0 : { *(.stab.excl) }
70  .stab.exclstr 0 : { *(.stab.exclstr) }
71  .stab.index 0 : { *(.stab.index) }
72  .stab.indexstr 0 : { *(.stab.indexstr) }
73  .comment 0 : { *(.comment) }
74
75  /* Sections to be discarded */
76  DISCARDS
77}
78