vmlinux.lds.S 2.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172
  1. #define VMLINUX_SYMBOL(_sym_) _##_sym_
  2. #include <asm-generic/vmlinux.lds.h>
  3. #include <linux/config.h>
  4. /* target memory map */
  5. #ifdef CONFIG_H8300H_GENERIC
  6. #define ROMTOP 0x000000
  7. #define ROMSIZE 0x400000
  8. #define RAMTOP 0x400000
  9. #define RAMSIZE 0x400000
  10. #endif
  11. #ifdef CONFIG_H8300H_AKI3068NET
  12. #define ROMTOP 0x000000
  13. #define ROMSIZE 0x080000
  14. #define RAMTOP 0x400000
  15. #define RAMSIZE 0x200000
  16. #endif
  17. #ifdef CONFIG_H8300H_H8MAX
  18. #define ROMTOP 0x000000
  19. #define ROMSIZE 0x080000
  20. #define RAMTOP 0x400000
  21. #define RAMSIZE 0x200000
  22. #endif
  23. #ifdef CONFIG_H8300H_SIM
  24. #define ROMTOP 0x000000
  25. #define ROMSIZE 0x400000
  26. #define RAMTOP 0x400000
  27. #define RAMSIZE 0x400000
  28. #endif
  29. #ifdef CONFIG_H8S_SIM
  30. #define ROMTOP 0x000000
  31. #define ROMSIZE 0x400000
  32. #define RAMTOP 0x400000
  33. #define RAMSIZE 0x800000
  34. #endif
  35. #ifdef CONFIG_H8S_EDOSK2674
  36. #define ROMTOP 0x000000
  37. #define ROMSIZE 0x400000
  38. #define RAMTOP 0x400000
  39. #define RAMSIZE 0x800000
  40. #endif
  41. #if defined(CONFIG_H8300H_SIM) || defined(CONFIG_H8S_SIM)
  42. INPUT(romfs.o)
  43. #endif
  44. _jiffies = _jiffies_64 + 4;
  45. ENTRY(__start)
  46. SECTIONS
  47. {
  48. #if defined(CONFIG_ROMKERNEL)
  49. . = ROMTOP;
  50. .vectors :
  51. {
  52. __vector = . ;
  53. *(.vectors*)
  54. }
  55. #else
  56. . = RAMTOP;
  57. .bootvec :
  58. {
  59. *(.bootvec)
  60. }
  61. #endif
  62. .text :
  63. {
  64. #if defined(CONFIG_ROMKERNEL)
  65. *(.int_redirect)
  66. #endif
  67. __stext = . ;
  68. *(.text)
  69. SCHED_TEXT
  70. LOCK_TEXT
  71. __etext = . ;
  72. . = ALIGN(16); /* Exception table */
  73. ___start___ex_table = .;
  74. *(__ex_table)
  75. ___stop___ex_table = .;
  76. }
  77. RODATA
  78. #if defined(CONFIG_ROMKERNEL)
  79. SECURITY_INIT
  80. #endif
  81. ROEND = .;
  82. #if defined(CONFIG_ROMKERNEL)
  83. . = RAMTOP;
  84. .data : AT(ROEND)
  85. #else
  86. .data :
  87. #endif
  88. {
  89. __sdata = . ;
  90. ___data_start = . ;
  91. . = ALIGN(0x2000) ;
  92. *(.data.init_task)
  93. . = ALIGN(0x4) ;
  94. *(.data)
  95. . = ALIGN(0x4) ;
  96. *(.data.*)
  97. . = ALIGN(0x4) ;
  98. ___init_begin = .;
  99. __sinittext = .;
  100. *(.init.text)
  101. __einittext = .;
  102. *(.init.data)
  103. . = ALIGN(0x4) ;
  104. ___setup_start = .;
  105. *(.init.setup)
  106. . = ALIGN(0x4) ;
  107. ___setup_end = .;
  108. ___initcall_start = .;
  109. *(.initcall1.init)
  110. *(.initcall2.init)
  111. *(.initcall3.init)
  112. *(.initcall4.init)
  113. *(.initcall5.init)
  114. *(.initcall6.init)
  115. *(.initcall7.init)
  116. ___initcall_end = .;
  117. ___con_initcall_start = .;
  118. *(.con_initcall.init)
  119. ___con_initcall_end = .;
  120. *(.exit.text)
  121. *(.exit.data)
  122. . = ALIGN(4);
  123. ___initramfs_start = .;
  124. *(.init.ramfs)
  125. ___initramfs_end = .;
  126. . = ALIGN(0x4) ;
  127. ___init_end = .;
  128. __edata = . ;
  129. }
  130. #if defined(CONFIG_RAMKERNEL)
  131. SECURITY_INIT
  132. #endif
  133. __begin_data = LOADADDR(.data);
  134. .bss :
  135. {
  136. . = ALIGN(0x4) ;
  137. __sbss = . ;
  138. *(.bss*)
  139. . = ALIGN(0x4) ;
  140. *(COMMON)
  141. . = ALIGN(0x4) ;
  142. __ebss = . ;
  143. __end = . ;
  144. __ramstart = .;
  145. }
  146. /DISCARD/ : {
  147. *(.exitcall.exit)
  148. }
  149. .romfs :
  150. {
  151. *(.romfs*)
  152. }
  153. . = RAMTOP+RAMSIZE;
  154. .dummy :
  155. {
  156. COMMAND_START = . - 0x200 ;
  157. __ramend = . ;
  158. }
  159. }