36 const uint8_t *buf,
int buf_size)
39 const uint8_t *buf_end = buf + buf_size;
41 int frame_rate_index, ext_type, bytes_left;
42 int frame_rate_ext_n, frame_rate_ext_d;
43 int top_field_first, repeat_first_field, progressive_frame;
44 int horiz_size_ext, vert_size_ext, bit_rate_ext;
49 while (buf < buf_end) {
52 bytes_left = buf_end - buf;
55 if (bytes_left >= 2) {
60 if (bytes_left >= 7) {
61 pc->
width = (buf[0] << 4) | (buf[1] >> 4);
62 pc->
height = ((buf[1] & 0x0f) << 8) | buf[2];
67 frame_rate_index = buf[3] & 0xf;
70 avctx->
bit_rate = ((buf[4]<<10) | (buf[5]<<2) | (buf[6]>>6))*400;
75 if (bytes_left >= 1) {
76 ext_type = (buf[0] >> 4);
79 if (bytes_left >= 6) {
80 horiz_size_ext = ((buf[1] & 1) << 1) | (buf[2] >> 7);
81 vert_size_ext = (buf[2] >> 5) & 3;
82 bit_rate_ext = ((buf[2] & 0x1F)<<7) | (buf[3]>>1);
83 frame_rate_ext_n = (buf[5] >> 5) & 3;
84 frame_rate_ext_d = (buf[5] & 0x1f);
88 pc->
width |=(horiz_size_ext << 12);
89 pc->
height |=( vert_size_ext << 12);
90 avctx->
bit_rate += (bit_rate_ext << 18) * 400;
99 if (bytes_left >= 5) {
100 top_field_first = buf[3] & (1 << 7);
101 repeat_first_field = buf[3] & (1 << 1);
102 progressive_frame = buf[4] & (1 << 7);
106 if (repeat_first_field) {
112 }
else if (progressive_frame) {
137 const uint8_t **poutbuf,
int *poutbuf_size,
138 const uint8_t *buf,
int buf_size)
160 av_dlog(
NULL,
"pict_type=%d frame_rate=%0.3f repeat_pict=%d\n",
164 *poutbuf_size = buf_size;
169 const uint8_t *buf,
int buf_size)
174 for(i=0; i<buf_size; i++){
175 state= (state<<8) | buf[i];
176 if(state != 0x1B3 && state != 0x1B5 && state < 0x200 && state >= 0x100)