Subversion Repositories HelenOS

Rev

Rev 693 | Rev 2089 | Go to most recent revision | Only display areas with differences | Ignore whitespace | Details | Blame | Last modification | View Log | RSS feed

Rev 693 Rev 1787
1
/** IA-32 linker script
1
/** IA-32 linker script
2
 *  
2
 *  
3
 * umapped section:
3
 * umapped section:
4
 * 	kernel text
4
 * 	kernel text
5
 * 	kernel data
5
 * 	kernel data
6
 * mapped section:
6
 * mapped section:
7
 *	kernel text
7
 *	kernel text
8
 *	kernel data 
8
 *	kernel data 
9
 */
9
 */
10
 
10
 
11
#define __ASM__
11
#define __ASM__
12
#include <arch/boot/boot.h>
12
#include <arch/boot/boot.h>
13
#include <arch/mm/page.h>
13
#include <arch/mm/page.h>
14
 
14
 
15
SECTIONS {
15
SECTIONS {
16
	.unmapped BOOT_OFFSET: AT (0) {
16
	.unmapped BOOT_OFFSET: AT (0) {
17
		unmapped_ktext_start = .;
17
		unmapped_ktext_start = .;
18
		*(K_TEXT_START);
18
		*(K_TEXT_START);
19
		unmapped_ktext_end = .;
19
		unmapped_ktext_end = .;
20
	
20
	
21
		unmapped_kdata_start = .;
21
		unmapped_kdata_start = .;
22
		*(K_DATA_START);
22
		*(K_DATA_START);
23
		unmapped_kdata_end = .;
23
		unmapped_kdata_end = .;
24
	}
24
	}
25
	
25
	
26
	.mapped (PA2KA(BOOT_OFFSET)+SIZEOF(.unmapped)): AT (SIZEOF(.unmapped)) { 
26
	.mapped (PA2KA(BOOT_OFFSET)+SIZEOF(.unmapped)): AT (SIZEOF(.unmapped)) { 
27
		ktext_start = .;
27
		ktext_start = .;
28
		*(.text);
28
		*(.text);
29
		ktext_end = .;
29
		ktext_end = .;
30
		
30
		
31
		kdata_start = .;
31
		kdata_start = .;
32
		*(.data);			/* initialized data */
32
		*(.data);			/* initialized data */
33
		*(.rodata*);			/* string literals */
33
		*(.rodata*);			/* string literals */
34
		*(COMMON);			/* global variables */
34
		*(COMMON);			/* global variables */
35
		hardcoded_load_address = .;
35
		hardcoded_load_address = .;
36
		LONG(PA2KA(BOOT_OFFSET));
36
		LONG(PA2KA(BOOT_OFFSET));
37
		hardcoded_ktext_size = .;
37
		hardcoded_ktext_size = .;
38
		LONG((ktext_end - ktext_start) + (unmapped_ktext_end - unmapped_ktext_start));
38
		LONG((ktext_end - ktext_start) + (unmapped_ktext_end - unmapped_ktext_start));
39
		hardcoded_kdata_size = .;
39
		hardcoded_kdata_size = .;
40
		LONG((kdata_end - kdata_start) + (unmapped_kdata_end - unmapped_kdata_start));
40
		LONG((kdata_end - kdata_start) + (unmapped_kdata_end - unmapped_kdata_start));
41
		hardcoded_unmapped_ktext_size = .;
41
		hardcoded_unmapped_ktext_size = .;
42
		LONG(unmapped_ktext_end - unmapped_ktext_start);
42
		LONG(unmapped_ktext_end - unmapped_ktext_start);
43
		hardcoded_unmapped_kdata_size = .;
43
		hardcoded_unmapped_kdata_size = .;
44
		LONG(unmapped_kdata_end - unmapped_kdata_start);
44
		LONG(unmapped_kdata_end - unmapped_kdata_start);
45
		symbol_table = .;
45
		symbol_table = .;
46
		*(symtab.*);            	/* Symbol table, must be LAST symbol! */
46
		*(symtab.*);            	/* Symbol table, must be LAST symbol! */
47
		*(.bss);			/* uninitialized static variables */
47
		*(.bss);			/* uninitialized static variables */
48
		kdata_end = .;
48
		kdata_end = .;
49
	}
49
	}
50
 
50
 
51
	/DISCARD/ : {
51
	/DISCARD/ : {
52
		*(.note.GNU-stack);		
52
		*(.note.GNU-stack);		
53
		*(.comment);
53
		*(.comment);
54
	}
54
	}
55
	
55
	
56
#ifdef CONFIG_SMP	
56
#ifdef CONFIG_SMP	
57
	
57
	
58
	_hardcoded_unmapped_size = (unmapped_ktext_end - unmapped_ktext_start) + (unmapped_kdata_end - unmapped_kdata_start);
58
	_hardcoded_unmapped_size = (unmapped_ktext_end - unmapped_ktext_start) + (unmapped_kdata_end - unmapped_kdata_start);
59
	ap_boot = unmapped_ap_boot - BOOT_OFFSET + AP_BOOT_OFFSET;
59
	ap_boot = unmapped_ap_boot - BOOT_OFFSET + AP_BOOT_OFFSET;
60
	ap_gdtr = unmapped_ap_gdtr - BOOT_OFFSET + AP_BOOT_OFFSET;
60
	ap_gdtr = unmapped_ap_gdtr - BOOT_OFFSET + AP_BOOT_OFFSET;
61
	protected_ap_gdtr = PA2KA(ap_gdtr);
61
	protected_ap_gdtr = PA2KA(ap_gdtr);
62
 
62
 
63
#endif /* CONFIG_SMP */
63
#endif /* CONFIG_SMP */
64
 
64
 
65
}
65
}
66
 
66