Cortex-M3學(xué)習(xí)日志(一)-- GPIO實(shí)驗(yàn)1
因?yàn)轫?xiàng)目所需,所以不得不開始研究M3,我用的是NXP公司的LPC1768這個(gè)芯片,它是具有三級(jí)流水線的哈佛結(jié)構(gòu),帶獨(dú)立的本地指令和數(shù)據(jù)總線以及用于外設(shè)的稍微低性能的第三條總線,還包含一個(gè)支持隨機(jī)跳轉(zhuǎn)的內(nèi)部預(yù)取指單元。關(guān)于LPC1768這個(gè)芯片的內(nèi)部資源這里就不羅列了,這些數(shù)據(jù)手冊(cè)上都寫的很詳細(xì),以后在學(xué)習(xí)總結(jié)中也會(huì)慢慢涉及。好了,今天只是初步測(cè)試一下它的GPIO功能,所謂的GPIO
本文引用地址:http://butianyuan.cn/article/201611/319426.htm圖1-1
硬件原理圖很簡單了,74LVC244是用來驅(qū)動(dòng)LED的,74LVC244內(nèi)部就是8個(gè)三態(tài)門,關(guān)于它的詳細(xì)電氣參數(shù),請(qǐng)參閱它的數(shù)據(jù)手冊(cè)。關(guān)于程序也不是太難,有幾個(gè)地方要說一下。即然是GPIO實(shí)驗(yàn),當(dāng)然要關(guān)注GPIO的配置了,由于大部分引腳都具有一個(gè)以上功能,所以首先要配置引腳功能寄存器PINSEL,只有當(dāng)引腳配置為GPIO功能時(shí),GPIO的方向位才有效,對(duì)于其它功能來說,方向是自動(dòng)的。關(guān)于引腳功能寄存器PINSEL功能如下表所示:
PINSEL0~PINSEL9的值 | 功能 | 復(fù)位后的值 |
00 | 默認(rèn)功能,通常為GPIO口 | 00 |
01 | 第一個(gè)可選功能 | |
10 | 第二個(gè)可選功能 | |
11 | 第三個(gè)可選功能 |
PINSEL寄存器每兩位控制一個(gè)引腳,由于各個(gè)引腳的功能不一樣,所以PINSEL0~PINSEL9的配置也相應(yīng)的有所不同,想詳細(xì)了解這10個(gè)寄存器的功能可以參看《user.manual.lpc17xx》,這個(gè)手冊(cè)可以到NXP的網(wǎng)站上去下載。由于這次實(shí)驗(yàn)只是用到GPIO功能,所以暫時(shí)不用管這個(gè)寄存器,用它的默認(rèn)值就可以了。
另一個(gè)寄存器是引腳模式選擇寄存器PINMODE,它控制所有端口的工作模式,包括是否配置上拉/下拉電阻和特定的開漏操作模式等。引腳模式選擇寄存器PINMODE的功能如下表所示:
PINMODE0~PINMODE9的值 | 功能 | 復(fù)位后的值 |
00 | 引腳使能片內(nèi)上拉電阻 | 00 |
01 | 中斷模式 | |
10 | 引腳沒有使能片內(nèi)上拉/下拉電阻 | |
11 | 引腳使能下拉電阻 |
當(dāng)引腳處于邏輯高電平時(shí),中繼模式使能上拉電阻,當(dāng)引腳處于邏輯低電平時(shí),使能下拉電阻,當(dāng)引腳配置為輸入且不是通過外部驅(qū)動(dòng)時(shí),引腳將保持上一個(gè)已知狀態(tài)。PINMODE_0D寄存器控制寄存器的開漏模式,引腳配置為輸出且值為0時(shí),開漏模式會(huì)正常地將引腳電平拉低。但是如果輸出引腳為1,則引腳輸出驅(qū)動(dòng)關(guān)閉,等同于改變了引腳的方向,實(shí)際上是模擬了一個(gè)開漏輸出。
PINMODE_0D0~PINMODE_0D4的值 | 功能 | 復(fù)位后的值 |
00 | 引腳處于正常模式(非開漏模式) | 00 |
01 | 引腳處于開漏模式 |
除了以上兩個(gè)寄存器要配置,與GPIO端口相關(guān)的寄存器還有快速端口值寄存器FIOPIN可以用來讀/寫端口的值,端口輸出置位寄存器FIOSET,當(dāng)這個(gè)寄存器的相應(yīng)位置1時(shí),相應(yīng)端口引腳輸出1,當(dāng)然也可以從這個(gè)寄存器讀取當(dāng)前引腳輸出的值,與它對(duì)應(yīng)的寄存器是FIOCLR,當(dāng)寄存器FIOCLR相應(yīng)位置1時(shí),相應(yīng)引腳輸出0,但這個(gè)寄存器是只寫寄存器,不能讀取數(shù)據(jù)。好了,關(guān)于這些寄存器先總結(jié)到這,詳細(xì)的配置還要看LPC1768的用戶手冊(cè)《user.manual.lpc17xx》,當(dāng)然也可以經(jīng)常去NXP網(wǎng)站逛逛看看其它的handbook或whitepaper
#include"main.h"
volatile unsigned long SysTickCnt;
void SysTick_Handler (void)
{
}
void DelayMs (unsigned long tick)
{
}
void PortInit(void)
{
}
int main(void)
{
}
typedef struct
{
__IO uint32_t FIODIR;
uint32_t RESERVED0[3];
__IO uint32_t FIOMASK;
__IO uint32_t FIOPIN;
__IO uint32_t FIOSET;
__O
} GPIO_TypeDef;
還有幾個(gè)宏定義,如下所示:
1)、#define GPIO1
上面這個(gè)宏是把GPIO1指向芯片GPIO1的基址上,
2)、#define GPIO1_BASE
3)、#define GPIO_BASE
這三個(gè)宏就把GPIO的基址定義了出來,關(guān)于LPC1768內(nèi)部地址的分配情況,可以參看它的數(shù)據(jù)手冊(cè),也可參考一下《ARM Cortex-M3
評(píng)論