Subversion Repositories HelenOS-historic

Rev

Rev 301 | Go to most recent revision | Details | Compare with Previous | Last modification | View Log | RSS feed

Rev Author Line No. Line
178 palkovsky 1
/** AMD64 linker script
164 palkovsky 2
 *  
3
 * umapped section:
4
 * 	kernel text
5
 * 	kernel data
6
 * mapped section:
7
 *	kernel text
8
 *	kernel data 
9
 */
10
 
289 palkovsky 11
#define __ASM__
12
#include <arch/boot/boot.h>
13
#include <arch/mm/page.h>
14
 
164 palkovsky 15
OUTPUT_FORMAT(binary)
16
ENTRY(kernel_image_start)
17
 
18
SECTIONS {
289 palkovsky 19
	.unmapped BOOTSTRAP_OFFSET: AT (BOOTSTRAP_OFFSET) {
164 palkovsky 20
		unmapped_ktext_start = .;
21
		*(K_TEXT_START);
22
		*(K_TEXT_START_2);
23
		unmapped_ktext_end = .;
275 palkovsky 24
 
164 palkovsky 25
		unmapped_kdata_start = .;
26
		*(K_DATA_START);
27
		unmapped_kdata_end = .;
28
	}
29
 
289 palkovsky 30
	.mapped (PA2KA(BOOT_OFFSET+BOOTSTRAP_OFFSET)+SIZEOF(.unmapped)) : AT (BOOTSTRAP_OFFSET+SIZEOF(.unmapped)) {
164 palkovsky 31
		ktext_start = .;
243 palkovsky 32
		*(BOOT_DATA);
164 palkovsky 33
		*(.text);
34
		ktext_end = .;
35
 
36
		kdata_start = .;
37
		*(.data);		/* initialized data */
38
		*(.rodata*);		/* string literals */
216 palkovsky 39
		hardcoded_load_address = .;
301 palkovsky 40
		QUAD(PA2KA(BOOT_OFFSET+BOOTSTRAP_OFFSET));
216 palkovsky 41
		hardcoded_ktext_size = .;
42
		QUAD(ktext_end - ktext_start + (unmapped_ktext_end - unmapped_ktext_start));
43
		hardcoded_kdata_size = .;
44
		QUAD(kdata_end - kdata_start + (unmapped_kdata_end - unmapped_kdata_start));
275 palkovsky 45
		hardcoded_unmapped_ktext_size = .;
46
		LONG(unmapped_ktext_end - unmapped_ktext_start);
47
		hardcoded_unmapped_kdata_size = .;
48
		LONG(unmapped_kdata_end - unmapped_kdata_start);
268 palkovsky 49
		*(COMMON);		/* global variables */
50
 
51
 
52
 
216 palkovsky 53
		*(.eh_frame);
164 palkovsky 54
		*(.bss);		/* uninitialized static variables */
55
		*(K_DATA_END);
268 palkovsky 56
 
57
		symbol_table = .;
58
		*(symtab.*);            /* Symbol table, must be LAST symbol!*/
59
 
164 palkovsky 60
		kdata_end = .;
61
	}
282 palkovsky 62
 
63
	_hardcoded_kernel_size = (ktext_end - ktext_start) + (unmapped_ktext_end - unmapped_ktext_start) + (kdata_end - kdata_start) + (unmapped_kdata_end - unmapped_kdata_start);
277 palkovsky 64
 
332 palkovsky 65
	/* Symbols that need to be accessed both from real mode & long mode */
66
	/* e820*_boot is real mode (pre-above-1MB-move), e820* is */
67
	/* kernel mapped above-1MB-physical copied symbol */
289 palkovsky 68
	e820table_boot = KA2PA(e820table) - BOOT_OFFSET;
69
	e820counter_boot = KA2PA(e820counter) - BOOT_OFFSET;
332 palkovsky 70
 
71
	/* real_bootstrap_gdtr is mapped real_bootstrap_gdtr_boot */
72
	/* It is physically outside of kernel area, we have to access */
73
	/* it after modification from long mode for booting */
74
	/* SMP slave processors */
289 palkovsky 75
	real_bootstrap_gdtr = PA2KA(real_bootstrap_gdtr_boot);
164 palkovsky 76
}