]> git.sesse.net Git - ffmpeg/commitdiff
avformat/mxfdec: use binary search in mxf_absolute_bodysid_offset
authorMarton Balint <cus@passwd.hu>
Sun, 18 Feb 2018 23:43:05 +0000 (00:43 +0100)
committerMarton Balint <cus@passwd.hu>
Fri, 9 Mar 2018 19:37:49 +0000 (20:37 +0100)
Signed-off-by: Marton Balint <cus@passwd.hu>
libavformat/mxfdec.c

index d4291f5dc79b347854551376ee5851ce5164e228..70091e0dc9f2154faea8aeacffb28da6fa93bde1 100644 (file)
@@ -1347,24 +1347,30 @@ static int mxf_get_sorted_table_segments(MXFContext *mxf, int *nb_sorted_segment
  */
 static int mxf_absolute_bodysid_offset(MXFContext *mxf, int body_sid, int64_t offset, int64_t *offset_out)
 {
-    int x;
     MXFPartition *last_p = NULL;
+    int a, b, m, m0;
 
     if (offset < 0)
         return AVERROR(EINVAL);
 
-    for (x = 0; x < mxf->partitions_count; x++) {
-        MXFPartition *p = &mxf->partitions[x];
+    a = -1;
+    b = mxf->partitions_count;
 
-        if (p->body_sid != body_sid)
-            continue;
+    while (b - a > 1) {
+        m0 = m = (a + b) >> 1;
 
-        if (p->body_offset > offset)
-            break;
+        while (m < b && mxf->partitions[m].body_sid != body_sid)
+            m++;
 
-        last_p = p;
+        if (m < b && mxf->partitions[m].body_offset <= offset)
+            a = m;
+        else
+            b = m0;
     }
 
+    if (a >= 0)
+        last_p = &mxf->partitions[a];
+
     if (last_p && (!last_p->essence_length || last_p->essence_length > (offset - last_p->body_offset))) {
         *offset_out = last_p->essence_offset + (offset - last_p->body_offset);
         return 0;