最近在調ICM20602模塊,一個六軸陀螺儀和加速度計,使用IIC通信協議,這個過程中遇到一個困擾我很長時間的問題。
IIC協議正確,但是一直讀取失敗,最后發現因為沒配置GPIO為開漏輸出。
推挽輸出和開漏輸出
推挽輸出:
輸出邏輯0,則N-MOS激活;
輸出邏輯1,則P-MOS激活。
開漏輸出:
在不接上拉電阻時, 輸出邏輯0,則N-MOS激活;
輸出邏輯1,P-MOS不會激活, 不會輸出高電平。
在接上拉電阻時, 輸出邏輯0,則N-MOS激活;
輸出邏輯1,P-MOS激活, 可以輸出高電平。
也就是說開漏輸出如果不接上拉電阻, 沒有輸出高電平的能力。
如果需要開漏輸出有輸出高電平的能力需要接一個上拉電阻。目前很多單片機GPIO可以通過軟件配置上拉電阻。
如上,左圖為開漏輸出(接上拉電阻),右圖為推挽輸出。
開漏輸出的作用
防止短路:
在一些情況下(比如總線), 多個GPIO口可能會連接在同一根線上, 存在某個GPIO輸出高電平, 另一個GPIO輸出低電平的情況. 如果使用推挽輸出, 你會發現這個GPIO的VCC和另一個GPIO的GND接在了一起, 也就是短路了。
如果換成開漏輸出呢? VCC和GND多了個電阻, 這樣電路就是安全的.所以總線一般會使用開漏輸出。
線與:
開漏輸出還能實現線與,減少一個與門,簡化電路。
IIC為什么用開漏輸出和上拉電阻
IIC協議支持多個主設備與多個從設備在一條總線上, 如果不用開漏輸出, 而用推挽輸出, 會出現主設備之間短路的情況。
至于為什么需要上拉電阻, 那是因為IIC通信需要輸出高電平的能力。
為了實現多個主設備搶占總線時的仲裁,IIC只有兩根線(SCL和SDA),怎么判斷哪個主設備占用總線,當然是先來后到了。
假設主設備A需要啟動IIC,他需要在SCL高電平時, 將SDA由高電平轉換為低電平作為啟動信號。主設備A在把SDA拉高后, 它需要再檢查一下SDA的電平。
為什么? 因為線與. 如果主設備A拉高SDA時, 已經有其他主設備將SDA拉低了. 由于 1 & 0 = 0 那么主設備A在檢查SDA電平時, 會發現不是高電平, 而是低電平. 說明其他主設備搶占總線的時間比它早, 主設備A只能放棄占用總線. 如果是高電平, 則可以占用。
這就是開漏輸出在IIC通信中的另一個作用。
SDA是高電平, 說明主設備A可以占用總線, 然后主設備A將SDA拉低, 開始通信。
SDA是低電平, 說明有人已經捷足先登了, 主設備A不能占用總線, 結束通信。
因此,模擬IIC一定要將GPIO端口設置為開漏輸出并加上上拉電阻,硬件IIC會自動配置為開漏輸出。
審核編輯:湯梓紅
-
通信協議
+關注
關注
28文章
900瀏覽量
40352 -
IIC
+關注
關注
11文章
302瀏覽量
38408 -
MOS
+關注
關注
32文章
1281瀏覽量
94009 -
GPIO
+關注
關注
16文章
1215瀏覽量
52231 -
開漏輸出
+關注
關注
0文章
34瀏覽量
7338
原文標題:IIC為什么要配置GPIO為開漏輸出?
文章出處:【微信號:c-stm32,微信公眾號:STM32嵌入式開發】歡迎添加關注!文章轉載請注明出處。
發布評論請先 登錄
相關推薦
評論