對通用輸入輸出GPIO的深入理解

對通用輸入輸出GPIO的深入理解

ARM技術 2009-10-31 10:14:39 閱讀1 評論0   字號: 訂閱

一.GPIO簡介
        I/O(Input/Output)接口是一顆微控制器必須具備的最基本外設功能。通常在ARM裏,所有I/O都是通用的,稱爲 GPIO(General Purpose Input/Output)。每個GPIO端口包含8個管腳,如PA端口是PA0~PA7。GPIO模塊支持多個可編程輸入/輸出管腳(具體取決於與 GPIO複用的外設的使用情況)。GPIO模塊包含以下特性:
z 1)可編程控制GPIO中斷
?     ---屏蔽中斷髮生
?     ---邊沿觸發(上升沿、下降沿、雙邊沿)
?     ---電平觸發(高電平、低電平)
z 2)輸入/輸出可承受5V
z 3)在讀和寫操作中通過地址線進行位屏蔽
z 4)可編程控制GPIO管腳配置:
?     ---弱上拉或弱下拉電阻
?     ---2mA、4mA、8mA驅動,以及帶驅動轉換速率(Slew Rate)控制的8mA驅動
?     ---開漏使能
?     ---數字輸入使能

二.GPIO的各種模式
   GPIO管腳可以被配置爲多種工作模式,其中有3種比較常用:高阻輸入、推輓輸出、開漏輸出

1. 高阻輸入(Input)
點擊看大圖
圖1.1 GPIO高阻輸入模式結構示意圖
       爲減少信息傳輸線的數目,大多數計算機中的信息傳輸線採用總線形式,即凡要傳輸的同類信息都在同一組傳輸線,且信息是分時傳送的。在計算機中一般有三組總線,即數據總線、地址總線和控制總線。爲防止信息相互干擾,要求凡掛到總線上的寄存器或存儲器等,它的輸入輸出端不僅能呈現0、1兩個信息狀態,而且還應能呈現第三個狀態----高阻抗狀態,即此時好像它們的輸出被開關斷開,對總線狀態不起作用,此時總線可由其他器件佔用。三態緩衝器即可實現上述功能,它除具有輸入輸出端之外,還有一控制端。

       如圖1.1所示,爲GPIO管腳在高阻輸入模式下的等效結構示意圖。這是一個管腳的情況,其它管腳的結構也是同樣的。輸入模式的結構比較簡單,就是一個帶有施密特觸發輸入(Schmitt-triggered input)的三態緩衝器(U1),並具有很高的輸入等效阻抗。施密特觸發輸入的作用是能將緩慢變化的或者是畸變的輸入脈衝信號整形成比較理想的矩形脈衝信號。執行GPIO管腳讀操作時,在讀脈衝(Read Pulse)的作用下會把管腳(Pin)的當前電平狀態讀到內部總線上(Internal Bus)。在不執行讀操作時,外部管腳與內部總線之間是隔離的。

2. 推輓輸出(Output)
點擊看大圖
圖1.2 GPIO推輓輸出模式結構示意圖
           推輓輸出原理:在功率放大器電路中大量採用推輓放大器電路,這種電路中用兩隻三極管構成一級放大器電路,兩隻三極管分別放大輸入信號的正半周和負半周,即用一隻三極管放大信號的正半周,用另一隻三極管放大信號的負半周,兩隻三極管輸出的半周信號在放大器負載上合併後得到一個完整週期的輸出信號。

      推輓放大器電路中,一隻三極管工作在導通、放大狀態時,另一隻三極管處於截止狀態,當輸入信號變化到另一個半周後,原先導通、放大的三極管進入截止,而原先截止的三極管進入導通、放大狀態,兩隻三極管在不斷地交替導通放大和截止變化,所以稱爲推輓放大器(armjishu.com)。

        如圖1.2所示,爲GPIO管腳在推輓輸出模式下的等效結構示意圖。U1是輸出鎖存器,執行GPIO管腳寫操作時,在寫脈衝(Write Pulse)的作用下,數據被鎖存到Q和/Q。T1和T2構成CMOS反相器,T1導通或T2導通時都表現出較低的阻抗,但T1和T2不會同時導通或同時關閉,最後形成的是推輓輸出。在推輓輸出模式下,GPIO還具有回讀功能,實現回讀功能的是一個簡單的三態門U2。注意:執行回讀功能時,讀到的是管腳的輸出鎖存狀態,而不是外部管腳Pin的狀態。

3. 開漏輸出(OutputOD)
點擊看大圖
圖1.3 GPIO開漏輸出結構示意圖
            如圖1.3所示,爲GPIO管腳在開漏輸出模式下的等效結構示意圖。開漏輸出和推輓輸出相比結構基本相同,但只有下拉晶體管T1而沒有上拉晶體管。同樣,T1實際上也是多組可編程選擇的晶體管。開漏輸出的實際作用就是一個開關,輸出“1”時斷開、輸出“0”時連接到GND(有一定內阻)。回讀功能:讀到的仍是輸出鎖存器的狀態,而不是外部管腳Pin的狀態。因此開漏輸出模式是不能用來輸入的。

        開漏輸出結構沒有內部上拉,因此在實際應用時通常都要外接合適的上拉電阻(通常採用4.7~10kΩ)。開漏輸出能夠方便地實現“線與”邏輯功能,即多個開漏的管腳可以直接並在一起(不需要緩衝隔離)使用,並統一外接一個合適的上拉電阻,就自然形成“邏輯與”關係。開漏輸出的另一種用途是能夠方便地實現不同邏輯電平之間的轉換(如3.3V到5V之間),只需外接一個上拉電阻,而不需要額外的轉換電路。典型的應用例子就是基於開漏電氣連接的I2C總線。

4. 鉗位二極管
        GPIO內部具有鉗位保護二極管,如圖1.4所示。其作用是防止從外部管腳Pin輸入的電壓過高或者過低。VDD正常供電是3.3V,如果從Pin 輸入的信號(假設任何輸入信號都有一定的內阻)電壓超過VDD加上二極管D1的導通壓降(假定在0.6V左右),則二極管D1導通,會把多於的電流引到 VDD,而真正輸入到內部的信號電壓不會超過3.9V。同理,如果從Pin輸入的信號電壓比GND還低,則由於二極管D2的作用,會把實際輸入內部的信號電壓鉗制在-0.6V左右。
點擊看大圖
圖1.4 GPIO鉗位二極管示意圖
        假設VDD=3.3V,GPIO設置在開漏模式下,外接10kΩ上拉電阻連接到5V電源,在輸出“1”時,我們通過測量發現:GPIO管腳上的電壓並不會達到5V,而是在4V上下,這正是內部鉗位二極管在起作用。雖然輸出電壓達不到滿幅的5V,但對於實際的數字邏輯通常3.5V以上就算是高電平了 (armjishu.com)。
點擊看大圖
圖1.5 解決開漏模式上拉電壓不足的方法
        如果確實想進一步提高輸出電壓,一種簡單的做法是先在GPIO管腳上串聯一隻二極管(如1N4148),然後再接上拉電阻。參見圖1.5,框內是芯片內部電路。向管腳寫“1”時,T1關閉,在Pin處得到的電壓是3.3+VD1+VD3=4.5V,電壓提升效果明顯;向管腳寫“0”時,T1導通,在 Pin處得到的電壓是VD3=0.6V,仍屬低電平。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章