diff options
author | Volker RĂ¼melin | 2021-01-10 11:02:29 +0100 |
---|---|---|
committer | Gerd Hoffmann | 2021-01-15 11:25:22 +0100 |
commit | bea29e9f2ea6061abc212809090548cba6d64081 (patch) | |
tree | de588e2da2bbaa8e573a8b5377aa954f183f0fe7 /disas | |
parent | audio: remove remaining unused plive code (diff) | |
download | qemu-bea29e9f2ea6061abc212809090548cba6d64081.tar.gz qemu-bea29e9f2ea6061abc212809090548cba6d64081.tar.xz qemu-bea29e9f2ea6061abc212809090548cba6d64081.zip |
paaudio: avoid to clip samples multiple times
The pulseaudio backend currently converts, clips and copies audio
playback samples in the mixing-engine sample buffer multiple
times.
In qpa_get_buffer_out() the function pa_stream_begin_write()
returns a rather large buffer and this allows audio_pcm_hw_run_out()
in audio/audio.c to copy all samples in the mixing-engine buffer
to the pulse audio buffer. Immediately after copying, qpa_write()
notices with a call to pa_stream_writable_size() that pulse audio
only needs a smaller part of the copied samples and ignores the
rest. This copy and ignore process happens several times for each
audio sample.
To fix this behaviour, call pa_stream_writable_size() in
qpa_get_buffer_out() to limit the number of samples
audio_pcm_hw_run_out() will convert. With this change the
pulseaudio pcm_ops functions put_buffer_out and write are no
longer identical and a separate qpa_put_buffer_out is needed.
Signed-off-by: Volker RĂ¼melin <vr_qemu@t-online.de>
Message-id: 9315afe5-5958-c0b4-ea1e-14769511a9d5@t-online.de
Message-Id: <20210110100239.27588-13-vr_qemu@t-online.de>
Signed-off-by: Gerd Hoffmann <kraxel@redhat.com>
Diffstat (limited to 'disas')
0 files changed, 0 insertions, 0 deletions