Commit 69324d1f authored by alex's avatar alex

Fixing theora _again_. DONT BOTHER BREAKING THIS AGAIN. Added support for...

Fixing theora _again_. DONT BOTHER BREAKING THIS AGAIN. Added support for Theora 3.4 and stream created by Elphel cameras are decodable.


git-svn-id: file:///var/local/repositories/ffmpeg/trunk@4703 9553f0bf-9b14-0410-a0b8-cfaf0461ba5b
parent ce7fb4ce
...@@ -2407,6 +2407,10 @@ static int vp3_decode_frame(AVCodecContext *avctx, ...@@ -2407,6 +2407,10 @@ static int vp3_decode_frame(AVCodecContext *avctx,
if (s->theora && get_bits1(&gb)) if (s->theora && get_bits1(&gb))
{ {
#if 1
av_log(avctx, AV_LOG_ERROR, "Header packet passed to frame decoder, skipping\n");
return -1;
#else
int ptype = get_bits(&gb, 7); int ptype = get_bits(&gb, 7);
skip_bits(&gb, 6*8); /* "theora" */ skip_bits(&gb, 6*8); /* "theora" */
...@@ -2424,6 +2428,7 @@ static int vp3_decode_frame(AVCodecContext *avctx, ...@@ -2424,6 +2428,7 @@ static int vp3_decode_frame(AVCodecContext *avctx,
av_log(avctx, AV_LOG_ERROR, "Unknown Theora config packet: %d\n", ptype); av_log(avctx, AV_LOG_ERROR, "Unknown Theora config packet: %d\n", ptype);
} }
return buf_size; return buf_size;
#endif
} }
s->keyframe = !get_bits1(&gb); s->keyframe = !get_bits1(&gb);
...@@ -2667,12 +2672,27 @@ static int theora_decode_header(AVCodecContext *avctx, GetBitContext gb) ...@@ -2667,12 +2672,27 @@ static int theora_decode_header(AVCodecContext *avctx, GetBitContext gb)
s->height = get_bits(&gb, 16) << 4; s->height = get_bits(&gb, 16) << 4;
if(avcodec_check_dimensions(avctx, s->width, s->height)){ if(avcodec_check_dimensions(avctx, s->width, s->height)){
av_log(avctx, AV_LOG_ERROR, "Invalid dimensions (%dx%d)\n", s->width, s->height);
s->width= s->height= 0; s->width= s->height= 0;
return -1; return -1;
} }
if (s->theora >= 0x030400)
{
skip_bits(&gb, 32); /* total number of superblocks in a frame */
// fixme, the next field is 36bits long
skip_bits(&gb, 32); /* total number of blocks in a frame */
skip_bits(&gb, 4); /* total number of blocks in a frame */
skip_bits(&gb, 32); /* total number of macroblocks in a frame */
skip_bits(&gb, 24); /* frame width */
skip_bits(&gb, 24); /* frame height */
}
else
{
skip_bits(&gb, 24); /* frame width */ skip_bits(&gb, 24); /* frame width */
skip_bits(&gb, 24); /* frame height */ skip_bits(&gb, 24); /* frame height */
}
skip_bits(&gb, 8); /* offset x */ skip_bits(&gb, 8); /* offset x */
skip_bits(&gb, 8); /* offset y */ skip_bits(&gb, 8); /* offset y */
...@@ -2685,13 +2705,17 @@ static int theora_decode_header(AVCodecContext *avctx, GetBitContext gb) ...@@ -2685,13 +2705,17 @@ static int theora_decode_header(AVCodecContext *avctx, GetBitContext gb)
if (s->theora < 0x030200) if (s->theora < 0x030200)
skip_bits(&gb, 5); /* keyframe frequency force */ skip_bits(&gb, 5); /* keyframe frequency force */
skip_bits(&gb, 8); /* colorspace */ skip_bits(&gb, 8); /* colorspace */
if (s->theora >= 0x030400)
skip_bits(&gb, 2); /* pixel format: 420,res,422,444 */
skip_bits(&gb, 24); /* bitrate */ skip_bits(&gb, 24); /* bitrate */
skip_bits(&gb, 6); /* last(?) quality index */ skip_bits(&gb, 6); /* quality hint */
if (s->theora >= 0x030200) if (s->theora >= 0x030200)
{ {
skip_bits(&gb, 5); /* keyframe frequency force */ skip_bits(&gb, 5); /* keyframe frequency force */
if (s->theora < 0x030400)
skip_bits(&gb, 5); /* spare bits */ skip_bits(&gb, 5); /* spare bits */
} }
...@@ -2703,25 +2727,53 @@ static int theora_decode_header(AVCodecContext *avctx, GetBitContext gb) ...@@ -2703,25 +2727,53 @@ static int theora_decode_header(AVCodecContext *avctx, GetBitContext gb)
return 0; return 0;
} }
static inline int theora_get_32bit(GetBitContext gb)
{
int ret = get_bits(&gb, 8);
ret += get_bits(&gb, 8) << 8;
ret += get_bits(&gb, 8) << 16;
ret += get_bits(&gb, 8) << 24;
return ret;
}
static int theora_decode_comments(AVCodecContext *avctx, GetBitContext gb) static int theora_decode_comments(AVCodecContext *avctx, GetBitContext gb)
{ {
int nb_comments, i, tmp; Vp3DecodeContext *s = avctx->priv_data;
int len;
if (s->theora <= 0x030200)
{
int i, comments;
tmp = get_bits_long(&gb, 32); // vendor string
tmp = be2me_32(tmp); len = get_bits_long(&gb, 32);
while(tmp--) len = le2me_32(len);
while(len--)
skip_bits(&gb, 8); skip_bits(&gb, 8);
nb_comments = get_bits_long(&gb, 32); // user comments
nb_comments = be2me_32(nb_comments); comments = get_bits_long(&gb, 32);
for (i = 0; i < nb_comments; i++) comments = le2me_32(comments);
for (i = 0; i < comments; i++)
{ {
tmp = get_bits_long(&gb, 32); len = get_bits_long(&gb, 32);
tmp = be2me_32(tmp); len = be2me_32(len);
while(tmp--) while(len--)
skip_bits(&gb, 8); skip_bits(&gb, 8);
} }
}
else
{
do {
len = get_bits_long(&gb, 32);
len = le2me_32(len);
if (len <= 0)
break;
while (len--)
skip_bits(&gb, 8);
} while (1);
}
return 0; return 0;
} }
...@@ -2758,7 +2810,7 @@ static int theora_decode_tables(AVCodecContext *avctx, GetBitContext gb) ...@@ -2758,7 +2810,7 @@ static int theora_decode_tables(AVCodecContext *avctx, GetBitContext gb)
else else
n = 3; n = 3;
if (n != 3) { if (n != 3) {
av_log(NULL,AV_LOG_ERROR, "unsupported nbms : %d\n", n); av_log(avctx,AV_LOG_ERROR, "unsupported nbms : %d\n", n);
return -1; return -1;
} }
/* y coeffs */ /* y coeffs */
...@@ -2793,7 +2845,7 @@ static int theora_decode_tables(AVCodecContext *avctx, GetBitContext gb) ...@@ -2793,7 +2845,7 @@ static int theora_decode_tables(AVCodecContext *avctx, GetBitContext gb)
skip_bits(&gb, av_log2(2)+1); skip_bits(&gb, av_log2(2)+1);
} }
if (qi > 63) if (qi > 63)
av_log(NULL, AV_LOG_ERROR, "error...\n"); av_log(avctx, AV_LOG_ERROR, "invalid qi %d > 63\n", qi);
} }
} }
} }
...@@ -2825,7 +2877,10 @@ static int theora_decode_init(AVCodecContext *avctx) ...@@ -2825,7 +2877,10 @@ static int theora_decode_init(AVCodecContext *avctx)
s->theora = 1; s->theora = 1;
if (!avctx->extradata_size) if (!avctx->extradata_size)
{
av_log(avctx, AV_LOG_ERROR, "Missing extradata!\n");
return -1; return -1;
}
for(i=0;i<3;i++) { for(i=0;i<3;i++) {
op_bytes = *(p++)<<8; op_bytes = *(p++)<<8;
...@@ -2838,8 +2893,12 @@ static int theora_decode_init(AVCodecContext *avctx) ...@@ -2838,8 +2893,12 @@ static int theora_decode_init(AVCodecContext *avctx)
debug_vp3("Theora headerpacket type: %x\n", ptype); debug_vp3("Theora headerpacket type: %x\n", ptype);
if (!(ptype & 0x80)) if (!(ptype & 0x80))
{
av_log(avctx, AV_LOG_ERROR, "Invalid extradata!\n");
return -1; return -1;
}
// FIXME: check for this aswell
skip_bits(&gb, 6*8); /* "theora" */ skip_bits(&gb, 6*8); /* "theora" */
switch(ptype) switch(ptype)
...@@ -2853,6 +2912,9 @@ static int theora_decode_init(AVCodecContext *avctx) ...@@ -2853,6 +2912,9 @@ static int theora_decode_init(AVCodecContext *avctx)
case 0x82: case 0x82:
theora_decode_tables(avctx, gb); theora_decode_tables(avctx, gb);
break; break;
default:
av_log(avctx, AV_LOG_ERROR, "Unknown Theora config packet: %d\n", ptype&~0x80);
break;
} }
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment