打印

(求教) FPGA设计达人看过来!!

[复制链接]
1339|1
手机看帖
扫描二维码
随时随地手机跟帖
跳转到指定楼层
楼主
songchao01|  楼主 | 2008-7-7 09:50 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
最近遇到一个问题,同一个模块,将其单独作为一个工程下到FPGA片子里头工作正常,可是将其整合到一个大工程中再下进去工作就不行了呢。我的FPGA芯片选的是Stratix Ⅱ,资源很充足的,顶层例化连接都没问题,可以排除。我在想,是不是有可能FPGA布局布线改变了导致这种情况发生呢?

代码如下:
always @(posedge sys_clk2x or negedge sys_rst_n)
    if(!sys_rst_n)
        begin
            dqs_reg        <=    8'b0000_0000;
            dqsn_reg    <=    8'b1111_1111;
        end
    else if(dqs_en)
        begin
            dqs_reg[0]    <=    !dqs_reg[0];
            dqs_reg[1]    <=    !dqs_reg[1];
            dqsn_reg[0] <=    !dqsn_reg[0];
            dqsn_reg[1] <=    !dqsn_reg[1];
        end
        else
            begin
                dqs_reg        <=    8'b0000_0000;
                dqsn_reg    <=    8'b1111_1111;
            end
            


assign    ddr2_dqs[1]=(dqs_en)?dqs_reg[1]:1'bz;
assign    ddr2_dqs[0]=(dqs_en)?dqs_reg[0]:1'bz;
assign    rd_dqs=ddr2_dqs;
assign    ddr2_dqs_n[0]=(dqs_en)?dqsn_reg[0]:1'bz;
assign    ddr2_dqs_n[1]=(dqs_en)?dqsn_reg[1]:1'bz;
assign    rd_dqs_n=ddr2_dqs_n;
目的是在dqs_en使能有效期间在ddr2_dqs[1]、ddr2_dqs[0]、ddr2_dqs_n[0]、ddr2_dqs_n[1]信号上产生一个连续的脉冲群(ddr2_dqs,ddr2_dqs_n为8位双向总线),为其单独建一个工程,下到片子里跑用Signaltap查看没问题,可是加到大工程里后,就只有两三个信号工作正常,不知道为什么?!!!

P.S.这段代码主要是为了产生DDR2芯片写数据时需要的data strobe信号,不知道我这样写是不是有什么问题,如果有哪位高人之前做过DDR2控制器的,还望不吝赐教!!!多谢!

还有另一种方法,单独下到片子里也能行,但是加到大工程里就不行了,代码如下:
assign    ddr2_dqs[1]=(dqs_en)?sys_clk:1'bz;
assign    ddr2_dqs[0]=(dqs_en)?sys_clk:1'bz;
assign    rd_dqs=ddr2_dqs;
assign    ddr2_dqs_n[1]=(dqs_en)?(~sys_clk):1'bz;
assign    ddr2_dqs_n[0]=(dqs_en)?(~sys_clk):1'bz;
assign    rd_dqs_n=ddr2_dqs_n;
之前觉得涉及到门控时钟了,再加上时钟频率比较高125MHz,所以就没敢采用这种方法,可是现在看来不一定是门控时钟的问题了….急煞我也!!!

相关帖子

沙发
songchao01|  楼主 | 2008-7-9 23:14 | 只看该作者

顶起~

咋就没人帮忙解答一下呢,sigh

使用特权

评论回复
发新帖 我要提问
您需要登录后才可以回帖 登录 | 注册

本版积分规则

6

主题

28

帖子

0

粉丝