Xilinx Zynq SDK lwea函数swea函数

在Xilinx Zynq SDK中,mb_interface.h头文件中定义了用于Microblaze的低层访问DDR内存的函数。其中就包括lwea()和swea()两个函数。

lwea()函数: 用于 Load Word Extended Address 的缩写,用于读取DDR中指定扩展地址的值。

函数原型:
unsigned int lwea(unsigned int extended_address);

参数extended_address: 36位的扩展物理地址
返回值:读取的32位数据

swea()函数: 用于 Store Word Extended Address的缩写,用于向DDR中指定扩展地址写入数据。

函数原型:
void swea(unsigned int extended_address, unsigned int data);

参数extended_address: 36位的扩展物理地址

参数data: 待写入的32位数据

这两个函数都通过 36 位的 extended_address 作为参数,可以访问 Microblaze 的全部 64GB DDR 空间。要正确使用这两个函数,需要在Microblaze中启用 MMU 和 SPACE 指令,并正确配置MMU的页表和段表,将extended_address翻译为物理内存地址。

使用实例:

// 读取DDR 0x1_0000_0000 地址的值 
unsigned int data = lwea(0x1_0000_0000);

// 往DDR 0x2_0000_0000 地址写入值 0x12345678
swea(0x2_0000_0000, 0x12345678);


 

这两个函数为Microblaze架构在DDR中读写超过4GB空间提供了非常方便的接口,我们可以像寻址默认的4GB空间一样来访问扩展的64GB DDR。但在使用这两个函数之前,一定要正确完成Microblaze的MMU配置与SPACE指令的使用设置,否则无法正确访问超出默认范围的DDR空间。

lwea()和swea()这两个函数的应用,加上MMU与SPACE指令,可以很好地解决Microblaze在处理大规模数据时的memorybottleneck问题,采用64位寻址来扩展可使用的存储空间,这在需要访问和处理超大规模数据集的情况下是非常必要的功能。 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值