在线咨询
eetop公众号 创芯大讲堂 创芯人才网
切换到宽版

EETOP 创芯网论坛 (原名:电子顶级开发网)

手机号码,快捷登录

手机号码,快捷登录

找回密码

  登录   注册  

快捷导航
搜帖子
查看: 3288|回复: 4

[求助] 仿真看到高阻态,比较奇怪[已解决]

[复制链接]
发表于 2017-12-26 08:16:34 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

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

x
本帖最后由 sdlyyuxi 于 2017-12-26 11:12 编辑

跑了一下eeprom相关的I2C状态机仿真<夏老师书上的>,发现SDA总线挂起后,不是一直处于高阻态,而是只维持了大概半个时钟周期。
   代码是:
   



  1. assign sda1  = (link_head)     ?   head_buf[1]    :  1'b0;
  2. assign sda2  = (link_write)    ?   sh8out_buf[7]   :  1'b0;
  3. assign sda3  = (link_stop)     ?   stop_buf[1]     :  1'b0;
  4. assign sda4  = (sda1 | sda2 | sda3);
  5. assign SDA  = (link_sda)       ?  sda4          :  1'bz;



复制代码

    波形
      eeprom_i2c.png
    如图所示,link_sda挂起时,按道理SDA bus不应该只维持半个周期的高阻态。这个是vcs需要开什么选项吗?

    此外,当link_sda打开时,head_buf[1]是高电平,这个时候SDA 上又出现了X态,也不清楚为什么
    请大神帮忙解答一下,感谢~~
发表于 2017-12-26 08:35:25 | 显示全部楼层
這應不是高阻态,是 signals conflict.
发表于 2017-12-26 10:26:26 | 显示全部楼层
楼上说的对,第一个timing line处是黄色的高祖,此处应该是驱动冲突啦
 楼主| 发表于 2017-12-26 10:50:08 | 显示全部楼层
回复 2# kuolifeng


    多谢,SDA是inout,的确eeprom那边有状态变化,引起了冲突;
    assign sda = (out_flag == 1) ? sda_buf[7] : 1'bz;
    i2c_eeprom2.jpg
 楼主| 发表于 2017-12-26 10:50:55 | 显示全部楼层
回复 3# laogou618


    感谢,是这样的^^
您需要登录后才可以回帖 登录 | 注册

本版积分规则

关闭

站长推荐 上一条 /1 下一条

×

小黑屋| 关于我们| 联系我们| 在线咨询| 隐私声明| EETOP 创芯网
( 京ICP备:10050787号 京公网安备:11010502037710 )

GMT+8, 2024-3-28 23:08 , Processed in 0.022746 second(s), 8 queries , Gzip On, Redis On.

eetop公众号 创芯大讲堂 创芯人才网
快速回复 返回顶部 返回列表