
如题 STM32F407用FSMC挂外部SRAM,RAM大小512K*16bit,正好1MB ![]() 外部SRAM已经测试可用(循环全写后读出来做数据比对),然后在MDK中启用外部ram的设置,并且申请一个1024*1024字节的大数组,编译后在map文件中已经能够看到 Total RW Size (RW Data + ZI Data) 1049720 (1025.12kB) 说明数组确实已经编进去了 而且MDK自动给分配了RAM i 0x20000000 Data 4 main.o(.data) pSRAM 0x20000004 Data 4 main.o(.data) Data 0x20000008 Data 1 main.o(.data) uwTick 0x20000014 Data 4 stm32f4xx_hal.o(.data) uwTickPrio 0x20000018 Data 4 stm32f4xx_hal.o(.data) uwTickFreq 0x2000001c Data 1 stm32f4xx_hal.o(.data) SystemCoreClock 0x20000020 Data 4 system_stm32f4xx.o(.data) hsram1 0x20000024 Data 80 fsmc.o(.bss) __initial_sp 0x20000478 Data 0 startup_stm32f407xx.o(STACK) BigData 0x68000000 Data 1048576 main.o(.bss) BIgData就是那个大数组,大小1024*1024字节 那么问题来了,只要BigData的大小超过外部SRAM大小,哪怕超1字节,编译器就会报错说内存不够了 这是不是就说明单一一个变量不能跨内外部RAM使用,只能在内部或者在外部 |
数组不是连续分配的么? |
没那么玩过。如果IDE不支持,如果说两块地址都不连续,不支持是可以理解的。如果说两块地址是连续的,你可以尝试拆分成2块来定义,指定地址定义。 |
这个提问挺有意思,个人觉得是不能跨段的,除非地址是连续的,但实际上是内外RAM地址是不可能连续的。 |
编译器根据数组申请的个数分配存储器,不管数组放在哪里或者哪怕SRAM还有富余空间,只要数组个数超过申请的个数,编译器都报错,个人认为这跟跨区无关 |
内部RAM和外部RAM地址又不连续 |
不会跨段的。编译器会自动处理的。可以看看堆栈说明中,变量的定义规则。 |
如果跨越内部外部,那么地址就不是连续的,这让编译器为难了吧。对于硬件执行起来也有难度,速度就差很远哦。 |
关于AN2867文档的疑问
tougfx 显示问题
F429同时使用SDRAM和SRAM
CAN数据重发
littlefs系统能读写SD卡吗?
STM32F405的ADC功耗参数不理解
STM32F405RGT6 ADC2+TIM4触发+DMA(DMA2_Stream2_CH1)+DMA中断会死机(取消中断后完全正常)
CUBEIDE1.19.0
stm32支持canfd和dma结合使用吗
NUCLEO-F401RE板卡,连接USB,在KEIL下可以找到ST-LINK仿真器,也可以下载代码。在电脑上看不到NODE_F401RE的磁盘,有知道是什么原因?