• <li id="00i08"><input id="00i08"></input></li>
  • <sup id="00i08"><tbody id="00i08"></tbody></sup>
    <abbr id="00i08"></abbr>
  • 新聞中心

    EEPW首頁 > 嵌入式系統 > 設計應用 > Cortex-M3學習日志(一)-- GPIO實驗1

    Cortex-M3學習日志(一)-- GPIO實驗1

    作者: 時間:2016-11-21 來源:網絡 收藏
    以前在學校時不知以后會干什么所以什么都學點,感覺什么有用就拿起學學,但是出來以后發現學沒有致以用,于是也開始學者老前輩們抱怨當前教育與社會嚴重脫鉤,但是學校也有冠冕堂皇的理由,我們教你的是思想,教你的是學習的方法。也許社會的現實就是這樣吧,一遇到事,公說公有理,婆說婆有理,我們又能奈何?幸虧我們還有網絡,幸虧我們還沒有完全被封口,所以我們還能發發牢騷,好了,時間不早了,牢騷發的差不多了,下面開始寫學習總結。

    因為項目所需,所以不得不開始研究M3,我用的是NXP公司的LPC1768這個芯片,它是具有三級流水線的哈佛結構,帶獨立的本地指令和數據總線以及用于外設的稍微低性能的第三條總線,還包含一個支持隨機跳轉的內部預取指單元。關于LPC1768這個芯片的內部資源這里就不羅列了,這些數據手冊上都寫的很詳細,以后在學習總結中也會慢慢涉及。好了,今天只是初步測試一下它的GPIO功能,所謂的GPIO

    本文引用地址:http://www.czjhyjcfj.com/article/201611/319426.htm

    圖1-1硬件原理圖

    硬件原理圖很簡單了,74LVC244是用來驅動LED的,74LVC244內部就是8個三態門,關于它的詳細電氣參數,請參閱它的數據手冊。關于程序也不是太難,有幾個地方要說一下。即然是GPIO實驗,當然要關注GPIO的配置了,由于大部分引腳都具有一個以上功能,所以首先要配置引腳功能寄存器PINSEL,只有當引腳配置為GPIO功能時,GPIO的方向位才有效,對于其它功能來說,方向是自動的。關于引腳功能寄存器PINSEL功能如下表所示:

    PINSEL0~PINSEL9的值

    功能

    復位后的值

    00

    默認功能,通常為GPIO口

    00

    01

    第一個可選功能

    10

    第二個可選功能

    11

    第三個可選功能

    PINSEL寄存器每兩位控制一個引腳,由于各個引腳的功能不一樣,所以PINSEL0~PINSEL9的配置也相應的有所不同,想詳細了解這10個寄存器的功能可以參看《user.manual.lpc17xx》,這個手冊可以到NXP的網站上去下載。由于這次實驗只是用到GPIO功能,所以暫時不用管這個寄存器,用它的默認值就可以了。

    另一個寄存器是引腳模式選擇寄存器PINMODE,它控制所有端口的工作模式,包括是否配置上拉/下拉電阻和特定的開漏操作模式等。引腳模式選擇寄存器PINMODE的功能如下表所示:

    PINMODE0~PINMODE9的值

    功能

    復位后的值

    00

    引腳使能片內上拉電阻

    00

    01

    中斷模式

    10

    引腳沒有使能片內上拉/下拉電阻

    11

    引腳使能下拉電阻

    當引腳處于邏輯高電平時,中繼模式使能上拉電阻,當引腳處于邏輯低電平時,使能下拉電阻,當引腳配置為輸入且不是通過外部驅動時,引腳將保持上一個已知狀態。PINMODE_0D寄存器控制寄存器的開漏模式,引腳配置為輸出且值為0時,開漏模式會正常地將引腳電平拉低。但是如果輸出引腳為1,則引腳輸出驅動關閉,等同于改變了引腳的方向,實際上是模擬了一個開漏輸出。

    PINMODE_0D0~PINMODE_0D4的值

    功能

    復位后的值

    00

    引腳處于正常模式(非開漏模式)

    00

    01

    引腳處于開漏模式

    除了以上兩個寄存器要配置,與GPIO端口相關的寄存器還有快速端口值寄存器FIOPIN可以用來讀/寫端口的值,端口輸出置位寄存器FIOSET,當這個寄存器的相應位置1時,相應端口引腳輸出1,當然也可以從這個寄存器讀取當前引腳輸出的值,與它對應的寄存器是FIOCLR,當寄存器FIOCLR相應位置1時,相應引腳輸出0,但這個寄存器是只寫寄存器,不能讀取數據。好了,關于這些寄存器先總結到這,詳細的配置還要看LPC1768的用戶手冊《user.manual.lpc17xx》,當然也可以經常去NXP網站逛逛看看其它的handbook或whitepaper

    好了,下面給出實驗程序,由于程序太多,只給出部分,剩下的源文件可以到工程文件夾中去找:

    #include"main.h"

    volatile unsigned long SysTickCnt;

    void SysTick_Handler (void)

    {

    SysTickCnt++;

    }

    void DelayMs (unsigned long tick)

    {

    unsigned long systickcnt;

    systickcnt = SysTickCnt;

    while ((SysTickCnt - systickcnt) < tick);

    }

    void PortInit(void)

    {

    GPIO1->FIODIR = 0xB0000000;

    GPIO2->FIODIR = 0x0000007C;

    Led1Off();

    Led2Off();

    Led3Off();

    Led4Off();

    Led5Off();

    Led6Off();

    Led7Off();

    Led8Off();

    }

    int main(void)

    {

    SystemInit();

    SysTick_Config(SystemFrequency/1000 - 1);

    PortInit();

    while(1)

    {

    Led1On();//LED1開

    Led4On();//LED4

    DelayMs(200);

    Led1Off();//LED1關

    Led4Off();//LED4關

    DelayMs(200);

    }

    }

    因為程序是最基礎的實驗,所以不是太難,程序中延時函數用的是系統節拍定時器,每1m中斷一次,系統節拍定時器的中斷配置函數是SysTick_Config(uint32_t ticks)它在core_cm3.h中有定義,有興趣的話可以看看。GPIO是一個結構體指針,原型在LPC17XX.H這個頭文件中,其定義的原型如下所示:

    typedef struct

    {

    __IO uint32_t FIODIR;

    uint32_t RESERVED0[3];

    __IO uint32_t FIOMASK;

    __IO uint32_t FIOPIN;

    __IO uint32_t FIOSET;

    __Ouint32_t FIOCLR;

    } GPIO_TypeDef;

    還有幾個宏定義,如下所示:

    1)、#define GPIO1((GPIO_TypeDef *)GPIO1_BASE)

    上面這個宏是把GPIO1指向芯片GPIO1的基址上,

    2)、#define GPIO1_BASE(GPIO_BASE + 0x00020)

    3)、#define GPIO_BASE(0x2009C000UL)

    這三個宏就把GPIO的基址定義了出來,關于LPC1768內部地址的分配情況,可以參看它的數據手冊,也可參考一下《ARM Cortex-M3權威指南》,這本書在網上有電子書,好像宋巖寧牛人早已把它翻譯成中文了,懶貓現在也正在參考這本書,另外一定要多去NXP網站看一下它的handbook,whitepaper等資料,還可多到論壇轉轉,有些壇子里深藏了好多老鳥,好多大蝦,好多大牛,有你學的,有你問的,只要肯用心,一根網線,能解決很多問題。



    關鍵詞: Cortex-M3GPIO實

    評論


    相關推薦

    技術專區

    關閉
    主站蜘蛛池模板: 湾仔区| 大埔区| 阿拉善盟| 洪湖市| 普宁市| 杭锦后旗| 灵丘县| 永善县| 浦东新区| 偃师市| 万宁市| 长顺县| 和田市| 会泽县| 平顺县| 军事| 秦安县| 连州市| 吉林市| 九龙坡区| 临清市| 尉犁县| 阿勒泰市| 上杭县| 荥经县| 九龙城区| 绵竹市| 舟山市| 兴山县| 获嘉县| 汝州市| 米林县| 南昌市| 来凤县| 盐山县| 昆山市| 招远市| 新泰市| 凤城市| 蛟河市| 永年县|