lPC1788的GPIO驱动
#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)
{
case 0:
P1high(14) = 1;
break;
case 1:
P0high(16) = 1;
break;
case 2:
P1high(13) = 1;
break;
case 3:
P4high(27) = 1;
break;
}
}
void led_clear(u8 ch)
{
switch(ch)
{
case 0:
P1low(14) = 1;//设置为低电平
break;
case 1:
P0low(16) = 1;//设置为低电平
break;
case 2:
P1low(13) = 1;//设置为低电平
break;
case 3:
P4low(27) = 1;//设置为低电平
break;
}
}
//位带操作,实现51类似的GPIO控制功能
//具体实现思想,参考<<CM3权威指南>>第五章(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输出
lPC1788的GPIO驱动的更多相关文章
- Linux下GPIO驱动(三) ----gpio_desc()的分析
上篇最后提出的疑问是结构体gpio_chip中的成员函数set等是怎么实现的,在回答之前先介绍下gpio_desc这个结构体. 如上图所示,右上方部分为GPIO驱动对其它驱动提供的GPIO操作接口,其 ...
- 调试exynos4412—ARM嵌入式Linux—LEDS/GPIO驱动之二
/** ****************************************************************************** * @author 暴走的小 ...
- 调试exynos4412—ARM嵌入式Linux—LEDS/GPIO驱动之一
/** ****************************************************************************** * @author 暴走的小 ...
- 调试exynos4412—ARM嵌入式Linux—LEDS/GPIO驱动之三
/** ****************************************************************************** * @author 暴走的小 ...
- 开发GPIO驱动的基本套路
最近完成了基于AR9331的GPIO驱动的开发,主要包括:控制一个连接GPIO的灯控:接收一个连接GPIO的按键事件:以及接收一个连接GPIO的脉冲事件. 这里,结合开发实践,总结一下GPIO驱动开发 ...
- [RK3288][Android6.0] 调试笔记 --- 通用GPIO驱动控制LED【转】
本文转载自:http://m.blog.csdn.net/kris_fei/article/details/69553422 Platform: ROCKCHIPOS: Android 6.0Kern ...
- uboot的GPIO驱动分析--基于全志的A10芯片【转】
本文转载自:http://blog.csdn.net/lw2011cg/article/details/68954707 uboot的GPIO驱动分析--基于全志的A10芯片 转载至:http://b ...
- MM32F0020 GPIO驱动LED灯(MM32F0020 GPIO Toggle)
目录: 1.MM32F0020简介 2.MM32F0020系统时钟配置 3.MM32F0020的GPIO外设配置及其初始化 4.使用官网的Systick定时器做延时 5.MM32F0020 GPIO驱 ...
- MM32F0140 GPIO驱动LED灯(MM32F0140 GPIO)
目录: 1.MM32F0140简介 2.MM32F0140系统时钟配置 3.MM32F0140的GPIO外设配置及其初始化 4.使用官网的Systick定时器做延时 5.MM32F0140 GPIO驱 ...
随机推荐
- iOS 判断奇偶数
if (_bigUrlArray.count%2==0) {//如果是偶数 a = i*(_bigUrlArray.count/count);//每个线程图片初始数 b = (i+1)*(_bigUr ...
- 无线手柄+步进电机——控制方向
今天测试了一下无线手柄控制电机转向的改变 1: #include <PS2X_lib.h> //for v1.6 2: #include <Stepper.h> 3: 4: ...
- android性能优化优秀文章
郭霖最近整理的文章: 合理管理内存 分析编码过程中如何避免过多内存占用,以及如何实现高性能的内存使用. 尽可能使用intentService; 当界面不可见时释放内存; 当内存紧张时释放内存; 避免b ...
- hdu_3564_Another LIS(线段树+LIS)
题目连接:http://acm.hdu.edu.cn/showproblem.php?pid=3564 题意:给你N个数的位置.数i的位置为第i个数,比如 0 0 2,表示1插在第0个位置,此时数列为 ...
- Linux SCP命令复制传输文件的用法
SCP命令是用户通过网络将一台Linux服务器的文件复制到另一台Linux服务器,方法如下: 一:从本地复制到远程 复制文件: 命令格式: scp local_file remote_username ...
- 7、装饰模式(Decorator)
顾名思义,装饰模式就是给一个对象增加一些新的功能,而且是动态的,要求装饰对象和被装饰对象实现同一个接口,装饰对象持有被装饰对象的实例,关系图如下: Source类是被装饰类,Decorator类是一个 ...
- android使用support的ActionBar时遇到的问题
多从网上下载好了support library之后,把android-support-v7-appcompat.jar放到了libs目录下,并加入到了编译路径,本以为万事大吉,可是却报了下面的一个错误 ...
- (转)Vim的Python编辑器详细配置过程 (Based on Ubuntu 12.04 LTS)
为什么要用vim编辑py文件? 因为在Linux命令行中,缺少图形界面的IDE,vim是最佳的文本编辑器,而为了更好的编辑py文本,所以配置vim. 1. 安装完整版vim vi和vim的区别? 在L ...
- Python3基础 定义有参数有返回值函数 对传入的参数加1
镇场诗: 诚听如来语,顿舍世间名与利.愿做地藏徒,广演是经阎浮提. 愿尽吾所学,成就一良心博客.愿诸后来人,重现智慧清净体.-------------------------------------- ...
- 基于Verilog HDL 的数字时钟设计
基于Verilog HDL的数字时钟设计 一.实验内容: 利用FPGA实现数字时钟设计,附带秒表功能及时间设置功能.时间设置由开关S1和S2控制,分别是增和减.开关S3是模式选择:0是正常时钟 ...