跳转到内容

ALSA

来自 Arch Linux 中文维基

这篇文章或章节的翻译质量不佳。

原因:本文疑似机翻,许多用词不自然、不准确。(在 Talk:ALSA# 中讨论)

高级 Linux 声音体系(Advanced Linux Sound Architecture,(ALSA) )提供声卡的内核 驱动,代替了原来的Open Sound System (OSS)。

除了声音设备驱动,ALSA还捆绑了一个用户空间驱动的库用于应用开发。开发者可以使用这些 ALSA 驱动进行高级 API 开发,可以通过 ALSA 库达成与声音设备的内核(直接)交互。

提示:ALSA 相关术语的解释—interface, card, device (一个card 不是一个 device), subdevice, 以及更多 - 可以在 Wikipedia:Advanced Linux Sound Architecture#Concepts找到

安装

[编辑 | 编辑源代码]

ALSA 驱动是内核的一部分,ALSA 库(alsa-lib)通常作为依赖安装,故无需手动安装。

udev会在系统启动时自动检测硬件并选择所需的驱动,并加载相应的声音设备驱动模块。所以你的声卡应当已经可以工作了.

然而在一开始声音可能被静音了。这种情况下见#解除频道静音

固件

[编辑 | 编辑源代码]

笔记本电脑通常需要Sound Open Firmware (SOF) (sof-firmware) —他们倾向于使用 Cadence Tensilica Xtensa 架构DSPs,请参阅支持的平台列表。如果固件丢失,日志将提供以下消息:

error: sof firmware file is missing
error: failed to load DSP firmware -2
error: sof_probe_work failed err: -2


有关更多 SOF 故障排除信息,请参阅英特尔硬件平台概述.

装有Cirrus Logic智能放大器的笔记本电脑需要linux-firmware-cirrus包。参考:


某些英特尔音频设备需要linux-firmware-intel包。


alsa-firmware包含一些声卡可能需要的固件。


See also #Cards and modules and Linux firmware.

ALSA 实用程序

[编辑 | 编辑源代码]

安装软件包 alsa-utils。其包含 alsamixeramixer 等实用程序。amixer是一个用于更改音频设置的shell命令,而alsamixer则提供了一个较为直观的,基于ncurses的界面,用于配置声音设备。



ALSA 和 Systemd

[编辑 | 编辑源代码]

alsa-utils 软件包默认包含了 systemd 单元配置文件 alsa-restore.servicealsa-state.service

在安装时它们会自动安装并激活(通过软件包提供的指向sound.target的符号链接)。选项如下所述:

  • alsa-restore.service默认在启动时读取/var/lib/alsa/asound.state,并在关机时写入更新值。由于 /etc/alsa/state-daemon.conf不存在,除非用户有意识的创建。
  • alsa-state.service在守护进程模式下(重新)启动alsactl 以持续跟踪并保持音量改变,前提是用户有意识的创建了/etc/alsa/state-daemon.conf

显然,这两种方法是互斥的,您可以根据自己的要求决定选择两种方法之一。要编辑这些单位,参考systemd#修改现存单元文件. 您可以用systemctl查看他们的状态。

了解更多信息,参考alsactl(1).

用户权限

[编辑 | 编辑源代码]

本地用户有权限播放音频和更改混音器水平。要允许远程用户使用 ALSA,您需要将这些用户添加audio组。

注意:将用户添加到audio组允许直接访问设备。请记住,这允许应用程序专门保留输出设备。这可能会破坏多座系统上的软件混合或快速用户切换。因此,默认情况下不建议将用户添加到audio组,除非您有特殊需求

OSS 模拟

[编辑 | 编辑源代码]

OSS 模拟 有拦截OSS呼叫并通过 ALSA 重新路由它们的能力。此模拟层非常有用,例如,对于尝试打开/dev/dsp 并直接向它们写入声音数据的老旧应用程序,如果没有 OSS 或模拟库,将会缺少/dev/dsp,应用程序将不会产生任何声音。

如果您希望 OSS 应用程序与dmix一起使用,请同时安装alsa-oss包。

加载 snd_pcm_osssnd_seq_oss内核模块。将它们配置为在 启动时加载

解除频道静音

[编辑 | 编辑源代码]

ALSA 默认静音所有声道,必须手动解除。

使用amixer解除静音

[编辑 | 编辑源代码]

可以使用 amixer 解除声卡的主音量静音:

$ amixer sset Master unmute
$ amixer sset Speaker unmute
$ amixer sset Headphone unmute

使用alsamixer解除静音

[编辑 | 编辑源代码]

使用 alsamixer 可以解除声卡的静音:

$ alsamixer

声道下方标有 MM 表示其已经静音,而标有 00 表示已经启用。

使用 键滚动到 MasterPCM 声道,按下 m 键解除静音。

使用 键增加音量,获得0dB的增益。增益值可在左上方 Item: 字段旁边看到。

注意:若增益高于0 dB,可能会听到失真。

解除5.1/7.1声音的静音

[编辑 | 编辑源代码]

要想得到完整的 5.17.1 环绕声,可能需要解除 FrontSurroundCenterLFE (低音炮)以及 Side 等其他声道的静音(这些声道名称是Intel HD Audio声卡使用的,可能因设备不同而有所差异)。

注意:请注意这样并不会自动上混立体声源(如多数音乐)。要实现这一功能,见#上混

启用麦克风

[编辑 | 编辑源代码]

要启用麦克风,按 F4 切换至 Capture (捕获)选项卡,然后按 空格 启用一个声道即可。如果麦克风不工作,参考Advanced Linux Sound Architecture/Troubleshooting#没有麦克风输入

按下 Esc 键退出 alsamixer。

测试你的更改

[编辑 | 编辑源代码]

接下来,测试声卡是否工作:

$ speaker-test -c 2

根据扬声器的配置,调整 -c 。对于 7.1 声道,使用 -c 8

$ speaker-test -c 8

如果声音输出到了错误的设备,可以试试用 -D 参数手动指定。

$ speaker-test -D default:PCH -c 8

-D 的值是 PCM 通道的名字,运行以下命令即可获取:

$ aplay -L | grep :CARD
default:CARD=PCH  # 'default:PCH' is the PCM channel name for -D
sysdefault:CARD=PCH
front:CARD=PCH,DEV=0
surround21:CARD=PCH,DEV=0
surround40:CARD=PCH,DEV=0
surround41:CARD=PCH,DEV=0
surround50:CARD=PCH,DEV=0
surround51:CARD=PCH,DEV=0
surround71:CARD=PCH,DEV=0


附加注释

[编辑 | 编辑源代码]
  • 如果你的系统有多个声卡,则可以按F6切换声卡。
  • 有些声卡需要静音或禁用数字输出,才能听到模拟声音。反之亦然
  • 有些机器,如Thinkpad T61,有Speaker声道,也需要解除静音并调整。
  • 有些机器,如Dell E6400,可能也需要解除FrontHeadphone 通道的静音并调整它们。
  • 如果重启以后,你的声音调整似乎丢失了,尝试以root运行alsamixer。

驱动配置

[编辑 | 编辑源代码]

更多信息,参考驱动程序配置指南.

要重新加载 ALSA 驱动程序配置,您必须重新加载相应的模块。在执行此作之前,使用相应 ALSA 驱动程序的所有进程(如PipeWire)必须停止。要使用声音设备文件识别进程,请使用fuser(1)

# fuser --all --verbose /dev/snd/*

参考:

卡和模块

[编辑 | 编辑源代码]

运行 lspci -k -nn -d ::0403确定PCI设备的模块。

提示:
  • ::0403这里表示多媒体控制器PCI 设备类的音频设备 子类。
  • lspci 输出中的 Kernel driver in use是加载的模块。 Kernel modules能够处理设备,参考lspci(8) § k

USB设备运行lsusb --verbose --tree | grep --after-context=1 'Class=Audio'

运行lsmod | grep '^snd' 以获取已加载声音模块的完整列表。

运行 cat /proc/asound/cards 以获取声卡列表及其相应的索引卡号)。

