I2C学习总结

i2c概述

I2C(Inter-Intergreted Circuit) 是一种串行通信协议,用于集成电路之间完成数据传输,i2c用广泛用以各种领域,包括电子设备、嵌入式系统、工业自动化等;

i2c仅仅只是一个数据传输的协议,具体传输的数据用途由上层决定;

针对i2c协议的一个小例子

该例子灵感出自参考文档;

针对上图中:我们类比单片机A为课堂中的老师,其它设备为学生;课堂上会有一些互动,如下流程说明,后面会针对例子和i2c中的通信做一些联系,这里有个大概流程即可;

  • 老师呼叫甲同学背诵课文
    1. 老师怒拍讲台,大喊安静;
    2. 点名甲同学,你给我背诵下《蜀道难》;
    3. 甲同学接收到请求,并回复收到;
    4. 此后开始背诵;“噫吁嚱,危乎高哉!蜀道之难,难于上青天!.....”
    5. 老师在甲同学背诵过程中不断的点头回应。
    6. 在甲同学背诵完成后,老师发话:“真不错,坐下吧”;(要不然甲同学会很尴尬)
  • 老师公布分数流程
    1. 老师又怒拍讲台,大喊安静,
    2. 老师点名:‘甲同学’;
    3. 甲同学回复:‘到’;
    4. 老师:‘我要告诉你分数了’;
    5. 甲同学回应:‘好的’;
    6. 老师:‘93分’;
    7. 甲同学:‘好的,我知道了’;
    8. 老师随即咳嗽一声,准备叫下一个同学;

协议特点

这里先抛出协议的特点,后续知识点说明部分会有针对性的说明;

  1. 仅需两根线即可完成通信(SDA、SCL);
  2. 均连接到总线上,无特定的主从之分,每个设备可访问总线上的其它设备;
  3. 串行通信,存在时钟线SCL用作接收指示;
  4. 总线上的设备既可以接收数据,也可以发送数据。但二者为互斥关系,所以为半双工通信方式;
  5. 存在应答机制,可实现接受侧的反压;

i2c重要知识点说明

SDA、SCL通信知识

  1. 默认情况下SDA、SCL的值均为1;
  2. 任何一个设备想要控制SDA、SCL输出0即可,输出1可通过外部的上拉完成输出1;
  3. 多个设备间的SDA、SCL为线与功能。当多个设备输出冲突时,将多个设备期望输出值进行与操作,即为最终SDA、SCL上的值;

i2c写操作

  1. 刚开始主机要发出一个start信号,然后发出一个设备地址(用来确定是往哪一个从机写数据),方向(读/写,0表示写,1表示读)。

  2. slave回应(用来确定这个设备是否存在),然后就可以传输数据,传输数据之后,要有一个回应信号(确定数据是否接受完成),然后再传输下一个数据。

每传输一个数据,接受方都会有一个回应信号,数据发送完之后,主机就会发送一个P停止信号。

白色背景:主→从

灰色背景:从→主

注意点:

  1. 写操作除了要指定设备地址,还需要指定对设备发生访问的地址,第一个数据为访问地址;;

带入前面的例子理解写过程

  • 老师公布分数流程

    1. 老师又怒拍讲台,大喊安静,(月考后,开始点名说分数);—发送start;
    2. 老师点名:‘甲同学’;—发送设备地址,指定甲同学;
    3. 甲同学回复:‘到’;—回应,代表从机存在并准备好了;
    4. 老师:‘我要告诉你分数了’;—指定要告知的是分数,也就是会知道写地址,指示从机该内容含义;
    5. 甲同学回应:‘好的’;—从机回应
    6. 老师:‘93分’; —发送数据;
    7. 甲同学:‘好的,我知道了’;—回应
    8. 老师随即咳嗽一声,准备叫下一个同学;— 发送P结束条件;

    以上例子i2c传输对应的其实就是教室里的声音,由于是单线的,所以也就是教室里只能存在一种声音,所以老师与同学之间的交流是串行执行的。当然可能我们人类由于存在某些潜规则,使得通信变的更简单了,但是电子设备中没有这种潜意识,所以需要再帧内指定地址、读写指示、从设备响应等动作完成一次通信;

i2c读操作

  1. 刚开始主机要发出一个start信号,然后发出一个设备地址(用来确定是从哪一个芯片读取数据),方向(读/写,0表示写,1表示读)。
  2. 回应(用来确定这个设备是否存在),然后就可以传输数据,传输数据之后,要有一个回应信号(确定数据是否接受完成),然后在传输下一个数据。
  3. 每传输一个数据,接受方都会有一个回应信号,数据发送完之后,主机就会发送一个P停止结束信号。

白色背景:主→从

灰色背景:从→主

说明:slave侧在完成一次传输后,需要master指示是否结束,或者进行下一次传输。slave默认会在当前地址进行递增动作进行下一次传输;读操作默认在上一写操作结束地址发生;

i2c读操作例子解读

  • 老师呼叫甲同学背诵课文
    1. 老师怒拍讲台,大喊安静;—start
    2. 点名甲同学;你给我背诵下《蜀道难》;—指定为读操作,并指定读的内容为《蜀道难》
    3. 甲同学接收到请求,并回复收到;—回应
    4. 此后开始背诵;“噫吁嚱,危乎高哉!蜀道之难,难于上青天!.....”—读数据
    5. 老师在甲同学背诵过程中不断的点头回应。—主机回应
    6. 在甲同学背诵完成后,老师发话:“真不错,坐下吧”;(要不然甲同学会很尴尬)—slave回应NACK,主机结束一次传输;

