IIC串行總線工作原理與應用課件_第1頁
IIC串行總線工作原理與應用課件_第2頁
IIC串行總線工作原理與應用課件_第3頁
IIC串行總線工作原理與應用課件_第4頁
IIC串行總線工作原理與應用課件_第5頁
已閱讀5頁,還剩113頁未讀, 繼續(xù)免費閱讀

下載本文檔

版權說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權,請進行舉報或認領

文檔簡介

IIC串行總線工作原理與應用IIC串行總線工作原理與應用IIC串行總線工作原理與應用1.I2C串行總線的組成及工作原理采用串行總線技術可以使系統(tǒng)的硬件設計大大簡化、系統(tǒng)的體積減小、可靠性提高。同時,系統(tǒng)的更改和擴充極為容易。常用的串行擴展總線有:I2C(InterICBUS)總線、單總線(1-WIREBUS)、SPI(SerialPeripheralInterface)總線及Microwire/PLUS等。本章僅討論I2C串行總線。2IIC串行總線工作原理與應用IIC串行總線工作原理與應用II11.I2C串行總線的組成及工作原理采用串行總線技術可以使系統(tǒng)的硬件設計大大簡化、系統(tǒng)的體積減小、可靠性提高。同時,系統(tǒng)的更改和擴充極為容易。常用的串行擴展總線有:I2C(InterICBUS)總線、單總線(1-WIREBUS)、SPI(SerialPeripheralInterface)總線及Microwire/PLUS等。

本章僅討論I2C串行總線。21.I2C串行總線的組成及工作原理采用串行總線技術可以I2C串行總線概述I2C總線是PHLIPS公司推出的一種串行總線,是具備多主機系統(tǒng)所需的包括總線裁決和高低速器件同步功能的高性能串行總線。

I2C總線只有兩根雙向信號線。一根是數(shù)據(jù)線SDA,另一根是時鐘線SCL。3I2C串行總線概述I2C總線是PHLIPS公司推出的總線接口器件地址具有很大的獨立性。在單主系統(tǒng)中,每個I2C接口芯片具有唯一的器件地址,各從器件之間互不干擾,相互之間不能進行通信。MCU與I2C器件之間的通信是通過獨一無二的器件地址來實現(xiàn)的。數(shù)據(jù)傳輸首先從最高位開始。傳輸速率在標準模式下可達100kbit/s,在快速模式下達400kbit/s,在高速模式下達3.4Mbit/s。它是一個真正的多主機總線。如果兩個或更多主機同時初始化數(shù)據(jù)傳輸,可以通過沖突檢測和仲裁防止數(shù)據(jù)被破壞。軟件操作的一致性。任何器件通過I2C總線與MCU進行數(shù)據(jù)傳送的方式基本一樣,決定了I2C總線軟件編寫的一致性。數(shù)據(jù)線SDA/時鐘線SCL(接上拉電阻)

4總線接口器件地址具有很大的獨立性。在單主系統(tǒng)中,每個I2C接I2C總線通過上拉電阻接正電源。當總線空閑時,兩根線均為高電平。連到總線上的任一器件輸出的低電平,都將使總線的信號變低,即各器件的SDA及SCL都是線“與”關系。5I2C總線通過上拉電阻接正電源。當總線空閑時,兩根

每個接到I2C總線上的器件都有唯一的地址。主機與其它器件間的數(shù)據(jù)傳送可以是由主機發(fā)送數(shù)據(jù)到其它器件,這時主機即為發(fā)送器。由總線上接收數(shù)據(jù)的器件則為接收器。

在多主機系統(tǒng)中,可能同時有幾個主機企圖啟動總線傳送數(shù)據(jù)。為了避免混亂,I2C總線要通過總線仲裁,以決定由哪一臺主機控制總線。在80C51單片機應用系統(tǒng)的串行總線擴展中,我們經(jīng)常遇到的是以80C51單片機為主機,其它接口器件為從機的單主機情況。

6每個接到I2C總線上的器件都有唯一的地址。主機與其它一、數(shù)據(jù)位的有效性規(guī)定

I2C總線進行數(shù)據(jù)傳送時,時鐘信號為高電平期間,數(shù)據(jù)線上的數(shù)據(jù)必須保持穩(wěn)定,只有在時鐘線上的信號為低電平期間,數(shù)據(jù)線上的高電平或低電平狀態(tài)才允許變化。2.I2C總線的數(shù)據(jù)傳送7一、數(shù)據(jù)位的有效性規(guī)定2.I2C總線的數(shù)據(jù)傳送7二、起始和終止信號SCL線為高電平期間,SDA線由高電平向低電平的變化表示起始信號;SCL線為高電平期間,SDA線由低電平向高電平的變化表示終止信號。

8二、起始和終止信號SCL線為高電平期間,SDA線由高

起始和終止信號都是由主機發(fā)出的,在起始信號產(chǎn)生后,總線就處于被占用的狀態(tài);在終止信號產(chǎn)生后,總線就處于空閑狀態(tài)。