提示:

运行cat /proc/asound/modules获取卡片索引及其相应的模块名称。

声卡索引

[编辑 | 编辑源代码]

如果要更改声卡顺序(或你的声卡顺序在启动时发生更改,你想要让它保持不变),使用snd 模块的slots选项为给定驱动程序保留索引,参考内核模块#S配置模块参数

提示:slot 名称源自OSS,相当于ALSA中的术语索引

以下示例假设你希望 USB 声卡始终是第一个(即索引为0),无论何时加载模块(例如,此卡可以在启动时拔出):


/etc/modprobe.d/alsa-base.conf
options snd slots=snd_usb_audio


当模块名称前面加上感叹号(!)时,将为除该名称之外的任何模块提供相应的索引。例如,将索引(0)留给除了snd_usb_audio外的任何模块,以避免 USB 声卡获取它:

options snd slots=!snd_usb_audio

您还可以提供-2的索引,以指示 ALSA 永远不要使用此卡作为主卡:负值被解释为允许索引的位掩码。使用特定模块的index选项,和上面例子作用相同:

options snd_usb_audio index=-2

如果多张声卡使用相同的模块,并且它们的顺序始终相同,则只需使用index选项即可更改顺序。以下示例假设有两个使用 HD 音频模块的音频卡(例如,集成音频卡和非集成视频卡的 HDMI 输出),并且你想交换它们的索引:

