summaryrefslogtreecommitdiffstats
path: root/ext/annodex/gstannodex.c
diff options
context:
space:
mode:
authorAlessandro Decina <alessandro@nnva.org>2006-08-25 09:42:43 +0000
committerWim Taymans <wim.taymans@gmail.com>2006-08-25 09:42:43 +0000
commit2f4517a70b9ef85bd18d232b6596848f8a285f7c (patch)
tree2f9e807b42c9ab22328452db45a03fe0930dc91d /ext/annodex/gstannodex.c
parent2019f527f701018622083cdbba4b12b4f53875de (diff)
ext/annodex/gstannodex.c: Do some extra sanity checks.
Original commit message from CVS: Patch by: Alessandro Decina <alessandro at nnva dot org> * ext/annodex/gstannodex.c: (gst_annodex_granule_to_time): Do some extra sanity checks. Fixes #350340. * ext/annodex/gstcmmlenc.c: (gst_cmml_enc_change_state), (gst_cmml_enc_parse_tag_head), (gst_cmml_enc_parse_tag_clip), (gst_cmml_enc_push_clip), (gst_cmml_enc_push): Check if clip->start_time is valid before adding the clip to the track list. Reset enc->preamble going from PAUSED to READY. Don't use GST_FLOW_UNEXPECTED for wrong usage of the element, it is only used for EOS. Only post an error message if we were the one that created the fatal GstFlowReturn value. * ext/annodex/gstcmmlutils.c: (gst_cmml_clock_time_from_npt), (gst_cmml_clock_time_to_granule), (gst_cmml_track_list_has_clip): Parse the seconds field of the npt-sec time format using %llu rather than %d and check that the value scaled by GST_SECOND doesn't overflow. Use guint64(s) to represent the keyindex and keyoffset fields of a granulepos. Lookup a clip's track with clip->track rather than clip->id which makes no sense. Identify a clip by its track and start time and not its xml id. do some more input checking and make sure we don't do undefined shifts. * tests/check/elements/cmmldec.c: (setup_cmmldec), (teardown_cmmldec), (check_output_buffer_is_equal), (push_data), (cmml_tag_message_pop), (check_headers), (push_clip_full), (push_clip), (push_empty_clip), (check_output_clip), (GST_START_TEST), (cmmldec_suite): * tests/check/elements/cmmlenc.c: (setup_cmmlenc), (teardown_cmmlenc), (check_output_buffer_is_equal), (push_data), (check_headers), (push_clip), (check_clip_times), (check_clip), (check_empty_clip), (GST_START_TEST), (cmmlenc_suite): Added some more checks.
Diffstat (limited to 'ext/annodex/gstannodex.c')
-rw-r--r--ext/annodex/gstannodex.c4
1 files changed, 3 insertions, 1 deletions
diff --git a/ext/annodex/gstannodex.c b/ext/annodex/gstannodex.c
index fa935f25..22fe798d 100644
--- a/ext/annodex/gstannodex.c
+++ b/ext/annodex/gstannodex.c
@@ -39,13 +39,15 @@ gst_annodex_granule_to_time (gint64 granulepos, gint64 granulerate_n,
gint64 granulerate;
GstClockTime res;
+ g_return_val_if_fail (granuleshift <= 64, GST_CLOCK_TIME_NONE);
+
if (granulepos == -1)
return GST_CLOCK_TIME_NONE;
if (granulepos == 0 || granulerate_n == 0 || granulerate_d == 0)
return 0;
- if (granuleshift != 0) {
+ if (granuleshift != 0 && granuleshift != 64) {
keyindex = granulepos >> granuleshift;
keyoffset = granulepos - (keyindex << granuleshift);
granulepos = keyindex + keyoffset;