diff options
author | Even Rouault <even.rouault@spatialys.com> | 2020-11-14 12:51:06 +0000 |
---|---|---|
committer | Even Rouault <even.rouault@spatialys.com> | 2020-11-14 12:51:06 +0000 |
commit | bf84e70665b283f675a10a680aef4b327a4c3525 (patch) | |
tree | 766d29c421bbc48e500f8de0816fd2be9e49080b | |
parent | 7ade760d79a473b37d22a46fb74d87bcf4553ed5 (diff) | |
parent | a61c255236da08f023faa111c73186f66015068d (diff) | |
download | libtiff-git-bf84e70665b283f675a10a680aef4b327a4c3525.tar.gz |
Merge branch 'issue-204' into 'master'
avoid buffer overflow while writing jpeg end of file marker
Closes #204
See merge request libtiff/libtiff!161
-rw-r--r-- | tools/tiff2pdf.c | 14 |
1 files changed, 7 insertions, 7 deletions
diff --git a/tools/tiff2pdf.c b/tools/tiff2pdf.c index 719811ea..9f20bbea 100644 --- a/tools/tiff2pdf.c +++ b/tools/tiff2pdf.c @@ -2229,6 +2229,9 @@ int t2p_tile_is_corner_edge(T2P_TILES tiles, ttile_t tile){ return(t2p_tile_is_right_edge(tiles, tile) & t2p_tile_is_bottom_edge(tiles, tile) ); } +#if defined(JPEG_SUPPORT) || defined(OJPEG_SUPPORT) +static const unsigned char jpeg_eof_marker[] = { 0xff, 0xd9 }; +#endif /* This function reads the raster image data from the input TIFF for an image and writes @@ -2448,11 +2451,10 @@ tsize_t t2p_readwrite_pdf_image(T2P* t2p, TIFF* input, TIFF* output){ } bufferoffset += retTIFFReadRawStrip; } + t2pWriteFile(output, (tdata_t) buffer, bufferoffset); if( ! ( (buffer[bufferoffset-1]==0xd9) && (buffer[bufferoffset-2]==0xff) ) ){ - buffer[bufferoffset++]=0xff; - buffer[bufferoffset++]=0xd9; + t2pWriteFile(output, (tdata_t) jpeg_eof_marker, sizeof(jpeg_eof_marker)); } - t2pWriteFile(output, (tdata_t) buffer, bufferoffset); _TIFFfree(buffer); return(bufferoffset); #if 0 @@ -2533,9 +2535,8 @@ tsize_t t2p_readwrite_pdf_image(T2P* t2p, TIFF* input, TIFF* output){ return(0); } } - buffer[bufferoffset++]=0xff; - buffer[bufferoffset++]=0xd9; t2pWriteFile(output, (tdata_t) buffer, bufferoffset); + t2pWriteFile(output, (tdata_t) jpeg_eof_marker, sizeof(jpeg_eof_marker)); _TIFFfree(stripbuffer); _TIFFfree(buffer); return(bufferoffset); @@ -2999,9 +3000,8 @@ tsize_t t2p_readwrite_pdf_image_tile(T2P* t2p, TIFF* input, TIFF* output, ttile_ return(0); } bufferoffset += retTIFFReadRawTile; - ((unsigned char*)buffer)[bufferoffset++]=0xff; - ((unsigned char*)buffer)[bufferoffset++]=0xd9; t2pWriteFile(output, (tdata_t) buffer, bufferoffset); + t2pWriteFile(output, (tdata_t) jpeg_eof_marker, sizeof(jpeg_eof_marker)); _TIFFfree(buffer); return(bufferoffset); } |