Rev 275 | Rev 282 | Go to most recent revision | Only display areas with differences | Regard whitespace | Details | Blame | Last modification | View Log | RSS feed
Rev 275 | Rev 277 | ||
---|---|---|---|
1 | /** AMD64 linker script |
1 | /** AMD64 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 | OUTPUT_FORMAT(binary) |
11 | OUTPUT_FORMAT(binary) |
12 | ENTRY(kernel_image_start) |
12 | ENTRY(kernel_image_start) |
13 | 13 | ||
14 | SECTIONS { |
14 | SECTIONS { |
15 | .unmapped 0x8000: AT (0x8000) { |
15 | .unmapped 0x8000: AT (0x8000) { |
16 | unmapped_ktext_start = .; |
16 | unmapped_ktext_start = .; |
17 | *(K_TEXT_START); |
17 | *(K_TEXT_START); |
18 | *(K_TEXT_START_2); |
18 | *(K_TEXT_START_2); |
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 (0xffffffff80100000+0x8000+SIZEOF(.unmapped)) : AT (0x8000+SIZEOF(.unmapped)) { |
26 | .mapped (0xffffffff80100000+0x8000+SIZEOF(.unmapped)) : AT (0x8000+SIZEOF(.unmapped)) { |
27 | ktext_start = .; |
27 | ktext_start = .; |
28 | *(BOOT_DATA); |
28 | *(BOOT_DATA); |
29 | *(.text); |
29 | *(.text); |
30 | ktext_end = .; |
30 | ktext_end = .; |
31 | 31 | ||
32 | kdata_start = .; |
32 | kdata_start = .; |
33 | *(.data); /* initialized data */ |
33 | *(.data); /* initialized data */ |
34 | *(.rodata*); /* string literals */ |
34 | *(.rodata*); /* string literals */ |
35 | hardcoded_load_address = .; |
35 | hardcoded_load_address = .; |
36 | QUAD(0xffffffff80008000); |
36 | QUAD(0xffffffff80008000); |
37 | hardcoded_ktext_size = .; |
37 | hardcoded_ktext_size = .; |
38 | QUAD(ktext_end - ktext_start + (unmapped_ktext_end - unmapped_ktext_start)); |
38 | QUAD(ktext_end - ktext_start + (unmapped_ktext_end - unmapped_ktext_start)); |
39 | hardcoded_kdata_size = .; |
39 | hardcoded_kdata_size = .; |
40 | QUAD(kdata_end - kdata_start + (unmapped_kdata_end - unmapped_kdata_start)); |
40 | QUAD(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 | *(COMMON); /* global variables */ |
45 | *(COMMON); /* global variables */ |
46 | 46 | ||
47 | 47 | ||
48 | 48 | ||
49 | *(.eh_frame); |
49 | *(.eh_frame); |
50 | *(.bss); /* uninitialized static variables */ |
50 | *(.bss); /* uninitialized static variables */ |
51 | *(K_DATA_END); |
51 | *(K_DATA_END); |
52 | 52 | ||
53 | symbol_table = .; |
53 | symbol_table = .; |
54 | *(symtab.*); /* Symbol table, must be LAST symbol!*/ |
54 | *(symtab.*); /* Symbol table, must be LAST symbol!*/ |
55 | 55 | ||
56 | kdata_end = .; |
56 | kdata_end = .; |
57 | } |
57 | } |
- | 58 | _boot_offset = 0x100000; |
|
58 | _map_address = 0xffffffff80100000; |
59 | _ka2pa_offset = 0xffffffff80000000; |
- | 60 | _map_address = _ka2pa_offset + _boot_offset; |
|
- | 61 | ||
59 | _hardcoded_kernel_size = (ktext_end - ktext_start) + (unmapped_ktext_end - unmapped_ktext_start) + (kdata_end - kdata_start) + (unmapped_kdata_end - unmapped_kdata_start); |
62 | _hardcoded_kernel_size = (ktext_end - ktext_start) + (unmapped_ktext_end - unmapped_ktext_start) + (kdata_end - kdata_start) + (unmapped_kdata_end - unmapped_kdata_start); |
60 | 63 | ||
61 | e820table_boot = e820table - _map_address; |
64 | e820table_boot = e820table - _map_address; |
62 | e820counter_boot = e820counter - _map_address; |
65 | e820counter_boot = e820counter - _map_address; |
- | 66 | ap_bootstrap_gdtr = ap_bootstrap_gdtr_boot + _ka2pa_offset; |
|
63 | } |
67 | } |
64 | 68 |