eth*_*nny 7 linux audio usb alsa
我试图使用ALSA从USB音频设备获取输入并将其作为一系列signed short值写入磁盘.我最终得到的是看似有效数据的块,其中散布着大块的零.我猜我的缓冲区设置不正确,并没有正确使用内存映射.
我在尝试什么:
- 采样率:8K(由设备强制)
- 缓冲区大小:2048
- 期间大小:512
- 一个频道
该设备似乎正确打开并接受各种参数.经过一些设置后,循环运行如下:
snd_pcm_avail_update
snd_pcm_mmap_begin
memcpy data from mmap buffer to array of short
snd_pcm_mmap_commit
Run Code Online (Sandbox Code Playgroud)
memcpy是指向short数组的指针,并以每次传递返回的帧数递增.
在此记录几秒钟后,我将其关闭并将后续缓冲区写入磁盘,作为每行的单个短值.我期待的是在1200和2300 Hz之间变化的PCM数据中的第二个或两个.我得到的是一些有很多零的数据.
我想知道的是:我对缓冲和期间理性的价值观是什么?有没有人成功使用ALSA的内存映射输出?
编辑:一些代码
const snd_pcm_channel_area_t *areas;
snd_pcm_uframes_t offset, frames, size;
short* pCID = (short*)malloc( 50000 * sizeof( short ));
short* ppCID = pCID;
while( size > 0 )
{
frames = size;
snd_pcm_mmap_begin (device, &areas, &offset, &frames);
short* pd = (short*)areas[0].addr;
memcpy( ppCID, (pd + (offset*sizeof(short))), frames * sizeof( short ));
ppCID += frames;
snd_pcm_mmap_commit(device, offset, frames);
size -= frames;
}
Run Code Online (Sandbox Code Playgroud)
(为清楚起见,删除了错误检查)
完成所有操作后,我遍历pCID并写入磁盘.每行一个值.
| 归档时间: |
|
| 查看次数: |
3505 次 |
| 最近记录: |