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

完善資料讓更多小伙伴認(rèn)識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

通過寄存器來操作GPIO引腳

GReq_mcu168 ? 來源:未知 ? 作者:龔婷 ? 2018-03-13 15:14 ? 次閱讀

GPIO,英文全稱為General-Purpose IO ports,也就是通用IO口。在嵌入式系統(tǒng)中常常有數(shù)量眾多,但是結(jié)構(gòu)卻比較簡單的外部設(shè)備/電路,對這些設(shè)備/電路有的需要CPU為之提供控制手段,有的則需要被CPU用作輸入信號。而且,許多這樣的設(shè)備/電路只要求一位,即只要有開/關(guān)兩種狀態(tài)就夠了,比如燈亮與滅。對這些設(shè)備/電路的控制,使用傳統(tǒng)的串行口或并行口都不合適。所以在微控制器芯片上一般都會提供一個“通用可編程IO接口”,即GPIO。接口至少有兩個寄存器,即“通用IO控制寄存器”與“通用IO數(shù)據(jù)寄存器”。數(shù)據(jù)寄存器的各位都直接引到芯片外部,而對這種寄存器中每一位的作用,即每一位的信號流通方向,則可以通過控制寄存器中對應(yīng)位獨(dú)立的加以設(shè)置。這樣,有無GPIO接口也就成為微控制器區(qū)別于微處理器的一個特征。

二、 GPIO之LCD控制編程:

S3C2440有130個I/O端口,分為A-J共9組:GPA、GPB、、、、GPJ,可以通過設(shè)置寄存器來確定某個引腳用于輸入、輸出還是特殊功能。比如:可以設(shè)置GPH6作為輸入、輸出、或者用于串口。

1、通過寄存器來操作GPIO引腳

1)GPxCON寄存器它用于配置引腳的功能端口A與端口B-J在功能上有所不同,GPACON中每一位對應(yīng)一根引腳(共23根引腳)當(dāng)某位為0時,對應(yīng)引腳為輸出,此時在GPADAT中相應(yīng)位寫入0或1,讓此引腳輸出低電平或高電平;當(dāng)某位被設(shè)為1時,對應(yīng)引腳為地址線或用于地址控制,此時GPADAT保留不用。GPACON通常被設(shè)為全1,以便訪問外部存儲設(shè)備端口B-J在寄存器操作上完全相同,PxCon中每兩位控制一根引腳,00表示輸入,01表示輸出,10表示特殊功能,11保留不用。

2)GPxDAT寄存器它用于讀寫引腳,當(dāng)引腳被設(shè)為輸入時,讀此寄存器得到對應(yīng)引腳的電平狀態(tài)是高還是低;當(dāng)引腳被設(shè)為輸出時,寫此寄存器相應(yīng)位可令此引腳輸出高低電平。

3)GPxUP寄存器GPxUP,某位為1時,相應(yīng)引腳無內(nèi)部上拉電阻;為1時,相應(yīng)引腳使用內(nèi)部上拉電阻上拉電阻、下拉電阻的作用在于,當(dāng)GPIO引腳出于第三態(tài)(非高低電平,而是高阻態(tài),即相當(dāng)于沒接芯片)時,它的電平狀態(tài)由上拉電阻和下拉電阻確定。

圖1 GPBCON引腳配置

圖2 GPBDAT引腳配置

GPIO控制LCD編程實(shí)例:

[cpp] view plain copy print?

#include

void delay(int times)

{

int i;

for(;times>0;times--)

for(i=0;i<400;i++);

}

int main(void)

{

int i;

GPBCON =10000000000; /*配置GPB5為輸出 (參考圖1)*/

GPBUP =~100000; /*配置GPB5上拉電阻使能(參考圖2)*/

for(i=0;i<10000;i++)

{

/* LED1亮 */

GPBDAT = ~100000; /*GPB5低電平*/

delay(1000);

/* LED1滅 */

GPBDAT = 100000; /*GPB5高電平*/

delay(1000);

}

}

其實(shí)上面的例子存在一個非常重要的問題,就是在配置某引腳的時候把其他引腳的值也進(jìn)行了修改。在實(shí)際應(yīng)用中,有可能其他引腳正在執(zhí)行某操作,而我們這樣進(jìn)行配置的時候,修改掉其他引腳可能引發(fā)不可收拾的后果,那我們應(yīng)該如何操作呢?

三、 引腳配置的按位“與”和按位“或”操作:

