当前位置:网站首页>Easy to understand IIC protocol explanation
Easy to understand IIC protocol explanation
2022-07-06 05:23:00 【Embedded base】
I2C The bus is a simple 、 Two way two wire synchronous serial bus .
I2C The communication protocol has few pins , The hardware implementation is simple , High scalability , Unwanted USART、CAN And other communication protocols , It is widely used in multiple integrated circuits in the system (IC) Communication between .
I2C Information exchange is completed by two signal lines ,SCL It's a clock signal line ,SDA For data entry / Output line .
I2C Support multiple slaves (Slaver), It can also support multi host mode (Master). Most of the I2C Device support 100kHz and 400kHz Pattern , Some special applications can also be designed to support 3.4MHz.
I2C Its simple applications mainly include I2C Hardware connection and I2C Communication protocol Two aspects , This article gives a brief description of common communication methods .
I2C Hardware connection
As shown in the figure below , In a I2C In the communication bus , Can connect multiple I2C Communication equipment , Support multiple communication hosts and multiple communication slaves .
- SDA, SCL Pin and pull-up resistance
- The equipment SDA, SCL Pin use OD Gate output , Line and operate between different equipment , namely “ And logic ”.
- SDA and SCL It needs to be connected with pull resistance , According to I2C Number of equipment , Communication speed of the system , Design and choose different pull-up resistors .I2C The number of devices determines the bus capacitance on the bus , Bus capacitance and pull-up resistance limit the communication rate of the system .
- Usually ,3.3V Pull up the resistance of the system and take 3.3kΩ,5V Pull up the resistance of the system and take 4.7kΩ.
- When I2C When the device is idle , It will output a high resistance state , And when all the devices are idle , When both output high resistance states , Pull the bus to high level by pull-up resistor .
Multi master and multi slave applications
- Each slave device connected to the bus has an independent address , The host can use this address to access different devices .
- When multiple hosts use the bus at the same time , To prevent data conflicts , Arbitration can be used to decide which host device occupies the bus .
I2C Communication protocol
The following figure shows a host (Master) To the slave (Slaver) Write a byte of data as an example , explain I2C Basic protocol of communication .

- Start signal ( S ): When SCL It's high level ,SDA Switch from high level to low level .
- Stop signal ( P ): When SCL It's high level ,SDA Switch from low level to high level .

- Frame address : Unique to each slave 7 Bit or 10 Bit address , Used for address identification between master and slave devices .I2C The protocol states that the device address can be 7 Bit or 10 position , In the actual 7 Bit addresses are widely used .
- read / Write in : a , If the master sends data to the slave, it is low , The request data is high .
- ACK/NACK:I2C The data and address of the transmission are with response . Responses include “ The reply (ACK)” and “ Non response (NACK)” Two signals .ACK Low level ,NACK High level .
- The data is valid : When data is transmitted ,SCL For high voltage ,SDA The data is valid , That at this time SDA Show data for high level “1”, Show data for low level “0”; When SCL Low power level ,SDA Invalid data for , Usually at this time , Yes SDA Carry out level switching .

Focus on v-x- Male - many - Number :【 Embedded base 】
after - platform - return - complex :【 Electric competition 】 Information available
reply 【 Programming 】 Can get
It includes :C、C++、C#、JAVA、Python、JavaScript、PHP、 database 、 Wechat applet 、 Artificial intelligence 、 The embedded 、Linux、Unix、QT、 The Internet of things 、 Introduction to algorithms 、 Big data and other information

边栏推荐
猜你喜欢
![[leetcode16] the sum of the nearest three numbers (double pointer)](/img/99/a167b0fe2962dd0b5fccd2d9280052.jpg)
[leetcode16] the sum of the nearest three numbers (double pointer)

Vulhub vulnerability recurrence 71_ Unomi

自建DNS服务器,客户端打开网页慢,解决办法

指針經典筆試題

RT thread analysis - object container implementation and function

Imperial cms7.5 imitation "D9 download station" software application download website source code

F12 solve the problem that web pages cannot be copied

Microblogging hot search stock selection strategy

Modbus协议通信异常
![[leetcode] 18. Sum of four numbers](/img/06/c160b47d756290e5474e4c07e68648.png)
[leetcode] 18. Sum of four numbers
随机推荐
[classic example] binary tree recursive structure classic topic collection @ binary tree
Nacos - TC Construction of High available seata (02)
Principle and performance analysis of lepton lossless compression
【云原生】3.1 Kubernetes平台安装KubeSpher
Fiddler installed the certificate, or prompted that the certificate is invalid
Implementing fuzzy query with dataframe
Using stopwatch to count code time
JS quick start (II)
The ECU of 21 Audi q5l 45tfsi brushes is upgraded to master special adjustment, and the horsepower is safely and stably increased to 305 horsepower
The ECU of 21 Audi q5l 45tfsi brushes is upgraded to master special adjustment, and the horsepower is safely and stably increased to 305 horsepower
Knowledge points of circular structure
EditorUtility. The role and application of setdirty in untiy
Figure database ongdb release v-1.0.3
Configuration file converted from Excel to Lua
Compilation and connection of shader in games202 webgl (learn from)
从0到1建设智能灰度数据体系:以vivo游戏中心为例
Pagoda configuration mongodb
The ECU of 21 Audi q5l 45tfsi brushes is upgraded to master special adjustment, and the horsepower is safely and stably increased to 305 horsepower
[cloud native] 3.1 kubernetes platform installation kubespher
组播和广播的知识点梳理