options snd_hda_intel index=1,0
提示:
  • 上面的示例解读为“使用snd_hda_intel的第一张声卡给出索引 1,第二个给出索引0”。哪张卡是第一张,哪张卡是第二张由udev决定的。
  • ALSA 模块选项通常不会采用单个值,而是采用一个值数组,选项设置的每个值,仅适用于给定模块正在处理的声卡之一。在以下输出中查找概念数组的存在:
$ modinfo --field=parm module_name | column --separator=':' --table --table-columns-limit=2


slots选项可以与 index 选项组合,只要它们不冲突:


options snd slots=,snd_hda_intel,snd_hda_intel,snd_usb_audio,snd_usb_audio,snd_usb_audio
options snd_hda_intel index=2,1
options snd_usb_audio index=3,4,5 vid=0xVID_3,0xVID_4,0xVID_5 pid=0xPID_3,0xPID_4,0xPID_5


提示:
  • slots=,意思是“不保留索引零”,因此例如,一些 USB 卡(在snd-usb-audio选项中未提及)在启动后插入,可能是第一个。
  • snd_usb_audio模块允许使用vidpid选项来指定卡,因此您不依赖于 udev 的顺序。

参考:

禁用卡

[编辑 | 编辑源代码]

要禁用由给定内核模块控制的所有卡,使用安装模块黑名单方法阻止模块加载


注意:modprobe.d配置文件中使用blacklist关键字将不起作用。

要选择应禁用的卡,请使用内核模块的enable选项 。例如,禁用一个模块所操作的第二张卡:

/etc/modprobe.d/alsa-base.conf
options module_name enable=1,0


另请参阅/疑难解答#编解码器探测 以禁用 HD Audio 卡编解码器。


库配置

[编辑 | 编辑源代码]

系统配置文件是/etc/asound.conf,每个用户配置文件是 ~/.asoundrc


配置文件中解释了库配置的语法,例如空格、行延续、注释,包括配置文件、标点符号(分隔符)、赋值、复合赋值、操作模式等。


ALSA 库配置是为库的每个实例加载的,因此要重新加载它,您所要做的就是重新启动正在使用它的程序。


更多信息,参考:




基本语法

[编辑 | 编辑源代码]

操作模式

[编辑 | 编辑源代码]

解析节点有不同的操作模式,默认模式为“合并/创建”(merge/create)。如果操作模式为“合并/创建”或“合并”(merge),会进行类型检查。只有同样类型的赋值能够被合并,因此字符串不能与整形数合并。在默认操作模式中尝试对复合键值定义一个简单赋值是没有作用的,反之亦然。

操作模式前缀符号:

  • "+" -- 合并/创建
  • "-" -- 合并
  • "?" -- 不覆盖(do not override)
  • "!" -- 覆盖(override)
# 合并/创建 - 如果不存在节点则创建之。
# 如果其存在且类型匹配,则合并subkeyN到键值中。
key.subkeyN valueN;

# 合并/创建 - 与上面等同
key.+subkeyN valueN;

# 合并 - 节点 key.subkeyN 必须已经存在且拥有相同类型
key.-subkeyN valueN;

# 不覆盖 - 如果 key.subkeyN 节点已经存在,则忽略新的赋值
key.?subkeyN valueN;

# 覆盖 - 移除 subkeyN 及其下所有键值, 然后创建节点 key.subkeyN
key.!subkeyN valueN;

在操作正确的情况下,使用覆盖操作模式通常来说是安全的。但是切记,在一个节点中可能会有其他对于正确动作来说必要的键值。

警告:覆盖 pcm 节点大致必然会使 alsa 无法使用,因为所有插件定义都会被删除。 因此除非要从头开始创建配置,否则 不要使用 !pcm.key

嵌套

[编辑 | 编辑源代码]

有时,在配置中使用嵌套可能很有用,甚至更容易阅读。

Nesting PCM plugins
pcm.azalia {	type hw; card 0	}
pcm.!default {	type plug; slave.pcm "azalia"	}

# 相当于

