99精品伊人亚洲|最近国产中文炮友|九草在线视频支援|AV网站大全最新|美女黄片免费观看|国产精品资源视频|精彩无码视频一区|91大神在线后入|伊人终合在线播放|久草综合久久中文

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

關于I2C總線的讀寫操作流程詳解

電子設計 ? 來源:硬件助手 ? 作者:硬件助手 ? 2020-11-29 09:38 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

本文主要介紹I2C總線的讀寫操作流程。

I2C總線的操作包括讀和寫,具體的操作流程如下:

1、主機發(fā)送數(shù)據(jù)(I2C寫)流程
I2C主機給從機寫數(shù)據(jù)的操作流程如下:
Master發(fā)起START;
Master發(fā)送I2C ADDR(7bit)和W操作0(1bit),等待ACK;
Slave發(fā)送ACK(ACK=0);
Master發(fā)送reg addr(8bit),等待ACK(該地址為雙方約定的需要寫入數(shù)據(jù)的首地址,實際使用中隨機寫入時可以沒有該地址數(shù)據(jù));
Slave發(fā)送ACK;
Master收到Slave的ACK信號后開始發(fā)送第一個字節(jié)的數(shù)據(jù)(8bit),等待ACK;
Slave收到數(shù)據(jù)后發(fā)送ACK;
Master收到ACK后再發(fā)送下一個數(shù)據(jù);
當Master發(fā)送完最后一個字節(jié)數(shù)據(jù)并收到Slave的ACK后,發(fā)起STOP。



★主機通過發(fā)送地址碼與對應的從機建立了通信關系,而掛接在總線上的其它從機雖然同時也收到了地址碼,但因為與其自身的地址不相符合,因此提前退出與主機的通信;
★主機的一次發(fā)送通信,其發(fā)送的數(shù)據(jù)數(shù)量不受限制。主機是通過STOP信號通知發(fā)送的結束,從機收到STOP信號后退出本次通信;
★主機的每一次發(fā)送后都是通過從機的ACK信號了解從機的接收狀況,如果應答錯誤則重發(fā)(一般重發(fā)次數(shù)可以設置,但次數(shù)太多會影響效率);
★實際測試時,ACK信號會有一個毛刺,是因為數(shù)據(jù)和ACK是不同的角色發(fā)出的(當主機發(fā)送數(shù)據(jù)時,從機返回ACK;當從機發(fā)送數(shù)據(jù)時,主機返回ACK),這樣ACK正好是方向切換的時候,毛刺的大小取決于主從之間的切換速度。

2、主機接收數(shù)據(jù)(I2C讀)流程
I2C主機讀取從機數(shù)據(jù)的操作流程如下:
Master發(fā)送START;
Master發(fā)送I2C ADDR(7bit)和R操作1(1bit),等待ACK;
Slave發(fā)送ACK;
Master發(fā)送reg addr(8bit),等待ACK;
Slave發(fā)送ACK;
Master發(fā)起START;
Master發(fā)送I2C addr(7bit)和r操作1(1bit),等待ACK;
Slave發(fā)送ACK;
Slave發(fā)送ACK后,緊接著向Master發(fā)送數(shù)據(jù);
Master收到數(shù)據(jù)后發(fā)送ACK;
Slave接收到ACK后再向Master發(fā)送下一個數(shù)據(jù);
當Master完成接收數(shù)據(jù)后,向Slave發(fā)送一個非應答信號(NAK=1),從機收到非應答信號后停止發(fā)送數(shù)據(jù);
Master發(fā)送非應答信號后,再發(fā)送一個STOP信號。



★主機所接收數(shù)據(jù)的數(shù)量是由主機自身決定,當發(fā)送“非應答信號/A”時從機便結束傳送并釋放總線(非應答信號的兩個作用:前一個數(shù)據(jù)接收成功,從機不再發(fā)送數(shù)據(jù))。當從機收到NAK信號后如果沒有停止信號,則從機會重發(fā)上一字節(jié)數(shù)據(jù)。

