第8章 让开发板发出声音,蜂鸣器驱动

8让开发板发出声音,蜂鸣器驱动

心得体会

在目录下创建一个Makefile文件

先运行make clean命令清楚到编译生成的一些工程文件,执行make命令,重新编译驱动程序。将编译生成的buzzer.ko内核镜像文件拷贝出来,adb push buzzer.ko /fpga/moudles

然后插入内核镜像文件到系统中,insmod buzzer.ko,并且装载设备驱动程序,mknod  /dev/buzzer c 248 0

现在就可以在库层直接编写C/C++文件来调用这个驱动程序,这个可以在ubuntu中安装NDK编译环境,新建buzzer文件,编译生成一个库文件,那样就可以直接在应用层使用这个库提供的JNI方法,那样调用会显得更加的简单,当然这个调用方式google并不提倡,我在这里只是想展示这种调用方式而已

构建一个jni工程,新建一个buzzer.c的源文件

进行NDK编译,生成libbuzzer.so,这个库就可以直接在应用层进行调用

  1. #include <reg52.h>
  2. sbit BUZZ = P1^6; //蜂鸣器控制引脚
  3. unsigned char T0RH = 0; //T0 重载值的高字节
  4. unsigned char T0RL = 0; //T0 重载值的低字节
  5. void OpenBuzz(unsigned int frequ);
  6. void StopBuzz();
  7. void main(){
  8. unsigned int i;
  9. TMOD = 0x01; //配置 T0 工作在模式 1,但先不启动
  10. EA = 1;
  11. while (1){ //使能全局中断
  12. OpenBuzz(4000); //以 4KHz 的频率启动蜂鸣器
  13. for (i=0; i<40000; i++);
  14. StopBuzz(); //停止蜂鸣器
  15. for (i=0; i<40000; i++);
  16. OpenBuzz(1000); //以 1KHz 的频率启动蜂鸣器
  17. for (i=0; i<40000; i++);
  18. StopBuzz(); //停止蜂鸣器
  19. for (i=0; i<40000; i++);
  20. }
  21. }
  22. /* 蜂鸣器启动函数,frequ-工作频率 */
  23. void OpenBuzz(unsigned int frequ){
  24. unsigned int reload;//计算所需的定时器重载值
  25. reload = 65536 - (11059200/12)/(frequ*2); //由给定频率计算定时器重载值
  26. T0RH = (unsigned char)(reload >> 8); //16 位重载值分解为高低两个字节
  27. T0RL = (unsigned char)reload;
  28. TH0 = 0xFF; //设定一个接近溢出的初值,以使定时器马上投入工作
  29. TL0 = 0xFE;
  30. ET0 = 1; //使能 T0 中断
  31. TR0 = 1; //启动 T0
  32. }
  33. /* 蜂鸣器停止函数 */
  34. void StopBuzz(){
  35. ET0 = 0; //禁用 T0 中断
  36. TR0 = 0; //停止 T0
  37. }
  38. /* T0 中断服务函数,用于控制蜂鸣器发声 */
  39. void InterruptTimer0() interrupt 1{
  40. TH0 = T0RH; //重新加载重载值
  41. TL0 = T0RL;
  42. BUZZ = ~BUZZ; //反转蜂鸣器控制电平
  43. }
时间: 2024-10-14 03:49:58

第8章 让开发板发出声音,蜂鸣器驱动的相关文章

第8章 让开发板发出声音,蜂鸣器驱动 心得体会

第8章让开发板发出声音,蜂鸣器驱动 心得体会 通过学习Android深度探索(卷1)HAL与驱动开发的第8章 让开发板发出声音,蜂鸣器驱动,我加深对驱动的认识.以下主要是我对本节实验和参考在Linux驱动开发中使用PWM控制蜂鸣器中的一些见解. 先编写一个简单的蜂鸣器驱动程序,根据开发板上的硬件IO接口和Android驱动规范,在kernel中的driver目录中新建一个Buzzer文件,新建一个buzzer.c的源文 在目录下创建一个Makefile文件 先运行make clean命令清楚到编

第8章:让开发板发出声音:蜂鸣器

一.Linux驱动的代码重用 Linux 驱动的代码重用有很多种方法.可以采用标准 C 程序的方式.将要重用的代码放在其他的文件(在头文件中声明)中.如果要使用某些功能, include 相应的头文件即可(这种方式称为静态重用).也可以使用另外一种动态重用的方式,也就是一个 Linux 驱动可以使用另外一个Linux驱动中的资源(函数.变量.宏等).本节将详细介绍这些代码重用方法. 编译是有多个文件组成的Linux驱动 Linux 驱动的代码不多,将所有的代码都放到一个文件中并没有什么不妥, 但

第八章 让开发板发出声音:蜂鸣器驱动