pcm.!default {	type plug; slave.pcm {	type hw; card 0;	}	}

# 也相当于

pcm.!default.type plug;
pcm.default.slave.pcm.type hw;
pcm.default.slave.pcm.card 0;

设置默认声卡

[编辑 | 编辑源代码]

使用“defaults”节点设置默认设备的示例

[编辑 | 编辑源代码]

假设“默认”(default)节点在 /usr/share/alsa/alsa.conf 设定,其中“defaults.pcm.card”及其对应的“ctl”(控制)项都赋值为整型数“0”, 而用户想要将默认PCM与控制设备设定为声卡“2”(第三个声卡),或对于Azalia声卡设定为“SB”。

defaults.ctl.card 2; # 将默认设备与控制设定为第三个声卡(计数从0开始)。
defaults.pcm.card 2; # 寻址类型不会更改。

defaults.ctl.+card 2; # 与上面相同。
defaults.pcm.+card 2;

defaults.ctl.-card 2; # 对于默认设置来说效果相同,但如果默认节点被去除
defaults.pcm.-card 2; # 或类型被更改,则合并操作不会带来更改。

defaults.pcm.?card 2; # 没有效果,因为该赋值已经存在。
defaults.ctl.?card 2;

defaults.pcm.!card "SB"; # 此处有必要使用覆盖操作模式,
defaults.ctl.!card "SB"; # 因为数值类型有所不同。


这里使用双引号会自动将值的数据类型设为字符串,因此在上例中设置 defaults.pcm.!card "2" 的结果就是保持之前的默认设备不变,此例中为声卡0。只要不使用特殊字符(理想状态下也不应该会使用),双引号就不是强制性的。这可能与其他作业无关。


注意:从配置的角度来看,这些并不等同于设置复合的“default”PCM 设备,因为大多数用户也在其中指定寻址类型,这实际上可能是相同的,但分配本身仍然不同。 此外,defaults.pcm.card在 ALSA 配置文件中被多次引用,通常作为回退分配,其中不同的环境变量优先。


通过默认节点设置默认声卡

[编辑 | 编辑源代码]

关于 defaults.pcm.carddefaults.pcm.device,要实际运用上面的例子,假定有2块声卡分别编号为0和1,想要默认使用编号1的声卡,在 /etc/asound.conf 或用户对应的 ~/.asoundrc 使用以下配置即可更改回放与混音控制声卡。

defaults.pcm.card 1
defaults.ctl.card 1


使用环境变量选择默认PCM设备

[编辑 | 编辑源代码]

把ALSA_CARD设为设备的名字也许就可以了。首先用 aplay -l 获取名称,然后将ALSA_CARD设为冒号之后、方括号之前的名称:例如,如果有

card 1: HDMI [HDA ATI HDMI], device 3: HDMI 0 [HDMI 0]

那就设置ALSA_CARD=HDMI

其他变量也在默认全局配置 /usr/share/alsa/alsa.conf 中检查。通过在那里查找形式为 vars [ ... ] 的构造,出现了下表:

Variable name Used by
1 ALSA_CARD pcm.default , pcm.hw , pcm.plughw , ctl.sysdefault , ctl.hw , rawmidi.default , rawmidi.hw , hwdep.hw
2 ALSA_CTL_CARD ctl.sysdefault , ctl.hw
3 ALSA_HWDEP_CARD hwdep.default , hwdep.hw
4 ALSA_HWDEP_DEVICE hwdep.default , hwdep.hw
5 ALSA_PCM_CARD pcm.default , pcm.hw , pcm.plughw
6 ALSA_PCM_DEVICE pcm.hw , pcm.plughw
7 ALSA_RAWMIDI_CARD rawmidi.default , rawmidi.hw
8 ALSA_RAWMIDI_DEVICE rawmidi.default , rawmidi.hw


或者也可以在你自己的配置文件(最好是全局的/etc/asound.conf)中对行为进行覆盖。添加:

pcm.!default {
  type plug
  slave.pcm {
    @func getenv
    vars [ ALSAPCM ]
    default "hw:Audigy2"
  }
}

同样把本例中的 Audigy2 替换成你的设备名字。你可以使用aplay -l获取名字,或者也可以使用surround51等PCM。不过,如果你需要使用麦克风的话,选择全双工PCM声卡为默认设备是个不错的选择。

现在只需改变环境变量 ALSAPCM,就可以在启动程序时选择声卡。对于所有不允许选择声卡的程序此法效果良好,而对于其他的程序请确保保持默认声卡选择。