3、讀寫指定地址的方式
I2C讀寫指定地址有以下幾種方式:
在從器件地址后面直接跟需要讀寫的寄存器首地址,然后直接跟數(shù)據(jù),最后通過停止信號結束此次讀寫。

主從器件約定讀寫指令,在從器件地址后面直接跟讀寫指令,然后再跟需要讀寫的寄存器首地址,然后直接跟數(shù)據(jù)。

在發(fā)送完從器件地址后直接跟需要讀寫的寄存器地址,然后再通過重復開始信號(后跟從機地址)進行讀寫操作(數(shù)據(jù)直接寫入或者讀取相應的寄存器)。





★所有讀寫操作,都不會限定數(shù)據(jù)的長度,讀寫數(shù)據(jù)的長度由主機決定。不需要讀寫數(shù)據(jù)了就發(fā)送STOP信號。

4、復合傳輸實現(xiàn)方式
在傳輸過程中改變方向,開始條件和從機地址都要重復,而讀寫bit要取反。如果主機發(fā)送一個重復的開始條件,那么它在這之前要發(fā)送一個NAK。

★復合模式可以在比如控制串行寄存器時用到。在第一個數(shù)據(jù)字節(jié)時一定要寫寄存器內部的地址。開始條件和從地址重復后,數(shù)據(jù)就開始傳輸了。
★自動增加或減少之前訪問的寄存器地址都由設備的設計者決定。
★兼容I2C總線的設備在接收到開始條件或重復開始條件時都一定要重啟它們的總線邏輯,即使開始條件都不是正確的格式,它們都期望發(fā)送從機地址。
★開始條件后馬上跟著一個終止條件是不合法的格式。

以上就是針對I2C總線的主機發(fā)送、主機接收、讀寫指定地址數(shù)據(jù)、符合傳輸方式的操作流程介紹。

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權轉載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • I2C總線
    +關注

    關注

    8

    文章

    408

    瀏覽量

    62200
