From: Michael Niedermayer Date: Mon, 22 Feb 2010 00:34:27 +0000 (+0000) Subject: Attempt to fix the completely random values returned by ff_avc_find_startcode(). X-Git-Tag: v0.6~1172 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=403c545d08c8cfeb335f3ecb508ef90a54a44037;p=platform%2Fupstream%2Flibav.git Attempt to fix the completely random values returned by ff_avc_find_startcode(). Originally committed as revision 21955 to svn://svn.ffmpeg.org/ffmpeg/trunk --- diff --git a/libavformat/avc.c b/libavformat/avc.c index 0731e39..f2b57cd 100644 --- a/libavformat/avc.c +++ b/libavformat/avc.c @@ -23,7 +23,7 @@ #include "avformat.h" #include "avio.h" -const uint8_t *ff_avc_find_startcode(const uint8_t *p, const uint8_t *end) +static const uint8_t *ff_avc_find_startcode_internal(const uint8_t *p, const uint8_t *end) { const uint8_t *a = p + 4 - ((intptr_t)p & 3); @@ -39,15 +39,15 @@ const uint8_t *ff_avc_find_startcode(const uint8_t *p, const uint8_t *end) if ((x - 0x01010101) & (~x) & 0x80808080) { // generic if (p[1] == 0) { if (p[0] == 0 && p[2] == 1) - return p-1; - if (p[2] == 0 && p[3] == 1) return p; + if (p[2] == 0 && p[3] == 1) + return p+1; } if (p[3] == 0) { if (p[2] == 0 && p[4] == 1) - return p+1; - if (p[4] == 0 && p[5] == 1) return p+2; + if (p[4] == 0 && p[5] == 1) + return p+3; } } } @@ -60,6 +60,12 @@ const uint8_t *ff_avc_find_startcode(const uint8_t *p, const uint8_t *end) return end + 3; } +const uint8_t *ff_avc_find_startcode(const uint8_t *p, const uint8_t *end){ + const uint8_t *out= ff_avc_find_startcode_internal(p, end); + if(p