×
单片机 > 单片机程序设计 > 详情

I2C总线学习—查缺补漏—S3C2440的I2C控制器

发布时间:2020-08-31 发布时间:
|
                 学习了IIC总线协议的理论部分,觉得应该学习具体操作2440的IIC控制器,毕竟最终都是为了学习S3C2440,所以就把这一部分补上。 S3C2440的I2C接口有四种工作模式:主机发送器、主机接收器、从机发送器、从机接收机。其内部结构如下图所示。
 
          从上图可以看出,S3C2440提供4个寄存器来完成所有的IIC操作。SDA线上的数据从IICDS寄存器经过移位寄存器发出,或通过移位寄存器传入IICDS寄存器;IICADD寄存器中保存S3C2440当做从机时的地址;IICCON、IICSTAT两个寄存器用来控制或标识各种状态,比如选择工作工作模式,发出S信号、P信号,决定是否发出ACK信号,检测是否接收到ACK信号。下面详细接收各寄存器的用法。
 

IICCON寄存器IIC-Bus control register

 
 
注意事项:
  1. IIC中断发生在以下三种情况:当发出地址信息或接收到一个从机地址并吻合时,当总线总裁失败时,当发送/接收完一个字节的数据(包括响应位)时。当发出地址信息或接收到一个从机地址并吻合时产生中断,在中断处理函数中要准备发送或者接收数据,即读取或设备IICDS寄存器,或者发出P信号。当总线总裁失败时产生中断,在中断处理函数中决定时候延时后再次竞争总线等。当发送/接收完一个字节的数据(包括响应位)时产生中断,在中断处理函数中要准备下次要发送或者接收数据,即读取或设备IICDS寄存器,或者发出P信号。
  2. 基于SDA、SCL线上时间特性的考虑,要发送数据时,先将数据写入IICDS寄存器,然后再清除中断。清除中断,即向IICCON[4]写入0,也就是将SCL线拉高,此时产生一个上升沿,将移位寄存器中的数据发送到SDA线。至于先将数据写入IICDS寄存器,然后再清除中断,可能是数据稳定需要一个时间吧。在清除中断前要数据保持问的那个。
  3. 如果IICCON[5]==0,IICCON[4]将不能正常工作。所以,即使不使用IIC中断,也要将IICCON[5]设为1。

IICSTAT寄存器

IICADD寄存器

                        用到IICADD寄存器的位[7:1],表示从机地址。IICADD寄存器在串行输出使能位IICSTAT[4]为0时,才可以写入;在任何时候都可以读出。IICSTAT[4]为0时,禁止接收/发送功能,即此时SCL线被拉低。

 

IICDS寄存器

                      用到IICDS寄存器的位[7:0],其中保存的是要发送或已经接收到的数据。IICDS寄存器在串行输出使能位IICSTAT[4]为1时才可以写入;在任何时候都可以读出。IICSTAT[4]为1时,使能接收/发送功能,也就是释放了SCL线。
 

关键字:I2C总线  S3C2440  I2C控制器

『本文转载自网络,版权归原作者所有,如有侵权请联系删除』

热门文章 更多
如何为单片机选择合适的负载电容