模擬I2C總線(xiàn)多主節點(diǎn)通信原理簡(jiǎn)介
摘要 介紹模擬I2C總線(xiàn)的多主節點(diǎn)通信原理,并提出一種新的實(shí)現方法。這種采用延時(shí)接收比較來(lái)實(shí)現仲裁的方法,可使不具有I2C接口的普通微控制器(MCU)能夠實(shí)現模擬I2C總線(xiàn)的多主通信,同時(shí)對I2C總線(xiàn)的推廣起到了積極作用。
本文引用地址:http://dyxdggzs.com/article/154009.htmI2C總線(xiàn)(Inter IC BUS)是PHILIPS公司推出的雙向兩線(xiàn)串行通信標準。由于它具有接口少、通信效率高等優(yōu)點(diǎn),現已得到廣泛的應用[1~3]。它除了可以進(jìn)行簡(jiǎn)單的單主節點(diǎn)通信外,還可以應用在多主節點(diǎn)的通信系統中。在多主節點(diǎn)通信系統中,如果兩個(gè)或者更多的主節點(diǎn)同時(shí)啟動(dòng)數據傳輸,總線(xiàn)具有沖突檢測和仲裁功能,保證通信正常進(jìn)行并防止數據破壞?,F在許多微控制器(MCU)都具有I2C總線(xiàn)接口,能方便地進(jìn)行I2C總線(xiàn)設計。對于沒(méi)有I2C總線(xiàn)接口的MCU,可以采用兩條I/O接口線(xiàn)進(jìn)行模擬[2,3]。目前,一些介紹模擬I2C的資料主要講的是在單主節點(diǎn)系統中進(jìn)行的通信,這使得模擬I2C總線(xiàn)的應用具有一定的局限性。本文根據總線(xiàn)仲裁的思想,提出一種多主節點(diǎn)通信的思想及實(shí)現流程。
1 I2C總線(xiàn)系統簡(jiǎn)介[1~3]
I2C總線(xiàn)系統是由SCL(串行時(shí)鐘)和SDA(串行數據)兩根總線(xiàn)構成的。該總線(xiàn)有嚴格的時(shí)序要求,總線(xiàn)工作時(shí),由串行時(shí)鐘線(xiàn)SCL傳送時(shí)鐘脈沖,由串行數據線(xiàn)SDA傳送數據??偩€(xiàn)協(xié)議規定,各主節點(diǎn)進(jìn)行通信時(shí)都要有起始、結束、發(fā)送數據和應答信號。這些信號都是通信過(guò)程中的基本單元??偩€(xiàn)傳送的每1幀數據均是1個(gè)字節,每當發(fā)送完1個(gè)字節后,接收節點(diǎn)就相應給一應答信號。協(xié)議規定,在啟動(dòng)總線(xiàn)后的第1個(gè)字節的高7位是對從節點(diǎn)的尋址地址,第8位為方向位(“0”表示主節點(diǎn)對從節點(diǎn)的寫(xiě)操作;“1”表示主節點(diǎn)對從節點(diǎn)的讀操作),其余的字節為操作數據。圖1列出I2C總線(xiàn)上幾個(gè)基本信號的時(shí)序。
圖1中包括起始信號、停止信號、應答信號、非應答信號以及傳輸數據“0”和數據“1”的時(shí)序。起始信號就是在SCL線(xiàn)為高時(shí)SDA線(xiàn)從高變化到低;停止信號就是在SCL線(xiàn)為高時(shí)SDA線(xiàn)從低變化到高;應答信號是在SCL為高時(shí)SDA為低;非應答信號相反,是在SCL為高時(shí)SDA為高。傳輸數據“0”和數據“1”與發(fā)送應答位和非應答位時(shí)序圖是相同的。
圖1 I2C總線(xiàn)上基本信號的時(shí)序
圖2表示了一個(gè)完整的數據傳送過(guò)程。在I2C總線(xiàn)發(fā)送起始信號后,發(fā)送從機的7位尋址地址和1位表示這次操作性質(zhì)的讀寫(xiě)位,在有應答信號后開(kāi)始傳送數據,直到發(fā)送停止信號。數據是以字節為單位的。發(fā)送節點(diǎn)每發(fā)送1個(gè)字節就要檢測SDA線(xiàn)上有沒(méi)有收到應答信號,有則繼續發(fā)送,否則將停止發(fā)送數據。
圖2 一次完整的數據傳送過(guò)程
2 I2C總線(xiàn)的仲裁
在多主的通信系統中??偩€(xiàn)上有多個(gè)節點(diǎn),它們都有自己的尋址地址,可以作為從節點(diǎn)被別的節點(diǎn)訪(fǎng)問(wèn),同時(shí)它們都可以作為主節點(diǎn)向其他的節點(diǎn)發(fā)送控制字節和傳送數據。但是如果有兩個(gè)或兩個(gè)以上的節點(diǎn)都向總線(xiàn)上發(fā)送啟動(dòng)信號并開(kāi)始傳送數據,這樣就形成了沖突。要解決這種沖突,就要進(jìn)行仲裁的判決,這就是I2C總線(xiàn)上的仲裁。
I2C總線(xiàn)上的仲裁分兩部分:SCL線(xiàn)的同步和SDA線(xiàn)的仲裁。SCL同步是由于總線(xiàn)具有線(xiàn)“與”的邏輯功能,即只要有一個(gè)節點(diǎn)發(fā)送低電平時(shí),總線(xiàn)上就表現為低電平。當所有的節點(diǎn)都發(fā)送高電平時(shí),總線(xiàn)才能表現為高電平。正是由于線(xiàn)“與”邏輯功能的原理,當多個(gè)節點(diǎn)同時(shí)發(fā)送時(shí)鐘信號時(shí),在總線(xiàn)上表現的是統一的時(shí)鐘信號。這就是SCL的同步原理。
SDA線(xiàn)的仲裁也是建立在總線(xiàn)具有線(xiàn)“與”邏輯功能的原理上的。節點(diǎn)在發(fā)送1位數據后,比較總線(xiàn)上所呈現的數據與自己發(fā)送的是否一致。是,繼續發(fā)送;否則,退出競爭。圖3中給出了兩個(gè)節點(diǎn)在總線(xiàn)上的仲裁過(guò)程。SDA線(xiàn)的仲裁可以保證I2C總線(xiàn)系統在多個(gè)主節點(diǎn)同時(shí)企圖控制總線(xiàn)時(shí)通信正常進(jìn)行并且數據不丟失??偩€(xiàn)系統通過(guò)仲裁只允許一個(gè)主節點(diǎn)可以繼續占據總線(xiàn)[1]。
圖3是以?xún)蓚€(gè)節點(diǎn)為例的仲裁過(guò)程。DATA1和DATA2分別是主節點(diǎn)向總線(xiàn)所發(fā)送的數據信號,SDA為總線(xiàn)上所呈現的數據信號,SCL是總線(xiàn)上所呈現的時(shí)鐘信號。當主節點(diǎn)1、2同時(shí)發(fā)送起始信號時(shí),兩個(gè)主節點(diǎn)都發(fā)送了高電平信號。這時(shí)總線(xiàn)上呈現的信號為高電平,兩個(gè)主節點(diǎn)都檢測到總線(xiàn)上的信號與自己發(fā)送的信號相同,繼續發(fā)送數據。第2個(gè)時(shí)鐘周期,2個(gè)主節點(diǎn)都發(fā)送低電平信號,在總線(xiàn)上呈現的信號為低電平,仍繼續發(fā)送數據。在第3個(gè)時(shí)鐘周期,主節點(diǎn)1發(fā)送高電平信號,而主節點(diǎn)2發(fā)送低電平信號。根據總線(xiàn)的線(xiàn)“與”的邏輯功能,總線(xiàn)上的信號為低電平,這時(shí)主節點(diǎn)1檢測到總線(xiàn)上的數據和自己所發(fā)送的數據不一樣,就斷開(kāi)數據的輸出級,轉為從機接收狀態(tài)。這樣主節點(diǎn)2就贏(yíng)得了總線(xiàn),而且數據沒(méi)有丟失,即總線(xiàn)的數據與主節點(diǎn)2所發(fā)送的數據一樣,而主節點(diǎn)1在轉為從節點(diǎn)后繼續接收數據,同樣也沒(méi)有丟掉SDA線(xiàn)上的數據。因此在仲裁過(guò)程中數據沒(méi)有丟失。
圖3 兩個(gè)主節點(diǎn)的仲裁過(guò)程
3 多主通信的原理及其實(shí)現流程
多主通信就是在總線(xiàn)上有多個(gè)節點(diǎn)。這些節點(diǎn)既可以作為主節點(diǎn)訪(fǎng)問(wèn)其他的節點(diǎn),也可以作為從節點(diǎn)被其他節點(diǎn)訪(fǎng)問(wèn)。當有多個(gè)節點(diǎn)同時(shí)企圖占用總線(xiàn)時(shí),就需要總線(xiàn)的仲裁。對于模擬I2C總線(xiàn)系統,怎樣實(shí)現總線(xiàn)的仲裁是現在研究模擬I2C總線(xiàn)系統的難點(diǎn)。文獻[4]提出在系統中增加1根BUSY線(xiàn),在占用總線(xiàn)之前先檢測BUSY線(xiàn),看總線(xiàn)是否被占用。若總線(xiàn)空閑,則設置BUSY線(xiàn)并向總線(xiàn)上傳送數據;否則,接收數據,直到總線(xiàn)空閑時(shí)才占有總線(xiàn)。這種實(shí)現多主通信的方法有兩個(gè)缺點(diǎn):① 因為I2C最大的優(yōu)點(diǎn)就是接口少、效率高,這樣做不僅增加了使用資源而且減少了I2C總線(xiàn)的優(yōu)勢;② 當主節點(diǎn)數比較多時(shí),等待時(shí)間比較長(cháng),效率不高。本設計根據總線(xiàn)的仲裁原理,提出一種基于延時(shí)比較的仲裁方法。當主節點(diǎn)想要占用總線(xiàn)時(shí),先檢測總線(xiàn)上是否空閑,如果總線(xiàn)是空閑的就發(fā)送數據。在發(fā)送數據的同時(shí),將總線(xiàn)上的數據接收并與發(fā)送的數據進(jìn)行比較。如果不同,說(shuō)明總線(xiàn)上同時(shí)還存在其他節點(diǎn),于是就退出;否則,一直到發(fā)送完數據。這種方法既體現了I2C總線(xiàn)的高效性,同時(shí)還具有良好的擴展性。
圖4 多主通信流程
圖4給出了基于延時(shí)比較的多主通信流程,其中MCU作為從節點(diǎn)部分的流程在圖5中給出。在節點(diǎn)發(fā)送起始信號之前先要檢測一下總線(xiàn)上是否為空閑狀態(tài)(BUSY是否為0)。這里使用的檢測方法是,持續檢測一段時(shí)間看總線(xiàn)上的電平是否一直為高,若是說(shuō)明總線(xiàn)上為閑狀態(tài),否則說(shuō)明有其他的節點(diǎn)正在使用總線(xiàn),要等一段時(shí)間再發(fā)送。當總線(xiàn)空閑時(shí),發(fā)送起始信號,接著(zhù)發(fā)送要訪(fǎng)問(wèn)的從節點(diǎn)的地址字節。每發(fā)送1位數據就接收比較1次,看發(fā)送和接收的是否一致,若是則繼續,否則跳出到從節點(diǎn)的接收狀態(tài)。如果沒(méi)有產(chǎn)生沖突,MCU作為主節點(diǎn)繼續發(fā)送數據,直到任務(wù)結束,然后發(fā)送停止信號并返回。如果數據不一樣,MCU將跳轉到從節點(diǎn)狀態(tài)。由于在跳轉到從節點(diǎn)接收狀態(tài)的過(guò)程中累加器(ACC)和工作寄存器(Ri)的數據沒(méi)有發(fā)生變化,所以數據沒(méi)有丟失,作為從節點(diǎn)可以繼續接收總線(xiàn)上的數據。這樣整個(gè)通信的過(guò)程沒(méi)有中斷,數據也沒(méi)有丟失。
圖5 從節點(diǎn)部分的流程
評論