Blame SOURCES/0003-v4l2src-fix.patch

860d70
--- gst-plugins-good-0.10.31/sys/v4l2/gstv4l2object.c	2011-12-30 14:59:13.000000000 +0100
860d70
+++ gst-plugins-good-0.10.31.fixed/sys/v4l2/gstv4l2object.c	2012-06-05 23:45:16.670981047 +0200
860d70
@@ -1583,6 +1583,7 @@
860d70
 
860d70
   if (ival.type == V4L2_FRMIVAL_TYPE_DISCRETE) {
860d70
     GValue rate = { 0, };
860d70
+    guint i;
860d70
 
860d70
     g_value_init (&rates, GST_TYPE_LIST);
860d70
     g_value_init (&rate, GST_TYPE_FRACTION);
860d70
@@ -1602,7 +1603,16 @@
860d70
 
860d70
       /* swap to get the framerate */
860d70
       gst_value_set_fraction (&rate, denom, num);
860d70
-      gst_value_list_append_value (&rates, &rate;;
860d70
+      /* avoid duplicate framerates, yes some hw reports duplicates :( */
860d70
+      for (i = 0; i < gst_value_list_get_size(&rates); i++) {
860d70
+        const GValue *val = gst_value_list_get_value(&rates, i);
860d70
+        if (gst_value_compare(val, &rate) == GST_VALUE_EQUAL) {
860d70
+          break;
860d70
+        }
860d70
+      }
860d70
+      if (i == gst_value_list_get_size(&rates)) {
860d70
+        gst_value_list_append_value(&rates, &rate;;
860d70
+      }
860d70
 
860d70
       ival.index++;
860d70
     } while (v4l2_ioctl (fd, VIDIOC_ENUM_FRAMEINTERVALS, &ival) >= 0);