举例来说,假设你写了一个缩混PCM命名为 mix51to20 ,用以下命令即可将之用于mplayerALSAPCM=mix51to20 mplayer example_6_channel.wav

注意:请注意默认寻址类型。

直接寻址硬件

[编辑 | 编辑源代码]
警告:此设置使设备无法对其他应用程序使用。仅当它是更复杂的设置 ~/.asoundrc 的一部分或用户有意的想要直接寻址声卡(例如通过IEC958 或专用音乐服务器进行数字输出)时,才建议使用此方法。某些应用程序(例如Chromium)不支持此没有声音服务器或#软件混音的设置。

首先确认你想设为默认的声卡和设备ID:

$ aplay -l
**** List of PLAYBACK Hardware Devices ****
card 0: Intel [HDA Intel], device 0: CONEXANT Analog [CONEXANT Analog]
  Subdevices: 1/1
  Subdevice #0: subdevice #0
card 0: Intel [HDA Intel], device 1: Conexant Digital [Conexant Digital]
  Subdevices: 1/1
  Subdevice #0: subdevice #0
card 1: JamLab [JamLab], device 0: USB Audio [USB Audio]
  Subdevices: 1/1
  Subdevice #0: subdevice #0
card 2: Audio [Altec Lansing XT1 - USB Audio], device 0: USB Audio [USB Audio]
  Subdevices: 1/1
  Subdevice #0: subdevice #0

例如,此列表中的最后一个条目具有卡索引(卡号)2、卡 ID 字符串 Audio 和设备 ID 0。要把这块声卡设为默认,可以使用系统级的 /etc/asound.conf 或用户级的 ~/.asoundrc 文件。如果文件不存在,需要手动创建。然后针对相应的声卡加入以下内容:

pcm.!default {
   type hw
   card Audio #or card 2
   hint {
    show on # for some applications
   }
}

ctl.!default {
   type hw
   card Audio
}

pcm.dmixer {
	type dmix
	ipc_key 2048
	slave {
		pcm "hw:Audio" #or "hw:2"
	}
}

pcm.dsnooper {
	type dsnoop
	ipc_key 2048
	slave {
		pcm "hw:Audio"
	}
}

建议使用声卡 ID 字符串而代替数字引用来克服启动顺序问题。

注意:T这种方法可能会有问题 ,如果您的系统有多个相同 ID 字符串的卡(追加 _1, _2, … 后缀).有关详细信息,请参阅 识别两个相同的音频设备

pcm.dmixerpcm.dsnooper 是不支持不混音的应用程序的备用。

本文或本章节的事实准确性存在争议。

原因: 应引入选择ALSA设备的一般方法,例如环境值。(在 Talk:ALSA 中讨论)


例如,chromium -alsa-output-device=pcm.dmixer -alsa-input-device=pcm.dsnooper 使得Chromium临时混音。

pcm选项会影响将用于音频播放的卡和设备,而 ctl选项会影响 alsamixer 等控制实用程序使用哪张卡。

更改应在您(重新)启动应用程序后立即生效(例如,Player)。您还可以使用类似aplay的命令进行测试:

$ aplay -D default:PCH your_favourite_sound.wav

如果您收到有关 asound 配置的错误,请检查上游文档,了解配置文件格式可能发生的更改。

插件

[编辑 | 编辑源代码]

如果需要启用#上混#缩混#高质量重采样 和其他高级功能,请安装插件alsa-plugins


有关更多信息,请参阅PCM(数字音频)插件


软件混音

[编辑 | 编辑源代码]

混音使多个应用程序能够同时输出声音。大多数独立声卡都支持硬件混合,如果可用,默认情况下会启用。集成主板声卡(如英特尔高清音频),通常不支持硬件混音。在此类卡上,软件混音由名为dmix的 ALSA 插件完成。如果硬件混音不可用,则会自动启用此功能。

注意:默认情况下,对于不支持硬件混音的声卡,软件混音是启用。默认情况下,dmix未为数字输出 (S/PDIF) 启用,需要以下配置片段启用。


要手动启用dmix,请将以下内容添加到 ALSA 配置文件中:


/etc/asound.conf
pcm.dsp {
	
    type plug
	
    slave.pcm "dmix"
	
}


上混

[编辑 | 编辑源代码]

播放双声道立体声音源(如音乐)时,需要利用上混才能充分利用 5.1 或 7.1 环绕立体声系统。以前,上混很麻烦,还经常出错;但如今有了插件可以轻松地打理好这一任务。我们使用由 alsa-plugins 软件包提供的 upmix 插件。

