基于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

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值