lPC1788的GPIO驅(qū)動(dòng)
#include "led.h"
void led_init(void)
{
//p1.14 p0.16 p1.13 p4.27
LPC_SC->PCONP|=(1<<15);//打開時(shí)鐘
//選擇管腳模式,1788為每個(gè)管腳都設(shè)計(jì)了一個(gè)寄存器來選擇管腳模式
LPC_IOCON->P1_14=0x00;//選擇gpio功能,禁止遲滯 不反向 正常推挽
LPC_IOCON->P1_14|=(2<<3);//上拉
P1dir(14)=1; //輸出
P1low(14)=1;//設(shè)置為低電平
LPC_IOCON->P0_16=0x00;//選擇gpio功能,禁止遲滯 不反向 正常推挽
LPC_IOCON->P0_16|=(2<<3);//上拉
P0dir(16)=1; //輸出
P0low(16)=1;//設(shè)置為低電平
LPC_IOCON->P1_13=0x00;//選擇gpio功能,禁止遲滯 不反向 正常推挽
LPC_IOCON->P1_13|=(2<<3);//上拉
P1dir(13)=1; //輸出
P1low(13)=1;//設(shè)置為低電平
LPC_IOCON->P4_27=0x00;//選擇gpio功能,禁止遲滯 不反向 正常推挽
LPC_IOCON->P4_27|=(2<<3);//上拉
P4dir(27)=1; //輸出
P4low(27)=1;//設(shè)置為低電平
}
void led_set(u8 ch)
{
switch(ch)
{
case0:
P1high(14)=1;
break;
case1:
P0high(16)=1;
break;
case2:
P1high(13)=1;
break;
case3:
P4high(27)=1;
break;
}
}
void led_clear(u8 ch)
{
switch(ch)
{
case0:
P1low(14)=1;//設(shè)置為低電平
break;
case1:
P0low(16)=1;//設(shè)置為低電平
break;
case2:
P1low(13)=1;//設(shè)置為低電平
break;
case3:
P4low(27)=1;//設(shè)置為低電平
break;
}
}
//位帶操作,實(shí)現(xiàn)51類似的GPIO控制功能
//具體實(shí)現(xiàn)思想,參考<
//IO口操作宏定義
#define BITBAND(addr, bitnum) ((addr & 0xF0000000)+0x2000000+((addr &0xFFFFF)<<5)+(bitnum<<2))
#define MEM_ADDR(addr) *((volatile unsigned long *)(addr))
#define BIT_ADDR(addr, bitnum) MEM_ADDR(BITBAND(addr, bitnum))
//IO口地址映射
//輸出寄存器
#define GPIO0_ODR_Addr (LPC_GPIO0_BASE+0x18) //0x2009C018
#define GPIO1_ODR_Addr (LPC_GPIO1_BASE+0x18) //0x2009C038
#define GPIO2_ODR_Addr (LPC_GPIO2_BASE+0x18) //0x2009C058
#define GPIO3_ODR_Addr (LPC_GPIO3_BASE+0x18) //0x2009C078
#define GPIO4_ODR_Addr (LPC_GPIO4_BASE+0x18) //0x2009C098
//輸入寄存器
#define GPIO0_IDR_Addr (LPC_GPIO0_BASE+0x14) //0x2009C014
#define GPIO1_IDR_Addr (LPC_GPIO1_BASE+0x14) //0x2009C034
#define GPIO2_IDR_Addr (LPC_GPIO2_BASE+0x14) //0x2009C054
#define GPIO3_IDR_Addr (LPC_GPIO3_BASE+0x14) //0x2009C074
#define GPIO4_IDR_Addr (LPC_GPIO4_BASE+0x14) //0x2009C094
//方向寄存器
#define GPIO0_DIR_Addr (LPC_GPIO0_BASE+0x00) //0x2009C000
#define GPIO1_DIR_Addr (LPC_GPIO1_BASE+0x00) //0x2009C020
#define GPIO2_DIR_Addr (LPC_GPIO2_BASE+0x00) //0x2009C040
#define GPIO3_DIR_Addr (LPC_GPIO3_BASE+0x00) //0x2009C060
#define GPIO4_DIR_Addr (LPC_GPIO4_BASE+0x00) //0x2009C080
//清零寄存器
#define GPIO0_CLS_Addr (LPC_GPIO0_BASE+0x1C) //0x2009C01C
#define GPIO1_CLS_Addr (LPC_GPIO1_BASE+0x1C) //0x2009C03C
#define GPIO2_CLS_Addr (LPC_GPIO2_BASE+0x1C) //0x2009C05C
#define GPIO3_CLS_Addr (LPC_GPIO3_BASE+0x1C) //0x2009C07C
#define GPIO4_CLS_Addr (LPC_GPIO4_BASE+0x1C) //0x2009C09C
//IO口操作,只對(duì)單一的IO口!
//確保n的值小于32!
#define P0high(n) BIT_ADDR(GPIO0_ODR_Addr,n) //輸出 0輸出不變 1輸出為1
#define P0low(n) BIT_ADDR(GPIO0_CLS_Addr,n) // 清除 0輸出不變 1輸出0
#define P0in(n) BIT_ADDR(GPIO0_IDR_Addr,n) //輸入
#define P0dir(n) BIT_ADDR(GPIO0_DIR_Addr,n) //方向 0輸入1輸出
#define P1high(n) BIT_ADDR(GPIO1_ODR_Addr,n) //輸出 0輸出不變 1輸出為1
#define P1low(n) BIT_ADDR(GPIO1_CLS_Addr,n) // 清除 0輸出不變 1輸出0
#define P1in(n) BIT_ADDR(GPIO1_IDR_Addr,n) //輸入
#define P1dir(n) BIT_ADDR(GPIO1_DIR_Addr,n) //方向 0輸入1輸出
#define P2high(n) BIT_ADDR(GPIO2_ODR_Addr,n) //輸出 0輸出不變 1輸出為1
#define P2low(n) BIT_ADDR(GPIO2_CLS_Addr,n) // 清除 0輸出不變 1輸出0
#define P2in(n) BIT_ADDR(GPIO2_IDR_Addr,n) //輸入
#define P2dir(n) BIT_ADDR(GPIO2_DIR_Addr,n) //方向 0輸入1輸出
#define P3high(n) BIT_ADDR(GPIO3_ODR_Addr,n) //輸出 0輸出不變 1輸出為1
#define P3low(n) BIT_ADDR(GPIO3_CLS_Addr,n) // 清除 0輸出不變 1輸出0
#define P3in(n) BIT_ADDR(GPIO3_IDR_Addr,n) //輸入
#define P3dir(n) BIT_ADDR(GPIO3_DIR_Addr,n) //方向 0輸入1輸出
#define P4high(n) BIT_ADDR(GPIO4_ODR_Addr,n) //輸出 0輸出不變 1輸出為1
#define P4low(n) BIT_ADDR(GPIO4_CLS_Addr,n) // 清除 0輸出不變 1輸出0
#define P4in(n) BIT_ADDR(GPIO4_IDR_Addr,n) //輸入
#define P4dir(n) BIT_ADDR(GPIO4_DIR_Addr,n) //方向 0輸入1輸出