基于AXI接口的BRAM IP核配置学习

前言

当我们的项目想实现microblaze和rtl进行数据交互时,可以使用双口ram。portB连接我们的RTL逻辑部分,portA可以在block design中使用axi_bram_ctrl  ip核进行连接。

一、基础配置(Basic Setting)

主要的设置选项包括两个:模式(Mode)和存储器类型(Memory Type)。

①Mode:用来设置IP模式,默认为BRAM Controller,当你打算使用axi_bram_ctrl或者lmb_bram_if_ctrl两个官方的ip核来对BRAM进行控制时,Mode设置为BRAM Controller。但需要注意,该模式下,除了配置BRAM的类型外,所有的参数不可自行设置。

         当你选用BRAM Controller模式后,用户在该IP配置页面仅仅可以配置BRAM为单端口RAM、真双端口RAM、单端口ROM等。我们常规的参数如:端口数据位宽(write/read width),以及存储深度(write/read depth),均无法自己配置。这是用户在block design->address editor中对ip核进行地址大小分配时就自动生成了。

例如:我在这里给一个bram分配了4K的地址空间,则其容量可以视为:4*1024*8bit,那么与该axi_bram_ctrl相连接的bram(blk_mem_gen1)的数据宽度(width)和深度(depth)被自动分配成了1024*32bit,总容量与用户分配的地址空间一致。

②Meomory type:配置BRAM为单端口RAM、真双端口RAM、单端口ROM及真双端口ROM。

二、实际使用

        RTL对bram的访问和常规使用一致,在sdk中对bram进行读写需注意一个指针长度问题。sdk访问bram时,最小的读写数据为8bit(每个地址存储一个字节的数据)。当你指针定义为u8时,则可以一个地址进行读写,定义为u16时,则两个地址进行读写,u32则四个地址进行读写。

        当我们将指针定义为u16时:*(bram_0+1)= 0xFFFF。实际访问的地址是2=1*2。

        当我们将指针定义为u32时:*(bram_0+1)= 0xFFFF。实际访问的地址是4=1*4。

三、官方文档

想详细研究的可查看官方文档,附上链接。https://docs.amd.com/v/u/en-US/pg058-blk-mem-gen

  • 3
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
以下是一个简单的 AXI Quad SPI IP配置MICRON芯片的初始化程序,仅供参考: ```c #include "xparameters.h" #include "xspi.h" #include "micron_chip.h" #define SPI_DEVICE_ID XPAR_SPI_0_DEVICE_ID XSpi SpiInstance; /* The instance of the SPI device */ int main() { int Status; u8 WriteBuffer[256]; u8 ReadBuffer[256]; // 初始化 AXI Quad SPI IP XSpi_Config *ConfigPtr; ConfigPtr = XSpi_LookupConfig(SPI_DEVICE_ID); if (ConfigPtr == NULL) { return XST_FAILURE; } Status = XSpi_CfgInitialize(&SpiInstance, ConfigPtr, ConfigPtr->BaseAddress); if (Status != XST_SUCCESS) { return XST_FAILURE; } XSpi_SetOptions(&SpiInstance, XSP_MASTER_OPTION | XSP_CLK_ACTIVE_LOW_OPTION | XSP_CLK_PHASE_1_OPTION); XSpi_SetSlaveSelect(&SpiInstance, 0x01); // 配置MICRON芯片 micron_chip_init(); // 初始化MICRON芯片 // 写入命令 WriteBuffer[0] = 0x06; // 写入寄存器命令 Status = XSpi_Transfer(&SpiInstance, WriteBuffer, NULL, 1); if (Status != XST_SUCCESS) { return XST_FAILURE; } // 写入配置数据 WriteBuffer[0] = 0x01; // 工作模式 WriteBuffer[1] = 0x03; // 时序参数 WriteBuffer[2] = 0x00; // 地址 Status = XSpi_Transfer(&SpiInstance, WriteBuffer, NULL, 3); if (Status != XST_SUCCESS) { return XST_FAILURE; } // 检验配置 WriteBuffer[0] = 0x05; // 读取寄存器命令 Status = XSpi_Transfer(&SpiInstance, WriteBuffer, ReadBuffer, 1); if (Status != XST_SUCCESS) { return XST_FAILURE; } if (ReadBuffer[0] != 0x01) { return XST_FAILURE; } return XST_SUCCESS; } ``` 这段代码中,我们首先使用 XSpi_LookupConfig 函数获取 AXI Quad SPI IP配置信息,然后调用 XSpi_CfgInitialize 函数初始化 SPI 设备。接着使用 XSpi_SetOptions 函数设置 SPI 设备的传输参数,XSpi_SetSlaveSelect 函数设置 SPI 设备的从设备地址。 在初始化 SPI 设备之后,我们调用 micron_chip_init 函数初始化 MICRON 芯片。然后向 MICRON 芯片发送写入命令,再写入配置数据,最后读取 MICRON 芯片的寄存器,检验配置是否生效。如果配置成功,返回 XST_SUCCESS;否则返回 XST_FAILURE。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值