vmlinux.lds.S 3.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178
  1. /*
  2. * ld script to make SuperH Linux kernel
  3. * Written by Niibe Yutaka and Paul Mundt
  4. */
  5. #ifdef CONFIG_SUPERH64
  6. #define LOAD_OFFSET CONFIG_PAGE_OFFSET
  7. OUTPUT_ARCH(sh:sh5)
  8. #else
  9. #define LOAD_OFFSET 0
  10. OUTPUT_ARCH(sh)
  11. #endif
  12. #include <asm/thread_info.h>
  13. #include <asm/cache.h>
  14. #include <asm-generic/vmlinux.lds.h>
  15. ENTRY(_start)
  16. SECTIONS
  17. {
  18. #ifdef CONFIG_PMB_FIXED
  19. . = CONFIG_PAGE_OFFSET + (CONFIG_MEMORY_START & 0x1fffffff) +
  20. CONFIG_ZERO_PAGE_OFFSET;
  21. #elif defined(CONFIG_32BIT)
  22. . = CONFIG_PAGE_OFFSET + CONFIG_ZERO_PAGE_OFFSET;
  23. #else
  24. . = CONFIG_PAGE_OFFSET + CONFIG_MEMORY_START + CONFIG_ZERO_PAGE_OFFSET;
  25. #endif
  26. _text = .; /* Text and read-only data */
  27. .empty_zero_page : AT(ADDR(.empty_zero_page) - LOAD_OFFSET) {
  28. *(.empty_zero_page)
  29. } = 0
  30. .text : AT(ADDR(.text) - LOAD_OFFSET) {
  31. HEAD_TEXT
  32. TEXT_TEXT
  33. #ifdef CONFIG_SUPERH64
  34. *(.text64)
  35. *(.text..SHmedia32)
  36. #endif
  37. SCHED_TEXT
  38. LOCK_TEXT
  39. KPROBES_TEXT
  40. IRQENTRY_TEXT
  41. *(.fixup)
  42. *(.gnu.warning)
  43. _etext = .; /* End of text section */
  44. } = 0x0009
  45. . = ALIGN(16); /* Exception table */
  46. __ex_table : AT(ADDR(__ex_table) - LOAD_OFFSET) {
  47. __start___ex_table = .;
  48. *(__ex_table)
  49. __stop___ex_table = .;
  50. }
  51. NOTES
  52. RO_DATA(PAGE_SIZE)
  53. /*
  54. * Code which must be executed uncached and the associated data
  55. */
  56. . = ALIGN(PAGE_SIZE);
  57. .uncached : AT(ADDR(.uncached) - LOAD_OFFSET) {
  58. __uncached_start = .;
  59. *(.uncached.text)
  60. *(.uncached.data)
  61. __uncached_end = .;
  62. }
  63. . = ALIGN(THREAD_SIZE);
  64. .data : AT(ADDR(.data) - LOAD_OFFSET) { /* Data */
  65. *(.data.init_task)
  66. . = ALIGN(L1_CACHE_BYTES);
  67. *(.data.cacheline_aligned)
  68. . = ALIGN(L1_CACHE_BYTES);
  69. *(.data.read_mostly)
  70. . = ALIGN(PAGE_SIZE);
  71. *(.data.page_aligned)
  72. __nosave_begin = .;
  73. *(.data.nosave)
  74. . = ALIGN(PAGE_SIZE);
  75. __nosave_end = .;
  76. DATA_DATA
  77. CONSTRUCTORS
  78. }
  79. _edata = .; /* End of data section */
  80. . = ALIGN(PAGE_SIZE); /* Init code and data */
  81. .init.text : AT(ADDR(.init.text) - LOAD_OFFSET) {
  82. __init_begin = .;
  83. _sinittext = .;
  84. INIT_TEXT
  85. _einittext = .;
  86. }
  87. .init.data : AT(ADDR(.init.data) - LOAD_OFFSET) { INIT_DATA }
  88. . = ALIGN(16);
  89. .init.setup : AT(ADDR(.init.setup) - LOAD_OFFSET) {
  90. __setup_start = .;
  91. *(.init.setup)
  92. __setup_end = .;
  93. }
  94. .initcall.init : AT(ADDR(.initcall.init) - LOAD_OFFSET) {
  95. __initcall_start = .;
  96. INITCALLS
  97. __initcall_end = .;
  98. }
  99. .con_initcall.init : AT(ADDR(.con_initcall.init) - LOAD_OFFSET) {
  100. __con_initcall_start = .;
  101. *(.con_initcall.init)
  102. __con_initcall_end = .;
  103. }
  104. SECURITY_INIT
  105. #ifdef CONFIG_BLK_DEV_INITRD
  106. . = ALIGN(PAGE_SIZE);
  107. .init.ramfs : AT(ADDR(.init.ramfs) - LOAD_OFFSET) {
  108. __initramfs_start = .;
  109. *(.init.ramfs)
  110. __initramfs_end = .;
  111. }
  112. #endif
  113. . = ALIGN(4);
  114. .machvec.init : AT(ADDR(.machvec.init) - LOAD_OFFSET) {
  115. __machvec_start = .;
  116. *(.machvec.init)
  117. __machvec_end = .;
  118. }
  119. PERCPU(PAGE_SIZE)
  120. /*
  121. * .exit.text is discarded at runtime, not link time, to deal with
  122. * references from __bug_table
  123. */
  124. .exit.text : AT(ADDR(.exit.text) - LOAD_OFFSET) { EXIT_TEXT }
  125. .exit.data : AT(ADDR(.exit.data) - LOAD_OFFSET) { EXIT_DATA }
  126. . = ALIGN(PAGE_SIZE);
  127. .bss : AT(ADDR(.bss) - LOAD_OFFSET) {
  128. __init_end = .;
  129. __bss_start = .; /* BSS */
  130. *(.bss.page_aligned)
  131. *(.bss)
  132. *(COMMON)
  133. . = ALIGN(4);
  134. _ebss = .; /* uClinux MTD sucks */
  135. _end = . ;
  136. }
  137. /*
  138. * When something in the kernel is NOT compiled as a module, the
  139. * module cleanup code and data are put into these segments. Both
  140. * can then be thrown away, as cleanup code is never called unless
  141. * it's a module.
  142. */
  143. /DISCARD/ : {
  144. *(.exitcall.exit)
  145. }
  146. STABS_DEBUG
  147. DWARF_DEBUG
  148. }