mirror of
				https://github.com/webmproject/libwebp.git
				synced 2025-10-31 10:25:46 +01:00 
			
		
		
		
	Fix invalid incremental decoding check.
(cherry picked from commit 95ea5226c8)
Change-Id: I80c2165aa9fdf43077db155d2d00e0e99db73eab
			
			
This commit is contained in:
		| @@ -1237,9 +1237,20 @@ static int DecodeImageData(VP8LDecoder* const dec, uint32_t* const data, | |||||||
|   } |   } | ||||||
|  |  | ||||||
|   br->eos_ = VP8LIsEndOfStream(br); |   br->eos_ = VP8LIsEndOfStream(br); | ||||||
|   if (dec->incremental_ && br->eos_ && src < src_end) { |   // In incremental decoding: | ||||||
|  |   // br->eos_ && src < src_last: if 'br' reached the end of the buffer and | ||||||
|  |   // 'src_last' has not been reached yet, there is not enough data. 'dec' has to | ||||||
|  |   // be reset until there is more data. | ||||||
|  |   // !br->eos_ && src < src_last: this cannot happen as either the buffer is | ||||||
|  |   // fully read, either enough has been read to reach 'src_last'. | ||||||
|  |   // src >= src_last: 'src_last' is reached, all is fine. 'src' can actually go | ||||||
|  |   // beyond 'src_last' in case the image is cropped and an LZ77 goes further. | ||||||
|  |   // The buffer might have been enough or there is some left. 'br->eos_' does | ||||||
|  |   // not matter. | ||||||
|  |   assert(!dec->incremental_ || (br->eos_ && src < src_last) || src >= src_last); | ||||||
|  |   if (dec->incremental_ && br->eos_ && src < src_last) { | ||||||
|     RestoreState(dec); |     RestoreState(dec); | ||||||
|   } else if (!br->eos_) { |   } else if ((dec->incremental_ && src >= src_last) || !br->eos_) { | ||||||
|     // Process the remaining rows corresponding to last row-block. |     // Process the remaining rows corresponding to last row-block. | ||||||
|     if (process_func != NULL) { |     if (process_func != NULL) { | ||||||
|       process_func(dec, row > last_row ? last_row : row); |       process_func(dec, row > last_row ? last_row : row); | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user