然后在ALSA配置文件(/etc/asound.conf~/.asoundrc)中添加如下内容:

pcm.upmix71 {
    type upmix
    slave.pcm "surround71"
    delay 15
    channels 8
}

该范例适用于7.1声道上混。类比该范例,同样能设置5.1或4.0声道上混。

该设置添加了一个新的用于上混的pcm通道。如果希望所有音频源都通过该 pcm 输出,在上述设置后添加如下配置即可:

pcm.!default "plug:upmix71"

插件自动允许多个音频源同时通过它输出,所以将其设为默认实际上是个安全的选择。如果不行,就得像下面这样为上混配置 dmixer:

pcm.dmix6 {
    type asym
    playback.pcm {
        type dmix
        ipc_key 567829
        slave {
            pcm "hw:0,0"
            channels 6
        }
    }
}

并使用 dmix6 而非 surround71。如果遇到声音卡顿或混乱,考虑增加 buffer_size(比如增加到 32768),或使用高质量重采样

缩混

[编辑 | 编辑源代码]

如果您想将源缩混为立体声,比如您想在立体声系统上观看具有 5.1 声音的电影,请使用 alsa-plugins中包含的 vdownmix 插件。

在配置文件中添加如下内容:

pcm.!surround51 {
    type vdownmix
    slave.pcm "default"
}
pcm.!surround40 {
    type vdownmix
    slave.pcm "default"
}
注意:这可能还不足以让缩混工作,见 [1] 。因此可能需要添加 pcm.!default "plug:surround51"pcm.!default "plug:surround40"。只能使用一个 vdownmix 插件;如果你有7.1声道音响,需要使用 surround71 来代替上面所述的配置文件。一个让 vdownmixdmix 同时工作的配置文件的示例见 [2]


多频段均衡器

[编辑 | 编辑源代码]

多频段均衡器 (mbeq) 是一个相当典型的多频段图形均衡器。它是使用快速傅里叶变换(FFT)实现的,因此它需要相当多的 CPU 功率,但相位效应应该比等效滤波器实现更少。如果输入信号的采样率太低,则顶部频段将被忽略 - 最高有用频段将始终是高架。

mbeq是 Steve Harris 的LADSPA 插件套件的一部分。

如果还没有的话,安装 alsa-pluginsladspaswh-plugins 软件包。

  • ~/.asoundrc/etc/asound.conf 中添加如下内容:
/etc/asound.conf
pcm.eq {
  type ladspa

  # The output from the EQ can either go direct to a hardware device
  # (if you have a hardware mixer, e.g. SBLive/Audigy) or it can go
  # to the software mixer shown here.
  #slave.pcm "plughw:0,0"
  slave.pcm "plug:dmix"

  # Sometimes you may need to specify the path to the plugins,
  # especially if you have just installed them.  Once you have logged
  # out/restarted this should not be necessary, but if you get errors
  # about being unable to find plugins, try uncommenting this.
  #path "/usr/lib/ladspa"

  plugins [
    {
      label mbeq
      id 1197
      input {
        #this setting is here by example, edit to your own taste
        #bands: 
        50hz, 100hz, 156hz, 220hz, 311hz, 440hz, 622hz, 880hz, 1250hz, 1750hz, 25000hz, #50000hz, 10000hz, 20000hz
        controls [ -5 -5 -5 -5 -5 -10 -20 -15 -10 -10 -10 -10 -10 -3 -2 ]
      }
    }
  ]
 }

 # Redirect the default device to go via the EQ - you may want to do
 # this last, once you are sure everything is working.  Otherwise all
 # your audio programs will break/crash if something has gone wrong.

 pcm.!default {
  type plug
  slave.pcm "eq"
 }

 # Redirect the OSS emulation through the EQ too (when programs are running through "aoss")

 pcm.dsp0 {
  type plug
  slave.pcm "eq"
 }


AlsaEqual

[编辑 | 编辑源代码]

System-wide

[编辑 | 编辑源代码]

安装 alsaequalAUR包。

安装包后,将以下内容添加到 ALSA 配置文件中:


/etc/asound.conf
ctl.equal {
	
    type equal;
	
}
	
	
pcm.plugequal {
	
    type equal;
	
    # Normally, the equalizer feeds into dmix so that audio
	
    # from multiple applications can be played simultaneously:
	
    slave.pcm "plug:dmix";
	
    # If you want to feed directly into a device, specify it instead of dmix:
	
    #slave.pcm "plughw:0,0";
	
}
	
	
# Configuring pcm.!default will make the equalizer your default sink
	
