Tiny6410声卡驱动——录音与回放
Tiny6410声卡驱动——录音与回放
在Linux下,音频设备程序的实现与文件系统的操作密切相关。Linux将各种设备以文件的形式给出统一的接口,这样的设计使得对设备的编程与对文件的操作基本相同,对Linux内核的系统调用也基本一致,从而简化了设备编程。
如何对各种音频设备进行操作是在Linux上进行音频编程的关键,通过内核提供的一组系统调用,应用程序能够访问声卡驱动程序提供的各种音频设备接口,这是在Linux下进行音频编程最简单也是最直接的方法。
声卡不是Linux控制台的一部分,它是一个特殊的设备。声卡主要提供3个重要的特征:
- 数字取样输入/输出
- 频率调制输出
- MIDI接口
这3个特征都有它们自己的设备驱动程序接口
- 数字取样的接口是/dev/dsp
- 频率调制的接口/dev/sequencer
- MIDI接口是/dev/midi
混音设备(如音量、平衡或者贝斯)可以通过/dev/mixer接口来控制。
为了满足兼容性的需要,还提供了一个/dev/audio设备,该设备可用于读SUN_law的声音数据,但它是映射到数字取样设备的。
1、音频编程接口
程序员可以使用ioctl()来操作这些设备,ioctl()请求是在linux/soundcard.h中定义的,它们以SNDCTL_开头。
- 首先使用open系统调用建立起与硬件间的联系,此时返回的文件描述符将作为随后操作的标识;
- 接着使用read系统调用从设备接收数据,或者使用write系统调用向设备写入数据,而其他所有不符合读/写这一基本模式的操作都可以由ioctl系统调用来完成;
- 最后,使用close系统调用告诉Linux内核不会再对该设备做进一步的处理。
1.1.open系统调用
系统调用open可以获得对声卡的访问权,同时还能为随后的系统调用做好准备,其函数原型如下所示:
int open(const char *pathname, int flags, int mode);
- 参数pathname是将要被打开的设备文件的名称,对于声卡来讲一般是/dev/dsp。
- 参数flags用来指明应该以什么方式打开设备文件,它可以是O_RDONLY、O_WRONLY或者O_RDWR,分别表示以只读、只写或者读写的方式打开设备文件;
- 参数mode通常是可选的,它只有在指定的设备文件不存在时才会用到,指明新创建的文件应该具有怎样的权限。如果open系统调用能够成功完成,它将返回一个正整数作为文件标志符,在随后的系统调用中需要用到该标志符。
如果open系统调用失败,它将返回-1,同时还会设置全局变量errno,指明是什么原因导致了错误的发生。
1.2.read系统调用
read用来从声卡读取数据,其函数原型如下所示:
int read(int fd, char *buf, size_t count);
- 参数fd是设备文件的标志符,它是通过之前的open系统调用获得的;
- 参数buf是指向缓冲区的字符指针,它用来保存从声卡获得的数据;
- 参数count则用来限定从声卡获得的最大字节数。
如果read系统调用成功完成,它将返回从声卡实际读取的字节数,通常情况会比count的值小一些;如果read系统调用失败,它将返回-1,同时还会设置全局变量errno,来指明是什么原因导致了错误的发生。
1.3.write系统调用
write用来向声卡写入数据,其函数原型如下所示: size_t write(int fd, const char *buf, size_t count); 系统调用write和系统调用read在很大程度是类似的,差别只在于write是向声卡写入数据,而read则是从声卡读入数据。- 参数fd同样是设备文件的标志符,它也是通过之前的open系统调用获得的;
- 参数buf是指向缓冲区的字符指针,它保存着即将向声卡写入的数据;
- 参数count则用来限定向声卡写入的最大字节数。
1.4.ioctl系统调用
系统调用ioctl可以对声卡进行控制,凡是对设备文件的操作不符合读/写基本模式的,都是通过ioctl来完成的,它可以影响设备的行为,或者返回设备的状态,其函数原型如下所示: int ioctl(int fd, int request, ...);- 参数fd是设备文件的标志符,它是在设备打开时获得的,如果设备比较复杂,那么对它的控制请求相应地也会有很多种,
- 参数request的目的就是用来区分不同的控制请求;
1.5.close系统调用
当应用程序使用完声卡之后,需要用close系统调用将其关闭,以便及时释放占用的硬件资源,其函数原型如下所示: int close(int fd);- 参数fd是设备文件的标志符,它是在设备打开时获得的。
2、音频设备文件
- /dev/sndstat
- /dev/dsp
- /dev/audio
- /dev/mixer
- /dev/sequencer
更多详情见请继续阅读下一页的精彩内容:
Tiny6410 简单的交叉编译helloworld
基于Tiny6410的LED驱动程序
写驱动时交叉编译之makefile编写模板(Tiny6410)
Tiny6410开发板上Linux系统的安装
|
评论暂时关闭