这一章的主要内容是让开发板发出声音——蜂鸣器驱动,在Linux驱动开发中重点也学习了这一部分内容,同时最后我们小组的考核内容是通过中断控制蜂鸣器发七个音符的音. 这一部分中,要中断控制蜂鸣器,在中断和蜂鸣器代码的基础上进行增加.中断与蜂鸣器的代码不变,在中断的测试代码中,首先要定义七个音符,之后将开发板上的七个键与七个音符相连接,再将七个音符的转换与蜂鸣器相连接,来达到所需的效果. 核心代码: int main() { int fd,fd1; int div; int keyval; fd1 =

让开发板发出声音:蜂鸣器驱动

第八章介绍了一个个实验:蜂鸣器驱动,让开发板发出声音. 将介绍蜂鸣器的实现原理,并实现一个完整的蜂鸣器驱动,通过该驱动可以控制蜂鸣器的打开与关闭. 蜂鸣器也称为PWM脉冲宽度调制,基本原理就是通过脉冲来控制蜂鸣器的打开和停止.蜂鸣器是开发板上带的一个硬件设备,可以通过向寄存器写入特定的值来控制蜂鸣器发出的声音.本节介绍了蜂鸣器的实现原理,并实现一个完整的蜂鸣器驱动,可以打开和关闭.PWM驱动的实现方式不同于LED驱动,PWM驱动由多个文件组成,这也是大多数Linux驱动的标准实现方式. Linu

让开发板发出声音

第八章介绍了第二个实验:蜂鸣器驱动,使开发板发出声音将介绍蜂鸣器的实现原理,并实现一个完整的蜂呜器驱动,通过该驱动可以控制蜂鸣器的打开与关闭. 蜂鸣器也称为PWM脉冲宽度调制,基本原理就是通过脉冲来控制蜂鸣器的打开和停止.蜂鸣 器是开发板上带的一个硬件设备,可以通过向寄存器写入特定的值来控制蜂鸣器发出的声音.本节介绍了蜂鸣器的实现原理,并实现一个完整的蜂鸣器驱动,可以打 开和关闭.PWM驱动的实现方式不同于LED驱动,PWM驱动由多个文件组成,这也是大多数Linux驱动的标准实现方式. Linu

第八章 让开发板发出声音:蜂鸣器驱动 心得笔记

蜂鸣器也称为PWM脉冲宽度调制,基本原理就是通过脉冲来控制蜂鸣器的打开和停止.蜂鸣器是开发板上带的一个硬件设备,可以通过向寄存器写入特定的值来控制蜂鸣器发出的声音.本节介绍了蜂鸣器的实现原理,并实现一个完整的蜂鸣器驱动,可以打 开和关闭.PWM驱动的实现方式不同于LED驱动,PWM驱动由多个文件组成,这也是大多数Linux驱动的标准实现方式. Linux驱动的代码重用有很多种方法.分为静态重用和动态重用,静态重用是代码级的重用,就是将需要重用的代码和使用这些代码的文档放在一起编 译,最终生成一个

让开发板发出声音: 蜂鸣器驱动 读书笔记

蜂鸣器(buzzer)与 LED 类似,也是 S3C64l0 开发板上自带的一个简单的硬件.如果打开蜂鸣器,开发板会发出类似蜂鸣的尖叫声,关闭蜂鸣器则会停止尖叫声. 这一章将介绍如何通过相应的寄 存器来控制蜂鸣器的打开和关闭, 并且在实现蜂鸣器驱动时,将打开和关闭蜂鸣器的函数放到了另 外的 C源代码文件中. 从 Makefile 文件的内容可以看出,编译器 首先将pwm.c和 pwm_fun.c文件编译成 pw肌0 和 pwm_fun.o,然后再将这两个飞.文件链接成 pwm_命iver.o,最

第八章:让开发板发出声音: 蜂鸣器驱动

蜂鸣器是 S3C6410 开发板上带的一个硬件设备.可以通过向寄存器写入特定的值来控制蜂鸣器 发出尖叫声.本章实现一个完整的蜂呜器驱动(可以打开和关闭蜂鸣器)时驱动的实现方式不同于 LED PWM 驱动将由多个文件组成.这也是大多 inux 驱动的标准实现方式 也就是说 个复杂的驱动不太可能将所有的代码都放在 个文件中.最好将相关的代码放在相应的文件中.在编译 Linux 驱动时将这些文件进行联合编译.将Linux 驱动分成多个文件的方式.这些文件中的数据结构.函数的代码也可以被多个不同的驱动使

让开发板发出声音: 蜂鸣器驱动

蜂鸣器是 S3C6410 开发板上带的一个硬件设备.可以通过向寄存器写入特定的值来控制蜂鸣器 发出尖叫声. 这章将介绍蜂鸣器的实现原犁,并实现一个完整的蜂呜器驱动(可以打开和关闭蜂鸣 器). PWm时驱动的实现方式不同于 LED 驱动, PWM 驱动将由多个文件组成.这也是大多数 Linux 驱动的标准实现方式. 也就是说--个复杂的驱动不太可能将所有的代码都放在…个文件中.最好将 相关的代码放在相应的文件中.在编译 Linux 驱动时将这些文件进行联合编译.本节将介绍把 Linux 驱动分成多