1# Copyright (C) 2014-2016 Free Software Foundation, Inc.
2#
3# Copying and distribution of this file, with or without modification,
4# are permitted in any medium without royalty provided the copyright
5# notice and this notice are preserved.
6
7cat << EOF
8/* Copyright (C) 2014-2016 Free Software Foundation, Inc.
9
10   Copying and distribution of this script, with or without modification,
11   are permitted in any medium without royalty provided the copyright
12   notice and this notice are preserved.  */
13
14OUTPUT_FORMAT("elf32-ip2k", "elf32-ip2k", "elf32-ip2k")
15OUTPUT_ARCH(ip2k)
16${RELOCATING+ENTRY(_start)}
17SEARCH_DIR(.);
18
19/* IP2022 default linker script.  */
20
21MEMORY
22{
23	D_GPR    : org = 0x01000080, len = 128
24        D_RAM    : org = 0x01000100, len = 4K - 256
25        P_RAM    : org = 0x02000000, len = 16K
26        P_ROM    : org = 0x02010000, len = 64K - 32
27        P_RESET  : org = 0x0201FFE0, len = 32
28        P_CONFIG : org = 0x02020000, len = 128
29}
30
31SECTIONS
32{
33	/* Allocated memory end markers
34	   (initialized to start of appropiate memory address).  */
35	__data_end  = 0x01000100;
36	__pram_end  = 0x02000000;
37	__flash_end = 0x02010000;
38
39	/* Global general purpose registers in direct addressing range.  */
40	.gpr 0x01000080 :
41	{
42		*(.gpr)
43	} >D_GPR
44
45	/* Pre-allocated, pre-initialized data memory.  */
46	__data_run_begin = __data_end;
47	__data_load_begin = (__flash_end + 1) & 0xFFFFFFFE;
48	.data __data_run_begin : AT (__data_load_begin)
49	{
50		* (.data);
51		* (.rodata)
52	} >D_RAM
53	__data_run_end  = __data_run_begin  + SIZEOF(.data);
54	__data_load_end = __data_load_begin + SIZEOF(.data);
55	__data_end      = __data_run_end;
56	__flash_end     = __data_load_end;
57
58	/* Pre-allocated, uninitialized data memory.  */
59	__bss_begin = __data_end;
60	.bss __bss_begin :
61	{
62		* (.bss)
63	} >D_RAM
64	__bss_end  = __bss_begin + SIZEOF(.bss);
65	__data_end = __bss_end;
66
67	/* Pre-allocated PRAM data memory.  */
68	__pram_data_begin = (__pram_end + 1) & 0xFFFFFFFE;
69	.pram_data __pram_data_begin :
70	{
71		* (.pram_data)
72	} >P_RAM
73	__pram_data_end = __pram_data_begin + SIZEOF(.pram_data);
74	__pram_end      = __pram_data_end;
75
76	/* PRAM code.  */
77	__pram_run_begin  = (__pram_end + 1) & 0xFFFFFFFE;
78	__pram_load_begin = (__flash_end + 1) & 0xFFFFFFFE;
79	.pram __pram_run_begin : AT (__pram_load_begin)
80	{
81		* (.pram)
82	} >P_RAM
83	__pram_run_end  = __pram_run_begin  + SIZEOF(.pram);
84	__pram_load_end = __pram_load_begin + SIZEOF(.pram);
85
86	__pram_load_shift = ((__pram_run_begin - __pram_load_begin) & 0x1FFFF) | 0x02000000;
87	__pram_end  = __pram_run_end;
88	__flash_end = __pram_load_end;
89
90	/* PRAM overlay code.  */
91	__pram_overlay_run_start  = (__pram_end  + 1) & 0xFFFFFFFE;
92	__pram_overlay_load_start = (__flash_end + 1) & 0xFFFFFFFE;
93	OVERLAY __pram_overlay_run_start : AT (__pram_overlay_load_start)
94	{
95		.pram1 { */overlay1/* (.pram); * (.pram1) }
96		.pram2 { */overlay2/* (.pram); * (.pram2) }
97	} >P_RAM
98	__pram_overlay_run_end = .;
99	__pram_overlay_load_end = __pram_overlay_load_start + SIZEOF(.pram1) + SIZEOF(.pram2);
100	__pram_end  = __pram_overlay_run_end;
101	__flash_end = __pram_overlay_load_end;
102
103	/* Flash code.  */
104	__text_begin = (__flash_end + 1) & 0xFFFFFFFE;
105	.text __text_begin :
106	{
107		* (.text);
108		* (.text.libgcc)
109	} >P_ROM = 0xffff
110	__text_end  = __text_begin + SIZEOF(.text);
111	__flash_end = __text_end;
112
113	/* Strings.  */
114	__strings_begin = (__flash_end + 1) & 0xFFFFFFFE;
115	.strings __strings_begin :
116	{
117		* (strings);
118		* (.progmem.data)
119	} >P_ROM = 0xffff
120	__strings_end = __strings_begin + SIZEOF (.strings);
121	__flash_end   = __strings_end;
122
123	.ctors : { * (.ctors) } > P_ROM
124	.dtors : { * (.dtors) } > P_ROM
125
126	/* Reset code.  */
127	.reset  : { * (.reset)  } >P_RESET  = 0xffff
128
129	/* Configuration block.  */
130	.config : { * (.config) } >P_CONFIG = 0xffff
131
132	/* Stack.  */
133	PROVIDE (__stack = 0x01000FFF);
134
135	/* Stabs debugging sections.  */
136	.stab           0 : { *(.stab) }
137	.stabstr        0 : { *(.stabstr) }
138	.stab.excl      0 : { *(.stab.excl) }
139	.stab.exclstr   0 : { *(.stab.exclstr) }
140	.stab.index     0 : { *(.stab.index) }
141	.stab.indexstr  0 : { *(.stab.indexstr) }
142	.comment        0 : { *(.comment) }
143
144EOF
145
146. $srcdir/scripttempl/DWARF.sc
147
148cat <<EOF
149}
150EOF
151