精华内容
下载资源
问答
  • I2C总线

    2019-06-24 18:19:58
    I2C总线特点 I2C总线最主要的优点是其简单性和有效性。由于接口直接在组件之上,因此I2C总线占用的空间非常小,减少了电路板的空间和芯片管脚的数量,降低了互联成本。总线的长度可高达25英尺,并且能够以10Kbps...

    I2C总线特点


        I2C总线最主要的优点是其简单性和有效性。由于接口直接在组件之上,因此I2C总线占用的空间非常小,减少了电路板的空间和芯片管脚的数量,降低了互联成本。总线的长度可高达25英尺,并且能够以10Kbps的最大传输速率支持40个组件。I2C总线的另一个优点是,它支持多主控(multimastering) 其中任何能够进行发送和接收的设备都可以成为主总线。一个主控能够控制信号的传输和时钟频率。当然,在任何时间点上只能有一个主控。

       

    I2C总线工作原理


    总线的构成及信号类型 


    I2C总线是由数据线SDA和时钟SCL构成的串行总线,可发送和接收数据。在CPU与被控IC之间、ICIC之间进行双向传送,最高传送速率100kbps。各种被控制电路均并联在这条总线上,但就像电话机一样只有拨通各自的号码才能工作,所以每个电路和模块都有唯一的地址,在信息的传输过程中,I2C总线上并接的每一模块电路既是主控器(或被控器),又是发送器(或接收器),这取决于它所要完成的功能。CPU发出的控制信号分为地址码和控制量两部分,地址码用来选址,即接通需要控制的电路,确定控制的种类;控制量决定该调整的类别(如对比度、亮度等)及需要调整的量。这样,各控制电路虽然挂在同一条总线上,却彼此独立,互不相关。 

    I2C总线在传送数据过程中共有三种类型信号, 它们分别是:开始信号、结束信号和应答信号。 

    开始信号:SCL为高电平时,SDA由高电平向低电平跳变,开始传送数据。 

    结束信号:SCL为高电平时,SDA由低电平向高电平跳变,结束传送数据。 

    应答信号:接收数据的IC在接收到8bit数据后,向发送数据的IC发出特定的低电平脉冲,表示已收到数据。CPU向受控单元发出一个信号后,等待受控单元发出一个应答信号,CPU接收到应答信号后,根据实际情况作出是否继续传递信号的判断。若未收到应答信号,由判断为受控单元出现故障。 

    这些信号中,起始信号是必需的,结束信号和应答信号,都可以不要。

    目前有很多半导体集成电路上都集成了I2C接口。带有I2C接口的单片机有:CYGNAL C8051F0XX系列,PHILIPSP87LPC7XX系列,MICROCHIPPIC16C6XX系列等。很多外围器件如存储器、监控芯片等也提供I2C接口

    I2C 总线是一种用于IC器件之间连接的双向二线制总线,所谓总线它上面可以挂多个器件,并且通过两根线连接,占用空间非常的小,总线的长度可长达25英尺,并且能够以10Kbps的最大传输速率支持4个组件。它的另一优点是多主控,只要能够进行接收和发送的设备都可以成为主控制器,当然多个主控不能同一时间 工作。

    I2C总线有两根信号线,一根为SDA(数据线),一根为SCL(时钟线)。任何时候时钟信号都是由主控器件产生

           总线上每个设备都有自己的一个addr,共7bit,广播地址全0.

       

    linux驱动开发之i2c驱动开发

    =============================================================

    busses目录:i2c总线驱动/i2c控制器驱动/i2c适配器驱动

    algos:i2c协议算法相关的

    i2c-core.c:i2c驱动的核心层

    i2c-dev.c:i2c设备设备驱动层

    i2c-boardinfo.c:板级资源操作函数

    ===============================================================

    i2c设备驱动层:各种i2c设备的驱动(如:lm75的驱动....)

    功能:1)给用户提供调用接口(申请设备号,实现file_operations,注册方法)

       2)实现策略问题,它知道发什么数据,但是它不知道怎么去发

    ===============================================================

    i2c核心层

    功能:1)提供很多的函数接口,用来联系上下两层,实现上下两层的数据交互

       2)注册了一条i2c总线

    ===============================================================

    i2c总线驱动层:

    功能:1)初始化控制器

       2)实现操作硬件的方法(实现功能函数)(它知道怎么去发数据,但是它不知道发什么数据)

    ================================================================

    设备、驱动、总线 三个实体。

    总线将设备和驱动绑定。

    在系统每注册一个设备的时候,会寻找与之匹配的驱动,相反在系统每注一个驱动的时候,会寻找与之匹配设备,而匹配由总线完成。

    struct I2C_Client 

    struct i2c_driver 

    struct i2c_msg

    i2c_add_driver

    i2c_del_driver

    i2c_new_device

    i2c_unregister_device

    i2c_master_send

    i2c_transfer

    转载于:https://www.cnblogs.com/postmaster/p/3661519.html

    展开全文
  • i2c总线

    2015-06-09 14:11:16
    I2C(Inter-Integrated Circuit)总线是由PHILIPS公司开发的两线式串行总线,用于连接微控制器及其外围设备。是微电子通信控制领域广泛采用的一种总线标准。具有接口线少,控制方式简单,器件封装形式小,通信速率...
    

    1.I2C协议
     

    I2C(Inter-Integrated Circuit)总线是由PHILIPS公司开发的两线式串行总线,用于连接微控制器及其外围设备。是微电子通信控制领域广泛采用的一种总线标准。具有接口线少,控制方式简单,器件封装形式小,通信速率较高等优点。

    I2C 总线通过串行数据(SDA)线和串行时钟(SCL)线在连接到总线的器件间传递信息。每个器件都有一个唯一的地址识别(无论是微控制器——MCU、LCD驱动器、存储器或键盘接口),而且都可以作为一个发送器或接收器(由器件的功能决定)。

    I2C有四种工作模式:

    1.主机发送

    2.主机接收

    3.从机发送

    4.从机接收
    1.1 I2C位传输

       数据传输:SCL为高电平时,SDA线若保持稳定,那么SDA上是在传输数据bit;
                 若SDA发生跳变,则用来表示一个会话的开始或结束(后面讲)
       数据改变:SCL为低电平时,SDA线才能改变传输的bit

    24148050_12977719989j8Y.jpg

    1.2 I2C开始和结束信号
      
       开始信号:SCL为高电平时,SDA由高电平向低电平跳变,开始传送数据。
       结束信号:SCL为高电平时,SDA由低电平向高电平跳变,结束传送数据。

      24148050_1297772090hlSk.jpg

    1.3 I2C应答信号
      
       Master每发送完8bit数据后等待Slave的ACK。
       即在第9个clock,若从IC发ACK,SDA会被拉低。
       若没有ACK,SDA会被置高,这会引起Master发生RESTART或STOP流程,如下所示:
    24148050_1297772233n55u.jpg


    1.4 I2C写流程

    写寄存器的标准流程为:
    1.    Master发起START
    2.    Master发送I2C addr(7bit)和w操作0(1bit),等待ACK
    3.    Slave发送ACK
    4.    Master发送reg addr(8bit),等待ACK
    5.    Slave发送ACK
    6.    Master发送data(8bit),即要写入寄存器中的数据,等待ACK
    7.    Slave发送ACK
    8.    第6步和第7步可以重复多次,即顺序写多个寄存器
    9.    Master发起STOP

    写一个寄存器
    24148050_1297772295fNrI.jpg



    写多个寄存器
    24148050_1297772325ih8z.jpg
    1.5 I2C读流程

    读寄存器的标准流程为:
    1.    Master发送I2C addr(7bit)和w操作1(1bit),等待ACK
    2.    Slave发送ACK
    3.    Master发送reg addr(8bit),等待ACK
    4.    Slave发送ACK
    5.    Master发起START
    6.    Master发送I2C addr(7bit)和r操作1(1bit),等待ACK
    7.    Slave发送ACK
    8.    Slave发送data(8bit),即寄存器里的值
    9.    Master发送ACK
    10.    第8步和第9步可以重复多次,即顺序读多个寄存器

    读一个寄存器
    24148050_1297772425TZt2.jpg

    读多个寄存器
    24148050_1297772459j7ru.jpg


    在Linux内核中定义了I2C驱动体系结构。我们通过一个图来说明:

    在Linux系统中,I2C驱动由三部分构成,即I2C核心、I2C总线驱动和I2C设备驱动。

    I2C核心用于联系I2C设备驱动与I2C控制驱动的纽带。实现了一组和硬件无关的函数。

    I2C总线驱动用于在I2C总线上产生相应的时序。

    I2C设备驱动调用I2C core中的函数来完成I2C设备驱动的注册以及I2C消息的封装。这也是我们主要关心的部分。

    在I2C子系统中实现I2C通用设备驱动,我们可以使用这个通过驱动来实现对I2C设备的控制,但是I2C消息就必须由用户程序自己封装,这绝对是不可行的。所以我们推荐自己实现对应的I2C特定驱动,从中封装I2C消息。使用户程序不需关心内部的细节。

    但是我们还是首先需要了解一下如何使用这个通用的I2C驱动。

    首先我们需要配置内核来添加I2C总线驱动。修改内容为:

    首先修改配置文件,添加S5PC100的支持。然后执行make menuconfig来添加总线设备驱动和通过设备驱动。

    之后编译内核,运行内核后我们会发现在/dev/下多了两个设备节点i2c-0和i2c-1.这是证明我们的通用设备驱动已经加载成功。

    我们直接访问这个设备文件就可以控制I2C设备。如何操作呢?

    在应用程序中:

    1.打开i2c设备文件。

    2.构建消息

    3.执行ioctl操作

    打开i2c设备文件不用多说。构建什么消息呢?

    我们首先需要来看两个数据结构

    i2c_rdwr_ioctl_data 用于给ioctl操作传递参数。当中有两个成员。

    第一个参数为msgs。即要传递的消息。它是一个指针,由于保存一个消息的首地址或者一组消息的数组首地址。

    第二个参数为消息的个数。

    接下来我们来看i2c_msg

    该结构体用于封装一个消息。

    addr:即从设备的地址

    flags:标志,下面定义了很多标志。0代表写。1代表读

    len: 数据的长度

    buf: 用于发送或者接收数据的缓冲区。


    i2c_transfer(适配器, 消息首地址, 数量);

    适配器从何而来,当我们的i2c设备与驱动匹配后执行probe函数,第一个参数为client。它当中就包含了适配器,所以我们在probe函数中,将client的首地址保存起来,用于传输消息。

    3.加载函数中注册i2c设备驱动i2c_add_driver

    4.卸载函数中注销i2c设备驱动i2c_del_driver


    转载于:

    http://blog.chinaunix.net/uid-24148050-id-120532.html

    http://www.embedu.org/Column/Column853.htm

    展开全文
  • I2C总线协议

    2018-02-25 10:55:38
    I2C总线协议I2C总线协议I2C总线协议I2C总线协议I2C总线协议I2C总线协议
  • I2C总线规范

    2018-02-24 11:12:28
    I2C总线规范 I2C总线规范 I2C总线规范 I2C总线规范 I2C总线规范

空空如也

空空如也

1 2 3 4 5 ... 20
收藏数 9,114
精华内容 3,645
关键字:

i2c总线