Signed-off-by: Jeremy White <jwhite@xxxxxxxxxxxxxxx> --- configure.ac | 37 +++++++++++++++--- gtk/channel-playback.c | 58 +++++++--------------------- gtk/channel-record.c | 98 +++++++++++++++--------------------------------- 3 files changed, 77 insertions(+), 116 deletions(-) diff --git a/configure.ac b/configure.ac index c42066f..8953446 100644 --- a/configure.ac +++ b/configure.ac @@ -97,11 +97,22 @@ AC_SUBST(PIXMAN_CFLAGS) AC_SUBST(PIXMAN_LIBS) SPICE_GLIB_REQUIRES="${SPICE_GLIB_REQUIRES} pixman-1 >= 0.17.7" -PKG_CHECK_MODULES(CELT051, celt051 >= 0.5.1.1) -AC_SUBST(CELT051_CFLAGS) -AC_SUBST(CELT051_LIBS) -AC_SUBST(CELT051_LIBDIR) -SPICE_GLIB_REQUIRES="${SPICE_GLIB_REQUIRES} celt051 >= 0.5.1.1" +AC_ARG_ENABLE(celt051, +[ --disable-celt051 Disable celt051 audio codec (enabled by default)],, +[enable_celt051="yes"]) + +if test "x$enable_celt051" = "xyes"; then + PKG_CHECK_MODULES(CELT051, celt051 >= 0.5.1.1) + AC_SUBST(CELT051_CFLAGS) + AC_SUBST(CELT051_LIBS) + AC_SUBST(CELT051_LIBDIR) + SPICE_GLIB_REQUIRES="${SPICE_GLIB_REQUIRES} celt051 >= 0.5.1.1" +else + have_celt051=no +fi + +AM_CONDITIONAL([HAVE_CELT051], [test "x$have_celt051" = "xyes"]) +AM_COND_IF([HAVE_CELT051], AC_DEFINE([HAVE_CELT051], 1, [Define if we have celt051 codec])) PKG_CHECK_MODULES(SSL, openssl) AC_SUBST(SSL_CFLAGS) @@ -264,6 +275,22 @@ PKG_CHECK_MODULES(GTHREAD, gthread-2.0 > 2.0.0) AC_SUBST(GTHREAD_CFLAGS) AC_SUBST(GTHREAD_LIBS) +AC_ARG_ENABLE(celt051, +[ --disable-celt051 Disable celt051 audio codec (enabled by default)],, +[enable_celt051="yes"]) + +if test "x$enable_celt051" = "xyes"; then + PKG_CHECK_MODULES(CELT051, celt051 >= 0.5.1.1, have_celt051=yes, have_celt051=no) + AC_SUBST(CELT051_CFLAGS) + AC_SUBST(CELT051_LIBS) + AC_SUBST(CELT051_LIBDIR) +else + have_celt051=no +fi + +AM_CONDITIONAL([HAVE_CELT051], [test "x$have_celt051" = "xyes"]) +AM_COND_IF([HAVE_CELT051], AC_DEFINE([HAVE_CELT051], 1, [Define if we have celt051 codec])) + AC_ARG_WITH([audio], AS_HELP_STRING([--with-audio=@<:@gstreamer/pulse/auto/no@:>@], [Select audio backend @<:@default=auto@:>@]), [], diff --git a/gtk/channel-playback.c b/gtk/channel-playback.c index 60fc113..b692d70 100644 --- a/gtk/channel-playback.c +++ b/gtk/channel-playback.c @@ -15,8 +15,6 @@ You should have received a copy of the GNU Lesser General Public License along with this library; if not, see <http://www.gnu.org/licenses/>. */ -#include <celt051/celt.h> - #include "spice-client.h" #include "spice-common.h" #include "spice-channel-priv.h" @@ -24,6 +22,8 @@ #include "spice-marshal.h" +#include "common/snd_codec.h" + /** * SECTION:channel-playback * @short_description: audio stream for playback @@ -48,8 +48,7 @@ struct _SpicePlaybackChannelPrivate { int mode; - CELTMode *celt_mode; - CELTDecoder *celt_decoder; + SndCodec codec; guint32 frame_count; guint32 last_time; guint8 nchannels; @@ -91,7 +90,8 @@ static void channel_set_handlers(SpiceChannelClass *klass); static void spice_playback_channel_reset_capabilities(SpiceChannel *channel) { if (!g_getenv("SPICE_DISABLE_CELT")) - spice_channel_set_capability(SPICE_CHANNEL(channel), SPICE_PLAYBACK_CAP_CELT_0_5_1); + if (snd_codec_is_capable(SPICE_AUDIO_DATA_MODE_CELT_0_5_1)) + spice_channel_set_capability(SPICE_CHANNEL(channel), SPICE_PLAYBACK_CAP_CELT_0_5_1); spice_channel_set_capability(SPICE_CHANNEL(channel), SPICE_PLAYBACK_CAP_VOLUME); spice_channel_set_capability(SPICE_CHANNEL(channel), SPICE_PLAYBACK_CAP_LATENCY); } @@ -107,15 +107,7 @@ static void spice_playback_channel_finalize(GObject *obj) { SpicePlaybackChannelPrivate *c = SPICE_PLAYBACK_CHANNEL(obj)->priv; - if (c->celt_decoder) { - celt051_decoder_destroy(c->celt_decoder); - c->celt_decoder = NULL; - } - - if (c->celt_mode) { - celt051_mode_destroy(c->celt_mode); - c->celt_mode = NULL; - } + snd_codec_destroy(&c->codec); g_free(c->volume); c->volume = NULL; @@ -174,15 +166,7 @@ static void spice_playback_channel_reset(SpiceChannel *channel, gboolean migrati { SpicePlaybackChannelPrivate *c = SPICE_PLAYBACK_CHANNEL(channel)->priv; - if (c->celt_decoder) { - celt051_decoder_destroy(c->celt_decoder); - c->celt_decoder = NULL; - } - - if (c->celt_mode) { - celt051_mode_destroy(c->celt_mode); - c->celt_mode = NULL; - } + snd_codec_destroy(&c->codec); SPICE_CHANNEL_CLASS(spice_playback_channel_parent_class)->channel_reset(channel, migrating); } @@ -379,18 +363,16 @@ static void playback_handle_data(SpiceChannel *channel, SpiceMsgIn *in) packet->data, packet->data_size); break; case SPICE_AUDIO_DATA_MODE_CELT_0_5_1: { - celt_int16_t pcm[256 * 2]; + uint8_t pcm[SND_CODEC_CELT_FRAME_SIZE * 2 * 2]; + int n = sizeof(pcm); - g_return_if_fail(c->celt_decoder != NULL); - - if (celt051_decode(c->celt_decoder, packet->data, - packet->data_size, pcm) != CELT_OK) { + if (snd_codec_decode(&c->codec, packet->data, packet->data_size, + pcm, &n) != SND_CODEC_OK) { g_warning("celt_decode() error"); return; } - emit_main_context(channel, SPICE_PLAYBACK_DATA, - (uint8_t *)pcm, sizeof(pcm)); + emit_main_context(channel, SPICE_PLAYBACK_DATA, pcm, n); break; } default: @@ -428,7 +410,6 @@ static void playback_handle_start(SpiceChannel *channel, SpiceMsgIn *in) { SpicePlaybackChannelPrivate *c = SPICE_PLAYBACK_CHANNEL(channel)->priv; SpiceMsgPlaybackStart *start = spice_msg_in_parsed(in); - int celt_mode_err; CHANNEL_DEBUG(channel, "%s: fmt %d channels %d freq %d time %d", __FUNCTION__, start->format, start->channels, start->frequency, start->time); @@ -444,19 +425,8 @@ static void playback_handle_start(SpiceChannel *channel, SpiceMsgIn *in) start->format, start->channels, start->frequency); break; case SPICE_AUDIO_DATA_MODE_CELT_0_5_1: { - /* TODO: only support one setting now */ - int frame_size = 256; - if (!c->celt_mode) - c->celt_mode = celt051_mode_create(start->frequency, start->channels, - frame_size, &celt_mode_err); - if (!c->celt_mode) - g_warning("create celt mode failed %d", celt_mode_err); - - if (!c->celt_decoder) - c->celt_decoder = celt051_decoder_create(c->celt_mode); - - if (!c->celt_decoder) - g_warning("create celt decoder failed"); + if (snd_codec_create(&c->codec, c->mode, start->frequency, FALSE, TRUE) != SND_CODEC_OK) + g_warning("create decoder failed"); emit_main_context(channel, SPICE_PLAYBACK_START, start->format, start->channels, start->frequency); diff --git a/gtk/channel-record.c b/gtk/channel-record.c index e1f3ec7..a80385b 100644 --- a/gtk/channel-record.c +++ b/gtk/channel-record.c @@ -15,8 +15,6 @@ You should have received a copy of the GNU Lesser General Public License along with this library; if not, see <http://www.gnu.org/licenses/>. */ -#include <celt051/celt.h> - #include "spice-client.h" #include "spice-common.h" #include "spice-channel-priv.h" @@ -24,6 +22,8 @@ #include "spice-marshal.h" #include "spice-session-priv.h" +#include "common/snd_codec.h" + /** * SECTION:channel-record * @short_description: audio stream for recording @@ -51,8 +51,7 @@ struct _SpiceRecordChannelPrivate { int mode; gboolean started; - CELTMode *celt_mode; - CELTEncoder *celt_encoder; + SndCodec codec; gsize frame_bytes; guint8 *last_frame; gsize last_frame_current; @@ -84,15 +83,13 @@ static guint signals[SPICE_RECORD_LAST_SIGNAL]; static void channel_set_handlers(SpiceChannelClass *klass); static void channel_up(SpiceChannel *channel); -#define FRAME_SIZE 256 -#define CELT_BIT_RATE (64 * 1024) - /* ------------------------------------------------------------------ */ static void spice_record_channel_reset_capabilities(SpiceChannel *channel) { if (!g_getenv("SPICE_DISABLE_CELT")) - spice_channel_set_capability(SPICE_CHANNEL(channel), SPICE_RECORD_CAP_CELT_0_5_1); + if (snd_codec_is_capable(SPICE_AUDIO_DATA_MODE_CELT_0_5_1)) + spice_channel_set_capability(SPICE_CHANNEL(channel), SPICE_RECORD_CAP_CELT_0_5_1); spice_channel_set_capability(SPICE_CHANNEL(channel), SPICE_RECORD_CAP_VOLUME); } @@ -110,15 +107,7 @@ static void spice_record_channel_finalize(GObject *obj) g_free(c->last_frame); c->last_frame = NULL; - if (c->celt_encoder) { - celt051_encoder_destroy(c->celt_encoder); - c->celt_encoder = NULL; - } - - if (c->celt_mode) { - celt051_mode_destroy(c->celt_mode); - c->celt_mode = NULL; - } + snd_codec_destroy(&c->codec); g_free(c->volume); c->volume = NULL; @@ -176,15 +165,7 @@ static void channel_reset(SpiceChannel *channel, gboolean migrating) g_free(c->last_frame); c->last_frame = NULL; - if (c->celt_encoder) { - celt051_encoder_destroy(c->celt_encoder); - c->celt_encoder = NULL; - } - - if (c->celt_mode) { - celt051_mode_destroy(c->celt_mode); - c->celt_mode = NULL; - } + snd_codec_destroy(&c->codec); SPICE_CHANNEL_CLASS(spice_record_channel_parent_class)->channel_reset(channel, migrating); } @@ -325,6 +306,7 @@ static void channel_up(SpiceChannel *channel) rc = SPICE_RECORD_CHANNEL(channel)->priv; if (!g_getenv("SPICE_DISABLE_CELT") && + snd_codec_is_capable(SPICE_AUDIO_DATA_MODE_CELT_0_5_1) && spice_channel_test_capability(channel, SPICE_RECORD_CAP_CELT_0_5_1)) { rc->mode = SPICE_AUDIO_DATA_MODE_CELT_0_5_1; } else { @@ -363,12 +345,12 @@ void spice_record_send_data(SpiceRecordChannel *channel, gpointer data, { SpiceRecordChannelPrivate *rc; SpiceMsgcRecordPacket p = {0, }; - int celt_compressed_frame_bytes = FRAME_SIZE * CELT_BIT_RATE / 44100 / 8; - uint8_t *celt_buf = NULL; g_return_if_fail(channel != NULL); g_return_if_fail(spice_channel_get_read_only(SPICE_CHANNEL(channel)) == FALSE); + uint8_t *encode_buf = NULL; + rc = channel->priv; if (!rc->started) { @@ -377,8 +359,8 @@ void spice_record_send_data(SpiceRecordChannel *channel, gpointer data, rc->started = TRUE; } - if (rc->mode == SPICE_AUDIO_DATA_MODE_CELT_0_5_1) - celt_buf = g_alloca(celt_compressed_frame_bytes); + if (rc->mode != SPICE_AUDIO_DATA_MODE_RAW) + encode_buf = g_alloca(SND_CODEC_MAX_COMPRESSED_BYTES); p.time = time; @@ -412,14 +394,14 @@ void spice_record_send_data(SpiceRecordChannel *channel, gpointer data, break; } - if (rc->mode == SPICE_AUDIO_DATA_MODE_CELT_0_5_1) { - frame_size = celt051_encode(rc->celt_encoder, (celt_int16_t *)frame, NULL, celt_buf, - celt_compressed_frame_bytes); - if (frame_size < 0) { - g_warning("celt encode failed"); + if (rc->mode != SPICE_AUDIO_DATA_MODE_RAW) { + int len = SND_CODEC_MAX_COMPRESSED_BYTES; + if (snd_codec_encode(&rc->codec, frame, frame_size, encode_buf, &len) != SND_CODEC_OK) { + g_warning("encode failed"); return; } - frame = celt_buf; + frame = encode_buf; + frame_size = len; } msg = spice_msg_out_new(SPICE_CHANNEL(channel), SPICE_MSGC_RECORD_DATA); @@ -446,42 +428,24 @@ static void record_handle_start(SpiceChannel *channel, SpiceMsgIn *in) CHANNEL_DEBUG(channel, "%s: fmt %d channels %d freq %d", __FUNCTION__, start->format, start->channels, start->frequency); - c->frame_bytes = FRAME_SIZE * 16 * start->channels / 8; + g_return_if_fail(start->format == SPICE_AUDIO_FMT_S16); - g_free(c->last_frame); - c->last_frame = g_malloc(c->frame_bytes); - c->last_frame_current = 0; + c->frame_bytes = SND_CODEC_MAX_FRAME_SIZE * 16 * start->channels / 8; - switch (c->mode) { - case SPICE_AUDIO_DATA_MODE_RAW: - emit_main_context(channel, SPICE_RECORD_START, - start->format, start->channels, start->frequency); - break; - case SPICE_AUDIO_DATA_MODE_CELT_0_5_1: { - int celt_mode_err; - - g_return_if_fail(start->format == SPICE_AUDIO_FMT_S16); - - if (!c->celt_mode) - c->celt_mode = celt051_mode_create(start->frequency, start->channels, FRAME_SIZE, - &celt_mode_err); - if (!c->celt_mode) - g_warning("Failed to create celt mode"); + if (c->mode == SPICE_AUDIO_DATA_MODE_CELT_0_5_1) + { + c->frame_bytes = SND_CODEC_CELT_FRAME_SIZE * 16 * start->channels / 8; - if (!c->celt_encoder) - c->celt_encoder = celt051_encoder_create(c->celt_mode); + if (snd_codec_create(&c->codec, c->mode, start->frequency, TRUE, FALSE) != SND_CODEC_OK) + g_warning("Failed to create encoder"); + } - if (!c->celt_encoder) - g_warning("Failed to create celt encoder"); + g_free(c->last_frame); + c->last_frame = g_malloc(c->frame_bytes); + c->last_frame_current = 0; - emit_main_context(channel, SPICE_RECORD_START, - start->format, start->channels, start->frequency); - break; - } - default: - g_warning("%s: unhandled mode %d", __FUNCTION__, c->mode); - break; - } + emit_main_context(channel, SPICE_RECORD_START, + start->format, start->channels, start->frequency); } /* coroutine context */ -- 1.7.10.4 _______________________________________________ Spice-devel mailing list Spice-devel@xxxxxxxxxxxxxxxxxxxxx http://lists.freedesktop.org/mailman/listinfo/spice-devel