先來看看上述代碼用按位“與”和按位“或”操作修改之后的效果再來講解:

[cpp] view plain copy print?

#include

#define GPF5_out (1<<(5*2))

#define GPF5_msk (3<<(5*2))

void delay(int times)

{

int i;

for(;times>0;times--)

for(i=0;i<400;i++);

}

int main(void)

{

int i;

GPBCON &=~(GPF5_msk); /*GPB5數(shù)據(jù)清零*/

GPFCON |= GPF5_out; /*配置GPB5為輸出 (參考圖1)*/

for(i=0;i<10000;i++)

{

/* LED1亮 */

GPBDAT &= ~(1<<5); /*GPB5低電平*/

delay(1000);

/* LED1滅 */

GPBDAT |= (1<<5); /*GPB5高電平*/

delay(1000);

}

}

先來分析兩個宏定義:

#define GPF5_out (1<<(5*2))

#define GPF5_msk (3<<(5*2))

分別將GPF5_out定義為1左移10、變?yōu)椋?000,0000,000,GPF5_msk定義為3(即二進(jìn)制11)左移10、變?yōu)椋?100,0000,0000。

語句GPBCON &=~(GPF5_msk): /*GPB5數(shù)據(jù)清零*/:GPF5_msk進(jìn)行非操作變成:0011,1111,1111,任何數(shù)與其進(jìn)行與操作,最高兩位(的出來的結(jié)果均為00xx,xxxx,xxxx,x為未知),這樣就可以達(dá)到對應(yīng)位清零效果。

語句GPFCON |= GPF5_out:任何數(shù)與GPF5_out(1000,0000,000)進(jìn)行或操作,最高位必為1,變成1xxx,xxxx,xxx。加上前面未顯示出來的0,就可以將該引腳的端口5配置為輸入引腳即01。

同理,將GPBDAT配置為低電平可以使其與1左移5的非(100000 ->01111)進(jìn)行與操作,就得到該端口的低電平,高電平也是一樣的道理。

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

    關(guān)注

    5

    文章

    355

    瀏覽量

    30447
  • 寄存器
    +關(guān)注

    關(guān)注

    31

    文章

    5253

    瀏覽量

    119205
  • GPIO
    +關(guān)注

    關(guān)注

    16

    文章

    1175

    瀏覽量

    51515
  • gpio引腳
    +關(guān)注

    關(guān)注

    0

    文章

    7

    瀏覽量

    2622

原文標(biāo)題:嵌入式學(xué)習(xí)筆記之GPIO詳解

