有人用HDL做I2C通信吗?

2019-03-25 10:40发布

学习板上的PCF8563睡了几个月觉了。准备练练它。 此帖出自小平头技术问答
友情提示: 此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。
18条回答
linhaiqing60
2019-03-27 00:53

原帖由 shinexqq 于 2010-10-12 21:48 发表 不知道有没有人研究过altrea开发板DE1上的I2C程序,有几个问题我还没吃透,不知我直接发程序上来大家介不介意.....一起学习! http://www.myfpga.org/discuz/viewthread.php?tid=133&rpid=70321&ordertype=0&page=1 ...

 

对于你的第一个问题,我也还没看明白,先回答第二个问题吧。

 

首先,从代码上看这个代码应该是i2c主机模式的代码。你再认真看一下datasheet,i2c中,主机向从机发送任何数据(包括地址),从机在接受到之后都要有响应,而这个响应就是在数据最后一位结束后产生的。

 

现在解释一下响应的作用,主机在向从机发送数据后,如果从机没有返回任何信息的话,主机是不知道从机有没有接受到刚才发送的这个数据,因此为了让主机知道从机到底有没有接收到,就用这个响应信号来通知主机。即当主机发送完地址,从机在接收到这个地址(并且确认是自己的从机地址之后),从机就要发送一个响应信号来通知主机让主机知道从机已经接收到了(如果没有接收到,从机就不会发送这个响应信号)。同样的,主机发送完一个8位数据,从机在接收到之后也会有响应信号。

 

接下来再看这段代码,wire I2C_SDAT=SDO?1'bz:0 ;在结合源程序中,每次传输8位数据后有一个SDO=1'b1;可以知道当sdo等于一时,i2c_sdat为高阻态,这个时候i2c_sdat的值就等于输入值(因为i2c-sdat是I/O口,当i2c-sdat为高阻态时,它就是一个输入口),也就是从机发送过来的数值。然后再结合这句 6'd12  : begin SDO=SD[15]; ACK1=I2C_SDAT; end   ,于是ack1就等于之前一个周期的i2c_sdat的输入值,也就是状态‘ 11’6'd11 : SDO=1'b1;时从机发送过来的值,而这个从机发送过来的值是在主机发送完地址后发送的,也就是从机对地址的一个响应信号。于是ack2,ack3可以以此类推。



 

一周热门 更多>