在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位寻址来扩展可使用的存储空间,这在需要访问和处理超大规模数据集的情况下是非常必要的功能。