蜂鸣器驱动程序设计.doc
《蜂鸣器驱动程序设计.doc》由会员分享,可在线阅读,更多相关《蜂鸣器驱动程序设计.doc(21页珍藏版)》请在沃文网上搜索。
1、嵌入式系统开发技术课程设计设计题目: 蜂鸣器驱动程序设计 2014年05月word文档 可自由复制编辑1.绪论31.1概要31.2设计内容42.开发环境的搭建42.1Redhat的安装42.2安装arm-linux-gcc交叉编译器92.3安装及编译linux-2.6.29-mini2440-20090708内核93.字符设备驱动相关知识93.1模块机制93.2字符设备开发基本步骤103.3主设备号和次设备号113.4实现字符驱动程序124.蜂鸣器原理144.1蜂鸣器的种类和工作原理144.2开发板上蜂鸣器原理图分析154.3GPB0参数155.总体设计165.1设计思路165.2设计步骤16
2、6. 驱动及测试程序176.1beep.c176.2beep_tset.c217.运行结果及截图22综合设计总结与思考25word文档 可自由复制编辑 1.绪论1.1概要linux 驱动在本质上就是一种软件程序,上层软件可以在不用了解硬件特性的情况下,通过驱动提供的接口,和计算机硬件进行通信。 系统调用是内核和应用程序之间的接口,而驱动程序是内核和硬件之间的接口,也就是内核和硬件之间的桥梁。它为应用程序屏蔽了硬件的细节,这样在应用程序看来,硬件设备只是一个设备文件,应用程序可以象操作普通文件一样对硬件设备进行操作。 linux 驱动程序是内核的一部分,管理着系统中的设备控制器和相应的设备。它主
3、要完成这么几个功能:对设备初始化和释放;传送数据到硬件和从硬件读取数据;检测和处理设备出现的错误。 一般来说,一个驱动可以管理一种类型的设备。例如不同的 U 盘都属于 mass storage 设备,我们不需要为每一个 U 盘编写驱动,而只需要一个驱动就可以管理所有这些 mass storage 设备。 为方便我们加入各种驱动来支持不同的硬件,内核抽象出了很多层次结构,这些层次结构是 linux 设备驱动的上层。它们抽象出各种的驱动接口,驱动只需要填写相应的回调函数,就能很容易把新的驱动添加到内核。 一般来说, linux 驱动可以分为三类,就是块设备驱动,字符设备驱动和网络设备驱动。块设备的
4、读写都有缓存来支持,并且块设备必须能够随机存取。块设备驱动主要用于磁盘驱动器。 而字符设备的 I/O 操作没有通过缓存。字符设备操作以字节为基础,但不是说一次只能执行一个字节操作。例如对于字符设备我们可以通过 mmap 一次进行大量数据交换。字符设备实现比较简单和灵活。1.2设计内容本次设计是简单的字符设备驱动设计,基于mini2440的蜂鸣器的驱动设计。 2.开发环境的搭建2.1Redhat的安装创建一个虚拟机:点击菜单栏File-New-Virtual machine。点击下一步。选择Typical选项。选择Linux下的Red Hat Linux填写虚拟机的命名和存储地址。选择磁盘大小2
5、.2安装arm-linux-gcc交叉编译器 将 arm-linux-gcc-4.3.2.tgz复制到虚拟机的root目录下解压文件:tar zxvf arm-linux-gcc-4.3.2.tgz在bash_profile里添加路径:gedit /.bash_profiel 路径 /root/usr/local/arm/4.3.2/binsource /.bash_profile 使更改生效2.3安装及编译linux-2.6.29-mini2440-20090708内核复制内核到root目录下解压内核文件 tar zxvf linux-2.6.29-mini2440-20090708.tgz
6、使内核文件生效:cp config_mini2440_n35 .config使用make命令完成编译 3.字符设备驱动相关知识3.1模块机制Linux提供了机制被称为模块(Module)的机制 提供了对许多模块支持, 包括但不限于, 设备驱动每个模块由目标代码组成( 没有连接成一个完整可执行程序 )insmod 将模块动态加载到正在运行内核rmmod 程序移除模块Linux内核模块的程序结构l static int _init beep_init(void)-模块初始化函数 通过alloc_chrdev_region来分配设备号beep_cdev来对设备进行各种操作。比如在加载内核模块时,模块
7、的加载函数会自动被内核执行,完成模块的相关初始化工作l static void _exit beep_exit(void)-模块卸载函数(必须) 当通过unregister_chrdev_region命令卸载某模块时,模块的卸载函数会自动被内核执行,完成与模块装载函数相反的功能l MODULE_LICENSE()-模块许可证声明(必须)模块许可证(LICENSE)声明描述内核模块的许可权限如果不声明LICENSE,模块被加载时,将收到内核被污染(kernel tainted)的警告l 其他一些声明MODULE_XXXXX()-模块声明(可选)模块加载函数static int _init ini
8、tialization_function(void) /* 初始化代码 */module_init(initialization_function); 模块卸载函数 static void _exit cleanup_function(void) /* 释放资源 */ module_exit(cleanup_function); 3.2字符设备开发基本步骤l 确定主设备号和次设备号l 实现字符驱动程序实现file_operations结构体实现初始化函数,注册字符设备实现销毁函数,释放字符设备l 创建设备文件节点3.3主设备号和次设备号l 主设备号是内核识别一个设备的标识。整数(占12bits
9、),范围从0到4095,通常使用1到255l 次设备号由内核使用,用于正确确定设备文件所指的设备。整数(占20bits),范围从0到1048575,一般使用0到255l 设备编号的内部表达dev_t类型(32位):用来保存设备编号(包括主设备号(12位)和次设备号(20位)从dev_t获得主设备号和次设备号:MAJOR(dev_t);MINOR(dev_t);将主设备号和次设备号转换成dev_t类型:MKDEV(int major,int minor); l 分配主设备号手工分配主设备号:找一个内核没有使用的主设备号来使用。#include int register_chrdev_region
10、( dev_t first, unsigned int count, char *name );l 动态分配主设备号:#include int alloc_chrdev_resion(dev_t *dev,unsigned int firstminor,unsigned int count,char *name);l 释放设备号void unregister_chrdev_region(dev_t first, unsigned int count);3.4实现字符驱动程序l cdev 结构体struct cdev dev_t beep_devno; /*设备号*/unsigned int *
11、map;struct file_operations *ops; /*文件操作结构体*/ unsigned int count; ;l file_operations 结构体字符驱动和内核的接口:在include/linux/fs.h定义字符驱动只要实现一个file_operations结构体并注册到内核中,内核就有了操作此设备的能力。l file_operations的主要成员:open:打开设备release:关闭设备read:从设备上读数据write:向设备上写数据ioctl:I/O控制函数l ioctl函数为设备驱动程序执行“命令”提供了一个特有的入口点用来设置或者读取设备的属性信息。
- 1.请仔细阅读文档,确保文档完整性,对于不预览、不比对内容而直接下载带来的问题本站不予受理。
- 2.下载的文档,不会出现我们的网址水印。
- 3、该文档所得收入(下载+内容+预览)归上传者、原创作者;如果您是本文档原作者,请点此认领!既往收益都归您。
下载文档到电脑,查找使用更方便
20 积分
下载 | 加入VIP,下载更划算! |
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 蜂鸣器 驱动程序 设计