① 如何安装alsa-lib-devel-1.1.3-3.el7.x86
好了言归正转。 1.下载驱动你可以到这里下载ALSA的驱动: 你需要下载以下几个包: alsa-driver-1.0.10.tar.bz2 alsa-lib-1.0.10.tar.bz2 alsa-utils-1.0.10.tar.bz2 2.分别解压: #tar jxvf alsa-driver-1.0.10.tar.bz2 #tar jxvf alsa-lib-1.0.10.tar.bz2 #tar jxvf alsa-utils-1.0.10.tar.bz2 3.先进入alsa-driver,然后是,alsa-lib,最后是alsa-utils文件夹进行编译: #./configure#make#make install 最后一步再次进入alsa-driver文件夹运行再编译请输入: #./snddevices 等几分钟后编译完成,到此驱动总算安装完了,但是如果你马上重启动的话你的声卡还是不能工作,why?很简单你还得修改你的模块文件/etc/moles.conf #vi /etc/moles.conf并在最后加入以入几行:
② 如何安装ALSA驱动
1.下载驱动你可以到这里下载ALSA的驱动:你需要下载以下几个包:alsa-driver-1.0.10.tar.bz2alsa-lib-1.0.10.tar.bz2alsa-utils-1.0.10.tar.bz22.分别解压:#tar jxvf alsa-driver-1.0.10.tar.bz2#tar jxvf alsa-lib-1.0.10.tar.bz2#tar jxvf alsa-utils-1.0.10.tar.bz23.先进入alsa-driver,然后是,alsa-lib,最后是alsa-utils文件夹进行编译:#./configure#make#make install最后一步再次进入alsa-driver文件夹运行再编译请输入:#./snddevices等几分钟后编译完成,到此驱动总算安装完了,但是如果你马上重启动的话你的声卡还是不能工作,why?很简单你还得修改你的模块文件/etc/moles.conf#vi /etc/moles.conf并在最后加入以入几行:#====== added those lines =============alias char-major-116 sndoptions snd major=116 cards_limit=1#— Intel 8×0 and SiS 7012 ———-alias snd-card-0 snd-intel8x0options snd-intel8x0 index=0 id="ICH"alias char-major-14 soundcorealias sound-slot-0 snd-card-0alias sound-service-0-0 snd-mixer-ossalias sound-service-0-1 snd-seq-ossalias sound-service-0-3 snd-pcm-ossalias sound-service-0-8 snd-seq-ossalias sound-service-0-12 snd-pcm-oss#====然后保存退出重启。这就完成了,还不发声 ?不要紧我也遇到,打开音量控制器,你会发现所有的音量都是0, 接下来就不用我教了吧,调好音量后,先不要关控制器,直接测试声卡。能听到声音吗?还没有?那就把电脑砸了。 二、安装ALSA声卡驱动程序 1.到http://www.heihei.com/下载下面四个软件包: alsa-driver-0.5.9.tar.bz2 alsaconf-0.4.3b.tar.gz alsa-lib-0.5.9.tar.bz2 alsa-utils-0.5.9.tar.bz2 2.先安装alsa-driver-0.5.9.tar.bz2这个文件: (1)cp alsa-driver-0.5.9.tar.bz2 /tmp 将alsa-driver-0.5.9.tar.bz2 拷到/tmp目录下。 (2)bunzip2 alsa-driver-0.5.9.tar.bz2 解压缩这个文件,会在/tmp目录下生成一个文件叫做alsa-driver-0.5.9.tar。 (3)tar xvf alsa-driver-0.5.9.tar 将会在/tmp目录下产生一个子目录叫做alsa-driver-0.5.9,alsa的所有文件就存放在这个目录下。 (4)cd alsa-driver-0.5.9 进入alsa的驱动程序所存放的目录,准备配置和编译它。这时你可以看一下目录下的INSTALL文件来了解安装的步骤和注意事项。 (5)依次运行下面三个命令: ./configure make install ./snddevices 3.编辑/etc/ moles.conf文件 这个文件的配置虽然比较麻烦,但用alsaconf-0.4.3b.tar.gz也可以配好它,运行命令: (1)cp alsaconf-0.4.3b.tar.gz /tmp 将alsaconf-0.4.3b.tar.gz 拷到/tmp目录下。 (2)tar zxvf alsaconf-0.4.3b.tar.gz 解压缩这个文件,会在/tmp目录下生成一个子目录叫做alsaconf-0.4.3b。 (3)./alsaconf 会出现一个窗口叫你选择声卡,像SoundBlaster及ESS1868、S3_SonicVibes_PCI、Ensoniq_AudioPCI_ES1370 1371等,很多目前的kernel还不支持的声卡它都可以支持了。 选好声卡之后系统会问你一些问题,都回答OK,然后会回到第一个画面问你要不要继续设第二张声卡,选“No_more_cards”退出即可。完成这个步骤之后,/etc/moles.conf这个文件就基本上自动配置好了,重新启动电脑后声卡就可以发声了。 4.如果还不行,那么你就还需要安装alsa-lib和alsa-utils,安装方法和alsa-driver一样,注意要先安装alsa-lib,再安装alsa-utils。将文件拷到/tmp目录,解压缩,然后运行命令make和make install,具体请参照上面alsa-driver的安装步骤。 安装后到alsa-utils(解开alsa-utils-0.5.9.tar.bz2会产生该目录)目录下的alsamixer子目录执行 ./alsamixer 好了,你的声卡应该能发声了。
③ 如何给ubuntu装alsa驱动
第一步,删除原来安装alsa或者安装错的alsa sudo apt-get –purge remove linux-sound-base alsa-base alsa-utils。注意:这一步很重要,在删除alsa-utils的时候会同时删除gdm和ubuntu-desktop,意味着将失去桌面,所以得重新安装桌面 sudo apt-get in。第二步,下载最新的alsa驱动下载下面这三个文件alsa-driver-1.0.16.tar.bz2alsa-lib-1.0.16.tar.bz2alsa-utils-1.0.16.tar.bz2安装步骤:1、升级之前,必须现要确定当前系统的alsa版本,命令如下:cat /proc/asound/versionAdvanced Linux Sound Architecture Driver Version 1.0.18rc3.2、为确保在升级Alsa-utils时候不会出现问题,先要用下面命令停止它:sudo /etc/init.d/alsa-utils stop3、安装驱动前必须要先安装编译内核必须的工具组件,如下:sudo apt-get -y install build-essential ncurses-dev gettext xmltosudo apt-get -y install linux-headers-`uname -r` libncursesw5-dev4、接着进入到个人的根目录下下载这三个包:alsa-driver、alsa-lib 和 alsa-utils:cd ~rm -rf ~/alsa*wget ftp://ftp.alsa-project.org/pub/driver/alsa-driver-1.0.21.tar.bz2wget ftp://ftp.alsa-project.org/pub/lib/alsa-lib-1.0.21a.tar.bz2wget ftp://ftp.alsa-project.org/pub/utils/alsa-utils-1.0.21.tar.bz25、之后需要创建编译它们所需要的目录。然后,移动下载的这三个文件到刚创建的目录中:sudo rm -rf /usr/src/alsasudo mkdir -p /usr/src/alsacd /usr/src/alsasudo cp ~/alsa* .6、解压这三个文件:sudo tar xjf alsa-driver*sudo tar xjf alsa-lib*sudo tar xjf alsa-utils*7、开始编译安装 alsa-driver:cd alsa-driver*sudo ./configuresudo makesudo make install8、编译安装 alsa-lib:cd ../alsa-lib*sudo ./configuresudo makesudo make install9、编译安装 alsa-utils:cd ../alsa-utils*sudo ./configuresudo makesudo make install10、如果运行最后一次 “sudo ./configure” 遇到下面提示错误:checking form.h presence… yeschecking for form.h… yeschecking for new_panel in -lpanelw… noconfigure: error: panelw library not found11、需要添加下面文件映射链接(没有出错的跳过这步)并重新运行最后一个 “sudo ./configure” 命令:sudo ln -s libpanelw.so.5 /usr/lib/libpanelw.sosudo ln -s libformw.so.5 /usr/lib/libformw.sosudo ln -s libmenuw.so.5 /usr/lib/libmenuw.sosudo ln -s libncursesw.so.5 /lib/libncursesw.so12、然后,安装下载的这三个不需要的文件:rm -f ~/alsa-driver*rm -f ~/alsa-lib*rm -f ~/alsa-utils*13、最后,只需要重新启动电脑,Alsa应该已经是 最新版本!可以用下面命令确定你系统当前的 alsa 版本:cat /proc/asound/versionAdvanced Linux Sound Architecture Driver Version 1.0.21.Compiled on Aug 31 2009 for kernel 2.6.28-15-generic (SMP).14、确定所有都配置好以后,退出这个命令对话:sudo alsaconf
④ 请教Linux下ALSA声道切换
解各参数含义及些基本概念本度(sample):本记录音频数据基本单位见8位16位通道数(channel):该参数1表示单声道2则立体声桢(frame):桢记录声音单元其度本度与通道数乘积采率(rate):每秒钟采数该数针桢言周期(period):音频设备处理所需要桢数于音频设备数据访问及音频数据存储都单位交错模式(interleaved):种音频数据记录式交错模式数据连续桢形式存放即首先记录完桢1左声道本右声道本(假设立体声格式)再始桢2记录非交错模式首先记录周期内所桢左声道本再记录右声道本数据连续通道式存储数情况我需要使用交错模式period(周期):硬件断间间隔间表示输入延声卡接口指针指示声卡硬件缓存区前读写位置要接口运行指针循环指向缓存区某位置frame size = sizeof(one sample) * nChannelsalsa配置缓存(buffer)周期(size)runtime帧(frames)形式存储period_bytes = frames_to_bytes(runtime, runtime->period_size);bytes_to_frames()The period and buffer sizes are not dependent on the sample format because they are measured in frames; you do not need to change them.ALSA声音编程介绍ALSA表示高级Linux声音体系结构(Advanced Linux Sound Architecture)由系列内核驱应用程序编译接口(API)及支持Linux声音实用程序组篇文章我简单介绍ALSA项目基本框架及软件组主要集介绍PCM接口编程包括您自实践程序示例您使用ALSA原能新并唯用声音API您想完低级声音操作便能够化控制声音并化提高性能或者您使用其声音API没特性ALSA选择您已经写音频程序能想要ALSA声卡驱添加本支持您音频兴趣想播放音频文件高级API更选择比SDL,OpenAL及些桌面环境提供工具集另外您能ALSA支持Linux环境使用ALSAALSA历史ALSA项目发起起Linux声卡驱(OSS/Free drivers)没积极维护并且落于新声卡技术Jaroslav Kysela早先写声卡驱并由始ALSA项目随便更发者加入发队伍更声卡支持API结构重组Linux内核2.5发程ALSA合并官源码树发布内核2.6ALSA已经内建稳定内核版本并广泛使用数字音频基础声音由变化气压组麦克风转换器转换电形式模/数(ADC)转换器模拟电压转换离散本值声音固定间间隔采采速率称采率本输数/模(DAC)转换器比扩音器转换原模拟信号本位表示本影响声音转换数字信号精确程度素另主要素采率奈奎斯特(Nyquist)理论要离散系统奈奎斯特频率高于采信号高频率或带宽避免混叠现象ALSA基础ALSA由许声卡声卡驱程序组同提供称libasoundAPI库应用程序发者应该使用libasound内核ALSA接口libasound提供高级并且编程便编程接口并且提供设备逻辑命名功能发者甚至需要知道类似设备文件低层接口相反OSS/Free驱内核系统调用级编程要求发者提供设备文件名并且利用ioctrl实现相应功能向兼容ALSA提供内核模块模拟OSS前许OSS基础发应用程序需要任何改ALSA运行另外libaoss库模拟OSS需要内核模块ALSA包含插件功能使用插件扩展新声卡驱包括完全用软件实现虚拟声卡ALSA提供系列基于命令行工具集比混音器(mixer)音频文件播放器(aplay)及控制特定声卡特定属性工具ALSA体系结构ALSA API解几主要接口:1 控制接口:提供管理声卡注册请求用设备通用功能2 PCM接口:管理数字音频放(playback)录音(capture)接口本文续总结重点放接口发数字音频程序用接口3 Raw MIDI接口:支持MIDI(Musical Instrument Digital Interface),标准电乐器些API提供声卡MIDI总线访问原始接口基于MIDI事件工作由程序员负责管理协议及间处理4 定器(Timer)接口:同步音频事件提供声卡间处理硬件访问5 序器(Sequencer)接口6 混音器(Mixer)接口设备命名API库使用逻辑设备名设备文件设备名字真实硬件名字插件名字硬件名字使用hw:i,j格式其i卡号j块声卡设备号第声音设备hw:0,0.别名默认引用第块声音设备并且本文示例真用插件使用另外唯名字比plughw:,表示插件插件提供硬件设备访问提供像采率转换软件特性硬件本身并支持特性声音缓存数据传输每声卡都硬件缓存区保存记录本缓存区足够满声卡产断内核声卡驱使用直接内存(DMA)访问通道本传送内存应用程序缓存区类似于放任何应用程序使用DMA自缓存区数据传送声卡硬件缓存区硬件缓存区环缓存说数据达缓存区末尾重新缓存区起始位置ALSA维护指针指向硬件缓存及应用程序缓存区数据操作前位置内核外部看我应用程序缓存区兴趣所本文讨论应用程序缓存区应用程序缓存区通ALSA库函数调用控制缓存区传输操作能导致接受延迟我称延(latency)解决问题ALSA缓存区拆系列周期(period)(OSS/Free叫片断fragments).ALSAperiod单元传送数据周期(period)存储些帧(frames)每帧包含间点所抓取本于立体声设备帧包含两信道本图1展示解程:缓存区解周期帧本图包含些假定数值图左右信道信息交替存储帧内称交错(interleaved)模式非交错模式信道所本数据存储另外信道数据Over and Under Run声卡数据总连续硬件缓存区应用程序缓存区间传输例外录音例应用程序读取数据够快循环缓存区新数据覆盖种数据丢失称overrun.放例应用程序写入数据缓存区速度够快缓存区"饿死"错误称"underrun"ALSA文档两种情形统称"XRUN"适设计应用程序化XRUN并且恢复典型声音程序使用PCM程序通类似面伪代码:打放或录音接口设置硬件参数(访问模式数据格式信道数采率等等)while 数据要处理:读PCM数据(录音)或 写PCM数据(放)关闭接口我文看些工作代码我建议您Linux系统测试运行些代码查看输并尝试修改推荐代码本文相关所实例清单FTP获取:ftp.ssc.com/pub/lj/listings/issue126/6735.tgzListing 1. Display Some PCM Types and Formats#include asoundlib.h>int main() {int val;printf("ALSA library version: %s/n",SND_LIB_VERSION_STR);printf("/nPCM stream types:/n");for (val = 0; val <= SND_PCM_STREAM_LAST; val++)printf(" %s/n",snd_pcm_stream_name((snd_pcm_stream_t)val));printf("/nPCM access types:/n");for (val = 0; val <= SND_PCM_ACCESS_LAST; val++)printf(" %s/n",snd_pcm_access_name((snd_pcm_access_t)val));printf("/nPCM formats:/n");for (val = 0; val <= SND_PCM_FORMAT_LAST; val++)if (snd_pcm_format_name((snd_pcm_format_t)val)!= NULL)printf(" %s (%s)/n",snd_pcm_format_name((snd_pcm_format_t)val),snd_pcm_format_description((snd_pcm_format_t)val));printf("/nPCM subformats:/n");for (val = 0; val <= SND_PCM_SUBFORMAT_LAST;val++)printf(" %s (%s)/n",snd_pcm_subformat_name((snd_pcm_subformat_t)val),snd_pcm_subformat_description((snd_pcm_subformat_t)val));printf("/nPCM states:/n");for (val = 0; val <= SND_PCM_STATE_LAST; val++)printf(" %s/n",snd_pcm_state_name((snd_pcm_state_t)val));return 0;}清单显示些ALSA使用PCM数据类型参数首先需要做包括文件些文件包含所库函数声明其显示ALSA库版本程序剩部迭代些PCM数据类型流类型始ALSA每迭代值提供符号量名并且提供功能函数显示某特定值描述字符串看ALSA支持许格式我1.0.15版本支持达36种格式程序必须链接alsalib库通编译需要加-lasound选项些alsa库函数使用dlopen函数及浮点操作所您能需要加-ldl,-lm选项面该程序Makefile:CC=gccTARGET=testSRC=$(wildcard *.c)OBJECT= ${SRC:.c=.o}INCLUDES=-I/usr/include/alsaLDFLAGS=-lasoundall:$(TARGET)$(OBJECT):$(SRC)$(CC) -c $(INCLUDES) $<$(TARGET):$(OBJECT)$(CC) -o [email protected] $< $(LDFLAGS).PHONY:cleanclean:@rm -rf $(OBJECT) $(TARGET) *~Listing 2. Opening PCM Device and Setting Parameters/*This example opens the default PCM device, setssome parameters, and then displays the valueof most of the hardware parameters. It does notperform any sound playback or recording.*//* Use the newer ALSA API */#define ALSA_PCM_NEW_HW_PARAMS_API/* All of the ALSA library API is defined* in this header */#include asoundlib.h>int main() {int rc;snd_pcm_t *handle;snd_pcm_hw_params_t *params;unsigned int val, val2;int dir;snd_pcm_uframes_t frames;/* Open PCM device for playback. */rc = snd_pcm_open(&handle, "default",SND_PCM_STREAM_PLAYBACK, 0);if (rc < 0) {fprintf(stderr,"unable to open pcm device: %s/n",snd_strerror(rc));exit(1);}/* Allocate a hardware parameters object. */snd_pcm_hw_params_alloca(?ms);/* Fill it in with default values. */snd_pcm_hw_params_any(handle, params);/* Set the desired hardware parameters. *//* Interleaved mode */snd_pcm_hw_params_set_access(handle, params,SND_PCM_ACCESS_RW_INTERLEAVED);/* Signed 16-bit little-endian format */snd_pcm_hw_params_set_format(handle, params,SND_PCM_FORMAT_S16_LE);/* Two channels (stereo) */snd_pcm_hw_params_set_channels(handle, params, 2);/* 44100 bits/second sampling rate (CD quality) */val = 44100;snd_pcm_hw_params_set_rate_near(handle,params, &val, &dir);/* Write the parameters to the driver */rc = snd_pcm_hw_params(handle, params);if (rc < 0) {fprintf(stderr,"unable to set hw parameters: %s/n",snd_strerror(rc));exit(1);}/* Display information about the PCM interface */printf("PCM handle name = '%s'/n",snd_pcm_name(handle));printf("PCM state = %s/n",snd_pcm_state_name(snd_pcm_state(handle)));snd_pcm_hw_params_get_access(params,(snd_pcm_access_t *) &val);printf("access type = %s/n",snd_pcm_access_name((snd_pcm_access_t)val));snd_pcm_hw_params_get_format(params, &val);printf("format = '%s' (%s)/n",snd_pcm_format_name((snd_pcm_format_t)val),snd_pcm_format_description((snd_pcm_format_t)val));snd_pcm_hw_params_get_subformat(params,(snd_pcm_subformat_t *)&val);printf("subformat = '%s' (%s)/n",snd_pcm_subformat_name((snd_pcm_subformat_t)val),snd_pcm_subformat_description((snd_pcm_subformat_t)val));snd_pcm_hw_params_get_channels(params, &val);printf("channels = %d/n", val);snd_pcm_hw_params_get_rate(params, &val, &dir);printf("rate = %d bps/n", val);snd_pcm_hw_params_get_period_time(params,&val, &dir);printf("period time = %d us/n", val);snd_pcm_hw_params_get_period_size(params,&frames, &dir);printf("period size = %d frames/n", (int)frames);snd_pcm_hw_params_get_buffer_time(params,&val, &dir);printf("buffer time = %d us/n", val);snd_pcm_hw_params_get_buffer_size(params,(snd_pcm_uframes_t *) &val);printf("buffer size = %d frames/n", val);snd_pcm_hw_params_get_periods(params, &val, &dir);printf("periods per buffer = %d frames/n", val);snd_pcm_hw_params_get_rate_numden(params,&val, &val2);printf("exact rate = %d/%d bps/n", val, val2);val = snd_pcm_hw_params_get_sbits(params);printf("significant bits = %d/n", val);snd_pcm_hw_params_get_tick_time(params,&val, &dir);printf("tick time = %d us/n", val);val = snd_pcm_hw_params_is_batch(params);printf("is batch = %d/n", val);val = snd_pcm_hw_params_is_block_transfer(params);printf("is block transfer = %d/n", val);val = snd_pcm_hw_params_is_double(params);printf("is double = %d/n", val);val = snd_pcm_hw_params_is_half_plex(params);printf("is half plex = %d/n", val);val = snd_pcm_hw_params_is_joint_plex(params);printf("is joint plex = %d/n", val);val = snd_pcm_hw_params_can_overrange(params);printf("can overrange = %d/n", val);val = snd_pcm_hw_params_can_mmap_sample_resolution(params);printf("can mmap = %d/n", val);val = snd_pcm_hw_params_can_pause(params);printf("can pause = %d/n", val);val = snd_pcm_hw_params_can_resume(params);printf("can resume = %d/n", val);val = snd_pcm_hw_params_can_sync_start(params);printf("can sync start = %d/n", val);snd_pcm_close(handle);return 0;}
⑤ 如何修改alsa支持192khz的pcm输出
这里了解一下各个参数的含义以及一些基本概念。样本长度(sample):样本是记录音频数据最基本的单位,常见的有8位和16位。通道数(channel):该参数为1表示单声道,2则是立体声。桢(frame):桢记录了一个声音单元,其长度为样本长度与通道数的乘积。采样率(rate):每秒钟采样次数,该次数是针对桢而言。周期(period):音频设备一次处理所需要的桢数,对于音频设备的数据访问以及音频数据的存储,都是以此为单位。交错模式(interleaved):是一种音频数据的记录方式,在交错模式下,数据以连续桢的形式存放,即首先记录完桢1的左声道样本和右声道样本(假设为立体声格式),再开始桢2的记录。而在非交错模式下,首先记录的是一个周期内所有桢的左声道样本,再记录右声道样本,数据是以连续通道的方式存储。不过多数情况下,我们只需要使用交错模式就可以了。英文原文:http://www.linuxjournal.com/article/6735period(周期):硬件中中断间的间隔时间。它表示输入延时。声卡接口中有一个指针来指示声卡硬件缓存区中当前的读写位置。只要接口在运行,这个指针将循环地指向缓存区中的某个位置。frame size = sizeof(one sample) * nChannelsalsa中配置的缓存(buffer)和周期(size)大小在runtime中是以帧(frames)形式存储的。period_bytes = frames_to_bytes(runtime, runtime->period_size);bytes_to_frames()The period and buffer sizes are not dependent on the sample format because they are measured in frames; you do not need to change them.ALSA声音编程介绍ALSA表示高级Linux声音体系结构(Advanced Linux Sound Architecture)。它由一系列内核驱动,应用程序编译接口(API)以及支持Linux下声音的实用程序组成。这篇文章里,我将简单介绍ALSA项目的基本框架以及它的软件组成。主要集中介绍PCM接口编程,包括您可以自动实践的程序示例。您使用ALSA的原因可能就是因为它很新,但它并不是唯一可用的声音API。如果您想完成低级的声音操作,以便能够最大化地控制声音并最大化地提高性能,或者如果您使用其它声音API没有的特性,那么ALSA是很好的选择。如果您已经写了一个音频程序,你可能想要为ALSA声卡驱动添加本地支持。如果您对音频不感兴趣,只是想播放音频文件,那么高级的API将是更好的选择,比如SDL,OpenAL以及那些桌面环境提供的工具集。另外,您只能在有ALSA支持的Linux环境中使用ALSA。ALSA历史ALSA项目发起的起因是Linux下的声卡驱动(OSS/Free drivers)没有得到积极的维护。并且落后于新的声卡技术。Jaroslav Kysela早先写了一个声卡驱动,并由此开始了ALSA项目,随便,更多的开发者加入到开发队伍中,更多的声卡得到支持,API的结构也得到了重组。Linux内核2.5在开发过程中,ALSA被合并到了官方的源码树中。在发布内核2.6后,ALSA已经内建在稳定的内核版本中并将广泛地使用。数字音频基础声音由变化的气压组成。它被麦克风这样的转换器转换成电子形式。模/数(ADC)转换器将模拟电压转换成离散的样本值。声音以固定的时间间隔被采样,采样的速率称为采样率。把样本输出到数/模(DAC)转换器,比如扩音器,最后转换成原来的模拟信号。样本大小以位来表示。样本大小是影响声音被转换成数字信号的精确程度的因素之一。另一个主要的因素是采样率。奈奎斯特(Nyquist)理论中,只要离散系统的奈奎斯特频率高于采样信号的最高频率或带宽,就可以避免混叠现象。ALSA基础ALSA由许多声卡的声卡驱动程序组成,同时它也提供一个称为libasound的API库。应用程序开发者应该使用libasound而不是内核中的ALSA接口。因为libasound提供最高级并且编程方便的编程接口。并且提供一个设备逻辑命名功能,这样开发者甚至不需要知道类似设备文件这样的低层接口。相反,OSS/Free驱动是在内核系统调用级上编程,它要求开发者提供设备文件名并且利用ioctrl来实现相应的功能。为了向后兼容,ALSA提供内核模块来模拟OSS,这样之前的许多在OSS基础上开发的应用程序不需要任何改动就可以在ALSA上运行。另外,libaoss库也可以模拟OSS,而它不需要内核模块。ALSA包含插件功能,使用插件可以扩展新的声卡驱动,包括完全用软件实现的虚拟声卡。ALSA提供一系列基于命令行的工具集,比如混音器(mixer),音频文件播放器(aplay),以及控制特定声卡特定属性的工具。ALSA体系结构ALSA API可以分解成以下几个主要的接口:1 控制接口:提供管理声卡注册和请求可用设备的通用功能2 PCM接口:管理数字音频回放(playback)和录音(capture)的接口。本文后续总结重点放在这个接口上,因为它是开发数字音频程序最常用到的接口。3 Raw MIDI接口:支持MIDI(Musical Instrument Digital Interface),标准的电子乐器。这些API提供对声卡上MIDI总线的访问。这个原始接口基于MIDI事件工作,由程序员负责管理协议以及时间处理。4 定时器(Timer)接口:为同步音频事件提供对声卡上时间处理硬件的访问。5 时序器(Sequencer)接口6 混音器(Mixer)接口设备命名API库使用逻辑设备名而不是设备文件。设备名字可以是真实的硬件名字也可以是插件名字。硬件名字使用hw:i,j这样的格式。其中i是卡号,j是这块声卡上的设备号。第一个声音设备是hw:0,0.这个别名默认引用第一块声音设备并且在本文示例中一真会被用到。插件使用另外的唯一名字。比如plughw:,表示一个插件,这个插件不提供对硬件设备的访问,而是提供像采样率转换这样的软件特性,硬件本身并不支持这样的特性。声音缓存和数据传输每个声卡都有一个硬件缓存区来保存记录下来的样本。当缓存区足够满时,声卡将产生一个中断。内核声卡驱动然后使用直接内存(DMA)访问通道将样本传送到内存中的应用程序缓存区。类似地,对于回放,任何应用程序使用DMA将自己的缓存区数据传送到声卡的硬件缓存区中。这样硬件缓存区是环缓存。也就是说当数据到达缓存区末尾时将重新回到缓存区的起始位置。ALSA维护一个指针来指向硬件缓存以及应用程序缓存区中数据操作的当前位置。从内核外部看,我们只对应用程序的缓存区感兴趣,所以本文只讨论应用程序缓存区。应用程序缓存区的大小可以通过ALSA库函数调用来控制。缓存区可以很大,一次传输操作可能会导致不可接受的延迟,我们把它称为延时(latency)。为了解决这个问题,ALSA将缓存区拆分成一系列周期(period)(OSS/Free中叫片断fragments).ALSA以period为单元来传送数据。一个周期(period)存储一些帧(frames)。每一帧包含时间上一个点所抓取的样本。对于立体声设备,一个帧会包含两个信道上的样本。图1展示了分解过程:一个缓存区分解成周期,然后是帧,然后是样本。图中包含一些假定的数值。图中左右信道信息被交替地存储在一个帧内。这称为交错(interleaved)模式。在非交错模式中,一个信道的所有样本数据存储在另外一个信道的数据之后。Over and Under Run当一个声卡活动时,数据总是连续地在硬件缓存区和应用程序缓存区间传输。但是也有例外。在录音例子中,如果应用程序读取数据不够快,循环缓存区将会被新的数据覆盖。这种数据的丢失被称为overrun.在回放例子中,如果应用程序写入数据到缓存区中的速度不够快,缓存区将会"饿死"。这样的错误被称为"underrun"。在ALSA文档中,有时将这两种情形统称为"XRUN"。适当地设计应用程序可以最小化XRUN并且可以从中恢复过来。一个典型的声音程序使用PCM的程序通常类似下面的伪代码:打开回放或录音接口设置硬件参数(访问模式,数据格式,信道数,采样率,等等)while 有数据要被处理: 读PCM数据(录音) 或 写PCM数据(回放)关闭接口我们将在下文中看到一些可以工作的代码。我建议您在你的Linux系统上测试运行这些代码。查看输出并尝试修改推荐的代码。和本文相关的所有实例清单可以从FTP中获取:ftp.ssc.com/pub/lj/listings/issue126/6735.tgz。Listing 1. Display Some PCM Types and Formats#include <alsa/asoundlib.h>int main() {int val;printf("ALSA library version: %s/n", SND_LIB_VERSION_STR);printf("/nPCM stream types:/n");for (val = 0; val <= SND_PCM_STREAM_LAST; val++) printf(" %s/n", snd_pcm_stream_name((snd_pcm_stream_t)val));printf("/nPCM access types:/n");for (val = 0; val <= SND_PCM_ACCESS_LAST; val++) printf(" %s/n", snd_pcm_access_name((snd_pcm_access_t)val));printf("/nPCM formats:/n");for (val = 0; val <= SND_PCM_FORMAT_LAST; val++) if (snd_pcm_format_name((snd_pcm_format_t)val) != NULL) printf(" %s (%s)/n", snd_pcm_format_name((snd_pcm_format_t)val), snd_pcm_format_description( (snd_pcm_format_t)val));printf("/nPCM subformats:/n");for (val = 0; val <= SND_PCM_SUBFORMAT_LAST; val++) printf(" %s (%s)/n", snd_pcm_subformat_name(( snd_pcm_subformat_t)val), snd_pcm_subformat_description(( snd_pcm_subformat_t)val));printf("/nPCM states:/n");for (val = 0; val <= SND_PCM_STATE_LAST; val++) printf(" %s/n", snd_pcm_state_name((snd_pcm_state_t)val));return 0;}清单一显示了一些ALSA使用的PCM数据类型和参数。首先需要做的是包括头文件。这些头文件包含了所有库函数的声明。其中之一就是显示ALSA库的版本。这个程序剩下的部分的迭代一些PCM数据类型,以流类型开始。ALSA为每次迭代的最后值提供符号常量名,并且提供功能函数以显示某个特定值的描述字符串。你将会看到,ALSA支持许多格式,在我的1.0.15版本里,支持多达36种格式。这个程序必须链接到alsalib库,通过在编译时需要加上-lasound选项。有些alsa库函数使用dlopen函数以及浮点操作,所以您可能还需要加上-ldl,-lm选项。下面是该程序的Makefile:CC=gccTARGET=testSRC=$(wildcard *.c)OBJECT= ${SRC:.c=.o}INCLUDES=-I/usr/include/alsaLDFLAGS=-lasoundall:$(TARGET)$(OBJECT):$(SRC) $(CC) -c $(INCLUDES) $<$(TARGET):$(OBJECT) $(CC) -o [email protected] $< $(LDFLAGS).PHONY:cleanclean: @rm -rf $(OBJECT) $(TARGET) *~Listing 2. Opening PCM Device and Setting Parameters/*This example opens the default PCM device, setssome parameters, and then displays the valueof most of the hardware parameters. It does notperform any sound playback or recording.*//* Use the newer ALSA API */#define ALSA_PCM_NEW_HW_PARAMS_API/* All of the ALSA library API is defined* in this header */#include <alsa/asoundlib.h>int main() {int rc;snd_pcm_t *handle;snd_pcm_hw_params_t *params;unsigned int val, val2;int dir;snd_pcm_uframes_t frames;/* Open PCM device for playback. */rc = snd_pcm_open(&handle, "default", SND_PCM_STREAM_PLAYBACK, 0);if (rc < 0) { fprintf(stderr, "unable to open pcm device: %s/n", snd_strerror(rc)); exit(1);}/* Allocate a hardware parameters object. */snd_pcm_hw_params_alloca(¶ms);/* Fill it in with default values. */snd_pcm_hw_params_any(handle, params);/* Set the desired hardware parameters. *//* Interleaved mode */snd_pcm_hw_params_set_access(handle, params, SND_PCM_ACCESS_RW_INTERLEAVED);/* Signed 16-bit little-endian format */snd_pcm_hw_params_set_format(handle, params, SND_PCM_FORMAT_S16_LE);/* Two channels (stereo) */snd_pcm_hw_params_set_channels(handle, params, 2);/* 44100 bits/second sampling rate (CD quality) */val = 44100;snd_pcm_hw_params_set_rate_near(handle, params, &val, &dir);/* Write the parameters to the driver */rc = snd_pcm_hw_params(handle, params);if (rc < 0) { fprintf(stderr, "unable to set hw parameters: %s/n", snd_strerror(rc)); exit(1);}/* Display information about the PCM interface */printf("PCM handle name = '%s'/n", snd_pcm_name(handle));printf("PCM state = %s/n", snd_pcm_state_name(snd_pcm_state(handle)));snd_pcm_hw_params_get_access(params, (snd_pcm_access_t *) &val);printf("access type = %s/n", snd_pcm_access_name((snd_pcm_access_t)val));snd_pcm_hw_params_get_format(params, &val);printf("format = '%s' (%s)/n", snd_pcm_format_name((snd_pcm_format_t)val), snd_pcm_format_description( (snd_pcm_format_t)val));snd_pcm_hw_params_get_subformat(params, (snd_pcm_subformat_t *)&val);printf("subformat = '%s' (%s)/n", snd_pcm_subformat_name((snd_pcm_subformat_t)val), snd_pcm_subformat_description( (snd_pcm_subformat_t)val));snd_pcm_hw_params_get_channels(params, &val);printf("channels = %d/n", val);snd_pcm_hw_params_get_rate(params, &val, &dir);printf("rate = %d bps/n", val);snd_pcm_hw_params_get_period_time(params, &val, &dir);printf("period time = %d us/n", val);snd_pcm_hw_params_get_period_size(params, &frames, &dir);printf("period size = %d frames/n", (int)frames);snd_pcm_hw_params_get_buffer_time(params, &val, &dir);printf("buffer time = %d us/n", val);snd_pcm_hw_params_get_buffer_size(params, (snd_pcm_uframes_t *) &val);printf("buffer size = %d frames/n", val);snd_pcm_hw_params_get_periods(params, &val, &dir);printf("periods per buffer = %d frames/n", val);snd_pcm_hw_params_get_rate_numden(params, &val, &val2);printf("exact rate = %d/%d bps/n", val, val2);val = snd_pcm_hw_params_get_sbits(params);printf("significant bits = %d/n", val);snd_pcm_hw_params_get_tick_time(params, &val, &dir);printf("tick time = %d us/n", val);val = snd_pcm_hw_params_is_batch(params);printf("is batch = %d/n", val);val = snd_pcm_hw_params_is_block_transfer(params);printf("is block transfer = %d/n", val);val = snd_pcm_hw_params_is_double(params);printf("is double = %d/n", val);val = snd_pcm_hw_params_is_half_plex(params);printf("is half plex = %d/n", val);val = snd_pcm_hw_params_is_joint_plex(params);printf("is joint plex = %d/n", val);val = snd_pcm_hw_params_can_overrange(params);printf("can overrange = %d/n", val);val = snd_pcm_hw_params_can_mmap_sample_resolution(params);printf("can mmap = %d/n", val);val = snd_pcm_hw_params_can_pause(params);printf("can pause = %d/n", val);val = snd_pcm_hw_params_can_resume(params);printf("can resume = %d/n", val);val = snd_pcm_hw_params_can_sync_start(params);printf("can sync start = %d/n", val);snd_pcm_close(handle);return 0;}
⑥ Linux的声卡驱动中ALSA与OSS的区别和简单流程介
在声卡的驱动中一种是OSS(开放声音系统),一种是ALSA(先进Linux声音架构)。OSS是一个商业声卡驱动程序,需要花钱购买。一般我们现在使用的是ALSA的声音架构。Advanced Linux Sound Architecture 的简称为 ALSA,译成中文的意思是 Linux 高级声音体系,ALSA不仅仅是包括对声卡的支持和驱动;它的特征如下:1、对所有音频接口的高效支持,从普通用户的声卡到专业级别多路音频设备;2、声卡驱动完全模块化设计;3、SMP and thread-safe design.4、开发库(alsa-lib) 为程序设计提供了简单、方便,并且拥有有高级的效果和功能;5、支持旧版本的OSS API 结口,能为大多数的OSS应用程序提供兼容;OSS是一个商业性的驱动,OSS有一个简装本的代码已经移入内核和ALSA,其中alsa-oss就是;OSS公司据说目前已经并不存在了;我们没有必要用OSS 公司提供的商业版本;用ALSA和OSS简装版足够;如何查看硬件芯片;在Linux操作系统中,所有的硬件都是以芯片组来区分的,品牌并不是最重要的;硬件最重要的标识是芯片组;所以您在讨论区求助的时候,只说硬件品牌,而不提供芯片组,大家是帮助不了您的,切记;我们查看硬件的芯片组是的命令是 lspci -v 或者是dmesg,由于dmesg输出的信息不太多,不够直观;所以经常用的还是lspci -v ;也可以用lshal 获取;最方便的还是lspci -v;初学者还是用 lspci -v 更好一点;代码:[[email protected] beinan]# lspci -v我们运行lspci -v 后,如果查看声卡芯片组,发会现有类似下面的一段;[[email protected] beinan]# lspci -vMultimedia audio controller: Intel Corporation 82801DB/DBL/DBM (ICH4/ICH4-L/ICH4-M)AC'97 Audio Controller (rev 03)Subsystem: Hewlett-Packard Company: Unknown device 30802.6.11-1.1369_FC4 i686 i686 i386上面的表示的是系统的内核版本,处理器架构等;lsmod 查看已经加载的内核模块;如果一个设备在内核的编译中是以模块方式加载的,主要是通过lsmod 来查看;[[email protected] beinan]# lsmod可能初学Linux的弟兄会问,内核的mole存放在哪里,我们能不能自己来手工加载模块;内核的模块放在 /lib/moles/内核的版本/kernel/ ,比如在Fedora 4.0 中,我们可以看到如下的:[[email protected] beinan]# ls /lib/moles/2.6.11-1.1369_FC4/kernel/arch/crypto/drivers/ fs/lib/ net/ sound/其中,sound 就是声卡模块存放目录,大多数的硬件驱动放在 drivers目录,fs 是文件系统模块的目录;net是与网络有关的存放目录,比如一些网络协议支持的模块、防火墙支持的模块等;arch 是cpu方面 … …如果我们想自己加载模块,就到这些目录中查看相应模块的信息,然后用 modprobe 来加载;[[email protected] beinan]# modinfo snd-intel8x0查看一个模块的信息,我们用 modinfo 来查看,所要查看的模块不要带 .ko 或者.o 之类的;比如查看到类似下面的信息;description: Intel 82801AA,82901AB,i810,i820,i830,i840,i845,MX440; SiS 7012; Ali 5455通过这个我们足可以知道这是Intel 集成声卡,通过lspci -v 得到的声卡信息,感觉他们很相近;所以就能尝试用这个模块来驱动;[[email protected] beinan]# modprobe snd-intel8x0用 modprobe 加载了模块,然后我们通过 lsmod 就能看到了;对于声卡模块是这么加载的,其它设备的驱动模块也是如此。
⑦ ubuntu alsa声音独占问题怎么解决
Ubuntu下应用程序独占音频声道的问题解决【方法一】(针对无声或音频独占)干掉Pulseaudio,只使用Alsa执行以下命令:sudo apt-get install alsa-oss libasound2 libasound2-pluginssudo mv /etc/X11/Xsession.d/70pulseaudio ~/gconftool-2 -s -t bool /apps/gnome_settings_daemon/plugins/sound/active false#注意:gconftool-2 false 整个是一条命令,请输入在同一行。asoundconf unset-pulseaudiosudo update-rc.d -f pulseaudio remove然后执行asoundconf list输出应该是类似这样的情形:Names of available sound cards:Intel(记下你的声卡名,比如这里的Intel)然后执行:asoundconf set-default-card Intel(Intel请替换为你的声卡名)(补充:个别用户会出现真正的声卡名和HDMI两个选项,请注意不要选HDMI(除非你输出到液晶电视))如果想保留登入时的系统提示音,请编辑~/.bashrc文件:gedit ~/.bashrc在文件末尾加上:export SDL_audiodriver=alsa最后,打开系统->首选项->音效,将从上往下数前四个选项都选成 ALSA – Advanced Felix注:经测试,不这么做好像也没问题。至此,屏蔽pulseaudio并设置alsa已经完全解决。【方法二】(针对音频独占)我们让已经在成功运行于PulseAudio的继续使用PulseAudio。只支持ALSA的软件,继续使用ALSA。解决方法:gksu gedit /etc/pulse/default.pa找到:#load-mole mole-alsa-sink 改为load-mole mole-alsa-sink device=dmix找到:load-mole mole-suspend-on-idle改为#load-mole mole-suspend-on-idle(重新logout再login)另外:找到: (解决录音问题,如skype和audacity)load-mole mole-hal-detect改为:#load-mole mole-hal-detect这样,通过使用dmix,PulseAudio就不会霸占整个audio系统。PulseAudio将成为alsa的其中一个Mix Channel。然后,ALSA和PulseAudio便能很好地共存。以后都不再需要什么libflashsupport for pulseaudio了。还有,安装PulseAudio的控制器,好好享受PulseAudio的优势吧。sudo apt-get install padevchooser【方法三】(针对无声)(注:如果点击屏幕右上的小喇叭图标,出现一个错误提示,则可以直接采用此方法)如果以上设置仍然无效,可以尝试下载编译安装新版的alsa(注:安装之前,请确认自己的内核为源里的最新版)首先到/下载最新的alsa-driver,alsa-lib和alsa-utils。假设下载的文件放在~/alsa (/home/用户名/alsa)。首先进行解压:tar jxvf alsa-driver-xxx.tar.bz2tar jxvf alsa-lib-xxx.tar.bz2tar jxvf alsa-utils-xxx.tar.bz2然后分别编译安装cd ./alsa-driver-xxx./configure && makesudo make installcd ../alsa-lib-xxx./configure && makesudo make installcd ../alsa-utils-xxx./configure && makesudo make install重启计算机(注意不是重启X)
⑧ 3. 如何安装 ALSA 音效驱动程式
3.1 您需要什麽一套能动的 Linux 系统(如 Slackware 发行套件), 并有安装开发工具套件(像 gcc, make 等).)支援的音效卡一些Linux 的知识(您总要晓得 "ls", "cd", "tar" 等怎麽用. )root 帐号 如果您有 PnP 卡, 您也需要: isapnptools 软体套件 在驱程式目录中的 INSTALL 档内文提到对有些卡驱动程式内已经能处理 PnP 的支援. 我也从 Jaroslav 那儿得到一样的论点. 如果我将来得到更多资讯, 我会将它们加进本 mini-HOWTO. (原文是 The INSTALL text in the driver directory suggests that for some cards, PnP support is native. I also received a suggestion from Jaroslav about this. When I get further information about this topic I will add it to this mini-HOWTO. }请注意如果您想使用 ALSA 驱动程式, 那麽您不应该先载入任何其它音效驱动程式. 如果您的核心中内含音效驱动程式, 那麽有必要重编译核心. 如果您正在使用旧的 sound.o 模组, 您必须解除它. 如果您使用 kerneld, 这可能就是要您删去 /lib/moles//misc 目录下的 sound.o. 新的 RedHat 系统的音效驱动程式组织方式不太一样, 要载入好几个模组, 这种情况您需要解除全部的模组. 2.2 版核心对音效则采用了新的方式. 您应该要包含音效的支援! 是的, 没有说错, 您在核心中加入了对音效的支援, 但没有包含任何音效卡的部份. 然後重编译及安装核心, 接著编译 ALSA 驱动程式. 3.2 取得驱动程式ALSA 驱动程式可在 ftp://ftp.alsa-project.org/pub 找到, 并且在 ftp://linux.a2000.nl/alsa 有一份镜射(mirror). 要安装 ALSA 的完整功能, 您需要驱动程式, 函式库及一些公用程式; 也就是说如果您由镜射站抓您应该 ftp://linux.a2000.nl/alsa/driver/alsa-driver-0.3.0-pre4.tar.gz, ftp://linux.a2000.nl/alsa/lib/alsa-lib-0.3.0pre4.tar.gz, 还有 ftp://linux.a2000.nl/alsa/utils/alsa-utils-0.3.0-pre4.tar.gz. (喔, 上面的不是完整的连结, 您最好到原地点看看有没有新版, 并抓最新的.) 3.3 解开驱动程式用合理的命令像 tar -zxf 解开驱动程式. 以下的是写给新手或常忘记的人: (You extract the drivers by some reasonable command, like the all-time tar -zxf . For newbies and for those with amnesia:) cd /usr/src tar -zxf ~/alsa-driver-0.3.0-pre4.tar.gz (如果成功了, 您可能一直使用 root 身份进系统, 这是不对的, 停下来并读一下 DOS/Win95-to-Linux-HOWTO. 不是这样的话, 您已经知道这是关於系统管理(administrative)的事, 您需要 superuser/root 权限. 所以, 您需要 root 权限, 输入 su 以及密码. tar -zxf ~/alsa-lib-0.3.0pre4.tar.gz tar -zxf ~/alsa-utils-0.3.0-pre4.tar.gz 下这样的命令也可以, 且更有趣: find ~ -name alsa* -exec tar -zxf {} \; (孩子, 不要在家试这个, 这只是个□例而已. )注意如果您使用 Netscape 下载驱动程式, 您可能抓下的是解开过的, 但延伸档名还是 .tgz. 如果 tar 抱怨档案格式不对, 把 tar 命令中的 "z" 选项去掉, 可以得到较好的结果. 3.4 编译在您可以编译及使用函式库以前, 您需要先有驱动程式. 而有了函式库後才可以编译使用公用程式. 所以我们开始吧: cd alsa-driver-0.3.0-pre4 (给那些不太有经验的: 在 "alsa-d" 後接著按 ("tab" 键). 这样就会叫出 命令列自动补完(command line completion).) (译注: 有更好的翻法吗?) ./configure make 现在您需要用 root 身份安装东东(可能您已经是 root 了) make install 如果它回应像 "version.h" 档找不到之类的, 您可能没有妥善安装核心原始码. 要编译 ALSA 驱动程式需要核心原始码中的一些档案, 所以您把想用的 linux-2.x.y.tar.gz 在 /usr/src 下解开, 并下 make menuconfig 命令. (实际上, make symlinks 可能就够了). 现在编译函式库: cd ../alsa-lib-0.3.0-pre4 ./configure make make install OK, 您已经成功了, 再来是公用程式: cd ../alsa-utils-0.3.0-pre4 ./configure make make install 注意: 在第一次编译公用程式时可先不打 "make install". 甚至您可以先不要动函式库及公用程式, 只检查一下确定驱动程式能不能用. 3.5 准备设备档在驱动程式目录下有个命令稿(script)可以把 ALSA 的音效设备档安装进 /dev 目录. 在驱动程式目录下打入 ./snddevices 如此应该有 /dev/snd 子目录了(先看看有没有. 如果您甚至连 "ls" 命令都不熟, 请考虑先读别的 HOWTO. 在安装本驱动程式前您应该有些基本的 Linux 知识才对.) 现在您可以安插驱动程式了. 请跳到下一段吧.
⑨ Linux编译时报错fatal error: alsa/asoundlib.h: No such file or directory
你需要自己编译alsa-lib的抄arm版本,然后安装(make install)到预先定义的目标文件夹$prefix。编译music.c时在编译选项中加入-I$(prefix)/include -L$(prefix)/lib即可。
⑩ 如何在android 中编译alsa-utils工具
首先我从ALSA 官方网上下载了alsa-utils-1.0.23版本的工具,因为我android 的alsa-lib 也是1.023版本的,防止版本不一样出现问题,我就选择了版本一样,我们的alsa-lib放的路径是在android_source/external/alsa-lib目录下面,我们下载的alsa-utils-1.023工具包也下载放在里面。接下来我们需要完成以下几个动作:1、在alsa-utils下面创建一个Android.mk写的内容是:ifeq ($(strip $(BOARD_USES_ALSA_AUDIO)),true)LOCAL_PATH:= $(call my-dir)## Build aplay command#include $(CLEAR_VARS)LOCAL_CFLAGS := \ -fPIC -D_POSIX_SOURCE \ -DALSA_CONFIG_DIR=\"/system/usr/share/alsa\" \ -DALSA_PLUGIN_DIR=\"/system/usr/lib/alsa-lib\" \ -DALSA_DEVICE_DIRECTORY=\"/dev/snd/\"LOCAL_C_INCLUDES:= \ $(LOCAL_PATH)/include \ $(LOCAL_PATH)/android \ external/alsa-lib/includeLOCAL_SRC_FILES := \ aplay/aplay.cLOCAL_MODULE_TAGS := debugLOCAL_MODULE := alsa_aplayLOCAL_SHARED_LIBRARIES := \ libasound \ libcinclude $(BUILD_EXECUTABLE)上面我只写了个编译aplay工具的代码,别的工具也是一样的写法2、接下来进入alsa-utils工具包里面进行创建sys目录和aconfig.h文件,在aconfig.h文件里面编写以下内容#define DATADIR "/system/usr/share/alsa"#define rindex strrchr#define open64 open#undef __swab16#define __swab16(x) __arch__swab16((x))#undef __swab32#define __swab32(x) __arch__swab32((x))3、进入第2步中创建的sys目录,在sys目录中创建signal.h头文件,在这个头文件中写如以下内容[plain] view plainprint?01.#include <signal.h>#include <signal.h>4、接下来你直接编译android 就可以了,在编译过程中可能出现以下 错误“4.1:kernel/common/linux/un.h:18: error: expected specifier-qualifier-list before 'sa_family_t那是因为我们在alsa-utils/alsactl/init_parse.c里面在include un.h之前没有#include <sys/socket.h>,你只要在这之前include这个头文件就解决了4.2:还有可能遇到这个错误:在aplay.c里面会提示报错'S_IRGRP' undeclared (first use in this function,你只要在在aplay.c里面添加一个头文件:#include <sys/stat.h>,这样就解决了4.3:接下来可能语言到这样的错误:speaker-test.c里面报wav_file_dir没有定义,这个值是用来定义你的wav文件存放在pad中的位置的,你随便放在哪里,我定义的路径 就是在/sdcard目录下面经过上面的种种修改,alsa-utils工具终于编译成功了转载