vmlinux.lds.S 3.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163
  1. #include <asm/asm-offsets.h>
  2. #include <asm/page.h>
  3. #include <asm-generic/vmlinux.lds.h>
  4. #undef mips
  5. #define mips mips
  6. OUTPUT_ARCH(mips)
  7. ENTRY(kernel_entry)
  8. PHDRS {
  9. text PT_LOAD FLAGS(7); /* RWX */
  10. note PT_NOTE FLAGS(4); /* R__ */
  11. }
  12. #ifdef CONFIG_32BIT
  13. #ifdef CONFIG_CPU_LITTLE_ENDIAN
  14. jiffies = jiffies_64;
  15. #else
  16. jiffies = jiffies_64 + 4;
  17. #endif
  18. #else
  19. jiffies = jiffies_64;
  20. #endif
  21. SECTIONS
  22. {
  23. #ifdef CONFIG_BOOT_ELF64
  24. /* Read-only sections, merged into text segment: */
  25. /* . = 0xc000000000000000; */
  26. /* This is the value for an Origin kernel, taken from an IRIX kernel. */
  27. /* . = 0xc00000000001c000; */
  28. /* Set the vaddr for the text segment to a value
  29. * >= 0xa800 0000 0001 9000 if no symmon is going to configured
  30. * >= 0xa800 0000 0030 0000 otherwise
  31. */
  32. /* . = 0xa800000000300000; */
  33. . = 0xffffffff80300000;
  34. #endif
  35. . = VMLINUX_LOAD_ADDRESS;
  36. /* read-only */
  37. _text = .; /* Text and read-only data */
  38. .text : {
  39. TEXT_TEXT
  40. SCHED_TEXT
  41. LOCK_TEXT
  42. KPROBES_TEXT
  43. IRQENTRY_TEXT
  44. *(.text.*)
  45. *(.fixup)
  46. *(.gnu.warning)
  47. } :text = 0
  48. _etext = .; /* End of text section */
  49. EXCEPTION_TABLE(16)
  50. /* Exception table for data bus errors */
  51. __dbe_table : {
  52. __start___dbe_table = .;
  53. *(__dbe_table)
  54. __stop___dbe_table = .;
  55. }
  56. NOTES :text :note
  57. .dummy : { *(.dummy) } :text
  58. RODATA
  59. /* writeable */
  60. .data : { /* Data */
  61. . = . + DATAOFFSET; /* for CONFIG_MAPPED_KERNEL */
  62. INIT_TASK_DATA(PAGE_SIZE)
  63. NOSAVE_DATA
  64. CACHELINE_ALIGNED_DATA(1 << CONFIG_MIPS_L1_CACHE_SHIFT)
  65. READ_MOSTLY_DATA(1 << CONFIG_MIPS_L1_CACHE_SHIFT)
  66. DATA_DATA
  67. CONSTRUCTORS
  68. }
  69. _gp = . + 0x8000;
  70. .lit8 : {
  71. *(.lit8)
  72. }
  73. .lit4 : {
  74. *(.lit4)
  75. }
  76. /* We want the small data sections together, so single-instruction offsets
  77. can access them all, and initialized data all before uninitialized, so
  78. we can shorten the on-disk segment size. */
  79. .sdata : {
  80. *(.sdata)
  81. }
  82. _edata = .; /* End of data section */
  83. /* will be freed after init */
  84. . = ALIGN(PAGE_SIZE); /* Init code and data */
  85. __init_begin = .;
  86. INIT_TEXT_SECTION(PAGE_SIZE)
  87. INIT_DATA_SECTION(16)
  88. . = ALIGN(4);
  89. .mips.machines.init : AT(ADDR(.mips.machines.init) - LOAD_OFFSET) {
  90. __mips_machines_start = .;
  91. *(.mips.machines.init)
  92. __mips_machines_end = .;
  93. }
  94. /* .exit.text is discarded at runtime, not link time, to deal with
  95. * references from .rodata
  96. */
  97. .exit.text : {
  98. EXIT_TEXT
  99. }
  100. .exit.data : {
  101. EXIT_DATA
  102. }
  103. PERCPU(1 << CONFIG_MIPS_L1_CACHE_SHIFT, PAGE_SIZE)
  104. . = ALIGN(PAGE_SIZE);
  105. __init_end = .;
  106. /* freed after init ends here */
  107. BSS_SECTION(0, 0, 0)
  108. _end = . ;
  109. /* These mark the ABI of the kernel for debuggers. */
  110. .mdebug.abi32 : {
  111. KEEP(*(.mdebug.abi32))
  112. }
  113. .mdebug.abi64 : {
  114. KEEP(*(.mdebug.abi64))
  115. }
  116. /* This is the MIPS specific mdebug section. */
  117. .mdebug : {
  118. *(.mdebug)
  119. }
  120. STABS_DEBUG
  121. DWARF_DEBUG
  122. /* These must appear regardless of . */
  123. .gptab.sdata : {
  124. *(.gptab.data)
  125. *(.gptab.sdata)
  126. }
  127. .gptab.sbss : {
  128. *(.gptab.bss)
  129. *(.gptab.sbss)
  130. }
  131. /* Sections to be discarded */
  132. DISCARDS
  133. /DISCARD/ : {
  134. /* ABI crap starts here */
  135. *(.MIPS.options)
  136. *(.options)
  137. *(.pdr)
  138. *(.reginfo)
  139. }
  140. }