文章出處:【微信號:mcu168,微信公眾號:硬件攻城獅】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏

    評論

    相關(guān)推薦

    【NXP LPC54110試用體驗(yàn)】3:GPIO寄存器介紹

    有一個輸出位,對GPIO引腳進(jìn)行寫操作就是對這個輸出位進(jìn)行操作,驅(qū)動這個輸出位必須滿足以下兩個條件:1:必須通過IOCON
    發(fā)表于 08-21 21:49

    嵌入式學(xué)習(xí)筆記之GPIO詳解

    /O端口,分為A-J共9組:GPA、GPB、GPJ,可以通過設(shè)置寄存器確定某個引腳用于輸入、輸出還是特殊功能。比如:可以設(shè)置GPH6作為輸入、輸出、或者用于串口。 1、
    發(fā)表于 11-18 11:06

    在PORT寄存器GPIO引腳的LAT寄存器上進(jìn)行讀寫操作的利弊?

    大家好,誰能建議一下在PORT寄存器GPIO引腳的LAT寄存器上進(jìn)行讀寫操作的利弊?非常感謝你的幫助。
    發(fā)表于 03-11 10:43

    怎樣通過寄存器操作GPIO?GPIO有哪些操作實(shí)例?

    GPIO是什么?怎樣通過寄存器操作GPIO?GPIO有哪些
    發(fā)表于 06-28 07:34

    關(guān)于STM32的GPIO口的寄存器相關(guān)操作

    STM32 的寄存器,使用庫函數(shù)開發(fā)人員得以脫離最底層的寄存器操作(不用天天去查中文參考手冊,只需要知道需要配置哪些寄存器,然后直接在庫種調(diào)用即可),使用庫函數(shù)開發(fā)有開發(fā)快速、可移植性
    發(fā)表于 03-01 07:27

    STM32 GPIO寄存器ODR BSRR BRR

    STM32 GPIO寄存器ODR BSRR BRR詳細(xì)介紹
    發(fā)表于 07-29 10:27 ?2次下載

    STM32使用BSRR和BRR寄存器快速操作GPIO端口

    STM32的每個GPIO端口都有兩個特別的寄存器,GPIOx_BSRR和GPIOx_BRR寄存器,通過這兩個寄存器可以直接對對應(yīng)的GPIOx
    發(fā)表于 11-26 11:50 ?1次下載

    基于stm32的GPIO寄存器學(xué)習(xí)解析

    GPIO即通用輸入/輸出 (General Purpose Input Output) 包括: 兩個32位的配置寄存器 GPIOx->CRL,GPIOx->CRH 兩個32位的數(shù)據(jù)
    的頭像 發(fā)表于 01-11 09:03 ?1.3w次閱讀
    基于stm32的<b class='flag-5'>GPIO</b><b class='flag-5'>寄存器</b>學(xué)習(xí)解析

    GPIO寄存器

    ,一般高16位保留BSRR寄存器32位分為低16位BSRRL和高16位BSRRH,BSRRL配置一組IO口的16個IO口的狀態(tài)(1),BSRRH配置復(fù)位狀態(tài)(0)。每組GPIO端口的寄存器包括:4個32位配置
    發(fā)表于 12-08 17:06 ?5次下載
    <b class='flag-5'>GPIO</b><b class='flag-5'>寄存器</b>

    stm32是如何將寄存器通過標(biāo)準(zhǔn)庫寫入寄存器的?

    GPIO_Init函數(shù)3.總結(jié)0. 前言在平時的學(xué)習(xí)和工作中,可能很少有人會實(shí)際去操作寄存器,但是去了解庫函數(shù)是如何去操作寄存器是很有必要
    發(fā)表于 12-16 16:58 ?18次下載
    stm32是如何將<b class='flag-5'>寄存器</b>值<b class='flag-5'>通過</b>標(biāo)準(zhǔn)庫寫入<b class='flag-5'>寄存器</b>的?

    操作寄存器設(shè)置引腳的輸入輸出

    的話很不方便,所以當(dāng)我們被要求速度快的情況下,最好的辦法就是直接操作寄存器。那該怎么配置寄存器呢?接下來我們通過STM32L031F4P6單片機(jī)舉例子來看看怎么配置我們首先找到芯片的參
    發(fā)表于 01-12 20:36 ?3次下載
    <b class='flag-5'>操作</b><b class='flag-5'>寄存器</b>設(shè)置<b class='flag-5'>引腳</b>的輸入輸出

    STM32的寄存器操作

    STM32的寄存器操作在使用STM32單片機(jī)編程時一般都用ST給的庫函數(shù)編程,庫函數(shù)編程的底層就是對單片機(jī)寄存器操作,庫函數(shù)就是一系列寄存器
    發(fā)表于 01-13 15:43 ?19次下載
    STM32的<b class='flag-5'>寄存器</b><b class='flag-5'>操作</b>

    【STM32】GPIO的相關(guān)配置寄存器、庫函數(shù)、位操作

    STM32的每組GPIO口包括7個寄存器。也就是說,每個寄存器可以控制一組GPIO的16個GPIO口。這
    發(fā)表于 02-10 10:24 ?5次下載
    【STM32】<b class='flag-5'>GPIO</b>的相關(guān)配置<b class='flag-5'>寄存器</b>、庫函數(shù)、位<b class='flag-5'>操作</b>

    i.MX6ULL處理GPIO寄存器配置原理及方法

    之前的文章中介紹了新舊字符設(shè)備驅(qū)動開發(fā)的方式,并利用虛擬的字符設(shè)備學(xué)習(xí)其開發(fā)流程,沒有涉及到操作Linux開發(fā)板上的硬件。對硬件的操作,究其本質(zhì)最終都是要操作處理
    的頭像 發(fā)表于 04-14 11:43 ?1877次閱讀
    i.MX6ULL處理<b class='flag-5'>器</b><b class='flag-5'>GPIO</b><b class='flag-5'>寄存器</b>配置原理及方法

    RAL寄存器模型操作指南

    寄存器模型操作,指的是通過寄存器模型對RTL中寄存器進(jìn)行讀寫訪問,或者同步寄存器模型與RTL中
    的頭像 發(fā)表于 07-12 09:37 ?924次閱讀
    RAL<b class='flag-5'>寄存器</b>模型<b class='flag-5'>操作</b>指南