+2008-11-20 Wim Taymans <wim.taymans@collabora.co.uk>
+
+ * gst/wavparse/gstwavparse.c: (uint64_ceiling_scale_int),
+ (uint64_ceiling_scale), (gst_wavparse_calculate_duration),
+ (gst_wavparse_stream_headers):
+ Fix the scaling code.
+ Fix parsing of the INFO chunks, we were reading the wrong number of
+ bytes. Fixes #561580.
+
2008-11-20 Jan Schmidt <jan.schmidt@sun.com>
* gst/matroska/matroska-mux.c:
static guint64
uint64_ceiling_scale_int (guint64 val, gint num, gint denom)
{
- guint64 result = gst_util_uint64_scale (val, num, denom);
+ guint64 result = gst_util_uint64_scale_int (val, num, denom);
if (uint64_scale_modulo (val, num, denom) == 0)
return result;
static guint64
uint64_ceiling_scale (guint64 val, guint64 num, guint64 denom)
{
- guint64 result = gst_util_uint64_scale_int (val, num, denom);
+ guint64 result = gst_util_uint64_scale (val, num, denom);
if (uint64_scale_modulo (val, num, denom) == 0)
return result;
return TRUE;
if (wav->bps > 0) {
+ GST_INFO_OBJECT (wav, "Got datasize %" G_GUINT64_FORMAT, wav->datasize);
wav->duration =
uint64_ceiling_scale (wav->datasize, GST_SECOND, (guint64) wav->bps);
GST_INFO_OBJECT (wav, "Got duration (bps) %" GST_TIME_FORMAT,
}
switch (ltag) {
case GST_RIFF_LIST_INFO:{
- const guint data_size = size - 12;
+ const guint data_size = size - 4;
GstTagList *new;
GST_INFO_OBJECT (wav, "Have LIST chunk INFO");