搜索
bottom↓
回复: 22

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

[复制链接]

出0入0汤圆

发表于 2013-11-5 11:21:05 | 显示全部楼层 |阅读模式
最近看到很多帖子讨论使用FPGA或者CPLD控制SDRAM做LCD液晶屏缓存。

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

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

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









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






阿莫论坛20周年了!感谢大家的支持与爱护!!

知道什么是神吗?其实神本来也是人,只不过神做了人做不到的事情 所以才成了神。 (头文字D, 杜汶泽)

出0入0汤圆

 楼主| 发表于 2013-11-6 09:17:54 | 显示全部楼层
本帖最后由 huchl 于 2013-11-6 09:19 编辑

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





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





本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有帐号?注册

x

出0入0汤圆

 楼主| 发表于 2013-11-8 09:41:58 | 显示全部楼层
怎么感觉都是自己在自言自语,么有人用这样的方案吗?




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

出0入0汤圆

发表于 2013-11-8 14:15:02 | 显示全部楼层
huchl 发表于 2013-11-6 09:17
共享下altera公司的SDRAM底层控制控制器代码和说明。还有就是xilinx公司的DSP与FPGA的接口定义。
这两份资 ...

支持下!
传个SDRAM的资料

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有帐号?注册

x

出0入90汤圆

发表于 2013-11-8 14:18:42 | 显示全部楼层
为什么楼主的每一个回复都要加上自己网店的地址啊?发一次就够了吧!如果每个人都这样回帖子!那这个论坛就成了淘宝分论坛了

出0入0汤圆

 楼主| 发表于 2013-11-8 14:21:36 | 显示全部楼层
鼎昇科技 发表于 2013-11-8 14:15
支持下!
传个SDRAM的资料

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




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

出0入0汤圆

发表于 2013-11-8 14:26:52 | 显示全部楼层
sdram可以设置突发读写模式,最大可设置成整页突发读写,激活和读写指令只要需给出一次,剩下的给时钟脉冲就行了,

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

出0入0汤圆

 楼主| 发表于 2013-11-8 14:49:23 | 显示全部楼层
本帖最后由 huchl 于 2013-11-8 14:51 编辑
wangyeqing333 发表于 2013-11-8 14:26
sdram可以设置突发读写模式,最大可设置成整页突发读写,激活和读写指令只要需给出一次,剩下的给时钟脉冲 ...


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









本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有帐号?注册

x

出0入0汤圆

发表于 2013-11-8 15:02:28 | 显示全部楼层
需要用FIFO。

出0入0汤圆

发表于 2013-11-8 15:14:23 | 显示全部楼层
我准备举报

出0入0汤圆

发表于 2013-11-8 15:18:53 来自手机 | 显示全部楼层
可以试试直接调用altera的sdram的ip,然后tft控制器写成avalon master和avalon slave设备,再加个niosii,都挂到avalon总线上

出0入0汤圆

 楼主| 发表于 2013-11-8 15:23:16 | 显示全部楼层
Jigsaw 发表于 2013-11-8 15:14
我准备举报

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

出0入0汤圆

发表于 2013-11-8 16:09:45 | 显示全部楼层
楼主提供点资料

出0入0汤圆

发表于 2013-11-8 16:26:56 | 显示全部楼层
目前做VGA显示1024*768@60Hz
觉得用SDRAM控制复杂,最后用SRAM,verilog程序就简单多了,不过成本高

出0入0汤圆

 楼主| 发表于 2013-11-8 19:00:10 | 显示全部楼层
qwerttt 发表于 2013-11-8 16:26
目前做VGA显示1024*768@60Hz
觉得用SDRAM控制复杂,最后用SRAM,verilog程序就简单多了,不过成本高 ...

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

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



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

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

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

出0入0汤圆

发表于 2013-11-8 22:10:02 | 显示全部楼层
huchl 发表于 2013-11-8 14:49
上传一个开源达人写的SDRAM源码,测试波形还行!!!!!!
推荐大家使用。

给力!!!

出0入0汤圆

发表于 2013-11-8 22:15:16 | 显示全部楼层
只有CPLD +SRAM  才有成本优势。如果要用SDRAM,那么FPGA的逻辑门数量要求相对来说较高。这种情况,不如直接用带LCD控制器的MCU。

出0入0汤圆

 楼主| 发表于 2013-11-8 22:18:23 | 显示全部楼层
所以最好优化SDRAM code,这样可以使用CPLD来达到成本和性能的均衡。




http://shop106094428.taobao.com/ ... 09.2.YXzRTD&v=1

出0入0汤圆

发表于 2013-11-8 23:43:21 | 显示全部楼层
楼主开源吧:)

出0入0汤圆

发表于 2013-11-18 00:40:13 | 显示全部楼层
最近正在学习fpga,等过一阵子也搞一下sdram作为我的学习效果测试,谢谢了

出0入9汤圆

发表于 2013-11-18 06:55:38 来自手机 | 显示全部楼层
以前试过。是需要缓存的。不过缓存最后没有做。没有成功。

出0入0汤圆

发表于 2013-11-18 07:31:26 来自手机 | 显示全部楼层
马克一下,之前见过童鞋买的cpld+sdram驱动7寸屏,居然才是epm570.....

出0入0汤圆

 楼主| 发表于 2013-11-18 08:39:57 | 显示全部楼层
本帖最后由 huchl 于 2013-11-18 08:42 编辑

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

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




















http://shop106094428.taobao.com/ ... 09.2.hOv7kI&v=1
回帖提示: 反政府言论将被立即封锁ID 在按“提交”前,请自问一下:我这样表达会给举报吗,会给自己惹麻烦吗? 另外:尽量不要使用Mark、顶等没有意义的回复。不得大量使用大字体和彩色字。【本论坛不允许直接上传手机拍摄图片,浪费大家下载带宽和论坛服务器空间,请压缩后(图片小于1兆)才上传。压缩方法可以在微信里面发给自己(不要勾选“原图),然后下载,就能得到压缩后的图片。注意:要连续压缩2次才能满足要求!!】。另外,手机版只能上传图片,要上传附件需要切换到电脑版(不需要使用电脑,手机上切换到电脑版就行,页面底部)。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

手机版|Archiver|amobbs.com 阿莫电子技术论坛 ( 粤ICP备2022115958号, 版权所有:东莞阿莫电子贸易商行 创办于2004年 (公安交互式论坛备案:44190002001997 ) )

GMT+8, 2024-7-24 05:14

© Since 2004 www.amobbs.com, 原www.ourdev.cn, 原www.ouravr.com

快速回复 返回顶部 返回列表