最近遇到一个问题,同一个模块,将其单独作为一个工程下到FPGA片子里头工作正常,可是将其整合到一个大工程中再下进去工作就不行了呢。我的FPGA芯片选的是Stratix Ⅱ,资源很充足的,顶层例化连接都没问题,可以排除。我在想,是不是有可能FPGA布局布线改变了导致这种情况发生呢?<br /><br />代码如下:<br />always @(posedge sys_clk2x or negedge sys_rst_n)<br /> if(!sys_rst_n)<br /> begin<br /> dqs_reg <= 8'b0000_0000;<br /> dqsn_reg <= 8'b1111_1111;<br /> end<br /> else if(dqs_en)<br /> begin<br /> dqs_reg[0] <= !dqs_reg[0];<br /> dqs_reg[1] <= !dqs_reg[1];<br /> dqsn_reg[0] <= !dqsn_reg[0];<br /> dqsn_reg[1] <= !dqsn_reg[1];<br /> end<br /> else<br /> begin<br /> dqs_reg <= 8'b0000_0000;<br /> dqsn_reg <= 8'b1111_1111;<br /> end<br /> <br /><br /><br />assign ddr2_dqs[1]=(dqs_en)?dqs_reg[1]:1'bz;<br />assign ddr2_dqs[0]=(dqs_en)?dqs_reg[0]:1'bz;<br />assign rd_dqs=ddr2_dqs;<br />assign ddr2_dqs_n[0]=(dqs_en)?dqsn_reg[0]:1'bz;<br />assign ddr2_dqs_n[1]=(dqs_en)?dqsn_reg[1]:1'bz;<br />assign rd_dqs_n=ddr2_dqs_n;<br />目的是在dqs_en使能有效期间在ddr2_dqs[1]、ddr2_dqs[0]、ddr2_dqs_n[0]、ddr2_dqs_n[1]信号上产生一个连续的脉冲群(ddr2_dqs,ddr2_dqs_n为8位双向总线),为其单独建一个工程,下到片子里跑用Signaltap查看没问题,可是加到大工程里后,就只有两三个信号工作正常,不知道为什么?!!!<br /><br />P.S.这段代码主要是为了产生DDR2芯片写数据时需要的data strobe信号,不知道我这样写是不是有什么问题,如果有哪位高人之前做过DDR2控制器的,还望不吝赐教!!!多谢!<br /><br />还有另一种方法,单独下到片子里也能行,但是加到大工程里就不行了,代码如下:<br />assign ddr2_dqs[1]=(dqs_en)?sys_clk:1'bz;<br />assign ddr2_dqs[0]=(dqs_en)?sys_clk:1'bz;<br />assign rd_dqs=ddr2_dqs;<br />assign ddr2_dqs_n[1]=(dqs_en)?(~sys_clk):1'bz;<br />assign ddr2_dqs_n[0]=(dqs_en)?(~sys_clk):1'bz;<br />assign rd_dqs_n=ddr2_dqs_n;<br />之前觉得涉及到门控时钟了,再加上时钟频率比较高125MHz,所以就没敢采用这种方法,可是现在看来不一定是门控时钟的问题了….急煞我也!!!<br /> |
|