同写操作,人主观存在潜规则,通过例子理解I2c时注意需明确指定相关内容,电子设备才可以正确动作;

Start 和Pause条件

  1. 当 SCL 线是高电平时 SDA 线从高电平向低电平切换,这个情况表示通信的起始。
  2. 当 SCL 是高电平时 SDA 线由低电平向高电平切换,表示通信的停止。

发送点、采样点

i2c总体的数据线与采样时钟线的配合为:

  1. 当SCL为低时完成数据的改变,此时不会发送采样动作;
  2. 当SCL为高时完成数据的采样,此时完成数据采样动作;

I2c其它特性

  1. 响应可分为ACK和NACK,用以指示是否继续传输还是结束传输;
    • ACK主要用以指示传输完成;
    • NACK主要用以传输的一些特殊情况,如下:
      • I2C总线上没有主机所指定地址的从机设备
      • 从机正在执行一些操作,处于忙状态,还没有准备好与主机通讯
      • 主机发送的一些控制命令,从机不支持
      • 主机接收从机数据时,主机产生非应答信号,通知从机数据传输结束,不要再发数据了
  2. i2c slave会记住上一次操作的地址。下一次发送读动作即从该地址开始;所以要进行读之前需有一个无写数据的写动作;
  3. SCL、SDA的默认值为高;
  4. SDA的控制用主机和从机交替控制,同一时间仅一个设备控制。读写操作中的主机发送完相关信息后,需释放SDA的控制,由Slave控制是否应答;

参考文档

以上仅解释了大体部分,但i2c的其它特点还可以从以下文章学习到:

一篇短文让你彻底理解什么是I2C通信-CSDN博客

一文看懂I2C协议 - 知乎 (zhihu.com)

4分钟看懂!I2C通讯协议 最简单的总线通讯!_哔哩哔哩_bilibili

  • 30
    点赞
  • 20
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
C8051f020是一款集成了高速8位CPU、片内存储器、片内外设和多种外部接口的微控制器。本文档将介绍C8051f020的基本架构、外设和编程方法。 1. 基本架构 C8051f020采用了基于Harvard结构的体系结构,包含了片内存储器、片内外设和多种外部接口。它的基本架构如下图所示: ![C8051f020基本架构](https://i.imgur.com/piv4w4Q.png) 其中,CPU采用了高速8位8051架构,最高主频可达50MHz;片内存储器包含了32KB的Flash程序存储器和256B的SRAM数据存储器;片内外设包含了多种模拟和数字外设,如ADC、DAC、UART、SPI、I2C等;多种外部接口包括了GPIO、中断、定时器、看门狗等。 2. 外设介绍 2.1 ADC C8051f020内置12位SAR ADC,最高转换速率为1.6MSPS。可通过配置ADC控制寄存器实现不同的转换精度、转换速率和参考电压。ADC的输入通道可选择片内外部引脚或片外引脚。 2.2 DAC C8051f020内置12位DAC,最高转换速率为200kSPS。可通过配置DAC控制寄存器实现不同的转换精度、转换速率和输出电压。DAC的输出通道可选择片内外部引脚或片外引脚。 2.3 UART C8051f020内置UART模块,支持多种波特率,最高可达115200bps。可通过配置UART控制寄存器实现不同的数据位数、校验位和停止位。UART的输入输出通道可选择片内外部引脚或片外引脚。 2.4 SPI C8051f020内置SPI模块,支持主从模式和4种时钟极性和相位。可通过配置SPI控制寄存器实现不同的数据位数、时钟速率和传输模式。SPI的输入输出通道可选择片内外部引脚或片外引脚。 2.5 I2C C8051f020内置I2C模块,支持标准模式和快速模式。可通过配置I2C控制寄存器实现不同的数据位数、时钟速率和传输模式。I2C的输入输出通道可选择片内外部引脚或片外引脚。 2.6 GPIO C8051f020共有32个GPIO引脚,可作为输入或输出引脚。可通过配置GPIO控制寄存器实现不同的引脚功能和电平状态。GPIO引脚还可用于中断、定时器和看门狗等外部接口。 3. 编程方法 C8051f020可通过C语言编程或汇编语言编程。以下是一个简单的C语言程序示例,实现了ADC的初始化和采样: ```c #include <C8051f020.h> void init_adc() { ADC0CN = 0x02; // Enable ADC and set ADC0 to gain 1 REF0CN = 0x08; // Enable on-chip VREF and set voltage to 2.4V } unsigned int read_adc(unsigned char channel) { AMX0SL = channel; // Select ADC channel ADC0CN |= 0x20; // Start ADC conversion while (!(ADC0CN & 0x10)); // Wait for conversion to complete return ADC0; // Return ADC result } void main() { unsigned int result; init_adc(); result = read_adc(0); // Do something with result while (1); } ``` 以上程序中,init_adc()函数实现了ADC的初始化,包括使能ADC和设置参考电压;read_adc()函数实现了ADC的采样,包括选择通道、触发转换和等待转换完成;main()函数调用了init_adc()函数和read_adc()函数,并将采样结果存储在result中。程序最后进入死循环,等待后续操作。 除了C语言编程外,C8051f020还可以使用Keil、IAR等IDE进行集成开发,方便调试和程序烧录。 4. 总结 C8051f020是一款功能丰富、性能优异的微控制器,具有高速CPU、片内存储器、片内外设和多种外部接口等多种特点。通过本文档的学习,你可以了解到C8051f020的基本架构、外设和编程方法,为后续开发和应用提供了基础知识和参考依据。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

汶.z

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值