cortex m0 lpc1114 DATA寄存器
这一节,介绍如何利用DATA寄存器检测引脚上的高低电平变化。
新建一个工程,结构如下图所示:
在main.c文件中,输入以下代码:
- #include “LPC11XX.H”
- #define LED1_ON? LPC_GPIO1->DATA &= ~(1<<0)
- #define LED1_OFF LPC_GPIO1->DATA |= (1<<0)
- #define LED2_ON? LPC_GPIO1->DATA &= ~(1<<1)
- #define LED2_OFF LPC_GPIO1->DATA |= (1<<1)
- #define KEY1_DOWN (LPC_GPIO1->DATA&(1<<9))!=(1<<9)
- #define KEY2_DOWN (LPC_GPIO1->DATA&(1<<10))!=(1<<10)
- #define KEY3_DOWN (LPC_GPIO1->DATA&(1<<4))!=(1<<4)
- #define KEY4_DOWN (LPC_GPIO1->DATA&(1<<10))!=(1<<10)
- void delay()
- {
- ? ?uint16_t i,j;
- ? ?for(i=0;i<5000;i++)
- ? ? ? for(j=0;j<10;j++);
- }
- void led_init()
- {
- ? ?LPC_SYSCON->SYSAHBCLKCTRL |= (1<<16); // 使能IOCON时钟
- ? ?LPC_IOCON->R_PIO1_0 &= ~0x07;
- ? ?LPC_IOCON->R_PIO1_0 |= 0x01; //把P1.0脚设置为GPIO
- ? ?LPC_IOCON->R_PIO1_1 &= ~0x07;
- ? ?LPC_IOCON->R_PIO1_1 |= 0x01; //把P1.1脚设置为GPIO
- ? ?LPC_SYSCON->SYSAHBCLKCTRL &= ~(1<<16); // 禁能IOCON时钟
- ? ?LPC_GPIO1->DIR |= (1<<0); // 把P1.0设置为输出引脚
- ? ?LPC_GPIO1->DATA |= (1<<0); // 把P1.0设置为高电平
- ? ?LPC_GPIO1->DIR |= (1<<1); // 把P1.1设置为输出引脚
- ? ?LPC_GPIO1->DATA |= (1<<1); // 把P1.1设置为高电平
- }
- int main()
- {
- ? ?led_init();
- ? ?while(1)
- ? ?{
- ? ? ? if(KEY1_DOWN) // 如果按下了KEY1键
- ? ? ? {
- ? ? ? ? ?delay();?? // 延时消抖
- ? ? ? ? ?if(KEY1_DOWN) // 再次判断是否按下了KEY1键
- ? ? ? ? ?{
- ? ? ? ? ? ? LED1_ON;
- ? ? ? ? ? ? while(KEY1_DOWN); // 如果KEY1一直按着不放,程序停留在此处
- ? ? ? ? ? ? LED1_OFF;
- ? ? ? ? ?}
- ? ? ? }
- ? ? ? if(KEY2_DOWN) // 如果按下了KEY2键
- ? ? ? {
- ? ? ? ? ?delay();?? // 延时消抖
- ? ? ? ? ?if(KEY2_DOWN) // 再次判断是否按下了KEY2键
- ? ? ? ? ?{
- ? ? ? ? ? ? LED2_ON;
- ? ? ? ? ? ? while(KEY2_DOWN); // 如果KEY2一直按着不放,程序停留在此处
- ? ? ? ? ? ? LED2_OFF;
- ? ? ? ? ?}
- ? ? ? }
- ? ?}
- }
关于LED部分的代码解释,请看上一节。
第6~9行,按键1和按键2的宏定义,读取P1.9和P1.10引脚上的电平。
例如,读取P1.0引脚的电平:(LPC_GPIO1->DATA&(1<<9))!=(1<<9)
这条语句的思想是,给DATA寄存器bit9“与”1,如果bit9变为0,说明此位在没有“与”之前为0,即低电平;如果bit9还是1,说明是高电平。这样,即可判断按键有无按下。
在main函数中,没有对按键的初始化,是因为P1.9和P1.10引脚在默认的情况下就是GPIO,而且是输入功能。