Rev 532 | Rev 602 | Go to most recent revision | Details | Compare with Previous | Last modification | View Log | RSS feed
| Rev | Author | Line No. | Line |
|---|---|---|---|
| 65 | decky | 1 | /** IA-32 linker script |
| 1 | jermar | 2 | * |
| 105 | jermar | 3 | * umapped section: |
| 4 | * kernel text |
||
| 5 | * kernel data |
||
| 6 | * mapped section: |
||
| 7 | * kernel text |
||
| 8 | * kernel data |
||
| 1 | jermar | 9 | */ |
| 10 | |||
| 301 | palkovsky | 11 | #define __ASM__ |
| 12 | #include <arch/boot/boot.h> |
||
| 13 | #include <arch/mm/page.h> |
||
| 14 | |||
| 1 | jermar | 15 | ENTRY(kernel_image_start) |
| 16 | |||
| 17 | SECTIONS { |
||
| 301 | palkovsky | 18 | .unmapped BOOTSTRAP_OFFSET: AT (BOOTSTRAP_OFFSET) { |
| 106 | jermar | 19 | unmapped_ktext_start = .; |
| 20 | *(K_TEXT_START); |
||
| 110 | jermar | 21 | *(K_TEXT_START_2); |
| 106 | jermar | 22 | unmapped_ktext_end = .; |
| 381 | jermar | 23 | |
| 106 | jermar | 24 | unmapped_kdata_start = .; |
| 25 | *(K_DATA_START); |
||
| 26 | unmapped_kdata_end = .; |
||
| 27 | } |
||
| 267 | decky | 28 | |
| 301 | palkovsky | 29 | .mapped (PA2KA(BOOT_OFFSET+BOOTSTRAP_OFFSET)+SIZEOF(.unmapped)): AT (BOOTSTRAP_OFFSET+SIZEOF(.unmapped)) { |
| 106 | jermar | 30 | ktext_start = .; |
| 328 | jermar | 31 | *(BOOT_DATA); |
| 106 | jermar | 32 | *(.text); |
| 33 | ktext_end = .; |
||
| 267 | decky | 34 | |
| 106 | jermar | 35 | kdata_start = .; |
| 334 | jermar | 36 | *(.data); /* initialized data */ |
| 37 | *(.rodata*); /* string literals */ |
||
| 38 | *(COMMON); /* global variables */ |
||
| 216 | palkovsky | 39 | hardcoded_load_address = .; |
| 301 | palkovsky | 40 | LONG(PA2KA(BOOT_OFFSET+BOOTSTRAP_OFFSET)); |
| 216 | palkovsky | 41 | hardcoded_ktext_size = .; |
| 328 | jermar | 42 | LONG((ktext_end - ktext_start) + (unmapped_ktext_end - unmapped_ktext_start)); |
| 216 | palkovsky | 43 | hardcoded_kdata_size = .; |
| 328 | jermar | 44 | LONG((kdata_end - kdata_start) + (unmapped_kdata_end - unmapped_kdata_start)); |
| 267 | decky | 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); |
||
| 334 | jermar | 49 | *(.bss); /* uninitialized static variables */ |
| 268 | palkovsky | 50 | symbol_table = .; |
| 334 | jermar | 51 | *(symtab.*); /* Symbol table, must be LAST symbol! */ |
| 268 | palkovsky | 52 | |
| 106 | jermar | 53 | kdata_end = .; |
| 54 | } |
||
| 381 | jermar | 55 | |
| 56 | /DISCARD/ : { |
||
| 57 | *(.note.GNU-stack); |
||
| 58 | *(.comment); |
||
| 59 | } |
||
| 60 | |||
| 235 | decky | 61 | |
| 62 | _hardcoded_kernel_size = (ktext_end - ktext_start) + (unmapped_ktext_end - unmapped_ktext_start) + (kdata_end - kdata_start) + (unmapped_kdata_end - unmapped_kdata_start); |
||
| 285 | decky | 63 | _hardcoded_unmapped_size = (unmapped_ktext_end - unmapped_ktext_start) + (unmapped_kdata_end - unmapped_kdata_start); |
| 267 | decky | 64 | |
| 301 | palkovsky | 65 | e820table_boot = KA2PA(e820table) - BOOT_OFFSET; |
| 66 | e820counter_boot = KA2PA(e820counter) - BOOT_OFFSET; |
||
| 67 | real_bootstrap_gdtr = PA2KA(real_bootstrap_gdtr_boot); |
||
| 1 | jermar | 68 | } |