pcm.!default {
	
# If you do not want the equalizer to be your default,
	
# give it a different name, like pcm.equal commented below
	
# Then you can choose it as the output device by addressing
	
# it in individual apps, for example mpg123 -a equal 06.Back_In_Black.mp3
	
# pcm.equal {
	
    type plug;
	
    slave.pcm plugequal;
	
}


要更改均衡器设置,请运行

$ alsamixer -D equal


请注意,每个用户的均衡器配置都不同(除非未指定其他内容)。 保存在 ~/.alsaequal.bin中。

因此,如果您想将ALSAEqual与mpd 或在不同用户下运行的其他软件一起使用,您可以使用以下命令进行配置。

$ su mpd -c 'alsamixer -D equal'

或者,例如,您可以在他们的主目录中创建指向您的.alsaequal.bin的符号链接。


仅特定输出

[编辑 | 编辑源代码]

如果您只想将均衡器应用于特定的输出设备(例如,您的扬声器连接到 S/PDIF 输出,而不是耳机连接到耳机插孔),但又希望能够从多个应用程序和同时输出到两个输出设备,您需要创建两个直接馈送到各自设备(slave.pcm)的 {ic|dmix}} 设备。以下内容适用于立体声输出,并保持常规立体声输入,仅将均衡器应用于 S/PDIF 输出。

/etc/asound.conf
#
	
#  (capture.pcm)  <-- dnsoop
	
#        |
	
# !default                               --> dmixa
	
#        |                               |
	
#  (playback.pcm) --> stereo2quad ==> quad
	
#                                        |
	
#                                        --> softvol --> plugequal --> dmixd
	
#
	
	
# dmix for analog output
	
pcm.dmixa {
	
  type dmix
	
  ipc_key 1024
	
  ipc_perm 0666
	
  slave.pcm "hw:PCH,0"
	
  slave {
	
     period_time 0
	
    period_size 1024
	
    buffer_size 4096
	
     channels 2
	
  }
	
  bindings {
	
    0 0
	
    1 1
	
  }
	
}
	
	
# dmix for digital output
	
pcm.dmixd {
	
  type dmix
	
  ipc_key 2048
	
  ipc_perm 0666
	
  slave.pcm "hw:PCH,1"
	
  slave {
	
    period_time 0
	
    period_size 1024
	
    buffer_size 4096
	
    channels 2
	
  }
	
  bindings {
	
    0 0
	
    1 1
	
  }
	
}
	
	
# equalizer with controls
	
pcm.plugequal {
	
  type equal
	
  slave {
	
    pcm "plug:dmixd"
	
  }
	
}
	
ctl.equal {
	
 type equal
	
}
	
	
# Volume control for S/PDIF
	
pcm.softvol {
	
    type softvol
	
    slave.pcm "plug:plugequal"
	
    control {
	
        name "S/PDIF"
	
    }
	
}
	
	
# multi:
	
# "a" (analog)  -> dmix,
	
# "d" (digital) -> softvol -> plugequal -> dmix
	
pcm.quad {
	
     type multi
	
     slaves {
	
      a.pcm "dmixa"
	
      a.channels 2
	
      d.pcm "plug:softvol" # detour via softvol and equalizer
	
      d.channels 2
	
    }
	
    bindings {
	
      0 { slave a; channel 0; }
	
      1 { slave a; channel 1; }
	
      2 { slave d; channel 0; }
	
      3 { slave d; channel 1; }
	
     }
	
}
	
	
# stereo to quad
	
pcm.stereo2quad {
	
  type route
	
  slave.pcm "quad"
	
  ttable [
	
    [ 1 0 1 0 ]
	
    [ 0 1 0 1 ]
	
  ]
	
}
	
	
# playback to stereo to quad, capture as usual
	
pcm.!default {
	
  type asym
	
  playback.pcm "plug:stereo2quad"
	
  capture.pcm "plug:dnsoop"
	
}


管理状态

[编辑 | 编辑源代码]

安装alsaequal-mgrAUR 包。


像往常一样配置均衡器

$ alsamixer -D equal


当您对状态感到满意时,您可以给它起一个名字(在本例中为 foo)并保存它:

$ alsaequal-mgr save foo


状态 "foo"可以在以后用一下方式恢复

$ alsaequal-mgr load foo

但是,这只能恢复~/.alsaequal.bin然后,您必须通过 alsamixer -D equal更新均衡器。

