- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
实验三:按键程序
实验目的
熟悉linux系统,学会简单linux指令
熟悉OK6410-A开发板的烧入步骤
熟悉ARM寄存器,地址等。
系统性的了解UBOOT和linux内核,yaffs2系统映像等知识
掌握系统中断函数。
掌握内部相关寄存器的操作方法,最终实现对外部设备的控制。
实验环境
开发机环境
操作系统:ubuntu 12.04
交叉编译环境:arm-linux-gcc 4.3.2
6410板子内核源码:linux-3.0.1
目标板环境:OK6410-A linux-3.0.1
实验原理
图1-OK6410按键原理图
图2-按键原理图
按键相关端口配置寄存器:
按键相关端口数据寄存器:
按键相关端口上拉电路使能寄存器:
实验代码
修改系统内核文件
在原有到内核中,按键的GPIO口被占用,需要进行相应到修改才能达到预期到效果,首先需要做的是安装libncurses 的相关软件,来实现对内核到编写。
内核编写过程:
找到内核:#make menuconfig
Device Drivers
Input device support
keyboards
把GPIO Buttons选项去掉
生成新的zImage镜像文件,重新烧写系统
图3-内核修改
编写驱动程序:driver_key.c
#include linux/kernel.h
#include linux/module.h
#include linux/init.h
#include linux/fs.h
#include linux/gpio.h
#include linux/types.h
#include linux/cdev.h
#include linux/interrupt.h
#include linux/sched.h
#include linux/device.h
#include linux/poll.h
#include linux/semaphore.h
#include linux/timer.h
#include asm/irq.h
#include asm/uaccess.h
#include mach/hardware.h
#include mach/irqs.h
MODULE_LICENSE(GPL);
#define DEVICE_NAME keyint
#define KEYNUM 6
dev_t devid;
//static DEFINE_SEMAPHORE(key_lock); //declare a mutex lock for keyint
//定义一个信号量
struct semaphore key_lock;
static struct fasync_struct *key_async;
static struct timer_list key_timer;
struct key_irq_desc
{
int irq; //irq num
unsigned long flags; //irq flags,identified the way of irq here,eq.edge,level
char *name; //irq name
};
static struct key_irq_desc key_irqs[] = {
//下降沿产生中断
{IRQ_EINT(0), IRQF_TRIGGER_FALLING, KEY1},
{IRQ_EINT(1), IRQF_TRIGGER_FALLING, KEY2},
{IRQ_EINT(2), IRQF_TRIGGER_FALLING, KEY3},
{IRQ_EINT(3), IRQF_TRIGGER_FALLING, KEY4},
{IRQ_EINT(4), IRQF_TRIGGER_FALLING, KEY5},
{IRQ_EINT(5), IRQF_TRIGGER_FALLING, KEY6},
};
/*define a waiting queue here*/
static DECLARE_WAIT_QUEUE_HEAD(key_waitq);
/*define a event flag ev_press*/
static volatile int ev_press = 0;
static volatile int press_cnt[KEYNUM] = {0, 0, 0, 0, 0, 0};
/*中断处理函数*/
static irqreturn_t key
原创力文档


文档评论(0)