提交 8e72ab34 编写于 作者: J Jaroslav Kysela

[ALSA] Reverted last patch for SNDCTL_DSP_GETOPTR fix & possible overflow fix

ALSA<-OSS emulation
This reverts the last patch which wrongly mixes bytes and frames.
The real culprit might be the 32-bit overflow, so the return expression uses
64-bit values now in snd_pcm_oss_bytes().
Signed-off-by: NJaroslav Kysela <perex@suse.cz>
上级 c3a9cfac
...@@ -124,13 +124,12 @@ int snd_pcm_plugin_append(snd_pcm_plugin_t *plugin) ...@@ -124,13 +124,12 @@ int snd_pcm_plugin_append(snd_pcm_plugin_t *plugin)
static long snd_pcm_oss_bytes(snd_pcm_substream_t *substream, long frames) static long snd_pcm_oss_bytes(snd_pcm_substream_t *substream, long frames)
{ {
long bytes = 0;
snd_pcm_runtime_t *runtime = substream->runtime; snd_pcm_runtime_t *runtime = substream->runtime;
snd_pcm_uframes_t buffer_size = snd_pcm_lib_buffer_bytes(substream); snd_pcm_uframes_t buffer_size = snd_pcm_lib_buffer_bytes(substream);
bytes = frames_to_bytes(runtime, frames); frames = frames_to_bytes(runtime, frames);
if (buffer_size == runtime->oss.buffer_bytes) if (buffer_size == runtime->oss.buffer_bytes)
return bytes; return frames;
return (runtime->oss.buffer_bytes * frames) / buffer_size; return (long)(((int64_t)runtime->oss.buffer_bytes * (int64_t)frames) / (int64_t)buffer_size);
} }
static long snd_pcm_alsa_frames(snd_pcm_substream_t *substream, long bytes) static long snd_pcm_alsa_frames(snd_pcm_substream_t *substream, long bytes)
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册