連接到I2C總線上的器件,若具有I2C總線的硬件接口,則很容易檢測到起始和終止信號。對于不具備I2C總線硬件接口的有些單片機來說,為了檢測起始和終止信號,必須保證在每個時鐘周期內(nèi)對數(shù)據(jù)線SDA采樣兩次。

接收器件收到一個完整的數(shù)據(jù)字節(jié)后,有可能需要完成一些其它工作,如處理內(nèi)部中斷服務等,可能無法立刻接收下一個字節(jié),這時接收器件可以將SCL線拉成低電平,從而使主機處于等待狀態(tài)。直到接收器件準備好接收下一個字節(jié)時,再釋放SCL線使之為高電平,從而使數(shù)據(jù)傳送可以繼續(xù)進行。

9起始和終止信號都是由主機發(fā)出的,在起始信號產(chǎn)生后,三、數(shù)據(jù)傳送格式(1)字節(jié)傳送與應答

每一個字節(jié)必須保證是8位長度。數(shù)據(jù)傳送時,先傳送最高位(MSB),每一個被傳送的字節(jié)后面都必須跟隨一位應答位(即一幀共有9位)。

10三、數(shù)據(jù)傳送格式每一個字節(jié)必須保證是8位長度。數(shù)據(jù)傳

由于某種原因從機不對主機尋址信號應答時(如從機正在進行實時性的處理工作而無法接收總線上的數(shù)據(jù)),它必須將數(shù)據(jù)線置于高電平,而由主機產(chǎn)生一個終止信號以結束總線的數(shù)據(jù)傳送。

如果從機對主機進行了應答,但在數(shù)據(jù)傳送一段時間后無法繼續(xù)接收更多的數(shù)據(jù)時,從機可以通過對無法接收的第一個數(shù)據(jù)字節(jié)的“非應答”通知主機,主機則應發(fā)出終止信號以結束數(shù)據(jù)的繼續(xù)傳送。

