decoder/DsdLib: check size before seeking
This commit is contained in:
		| @@ -112,19 +112,18 @@ dsdlib_tag_id3(InputStream &is, | |||||||
| 	if (tagoffset == 0 || !is.KnownSize()) | 	if (tagoffset == 0 || !is.KnownSize()) | ||||||
| 		return; | 		return; | ||||||
|  |  | ||||||
| 	if (!dsdlib_skip_to(nullptr, is, tagoffset)) |  | ||||||
| 		return; |  | ||||||
|  |  | ||||||
| 	/* Prevent broken files causing problems */ | 	/* Prevent broken files causing problems */ | ||||||
| 	const auto size = is.GetSize(); | 	const auto size = is.GetSize(); | ||||||
| 	if (tagoffset >= size) | 	if (tagoffset >= size) | ||||||
| 		return; | 		return; | ||||||
|  |  | ||||||
| 	const id3_length_t count = size - tagoffset; | 	const id3_length_t count = size - tagoffset; | ||||||
|  |  | ||||||
| 	if (count < 10 || count > 1024 * 1024) | 	if (count < 10 || count > 1024 * 1024) | ||||||
| 		return; | 		return; | ||||||
|  |  | ||||||
|  | 	if (!dsdlib_skip_to(nullptr, is, tagoffset)) | ||||||
|  | 		return; | ||||||
|  |  | ||||||
| 	id3_byte_t *const id3_buf = new id3_byte_t[count]; | 	id3_byte_t *const id3_buf = new id3_byte_t[count]; | ||||||
| 	if (id3_buf == nullptr) | 	if (id3_buf == nullptr) | ||||||
| 		return; | 		return; | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 Max Kellermann
					Max Kellermann