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

[复制链接]
 楼主| songchao01 发表于 2008-7-7 09:50 | 显示全部楼层 |阅读模式
最近遇到一个问题,同一个模块,将其单独作为一个工程下到FPGA片子里头工作正常,可是将其整合到一个大工程中再下进去工作就不行了呢。我的FPGA芯片选的是Stratix&nbsp;Ⅱ,资源很充足的,顶层例化连接都没问题,可以排除。我在想,是不是有可能FPGA布局布线改变了导致这种情况发生呢?<br /><br />代码如下:<br />always&nbsp;@(posedge&nbsp;sys_clk2x&nbsp;or&nbsp;negedge&nbsp;sys_rst_n)<br />&nbsp;&nbsp;&nbsp;&nbsp;if(!sys_rst_n)<br />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;begin<br />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;dqs_reg&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&lt=&nbsp;&nbsp;&nbsp;&nbsp;8'b0000_0000;<br />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;dqsn_reg&nbsp;&nbsp;&nbsp;&nbsp;&lt=&nbsp;&nbsp;&nbsp;&nbsp;8'b1111_1111;<br />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;end<br />&nbsp;&nbsp;&nbsp;&nbsp;else&nbsp;if(dqs_en)<br />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;begin<br />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;dqs_reg[0]&nbsp;&nbsp;&nbsp;&nbsp;&lt=&nbsp;&nbsp;&nbsp;&nbsp;!dqs_reg[0];<br />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;dqs_reg[1]&nbsp;&nbsp;&nbsp;&nbsp;&lt=&nbsp;&nbsp;&nbsp;&nbsp;!dqs_reg[1];<br />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;dqsn_reg[0]&nbsp;&lt=&nbsp;&nbsp;&nbsp;&nbsp;!dqsn_reg[0];<br />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;dqsn_reg[1]&nbsp;&lt=&nbsp;&nbsp;&nbsp;&nbsp;!dqsn_reg[1];<br />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;end<br />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;else<br />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;begin<br />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;dqs_reg&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&lt=&nbsp;&nbsp;&nbsp;&nbsp;8'b0000_0000;<br />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;dqsn_reg&nbsp;&nbsp;&nbsp;&nbsp;&lt=&nbsp;&nbsp;&nbsp;&nbsp;8'b1111_1111;<br />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;end<br />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;<br /><br /><br />assign&nbsp;&nbsp;&nbsp;&nbsp;ddr2_dqs[1]=(dqs_en)?dqs_reg[1]:1'bz;<br />assign&nbsp;&nbsp;&nbsp;&nbsp;ddr2_dqs[0]=(dqs_en)?dqs_reg[0]:1'bz;<br />assign&nbsp;&nbsp;&nbsp;&nbsp;rd_dqs=ddr2_dqs;<br />assign&nbsp;&nbsp;&nbsp;&nbsp;ddr2_dqs_n[0]=(dqs_en)?dqsn_reg[0]:1'bz;<br />assign&nbsp;&nbsp;&nbsp;&nbsp;ddr2_dqs_n[1]=(dqs_en)?dqsn_reg[1]:1'bz;<br />assign&nbsp;&nbsp;&nbsp;&nbsp;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&nbsp;strobe信号,不知道我这样写是不是有什么问题,如果有哪位高人之前做过DDR2控制器的,还望不吝赐教!!!多谢!<br /><br />还有另一种方法,单独下到片子里也能行,但是加到大工程里就不行了,代码如下:<br />assign&nbsp;&nbsp;&nbsp;&nbsp;ddr2_dqs[1]=(dqs_en)?sys_clk:1'bz;<br />assign&nbsp;&nbsp;&nbsp;&nbsp;ddr2_dqs[0]=(dqs_en)?sys_clk:1'bz;<br />assign&nbsp;&nbsp;&nbsp;&nbsp;rd_dqs=ddr2_dqs;<br />assign&nbsp;&nbsp;&nbsp;&nbsp;ddr2_dqs_n[1]=(dqs_en)?(~sys_clk):1'bz;<br />assign&nbsp;&nbsp;&nbsp;&nbsp;ddr2_dqs_n[0]=(dqs_en)?(~sys_clk):1'bz;<br />assign&nbsp;&nbsp;&nbsp;&nbsp;rd_dqs_n=ddr2_dqs_n;<br />之前觉得涉及到门控时钟了,再加上时钟频率比较高125MHz,所以就没敢采用这种方法,可是现在看来不一定是门控时钟的问题了….急煞我也!!!<br />
 楼主| songchao01 发表于 2008-7-9 23:14 | 显示全部楼层

顶起~

咋就没人帮忙解答一下呢,sigh
您需要登录后才可以回帖 登录 | 注册

本版积分规则

6

主题

28

帖子

0

粉丝
快速回复 在线客服 返回列表 返回顶部