因此,您可以为游戏、电影、音乐流派、VoIP 应用程序等创建不同的均衡器状态,并根据需要重新加载它们。

有关更多选项,请参阅项目页面和帮助消息。


提示和技巧

[编辑 | 编辑源代码]

高质量重采样

[编辑 | 编辑源代码]

启用#软件混音混音后,ALSA 会强制将所有内容重新采样到相同的频率(支持时默认为 48 kHz)。默认情况下,它将尝试使用speexrate转换器来执行此作,如果不可用,则回退到低质量的线性插值。因此,如果您由于重采样不良而获得较差的音质,只需安装alsa-plugins包即可解决问题。

要获得更高质量的重采样,您可以将默认速率转换器更改为 speexrate_mediumspeexrate_best。两者都表现得足够好,在实践中您选择哪一个并不重要,因此使用最好的转换器通常不值得它所需的额外 CPU 周期。


要更改默认转换器,请将以下内容放在 ~/.asoundrc/etc/asound.conf中:

defaults.pcm.rate_converter "speexrate_medium"


注意:
  • 也可以使用 libsamplerate包转换器,其速度仅为 speexrate转换器的一半左右,但质量不会提高多少。
  • 某些应用程序(如 MPlayer 及其分支)默认执行自己的重采样,因为某些 ALSA 驱动程序在启用重采样时具有不正确的延迟报告(因此导致 AV 不同步),因此更改此设置不会产生任何影响,除非您将它们配置为使用 ALSA 重采样。


在启动时禁用自动静音

[编辑 | 编辑源代码]

自动静音模式可以在使用amixer启动时配置。例如,要禁用它:

 # amixer -c 0 sset "Auto-Mute Mode" Disabled


或者,可以通过alsamixer使用基于 ncurses 的接口。为了保存任何修改,请使用:


 # alsactl store



 # alsactl daemon


参考 #ALSA和systemd.


热插拔 USB 声卡

[编辑 | 编辑源代码]

请看为 ALSA 编写 Udev 规则.

同时输出

[编辑 | 编辑源代码]

您可能希望通过通过迷你插孔连接的外部扬声器和内部扬声器同时播放音乐。这可以通过使用alsamixer或{ic|amixer}}取消静音自动静音项目来完成:

$ amixer sset "Auto-Mute" unmute

然后取消静音其他必需项目,例如耳机扬声器低音扬声器......

注意:如果耳机连接器(迷你插孔)发出噼啪声,参考 /疑难解答#通过耳机插孔有爆裂声


键盘音量控制

[编辑 | 编辑源代码]

将以下命令映射到音量键: XF86AudioRaiseVolume, XF86AudioLowerVolume, XF86AudioMute.

提高音量:

amixer set Master 5%+

降低音量:

amixer set Master 5%-

切换音量的静音/取消静音:

amixer set Master toggle

使用snd_aloop的虚拟声音设备

[编辑 | 编辑源代码]

您可能需要一个插孔替代方案来创建虚拟录音或播放设备,以便使用{{ic|snd_aloop}模块混合不同的源:

modprobe snd_aloop

使用以下方法列出您的新虚拟设备

aplay -l

现在你可以使用 ffmpeg:

ffmpeg -f alsa -i hw:1,1,0 -f alsa -i hw:1,1,1 -filter_complex amerge output.mp3

在 hw:R,W,N 短语中,R 是您的虚拟卡设备号。录制设备应将 W 设置为 1,播放设备应设置为 0。N 是您的子设备。您可以使用所有可用的虚拟设备并使用 mplayer 等应用程序播放/停止:

mplayer -ao alsa:device=hw=1,0,0 fileA
mplayer -ao alsa:device=hw=1,0,1 fileB

您还可以用这种方法,就是使用下面的脚本来使用festival将语音生成到录音流中。

#!/bin/sh
echo "$1" | iconv -f utf-8 -t iso-8859-1 | text2wave  > "_tmp_.wav"
mplayer -ao alsa:device=hw=2,0,0 "_tmp.wav"
rm "_tmp.wav"

重新配置输入/输出端口

[编辑 | 编辑源代码]

alsa-tools包含hdajackretask工具,该工具可用于(在Intel HDA卡上)重新配置声卡输入/输出端口;例如,将麦克风插孔变成耳机插孔。

apulse

[编辑 | 编辑源代码]

apulseAUR 提供了PulseAudio API 的替代部分实现 。它允许您将 ALSA 用于仅支持 PulseAudio 声音的应用程序。用法很简单:

$ apulse application




相关阅读

[编辑 | 编辑源代码]