aarch32.ld 2.6 KB

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