audio: split pcm_ops function get_buffer_in
Split off pcm_ops function run_buffer_in from get_buffer_in and call run_buffer_in before get_buffer_in. The next patch only needs the generic buffer management part from audio_generic_get_buffer_in(). 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-8-vr_qemu@t-online.de> Signed-off-by: Gerd Hoffmann <kraxel@redhat.com>
This commit is contained in:
parent
ce31f099fb
commit
a2893c8303
@ -929,6 +929,7 @@ static struct audio_pcm_ops alsa_pcm_ops = {
|
|||||||
.init_in = alsa_init_in,
|
.init_in = alsa_init_in,
|
||||||
.fini_in = alsa_fini_in,
|
.fini_in = alsa_fini_in,
|
||||||
.read = alsa_read,
|
.read = alsa_read,
|
||||||
|
.run_buffer_in = audio_generic_run_buffer_in,
|
||||||
.enable_in = alsa_enable_in,
|
.enable_in = alsa_enable_in,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -1241,6 +1241,10 @@ static size_t audio_pcm_hw_run_in(HWVoiceIn *hw, size_t samples)
|
|||||||
size_t conv = 0;
|
size_t conv = 0;
|
||||||
STSampleBuffer *conv_buf = hw->conv_buf;
|
STSampleBuffer *conv_buf = hw->conv_buf;
|
||||||
|
|
||||||
|
if (hw->pcm_ops->run_buffer_in) {
|
||||||
|
hw->pcm_ops->run_buffer_in(hw);
|
||||||
|
}
|
||||||
|
|
||||||
while (samples) {
|
while (samples) {
|
||||||
size_t proc;
|
size_t proc;
|
||||||
size_t size = samples * hw->info.bytes_per_frame;
|
size_t size = samples * hw->info.bytes_per_frame;
|
||||||
@ -1381,10 +1385,8 @@ void audio_run(AudioState *s, const char *msg)
|
|||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
void *audio_generic_get_buffer_in(HWVoiceIn *hw, size_t *size)
|
void audio_generic_run_buffer_in(HWVoiceIn *hw)
|
||||||
{
|
{
|
||||||
ssize_t start;
|
|
||||||
|
|
||||||
if (unlikely(!hw->buf_emul)) {
|
if (unlikely(!hw->buf_emul)) {
|
||||||
size_t calc_size = hw->conv_buf->size * hw->info.bytes_per_frame;
|
size_t calc_size = hw->conv_buf->size * hw->info.bytes_per_frame;
|
||||||
hw->buf_emul = g_malloc(calc_size);
|
hw->buf_emul = g_malloc(calc_size);
|
||||||
@ -1403,8 +1405,12 @@ void *audio_generic_get_buffer_in(HWVoiceIn *hw, size_t *size)
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void *audio_generic_get_buffer_in(HWVoiceIn *hw, size_t *size)
|
||||||
|
{
|
||||||
|
ssize_t start = (ssize_t)hw->pos_emul - hw->pending_emul;
|
||||||
|
|
||||||
start = ((ssize_t) hw->pos_emul) - hw->pending_emul;
|
|
||||||
if (start < 0) {
|
if (start < 0) {
|
||||||
start += hw->size_emul;
|
start += hw->size_emul;
|
||||||
}
|
}
|
||||||
@ -1505,6 +1511,10 @@ size_t audio_generic_read(HWVoiceIn *hw, void *buf, size_t size)
|
|||||||
{
|
{
|
||||||
size_t total = 0;
|
size_t total = 0;
|
||||||
|
|
||||||
|
if (hw->pcm_ops->run_buffer_in) {
|
||||||
|
hw->pcm_ops->run_buffer_in(hw);
|
||||||
|
}
|
||||||
|
|
||||||
while (total < size) {
|
while (total < size) {
|
||||||
size_t src_size = size - total;
|
size_t src_size = size - total;
|
||||||
void *src = hw->pcm_ops->get_buffer_in(hw, &src_size);
|
void *src = hw->pcm_ops->get_buffer_in(hw, &src_size);
|
||||||
|
@ -172,12 +172,14 @@ struct audio_pcm_ops {
|
|||||||
int (*init_in) (HWVoiceIn *hw, audsettings *as, void *drv_opaque);
|
int (*init_in) (HWVoiceIn *hw, audsettings *as, void *drv_opaque);
|
||||||
void (*fini_in) (HWVoiceIn *hw);
|
void (*fini_in) (HWVoiceIn *hw);
|
||||||
size_t (*read) (HWVoiceIn *hw, void *buf, size_t size);
|
size_t (*read) (HWVoiceIn *hw, void *buf, size_t size);
|
||||||
|
void (*run_buffer_in)(HWVoiceIn *hw);
|
||||||
void *(*get_buffer_in)(HWVoiceIn *hw, size_t *size);
|
void *(*get_buffer_in)(HWVoiceIn *hw, size_t *size);
|
||||||
void (*put_buffer_in)(HWVoiceIn *hw, void *buf, size_t size);
|
void (*put_buffer_in)(HWVoiceIn *hw, void *buf, size_t size);
|
||||||
void (*enable_in)(HWVoiceIn *hw, bool enable);
|
void (*enable_in)(HWVoiceIn *hw, bool enable);
|
||||||
void (*volume_in)(HWVoiceIn *hw, Volume *vol);
|
void (*volume_in)(HWVoiceIn *hw, Volume *vol);
|
||||||
};
|
};
|
||||||
|
|
||||||
|
void audio_generic_run_buffer_in(HWVoiceIn *hw);
|
||||||
void *audio_generic_get_buffer_in(HWVoiceIn *hw, size_t *size);
|
void *audio_generic_get_buffer_in(HWVoiceIn *hw, size_t *size);
|
||||||
void audio_generic_put_buffer_in(HWVoiceIn *hw, void *buf, size_t size);
|
void audio_generic_put_buffer_in(HWVoiceIn *hw, void *buf, size_t size);
|
||||||
void audio_generic_run_buffer_out(HWVoiceOut *hw);
|
void audio_generic_run_buffer_out(HWVoiceOut *hw);
|
||||||
|
@ -657,6 +657,7 @@ static struct audio_pcm_ops jack_pcm_ops = {
|
|||||||
.init_in = qjack_init_in,
|
.init_in = qjack_init_in,
|
||||||
.fini_in = qjack_fini_in,
|
.fini_in = qjack_fini_in,
|
||||||
.read = qjack_read,
|
.read = qjack_read,
|
||||||
|
.run_buffer_in = audio_generic_run_buffer_in,
|
||||||
.enable_in = qjack_enable_in
|
.enable_in = qjack_enable_in
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -124,6 +124,7 @@ static struct audio_pcm_ops no_pcm_ops = {
|
|||||||
.init_in = no_init_in,
|
.init_in = no_init_in,
|
||||||
.fini_in = no_fini_in,
|
.fini_in = no_fini_in,
|
||||||
.read = no_read,
|
.read = no_read,
|
||||||
|
.run_buffer_in = audio_generic_run_buffer_in,
|
||||||
.enable_in = no_enable_in
|
.enable_in = no_enable_in
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -762,6 +762,7 @@ static struct audio_pcm_ops oss_pcm_ops = {
|
|||||||
.init_in = oss_init_in,
|
.init_in = oss_init_in,
|
||||||
.fini_in = oss_fini_in,
|
.fini_in = oss_fini_in,
|
||||||
.read = oss_read,
|
.read = oss_read,
|
||||||
|
.run_buffer_in = audio_generic_run_buffer_in,
|
||||||
.enable_in = oss_enable_in
|
.enable_in = oss_enable_in
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -293,6 +293,7 @@ static struct audio_pcm_ops audio_callbacks = {
|
|||||||
.init_in = line_in_init,
|
.init_in = line_in_init,
|
||||||
.fini_in = line_in_fini,
|
.fini_in = line_in_fini,
|
||||||
.read = line_in_read,
|
.read = line_in_read,
|
||||||
|
.run_buffer_in = audio_generic_run_buffer_in,
|
||||||
.enable_in = line_in_enable,
|
.enable_in = line_in_enable,
|
||||||
#if ((SPICE_INTERFACE_RECORD_MAJOR >= 2) && (SPICE_INTERFACE_RECORD_MINOR >= 2))
|
#if ((SPICE_INTERFACE_RECORD_MAJOR >= 2) && (SPICE_INTERFACE_RECORD_MINOR >= 2))
|
||||||
.volume_in = line_in_volume,
|
.volume_in = line_in_volume,
|
||||||
|
Loading…
Reference in New Issue
Block a user