You've already forked FFmpeg
							
							
				mirror of
				https://github.com/FFmpeg/FFmpeg.git
				synced 2025-10-30 23:18:11 +02:00 
			
		
		
		
	Merge commit '061c489895d29049a88dc6118e4b639a273b31d6'
* commit '061c489895d29049a88dc6118e4b639a273b31d6': eamad: check for out of bounds read Conflicts: libavcodec/eamad.c Merged-by: Michael Niedermayer <michaelni@gmx.at>
This commit is contained in:
		| @@ -151,6 +151,11 @@ static inline int decode_block_intra(MadContext *s, int16_t * block) | |||||||
|                 break; |                 break; | ||||||
|             } else if (level != 0) { |             } else if (level != 0) { | ||||||
|                 i += run; |                 i += run; | ||||||
|  |                 if (i > 63) { | ||||||
|  |                     av_log(s->avctx, AV_LOG_ERROR, | ||||||
|  |                            "ac-tex damaged at %d %d\n", s->mb_x, s->mb_y); | ||||||
|  |                     return -1; | ||||||
|  |                 } | ||||||
|                 j = scantable[i]; |                 j = scantable[i]; | ||||||
|                 level = (level*quant_matrix[j]) >> 4; |                 level = (level*quant_matrix[j]) >> 4; | ||||||
|                 level = (level-1)|1; |                 level = (level-1)|1; | ||||||
| @@ -165,6 +170,11 @@ static inline int decode_block_intra(MadContext *s, int16_t * block) | |||||||
|                 run = SHOW_UBITS(re, &s->gb, 6)+1; LAST_SKIP_BITS(re, &s->gb, 6); |                 run = SHOW_UBITS(re, &s->gb, 6)+1; LAST_SKIP_BITS(re, &s->gb, 6); | ||||||
|  |  | ||||||
|                 i += run; |                 i += run; | ||||||
|  |                 if (i > 63) { | ||||||
|  |                     av_log(s->avctx, AV_LOG_ERROR, | ||||||
|  |                            "ac-tex damaged at %d %d\n", s->mb_x, s->mb_y); | ||||||
|  |                     return -1; | ||||||
|  |                 } | ||||||
|                 j = scantable[i]; |                 j = scantable[i]; | ||||||
|                 if (level < 0) { |                 if (level < 0) { | ||||||
|                     level = -level; |                     level = -level; | ||||||
| @@ -176,10 +186,6 @@ static inline int decode_block_intra(MadContext *s, int16_t * block) | |||||||
|                     level = (level-1)|1; |                     level = (level-1)|1; | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|             if (i > 63) { |  | ||||||
|                 av_log(s->avctx, AV_LOG_ERROR, "ac-tex damaged at %d %d\n", s->mb_x, s->mb_y); |  | ||||||
|                 return -1; |  | ||||||
|             } |  | ||||||
|  |  | ||||||
|             block[j] = level; |             block[j] = level; | ||||||
|         } |         } | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user