From bf45760b330d18dfde219b5601d2efbf4e88d8bf Mon Sep 17 00:00:00 2001 From: "Ronald S. Bultje" Date: Thu, 25 Nov 2004 20:36:29 +0000 Subject: Surround sound support. Original commit message from CVS: * ext/a52dec/gsta52dec.c: (gst_a52dec_channels), (gst_a52dec_push), (gst_a52dec_reneg), (gst_a52dec_loop), (plugin_init): * ext/alsa/gstalsa.c: (gst_alsa_get_caps): * ext/alsa/gstalsaplugin.c: (plugin_init): * ext/dts/gstdtsdec.c: (gst_dtsdec_channels), (gst_dtsdec_renegotiate), (gst_dtsdec_loop), (plugin_init): * ext/faad/gstfaad.c: (gst_faad_init), (gst_faad_chanpos_from_gst), (gst_faad_chanpos_to_gst), (gst_faad_sinkconnect), (gst_faad_srcgetcaps), (gst_faad_srcconnect), (gst_faad_chain), (gst_faad_change_state), (plugin_init): * ext/faad/gstfaad.h: * ext/vorbis/vorbis.c: (plugin_init): * ext/vorbis/vorbisdec.c: (vorbis_dec_chain): * gst-libs/gst/audio/Makefile.am: * gst-libs/gst/audio/audio.c: (plugin_init): * gst-libs/gst/audio/multichannel.c: (gst_audio_check_channel_positions), (gst_audio_get_channel_positions), (gst_audio_set_channel_positions), (gst_audio_set_structure_channel_positions_list), (add_list_to_struct), (gst_audio_set_caps_channel_positions_list), (gst_audio_fixate_channel_positions): * gst-libs/gst/audio/multichannel.h: * gst-libs/gst/audio/testchannels.c: (main): * gst/audioconvert/gstaudioconvert.c: (gst_audio_convert_class_init), (gst_audio_convert_init), (gst_audio_convert_dispose), (gst_audio_convert_getcaps), (gst_audio_convert_parse_caps), (gst_audio_convert_link), (gst_audio_convert_fixate), (gst_audio_convert_channels): * gst/audioconvert/plugin.c: (plugin_init): Surround sound support. --- ext/dts/gstdtsdec.c | 80 +++++++++++++++++++++++++++++++++++++++++++++++++---- 1 file changed, 74 insertions(+), 6 deletions(-) (limited to 'ext/dts') diff --git a/ext/dts/gstdtsdec.c b/ext/dts/gstdtsdec.c index db4bd7de..edcc8bcc 100644 --- a/ext/dts/gstdtsdec.c +++ b/ext/dts/gstdtsdec.c @@ -26,6 +26,8 @@ #include #include +#include + #include #include "gstdtsdec.h" @@ -180,42 +182,102 @@ gst_dtsdec_init (GstDtsDec * dtsdec) } static gint -gst_dtsdec_channels (uint32_t flags) +gst_dtsdec_channels (uint32_t flags, GstAudioChannelPosition ** pos) { gint chans = 0; switch (flags & DTS_CHANNEL_MASK) { case DTS_MONO: chans = 1; + if (pos) { + *pos = g_new (GstAudioChannelPosition, 2); + *pos[0] = GST_AUDIO_CHANNEL_POSITION_FRONT_MONO; + } break; - case DTS_CHANNEL: + /* case DTS_CHANNEL: */ case DTS_STEREO: case DTS_STEREO_SUMDIFF: case DTS_STEREO_TOTAL: case DTS_DOLBY: chans = 2; + if (pos) { + *pos = g_new (GstAudioChannelPosition, 3); + *pos[0] = GST_AUDIO_CHANNEL_POSITION_FRONT_LEFT; + *pos[1] = GST_AUDIO_CHANNEL_POSITION_FRONT_RIGHT; + } break; case DTS_3F: + chans = 3; + if (pos) { + *pos = g_new (GstAudioChannelPosition, 4); + *pos[0] = GST_AUDIO_CHANNEL_POSITION_FRONT_CENTER; + *pos[1] = GST_AUDIO_CHANNEL_POSITION_FRONT_LEFT; + *pos[2] = GST_AUDIO_CHANNEL_POSITION_FRONT_RIGHT; + } + break; case DTS_2F1R: chans = 3; + if (pos) { + *pos = g_new (GstAudioChannelPosition, 4); + *pos[0] = GST_AUDIO_CHANNEL_POSITION_FRONT_LEFT; + *pos[1] = GST_AUDIO_CHANNEL_POSITION_FRONT_RIGHT; + *pos[2] = GST_AUDIO_CHANNEL_POSITION_REAR_CENTER; + } break; case DTS_3F1R: + chans = 4; + if (pos) { + *pos = g_new (GstAudioChannelPosition, 5); + *pos[0] = GST_AUDIO_CHANNEL_POSITION_FRONT_CENTER; + *pos[1] = GST_AUDIO_CHANNEL_POSITION_FRONT_LEFT; + *pos[2] = GST_AUDIO_CHANNEL_POSITION_FRONT_RIGHT; + *pos[3] = GST_AUDIO_CHANNEL_POSITION_REAR_CENTER; + } + break; case DTS_2F2R: chans = 4; + if (pos) { + *pos = g_new (GstAudioChannelPosition, 5); + *pos[0] = GST_AUDIO_CHANNEL_POSITION_FRONT_LEFT; + *pos[1] = GST_AUDIO_CHANNEL_POSITION_FRONT_RIGHT; + *pos[2] = GST_AUDIO_CHANNEL_POSITION_REAR_LEFT; + *pos[3] = GST_AUDIO_CHANNEL_POSITION_REAR_RIGHT; + } break; case DTS_3F2R: chans = 5; + if (pos) { + *pos = g_new (GstAudioChannelPosition, 6); + *pos[0] = GST_AUDIO_CHANNEL_POSITION_FRONT_CENTER; + *pos[1] = GST_AUDIO_CHANNEL_POSITION_FRONT_LEFT; + *pos[2] = GST_AUDIO_CHANNEL_POSITION_FRONT_RIGHT; + *pos[3] = GST_AUDIO_CHANNEL_POSITION_REAR_LEFT; + *pos[4] = GST_AUDIO_CHANNEL_POSITION_REAR_RIGHT; + } break; case DTS_4F2R: chans = 6; + if (pos) { + *pos = g_new (GstAudioChannelPosition, 7); + *pos[0] = GST_AUDIO_CHANNEL_POSITION_FRONT_LEFT_OF_CENTER; + *pos[1] = GST_AUDIO_CHANNEL_POSITION_FRONT_RIGHT_OF_CENTER; + *pos[2] = GST_AUDIO_CHANNEL_POSITION_FRONT_LEFT; + *pos[3] = GST_AUDIO_CHANNEL_POSITION_FRONT_RIGHT; + *pos[4] = GST_AUDIO_CHANNEL_POSITION_REAR_LEFT; + *pos[5] = GST_AUDIO_CHANNEL_POSITION_REAR_RIGHT; + } break; default: /* error */ g_warning ("dtsdec: invalid flags 0x%x", flags); return 0; } - if (flags & DTS_LFE) + if (flags & DTS_LFE) { + if (pos) { + *pos[chans] = GST_AUDIO_CHANNEL_POSITION_LFE; + } chans += 1; + } return chans; } @@ -223,8 +285,12 @@ gst_dtsdec_channels (uint32_t flags) static gboolean gst_dtsdec_renegotiate (GstDtsDec * dts) { + GstAudioChannelPosition *pos; GstCaps *caps = gst_caps_from_string (DTS_CAPS); - gint channels = gst_dtsdec_channels (dts->using_channels); + gint channels = gst_dtsdec_channels (dts->using_channels, &pos); + + if (!channels) + return FALSE; GST_INFO ("dtsdec renegotiate, channels=%d, rate=%d", channels, dts->sample_rate); @@ -232,6 +298,8 @@ gst_dtsdec_renegotiate (GstDtsDec * dts) gst_caps_set_simple (caps, "channels", G_TYPE_INT, channels, "rate", G_TYPE_INT, (gint) dts->sample_rate, NULL); + gst_audio_set_channel_positions (gst_caps_get_structure (caps, 0), pos); + g_free (pos); return gst_pad_set_explicit_caps (dts->srcpad, caps); } @@ -381,7 +449,7 @@ gst_dtsdec_loop (GstElement * element) } samples = dts_samples (dts->state); - num_c = gst_dtsdec_channels (dts->using_channels); + num_c = gst_dtsdec_channels (dts->using_channels, NULL); out = gst_buffer_new_and_alloc ((SAMPLE_WIDTH / 8) * 256 * num_c); GST_BUFFER_TIMESTAMP (out) = timestamp; GST_BUFFER_DURATION (out) = GST_SECOND * 256 / dts->sample_rate; @@ -497,7 +565,7 @@ gst_dtsdec_get_property (GObject * object, guint prop_id, GValue * value, static gboolean plugin_init (GstPlugin * plugin) { - if (!gst_library_load ("gstbytestream")) + if (!gst_library_load ("gstbytestream") || !gst_library_load ("gstaudio")) return FALSE; if (!gst_element_register (plugin, "dtsdec", GST_RANK_PRIMARY, -- cgit v1.2.1