MounRiver Studio RISC-V将定义数组到SRAM固定位置 __attribute__ __at__ 详细说明和步骤

RISC-V中数组定位到SRAM

使用 __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)));


注意事项

  1. 地址对齐
    确保指定的地址符合数据类型对齐要求(如 4 字节对齐对 uint32_t)。

  2. 内存区域有效性
    确认目标地址属于 RAM2K 的合法范围(如 0x200000000x20000800)。

  3. 链接脚本冲突
    若链接脚本已配置 RAM2K 为特殊段(如 .ram2k_section),需通过 __attribute__((section)) 替代:

    uint8_t buffer[64] __attribute__((section(".ram2k_section")));
    

  4. 初始化问题
    直接定位的变量可能不会被默认初始化,需手动赋值或通过启动代码处理。


完整示例代码

#include <stdint.h>

// 定义到 RAM2K 起始地址的数组
volatile uint8_t sleep_persistent_buf[1024] __attribute__((at(0x20000000)));

int main() {
    sleep_persistent_buf[0] = 0xAA; // 测试写入
    while (1);
}


验证方法

  1. 编译后查看生成的 .map 文件,确认变量地址在 0x20000000
  2. 通过调试器直接读取目标地址内容,验证数据是否正确写入。

若需进一步优化,可结合链接脚本自定义段分配,确保与其他代码段无冲突。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值