使用 __attribute__((at)) 将数组定义到 SRAM 固定位置
在 MounRiver Studio 中为 RISC-V 芯片(如 CH582M)的特定 SRAM 区域(如 2KB 双电源供电的 RAM2K)分配数组,需使用 GCC 的 __attribute__((at)) 扩展语法。以下是具体方法和注意事项:
语法格式
通过 __attribute__((at(address))) 直接指定变量或数组的物理地址。例如:
uint8_t my_array[256] __attribute__((at(0x20001000)));
此代码将 my_array 分配到绝对地址 0x20001000 开始的 SRAM 区域。
CH582M RAM2K 的地址确认
查阅 CH582M 的数据手册或内存映射文档,确认 RAM2K 的起始地址。假设其起始地址为 0x20000000,则定义示例:
// 分配 512 字节到 RAM2K 区域
uint32_t persistent_data[128] __attribute__((at(0x20000000)));
注意事项
-
地址对齐
确保指定的地址符合数据类型对齐要求(如 4 字节对齐对uint32_t)。 -
内存区域有效性
确认目标地址属于 RAM2K 的合法范围(如0x20000000到0x20000800)。 -
链接脚本冲突
若链接脚本已配置 RAM2K 为特殊段(如.ram2k_section),需通过__attribute__((section))替代:uint8_t buffer[64] __attribute__((section(".ram2k_section"))); -
初始化问题
直接定位的变量可能不会被默认初始化,需手动赋值或通过启动代码处理。
完整示例代码
#include <stdint.h>
// 定义到 RAM2K 起始地址的数组
volatile uint8_t sleep_persistent_buf[1024] __attribute__((at(0x20000000)));
int main() {
sleep_persistent_buf[0] = 0xAA; // 测试写入
while (1);
}
验证方法
- 编译后查看生成的
.map文件,确认变量地址在0x20000000。 - 通过调试器直接读取目标地址内容,验证数据是否正确写入。
若需进一步优化,可结合链接脚本自定义段分配,确保与其他代码段无冲突。
RISC-V中数组定位到SRAM
6168

被折叠的 条评论
为什么被折叠?



