vqavideo: return error if image size is not a multiple of block size
The decoder assumes in various places that the image size is a multiple of the block size, and there is no obvious way to support odd sizes. Bailing out early if the header specifies a bad size avoids various errors later on. Fixes CVE-2012-0947. Signed-off-by: Mans Rullgard <mans@mansr.com> (cherry picked from commit58b2e0f0f2) Signed-off-by: Reinhard Tartler <siretart@tauware.de> (cherry picked from commitd5207e2af8) Signed-off-by: Reinhard Tartler <siretart@tauware.de> (cherry picked from commitc71c77e56f) Signed-off-by: Reinhard Tartler <siretart@tauware.de> (cherry picked from commit c90da45d5a7a4045dbf22fba52c63ef55d207269) Signed-off-by: Reinhard Tartler <siretart@tauware.de>
This commit is contained in:
		
				
					committed by
					
						
						Reinhard Tartler
					
				
			
			
				
	
			
			
			
						parent
						
							6c9b404dba
						
					
				
				
					commit
					468cc41d6d
				
			@@ -163,6 +163,12 @@ static av_cold int vqa_decode_init(AVCodecContext *avctx)
 | 
				
			|||||||
        return -1;
 | 
					        return -1;
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    if (s->width  & (s->vector_width  - 1) ||
 | 
				
			||||||
 | 
					        s->height & (s->vector_height - 1)) {
 | 
				
			||||||
 | 
					        av_log(avctx, AV_LOG_ERROR, "Image size not multiple of block size\n");
 | 
				
			||||||
 | 
					        return AVERROR_INVALIDDATA;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    /* allocate codebooks */
 | 
					    /* allocate codebooks */
 | 
				
			||||||
    s->codebook_size = MAX_CODEBOOK_SIZE;
 | 
					    s->codebook_size = MAX_CODEBOOK_SIZE;
 | 
				
			||||||
    s->codebook = av_malloc(s->codebook_size);
 | 
					    s->codebook = av_malloc(s->codebook_size);
 | 
				
			||||||
 
 | 
				
			|||||||
		Reference in New Issue
	
	Block a user