diff options
-rw-r--r-- | ChangeLog | 11 | ||||
-rw-r--r-- | ext/wavpack/gstwavpackdec.c | 69 | ||||
-rw-r--r-- | ext/wavpack/gstwavpackdec.h | 1 |
3 files changed, 49 insertions, 32 deletions
@@ -1,5 +1,16 @@ 2006-07-18 Tim-Philipp Müller <tim at centricular dot net> + * ext/wavpack/gstwavpackdec.c: (gst_wavpack_dec_init), + (gst_wavpack_dec_format_samples), + (gst_wavpack_dec_clip_outgoing_buffer), (gst_wavpack_dec_chain), + (gst_wavpack_dec_change_state): + * ext/wavpack/gstwavpackdec.h: + Output audio in native byte order (which is also how we get + samples from wavpack); output samples with 21-24 bit depth + with 32 bit width (makes things easier for us). + +2006-07-18 Tim-Philipp Müller <tim at centricular dot net> + * ext/wavpack/gstwavpackdec.c: (gst_wavpack_dec_base_init), (gst_wavpack_dec_class_init), (gst_wavpack_dec_init), (gst_wavpack_dec_finalize), (gst_wavpack_dec_format_samples), diff --git a/ext/wavpack/gstwavpackdec.c b/ext/wavpack/gstwavpackdec.c index 69328a51..60a005f8 100644 --- a/ext/wavpack/gstwavpackdec.c +++ b/ext/wavpack/gstwavpackdec.c @@ -51,11 +51,11 @@ static GstStaticPadTemplate src_factory = GST_STATIC_PAD_TEMPLATE ("src", GST_PAD_SRC, GST_PAD_ALWAYS, GST_STATIC_CAPS ("audio/x-raw-int, " - "width = (int) { 8, 16, 24, 32 }, " - "depth = (int) { 8, 16, 24, 32 }, " + "width = (int) { 8, 16, 32 }, " + "depth = (int) [ 8, 32 ], " "channels = (int) [ 1, 2 ], " "rate = (int) [ 6000, 192000 ], " - "endianness = (int) LITTLE_ENDIAN, " "signed = (boolean) true") + "endianness = (int) BYTE_ORDER, " "signed = (boolean) true") ); static GstFlowReturn gst_wavpack_dec_chain (GstPad * pad, GstBuffer * buffer); @@ -121,6 +121,7 @@ gst_wavpack_dec_init (GstWavpackDec * dec, GstWavpackDecClass * gklass) dec->channels = 0; dec->sample_rate = 0; dec->width = 0; + dec->depth = 0; gst_segment_init (&dec->segment, GST_FORMAT_UNDEFINED); } @@ -137,39 +138,40 @@ gst_wavpack_dec_finalize (GObject * object) } static void -gst_wavpack_dec_format_samples (GstWavpackDec * dec, guint8 * dst, +gst_wavpack_dec_format_samples (GstWavpackDec * dec, guint8 * out_buffer, int32_t * samples, guint num_samples) { - gint i; - int32_t temp; - switch (dec->width) { - case 8: - for (i = 0; i < num_samples * dec->channels; ++i) - *dst++ = (guint8) (*samples++); - break; - case 16: - for (i = 0; i < num_samples * dec->channels; ++i) { - *dst++ = (guint8) (temp = *samples++); - *dst++ = (guint8) (temp >> 8); + case 8:{ + gint8 *dst = (gint8 *) out_buffer; + gint8 *end = dst + (num_samples * dec->channels); + + while (dst < end) { + *dst++ = (gint8) * samples++; } break; - case 24: - for (i = 0; i < num_samples * dec->channels; ++i) { - *dst++ = (guint8) (temp = *samples++); - *dst++ = (guint8) (temp >> 8); - *dst++ = (guint8) (temp >> 16); + } + case 16:{ + gint16 *dst = (gint16 *) out_buffer; + gint16 *end = dst + (num_samples * dec->channels); + + while (dst < end) { + *dst++ = (gint16) * samples++; } break; - case 32: - for (i = 0; i < num_samples * dec->channels; ++i) { - *dst++ = (guint8) (temp = *samples++); - *dst++ = (guint8) (temp >> 8); - *dst++ = (guint8) (temp >> 16); - *dst++ = (guint8) (temp >> 24); + } + case 24: + case 32:{ + gint32 *dst = (gint32 *) out_buffer; + gint32 *end = dst + (num_samples * dec->channels); + + while (dst < end) { + *dst++ = *samples++; } break; + } default: + g_return_if_reached (); break; } } @@ -193,7 +195,7 @@ gst_wavpack_dec_clip_outgoing_buffer (GstWavpackDec * dec, GstBuffer * buf) GST_BUFFER_TIMESTAMP (buf) = cstart; GST_BUFFER_DURATION (buf) -= diff; - diff = ((dec->width + 7) >> 3) * dec->channels + diff = (dec->width / 8) * dec->channels * GST_CLOCK_TIME_TO_FRAMES (diff, dec->sample_rate); GST_BUFFER_DATA (buf) += diff; GST_BUFFER_SIZE (buf) -= diff; @@ -203,7 +205,7 @@ gst_wavpack_dec_clip_outgoing_buffer (GstWavpackDec * dec, GstBuffer * buf) if (diff > 0) { GST_BUFFER_DURATION (buf) -= diff; - diff = ((dec->width + 7) >> 3) * dec->channels + diff = (dec->width / 8) * dec->channels * GST_CLOCK_TIME_TO_FRAMES (diff, dec->sample_rate); GST_BUFFER_SIZE (buf) -= diff; } @@ -269,19 +271,21 @@ gst_wavpack_dec_chain (GstPad * pad, GstBuffer * buf) format_changed = (dec->sample_rate != WavpackGetSampleRate (dec->context)) || (dec->channels != WavpackGetNumChannels (dec->context)) || - (dec->width != WavpackGetBitsPerSample (dec->context)); + (dec->depth != WavpackGetBitsPerSample (dec->context)); if (!GST_PAD_CAPS (dec->srcpad) || format_changed) { GstCaps *caps; dec->sample_rate = WavpackGetSampleRate (dec->context); dec->channels = WavpackGetNumChannels (dec->context); - dec->width = WavpackGetBitsPerSample (dec->context); + dec->depth = WavpackGetBitsPerSample (dec->context); + dec->width = + (GST_ROUND_UP_8 (dec->depth) == 24) ? 32 : GST_ROUND_UP_8 (dec->depth); caps = gst_caps_new_simple ("audio/x-raw-int", "rate", G_TYPE_INT, dec->sample_rate, "channels", G_TYPE_INT, dec->channels, - "depth", G_TYPE_INT, dec->width, + "depth", G_TYPE_INT, dec->depth, "width", G_TYPE_INT, dec->width, "endianness", G_TYPE_INT, G_LITTLE_ENDIAN, "signed", G_TYPE_BOOLEAN, TRUE, NULL); @@ -293,7 +297,7 @@ gst_wavpack_dec_chain (GstPad * pad, GstBuffer * buf) gst_caps_unref (caps); } - unpacked_size = wph.block_samples * ((dec->width + 7) >> 3) * dec->channels; + unpacked_size = wph.block_samples * (dec->width / 8) * dec->channels; /* alloc buffer */ ret = gst_pad_alloc_buffer (dec->srcpad, GST_BUFFER_OFFSET (buf), @@ -423,6 +427,7 @@ gst_wavpack_dec_change_state (GstElement * element, GstStateChange transition) dec->channels = 0; dec->sample_rate = 0; dec->width = 0; + dec->depth = 0; break; case GST_STATE_CHANGE_READY_TO_NULL: break; diff --git a/ext/wavpack/gstwavpackdec.h b/ext/wavpack/gstwavpackdec.h index 7a866ccb..d2e66d95 100644 --- a/ext/wavpack/gstwavpackdec.h +++ b/ext/wavpack/gstwavpackdec.h @@ -60,6 +60,7 @@ struct _GstWavpackDec guint sample_rate; guint width; + guint depth; guint channels; gint error_count; |