These function were really similar. Factor out a new snd_get_best_rate to avoid code duplication. Signed-off-by: Frediano Ziglio <fziglio@xxxxxxxxxx> --- server/sound.c | 27 +++++++++------------------ 1 file changed, 9 insertions(+), 18 deletions(-) diff --git a/server/sound.c b/server/sound.c index 80b0e03..1572019 100644 --- a/server/sound.c +++ b/server/sound.c @@ -1376,14 +1376,11 @@ SPICE_GNUC_VISIBLE uint32_t spice_server_record_get_samples(SpiceRecordInstance return len; } -SPICE_GNUC_VISIBLE uint32_t spice_server_get_best_playback_rate(SpicePlaybackInstance *sin) +static uint32_t snd_get_best_rate(SndChannel *channel, uint32_t cap) { int client_can_opus = TRUE; - if (sin && sin->st->worker.connection) { - SndChannel *channel = sin->st->worker.connection; - PlaybackChannel *playback_channel = SPICE_CONTAINEROF(channel, PlaybackChannel, base); - client_can_opus = red_channel_client_test_remote_cap(playback_channel->base.channel_client, - SPICE_PLAYBACK_CAP_OPUS); + if (channel) { + client_can_opus = red_channel_client_test_remote_cap(channel->channel_client, cap); } if (client_can_opus && snd_codec_is_capable(SPICE_AUDIO_DATA_MODE_OPUS, SND_CODEC_ANY_FREQUENCY)) @@ -1401,6 +1398,11 @@ static void snd_set_rate(SndWorker *worker, uint32_t frequency, uint32_t cap) } } +SPICE_GNUC_VISIBLE uint32_t spice_server_get_best_playback_rate(SpicePlaybackInstance *sin) +{ + return snd_get_best_rate(sin ? sin->st->worker.connection : NULL, SPICE_PLAYBACK_CAP_OPUS); +} + SPICE_GNUC_VISIBLE void spice_server_set_playback_rate(SpicePlaybackInstance *sin, uint32_t frequency) { snd_set_rate(&sin->st->worker, frequency, SPICE_PLAYBACK_CAP_OPUS); @@ -1408,18 +1410,7 @@ SPICE_GNUC_VISIBLE void spice_server_set_playback_rate(SpicePlaybackInstance *si SPICE_GNUC_VISIBLE uint32_t spice_server_get_best_record_rate(SpiceRecordInstance *sin) { - int client_can_opus = TRUE; - if (sin && sin->st->worker.connection) { - SndChannel *channel = sin->st->worker.connection; - RecordChannel *record_channel = SPICE_CONTAINEROF(channel, RecordChannel, base); - client_can_opus = red_channel_client_test_remote_cap(record_channel->base.channel_client, - SPICE_RECORD_CAP_OPUS); - } - - if (client_can_opus && snd_codec_is_capable(SPICE_AUDIO_DATA_MODE_OPUS, SND_CODEC_ANY_FREQUENCY)) - return SND_CODEC_OPUS_PLAYBACK_FREQ; - - return SND_CODEC_CELT_PLAYBACK_FREQ; + return snd_get_best_rate(sin ? sin->st->worker.connection : NULL, SPICE_RECORD_CAP_OPUS); } SPICE_GNUC_VISIBLE void spice_server_set_record_rate(SpiceRecordInstance *sin, uint32_t frequency) -- 2.7.4 _______________________________________________ Spice-devel mailing list Spice-devel@xxxxxxxxxxxxxxxxxxxxx https://lists.freedesktop.org/mailman/listinfo/spice-devel