link.lds 2.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137
  1. OUTPUT_FORMAT("elf32-littlearm", "elf32-littlearm", "elf32-littlearm")
  2. OUTPUT_ARCH(arm)
  3. ENTRY(_boot)
  4. SECTIONS
  5. {
  6. . = 0x80080000;
  7. .text :
  8. {
  9. *(.boot)
  10. . = ALIGN(64);
  11. *(.vectors)
  12. *(.text)
  13. *(.text.*)
  14. /* section information for utest */
  15. . = ALIGN(4);
  16. __rt_utest_tc_tab_start = .;
  17. KEEP(*(UtestTcTab))
  18. __rt_utest_tc_tab_end = .;
  19. /* section information for finsh shell */
  20. . = ALIGN(4);
  21. __fsymtab_start = .;
  22. KEEP(*(FSymTab))
  23. __fsymtab_end = .;
  24. . = ALIGN(4);
  25. __vsymtab_start = .;
  26. KEEP(*(VSymTab))
  27. __vsymtab_end = .;
  28. . = ALIGN(4);
  29. /* section information for modules */
  30. . = ALIGN(4);
  31. __rtmsymtab_start = .;
  32. KEEP(*(RTMSymTab))
  33. __rtmsymtab_end = .;
  34. /* section information for initialization */
  35. . = ALIGN(4);
  36. __rt_init_start = .;
  37. KEEP(*(SORT(.rti_fn*)))
  38. __rt_init_end = .;
  39. /* section information for usb usbh_class_info */
  40. . = ALIGN(4);
  41. __usbh_class_info_start__ = .;
  42. KEEP(*(.usbh_class_info))
  43. . = ALIGN(4);
  44. __usbh_class_info_end__ = .;
  45. } =0
  46. __text_end = .;
  47. .ARM.exidx :
  48. {
  49. __exidx_start = .;
  50. *(.ARM.exidx* .gnu.linkonce.armexidx.*)
  51. __exidx_end = .;
  52. }
  53. __rodata_start = .;
  54. .rodata : { *(.rodata) *(.rodata.*) }
  55. __rodata_end = .;
  56. . = ALIGN(4);
  57. .ctors :
  58. {
  59. PROVIDE(__ctors_start__ = .);
  60. /* new GCC version uses .init_array */
  61. KEEP(*(SORT(.init_array.*)))
  62. KEEP(*(.init_array))
  63. PROVIDE(__ctors_end__ = .);
  64. }
  65. .dtors :
  66. {
  67. PROVIDE(__dtors_start__ = .);
  68. KEEP(*(SORT(.dtors.*)))
  69. KEEP(*(.dtors))
  70. PROVIDE(__dtors_end__ = .);
  71. }
  72. . = ALIGN(16 * 1024);
  73. .l1_page_table :
  74. {
  75. __l1_page_table_start = .;
  76. . += 16K;
  77. }
  78. . = ALIGN(8);
  79. __data_start = .;
  80. .data :
  81. {
  82. *(.data)
  83. *(.data.*)
  84. }
  85. __data_end = .;
  86. . = ALIGN(8);
  87. __bss_start = .;
  88. .bss :
  89. {
  90. *(.bss)
  91. *(.bss.*)
  92. *(COMMON)
  93. . = ALIGN(4);
  94. }
  95. . = ALIGN(4);
  96. __bss_end = .;
  97. .heap :
  98. {
  99. . = ALIGN(8);
  100. __end__ = .;
  101. PROVIDE(end = .);
  102. __HeapBase = .;
  103. . += 0x400;
  104. __HeapLimit = .;
  105. __heap_limit = .; /* Add for _sbrk */
  106. }
  107. /* Stabs debugging sections. */
  108. .stab 0 : { *(.stab) }
  109. .stabstr 0 : { *(.stabstr) }
  110. .stab.excl 0 : { *(.stab.excl) }
  111. .stab.exclstr 0 : { *(.stab.exclstr) }
  112. .stab.index 0 : { *(.stab.index) }
  113. .stab.indexstr 0 : { *(.stab.indexstr) }
  114. .comment 0 : { *(.comment) }
  115. _end = .;
  116. }