嵌入式实验报告按键实验.docxVIP

  1. 1、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 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)

t_github + 关注
实名认证
文档贡献者

计算机研究者

1亿VIP精品文档

相关文档