kernel.ld 4.5 KB

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