镁光ddr3布线规则_lattice_ddr3调试经验分享(三)DDR速率计算

软件:lattice diamond 3.5 , DDR3 SDRAM Controller3.1     modelsim10.2c

硬件:ecp3 -8     镁光或者是海力士的DDR3

Lattice的DDR控制器是龟速,上面一篇已经提到了。所以没有xilinx的那么随心所欲了。

墨迹的原因有:

1,Lattice的DDR控制器在ddr的data位宽是16的情况下控制器的数据位宽只有64bit。写一次(8个地址)需要给两个64bit数据。

2,Lattice的DDR控制器是有burst 长度的,一次最大是32.

3,从你发出写命令到控制器吃数据之间需要等待。

必须要计算一下带宽。

需求里需要三路视频源(1080p)单独输入输出。经过计算,我这个是不符合要求的。

第一步:轮询时长(1920*1080p @60hz) 2200(行点数,包含了消隐)* 6.73ns(148.5Mhz)=14.806us

需要在14.806us实现所有的操作。

第二步:计算满负荷状态  ,两路1080p读写合起来需要时长  1920*1.25ns(latticeDDR3只能跑800M)*4(两路*读写=2*2=4)=9.6us

三路1080p 读写合起来需要时长 1920*1.25*(3*2)=14.4us

要知道这个计算方式没有算burst,refresh,percharge,latency 。

三路1080p的占用时长 14.4与轮询时长14.8us如此接近。肯定是不符合要求的。

第三步:实际情况。 因为1080p的行点数是1920 不能被32整除,所以这个lattice的DDR控制器的突发长度我就改成了16,避免了还要控制mask的麻烦。

结果呢,结果从仿真上来看,一路1080p居然占了7.625us !!! 是一路1080p哦。

把控制器的突发长度改成32,那么一个1080p的数据是7个32 burst_cnt加一个16 burst_cnt 。这样当然是增加了FSM的复杂度。还是用了6.616us,强调,是一路1080p哦!

结论:lattice的ddr控制器无法实现三路1080p视频独立输入输出。 项目选择上,对lattice的FPGA选择需要慎重啊

欢迎加入: FPGA广东交流群:162664354

FPGA开发者联盟: 485678884

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值