huchl 发表于 2013-11-5 11:21:05

FPGA控制SDRAM 8寸LCD显示缓存 交流

最近看到很多帖子讨论使用FPGA或者CPLD控制SDRAM做LCD液晶屏缓存。

俺头脑一热,也开始动手制作。

其实SDRAM的逻辑控制比较简单,几个状态机+几个定时器就OK。关键的技术是怎么实现SDRAM的连读和连写。如果每读一次或者每写一次都要对SDRAM的bank,先预充电,在激活,再等几个周期读入或者写入,这样即使100M的SDRAM的时钟带宽,也所剩无几。

所以本人认为,制作LCD显存控制器的关键不是SDRAM的读写,而是如何制作SDRAM读写的CACHE。









http://shop106094428.taobao.com/index.htm?v=1






huchl 发表于 2013-11-6 09:17:54

本帖最后由 huchl 于 2013-11-6 09:19 编辑

共享下altera公司的SDRAM底层控制控制器代码和说明。还有就是xilinx公司的DSP与FPGA的接口定义。
这两份资料是制作LCD控制器的基础{:biggrin:}{:biggrin:}





http://shop106094428.taobao.com/index.htm?v=1





huchl 发表于 2013-11-8 09:41:58

怎么感觉都是自己在自言自语,么有人用这样的方案吗?




http://shop106094428.taobao.com/index.htm?v=1

鼎昇科技 发表于 2013-11-8 14:15:02

huchl 发表于 2013-11-6 09:17 static/image/common/back.gif
共享下altera公司的SDRAM底层控制控制器代码和说明。还有就是xilinx公司的DSP与FPGA的接口定义。
这两份资 ...

支持下!
传个SDRAM的资料

honami520 发表于 2013-11-8 14:18:42

为什么楼主的每一个回复都要加上自己网店的地址啊?发一次就够了吧!如果每个人都这样回帖子!那这个论坛就成了淘宝分论坛了

huchl 发表于 2013-11-8 14:21:36

鼎昇科技 发表于 2013-11-8 14:15 static/image/common/back.gif
支持下!
传个SDRAM的资料

感谢LZ的资料,看来还是有人关注这个东西。




http://shop106094428.taobao.com/index.htm?v=1

wangyeqing333 发表于 2013-11-8 14:26:52

sdram可以设置突发读写模式,最大可设置成整页突发读写,激活和读写指令只要需给出一次,剩下的给时钟脉冲就行了,

如果还嫌慢,可以试试同时操作4个bank,网上用fpja做sdram的驱动中很多会用到这种方式。

huchl 发表于 2013-11-8 14:49:23

本帖最后由 huchl 于 2013-11-8 14:51 编辑

wangyeqing333 发表于 2013-11-8 14:26 static/image/common/back.gif
sdram可以设置突发读写模式,最大可设置成整页突发读写,激活和读写指令只要需给出一次,剩下的给时钟脉冲 ...

上传一个开源达人写的SDRAM源码,测试波形还行!!!!!!
推荐大家使用。









health 发表于 2013-11-8 15:02:28

需要用FIFO。

Jigsaw 发表于 2013-11-8 15:14:23

我准备举报{:lol:}

jianfengxixi 发表于 2013-11-8 15:18:53

可以试试直接调用altera的sdram的ip,然后tft控制器写成avalon master和avalon slave设备,再加个niosii,都挂到avalon总线上

huchl 发表于 2013-11-8 15:23:16

Jigsaw 发表于 2013-11-8 15:14 static/image/common/back.gif
我准备举报

有啥可以举报的,大家都是开源的呀!!!!!!!!!!!!!!!!!!!

taizhou1234 发表于 2013-11-8 16:09:45

楼主提供点资料

qwerttt 发表于 2013-11-8 16:26:56

目前做VGA显示1024*768@60Hz
觉得用SDRAM控制复杂,最后用SRAM,verilog程序就简单多了,不过成本高

huchl 发表于 2013-11-8 19:00:10

qwerttt 发表于 2013-11-8 16:26 static/image/common/back.gif
目前做VGA显示1024*768@60Hz
觉得用SDRAM控制复杂,最后用SRAM,verilog程序就简单多了,不过成本高 ...

LZ说的对,除了性能以外就是成本了。这也是个矛盾的,SDRAM比较便宜,但是需要的控制逻辑比较多。

使用CPLD实现一个SDRAM状态机的读写,资源还行。但是做TFT内存缓冲器,就必须除了读写以外还要加一个显示LCD输出端口。



大家可以算算:7寸LCD典型时钟要求的像素时钟是27MHz。

然后是VGA的30帧比如640x480x30=9MByte/s, 所以内存带宽最低要求也要能承受40MByte/s

如果SDRAM没有做缓冲机制,没读写一次都要先预充电、再激活、再读写 这样带宽根本不够,结果就是帧率达不到。

随风_98 发表于 2013-11-8 22:10:02

huchl 发表于 2013-11-8 14:49 static/image/common/back.gif
上传一个开源达人写的SDRAM源码,测试波形还行!!!!!!
推荐大家使用。



给力!!!

zf12862177 发表于 2013-11-8 22:15:16

只有CPLD +SRAM才有成本优势。如果要用SDRAM,那么FPGA的逻辑门数量要求相对来说较高。这种情况,不如直接用带LCD控制器的MCU。

huchl 发表于 2013-11-8 22:18:23

所以最好优化SDRAM code,这样可以使用CPLD来达到成本和性能的均衡。




http://shop106094428.taobao.com/index.htm?spm=a1z10.5.w5002-3479751109.2.YXzRTD&v=1

sblpp 发表于 2013-11-8 23:43:21

楼主开源吧:)

MotionControl 发表于 2013-11-18 00:40:13

最近正在学习fpga,等过一阵子也搞一下sdram作为我的学习效果测试,谢谢了

sokou 发表于 2013-11-18 06:55:38

以前试过。是需要缓存的。不过缓存最后没有做。没有成功。

zgxcom123 发表于 2013-11-18 07:31:26

马克一下,之前见过童鞋买的cpld+sdram驱动7寸屏,居然才是epm570.....

huchl 发表于 2013-11-18 08:39:57

本帖最后由 huchl 于 2013-11-18 08:42 编辑

大家可以下载我发的那个opensource的sdram控制器,本人也正在上面做优化工作。

有什么想法大家相互交流!!!!!!!




















http://shop106094428.taobao.com/index.htm?spm=2013.1.w5002-3479751109.2.hOv7kI&v=1
页: [1]
查看完整版本: FPGA控制SDRAM 8寸LCD显示缓存 交流