核心经验:
STM32H7 多 RAM 区域,外设相关数据段必须放在 AXI SRAM(RAM)区,不能放在 DTCMRAM,否则外设无法访问,程序表面正常但外设全失效。迁移工程时,务必检查链接脚本的内存分布!
_estack = ORIGIN(RAM) + LENGTH(RAM); /* 堆栈顶设置为 AXI SRAM 末尾 */....data :
{. = ALIGN(4);_sdata = .;*(.data)*(.data*)*(.RamFunc)*(.RamFunc*). = ALIGN(4);_edata = .;
} >RAM AT> FLASH.bss :
{_sbss = .;__bss_start__ = _sbss;*(.bss)*(.bss*)*(COMMON). = ALIGN(4);_ebss = .;__bss_end__ = _ebss;
} >RAM._user_heap_stack :
{. = ALIGN(8);PROVIDE ( end = . );PROVIDE ( _end = . );. = . + _Min_Heap_Size;. = . + _Min_Stack_Size;. = ALIGN(8);
} >RAM