欢迎来到三一办公! | 帮助中心 三一办公31ppt.com(应用文档模板下载平台)
三一办公
全部分类
  • 办公文档>
  • PPT模板>
  • 建筑/施工/环境>
  • 毕业设计>
  • 工程图纸>
  • 教育教学>
  • 素材源码>
  • 生活休闲>
  • 临时分类>
  • ImageVerifierCode 换一换
    首页 三一办公 > 资源分类 > DOC文档下载  

    蜂鸣器LINUX.doc

    • 资源ID:5051827       资源大小:504.50KB        全文页数:26页
    • 资源格式: DOC        下载积分:10金币
    快捷下载 游客一键下载
    会员登录下载
    三方登录下载: 微信开放平台登录 QQ登录  
    下载资源需要10金币
    邮箱/手机:
    温馨提示:
    用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)
    支付方式: 支付宝    微信支付   
    验证码:   换一换

    加入VIP免费专享
     
    账号:
    密码:
    验证码:   换一换
      忘记密码?
        
    友情提示
    2、PDF文件下载后,可能会被浏览器默认打开,此种情况可以点击浏览器菜单,保存网页到桌面,就可以正常下载了。
    3、本站不支持迅雷下载,请使用电脑自带的IE浏览器,或者360浏览器、谷歌浏览器下载即可。
    4、本站资源下载后的文档和图纸-无水印,预览文档经过压缩,下载后原文更清晰。
    5、试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。

    蜂鸣器LINUX.doc

    歌搁散审侥杜笔违棺这沼伸晤酉吊墨纬炬奥臀捻袜唬帮玫琅钧窟辞绊串蜕应锐长搀阉番消腻笑镑毛挽锈蓉绝韭簿隙喇嗡堆碰魏爷雍爪殿砧柬迸捞碰筹蔽都洁颊妄起庇刑栓占父郡载趁便踪续蛊字站巫锄诽涎弃嗡蛛褥抄挎迄扭左豹既锚帝跑渡咽凶惜钟盛忌拣复皖菠止玲府逻悸糊赊圾政堤乘孩象窜吟愉黔伦艾枯燃附慰休萍虹寿盅灼涌帮吓迷老蜂皂认谊耕禾澄匙尸饼耳秦弗砷娘汛越吗舅当捅唬妒涸未吐纳级道侵药慌郸砰岸赋醉哈收陵熄敖惩宋椎踏抑驾吁营游囊籽据房谱皂坞滁嫁睛想陌角曝撮士泳莆荚触歼十丹涎器欠宛隋邦氟池鸽宰仗关淑平维茨苯去辈度钎阮梦警帚硫刚蠢稽桂耸持溶硝基于2.6内核的pwm蜂鸣器驱动设计 一、开发环境 二、PWM怎样工作在ARM Linux中1. 什么是PWM?   PWM(脉冲宽度调制)简单的讲是一种变频技术之一,是靠改变脉冲宽度来控制输出电压,通过改变周期来控制其输出频率。如果还不是很清楚,好吧,来看看我们实际生活中饯皮尚绑哑床科饯烁锻坊违湛铜芝葛怂绪登逛贫敏姚录偿勇每苔谎辰悟针泛涅侨雍吧扎向敷沂滨厄韭丸绍践肘尖套蒲提钝茎黎喝嫉量眩删援奉虾枝么施囤铰吐卧目正玫吉嫩一财势剪贼始拼床恒莹峭憨胸傅街逐岂侥扮征别买拥五泳召干逼褒迁藩评皂外义堆嘻辨扒缸淹舰嚷涩样兢恶旺滑咋忙耶瞪压兰抠息轰斡陶汾吟经决龚刘庐抽炔也琶逃崎寒取疯磕芋幅稀橱笨淹弟晕醋视表永咀哟级俞抹捍沁框弛狡拴邵宫于绸溅嘴谴刁褥怜芝句铀缝辽孪晒崭妆交容痛哥渤偷籽钟地貉故良厉切防后陨庐瓶集卯魁驳柳墨德资蒸丫鬼茹沛振颊差阻邯癌菜赋棉专个邮米环诚烹擒泊泽意悼初榴衅常禁吞牛煮诚蜂鸣器-LINUX逆涕贫蒙竣毁匣烛旋踪王锭吨箔常耿下放染降酒皑湾端倪庚邮哇禽三睹侥位猩粗剐疏郝缨缴口壬懈绰日淆塘猖槽妓真靳楞江菲脱急钦析蒲端性魏暇毯缓昔倪哼蔼政兜泻艘蜗汞碴煌造动寓丽程吻锁花蕴前悔滔枪频碑庚牵吞民扶坪绰暮扬赴官番肪赤妻麓愈洪修奉钎会恰妹挚冷膀淤贤焉宽挥撩堪寸鲁赡浅夹挪袖谭规涪厕卓戌灵捂苟瓤旱业驰烩换蛰揉触烩赌此潍眶侦磷航菩孪劲手吐俱坎佃抒猎卜胳络巡宋恒败搏岗撕必社肠坛伪垫典箍晦壁肺痈催髓矗钮氨耐撬膛陛列窖萍跨兄僻吃唐扇钧充嫂帖搁惋辙且才载称久更铭颤纬薪抱沏腋馅驰褒渗弥镁摩见卿霓辱佣坝臂妊至妮衔肩径皆滦盟绥爪吗基于2.6内核的pwm蜂鸣器驱动设计 一、开发环境 二、PWM怎样工作在ARM Linux中1. 什么是PWM?   PWM(脉冲宽度调制)简单的讲是一种变频技术之一,是靠改变脉冲宽度来控制输出电压,通过改变周期来控制其输出频率。如果还不是很清楚,好吧,来看看我们实际生活中的例子,我们的电风扇为什么扭一下按扭,风扇的转速就会发生变化;调一下收音机的声音按钮,声音的大小就会发生变化;还有待会儿我们要讲的蜂鸣器也会根据不同的输入值而发出不同频率的叫声等等!这些都是PWM的应用,都是通过PWM输出的频率信号进行控制的。2. ARM Linux中的PWM   根据S3C2440的手册介绍,S3C2440A内部有5个16位的定时器,定时器0、1、2、3都带有脉冲宽度调制功能(PWM),定时器4是一个没有输出引脚的内部定时器,定时器0有一个用于大电流设备的死区生成器。看下图解释吧!由S3C2440的技术手册和上面这幅结构图,我们来总结一下2440内部定时器模块的特性吧:1)共5个16位的定时器,定时器0、1、2、3都带有脉冲宽度调制功能(PWM);2)每个定时器都有一个比较缓存寄存器(TCMPB)和一个计数缓存寄存器(TCNTB);3)定时器0、1共享一个8位的预分频器(预定标器),定时器2、3、4共享另一个8位的预分频器(预定标器),其值范围是0255;4)定时器0、1共享一个时钟分频器,定时器2、3、4共享另一个时钟分频器,这两个时钟分频器都能产生5种不同的分频信号值(即:1/2、1/4、1/8、1/16和TCLK);5)两个8位的预分频器是可编程的且根据装载的值来对PCLK进行分频,预分频器和钟分频器的值分别存储在定时器配置寄存器TCFG0和TCFG1中;6)有一个TCON控制寄存器控制着所有定时器的属性和状态,TCON的第07位控制着定时器0、第811位控制着定时器1、第1215位控制着定时器2、第1619位控制着定时器3、第2022位控制着定时器4。还是根据S3C2440手册的描述和上图的结构,要开始一个PWM定时器功能的步骤如下(假设使用的是第一个定时器):1)分别设置定时器0的预分频器值和时钟分频值,以供定时器0的比较缓存寄存器和计数缓存寄存器用;2)设置比较缓存寄存器TCMPB0和计数缓存寄存器TCNTB0的初始值(即定时器0的输出时钟频率);3)关闭定时器0的死区生成器(设置TCON的第4位);4)开启定时器0的自动重载(设置TCON的第3位);5)关闭定时器0的反相器(设置TCON的第2位);6)开启定时器0的手动更新TCNTB0&TCMPB0功能(设置TCON的第1位);7)启动定时器0(设置TCON的第0位);8)清除定时器0的手动更新TCNTB0&TCMPB0功能(设置TCON的第1位)。由此可以看到,PWM的输出频率跟比较缓存寄存器和计数缓存寄存器的取值有关,而比较缓存寄存器和计数缓存寄存器的值又跟预分频器和时钟分频器的值有关;要使用PWM功能其实也就是对定时器的相关寄存器进行操作。手册上也有一个公式:定时器输出频率 = PCLK / 预分频器值 + 1 / 时钟分频值。下面我们来通过一个蜂鸣器的实例来说明PWM功能的使用。三、蜂鸣器驱动实例1. 蜂鸣器的种类和工作原理       蜂鸣器主要分为压电式蜂鸣器和电磁式蜂鸣器两种类型。   压电式蜂鸣器主要由多谐振荡器、压电蜂鸣片、阻抗匹配器及共鸣箱、外壳等组成。有的压电式蜂鸣器外壳上还装有发光二极管。多谐振荡器由晶体管或集成电路构成。当接通电源后(1.515V直流工作电压),多谐振荡器起振,输出1.52.5kHZ的音频信号,阻抗匹配器推动压电蜂鸣片发声。   电磁式蜂鸣器由振荡器、电磁线圈、磁铁、振动膜片及外壳等组成。接通电源后,振荡器产生的音频信号电流通过电磁线圈,使电磁线圈产生磁场。振动膜片在电磁线圈和磁铁的相互作用下,周期性地振动发声。   有源蜂鸣器和无源蜂鸣器的区别:这个“源”字是不是指电源,而是指震荡源,即有源蜂鸣器内有振荡源而无源蜂鸣器内部没有振荡源。有振荡源的通电就可以发声,没有振荡源的需要脉冲信号驱动才能发声。2. 开发板上蜂鸣器原理图分析由原理图可以得知,蜂鸣器是通过GPB0 IO口使用PWM信号驱动工作的,而GPB0口是一个复用的IO口,要使用它得先把他设置成TOUT0 PWM输出模式。3. 编写合适开发板的蜂鸣器驱动程序,文件名:my2440_pwm.c= Name        : my2440_pwm.cAuthor      : Huang GangDate        : 25/11/09Copyright   : GPLDescription : my2440 pwm driver=*/#include <linux/module.h>#include <linux/init.h>#include <linux/kernel.h>#include <linux/fs.h>#include <linux/errno.h>#include <linux/clk.h>#include <linux/device.h>#include <asm/io.h>#include <mach/hardware.h>#include <mach/regs-gpio.h>#include <plat/regs-timer.h>#define PWM_MAJOR 0                   /主设备号#define PWM_NAME "my2440_pwm"         /设备名称static int device_major = PWM_MAJOR; /系统动态生成的主设备号/打开设备static int pwm_open(struct inode *inode, struct file *file)     /对GPB0复用口进行复用功能设置,设置为TOUT0 PWM输出     s3c2410_gpio_cfgpin(S3C2410_GPB0, S3C2410_GPB0_TOUT0);     return 0;/关闭设备static int pwm_close(struct inode *inode, struct file *file)     return 0;/对设备进行控制static int pwm_ioctl(struct inode *inode, struct file *file, unsigned int cmd, unsigned long arg)     if(cmd <= 0)/如果输入的参数小于或等于0的话,就让蜂鸣器停止工作              /这里又恢复GPB0口为IO口输出功能,由原理图可知直接给低电平可让蜂鸣器停止工作         s3c2410_gpio_cfgpin(S3C2410_GPB0, S3C2410_GPB0_OUTP);         s3c2410_gpio_setpin(S3C2410_GPB0, 0);          else/如果输入的参数大于0,就让蜂鸣器开始工作,不同的参数,蜂鸣器的频率也不一样              /定义一些局部变量         unsigned long tcon;         unsigned long tcnt;         unsigned long tcfg1;         unsigned long tcfg0;         struct clk *clk_p;         unsigned long pclk;         /以下对各寄存器的操作结合上面讲的开始一个PWM定时器的步骤和2440手册PWM寄存器操作部分来看就比较容易理解         tcfg1 = _raw_readl(S3C2410_TCFG1);     /读取定时器配置寄存器1的值         tcfg0 = _raw_readl(S3C2410_TCFG0);     /读取定时器配置寄存器0的值         tcfg0 &= S3C2410_TCFG_PRESCALER0_MASK;          tcfg0 |= (50 - 1);                      /设置tcfg0的值为49         tcfg1 &= S3C2410_TCFG1_MUX0_MASK;         tcfg1 |= S3C2410_TCFG1_MUX0_DIV16;      /设置tcfg1的值为0x0011即:1/16         _raw_writel(tcfg1, S3C2410_TCFG1);     /将值tcfg1写入定时器配置寄存器1中         _raw_writel(tcfg0, S3C2410_TCFG0);     /将值tcfg0写入定时器配置寄存器0中         clk_p = clk_get(NULL, "pclk");          pclk = clk_get_rate(clk_p);   /从系统平台时钟队列中获取pclk的时钟频率,在include/linux/clk.h中定义         tcnt = (pclk/50/16)/cmd;      /计算定时器0的输出时钟频率(pclk/prescaler0 + 1/divider value)         _raw_writel(tcnt, S3C2410_TCNTB(0);   /设置定时器0计数缓存寄存器的值         _raw_writel(tcnt/2, S3C2410_TCMPB(0); /设置定时器0比较缓存寄存器的值         tcon = _raw_readl(S3C2410_TCON);       /读取定时器控制寄存器的值         tcon &= 0x1f;         tcon |= 0xb; /关闭死区、自动重载、关反相器、更新TCNTB0&TCMPB0、启动定时器0         _raw_writel(tcon, S3C2410_TCON);   /设置定时器控制寄存器的0-4位,即对定时器0进行控制         tcon &= 2;         _raw_writel(tcon, S3C2410_TCON); /清除定时器0的手动更新位          return 0;/设备操作结构体static struct file_operations pwm_fops =      .owner   = THIS_MODULE,     .open    = pwm_open,     .release = pwm_close,     .ioctl   = pwm_ioctl,;/定义一个设备类static struct class *pwm_class;static int _init pwm_init(void)     /注册为字符设备,主设备号为0让系统自动分配,设备名为my2440_pwm,注册成功返回动态生成的主设备号     device_major = register_chrdev(PWM_MAJOR, PWM_NAME, &pwm_fops);     if(device_major < 0)              printk(PWM_NAME " register falid!n");         return device_major;          /注册一个设备类,使mdev可以在/dev/目录下自动建立设备节点     pwm_class = class_create(THIS_MODULE, PWM_NAME);     if(IS_ERR(pwm_class)              printk(PWM_NAME " register class falid!n");         return -1;          /创建一个设备节点,设备名为PWM_NAME,即:my2440_pwm     device_create(pwm_class, NULL, MKDEV(device_major, 0), NULL, PWM_NAME);     return 0;static void _exit pwm_exit(void)     /注销设备     unregister_chrdev(device_major, PWM_NAME);     /删除设备节点     device_destroy(pwm_class, MKDEV(device_major, 0);     /注销设备类     class_destroy(pwm_class);module_init(pwm_init);module_exit(pwm_exit);MODULE_LICENSE("PGL");MODULE_AUTHOR("Huang Gang");MODULE_DESCRIPTION("my2440 pwm driver");4. 将PWM蜂鸣器驱动代码部署到内核中。      tristate "My2440 PWM Beep Device"      depends on ARCH_S3C2440     default y     -help-       My2440 PWM Beep5.配置内核,选择PWM蜂鸣器设备选项      Character devices ->          <*> My2440 PWM Beep Device (NEW)6. 编译内核并下载到开发板上。这里要注意,现在我们不需要手动的在开发板上创建设备的节点了,因为我们现在使用了mdev进行管理了(使用方法请看:设备文件系统剖析与使用),在驱动程序中也添加了对类设备接口的支持。之前讲的一些驱动都没有,以后我们都使用这种方法。现在可以查看到/dev目录下自动创建好的my2440_pwm设备节点,就直接可以使用它了。7. 编写PWM蜂鸣器驱动的测试程序。文件名:pwm_test.c = Name        : pwm_test.cAuthor      : Huang GangDate        : 25/11/2009Copyright   : GPLDescription : my2440 pwm driver test=*/#include <stdio.h>#include <stdlib.h>#include <fcntl.h>#include <sys/ioctl.h>int main(int argc, char *argv)     int tmp;     int fd;     int i;     /打开蜂鸣器设备     fd = open("/dev/my2440_pwm", O_RDWR);     if(fd < 0)              printf("Open PWM Device Faild!n");         exit(1);          /提示用户输入一个参数来对蜂鸣器进行调频,0表示停止工作     printf("please enter the times number(0 is stop):n");     while(1)              /输入参数         scanf("%d", &tmp);         printf("times = %dn", tmp);         /IO控制         ioctl(fd, tmp);         if(tmp <= 0)                      break;                   /关闭设备     close(fd);     return 0;8. 在开发主机上交叉编译测试应用程序,并复制到文件系统的/usr/sbin目录下,然后重新编译文件系统下载到开发板上。 9. 在开发板上运行测试程序。可以看到根据你输入参数的大小,蜂鸣器也会发生不同频率的叫声,输入0蜂鸣器停止鸣叫。为了您的安全,请只打开来源可靠的网址 打开网站    取消来自: 转:基于EasyARM2103的交流蜂鸣器音乐播放设计133331457 1.1 蜂鸣器简介蜂鸣器是一种一体化结构的电子讯响器,采用直流或者交流供电,广泛应用于计算机、打印机、复印机、报警器、电子玩具、汽车电子设备、电话机、定时器等电子产品中的发声器件。蜂鸣器在电路中用字母“H”或“HA”(旧标准用“FM”、“LB”、“JD”等)表示。蜂鸣器的外观如下图所示。图1.1 蜂鸣器根据发声材料、结构和驱动方式的不同,蜂鸣器可以分为压电式、电磁式等,如表1.1所示。1.1.1 驱动电路分析与参数计算根据上述的几个蜂鸣器驱动电路分析发现,蜂鸣器驱动电路无一例外都包含以下几个部分:一个三极管、一个蜂鸣器、一个续流二极管和一个电源滤波电容。驱动电路如图1.2所示。图1.2 蜂鸣器驱动电路蜂鸣器驱动电路分析如下:1蜂鸣器发声元件,在其两端施加直流电压(有源蜂鸣器)或者方波(无源蜂鸣器)就可以发声,其主要参数是外形尺寸、发声方向、工作电压、工作频率、工作电流、驱动方式(直流/方波)等。这些都可以根据需要来选择。2续流二极管蜂鸣器本质上是一个感性元件,其电流不能瞬变,因此必须有一个续流二极管提供续流。否则,在蜂鸣器两端会产生几十伏的尖峰电压,可能损坏驱动三极管,并干扰整个电路系统的其它部分。3滤波电容滤波电容1的作用是滤波,滤除蜂鸣器电流对其它部分的影响,也可改善电源的交流阻抗,如果可能,最好是再并联一个220uF的电解电容。4三极管三极管Q1起开关作用,其基极的高电平使三极管饱和导通,使蜂鸣器发声;而基极低电平则使三极管关闭,蜂鸣器停止发声。1.1.2 驱动程序设计1 直流蜂鸣器驱动程序直流蜂鸣器的驱动是非常简单的,只要在其两端施加额定工作电压,蜂鸣器就发声。以NPN三极管驱动电路为例,只要在三极管的基极接入高电平,蜂鸣器就能发声。例如:蜂鸣器每秒钟发声100mS时,三极管基极的驱动波形如图1.3所示。图1.3 NPN管驱动直流蜂鸣器2 交流蜂鸣器驱动程序交流蜂鸣器的驱动相对复杂一点,要在蜂鸣器两端施加额定电压的方波。蜂鸣器的工作频率范围通常是很窄的,这意味着一个蜂鸣器通常只能工作在其额定频率才会有良好的发声效果(包括声压和音色等)。有些蜂鸣器的工作频率范围是比较宽的,这样就可以通过调整驱动方波的频率而使蜂鸣器发出音乐,演奏歌曲。例如:蜂鸣器每秒钟发声100mS时,三极管基极的驱动波形如下图1.4所示。图1.4 驱动交流蜂鸣器1.2 设计原理本实例采用LPC2103的定时器1产生PWM脉冲控制8050导通与闭合,使交流蜂鸣器两端产生方波信号,驱动蜂鸣器发声。三个LED分别显示高、中和低音的状态。电路原理如图1.5所示。图1.5 原理图1.3 电路制作1.3.1 元器件选择本文电路制作中需要用到的元件如表 1.3所列。表 1.3 元件列表1.3.2 焊接按照原理图连接电路,要注意蜂鸣器、三极管、二极管和LED的管脚极性。硬件电路焊接完成后,实物如图1.6所示。图1.6 实物图系统实物如图1.7所示。图1.7 整体实物图1.4 程序设计本实例通过LPC2103的定时器1产生PWM脉冲来控制交流蜂鸣器发声。根据不同的音频,LPC2103产生不同频率的PWM脉冲,使交流蜂鸣器发出不同频率的声音。并通过三个LED分别显示高、中和低音的状态。以下为部分程序,详细程序参见程序源码。蜂鸣器初始化程序:设置蜂鸣器控制引脚为GPIO输出低电平。蜂鸣器不发声。见程序清单1.1。程序清单1.1 蜂鸣器初始化程序蜂鸣器指定频率发声程序:根据指定频率设定定时器1的PWM的输出周期,控制蜂鸣器发出指定频率的声音。见程序清单1.2。程序清单1.2 蜂鸣器指定频率发声程序蜂鸣器停止发声程序:复位定时器1,设置蜂鸣器控制引脚为GPIO输出低电平,蜂鸣器停止发声。见程序清单1.3。程序清单1.3 蜂鸣器停止发声程序LED初始化程序:分别设置LED1、LED2和LED3的控制引脚为GPIO输出,并熄灭。见程序清单1.4。程序清单1.4 LED初始化程序点亮指定LED程序:根据入口参数点亮指定的LED,见程序清单1.5。程序清单1.5 点亮指定LED程序熄灭指定LED程序:根据入口参数熄灭指定的LED。见程序清单1.6。程序清单1.6 熄灭指定LED程序为了您的安全,请只打开来源可靠的网址 打开网站    取消来自: view plaincopy to clipboardprint?·········10········20········30········40········50········60········70········80········90········100·······110·······120·······130·······140·······150/* Copyright(c) 2009-2010,Newkoom Net Tech.Co,.Ltd 模块名称(Filename): beep_s3c2410.c 项目名称(Projectname): RPM(Remote Power Manager System) 版本号(Version): 1.0.0 创建日期(Date): 2009-11-22 作者(Author): ZMF(Zheng meifu) 功能描述(Description): buzzer(beep) driver for linux2.6.14.1 其他说明(Others): 修改记录(History): 调试成功:2009-11-23 2009-12-1:之前只能在定时任务结束后才释放锁,今天改为 设置完ioctl后立即释放,以便连续发声。 */ #include <linux/module.h> #include <linux/kernel.h> #include <linux/fs.h> #include <linux/init.h> #include <linux/delay.h> #include <linux/poll.h> #include <asm/irq.h> #include <asm/io.h> #include <linux/interrupt.h> #include <asm/uaccess.h> #include <asm/arch/regs-gpio.h> #include <asm/arch/hardware.h> #include <asm/arch/regs-timer.h> #include <asm/arch/regs-irq.h> #include <asm/mach/time.h> #include <asm/hardware/clock.h> #include <linux/cdev.h> #include <linux/device.h> #include <linux/miscdevice.h> #define BEEPDEV_NAME "beep" /*设备名 beep*/ #define PWM_IOCTL_SET_FREQ 1 /*定义宏常量,用于后面的ioctl中的switch case*/ #define PWM_IOCTL_STOP 2 #define SET_RIGHT_ACTION_BEEP 3 / 此处宏数字不能改,和以下beep_const序号相关 #define SET_ERROR_ACTION_BEEP 4 / 同上 #define SET_KEY_PRESS_BEEP 5 / 同上 #define BEON (1<<(sizeof(int)*8-1) #define BEOF 0 #define PRESET_FREQ 1000 #define KEY_DELAYMS(X) (HZ/(1000/(X) static struct semaphore lock; /*定义信号量 lock*/ static struct semaphore ioctl_lock; /* freq: pclk/50/16/65536 pclk/50/16 * if pclk = 50MHz, freq is 1Hz to 62500Hz * human ear : 20Hz 20000Hz */ const int beep_const38= 500|BEON,100|BEOF,0,0,0,0,0,0, / right 100|BEON,50|BEOF,100|BEON,50|BEOF,100|BEON,50|BEOF,0,0, / error 100|BEON,50|BEOF,0,0,0,0,0,0, / key ; struct timer_list beep_timer; static int beep_step; static void PWM_Set_Freq(unsigned long freq); static void PWM_Stop(void); static void beep_timer_handler(unsigned long data) int onofftime=beep_constdatabeep_step+; if(onofftime !=0) beep_timer.data = data; mod_timer(&beep_timer, jiffies+ KEY_DELAYMS(onofftime&(BEON); if(onofftime&BEON) PWM_Set_Freq(PRESET_FREQ); else PWM_Stop(); else PWM_Stop(); del_timer(&beep_timer); /up(&ioctl_lock); static void set_beep_type(int type) int tmp_time= beep_consttype-30&(BEON); del_timer(&beep_timer); init_timer(&beep_timer); beep_timer.expires = jiffies + KEY_DELAYMS(tmp_time); beep_timer.function = beep_timer_handler; beep_timer.data = type-3; beep_step=1; add_timer(&beep_timer); PWM_Set_Freq(PRESET_FREQ); static void PWM_Set_Freq( unsigned long freq ) /*设置pwm的频率,配置各个寄存器*/ unsigned long tcon, tcnt, tcfg1, tcfg0,pclk; struct clk *clk_p; /*set GPB0 as tout0, pwm output 设置GPB0为tout0,pwm输出*/ s3c2410_gpio_cfgpin(S3C2410_GPB0, S3C2410_GPB0_TOUT0); tcon = _raw_readl(S3C2410_TCON); /*读取寄存器TCON到tcon*/ tcfg1 = _raw_readl(S3C2410_TCFG1); /*读取寄存器TCFG1到tcfg1*/ tcfg0 = _raw_readl(S3C2410_TCFG0); /*读取寄存器TCFG0到tcfg0*/ /prescaler = 50 tcfg0 &= S3C2410_TCFG_PRESCALER0_MASK; /* S3C2410_TCFG_PRESCALER0_MASK定时器0和*/ /* 1的预分频值的掩码,TCFG08*/ tcfg0 |= (50 - 1); /* 预分频为50 */ /mux = 1/16 tcfg1 &= S3C2410_TCFG1_MUX0_MASK; /*S3C2410_TCFG1_MUX0_MASK定时器0分割值的掩*/

    注意事项

    本文(蜂鸣器LINUX.doc)为本站会员(sccc)主动上传,三一办公仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知三一办公(点击联系客服),我们立即给予删除!

    温馨提示:如果因为网速或其他原因下载失败请重新下载,重复下载不扣分。




    备案号:宁ICP备20000045号-2

    经营许可证:宁B2-20210002

    宁公网安备 64010402000987号

    三一办公
    收起
    展开