打印
[Quartus]

quartus问题

[复制链接]
2123|16
手机看帖
扫描二维码
随时随地手机跟帖
跳转到指定楼层
楼主
沙发
天河系的星星|  楼主 | 2013-9-18 15:53 | 只看该作者
接到fifo引脚

QQ截图20130918154918.png (13.87 KB )

QQ截图20130918154918.png

使用特权

评论回复
板凳
天河系的星星|  楼主 | 2013-9-18 15:54 | 只看该作者
接到inout

QQ截图20130918154951.png (12.32 KB )

QQ截图20130918154951.png

使用特权

评论回复
地板
GoldSunMonkey| | 2013-9-18 21:22 | 只看该作者
是不是inout描写的方式有问题呢?

使用特权

评论回复
5
GoldSunMonkey| | 2013-9-18 21:23 | 只看该作者
这个还是有有些要注意的地方。

使用特权

评论回复
6
xjsxjtu| | 2013-9-19 22:53 | 只看该作者
怎么没有回复啊

使用特权

评论回复
7
FangTT| | 2013-9-19 23:16 | 只看该作者
按猴哥说的办

使用特权

评论回复
8
天河系的星星|  楼主 | 2013-9-21 19:57 | 只看该作者
GoldSunMonkey 发表于 2013-9-18 21:22
是不是inout描写的方式有问题呢?

你好,我的代码是这个样子的:
inout[15:0] sdram_data;
reg[15:0] sdr_din;       
reg sdr_dlink;               
always @ (posedge clk or negedge rst_n)
    if(!rst_n) sdr_din <= 16'd0;       
    else if((work_state == `W_WRITE) | (work_state == `W_WD))
       sdr_din<=sys_data_in;               
    else sdr_din <= 16'd0;
always @ (posedge clk or negedge rst_n)
        if(!rst_n) sdr_dlink <= 1'b0;
   else if((work_state == `W_WRITE) | (work_state == `W_WD)) sdr_dlink <= 1'b1;
    else sdr_dlink <= 1'b0;       
assign sdram_data = sdr_dlink ? sdr_din:16'hzzzz;

使用特权

评论回复
9
天河系的星星|  楼主 | 2013-9-21 20:03 | 只看该作者
FangTT 发表于 2013-9-19 23:16
按猴哥说的办

帮我看一下代码吧,谢谢

使用特权

评论回复
10
mhanchen| | 2013-9-21 20:39 | 只看该作者
虽然我没用过signaltap,不过它和chipscope是一样的东西,chipscope中是不允许直接去抓取双向端口的信号的,只能是根据不同方向观测相关的reg中的值。你可以关于signaltap的说明,肯定有这方面的说明。

使用特权

评论回复
11
joychou| | 2013-9-22 10:11 | 只看该作者
mhanchen 发表于 2013-9-21 20:39
虽然我没用过signaltap,不过它和chipscope是一样的东西,chipscope中是不允许直接去抓取双向端口的信号的 ...

好像是这样的,甚至reg不赋初值的话,signaltap有时候抓取的值都是错误的

使用特权

评论回复
评分
参与人数 1威望 +1 收起 理由
天河系的星星 + 1 赞一个!
12
天河系的星星|  楼主 | 2013-9-22 10:35 | 只看该作者
joychou 发表于 2013-9-22 10:11
好像是这样的,甚至reg不赋初值的话,signaltap有时候抓取的值都是错误的

inout信号该怎么抓取呢

使用特权

评论回复
13
天河系的星星|  楼主 | 2013-9-22 10:35 | 只看该作者
GoldSunMonkey 发表于 2013-9-18 21:23
这个还是有有些要注意的地方。

inout信号该怎么抓取呢

使用特权

评论回复
14
joychou| | 2013-9-22 10:54 | 只看该作者
天河系的星星 发表于 2013-9-22 10:35
inout信号该怎么抓取呢

我又看了一下我以前的程序,好像inout也是能直接抓取的。。。代码里和你的区别在于sdram_data的值我也读取了,有读总线的部分,你的代码只有写总线的部分。

使用特权

评论回复
15
天河系的星星|  楼主 | 2013-9-22 10:59 | 只看该作者
joychou 发表于 2013-9-22 10:54
我又看了一下我以前的程序,好像inout也是能直接抓取的。。。代码里和你的区别在于sdram_data的值我也读 ...

我也有读总线,没粘贴出来。我是想先调写后调读
reg[15:0] sdr_dout;               
always @ (posedge clk or negedge rst_n)
        if(!rst_n) sdr_dout <= 16'd0;       
        else if((work_state == `W_RD) & (cnt_clk > 9'd0) & (cnt_clk < 9'd10))
               sdr_dout <= sdram_data;       

assign sys_data_out = sdr_dout;

你的代码可以用signal tap抓取吗

使用特权

评论回复
16
joychou| | 2013-9-22 11:16 | 只看该作者
天河系的星星 发表于 2013-9-22 10:59
我也有读总线,没粘贴出来。我是想先调写后调读
reg[15:0] sdr_dout;               
always @ (posedge clk or negedg ...

我的可以的,也没看出程序和你有什么特别不一样的地方。或者你试试先不要指定总线管脚,排除掉硬件上的问题。

使用特权

评论回复
17
天河系的星星|  楼主 | 2013-9-22 11:26 | 只看该作者
joychou 发表于 2013-9-22 11:16
我的可以的,也没看出程序和你有什么特别不一样的地方。或者你试试先不要指定总线管脚,排除掉硬件上的问 ...

有试过,一样的结果:(

使用特权

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

本版积分规则

7

主题

25

帖子

0

粉丝