mirror of
https://github.com/mpv-player/mpv.git
synced 2025-12-28 05:33:14 +00:00
demux: mp_msg conversions
The TV code pretends to be part of stream/, but it's actually demuxer code too. The audio_in code is shared between the TV code and stream_radio.c, so stream_radio.c needs a small hack until stream.c is converted.
This commit is contained in:
@@ -57,10 +57,10 @@ int ai_oss_set_channels(audio_in_t *ai)
|
||||
if (ai->req_channels > 2)
|
||||
{
|
||||
ioctl_param = ai->req_channels;
|
||||
mp_msg(MSGT_TV, MSGL_V, "ioctl dsp channels: %d\n",
|
||||
MP_VERBOSE(ai, "ioctl dsp channels: %d\n",
|
||||
err = ioctl(ai->oss.audio_fd, SNDCTL_DSP_CHANNELS, &ioctl_param));
|
||||
if (err < 0) {
|
||||
mp_msg(MSGT_TV, MSGL_ERR, "Unable to set channel count: %d\n",
|
||||
MP_ERR(ai, "Unable to set channel count: %d\n",
|
||||
ai->req_channels);
|
||||
return -1;
|
||||
}
|
||||
@@ -69,11 +69,11 @@ int ai_oss_set_channels(audio_in_t *ai)
|
||||
else
|
||||
{
|
||||
ioctl_param = (ai->req_channels == 2);
|
||||
mp_msg(MSGT_TV, MSGL_V, "ioctl dsp stereo: %d (req: %d)\n",
|
||||
MP_VERBOSE(ai, "ioctl dsp stereo: %d (req: %d)\n",
|
||||
err = ioctl(ai->oss.audio_fd, SNDCTL_DSP_STEREO, &ioctl_param),
|
||||
ioctl_param);
|
||||
if (err < 0) {
|
||||
mp_msg(MSGT_TV, MSGL_ERR, "Unable to set stereo: %d\n",
|
||||
MP_ERR(ai, "Unable to set stereo: %d\n",
|
||||
ai->req_channels == 2);
|
||||
return -1;
|
||||
}
|
||||
@@ -90,65 +90,65 @@ int ai_oss_init(audio_in_t *ai)
|
||||
ai->oss.audio_fd = open(ai->oss.device, O_RDONLY | O_CLOEXEC);
|
||||
if (ai->oss.audio_fd < 0)
|
||||
{
|
||||
mp_msg(MSGT_TV, MSGL_ERR, "Unable to open '%s': %s\n",
|
||||
MP_ERR(ai, "Unable to open '%s': %s\n",
|
||||
ai->oss.device, strerror(errno));
|
||||
return -1;
|
||||
}
|
||||
|
||||
ioctl_param = 0 ;
|
||||
mp_msg(MSGT_TV, MSGL_V, "ioctl dsp getfmt: %d\n",
|
||||
MP_VERBOSE(ai, "ioctl dsp getfmt: %d\n",
|
||||
ioctl(ai->oss.audio_fd, SNDCTL_DSP_GETFMTS, &ioctl_param));
|
||||
|
||||
mp_msg(MSGT_TV, MSGL_V, "Supported formats: %x\n", ioctl_param);
|
||||
MP_VERBOSE(ai, "Supported formats: %x\n", ioctl_param);
|
||||
if (!(ioctl_param & AFMT_S16_LE))
|
||||
mp_msg(MSGT_TV, MSGL_ERR, "unsupported format\n");
|
||||
MP_ERR(ai, "unsupported format\n");
|
||||
|
||||
ioctl_param = AFMT_S16_LE;
|
||||
mp_msg(MSGT_TV, MSGL_V, "ioctl dsp setfmt: %d\n",
|
||||
MP_VERBOSE(ai, "ioctl dsp setfmt: %d\n",
|
||||
err = ioctl(ai->oss.audio_fd, SNDCTL_DSP_SETFMT, &ioctl_param));
|
||||
if (err < 0) {
|
||||
mp_msg(MSGT_TV, MSGL_ERR, "Unable to set audio format.");
|
||||
MP_ERR(ai, "Unable to set audio format.");
|
||||
return -1;
|
||||
}
|
||||
|
||||
if (ai_oss_set_channels(ai) < 0) return -1;
|
||||
|
||||
ioctl_param = ai->req_samplerate;
|
||||
mp_msg(MSGT_TV, MSGL_V, "ioctl dsp speed: %d\n",
|
||||
MP_VERBOSE(ai, "ioctl dsp speed: %d\n",
|
||||
err = ioctl(ai->oss.audio_fd, SNDCTL_DSP_SPEED, &ioctl_param));
|
||||
if (err < 0) {
|
||||
mp_msg(MSGT_TV, MSGL_ERR, "Unable to set samplerate: %d\n",
|
||||
MP_ERR(ai, "Unable to set samplerate: %d\n",
|
||||
ai->req_samplerate);
|
||||
return -1;
|
||||
}
|
||||
ai->samplerate = ioctl_param;
|
||||
|
||||
mp_msg(MSGT_TV, MSGL_V, "ioctl dsp trigger: %d\n",
|
||||
MP_VERBOSE(ai, "ioctl dsp trigger: %d\n",
|
||||
ioctl(ai->oss.audio_fd, SNDCTL_DSP_GETTRIGGER, &ioctl_param));
|
||||
mp_msg(MSGT_TV, MSGL_V, "trigger: %x\n", ioctl_param);
|
||||
MP_VERBOSE(ai, "trigger: %x\n", ioctl_param);
|
||||
ioctl_param = PCM_ENABLE_INPUT;
|
||||
mp_msg(MSGT_TV, MSGL_V, "ioctl dsp trigger: %d\n",
|
||||
MP_VERBOSE(ai, "ioctl dsp trigger: %d\n",
|
||||
err = ioctl(ai->oss.audio_fd, SNDCTL_DSP_SETTRIGGER, &ioctl_param));
|
||||
if (err < 0) {
|
||||
mp_msg(MSGT_TV, MSGL_ERR, "Unable to set trigger: %d\n",
|
||||
MP_ERR(ai, "Unable to set trigger: %d\n",
|
||||
PCM_ENABLE_INPUT);
|
||||
}
|
||||
|
||||
ai->blocksize = 0;
|
||||
mp_msg(MSGT_TV, MSGL_V, "ioctl dsp getblocksize: %d\n",
|
||||
MP_VERBOSE(ai, "ioctl dsp getblocksize: %d\n",
|
||||
err = ioctl(ai->oss.audio_fd, SNDCTL_DSP_GETBLKSIZE, &ai->blocksize));
|
||||
if (err < 0) {
|
||||
mp_msg(MSGT_TV, MSGL_ERR, "Unable to get block size!\n");
|
||||
MP_ERR(ai, "Unable to get block size!\n");
|
||||
}
|
||||
mp_msg(MSGT_TV, MSGL_V, "blocksize: %d\n", ai->blocksize);
|
||||
MP_VERBOSE(ai, "blocksize: %d\n", ai->blocksize);
|
||||
|
||||
// correct the blocksize to a reasonable value
|
||||
if (ai->blocksize <= 0) {
|
||||
ai->blocksize = 4096*ai->channels*2;
|
||||
mp_msg(MSGT_TV, MSGL_ERR, "Audio block size is zero, setting to %d!\n", ai->blocksize);
|
||||
MP_ERR(ai, "Audio block size is zero, setting to %d!\n", ai->blocksize);
|
||||
} else if (ai->blocksize < 4096*ai->channels*2) {
|
||||
ai->blocksize *= 4096*ai->channels*2/ai->blocksize;
|
||||
mp_msg(MSGT_TV, MSGL_ERR, "Audio block size too low, setting to %d!\n", ai->blocksize);
|
||||
MP_ERR(ai, "Audio block size too low, setting to %d!\n", ai->blocksize);
|
||||
}
|
||||
|
||||
ai->samplesize = 16;
|
||||
|
||||
Reference in New Issue
Block a user