當主機接收數(shù)據(jù)時,它收到最后一個數(shù)據(jù)字節(jié)后,必須向從機發(fā)出一個結束傳送的信號。這個信號是由對從機的“非應答”來實現(xiàn)的。然后,從機釋放SDA線,以允許主機產(chǎn)生終止信號。11由于某種原因從機不對主機尋址信號應答時(如從機正在進(2)數(shù)據(jù)幀格式

I2C總線上傳送的數(shù)據(jù)信號是廣義的,既包括地址信號,又包括真正的數(shù)據(jù)信號。

在總線的一次數(shù)據(jù)傳送過程中,可以有以下幾種組合方式:

在起始信號后必須傳送一個從機的地址(7位),第8位是數(shù)據(jù)的傳送方向位(R/),用“0”表示主機發(fā)送數(shù)據(jù)(T),“1”表示主機接收數(shù)據(jù)(R)。每次數(shù)據(jù)傳送總是由主機產(chǎn)生的終止信號結束。但是,若主機希望繼續(xù)占用總線進行新的數(shù)據(jù)傳送,則可以不產(chǎn)生終止信號,馬上再次發(fā)出起始信號對另一從機進行尋址。

12(2)數(shù)據(jù)幀格式在總線的一次數(shù)據(jù)傳送過程中,可以有以a、主機向從機發(fā)送數(shù)據(jù),數(shù)據(jù)傳送方向在整個傳送過程中不變:注:有陰影部分表示數(shù)據(jù)由主機向從機傳送,無陰影部分則表示數(shù)據(jù)由從機向主機傳送。

A表示應答,表示非應答(高電平)。S表示起始信號,P表示終止信號。。13a、主機向從機發(fā)送數(shù)據(jù),數(shù)據(jù)傳送方向在整個傳送過程中不變:注b、主機在第一個字節(jié)后,立即由從機讀數(shù)據(jù)c、在傳送過程中,當需要改變傳送方向時,起始信號和從機地址都被重復產(chǎn)生一次,但兩次讀/寫方向位正好反相。14b、主機在第一個字節(jié)后,立即由從機讀數(shù)據(jù)c、在傳送過程中,當四、總線的尋址I2C總線協(xié)議有明確的規(guī)定:采用7位的尋址字節(jié)(尋址字節(jié)是起始信號后的第一個字節(jié))。(1)尋址字節(jié)的位定義D7~D1位組成從機的地址。D0位是數(shù)據(jù)傳送方向位,為“0”時表示主機向從機寫數(shù)據(jù),為“1”時表示主機由從機讀數(shù)據(jù)。15四、總線的尋址I2C總線協(xié)議有明確的規(guī)定:采用7位主機發(fā)送地址時,總線上的每個從機都將這7位地址碼與自己的地址進行比較,如果相同,則認為自己正被主機尋址,根據(jù)R/位將自己確定為發(fā)送器或接收器。從機的地址由固定部分和可編程部分組成。在一個系統(tǒng)中可能希望接入多個相同的從機,從機地址中可編程部分決定了可接入總線該類器件的最大數(shù)目。如一個從機的7位尋址位有4位是固定位,3位是可編程位,這時僅能尋址8個同樣的器件,即可以有8個同樣的器件接入到該I2C總線系統(tǒng)中。16主機發(fā)送地址時,總線上的每個從機都將這7位地址碼與自己的地址(2)尋址字節(jié)中的特殊地址固定地址編號0000和1111已被保留作為特殊用途。

17(2)尋址字節(jié)中的特殊地址17

起始信號后的第一字節(jié)的8位為“00000000”時,稱為通用呼叫地址。通用呼叫地址的用意在第二字節(jié)中加以說明。格式為:

第二字節(jié)為06H時,所有能響應通用呼叫地址的從機器件復位,并由硬件裝入從機地址的可編程部分。能響應命令的從機器件復位時不拉低SDA和SCL線,以免堵塞總線。

第二字節(jié)為04H時,所有能響應通用呼叫地址并通過硬件來定義其可編程地址的從機器件將鎖定地址中的可編程位,但不進行復位。18起始信號后的第一字節(jié)的8位為“00000000”時,

如果第二字節(jié)的方向位B為“1”,則這兩個字節(jié)命令稱為硬件通用呼叫命令。

在這第二字節(jié)的高7位說明自己的地址。接在總線上的智能器件,如單片機或其他微處理器能識別這個地址,并與之傳送數(shù)據(jù)。硬件主器件作為從機使用時,也用這個地址作為從機地址。格式為:

在系統(tǒng)中另一種選擇可能是系統(tǒng)復位時硬件主機器件工作在從機接收器方式,這時由系統(tǒng)中的主機先告訴硬件主機器件數(shù)據(jù)應送往的從機器件地址,當硬件主機器件要發(fā)送數(shù)據(jù)時就可以直接向指定從機器件發(fā)送數(shù)據(jù)了。19如果第二字節(jié)的方向位B為“1”,則這兩個字節(jié)命令稱(3)起始字節(jié)

不具備I2C總線接口的單片機,則必須通過軟件不斷地檢測總線,以便及時地響應總線的請求。單片機的速度與硬件接口器件的速度就出現(xiàn)了較大的差別,為此,I2C總線上的數(shù)據(jù)傳送要由一個較長的起始過程加以引導。

起始字節(jié)是提供給沒有I2C總線接口的單片機查詢I2C總線時使用的特殊字節(jié)。20(3)起始字節(jié)不具備I2C總線接口的單片機,則必須通

引導過程由起始信號、起始字節(jié)、應答位、重復起始信號(Sr)組成。請求訪問總線的主機發(fā)出起始信號后,發(fā)送起始字節(jié)(00000001),另一個單片機可以用一個比較低的速率采樣SDA線,直到檢測到起始字節(jié)中的7個“0”中的一個為止。在檢測到SDA線上的高電平后,單片機就可以用較高的采樣速率,以便尋找作為同步信號使用的第二個起始信號Sr。在起始信號后的應答時鐘脈沖僅僅是為了和總線所使用的格式一致,并不要求器件在這個脈沖期間作應答。

21引導過程由起始信號、起始字節(jié)、應答位、重復起始信3.80C51單片機I2C串行總線器件的接口一、典型信號模擬為了保證數(shù)據(jù)傳送的可靠性,標準的I2C總線的數(shù)據(jù)傳送有嚴格的時序要求。I2C總線的起始信號、終止信號、發(fā)送“0”及發(fā)送“1”的模擬時序:一、總線數(shù)據(jù)傳送的模擬

主機可以采用不帶I2C總線接口的單片機,如80C51、AT89C2051等單片機,利用軟件實現(xiàn)I2C總線的數(shù)據(jù)傳送,即軟件與硬件結合的信號模擬。

223.80C51單片機I2C串行總線器件的接口一、典型信號I2C總線信號類型開始信號:SCL為高電平時,SDA由高電平向低電平跳變,開始傳送數(shù)據(jù)。結束信號:SCL為低電平時,SDA由低電平向高電平跳變,結束傳送數(shù)據(jù)。應答信號:接收數(shù)據(jù)的器件在接收到8bit數(shù)據(jù)后,向發(fā)送數(shù)據(jù)的器件(發(fā)送器)發(fā)出特定的低電平脈沖,表示已收到數(shù)據(jù)。發(fā)送器接收到應答信號后,根據(jù)實際情況作出是否繼續(xù)傳遞信號的判斷。若未收到應答信號,由判斷為接收器出現(xiàn)故障。數(shù)據(jù)只能在SCL為低電平時才能改變,SCL為高電平時SDA須穩(wěn)定。起始信號與結束信號都是由主器件產(chǎn)生。23I2C總線信號類型232424二、典型信號模擬子程序(1)起始信號VoidT2CStart(void){ SomeNop(); SCL=1; SomeNop(); SDA=0; SomeNop(); SCL=0; SomeNop();}25二、典型信號模擬子程序(1)起始信號25(2)終止信號voidI2cStop(void){ SDA=0; SomeNop(); SCL=1; SomeNop(); SDA=1; SomeNop(); SCL=0;}26(2)終止信號26三、在51上用P1口模擬I2C(c語言)/*電平模擬函數(shù)和基本讀寫函數(shù)voidIIC_Start(void);voidIIC_Stop(void);voidSEND_0(void);voidSEND_1(void);bitCheck_Acknowledge(void);voidWrite_Byte(ucharb);bitWrite_N_Bytes(uchar*buffer,ucharn);bitRead_N_Bytes(ucharSlaveAdr,ucharn,uchar*buffer);ucharRead_Byte(void);*/27三、在51上用P1口模擬I2C(c語言)/*電平模擬函#include<string.h>#include<reg52.h>#include<intrins.h>#include"aiic_51.h"sbitSCL=P1^6;sbitSDA=P1^7;voidDELAY(uintt){while(t!=0)t--;}28#include<string.h>28voidIIC_Start(void){//啟動I2C總線的函數(shù),當SCL為高電平時使SDA產(chǎn)生一個負跳變SDA=1;SCL=1;DELAY(DELAY_TIME);SDA=0;DELAY(DELAY_TIME);SCL=0;DELAY(DELAY_TIME);}29voidIIC_Start(void)29voidIIC_Stop(void){//終止I2C總線,當SCL為高電平時使SDA產(chǎn)生一個正跳變SDA=0;SCL=1;DELAY(DELAY_TIME);SDA=1;DELAY(DELAY_TIME);SCL=0;DELAY(DELAY_TIME);}30voidIIC_Stop(void)30voidSEND_0(void){//發(fā)送0,在SCL為低電平時使SDA信號變?yōu)榈蚐CL=0;SDA=0;SCL=1;DELAY(DELAY_TIME);SCL=0;DELAY(DELAY_TIME);}voidSEND_1(void){//發(fā)送1,在SCL為低電平時使SDA信號變?yōu)楦逽CL=0;SDA=1;SCL=1;DELAY(DELAY_TIME);SCL=0;DELAY(DELAY_TIME);}31voidSEND_0(void)31bitCheck_Acknowledge(void){//發(fā)送完一個字節(jié)后檢驗設備的應答信號SDA=1;SCL=1;DELAY(DELAY_TIME/2);F0=SDA;DELAY(DELAY_TIME/2);SCL=0;DELAY(DELAY_TIME);if(F0==1)returnFALSE;elsereturnTRUE;}32bitCheck_Acknowledge(void)32voidWrite_Byte(ucharb){//向IIC總線寫一個字節(jié)uchari;for(i=0;i<8;i++)if((b<<i)&0x80)SEND_1();elseSEND_0();}33voidWrite_Byte(ucharb)33bitWrite_N_Bytes(uchar*buffer,ucharn){//向I2C總線寫n個字節(jié)uchari;IIC_Start();for(i=0;i<n;i++) { Write_Byte(buffer[i]); if(!Check_Acknowledge()) { IIC_Stop(); return(i==n); } }IIC_Stop();returnTRUE;}34bitWrite_N_Bytes(uchar*buffeucharRead_Byte(void)reentrant{//從I2C總線讀一個字節(jié)ucharb=0,i;for(i=0;i<8;i++) { SDA=1;//釋放總線

SCL=1;//接受數(shù)據(jù)

DELAY(10); F0=SDA; DELAY(10); SCL=0; if(F0==1) { b=b<<1; b=b|0x01; } else b=b<<1; }returnb;}35ucharRead_Byte(void)reentrantbitRead_N_Bytes(ucharSlaveAdr,ucharn,uchar*buffer){//從I2C總線讀n個字節(jié)uchari;IIC_Start();Write_Byte(SlaveAdr);//向總線發(fā)送接收器地址if(!Check_Acknowledge())//等待接收器應答信號returnFALSE;for(i=0;i<n;i++) { buffer[i]=Read_Byte(); if(i!=n) SEND_0();//發(fā)送應答

else SEND_1();//發(fā)送非應答

}IIC_Stop();returnTRUE;}36bitRead_N_Bytes(ucharSlaveAd

2I2C總線器件的擴展一、擴展電路

372I2C總線器件的擴展一、擴展電路37

二、串行E2PROM的擴展

(1)串行E2PROM典型產(chǎn)品AT24C01:128字節(jié)(128×8位);

AT24C02:256字節(jié)(256×8位);AT24C04:512字節(jié)(512×8位)AT24C08:1K字節(jié)(1K×8位);AT24C16:2K字節(jié)(2K×8位);ATMEL公司的AT24C系列:38二、串行E2PROM的擴展(1)串行E2PROM典

(2)寫入過程

AT24C系列E2PROM芯片地址的固定部分為1010,A2、A1、A0引腳接高、低電平后得到確定的3位編碼。形成的7位編碼即為該器件的地址碼。

單片機進行寫操作時,首先發(fā)送該器件的7位地址碼和寫方向位“0”(共8位,即一個字節(jié)),發(fā)送完后釋放SDA線并在SCL線上產(chǎn)生第9個時鐘信號。被選中的存儲器器件在確認是自己的地址后,在SDA線上產(chǎn)生一個應答信號作為相應,單片機收到應答后就可以傳送數(shù)據(jù)了。39(2)寫入過程單片機進行寫操作時,首先發(fā)送該器

傳送數(shù)據(jù)時,單片機首先發(fā)送一個字節(jié)的被寫入器件的存儲區(qū)的首地址,收到存儲器器件的應答后,單片機就逐個發(fā)送各數(shù)據(jù)字節(jié),但每發(fā)送一個字節(jié)后都要等待應答。AT24C系列器件片內(nèi)地址在接收到每一個數(shù)據(jù)字節(jié)地址后自動加1,在芯片的“一次裝載字節(jié)數(shù)”(不同芯片字節(jié)數(shù)不同)限度內(nèi),只需輸入首地址。裝載字節(jié)數(shù)超過芯片的“一次裝載字節(jié)數(shù)”時,數(shù)據(jù)地址將“上卷”,前面的數(shù)據(jù)將被覆蓋。

當要寫入的數(shù)據(jù)傳送完后,單片機應發(fā)出終止信號以結束寫入操作。寫入n個字節(jié)的數(shù)據(jù)格式:40傳送數(shù)據(jù)時,單片機首先發(fā)送一個字節(jié)的被寫入器件的存儲

(3)讀出過程單片機先發(fā)送該器件的7位地址碼和寫方向位“0”(“偽寫”),發(fā)送完后釋放SDA線并在SCL線上產(chǎn)生第9個時鐘信號。被選中的存儲器器件在確認是自己的地址后,在SDA線上產(chǎn)生一個應答信號作為相應。

然后,再發(fā)一個字節(jié)的要讀出器件的存儲區(qū)的首地址,收到應答后,單片機要重復一次起始信號并發(fā)出器件地址和讀方向位(“1”),收到器件應答后就可以讀出數(shù)據(jù)字節(jié),每讀出一個字節(jié),單片機都要回復應答信號。當最后一個字節(jié)數(shù)據(jù)讀完后,單片機應返回以“非應答”(高電平),并發(fā)出終止信號以結束讀出操作。

41(3)讀出過程然后,再發(fā)一個字節(jié)的要讀出器件的IIC例:42IIC例:424343444445454646474748484949505051515252535354545555565657575858謝謝大家!

結語謝謝大家!結語59IIC串行總線工作原理與應用IIC串行總線工作原理與應用IIC串行總線工作原理與應用1.I2C串行總線的組成及工作原理采用串行總線技術可以使系統(tǒng)的硬件設計大大簡化、系統(tǒng)的體積減小、可靠性提高。同時,系統(tǒng)的更改和擴充極為容易。常用的串行擴展總線有:I2C(InterICBUS)總線、單總線(1-WIREBUS)、SPI(SerialPeripheralInterface)總線及Microwire/PLUS等。本章僅討論I2C串行總線。2IIC串行總線工作原理與應用IIC串行總線工作原理與應用II601.I2C串行總線的組成及工作原理采用串行總線技術可以使系統(tǒng)的硬件設計大大簡化、系統(tǒng)的體積減小、可靠性提高。同時,系統(tǒng)的更改和擴充極為容易。常用的串行擴展總線有:I2C(InterICBUS)總線、單總線(1-WIREBUS)、SPI(SerialPeripheralInterface)總線及Microwire/PLUS等。

本章僅討論I2C串行總線。611.I2C串行總線的組成及工作原理采用串行總線技術可以I2C串行總線概述I2C總線是PHLIPS公司推出的一種串行總線,是具備多主機系統(tǒng)所需的包括總線裁決和高低速器件同步功能的高性能串行總線。

I2C總線只有兩根雙向信號線。一根是數(shù)據(jù)線SDA,另一根是時鐘線SCL。62I2C串行總線概述I2C總線是PHLIPS公司推出的總線接口器件地址具有很大的獨立性。在單主系統(tǒng)中,每個I2C接口芯片具有唯一的器件地址,各從器件之間互不干擾,相互之間不能進行通信。MCU與I2C器件之間的通信是通過獨一無二的器件地址來實現(xiàn)的。數(shù)據(jù)傳輸首先從最高位開始。傳輸速率在標準模式下可達100kbit/s,在快速模式下達400kbit/s,在高速模式下達3.4Mbit/s。它是一個真正的多主機總線。如果兩個或更多主機同時初始化數(shù)據(jù)傳輸,可以通過沖突檢測和仲裁防止數(shù)據(jù)被破壞。軟件操作的一致性。任何器件通過I2C總線與MCU進行數(shù)據(jù)傳送的方式基本一樣,決定了I2C總線軟件編寫的一致性。數(shù)據(jù)線SDA/時鐘線SCL(接上拉電阻)

63總線接口器件地址具有很大的獨立性。在單主系統(tǒng)中,每個I2C接I2C總線通過上拉電阻接正電源。當總線空閑時,兩根線均為高電平。連到總線上的任一器件輸出的低電平,都將使總線的信號變低,即各器件的SDA及SCL都是線“與”關系。64I2C總線通過上拉電阻接正電源。當總線空閑時,兩根

每個接到I2C總線上的器件都有唯一的地址。主機與其它器件間的數(shù)據(jù)傳送可以是由主機發(fā)送數(shù)據(jù)到其它器件,這時主機即為發(fā)送器。由總線上接收數(shù)據(jù)的器件則為接收器。

在多主機系統(tǒng)中,可能同時有幾個主機企圖啟動總線傳送數(shù)據(jù)。為了避免混亂,I2C總線要通過總線仲裁,以決定由哪一臺主機控制總線。在80C51單片機應用系統(tǒng)的串行總線擴展中,我們經(jīng)常遇到的是以80C51單片機為主機,其它接口器件為從機的單主機情況。

65每個接到I2C總線上的器件都有唯一的地址。主機與其它一、數(shù)據(jù)位的有效性規(guī)定

I2C總線進行數(shù)據(jù)傳送時,時鐘信號為高電平期間,數(shù)據(jù)線上的數(shù)據(jù)必須保持穩(wěn)定,只有在時鐘線上的信號為低電平期間,數(shù)據(jù)線上的高電平或低電平狀態(tài)才允許變化。2.I2C總線的數(shù)據(jù)傳送66一、數(shù)據(jù)位的有效性規(guī)定2.I2C總線的數(shù)據(jù)傳送7二、起始和終止信號SCL線為高電平期間,SDA線由高電平向低電平的變化表示起始信號;SCL線為高電平期間,SDA線由低電平向高電平的變化表示終止信號。

67二、起始和終止信號SCL線為高電平期間,SDA線由高

起始和終止信號都是由主機發(fā)出的,在起始信號產(chǎn)生后,總線就處于被占用的狀態(tài);在終止信號產(chǎn)生后,總線就處于空閑狀態(tài)。

連接到I2C總線上的器件,若具有I2C總線的硬件接口,則很容易檢測到起始和終止信號。對于不具備I2C總線硬件接口的有些單片機來說,為了檢測起始和終止信號,必須保證在每個時鐘周期內(nèi)對數(shù)據(jù)線SDA采樣兩次。

接收器件收到一個完整的數(shù)據(jù)字節(jié)后,有可能需要完成一些其它工作,如處理內(nèi)部中斷服務等,可能無法立刻接收下一個字節(jié),這時接收器件可以將SCL線拉成低電平,從而使主機處于等待狀態(tài)。直到接收器件準備好接收下一個字節(jié)時,再釋放SCL線使之為高電平,從而使數(shù)據(jù)傳送可以繼續(xù)進行。

68起始和終止信號都是由主機發(fā)出的,在起始信號產(chǎn)生后,三、數(shù)據(jù)傳送格式(1)字節(jié)傳送與應答

每一個字節(jié)必須保證是8位長度。數(shù)據(jù)傳送時,先傳送最高位(MSB),每一個被傳送的字節(jié)后面都必須跟隨一位應答位(即一幀共有9位)。

69三、數(shù)據(jù)傳送格式每一個字節(jié)必須保證是8位長度。數(shù)據(jù)傳

由于某種原因從機不對主機尋址信號應答時(如從機正在進行實時性的處理工作而無法接收總線上的數(shù)據(jù)),它必須將數(shù)據(jù)線置于高電平,而由主機產(chǎn)生一個終止信號以結束總線的數(shù)據(jù)傳送。

如果從機對主機進行了應答,但在數(shù)據(jù)傳送一段時間后無法繼續(xù)接收更多的數(shù)據(jù)時,從機可以通過對無法接收的第一個數(shù)據(jù)字節(jié)的“非應答”通知主機,主機則應發(fā)出終止信號以結束數(shù)據(jù)的繼續(xù)傳送。

當主機接收數(shù)據(jù)時,它收到最后一個數(shù)據(jù)字節(jié)后,必須向從機發(fā)出一個結束傳送的信號。這個信號是由對從機的“非應答”來實現(xiàn)的。然后,從機釋放SDA線,以允許主機產(chǎn)生終止信號。70由于某種原因從機不對主機尋址信號應答時(如從機正在進(2)數(shù)據(jù)幀格式

I2C總線上傳送的數(shù)據(jù)信號是廣義的,既包括地址信號,又包括真正的數(shù)據(jù)信號。

在總線的一次數(shù)據(jù)傳送過程中,可以有以下幾種組合方式:

在起始信號后必須傳送一個從機的地址(7位),第8位是數(shù)據(jù)的傳送方向位(R/),用“0”表示主機發(fā)送數(shù)據(jù)(T),“1”表示主機接收數(shù)據(jù)(R)。每次數(shù)據(jù)傳送總是由主機產(chǎn)生的終止信號結束。但是,若主機希望繼續(xù)占用總線進行新的數(shù)據(jù)傳送,則可以不產(chǎn)生終止信號,馬上再次發(fā)出起始信號對另一從機進行尋址。

71(2)數(shù)據(jù)幀格式在總線的一次數(shù)據(jù)傳送過程中,可以有以a、主機向從機發(fā)送數(shù)據(jù),數(shù)據(jù)傳送方向在整個傳送過程中不變:注:有陰影部分表示數(shù)據(jù)由主機向從機傳送,無陰影部分則表示數(shù)據(jù)由從機向主機傳送。

A表示應答,表示非應答(高電平)。S表示起始信號,P表示終止信號。。72a、主機向從機發(fā)送數(shù)據(jù),數(shù)據(jù)傳送方向在整個傳送過程中不變:注b、主機在第一個字節(jié)后,立即由從機讀數(shù)據(jù)c、在傳送過程中,當需要改變傳送方向時,起始信號和從機地址都被重復產(chǎn)生一次,但兩次讀/寫方向位正好反相。73b、主機在第一個字節(jié)后,立即由從機讀數(shù)據(jù)c、在傳送過程中,當四、總線的尋址I2C總線協(xié)議有明確的規(guī)定:采用7位的尋址字節(jié)(尋址字節(jié)是起始信號后的第一個字節(jié))。(1)尋址字節(jié)的位定義D7~D1位組成從機的地址。D0位是數(shù)據(jù)傳送方向位,為“0”時表示主機向從機寫數(shù)據(jù),為“1”時表示主機由從機讀數(shù)據(jù)。74四、總線的尋址I2C總線協(xié)議有明確的規(guī)定:采用7位主機發(fā)送地址時,總線上的每個從機都將這7位地址碼與自己的地址進行比較,如果相同,則認為自己正被主機尋址,根據(jù)R/位將自己確定為發(fā)送器或接收器。從機的地址由固定部分和可編程部分組成。在一個系統(tǒng)中可能希望接入多個相同的從機,從機地址中可編程部分決定了可接入總線該類器件的最大數(shù)目。如一個從機的7位尋址位有4位是固定位,3位是可編程位,這時僅能尋址8個同樣的器件,即可以有8個同樣的器件接入到該I2C總線系統(tǒng)中。75主機發(fā)送地址時,總線上的每個從機都將這7位地址碼與自己的地址(2)尋址字節(jié)中的特殊地址固定地址編號0000和1111已被保留作為特殊用途。

76(2)尋址字節(jié)中的特殊地址17

起始信號后的第一字節(jié)的8位為“00000000”時,稱為通用呼叫地址。通用呼叫地址的用意在第二字節(jié)中加以說明。格式為:

第二字節(jié)為06H時,所有能響應通用呼叫地址的從機器件復位,并由硬件裝入從機地址的可編程部分。能響應命令的從機器件復位時不拉低SDA和SCL線,以免堵塞總線。

第二字節(jié)為04H時,所有能響應通用呼叫地址并通過硬件來定義其可編程地址的從機器件將鎖定地址中的可編程位,但不進行復位。77起始信號后的第一字節(jié)的8位為“00000000”時,

如果第二字節(jié)的方向位B為“1”,則這兩個字節(jié)命令稱為硬件通用呼叫命令。

在這第二字節(jié)的高7位說明自己的地址。接在總線上的智能器件,如單片機或其他微處理器能識別這個地址,并與之傳送數(shù)據(jù)。硬件主器件作為從機使用時,也用這個地址作為從機地址。格式為:

在系統(tǒng)中另一種選擇可能是系統(tǒng)復位時硬件主機器件工作在從機接收器方式,這時由系統(tǒng)中的主機先告訴硬件主機器件數(shù)據(jù)應送往的從機器件地址,當硬件主機器件要發(fā)送數(shù)據(jù)時就可以直接向指定從機器件發(fā)送數(shù)據(jù)了。78如果第二字節(jié)的方向位B為“1”,則這兩個字節(jié)命令稱(3)起始字節(jié)

不具備I2C總線接口的單片機,則必須通過軟件不斷地檢測總線,以便及時地響應總線的請求。單片機的速度與硬件接口器件的速度就出現(xiàn)了較大的差別,為此,I2C總線上的數(shù)據(jù)傳送要由一個較長的起始過程加以引導。

起始字節(jié)是提供給沒有I2C總線接口的單片機查詢I2C總線時使用的特殊字節(jié)。79(3)起始字節(jié)不具備I2C總線接口的單片機,則必須通

引導過程由起始信號、起始字節(jié)、應答位、重復起始信號(Sr)組成。請求訪問總線的主機發(fā)出起始信號后,發(fā)送起始字節(jié)(00000001),另一個單片機可以用一個比較低的速率采樣SDA線,直到檢測到起始字節(jié)中的7個“0”中的一個為止。在檢測到SDA線上的高電平后,單片機就可以用較高的采樣速率,以便尋找作為同步信號使用的第二個起始信號Sr。在起始信號后的應答時鐘脈沖僅僅是為了和總線所使用的格式一致,并不要求器件在這個脈沖期間作應答。

80引導過程由起始信號、起始字節(jié)、應答位、重復起始信3.80C51單片機I2C串行總線器件的接口一、典型信號模擬為了保證數(shù)據(jù)傳送的可靠性,標準的I2C總線的數(shù)據(jù)傳送有嚴格的時序要求。I2C總線的起始信號、終止信號、發(fā)送“0”及發(fā)送“1”的模擬時序:一、總線數(shù)據(jù)傳送的模擬

主機可以采用不帶I2C總線接口的單片機,如80C51、AT89C2051等單片機,利用軟件實現(xiàn)I2C總線的數(shù)據(jù)傳送,即軟件與硬件結合的信號模擬。

813.80C51單片機I2C串行總線器件的接口一、典型信號I2C總線信號類型開始信號:SCL為高電平時,SDA由高電平向低電平跳變,開始傳送數(shù)據(jù)。結束信號:SCL為低電平時,SDA由低電平向高電平跳變,結束傳送數(shù)據(jù)。應答信號:接收數(shù)據(jù)的器件在接收到8bit數(shù)據(jù)后,向發(fā)送數(shù)據(jù)的器件(發(fā)送器)發(fā)出特定的低電平脈沖,表示已收到數(shù)據(jù)。發(fā)送器接收到應答信號后,根據(jù)實際情況作出是否繼續(xù)傳遞信號的判斷。若未收到應答信號,由判斷為接收器出現(xiàn)故障。數(shù)據(jù)只能在SCL為低電平時才能改變,SCL為高電平時SDA須穩(wěn)定。起始信號與結束信號都是由主器件產(chǎn)生。82I2C總線信號類型238324二、典型信號模擬子程序(1)起始信號VoidT2CStart(void){ SomeNop(); SCL=1; SomeNop(); SDA=0; SomeNop(); SCL=0; SomeNop();}84二、典型信號模擬子程序(1)起始信號25(2)終止信號voidI2cStop(void){ SDA=0; SomeNop(); SCL=1; SomeNop(); SDA=1; SomeNop(); SCL=0;}85(2)終止信號26三、在51上用P1口模擬I2C(c語言)/*電平模擬函數(shù)和基本讀寫函數(shù)voidIIC_Start(void);voidIIC_Stop(void);voidSEND_0(void);voidSEND_1(void);bitCheck_Acknowledge(void);voidWrite_Byte(ucharb);bitWrite_N_Bytes(uchar*buffer,ucharn);bitRead_N_Bytes(ucharSlaveAdr,ucharn,uchar*buffer);ucharRead_Byte(void);*/86三、在51上用P1口模擬I2C(c語言)/*電平模擬函#include<string.h>#include<reg52.h>#include<intrins.h>#include"aiic_51.h"sbitSCL=P1^6;sbitSDA=P1^7;voidDELAY(uintt){while(t!=0)t--;}87#include<string.h>28voidIIC_Start(void){//啟動I2C總線的函數(shù),當SCL為高電平時使SDA產(chǎn)生一個負跳變SDA=1;SCL=1;DELAY(DELAY_TIME);SDA=0;DELAY(DELAY_TIME);SCL=0;DELAY(DELAY_TIME);}88voidIIC_Start(void)29voidIIC_Stop(void){//終止I2C總線,當SCL為高電平時使SDA產(chǎn)生一個正跳變SDA=0;SCL=1;DELAY(DELAY_TIME);SDA=1;DELAY(DELAY_TIME);SCL=0;DELAY(DELAY_TIME);}89voidIIC_Stop(void)30voidSEND_0(void){//發(fā)送0,在SCL為低電平時使SDA信號變?yōu)榈蚐CL=0;SDA=0;SCL=1;DELAY(DELAY_TIME);SCL=0;DELAY(DELAY_TIME);}voidSEND_1(void){//發(fā)送1,在SCL為低電平時使SDA信號變?yōu)楦逽CL=0;SDA=1;SCL=1;DELAY(DELAY_TIME);SCL=0;DELAY(DELAY_TIME);}90voidSEND_0(void)31bitCheck_Acknowledge(void){//發(fā)送完一個字節(jié)后檢驗設備的應答信號SDA=1;SCL=1;DELAY(DELAY_TIME/2);F0=SDA;DELAY(DELAY_TIME/2);SCL=0;DELAY(DELAY_TIME);if(F0==1)returnFALSE;elsereturnTRUE;}91bitCheck_Acknowledge(void)32voidWrite_Byte(ucharb){//向IIC總線寫一個字節(jié)uchari;for(i=0;i<8;i++)if((b<<i)&0x80)SEND_1();elseSEND_0();}92voidWrite_Byte(ucharb)33bitWrite_N_Bytes(uchar*buffer,ucharn){//向I2C總線寫n個字節(jié)uchari;IIC_Start();for(i=0;i<n;i++) { Write_Byte(buffer[i]); if(!Check_Acknowledge()) { IIC_Stop(); return(i==n); } }IIC_Stop();returnTRUE;}93bitWrite_N_Bytes(uchar*buffeucharRead_Byte(void)reentrant{//從I2C總線讀一個字節(jié)ucharb=0,i;for(i=0;i<8;i++) { SDA=1;//釋放總線

SCL=1;//接受數(shù)據(jù)

DELAY(10); F0=SDA; DELAY(10); SCL=0;

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
  • 4. 未經(jīng)權益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責。
  • 6. 下載文件中如有侵權或不適當內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論