搜索
bottom↓
回复: 8

sdram数据读出vga显示问题求解

[复制链接]

出0入0汤圆

发表于 2014-4-11 10:10:41 | 显示全部楼层 |阅读模式
本帖最后由 zcy0517 于 2014-4-11 14:51 编辑

我做的是摄像头采集,sdram存储,vga输出。目前我使用摄像头的帧同步头来清零写入地址,用vga的帧同步头来清零读写入地址,且写偶数页时,读奇数页。我只对sdram输入0x001的数据(我把摄像头输出数据给改成单色的0x001,帧行同步保留),但读出来的数据有很多杂质,如0x088等。我怀疑读取到了很多没有赋值的区域。该怎么控制会解决这个问题?
(最后用这个程序初步调出来了稳定的0x001数据,放在这边大家共享,楼下还有一些列问题,望大家指教)
module fifo_Ctrl(addr,dpm,cs,
                                                rst,clk150,valid2,key,
                                                clk_cmos,vsync1,vsync2,clk100,
                                                Raddr,Waddr);
///basic
output cs;
output[1:0] dpm;
assign cs=1'b1;
assign dpm=0;
///out
input rst;
input clk150;//in
input clk100;
input valid2;
input key; //key==0,wr;key==1,rd;

///in
input clk_cmos;
input vsync1;
input vsync2;
output[21:0] addr;
///try
output[21:0] Raddr;
output[21:0] Waddr;




reg flag;


reg[21:0] Raddr;
reg[21:0] Waddr;
reg[21:0] Endaddr;
reg[21:0] addr;

reg vsync1_buff1;
reg vsync1_buff2;
wire vsync1_req;
always @(posedge clk_cmos or negedge rst)
begin
vsync1_buff1<=vsync1;
vsync1_buff2<=vsync1_buff1;
end
assign vsync1_req = vsync1_buff1 & ~vsync1_buff2; //上升沿为1

reg vsync2_buff1;
reg vsync2_buff2;
wire vsync2_req;
always @(posedge clk100 or negedge rst)
begin
vsync2_buff1<=vsync2;
vsync2_buff2<=vsync2_buff1;
end
assign vsync2_req = vsync2_buff1 & ~vsync2_buff2; //上升沿为1


always @(posedge clk150 or negedge rst )
begin
if(!rst) begin flag<=0;Raddr<=0;Waddr<=0; end
else if(vsync1_req)
                begin
                {Endaddr[20:9],Endaddr[7:0]}<={Raddr[20:9],Raddr[7:0]};
                {Raddr[20:9],Raddr[7:0]}<=0;
                {Waddr[20:9],Waddr[7:0]}<=0;
           if(flag==0) begin {Raddr[21],Raddr[8]}<=2'b10; {Waddr[21],Waddr[8]}<=2'b00; flag<=~flag; end
           else if(flag==1) begin {Raddr[21],Raddr[8]}<=2'b00; {Waddr[21],Waddr[8]}<=2'b10;flag<=~flag; end
           end
                else  if(key==1)//read
                                begin
                                if(Raddr[7:0]<8'hff) Raddr[7:0]<=Raddr[7:0]+1'b1;
                           else if(Raddr[7:0]==8'hff) begin
                                                                                                        Raddr[7:0]<=0;
                                                                                                   Raddr[20:9]<=Raddr[20:9]+1'b1;                                                                                
                                                                                                        end
                                end
                               
                                else if({Waddr[20:9],Waddr[7:0]}=={Endaddr[20:9],Endaddr[7:0]}) //write
                                          {Waddr[20:9],Waddr[7:0]}<=0;
                                          else if(Waddr[7:0]<8'hff) Waddr[7:0]<=Waddr[7:0]+1'b1;
                                                        else if(Waddr[7:0]==8'hff) begin
                                                                                                                                Waddr[7:0]<=0;
                                                                                                                                Waddr[20:9]<=Waddr[20:9]+1'b1;
                                                                                                                                end
end                 
                               
                               
       
always @(posedge clk150 or negedge rst)
if(!rst) addr<=0;
else if(key==1) addr<=Raddr;
else if(key==0) addr<=Waddr;

endmodule








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

曾经有一段真挚的爱情摆在我的面前,我没有珍惜,现在想起来,还好我没有珍惜……

出0入0汤圆

 楼主| 发表于 2014-4-11 10:55:45 | 显示全部楼层
本帖最后由 zcy0517 于 2014-4-11 14:54 编辑

我把摄像头采集的数据加入,还是这个鬼样子(如下图)
并且想显示半边绿色,半边蓝色的数据失败了。sdram输出还是有杂质

本帖子中包含更多资源

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

x

出0入0汤圆

 楼主| 发表于 2014-4-11 10:57:25 | 显示全部楼层
本帖最后由 zcy0517 于 2014-4-11 10:59 编辑

这是我输出数据经过的fifo(只要数据没满就继续写入,一共8k的width,rdempty没有用它)

本帖子中包含更多资源

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

x

出0入0汤圆

发表于 2014-4-11 20:08:02 | 显示全部楼层
描述看这种问题关联太多
“且写偶数页时,读奇数页”,有没单独验证SDRAM控制器正确性

出0入0汤圆

发表于 2014-4-14 17:47:46 | 显示全部楼层
楼主貌似最近一直在弄SDRAM啊,不知道你用的SDRAM是多大的,我的是8M*16*4bank的。我是整页突发读取时,首个数据出错,其他没有问题。至今没有搞定。

出0入0汤圆

 楼主| 发表于 2014-4-17 22:27:51 | 显示全部楼层
步凡王子 发表于 2014-4-14 17:47
楼主貌似最近一直在弄SDRAM啊,不知道你用的SDRAM是多大的,我的是8M*16*4bank的。我是整页突发读取时,首 ...

是不是潜伏期CAS的问题?

出0入0汤圆

发表于 2014-4-18 16:00:18 | 显示全部楼层
以前经常做这类的应用,给你一个建议,你得一步步的确认各个模块正常,首先得确认 VGA 驱动正常,可以先生成灰阶图像,例如:从左到右灰度从 0 到 255,显示正常后第二步:将灰阶图像写入 SDRAM ,再读出后还能显示正常,第三步写入摄像头数据。

出0入0汤圆

 楼主| 发表于 2014-4-18 16:02:04 | 显示全部楼层
grantlu 发表于 2014-4-18 16:00
以前经常做这类的应用,给你一个建议,你得一步步的确认各个模块正常,首先得确认 VGA 驱动正常,可以先生 ...

谢谢你!

出0入0汤圆

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

本版积分规则

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

GMT+8, 2024-8-27 02:13

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

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