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
release/0.6
Michael Niedermayer 15 years ago
parent dd4a03f7b3
commit 403c545d08
  1. 16
      libavformat/avc.c

@ -23,7 +23,7 @@
#include "avformat.h" #include "avformat.h"
#include "avio.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); 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 ((x - 0x01010101) & (~x) & 0x80808080) { // generic
if (p[1] == 0) { if (p[1] == 0) {
if (p[0] == 0 && p[2] == 1) if (p[0] == 0 && p[2] == 1)
return p-1;
if (p[2] == 0 && p[3] == 1)
return p; return p;
if (p[2] == 0 && p[3] == 1)
return p+1;
} }
if (p[3] == 0) { if (p[3] == 0) {
if (p[2] == 0 && p[4] == 1) if (p[2] == 0 && p[4] == 1)
return p+1;
if (p[4] == 0 && p[5] == 1)
return p+2; 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; 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<out && out<end && !out[-1]) out--;
return out;
}
int ff_avc_parse_nal_units(ByteIOContext *pb, const uint8_t *buf_in, int size) int ff_avc_parse_nal_units(ByteIOContext *pb, const uint8_t *buf_in, int size)
{ {
const uint8_t *p = buf_in; const uint8_t *p = buf_in;

Loading…
Cancel
Save