mirror of
				https://git.code.sf.net/p/libpng/code.git
				synced 2025-07-10 18:04:09 +02:00 
			
		
		
		
	Ensure that only one eXIf chunk is written in the entire datastream
EXIF data can be stored in an eXIf chunk before IDAT, or after IDAT, but the entire PNG datastream may contain one eXIf chunk at most. Introduce the private mode flag PNG_WROTE_eXIf, which is meant to be used like the PNG_WROTE_tIME flag. The eXIf chunk and the tIME chunk have the same ordering rules (i.e. no constraints are imposed), and the same multiplicity rules (i.e. no multiples are allowed), and they should be initialized and checked using the same algorithm. This fixes commit cd03aaf7bf0e0c748b8c6cb34a56b402b40d61d0, previously reverted in 3d57708c9166419b7f5e0bbda2f7a2149112c844. Reported-by: Ben Bullock <benkasminbullock@gmail.com>
This commit is contained in:
		
							parent
							
								
									8be5c147d5
								
							
						
					
					
						commit
						e6c5bf46c4
					
				| @ -1,7 +1,7 @@ | |||||||
| 
 | 
 | ||||||
| /* pngpriv.h - private declarations for use inside libpng
 | /* pngpriv.h - private declarations for use inside libpng
 | ||||||
|  * |  * | ||||||
|  * Copyright (c) 2018-2022 Cosmin Truta |  * Copyright (c) 2018-2023 Cosmin Truta | ||||||
|  * Copyright (c) 1998-2002,2004,2006-2018 Glenn Randers-Pehrson |  * Copyright (c) 1998-2002,2004,2006-2018 Glenn Randers-Pehrson | ||||||
|  * Copyright (c) 1996-1997 Andreas Dilger |  * Copyright (c) 1996-1997 Andreas Dilger | ||||||
|  * Copyright (c) 1995-1996 Guy Eric Schalnat, Group 42, Inc. |  * Copyright (c) 1995-1996 Guy Eric Schalnat, Group 42, Inc. | ||||||
| @ -626,7 +626,7 @@ | |||||||
| #define PNG_BACKGROUND_IS_GRAY     0x800U | #define PNG_BACKGROUND_IS_GRAY     0x800U | ||||||
| #define PNG_HAVE_PNG_SIGNATURE    0x1000U | #define PNG_HAVE_PNG_SIGNATURE    0x1000U | ||||||
| #define PNG_HAVE_CHUNK_AFTER_IDAT 0x2000U /* Have another chunk after IDAT */ | #define PNG_HAVE_CHUNK_AFTER_IDAT 0x2000U /* Have another chunk after IDAT */ | ||||||
|                    /*             0x4000U (unused) */ | #define PNG_WROTE_eXIf            0x4000U | ||||||
| #define PNG_IS_READ_STRUCT        0x8000U /* Else is a write struct */ | #define PNG_IS_READ_STRUCT        0x8000U /* Else is a write struct */ | ||||||
| 
 | 
 | ||||||
