当前位置:首页 > 单片机 > 单片机
[导读]#include \"led.h\"void led_init(void){ //p1.14 p0.16 p1.13 p4.27 LPC_SC->PCONP|=(1P1_14|=(2P0_16|=(2P1_13|=(2P4_27|=(2

#include "led.h"

void led_init(void)

{

//p1.14 p0.16 p1.13 p4.27

LPC_SC->PCONP|=(1<<15);//打开时钟

//选择管脚模式,1788为每个管脚都设计了一个寄存器来选择管脚模式

LPC_IOCON->P1_14=0x00;//选择gpio功能,禁止迟滞 不反向 正常推挽

LPC_IOCON->P1_14|=(2<<3);//上拉

P1dir(14)=1; //输出

P1low(14)=1;//设置为低电平

LPC_IOCON->P0_16=0x00;//选择gpio功能,禁止迟滞 不反向 正常推挽

LPC_IOCON->P0_16|=(2<<3);//上拉

P0dir(16)=1; //输出

P0low(16)=1;//设置为低电平

LPC_IOCON->P1_13=0x00;//选择gpio功能,禁止迟滞 不反向 正常推挽

LPC_IOCON->P1_13|=(2<<3);//上拉

P1dir(13)=1; //输出

P1low(13)=1;//设置为低电平

LPC_IOCON->P4_27=0x00;//选择gpio功能,禁止迟滞 不反向 正常推挽

LPC_IOCON->P4_27|=(2<<3);//上拉

P4dir(27)=1; //输出

P4low(27)=1;//设置为低电平

}

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;//设置为低电平

break;

case1:

P0low(16)=1;//设置为低电平

break;

case2:

P1low(13)=1;//设置为低电平

break;

case3:

P4low(27)=1;//设置为低电平

break;

}

}

//位带操作,实现51类似的GPIO控制功能

//具体实现思想,参考<>第五章(87页~92页).

//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口操作,只对单一的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输出


本站声明: 本文章由作者或相关机构授权发布,目的在于传递更多信息,并不代表本站赞同其观点,本站亦不保证或承诺内容真实性等。需要转载请联系该专栏作者,如若文章内容侵犯您的权益,请及时联系本站删除( 邮箱:macysun@21ic.com )。
换一批
延伸阅读
关闭