summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorZaheer Abbas Merali <zaheerabbas@merali.org>2008-02-27 12:34:00 +0000
committerZaheer Abbas Merali <zaheerabbas@merali.org>2008-02-27 12:34:00 +0000
commit4bf32cac7a2be3b16b1fa1945c7f3447510e2de9 (patch)
treed4873d8bf222fc7a950fd58f3b3ed48b15a72683
parent67e9c433df665aff6caf73e47108ddc4fb1d1de1 (diff)
downloadgst-plugins-bad-4bf32cac7a2be3b16b1fa1945c7f3447510e2de9.tar.gz
gst-plugins-bad-4bf32cac7a2be3b16b1fa1945c7f3447510e2de9.tar.bz2
gst-plugins-bad-4bf32cac7a2be3b16b1fa1945c7f3447510e2de9.zip
sys/dvb/camutils.c: Extra checks to prevent data corruption/segfaults.
Original commit message from CVS: * sys/dvb/camutils.c: Extra checks to prevent data corruption/segfaults.
-rw-r--r--ChangeLog5
-rw-r--r--sys/dvb/camutils.c30
2 files changed, 23 insertions, 12 deletions
diff --git a/ChangeLog b/ChangeLog
index e9539f5e..59de23c2 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,8 @@
+2008-02-27 Zaheer Abbas Merali <zaheerabbas at merali dot org>
+
+ * sys/dvb/camutils.c:
+ Extra checks to prevent data corruption/segfaults.
+
2008-02-26 Stefan Kost <ensonic@users.sf.net>
* ext/nas/nassink.c:
diff --git a/sys/dvb/camutils.c b/sys/dvb/camutils.c
index 1eb32175..b58eca1a 100644
--- a/sys/dvb/camutils.c
+++ b/sys/dvb/camutils.c
@@ -232,12 +232,14 @@ cam_build_ca_pmt (GstStructure * pmt, guint8 list_management, guint8 cmd_id,
streams = gst_structure_get_value (pmt, "streams");
value = gst_structure_get_value (pmt, "descriptors");
if (value != NULL) {
- program_descriptors = g_value_get_boxed (value);
- /* get the length of program level CA_descriptor()s */
- len = get_ca_descriptors_length (program_descriptors);
- if (len > 0)
- /* add one byte for the program level cmd_id */
- len += 1;
+ if (G_VALUE_HOLDS_BOXED (value)) {
+ program_descriptors = g_value_get_boxed (value);
+ /* get the length of program level CA_descriptor()s */
+ len = get_ca_descriptors_length (program_descriptors);
+ if (len > 0)
+ /* add one byte for the program level cmd_id */
+ len += 1;
+ }
}
lengths = g_list_append (lengths, GINT_TO_POINTER (len));
body_size += 6 + len;
@@ -249,12 +251,16 @@ cam_build_ca_pmt (GstStructure * pmt, guint8 list_management, guint8 cmd_id,
stream = g_value_get_boxed (value);
value = gst_structure_get_value (stream, "descriptors");
- stream_descriptors = g_value_get_boxed (value);
-
- len = get_ca_descriptors_length (stream_descriptors);
- if (len > 0)
- /* one byte for the stream level cmd_id */
- len += 1;
+ if (value != NULL) {
+ if (G_VALUE_HOLDS_BOXED (value)) {
+ stream_descriptors = g_value_get_boxed (value);
+
+ len = get_ca_descriptors_length (stream_descriptors);
+ if (len > 0)
+ /* one byte for the stream level cmd_id */
+ len += 1;
+ }
+ }
lengths = g_list_append (lengths, GINT_TO_POINTER (len));
body_size += 5 + len;