FPGA逻辑资源评估之BRAM(以Xilinx为例)

本文介绍了在Xilinx UltraSCALE+ FPGA中,BRAM作为重要的内存资源之一,其类型、特点以及如何进行资源评估和配置。BRAM是专用RAM,具有较大存储空间,可配置读写端口和深度。在进行BRAM资源评估时,考虑了数据大小和所需的存储容量,以确定所需BRAM块的数量。在实际应用中,通常会预留一定的裕量以适应不同的需求。
摘要由CSDN通过智能技术生成

        在FPGA逻辑设计时,需要参考所需逻辑资源对FPGA进行选型,其中一项就是对BRAM的评估,在这里以xilinx UltraSCALE+系列FPGA为例,对BRAM进行简单介绍。

        FPGA中RAM资源一般分为DRAM和BRAM两种,而Xilinx UltraSCALE+系列FPGA除了以上两种RAM之外,部分型号还包括UltraRAM。其中DRAM为Distributed RAM,是以FPGA中LUT(LUT in SLICEM)资源产生的,详细资料参考UG574:UltraScale ArchitectureConfigurable Logic Block User Guide;UltraRAM为一个时钟,两个端口(读写),同步读写,每个Block存储容量可达288Kb,一个时钟域可包含16个UltraRAM Blocks,而每个Block由4K x 7 、2 memory block组成,详细参考资料见UG573:UltraScale ArchitectureMemory Resources User Guide。

        本文主要对BRAM进行简单介绍,并给出BRAM资源评估的方法。BRAM的详细参考资料参考UG573:UltraScale ArchitectureMemory Resources User Guide。

        BRAM属于FPGA内嵌专用RAM,RAM块有较大的的存储空间,目前xilinx典型的BRAM有18Kbits和36Kbits。BRAM一定有时钟,DRAM可以是纯组合逻辑不用时钟,也可以增加一级reg使用时钟。BRAM读写端口可配,深度可配,多个BRAM block可组合级联,根据需要在允许范围内可以设置不同位宽不同深度(存储)的RAM块。

        例如:需要将一个文件先存入RAM中,在FPGA系统启动后读取RAM中的数据进行处理,coe文件中存储数据为10230个32bit位宽的数据,那么在IP核中RAM的设置位宽设置为32bit Width,Depth可设置为>10230,如果设置为10230,则RAM存储容量为32*10230=327360bits≈39.96KB,这也是数据的真实数据大小。配置完成后IP配置项显示使用36K BRAM共计10个Blocks,即10*36*1024=368640bits=45KB,这是由于一个Block块的大小为36Kb,根据IP配置的深度,所需RAM块的个数大于9小于10,故共需10个36K BRAM块。

        通常在配置BRAM时,可将设置深度比实际使用的大一些,留有一定裕量,一般根据情况灵活设置。

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值