OpenEdv-开源电子网

 找回密码
 立即注册
正点原子全套STM32/Linux/FPGA开发资料,上千讲STM32视频教程免费下载...
查看: 9959|回复: 3

[ALTERA] inout高阻态时候高电平没被检测到

[复制链接]

2

主题

16

帖子

0

精华

初级会员

Rank: 2

积分
167
金钱
167
注册时间
2019-6-8
在线时间
77 小时
发表于 2021-1-5 10:43:01 | 显示全部楼层 |阅读模式
10金钱
本帖最后由 混天四绝 于 2021-1-5 10:44 编辑

写了个i2c发送协议:
这是我inout接口的定义:
inout sda;
reg i2c_output_data;
reg is_oe;

assign sda=(is_oe)?i2c_output_data:1'bz;


然后是testbench里sda的初始化:我确实上拉了sda管脚
module top_vlg_tst;
wire sda;         
assign sda = treg_sda;
pullup(sda)


这是我检测sda高电平(也就是ack应答)
10'd124:begin
sclk<=1'b1;
cnt<=cnt+1'b1;
is_ack<=i2c_output_data?1'b1:1'b0;


神奇的是i2c_output_data不是已经拉高了么?为啥第一次检测到了,第二次没检测到?两次ack的代码机除了状态跳转其余都是一样的。是不是我的写法有问题还是我对inout理解有偏差?,我很确定ack只有这两处控制;
救救孩子吧,孩子太难了,仿真时序图如下,谢谢了,哪怕点一下都行
QQ截图20210105104042.png



QQ截图20210105103649.png

最佳答案

正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

2

主题

16

帖子

0

精华

初级会员

Rank: 2

积分
167
金钱
167
注册时间
2019-6-8
在线时间
77 小时
 楼主| 发表于 2021-1-5 10:43:02 | 显示全部楼层
回复

使用道具 举报

0

主题

1

帖子

0

精华

新手入门

积分
12
金钱
12
注册时间
2022-10-8
在线时间
2 小时
发表于 2022-10-8 22:32:40 | 显示全部楼层
assign sda=(is_oe)?i2c_output_data:1'bz;  三态门这里是不是反了啊?是不是应该assign sda=(is_oe== 0)?i2c_output_data:1'bz;
回复

使用道具 举报

3

主题

1979

帖子

0

精华

资深版主

Rank: 8Rank: 8

积分
5520
金钱
5520
注册时间
2018-10-21
在线时间
1561 小时
发表于 2022-10-9 09:37:06 | 显示全部楼层
arbitrate 发表于 2022-10-8 22:32
assign sda=(is_oe)?i2c_output_data:1'bz;  三态门这里是不是反了啊?是不是应该assign sda=(is_oe== 0)?i ...

它这里is_oe高电平表示输出,低电平切换成输入,所以是对的
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则



关闭

原子哥极力推荐上一条 /2 下一条

正点原子公众号

QQ|手机版|OpenEdv-开源电子网 ( 粤ICP备12000418号-1 )

GMT+8, 2024-10-4 02:25

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

快速回复 返回顶部 返回列表