kernel.ld 4.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191
  1. OUTPUT_FORMAT(elf64-x86-64)
  2. MEMORY
  3. {
  4. MBR (wx) : org = 0x0e00, l = 512
  5. STAGE1 (wx) : org = 0x1000, l = 4K
  6. PHYMEM (w) : org = 0xffffff0000000000, len = 512 * 1024M
  7. PARRAY (w) : org = 0xffffff8000000000, len = 128 * 1024M
  8. KBSS (w) : org = 0xffffffffc0200000, len = 2M
  9. KIMAGE (wx) : org = 0xffffffffffc00000, len = 2M
  10. KPERCPU (w) : org = 0x0000000000000000, len = 128K
  11. }
  12. SECTIONS
  13. {
  14. .mbr : AT(0)
  15. {
  16. KEEP(*(.mbr));
  17. . = 446;
  18. BYTE(0x00);
  19. . = 510;
  20. BYTE(0x55);
  21. BYTE(0xaa);
  22. } > MBR
  23. .stage1 : AT(LOADADDR(.mbr) + SIZEOF(.mbr))
  24. {
  25. KEEP(*(.stage1.smp));
  26. . = ALIGN(16);
  27. *(.stage1)
  28. . = ALIGN(0x1000);
  29. } > STAGE1
  30. .text :
  31. AT(LOADADDR(.stage1) + SIZEOF(.stage1))
  32. {
  33. TEXT_START = .;
  34. *(.text)
  35. *(.text*)
  36. . = ALIGN(0x1000);
  37. TEXT_END = .;
  38. } > KIMAGE
  39. TEXT_PAGES = (TEXT_END - TEXT_START) / 0x1000;
  40. .rodata :
  41. AT(LOADADDR(.text) + SIZEOF(.text))
  42. {
  43. RODATA_START = .;
  44. *(.rodata)
  45. *(.rodata*)
  46. . = ALIGN(16);
  47. start_ctors = .;
  48. KEEP(*(.init_array));
  49. KEEP(*(SORT_BY_INIT_PRIORITY(.init_array*)));
  50. KEEP(*(.ctors));
  51. KEEP(*(SORT_BY_INIT_PRIORITY(.ctors*)));
  52. end_ctors = .;
  53. . = ALIGN(16);
  54. _fix_start = .;
  55. KEEP(*(.fix));
  56. _fix_end = .;
  57. . = ALIGN(16);
  58. BSS_ADDR = .;
  59. QUAD(ABSOLUTE(BSS_START));
  60. BSS_LENGTH = .;
  61. QUAD(BSS_END - BSS_START);
  62. FIX_START = .;
  63. QUAD(ABSOLUTE(_fix_start));
  64. FIX_END = .;
  65. QUAD(ABSOLUTE(_fix_end));
  66. PERCPU_PAGES = .;
  67. QUAD(_PERCPU_PAGES);
  68. . = ALIGN(0x1000);
  69. RODATA_END = .;
  70. } > KIMAGE
  71. RODATA_PAGES = (RODATA_END - RODATA_START) / 0x1000;
  72. .data : AT(LOADADDR(.rodata) + SIZEOF(.rodata))
  73. {
  74. DATA_START = .;
  75. *(.data)
  76. *(.data*)
  77. *(.got)
  78. *(.got.plt)
  79. . = . + 4;
  80. . = ALIGN(0x1000) - 4;
  81. LONG(KERNEL_MAGIC);
  82. DATA_END = .;
  83. } > KIMAGE
  84. DATA_PAGES = (DATA_END - DATA_START) / 0x1000;
  85. _PERCPU_DATA_START = .;
  86. .percpu 0 : AT(LOADADDR(.data) + SIZEOF(.data))
  87. {
  88. PERCPU_START = .;
  89. QUAD(0); /* Reserved for x86 percpu pointer */
  90. QUAD(0);
  91. *(.percpu .percpu*)
  92. . = ALIGN(0x1000);
  93. PERCPU_END = .;
  94. } > KPERCPU
  95. _PERCPU_LENGTH = PERCPU_END - PERCPU_START;
  96. _PERCPU_PAGES = _PERCPU_LENGTH / 0x1000;
  97. .bss :
  98. {
  99. BSS_START = .;
  100. *(.bss)
  101. *(.bss*)
  102. . = ALIGN(0x1000);
  103. BSS_END = .;
  104. } > KBSS
  105. KIMAGE_PAGES = TEXT_PAGES + RODATA_PAGES + _PERCPU_PAGES + DATA_PAGES;
  106. BSS_PAGES = (BSS_END - BSS_START) / 0x1000;
  107. KERNEL_MAGIC = 0x01145140;
  108. KIMAGE_32K_COUNT = (KIMAGE_PAGES * 0x1000 + 32 * 1024 - 1) / (32 * 1024);
  109. .eh_frame :
  110. AT(LOADADDR(.percpu) + SIZEOF(.percpu))
  111. {
  112. KEEP(*(.eh_frame*))
  113. . = ALIGN(0x1000);
  114. } > KIMAGE
  115. /* Stabs debugging sections. */
  116. .stab 0 : { KEEP(*(.stab)); }
  117. .stabstr 0 : { KEEP(*(.stabstr)); }
  118. .stab.excl 0 : { KEEP(*(.stab.excl)); }
  119. .stab.exclstr 0 : { KEEP(*(.stab.exclstr)); }
  120. .stab.index 0 : { KEEP(*(.stab.index)); }
  121. .stab.indexstr 0 : { KEEP(*(.stab.indexstr)); }
  122. .comment 0 : { KEEP(*(.comment)); }
  123. /* DWARF debug sections.
  124. Symbols in the DWARF debugging sections are relative to the beginning
  125. of the section so we begin them at 0. */
  126. /* DWARF 1 */
  127. .debug 0 : { KEEP(*(.debug)); }
  128. .line 0 : { KEEP(*(.line)); }
  129. /* GNU DWARF 1 extensions */
  130. .debug_srcinfo 0 : { KEEP(*(.debug_srcinfo)); }
  131. .debug_sfnames 0 : { KEEP(*(.debug_sfnames)); }
  132. /* DWARF 1.1 and DWARF 2 */
  133. .debug_aranges 0 : { KEEP(*(.debug_aranges)); }
  134. .debug_pubnames 0 : { KEEP(*(.debug_pubnames)); }
  135. /* DWARF 2 */
  136. .debug_info 0 : { KEEP(*(.debug_info)); }
  137. .debug_abbrev 0 : { KEEP(*(.debug_abbrev)); }
  138. .debug_line 0 : { KEEP(*(.debug_line)); }
  139. .debug_frame 0 : { KEEP(*(.debug_frame)); }
  140. .debug_str 0 : { KEEP(*(.debug_str)); }
  141. .debug_loc 0 : { KEEP(*(.debug_loc)); }
  142. .debug_macinfo 0 : { KEEP(*(.debug_macinfo)); }
  143. /* SGI/MIPS DWARF 2 extensions */
  144. .debug_weaknames 0 : { KEEP(*(.debug_weaknames)); }
  145. .debug_funcnames 0 : { KEEP(*(.debug_funcnames)); }
  146. .debug_typenames 0 : { KEEP(*(.debug_typenames)); }
  147. .debug_varnames 0 : { KEEP(*(.debug_varnames)); }
  148. /* DWARF Other */
  149. .debug_ranges 0 : { KEEP(*(.debug_ranges)); }
  150. .debug_line_str 0 : { KEEP(*(.debug_line_str)); }
  151. /* Rust stuff */
  152. /DISCARD/ :
  153. {
  154. *(.fini_array*)
  155. *(.note*)
  156. *(.dtors*)
  157. *(.debug_gdb_scripts*)
  158. }
  159. }