|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
#include "avformat.h" |
|
#include "rawdec.h" |
|
#include "libavcodec/startcode.h" |
|
#include "libavutil/intreadwrite.h" |
|
|
|
#define AVS2_ISSQH(x) ((x) == 0xB0) |
|
#define AVS2_ISEND(x) ((x) == 0xB1) |
|
#define AVS2_ISPIC(x) ((x) == 0xB3 || (x) == 0xB6) |
|
#define AVS2_ISUNIT(x) (AVS2_ISSQH(x) || AVS2_ISEND(x) || (x) == 0xB2 || AVS2_ISPIC(x) || (x) == 0xB5 || (x) == 0xB7) |
|
#define AVS2_ISPROFILE(x) ((x) == 0x20 || (x) == 0x22 || (x) == 0x30 || (x) == 0x32) |
|
|
|
static int avs2_probe(const AVProbeData *p) |
|
{ |
|
uint32_t code = -1, hds = 0, pic = 0, seq = 0; |
|
uint8_t state = 0; |
|
const uint8_t *ptr = p->buf, *end = p->buf + p->buf_size, *sqb = 0; |
|
if (AV_RB32(p->buf) != 0x1B0){ |
|
return 0; |
|
} |
|
|
|
while (ptr < end) { |
|
ptr = avpriv_find_start_code(ptr, end, &code); |
|
state = code & 0xFF; |
|
if ((code & 0xffffff00) == 0x100) { |
|
if (AVS2_ISUNIT(state)) { |
|
if (sqb && !hds) { |
|
hds = ptr - sqb; |
|
} |
|
if (AVS2_ISSQH(state)) { |
|
if (!AVS2_ISPROFILE(*ptr)) |
|
return 0; |
|
sqb = ptr; |
|
seq++; |
|
} else if (AVS2_ISPIC(state)) { |
|
pic++; |
|
} else if (AVS2_ISEND(state)) { |
|
break; |
|
} |
|
} |
|
} |
|
} |
|
if (seq && hds >= 21 && pic){ |
|
return AVPROBE_SCORE_EXTENSION + 2; |
|
} |
|
|
|
return 0; |
|
} |
|
|
|
FF_DEF_RAWVIDEO_DEMUXER(avs2, "raw AVS2-P2/IEEE1857.4", avs2_probe, "avs,avs2", AV_CODEC_ID_AVS2) |
|
|