memory.ld.in 6.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175
  1. /*
  2. * SPDX-FileCopyrightText: 2021 Espressif Systems (Shanghai) CO LTD
  3. *
  4. * SPDX-License-Identifier: Apache-2.0
  5. */
  6. /* ESP32 Linker Script Memory Layout
  7. This file describes the memory layout (memory blocks) as virtual
  8. memory addresses.
  9. esp32.project.ld contains output sections to link compiler output
  10. into these memory blocks.
  11. ***
  12. This linker script is passed through the C preprocessor to include
  13. configuration options.
  14. Please use preprocessor features sparingly! Restrict
  15. to simple macros with numeric values, and/or #if/#endif blocks.
  16. */
  17. #include "sdkconfig.h"
  18. #include "ld.common"
  19. /* If BT is not built at all */
  20. #ifndef CONFIG_BTDM_RESERVE_DRAM
  21. #define CONFIG_BTDM_RESERVE_DRAM 0
  22. #endif
  23. #if defined(CONFIG_ESP32_USE_FIXED_STATIC_RAM_SIZE)
  24. ASSERT((CONFIG_ESP32_FIXED_STATIC_RAM_SIZE <= 0x2c200),
  25. "Fixed static ram data does not fit.")
  26. #define DRAM0_0_SEG_LEN CONFIG_ESP32_FIXED_STATIC_RAM_SIZE
  27. #else
  28. #define DRAM0_0_SEG_LEN 0x2c200
  29. #endif
  30. #if CONFIG_ESP_SYSTEM_ESP32_SRAM1_REGION_AS_IRAM
  31. #define SRAM1_IRAM_LEN 0xA000
  32. #else
  33. #define SRAM1_IRAM_LEN 0x0
  34. #endif
  35. MEMORY
  36. {
  37. /* All these values assume the flash cache is on, and have the blocks this uses subtracted from the length
  38. of the various regions. The 'data access port' dram/drom regions map to the same iram/irom regions but
  39. are connected to the data port of the CPU and eg allow bytewise access. */
  40. /* IRAM for PRO cpu. Not sure if happy with this, this is MMU area... */
  41. iram0_0_seg (RX) : org = 0x40080000, len = 0x20000 + SRAM1_IRAM_LEN
  42. #ifdef CONFIG_APP_BUILD_USE_FLASH_SECTIONS
  43. /* Even though the segment name is iram, it is actually mapped to flash
  44. */
  45. iram0_2_seg (RX) : org = 0x400D0020, len = 0x330000-0x20
  46. /*
  47. (0x20 offset above is a convenience for the app binary image generation.
  48. Flash cache has 64KB pages. The .bin file which is flashed to the chip
  49. has a 0x18 byte file header, and each segment has a 0x08 byte segment
  50. header. Setting this offset makes it simple to meet the flash cache MMU's
  51. constraint that (paddr % 64KB == vaddr % 64KB).)
  52. */
  53. #endif // CONFIG_APP_BUILD_USE_FLASH_SECTIONS
  54. /* Shared data RAM, excluding memory reserved for ROM bss/data/stack.
  55. Enabling Bluetooth & Trace Memory features in menuconfig will decrease
  56. the amount of RAM available.
  57. Note: Length of this section *should* be 0x50000, and this extra DRAM is available
  58. in heap at runtime. However due to static ROM memory usage at this 176KB mark, the
  59. additional static memory temporarily cannot be used.
  60. */
  61. dram0_0_seg (RW) : org = 0x3FFB0000 + CONFIG_BTDM_RESERVE_DRAM,
  62. len = DRAM0_0_SEG_LEN - CONFIG_BTDM_RESERVE_DRAM
  63. #ifdef CONFIG_APP_BUILD_USE_FLASH_SECTIONS
  64. /* Flash mapped constant data */
  65. drom0_0_seg (R) : org = 0x3F400020, len = 0x400000-0x20
  66. /* (See iram0_2_seg for meaning of 0x20 offset in the above.) */
  67. #endif // CONFIG_APP_BUILD_USE_FLASH_SECTIONS
  68. /* RTC fast memory (executable). Persists over deep sleep. */
  69. rtc_iram_seg(RWX) : org = 0x400C0000, len = 0x2000 - ESP_BOOTLOADER_RESERVE_RTC
  70. /* RTC fast memory (same block as above, rtc_iram_seg), viewed from data bus */
  71. rtc_data_seg(RW) : org = 0x3ff80000, len = 0x2000 - ESP_BOOTLOADER_RESERVE_RTC
  72. /* We reduced the size of rtc_iram_seg and rtc_data_seg by ESP_BOOTLOADER_RESERVE_RTC value.
  73. It reserves the amount of RTC fast memory that we use for this memory segment.
  74. This segment is intended for keeping bootloader rtc data (s_bootloader_retain_mem, when a Kconfig option is on).
  75. The aim of this is to keep data that will not be moved around and have a fixed address.
  76. org = 0x3ff80000 + 0x2000 - ESP_BOOTLOADER_RESERVE_RTC == SOC_RTC_DRAM_HIGH - sizeof(rtc_retain_mem_t)
  77. */
  78. rtc_fast_reserved_seg(RW) : org = 0x3ff80000 + 0x2000 - ESP_BOOTLOADER_RESERVE_RTC, len = ESP_BOOTLOADER_RESERVE_RTC
  79. /* RTC slow memory (data accessible). Persists over deep sleep.
  80. Start of RTC slow memory is reserved for ULP co-processor code + data, if enabled.
  81. */
  82. #if CONFIG_ULP_COPROC_ENABLED
  83. rtc_slow_seg(RW) : org = 0x50000000 + CONFIG_ULP_COPROC_RESERVE_MEM,
  84. len = 0x2000 - CONFIG_ULP_COPROC_RESERVE_MEM - RESERVE_RTC_MEM
  85. #else
  86. rtc_slow_seg(RW) : org = 0x50000000, len = 0x2000 - RESERVE_RTC_MEM
  87. #endif // CONFIG_ULP_COPROC_ENABLED
  88. /* We reduced the size of rtc_slow_seg by RESERVE_RTC_MEM value.
  89. It reserves the amount of RTC slow memory that we use for this memory segment.
  90. This segment is intended for keeping rtc timer data (s_rtc_timer_retain_mem, see esp_clk.c files).
  91. The aim of this is to keep data that will not be moved around and have a fixed address.
  92. org = 0x50000000 + 0x2000 - RESERVE_RTC_MEM
  93. */
  94. rtc_slow_reserved_seg(RW) : org = 0x50000000 + 0x2000 - RESERVE_RTC_MEM, len = RESERVE_RTC_MEM
  95. /* external memory */
  96. extern_ram_seg(RWX) : org = 0x3F800000,
  97. len = 0x400000
  98. }
  99. #if defined(CONFIG_ESP32_USE_FIXED_STATIC_RAM_SIZE)
  100. /* static data ends at defined address */
  101. _heap_start = 0x3FFB0000 + DRAM0_0_SEG_LEN;
  102. #else
  103. _heap_start = _heap_low_start;
  104. #endif
  105. _sram1_iram_start = 0x400A0000;
  106. _sram1_iram_len = ( _iram_end > _sram1_iram_start) ? (_iram_end - _sram1_iram_start) : 0;
  107. _heap_end = ALIGN(0x40000000 - _sram1_iram_len - 3, 4);
  108. #if CONFIG_ESP32_TRACEMEM_RESERVE_DRAM != 0
  109. _heap_end = 0x40000000 - CONFIG_ESP32_TRACEMEM_RESERVE_DRAM;
  110. #endif
  111. _data_seg_org = ORIGIN(rtc_data_seg);
  112. /* The lines below define location alias for .rtc.data section based on Kconfig option.
  113. When the option is not defined then use slow memory segment
  114. else the data will be placed in fast memory segment */
  115. #ifndef CONFIG_ESP32_RTCDATA_IN_FAST_MEM
  116. REGION_ALIAS("rtc_data_location", rtc_slow_seg );
  117. #else
  118. REGION_ALIAS("rtc_data_location", rtc_data_seg );
  119. #endif
  120. #ifdef CONFIG_APP_BUILD_USE_FLASH_SECTIONS
  121. REGION_ALIAS("default_code_seg", iram0_2_seg);
  122. #else
  123. REGION_ALIAS("default_code_seg", iram0_0_seg);
  124. #endif // CONFIG_APP_BUILD_USE_FLASH_SECTIONS
  125. #ifdef CONFIG_APP_BUILD_USE_FLASH_SECTIONS
  126. REGION_ALIAS("default_rodata_seg", drom0_0_seg);
  127. #else
  128. REGION_ALIAS("default_rodata_seg", dram0_0_seg);
  129. #endif // CONFIG_APP_BUILD_USE_FLASH_SECTIONS
  130. /**
  131. * If rodata default segment is placed in `drom0_0_seg`, then flash's first rodata section must
  132. * also be first in the segment.
  133. */
  134. #ifdef CONFIG_APP_BUILD_USE_FLASH_SECTIONS
  135. ASSERT(_rodata_start == ORIGIN(default_rodata_seg),
  136. ".flash.appdesc section must be placed at the beginning of the rodata segment.")
  137. #endif