|  |  | @@ -2371,6 +2371,7 @@ static int read_huffman_tree(AVCodecContext *avctx, GetBitContext *gb) | 
		
	
		
			
			|  |  |  | static int theora_decode_header(AVCodecContext *avctx, GetBitContext *gb) | 
		
	
		
			
			|  |  |  | { | 
		
	
		
			
			|  |  |  | Vp3DecodeContext *s = avctx->priv_data; | 
		
	
		
			
			|  |  |  | int visible_width, visible_height; | 
		
	
		
			
			|  |  |  | 
 | 
		
	
		
			
			|  |  |  | s->theora = get_bits_long(gb, 24); | 
		
	
		
			
			|  |  |  | av_log(avctx, AV_LOG_INFO, "Theora bitstream version %X\n", s->theora); | 
		
	
	
		
			
				|  |  | @@ -2399,16 +2400,11 @@ static int theora_decode_header(AVCodecContext *avctx, GetBitContext *gb) | 
		
	
		
			
			|  |  |  | 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 height */ | 
		
	
		
			
			|  |  |  | } | 
		
	
		
			
			|  |  |  | 
 | 
		
	
		
			
			|  |  |  | visible_width  = get_bits_long(gb, 24); | 
		
	
		
			
			|  |  |  | visible_height = get_bits_long(gb, 24); | 
		
	
		
			
			|  |  |  | 
 | 
		
	
		
			
			|  |  |  | if (s->theora >= 0x030200) { | 
		
	
		
			
			|  |  |  | skip_bits(gb, 8); /* offset x */ | 
		
	
		
			
			|  |  |  | skip_bits(gb, 8); /* offset y */ | 
		
	
	
		
			
				|  |  | @@ -2438,8 +2434,11 @@ static int theora_decode_header(AVCodecContext *avctx, GetBitContext *gb) | 
		
	
		
			
			|  |  |  | 
 | 
		
	
		
			
			|  |  |  | //    align_get_bits(gb); | 
		
	
		
			
			|  |  |  | 
 | 
		
	
		
			
			|  |  |  | avctx->width = s->width; | 
		
	
		
			
			|  |  |  | avctx->height = s->height; | 
		
	
		
			
			|  |  |  | if (   visible_width  <= s->width  && visible_width  > s->width-16 | 
		
	
		
			
			|  |  |  | && visible_height <= s->height && visible_height > s->height-16) | 
		
	
		
			
			|  |  |  | avcodec_set_dimensions(avctx, visible_width, visible_height); | 
		
	
		
			
			|  |  |  | else | 
		
	
		
			
			|  |  |  | avcodec_set_dimensions(avctx, s->width, s->height); | 
		
	
		
			
			|  |  |  | 
 | 
		
	
		
			
			|  |  |  | return 0; | 
		
	
		
			
			|  |  |  | } | 
		
	
	
		
			
				|  |  | 
 |