vmlinux.lds.S 2.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155
  1. #include <asm-generic/vmlinux.lds.h>
  2. #include <asm/page.h>
  3. /* target memory map */
  4. #ifdef CONFIG_H8300H_GENERIC
  5. #define ROMTOP 0x000000
  6. #define ROMSIZE 0x400000
  7. #define RAMTOP 0x400000
  8. #define RAMSIZE 0x400000
  9. #endif
  10. #ifdef CONFIG_H8300H_AKI3068NET
  11. #define ROMTOP 0x000000
  12. #define ROMSIZE 0x080000
  13. #define RAMTOP 0x400000
  14. #define RAMSIZE 0x200000
  15. #endif
  16. #ifdef CONFIG_H8300H_H8MAX
  17. #define ROMTOP 0x000000
  18. #define ROMSIZE 0x080000
  19. #define RAMTOP 0x400000
  20. #define RAMSIZE 0x200000
  21. #endif
  22. #ifdef CONFIG_H8300H_SIM
  23. #define ROMTOP 0x000000
  24. #define ROMSIZE 0x400000
  25. #define RAMTOP 0x400000
  26. #define RAMSIZE 0x400000
  27. #endif
  28. #ifdef CONFIG_H8S_SIM
  29. #define ROMTOP 0x000000
  30. #define ROMSIZE 0x400000
  31. #define RAMTOP 0x400000
  32. #define RAMSIZE 0x800000
  33. #endif
  34. #ifdef CONFIG_H8S_EDOSK2674
  35. #define ROMTOP 0x000000
  36. #define ROMSIZE 0x400000
  37. #define RAMTOP 0x400000
  38. #define RAMSIZE 0x800000
  39. #endif
  40. #if defined(CONFIG_H8300H_SIM) || defined(CONFIG_H8S_SIM)
  41. INPUT(romfs.o)
  42. #endif
  43. _jiffies = _jiffies_64 + 4;
  44. ENTRY(__start)
  45. SECTIONS
  46. {
  47. #if defined(CONFIG_ROMKERNEL)
  48. . = ROMTOP;
  49. .vectors :
  50. {
  51. __vector = . ;
  52. *(.vectors*)
  53. }
  54. #else
  55. . = RAMTOP;
  56. .bootvec :
  57. {
  58. *(.bootvec)
  59. }
  60. #endif
  61. .text :
  62. {
  63. _text = .;
  64. #if defined(CONFIG_ROMKERNEL)
  65. *(.int_redirect)
  66. #endif
  67. __stext = . ;
  68. TEXT_TEXT
  69. SCHED_TEXT
  70. LOCK_TEXT
  71. __etext = . ;
  72. }
  73. EXCEPTION_TABLE(16)
  74. RODATA
  75. #if defined(CONFIG_ROMKERNEL)
  76. SECURITY_INIT
  77. #endif
  78. ROEND = .;
  79. #if defined(CONFIG_ROMKERNEL)
  80. . = RAMTOP;
  81. .data : AT(ROEND)
  82. #else
  83. .data :
  84. #endif
  85. {
  86. __sdata = . ;
  87. ___data_start = . ;
  88. INIT_TASK_DATA(0x2000)
  89. . = ALIGN(0x4) ;
  90. DATA_DATA
  91. . = ALIGN(0x4) ;
  92. *(.data.*)
  93. . = ALIGN(0x4) ;
  94. ___init_begin = .;
  95. __sinittext = .;
  96. INIT_TEXT
  97. __einittext = .;
  98. INIT_DATA
  99. . = ALIGN(0x4) ;
  100. INIT_SETUP(0x4)
  101. ___setup_start = .;
  102. *(.init.setup)
  103. . = ALIGN(0x4) ;
  104. ___setup_end = .;
  105. INIT_CALLS
  106. CON_INITCALL
  107. EXIT_TEXT
  108. EXIT_DATA
  109. INIT_RAM_FS
  110. . = ALIGN(0x4) ;
  111. ___init_end = .;
  112. __edata = . ;
  113. }
  114. #if defined(CONFIG_RAMKERNEL)
  115. SECURITY_INIT
  116. #endif
  117. __begin_data = LOADADDR(.data);
  118. .bss :
  119. {
  120. . = ALIGN(0x4) ;
  121. __sbss = . ;
  122. *(.bss*)
  123. . = ALIGN(0x4) ;
  124. *(COMMON)
  125. . = ALIGN(0x4) ;
  126. __ebss = . ;
  127. __end = . ;
  128. __ramstart = .;
  129. }
  130. .romfs :
  131. {
  132. *(.romfs*)
  133. }
  134. . = RAMTOP+RAMSIZE;
  135. .dummy :
  136. {
  137. COMMAND_START = . - 0x200 ;
  138. __ramend = . ;
  139. }
  140. DISCARDS
  141. }