]> git.sesse.net Git - ffmpeg/blobdiff - libavcodec/iff.c
Merge commit '7f29644108c5fbd80f160930b31b78b8704c1a49'
[ffmpeg] / libavcodec / iff.c
index 4bde0a81174af4d3a481b7e9bfe69ada214240cc..f08a0f70cef6e9a24fe01426d5f87368eb481b10 100644 (file)
@@ -488,12 +488,12 @@ static int decode_byterun(uint8_t *dst, int dst_size,
         unsigned length;
         const int8_t value = *buf++;
         if (value >= 0) {
-            length = value + 1;
-            memcpy(dst + x, buf, FFMIN3(length, dst_size - x, buf_end - buf));
+            length = FFMIN3(value + 1, dst_size - x, buf_end - buf);
+            memcpy(dst + x, buf, length);
             buf += length;
         } else if (value > -128) {
-            length = -value + 1;
-            memset(dst + x, *buf++, FFMIN(length, dst_size - x));
+            length = FFMIN(-value + 1, dst_size - x);
+            memset(dst + x, *buf++, length);
         } else { // noop
             continue;
         }