sdram.ld 3.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168
  1. OUTPUT_ARCH( "riscv" )
  2. ENTRY( _start )
  3. MEMORY
  4. {
  5. flash (rxai!w) : ORIGIN = 0x20400000, LENGTH = 16M
  6. ram (wxa!ri) : ORIGIN = 0x80000000, LENGTH = 16K
  7. }
  8. PHDRS
  9. {
  10. flash PT_LOAD;
  11. ram_init PT_LOAD;
  12. ram PT_NULL;
  13. }
  14. SECTIONS
  15. {
  16. __stack_size = DEFINED(__stack_size) ? __stack_size : 512;
  17. . = 0x20400000;
  18. . = ALIGN(4);
  19. .init :
  20. {
  21. KEEP (*(SORT_NONE(.init)))
  22. } >flash AT>flash :flash
  23. .text :
  24. {
  25. *(.init)
  26. __init_end__ = .;
  27. *(.text)
  28. *(.gnu.linkonce.t*)
  29. /* section information for finsh shell */
  30. . = ALIGN(4);
  31. __fsymtab_start = .;
  32. KEEP(*(FSymTab))
  33. __fsymtab_end = .;
  34. . = ALIGN(4);
  35. __vsymtab_start = .;
  36. KEEP(*(VSymTab))
  37. __vsymtab_end = .;
  38. . = ALIGN(4);
  39. . = ALIGN(4);
  40. __rt_init_start = .;
  41. KEEP(*(SORT(.rti_fn*)))
  42. __rt_init_end = .;
  43. . = ALIGN(4);
  44. /* section information for modules */
  45. . = ALIGN(4);
  46. __rtmsymtab_start = .;
  47. KEEP(*(RTMSymTab))
  48. __rtmsymtab_end = .;
  49. }>flash AT>flash :flash
  50. .fini :
  51. {
  52. KEEP (*(SORT_NONE(.fini)))
  53. } >flash AT>flash :flash
  54. PROVIDE (__etext = .);
  55. PROVIDE (_etext = .);
  56. PROVIDE (etext = .);
  57. . = ALIGN(4);
  58. .rodata : {
  59. *(.rodata) ;
  60. *(.rodata.*) ;
  61. *(.gnu.linkonce.r*) ;
  62. *(.eh_frame)
  63. }>flash AT>flash :flash
  64. . = ALIGN(4);
  65. .ctors :
  66. {
  67. PROVIDE(__ctors_start__ = .);
  68. KEEP(*(SORT(.ctors.*)))
  69. KEEP(*(.ctors))
  70. PROVIDE(__ctors_end__ = .);
  71. }>flash AT>flash :flash
  72. .dtors :
  73. {
  74. PROVIDE(__dtors_start__ = .);
  75. KEEP(*(SORT(.dtors.*)))
  76. KEEP(*(.dtors))
  77. PROVIDE(__dtors_end__ = .);
  78. }>flash AT>flash :flash
  79. .lalign :
  80. {
  81. . = ALIGN(4);
  82. PROVIDE( _data_lma = . );
  83. } >flash AT>flash :flash
  84. .dalign :
  85. {
  86. . = ALIGN(4);
  87. PROVIDE( _data = . );
  88. } >ram AT>flash :ram_init
  89. . = ALIGN(4);
  90. .data :
  91. {
  92. *(.data)
  93. *(.data.*)
  94. . = ALIGN(8);
  95. PROVIDE( __global_pointer$ = . + 0x800 );
  96. *(.sdata .sdata.*)
  97. *(.gnu.linkonce.s.*)
  98. . = ALIGN(8);
  99. *(.srodata.cst16)
  100. *(.srodata.cst8)
  101. *(.srodata.cst4)
  102. *(.srodata.cst2)
  103. *(.srodata .srodata.*)
  104. *(.gnu.linkonce.d*)
  105. }>ram AT>flash :ram_init
  106. . = ALIGN(4);
  107. .nobss : { *(.nobss) }
  108. . = ALIGN(4);
  109. PROVIDE( _edata = . );
  110. PROVIDE( edata = . );
  111. PROVIDE( _fbss = . );
  112. PROVIDE( __bss_start = . );
  113. __bss_start__ = .;
  114. .bss : {
  115. *(.bss)
  116. *(.sbss*)
  117. *(.gnu.linkonce.sb.*)
  118. *(.bss .bss.*)
  119. *(.gnu.linkonce.b.*)
  120. *(COMMON)
  121. . = ALIGN(4);
  122. }>ram AT>flash :ram
  123. _end = .;
  124. __bss_end__ = .;
  125. .stack ORIGIN(ram) + LENGTH(ram) - __stack_size :
  126. {
  127. PROVIDE( _heap_end = . );
  128. . = __stack_size;
  129. PROVIDE( _sp = . );
  130. } >ram AT>ram :ram
  131. /* stabs debugging sections. */
  132. .stab 0 : { *(.stab) }
  133. .stabstr 0 : { *(.stabstr) }
  134. .stab.excl 0 : { *(.stab.excl) }
  135. .stab.exclstr 0 : { *(.stab.exclstr) }
  136. .stab.index 0 : { *(.stab.index) }
  137. .stab.indexstr 0 : { *(.stab.indexstr) }
  138. .comment 0 : { *(.comment) }
  139. .debug_abbrev 0 : { *(.debug_abbrev) }
  140. .debug_info 0 : { *(.debug_info) }
  141. .debug_line 0 : { *(.debug_line) }
  142. .debug_pubnames 0 : { *(.debug_pubnames) }
  143. .debug_aranges 0 : { *(.debug_aranges) }
  144. }