收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關推薦
    熱點推薦

    I2C總線復用

    帝晶智慧屏I2C總線復用
    的頭像 發(fā)表于 03-11 17:20 ?1416次閱讀

    I2C總線通信原理 如何設計I2C總線電路

    I2C總線通信原理 I2C(Inter-Integrated Circuit)總線是一種用于集成電路之間進行通信的串行通信協(xié)議。它最早由飛利浦公司(現(xiàn)被恩智浦電子收購)于1982年推出
    的頭像 發(fā)表于 01-31 15:01 ?1136次閱讀

    I2C總線的優(yōu)缺點分析

    I2C總線作為一種廣泛使用的串行通信協(xié)議,以其簡單性和高效性在嵌入式系統(tǒng)中占據(jù)著重要地位。 I2C總線的優(yōu)點 1. 簡單性和低成本 I2C
    的頭像 發(fā)表于 01-17 15:50 ?1165次閱讀

    I2C總線數(shù)據(jù)包結構詳解

    。以下是I2C總線數(shù)據(jù)包結構的詳解: 一、I2C總線數(shù)據(jù)包的基本組成 I2C
    的頭像 發(fā)表于 01-17 15:46 ?811次閱讀

    I2C總線與Arduino的接口示例

    在現(xiàn)代電子設計中,I2C總線因其簡單性和靈活性而廣受歡迎。它允許多個設備共享同一通信線路,從而節(jié)省空間和成本。Arduino,作為一個多功能的微控制器平臺,自然也支持I2C通信。 I2C
    的頭像 發(fā)表于 01-17 15:34 ?1605次閱讀

    I2C總線的工作模式介紹

    在現(xiàn)代電子系統(tǒng)中,I2C總線作為一種多主機、多從機的串行通信協(xié)議,扮演著至關重要的角色。它允許多個設備共享同一總線,進行數(shù)據(jù)傳輸,從而簡化了系統(tǒng)設計并降低了成本。 I2C
    的頭像 發(fā)表于 01-17 15:32 ?995次閱讀

    I2C總線協(xié)議詳細解析

    1. I2C總線簡介 I2C總線由Philips Semiconductor(現(xiàn)為NXP Semiconductors)在1980年代初期開發(fā)。它是一種多主機
    的頭像 發(fā)表于 01-17 15:22 ?910次閱讀

    I2C總線故障排除技巧

    I2C總線是一種廣泛使用的串行通信協(xié)議,它允許多個設備在兩條線上(數(shù)據(jù)線SDA和時鐘線SCL)進行通信。由于其簡單性和靈活性,I2C總線在嵌入式系統(tǒng)中非常流行。然而,當
    的頭像 發(fā)表于 01-17 15:20 ?2352次閱讀

    I2C總線設備地址設置方法

    通常是一個7位或10位的數(shù)字,用于標識總線上的每個設備。在7位尋址模式下,地址范圍是0x00到0x7F,而在10位尋址模式下,地址范圍是0x000到0x3FF。I2C地址的最低位(LSB)通常用于指示讀/寫操作。 硬件地址設置
    的頭像 發(fā)表于 01-17 15:17 ?4247次閱讀

    I2C總線應用實例分析

    在現(xiàn)代電子系統(tǒng)中,I2C總線因其簡單、靈活和高效的特點而被廣泛應用于各種設備之間的通信。 I2C總線概述 I2C
    的頭像 發(fā)表于 01-17 15:09 ?753次閱讀

    I2C總線與SPI總線的比較

    在現(xiàn)代電子系統(tǒng)中,微控制器與各種外設之間的通信是必不可少的。I2C和SPI是兩種流行的串行通信協(xié)議,它們各自具有獨特的特點和應用場景。 I2C總線 I2C是一種多主機、多從機的同步通信
    的頭像 發(fā)表于 01-17 15:08 ?943次閱讀

    I2C總線上拉電阻阻值如何確定?

    導讀I2C總線在產品設計中被廣泛應用,盡管其結構簡單,但經(jīng)常發(fā)生上拉電阻設計不合理的問題。本文將對I2C上拉電阻的選擇進行簡要分析。一根信號線上,通過電阻連接一個固定的高電平VCC,信號線初始、空閑
    的頭像 發(fā)表于 12-27 11:34 ?1859次閱讀
    <b class='flag-5'>I2C</b><b class='flag-5'>總線</b>上拉電阻阻值如何確定?

    詳解I2C總線與SPI總線的區(qū)別

    I2C(Inter-Integrated Circuit)表示集成電路互連,是一種用于線路板內部芯片之間通信的總線。
    的頭像 發(fā)表于 10-16 15:16 ?1.5w次閱讀
    <b class='flag-5'>詳解</b><b class='flag-5'>I2C</b><b class='flag-5'>總線</b>與SPI<b class='flag-5'>總線</b>的區(qū)別

    了解I2C總線

    電子發(fā)燒友網(wǎng)站提供《了解I2C總線.pdf》資料免費下載
    發(fā)表于 10-08 11:13 ?2次下載
    了解<b class='flag-5'>I2C</b><b class='flag-5'>總線</b>

    物聯(lián)網(wǎng)嵌入式軟件中的I2C總線設計詳解

    I2C(Inter-Integrated Circuit)通信總線,作為嵌入式系統(tǒng)設計中的一個關鍵組成部分,其靈活性和高效率使其在高級應用中備受青睞。本文旨在提供關于I2C通信
    的頭像 發(fā)表于 09-29 16:21 ?962次閱讀
    物聯(lián)網(wǎng)嵌入式軟件中的<b class='flag-5'>I2C</b><b class='flag-5'>總線</b>設計<b class='flag-5'>詳解</b>