Linux 音频系统全景解析:PipeWire、PulseAudio 与 ALSA 的层次关系
在 Linux 系统中,音频子系统由多个层次组成:内核驱动、ALSA、PulseAudio/PipeWire、以及桌面 UI。很多配置文件分布在 /usr/share 下,看似复杂,其实是各层次的"拼图"。本文将逐层解析它们的作用和关系。
1. ALSA 驱动与 UCM2
ALSA 驱动
- 位于内核层,直接与硬件交互。
- 提供基础的音频控件(如
Differential Mux、Speaker Switch、Mic Switch)。 - 驱动只报告插孔事件,不会主动改控件。
UCM2 配置
- 路径:
/usr/share/alsa/ucm2/,例如rockchip-es8388/HiFi.conf。 - 定义声卡的使用场景(HiFi、VoiceCall)。
- 告诉 ALSA 在不同场景下如何路由控件。
- 相当于声卡的"说明书",为上层提供硬件能力描述。
2. PulseAudio 路径配置
- 路径:
/usr/share/pulseaudio/alsa-mixer/paths/。 - 作用:描述输入/输出路径的策略。
- 例如
analog-input-mic.conf.common里[Element Line] switch=off,表示当选择麦克风路径时要关闭 Line 控件。 - Rockchip 专用的
analog-input-headset-mic-rockchip.conf会引用这些通用配置。
- 例如
- 特点:这些文件不是给 UI 用的,而是 PulseAudio(或 PipeWire 的 PulseAudio 兼容层)用来决定插拔耳机时要改哪些控件。
3. PipeWire 配置
- 路径:
/usr/share/pipewire/。 - 文件:
pipewire.conf→ 主配置。pipewire-pulse.conf→ PulseAudio 兼容层配置。jack.conf→ JACK 兼容层配置。
- 作用:PipeWire 是新一代多媒体服务器,取代 PulseAudio 和 JACK。
- 提供更低延迟、更灵活的音频处理。
- 通过
pipewire-pulse模拟 PulseAudio,让旧应用无需修改。 - 仍然会读取 PulseAudio 的路径配置文件来控制 ALSA。
4. ALSA Card Profile
- 路径:
/usr/share/alsa-card-profile/。 - 作用:把 ALSA 的 UCM2 配置翻译成 PulseAudio/PipeWire 能理解的"卡片配置"。
- 用途:用于设备选择和 profile 切换(比如 HiFi、Headset)。
5. UI 层
- 桌面环境(GNOME/KDE)的音量控制面板只是前端。
- 它调用 PulseAudio/PipeWire 提供的 API,背后真正执行的是路径配置和 UCM2。
- UI 本身不会直接改 ALSA 控件。
总体关系链条
应用程序 (UI: GNOME/KDE 音量控制)
│
▼
PipeWire (pipewire.conf / pipewire-pulse.conf)
│
▼
PulseAudio 路径配置 (/usr/share/pulseaudio/alsa-mixer/paths/*.conf)
│
▼
ALSA Card Profile (/usr/share/alsa-card-profile/mixer/)
│
▼
ALSA UCM2 (/usr/share/alsa/ucm2/HiFi.conf)
│
▼
ALSA 驱动 (硬件控件: Differential Mux, Speaker Switch)
结论
- ALSA 驱动:只提供硬件控件和插孔事件。
- UCM2:定义声卡场景和底层路由。
- PulseAudio 路径配置:定义插拔耳机时要改哪些控件。
- PipeWire:顶层音频服务器,执行策略,决定是否启用自动切换。
- alsa-card-profile:把 UCM2 配置翻译成 profile,供 PulseAudio/PipeWire 使用。
- UI:只是前端,背后逻辑由 PipeWire/PulseAudio + ALSA 配置决定。