• Home
  • History
  • Annotate
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1/* -----------------------------------------------------------------------
2 *
3 *   Copyright 2008-2009 H. Peter Anvin - All Rights Reserved
4 *   Copyright 2009 Intel Corporation; author: H. Peter Anvin
5 *
6 *   This program is free software; you can redistribute it and/or modify
7 *   it under the terms of the GNU General Public License as published by
8 *   the Free Software Foundation, Inc., 51 Franklin St, Fifth Floor,
9 *   Boston MA 02110-1301, USA; either version 2 of the License, or
10 *   (at your option) any later version; incorporated herein by reference.
11 *
12 * ----------------------------------------------------------------------- */
13
14/*
15 * Linker script for the SYSLINUX core
16 */
17
18OUTPUT_FORMAT("elf32-i386", "elf32-i386", "elf32-i386")
19OUTPUT_ARCH(i386)
20EXTERN(_start)
21ENTRY(_start)
22
23STACK32_LEN = 65536;
24
25SECTIONS
26{
27	/* Prefix structure for the compression program */
28	. = 0;
29	HIDDEN(__module_start = .);
30	.prefix : {
31		*(.prefix)
32	}
33
34	/* "Early" sections (before the load) */
35	. = 0x1000;
36
37	.earlybss (NOLOAD) : {
38		HIDDEN(__earlybss_start = .);
39		*(.earlybss)
40		HIDDEN(__earlybss_end = .);
41	}
42	HIDDEN(__earlybss_len = ABSOLUTE(__earlybss_end) - ABSOLUTE(__earlybss_start));
43	HIDDEN(__earlybss_dwords = (__earlybss_len + 3) >> 2);
44
45	. = ALIGN(4);
46	.bss16 (NOLOAD) : {
47		HIDDEN(__bss16_start = .);
48		*(.bss16)
49		HIDDEN(__bss16_end = .);
50	}
51	HIDDEN(__bss16_len = ABSOLUTE(__bss16_end) - ABSOLUTE(__bss16_start));
52	HIDDEN(__bss16_dwords = (__bss16_len + 3) >> 2);
53
54	. = ALIGN(4);
55 	.config : AT (__config_lma) {
56		HIDDEN(__config_start = .);
57		*(.config)
58		HIDDEN(__config_end = .);
59	}
60	HIDDEN(__config_len = ABSOLUTE(__config_end) - ABSOLUTE(__config_start));
61	HIDDEN(__config_dwords = (__config_len + 3) >> 2);
62
63	/* Generated and/or copied code */
64
65	. = ALIGN(128);		/* Minimum separation from mutable data */
66 	.replacestub : AT (__replacestub_lma) {
67		HIDDEN(__replacestub_start = .);
68		*(.replacestub)
69		HIDDEN(__replacestub_end = .);
70	}
71	HIDDEN(__replacestub_len = ABSOLUTE(__replacestub_end) - ABSOLUTE(__replacestub_start));
72	HIDDEN(__replacestub_dwords = (__replacestub_len + 3) >> 2);
73
74	. = ALIGN(16);
75	HIDDEN(__gentextnr_lma = .);
76	.gentextnr : AT(__gentextnr_lma) {
77		HIDDEN(__gentextnr_start = .);
78		*(.gentextnr)
79		HIDDEN(__gentextnr_end = .);
80	}
81	HIDDEN(__gentextnr_len = ABSOLUTE(__gentextnr_end) - ABSOLUTE(__gentextnr_start));
82	HIDDEN(__gentextnr_dwords = (__gentextnr_len + 3) >> 2);
83
84	. = STACK_BASE;
85	.stack16 : AT(STACK_BASE) {
86		HIDDEN(__stack16_start = .);
87		. += STACK_LEN;
88		HIDDEN(__stack16_end = .);
89	}
90	HIDDEN(__stack16_len = ABSOLUTE(__stack16_end) - ABSOLUTE(__stack16_start));
91	HIDDEN(__stack16_dwords = (__stack16_len + 3) >> 2);
92
93	/* Initialized sections */
94
95	. = 0x7c00;
96	.init : {
97		FILL(0x90909090)
98		HIDDEN(__init_start = .);
99		*(.init)
100		HIDDEN(__init_end = .);
101	}
102	HIDDEN(__init_len = ABSOLUTE(__init_end) - ABSOLUTE(__init_start));
103	HIDDEN(__init_dwords = (__init_len + 3) >> 2);
104
105	.text16 : {
106		FILL(0x90909090)
107		HIDDEN(__text16_start = .);
108		*(.text16)
109		HIDDEN(__text16_end = .);
110	}
111	HIDDEN(__text16_len = ABSOLUTE(__text16_end) - ABSOLUTE(__text16_start));
112	HIDDEN(__text16_dwords = (__text16_len + 3) >> 2);
113
114	/*
115	 * .textnr is used for 32-bit code that is used on the code
116	 * path to initialize the .text segment
117	 */
118	. = ALIGN(16);
119	.textnr : {
120		FILL(0x90909090)
121		HIDDEN(__textnr_start = .);
122		*(.textnr)
123		HIDDEN(__textnr_end = .);
124	}
125	HIDDEN(__textnr_len = ABSOLUTE(__textnr_end) - ABSOLUTE(__textnr_start));
126	HIDDEN(__textnr_dwords = (__textnr_len + 3) >> 2);
127
128	. = ALIGN(16);
129	HIDDEN(__bcopyxx_start = .);
130
131	.bcopyxx.text : {
132		FILL(0x90909090)
133		HIDDEN(__bcopyxx_text_start = .);
134		*(.bcopyxx.text)
135		HIDDEN(__bcopyxx_text_end = .);
136	}
137	HIDDEN(__bcopyxx_text_len = ABSOLUTE(__bcopyxx_text_end) - ABSOLUTE(__bcopyxx_text_start));
138	HIDDEN(__bcopyxx_text_dwords = (__bcopyxx_text_len + 3) >> 2);
139
140	.bcopyxx.data : {
141		HIDDEN(__bcopyxx_data_start = .);
142		*(.bcopyxx.text)
143		HIDDEN(__bcopyxx_data_end = .);
144	}
145	HIDDEN(__bcopyxx_data_len = ABSOLUTE(__bcopyxx_data_end) - ABSOLUTE(__bcopyxx_data_start));
146	HIDDEN(__bcopyxx_data_dwords = (__bcopyxx_data_len + 3) >> 2);
147
148	HIDDEN(__bcopyxx_end = .);
149	HIDDEN(__bcopyxx_len = ABSOLUTE(__bcopyxx_end) - ABSOLUTE(__bcopyxx_start));
150	HIDDEN(__bcopyxx_dwords = (__bcopyxx_len + 3) >> 2);
151
152	. = ALIGN(4);
153	.data16 : {
154		HIDDEN(__data16_start = .);
155		*(.data16)
156		HIDDEN(__data16_end = .);
157	}
158	HIDDEN(__data16_len = ABSOLUTE(__data16_end) - ABSOLUTE(__data16_start));
159	HIDDEN(__data16_dwords = (__data16_len + 3) >> 2);
160
161	. = ALIGN(4);
162	HIDDEN(__config_lma = .);
163	. += SIZEOF(.config);
164
165	. = ALIGN(4);
166	HIDDEN(__replacestub_lma = .);
167	. += SIZEOF(.replacestub);
168
169	/* The 32-bit code loads above the non-progbits sections */
170
171	. = ALIGN(16);
172	HIDDEN(__pm_code_lma = .);
173
174	HIDDEN(__high_clear_start = .);
175
176	. = ALIGN(512);
177	.adv (NOLOAD) : {
178		HIDDEN(__adv_start = .);
179		*(.adv)
180		HIDDEN(__adv_end = .);
181	}
182	HIDDEN(__adv_len = ABSOLUTE(__adv_end) - ABSOLUTE(__adv_start));
183	HIDDEN(__adv_dwords = (__adv_len + 3) >> 2);
184
185	/* Late uninitialized sections */
186
187	. = ALIGN(4);
188	.uibss (NOLOAD) : {
189		HIDDEN(__uibss_start = .);
190		*(.uibss)
191		HIDDEN(__uibss_end = .);
192	}
193	HIDDEN(__uibss_len = ABSOLUTE(__uibss_end) - ABSOLUTE(__uibss_start));
194	HIDDEN(__uibss_dwords = (__uibss_len + 3) >> 2);
195
196	HIDDEN(_end16 = .);
197	HIDDEN(__assert_end16 = ASSERT(_end16 <= 0x10000, "64K overflow"));
198
199	/*
200	 * Special 16-bit segments
201	 */
202
203	. = ALIGN(65536);
204	.real_mode (NOLOAD) : {
205		*(.real_mode)
206	}
207	HIDDEN(real_mode_seg = core_real_mode >> 4);
208
209	. = ALIGN(65536);
210	.xfer_buf (NOLOAD) : {
211		*(.xfer_buf)
212	}
213	HIDDEN(xfer_buf_seg = core_xfer_buf >> 4);
214
215	/*
216	 * Used to allocate lowmem buffers from 32-bit code
217	 */
218	.lowmem (NOLOAD) : {
219		HIDDEN(__lowmem_start = .);
220		*(.lowmem)
221		HIDDEN(__lowmem_end = .);
222	}
223	HIDDEN(__lowmem_len = ABSOLUTE(__lowmem_end) - ABSOLUTE(__lowmem_start));
224	HIDDEN(__lowmem_dwords = (__lowmem_len + 3) >> 2);
225
226	HIDDEN(__high_clear_end = .);
227
228	HIDDEN(__high_clear_len = ABSOLUTE(__high_clear_end) - ABSOLUTE(__high_clear_start));
229	HIDDEN(__high_clear_dwords = (__high_clear_len + 3) >> 2);
230
231	/* Start of the lowmem heap */
232	. = ALIGN(16);
233	HIDDEN(__lowmem_heap = .);
234
235	/*
236	 * 32-bit code.  This is a hack for the moment due to the
237	 * real-mode segments also allocated.
238	 */
239
240	. = 0x100000;
241
242	HIDDEN(__pm_code_start = .);
243
244	HIDDEN(__text_vma = .);
245	HIDDEN(__text_lma = __pm_code_lma);
246	.text : AT(__text_lma) {
247		FILL(0x90909090)
248		HIDDEN(__text_start = .);
249		*(.text)
250		*(.text.*)
251		HIDDEN(__text_end = .);
252	}
253
254	. = ALIGN(16);
255
256	HIDDEN(__rodata_vma = .);
257	HIDDEN(__rodata_lma = __rodata_vma + __text_lma - __text_vma);
258	.rodata : AT(__rodata_lma) {
259		HIDDEN(__rodata_start = .);
260		*(.rodata)
261		*(.rodata.*)
262		HIDDEN(__rodata_end = .);
263	}
264
265	. = ALIGN(4);
266
267	HIDDEN(__ctors_vma = .);
268	HIDDEN(__ctors_lma = __ctors_vma + __text_lma - __text_vma);
269	.ctors : AT(__ctors_lma) {
270		HIDDEN(__ctors_start = .);
271		KEEP (*(SORT(.preinit_array*)))
272		KEEP (*(SORT(.init_array*)))
273		KEEP (*(SORT(.ctors*)))
274		HIDDEN(__ctors_end = .);
275	}
276
277	HIDDEN(__dtors_vma = .);
278	HIDDEN(__dtors_lma = __dtors_vma + __text_lma - __text_vma);
279	.dtors : AT(__dtors_lma) {
280		HIDDEN(__dtors_start = .);
281		KEEP (*(SORT(.fini_array*)))
282		KEEP (*(SORT(.dtors*)))
283		HIDDEN(__dtors_end = .);
284	}
285
286	. = ALIGN(4);
287
288	HIDDEN(__dynsym_vma = .);
289	HIDDEN(__dynsym_lma = __dynsym_vma + __text_lma - __text_vma);
290	.dynsym : AT(__dynsym_lma) {
291		HIDDEN(__dynsym_start = .);
292		*(.dynsym)
293		HIDDEN(__dynsym_end = .);
294	}
295	HIDDEN(__dynsym_len = __dynsym_end - __dynsym_start);
296
297	. = ALIGN(4);
298
299	HIDDEN(__dynstr_vma = .);
300	HIDDEN(__dynstr_lma = __dynstr_vma + __text_lma - __text_vma);
301	.dynstr : AT(__dynstr_lma) {
302		HIDDEN(__dynstr_start = .);
303		*(.dynstr)
304		HIDDEN(__dynstr_end = .);
305	}
306	HIDDEN(__dynstr_len = __dynstr_end - __dynstr_start);
307
308	. = ALIGN(4);
309
310	HIDDEN(__gnu_hash_vma = .);
311	HIDDEN(__gnu_hash_lma = __gnu_hash_vma + __text_lma - __text_vma);
312	.gnu.hash : AT(__gnu_hash_lma) {
313		HIDDEN(__gnu_hash_start = .);
314		*(.gnu.hash)
315		HIDDEN(__gnu_hash_end = .);
316	}
317
318
319	. = ALIGN(4);
320
321	HIDDEN(__dynlink_vma = .);
322	HIDDEN(__dynlink_lma = __dynlink_vma + __text_lma - __text_vma);
323	.dynlink : AT(__dynlink_lma) {
324		HIDDEN(__dynlink_start = .);
325		*(.dynlink)
326		HIDDEN(__dynlink_end = .);
327	}
328
329	. = ALIGN(4);
330
331	HIDDEN(__got_vma = .);
332	HIDDEN(__got_lma = __got_vma + __text_lma - __text_vma);
333	.got : AT(__got_lma) {
334		HIDDEN(__got_start = .);
335		KEEP (*(.got.plt))
336		KEEP (*(.got))
337		HIDDEN(__got_end = .);
338	}
339
340	. = ALIGN(4);
341
342	HIDDEN(__dynamic_vma = .);
343	HIDDEN(__dynamic_lma = __dynamic_vma + __text_lma - __text_vma);
344	.dynamic : AT(__dynamic_lma) {
345		HIDDEN(__dynamic_start = .);
346		*(.dynamic)
347		HIDDEN(__dynamic_end = .);
348	}
349
350	. = ALIGN(16);
351
352	HIDDEN(__data_vma = .);
353	HIDDEN(__data_lma = __data_vma + __text_lma - __text_vma);
354	.data : AT(__data_lma) {
355		HIDDEN(__data_start = .);
356		*(.data)
357		*(.data.*)
358		HIDDEN(__data_end = .);
359	}
360
361	HIDDEN(__pm_code_end = .);
362	HIDDEN(__pm_code_len = ABSOLUTE(__pm_code_end) - ABSOLUTE(__pm_code_start));
363	HIDDEN(__pm_code_dwords = (__pm_code_len + 3) >> 2);
364
365	. = ALIGN(128);
366
367	HIDDEN(__bss_vma = .);
368	HIDDEN(__bss_lma = .);		/* Dummy */
369	.bss (NOLOAD) : AT (__bss_lma) {
370		HIDDEN(__bss_start = .);
371		*(.bss)
372		*(.bss.*)
373		*(COMMON)
374		HIDDEN(__bss_end = .);
375	}
376	HIDDEN(__bss_len = ABSOLUTE(__bss_end) - ABSOLUTE(__bss_start));
377	HIDDEN(__bss_dwords = (__bss_len + 3) >> 2);
378
379	/* Data saved away before bss initialization */
380	. = ALIGN(128);
381
382	HIDDEN(__savedata_vma = .);
383	HIDDEN(__savedata_lma = .);		/* Dummy */
384	.savedata (NOLOAD) : AT (__savedata_lma) {
385		HIDDEN(__savedata_start = .);
386		*(.savedata)
387		*(.savedata.*)
388		HIDDEN(__savedata_end = .);
389	}
390	HIDDEN(__savedata_len = ABSOLUTE(__savedata_end) - ABSOLUTE(__savedata_start));
391	HIDDEN(__savedata_dwords = (__savedata_len + 3) >> 2);
392
393	/* XXX: This stack should be unified with the COM32 stack */
394	HIDDEN(__stack_vma = .);
395	__stack_lma = .;	/* Dummy */
396	.stack (NOLOAD) : AT(__stack_lma) {
397		HIDDEN(__stack_start = .);
398		*(.stack)
399		HIDDEN(__stack_end = .);
400	}
401	HIDDEN(__stack_len = ABSOLUTE(__stack_end) - ABSOLUTE(__stack_start));
402	HIDDEN(__stack_dwords = (__stack_len + 3) >> 2);
403
404	HIDDEN(_end = .);
405
406	/* Heap follows after our own PM code */
407	. = ALIGN(65536);
408	HIDDEN(free_high_memory = .);
409
410	/* Stuff we don't need... */
411	/DISCARD/ : {
412		*(.eh_frame)
413	}
414}
415