| /* Flags for the transformations the PNG library does on the image data */ | /* Flags for the transformations the PNG library does on the image data */ | ||||||
|  | |||||||
							
								
								
									
										31
									
								
								pngset.c
									
									
									
									
									
								
							
							
						
						
									
										31
									
								
								pngset.c
									
									
									
									
									
								
							| @ -137,44 +137,39 @@ png_set_cHRM_XYZ(png_const_structrp png_ptr, png_inforp info_ptr, double red_X, | |||||||
| #ifdef PNG_eXIf_SUPPORTED | #ifdef PNG_eXIf_SUPPORTED | ||||||
| void PNGAPI | void PNGAPI | ||||||
| png_set_eXIf(png_const_structrp png_ptr, png_inforp info_ptr, | png_set_eXIf(png_const_structrp png_ptr, png_inforp info_ptr, | ||||||
|     png_bytep eXIf_buf) |     png_bytep exif) | ||||||
| { | { | ||||||
|   png_warning(png_ptr, "png_set_eXIf does not work; use png_set_eXIf_1"); |   png_warning(png_ptr, "png_set_eXIf does not work; use png_set_eXIf_1"); | ||||||
|   PNG_UNUSED(info_ptr) |   PNG_UNUSED(info_ptr) | ||||||
|   PNG_UNUSED(eXIf_buf) |   PNG_UNUSED(exif) | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void PNGAPI | void PNGAPI | ||||||
| png_set_eXIf_1(png_const_structrp png_ptr, png_inforp info_ptr, | png_set_eXIf_1(png_const_structrp png_ptr, png_inforp info_ptr, | ||||||
|     png_uint_32 num_exif, png_bytep eXIf_buf) |     png_uint_32 num_exif, png_bytep exif) | ||||||
| { | { | ||||||
|    int i; |    png_bytep new_exif; | ||||||
| 
 | 
 | ||||||
|    png_debug1(1, "in %s storage function", "eXIf"); |    png_debug1(1, "in %s storage function", "eXIf"); | ||||||
| 
 | 
 | ||||||
|    if (png_ptr == NULL || info_ptr == NULL) |    if (png_ptr == NULL || info_ptr == NULL || | ||||||
|  |        (png_ptr->mode & PNG_WROTE_eXIf) != 0) | ||||||
|       return; |       return; | ||||||
| 
 | 
 | ||||||
|    if (info_ptr->exif) |    new_exif = png_voidcast(png_bytep, png_malloc_warn(png_ptr, num_exif)); | ||||||
|    { |  | ||||||
|       png_free(png_ptr, info_ptr->exif); |  | ||||||
|       info_ptr->exif = NULL; |  | ||||||
|    } |  | ||||||
| 
 | 
 | ||||||
|    info_ptr->num_exif = num_exif; |    if (new_exif == NULL) | ||||||
| 
 |  | ||||||
|    info_ptr->exif = png_voidcast(png_bytep, png_malloc_warn(png_ptr, |  | ||||||
|        info_ptr->num_exif)); |  | ||||||
| 
 |  | ||||||
|    if (info_ptr->exif == NULL) |  | ||||||
|    { |    { | ||||||
|       png_warning(png_ptr, "Insufficient memory for eXIf chunk data"); |       png_warning(png_ptr, "Insufficient memory for eXIf chunk data"); | ||||||
|       return; |       return; | ||||||
|    } |    } | ||||||
| 
 | 
 | ||||||
|    for (i = 0; i < (int) info_ptr->num_exif; i++) |    memcpy(new_exif, exif, (size_t)num_exif); | ||||||
|       info_ptr->exif[i] = eXIf_buf[i]; |  | ||||||
| 
 | 
 | ||||||
|  |    png_free_data(png_ptr, info_ptr, PNG_FREE_EXIF, 0); | ||||||
|  | 
 | ||||||
|  |    info_ptr->num_exif = num_exif; | ||||||
|  |    info_ptr->exif = new_exif; | ||||||
|    info_ptr->free_me |= PNG_FREE_EXIF; |    info_ptr->free_me |= PNG_FREE_EXIF; | ||||||
|    info_ptr->valid |= PNG_INFO_eXIf; |    info_ptr->valid |= PNG_INFO_eXIf; | ||||||
| } | } | ||||||
|  | |||||||
							
								
								
									
										10
									
								
								pngwrite.c
									
									
									
									
									
								
							
							
						
						
									
										10
									
								
								pngwrite.c
									
									
									
									
									
								
							| @ -1,7 +1,7 @@ | |||||||
| 
 | 
 | ||||||
| /* pngwrite.c - general routines to write a PNG file
 | /* pngwrite.c - general routines to write a PNG file
 | ||||||
|  * |  * | ||||||
|  * Copyright (c) 2018-2022 Cosmin Truta |  * Copyright (c) 2018-2023 Cosmin Truta | ||||||
|  * Copyright (c) 1998-2002,2004,2006-2018 Glenn Randers-Pehrson |  * Copyright (c) 1998-2002,2004,2006-2018 Glenn Randers-Pehrson | ||||||
|  * Copyright (c) 1996-1997 Andreas Dilger |  * Copyright (c) 1996-1997 Andreas Dilger | ||||||
|  * Copyright (c) 1995-1996 Guy Eric Schalnat, Group 42, Inc. |  * Copyright (c) 1995-1996 Guy Eric Schalnat, Group 42, Inc. | ||||||
| @ -239,7 +239,10 @@ png_write_info(png_structrp png_ptr, png_const_inforp info_ptr) | |||||||
| 
 | 
 | ||||||
| #ifdef PNG_WRITE_eXIf_SUPPORTED | #ifdef PNG_WRITE_eXIf_SUPPORTED | ||||||
|    if ((info_ptr->valid & PNG_INFO_eXIf) != 0) |    if ((info_ptr->valid & PNG_INFO_eXIf) != 0) | ||||||
|  |    { | ||||||
|       png_write_eXIf(png_ptr, info_ptr->exif, info_ptr->num_exif); |       png_write_eXIf(png_ptr, info_ptr->exif, info_ptr->num_exif); | ||||||
|  |       png_ptr->mode |= PNG_WROTE_eXIf; | ||||||
|  |    } | ||||||
| #endif | #endif | ||||||
| 
 | 
 | ||||||
| #ifdef PNG_WRITE_hIST_SUPPORTED | #ifdef PNG_WRITE_hIST_SUPPORTED | ||||||
| @ -439,8 +442,9 @@ png_write_end(png_structrp png_ptr, png_inforp info_ptr) | |||||||
| #endif | #endif | ||||||
| 
 | 
 | ||||||
| #ifdef PNG_WRITE_eXIf_SUPPORTED | #ifdef PNG_WRITE_eXIf_SUPPORTED | ||||||
|    if ((info_ptr->valid & PNG_INFO_eXIf) != 0) |       if ((info_ptr->valid & PNG_INFO_eXIf) != 0 && | ||||||
|       png_write_eXIf(png_ptr, info_ptr->exif, info_ptr->num_exif); |           (png_ptr->mode & PNG_WROTE_eXIf) == 0) | ||||||
|  |          png_write_eXIf(png_ptr, info_ptr->exif, info_ptr->num_exif); | ||||||
| #endif | #endif | ||||||
| 
 | 
 | ||||||
| #ifdef PNG_WRITE_UNKNOWN_CHUNKS_SUPPORTED | #ifdef PNG_WRITE_UNKNOWN_CHUNKS_SUPPORTED | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user
	 Cosmin Truta
						Cosmin Truta