【问题标题】:Linux ALSA Driver using channel count 3使用通道数 3 的 Linux ALSA 驱动程序
【发布时间】:2015-07-30 01:06:03
【问题描述】:

我在 Ubuntu 14.04、64 位、3.16.0-30-generic 内核上运行我的 ALSA 驱动程序。

硬件是专有硬件,因此不能提供太多细节。

以下是现有的驱动程序实现:

通过模块参数为驱动程序提供采样格式、采样率、通道计数作为输入。 (由于需求需要通过模块参数提供输入)

播放路径的初始 snd_pcm_hardware 结构。

#define DEFAULT_PERIOD_SIZE (4096)
#define DEFAULT_NO_OF_PERIODS (1024)
static struct snd_pcm_hardware xxx_playback =
{

.info                   = SNDRV_PCM_INFO_MMAP |
                          SNDRV_PCM_INFO_INTERLEAVED |
                          SNDRV_PCM_INFO_MMAP_VALID |
                          SNDRV_PCM_INFO_SYNC_START,
.formats                = SNDRV_PCM_FMTBIT_S16_LE,
.rates                  = (SNDRV_PCM_RATE_8000 | \
                           SNDRV_PCM_RATE_16000 | \
                           SNDRV_PCM_RATE_48000 | \
                           SNDRV_PCM_RATE_96000),
.rate_min               = 8000,
.rate_max               = 96000,
.channels_min           = 1,
.channels_max           = 1,
.buffer_bytes_max       = (DEFAULT_PERIOD_SIZE * DEFAULT_NO_OF_PERIODS),
.period_bytes_min       = DEFAULT_PERIOD_SIZE,
.period_bytes_max       = DEFAULT_PERIOD_SIZE,
.periods_min            = DEFAULT_NO_OF_PERIODS,
.periods_max            = DEFAULT_NO_OF_PERIODS,
};

捕获端 snd_pcm_hardware 结构的类似值。

请注意,根据当前音频测试配置,以下值在播放打开入口点中被替换: (用户通过模块参数提供音频格式、音频速率、通道数作为驱动的输入,在snd_pcm_hardware结构中重新填充)

xxx_playback.formats = user_format_input
xxx_playback.rates = xxx_playback.rate_min, xxx_playback.rate_max = user_sample_rate_input
xxx_playback.channels_min = xxx_playback.channels_max = user_channel_input

在捕获打开的入口点中为捕获 snd_pcm_hardware 结构重新填充类似的值。

通过 ALSA 层成功根据 channel_count、format、sample_rate 和驱动寄存器为时钟配置硬件

发现在 channel_count = 1 或 2 或 4 时 aplay/arecord 工作正常

在播放/录制期间,在驱动程序中检查“runtime->channels”值时,它反映了配置的 channel_count,这听起来对我来说是正确的。

记录数据与播放匹配,因为它是一个环回测试。

但是当我使用 channel_count = 3 时,aplay 或 arecord 都报告

“此 PCM 的配置损坏:没有可用的配置”!!对于具有 channel_count '3' 的波形文件

例如:播放 WAVE './xxx.wav':有符号 16 位 Little Endian,速率 48000 Hz,通道 3

ALSA lib pcm_params.c:2162:(snd1_pcm_hw_refine_slave) 从属 PCM 不可用

aplay: set_params:1204: 此 PCM 的配置损坏:无可用配置

通过以下更改,我能够前进一点:

.......................

方法一:

通过模块参数为驱动程序提供 channel_count '3' 作为输入

修改驱动以填充 snd_pcm_hardware 结构作为回报->channels_min = 2 & 播放->channels_min = 3;捕获路径的相似值

aplay/arecord 报告为“频道数不可用”,尽管正在使用的波形文件有 3 个频道

例如:aplay -D hw:CARD=xxx,DEV=0 ./xxx.wav Playing WAVE './xxx.wav' :有符号 16 位 Little Endian,速率 48000 Hz,通道 3

aplay: set_params:1239: 频道数不可用

用 plughw 尝试了 aplay/arecord,aplay/arecord 继续前进

arecord -D plughw:CARD=xxx,DEV=0 -d 3 -f S16_LE -r 48000 -c 3 ./xxx_rec0.wav

aplay -D plughw:CARD=xxx,DEV=0 ./xxx.wav

录制 WAVE './xxx_rec0.wav' :有符号 16 位 Little Endian,速率 48000 Hz,通道 3

播放 WAVE './xxx.wav' :有符号 16 位 Little Endian,速率 48000 Hz,通道 3

测试结束

在播放/录制期间,在驱动程序中,当“runtime->channels”值被选中时,它返回值 2!!!但是播放的波形文件有 ch count 3...

当检查记录文件中的数据时,它的所有静音

.......................

方法二:

通过模块参数为驱动程序提供 channel_count '3' 作为输入

修改驱动以填充 snd_pcm_hardware 结构为播放->channels_min = 3 &播放->channels_min = 4;捕获路径的相似值

aplay/arecord 报告为“频道数不可用”,尽管正在使用的波形文件有 3 个频道

用 plughw 尝试了 aplay/arecord,aplay/arecord 继续前进

在 aplay/arecord 期间,在驱动程序中,当检查“runtime->channels”值时,它返回值 4!!!但是播放的波形文件有 ch count 3...

当检查记录文件中的数据时,它的所有静音

.......................

所以从上面的观察来看,runtime->channels 要么是 2 要么是 4,但尽管请求,alsa 堆栈从未使用过 3 个通道。使用 Plughw 时,alsa 正在转换数据以在 2 或 4 通道下运行。

任何人都可以帮助我为什么无法使用频道计数 3。

如有需要,将提供更多信息。

提前致谢。

【问题讨论】:

    标签: linux ubuntu audio alsa


    【解决方案1】:

    谢谢 CL。

    对于这个通道数为 3 的特定测试用例,我使用了周期大小 4092,并且能够成功地进行环回(不使用 plughw)。

    最后一个问题,我之前用plughw的时候,当runtime->channels是2或者4的时候,为什么记录的数据没有显示出来?

    【讨论】:

      【解决方案2】:

      一个句点(和整个缓冲区)必须包含整数个帧,也就是说,不能有部分帧。

      三个通道,一帧有六个字节。固定周期大小 (4096) 不能被 6 整除而没有余数。

      【讨论】:

        猜你喜欢
        • 1970-01-01
        • 2019-10-12
        • 2018-03-06
        • 2017-04-30
        • 2018-11-25
        • 2012-10-26
        • 1970-01-01
        • 1970-01-01
        • 1970-01-01
        相关资源
        最近更新 更多