1
0
mirror of git://git.gnupg.org/gnupg.git synced 2025-01-07 12:34:25 +01:00

gpg: Emit status lines for errors in the compression layer.

* g10/compress-bz2.c: Replace all log_fatal by log_error,
write_status_error, and g10_exit.
(do_uncompress): Ditto.
--

This gives gpgme a better way to detect corrupted data in the
compression layer.
GnuPG-bug-id: 6977
This commit is contained in:
Werner Koch 2024-02-27 11:33:21 +01:00
parent 962058f704
commit dcab895e4c
No known key found for this signature in database
GPG Key ID: E3FDFF218E45B72B
2 changed files with 39 additions and 15 deletions

View File

@ -53,7 +53,11 @@ init_compress( compress_filter_context_t *zfx, bz_stream *bzs )
} }
if((rc=BZ2_bzCompressInit(bzs,level,0,0))!=BZ_OK) if((rc=BZ2_bzCompressInit(bzs,level,0,0))!=BZ_OK)
log_fatal("bz2lib problem: %d\n",rc); {
log_error ("bz2lib problem: %d\n",rc);
write_status_error ("bzip2.init", gpg_error (GPG_ERR_INTERNAL));
g10_exit (2);
}
zfx->outbufsize = 8192; zfx->outbufsize = 8192;
zfx->outbuf = xmalloc( zfx->outbufsize ); zfx->outbuf = xmalloc( zfx->outbufsize );
@ -80,7 +84,11 @@ do_compress(compress_filter_context_t *zfx, bz_stream *bzs, int flush, IOBUF a)
if( zrc == BZ_STREAM_END && flush == BZ_FINISH ) if( zrc == BZ_STREAM_END && flush == BZ_FINISH )
; ;
else if( zrc != BZ_RUN_OK && zrc != BZ_FINISH_OK ) else if( zrc != BZ_RUN_OK && zrc != BZ_FINISH_OK )
log_fatal("bz2lib deflate problem: rc=%d\n", zrc ); {
log_error ("bz2lib deflate problem: rc=%d\n", zrc );
write_status_error ("bzip2.deflate", gpg_error (GPG_ERR_INTERNAL));
g10_exit (2);
}
n = zfx->outbufsize - bzs->avail_out; n = zfx->outbufsize - bzs->avail_out;
if( DBG_FILTER ) if( DBG_FILTER )
@ -91,7 +99,7 @@ do_compress(compress_filter_context_t *zfx, bz_stream *bzs, int flush, IOBUF a)
if( (rc=iobuf_write( a, zfx->outbuf, n )) ) if( (rc=iobuf_write( a, zfx->outbuf, n )) )
{ {
log_debug("bzCompress: iobuf_write failed\n"); log_error ("bzCompress: iobuf_write failed\n");
return rc; return rc;
} }
} }
@ -106,7 +114,11 @@ init_uncompress( compress_filter_context_t *zfx, bz_stream *bzs )
int rc; int rc;
if((rc=BZ2_bzDecompressInit(bzs,0,opt.bz2_decompress_lowmem))!=BZ_OK) if((rc=BZ2_bzDecompressInit(bzs,0,opt.bz2_decompress_lowmem))!=BZ_OK)
log_fatal("bz2lib problem: %d\n",rc); {
log_error ("bz2lib problem: %d\n",rc);
write_status_error ("bzip2.init.un", gpg_error (GPG_ERR_INTERNAL));
g10_exit (2);
}
zfx->inbufsize = 2048; zfx->inbufsize = 2048;
zfx->inbuf = xmalloc( zfx->inbufsize ); zfx->inbuf = xmalloc( zfx->inbufsize );
@ -159,7 +171,11 @@ do_uncompress( compress_filter_context_t *zfx, bz_stream *bzs,
if( zrc == BZ_STREAM_END ) if( zrc == BZ_STREAM_END )
rc = -1; /* eof */ rc = -1; /* eof */
else if( zrc != BZ_OK && zrc != BZ_PARAM_ERROR ) else if( zrc != BZ_OK && zrc != BZ_PARAM_ERROR )
log_fatal("bz2lib inflate problem: rc=%d\n", zrc ); {
log_error ("bz2lib inflate problem: rc=%d\n", zrc );
write_status_error ("bzip2.inflate", gpg_error (GPG_ERR_BAD_DATA));
g10_exit (2);
}
else if (zrc == BZ_OK && eofseen else if (zrc == BZ_OK && eofseen
&& !bzs->avail_in && bzs->avail_out > 0) && !bzs->avail_in && bzs->avail_out > 0)
{ {

View File

@ -73,10 +73,12 @@ init_compress( compress_filter_context_t *zfx, z_stream *zs )
-13, 8, Z_DEFAULT_STRATEGY) -13, 8, Z_DEFAULT_STRATEGY)
: deflateInit( zs, level ) : deflateInit( zs, level )
) != Z_OK ) { ) != Z_OK ) {
log_fatal("zlib problem: %s\n", zs->msg? zs->msg : log_error ("zlib problem: %s\n", zs->msg? zs->msg :
rc == Z_MEM_ERROR ? "out of core" : rc == Z_MEM_ERROR ? "out of core" :
rc == Z_VERSION_ERROR ? "invalid lib version" : rc == Z_VERSION_ERROR ? "invalid lib version" :
"unknown error" ); "unknown error" );
write_status_error ("zlib.init", gpg_error (GPG_ERR_INTERNAL));
g10_exit (2);
} }
zfx->outbufsize = 8192; zfx->outbufsize = 8192;
@ -104,9 +106,11 @@ do_compress( compress_filter_context_t *zfx, z_stream *zs, int flush, IOBUF a )
; ;
else if( zrc != Z_OK ) { else if( zrc != Z_OK ) {
if( zs->msg ) if( zs->msg )
log_fatal("zlib deflate problem: %s\n", zs->msg ); log_error ("zlib deflate problem: %s\n", zs->msg );
else else
log_fatal("zlib deflate problem: rc=%d\n", zrc ); log_error ("zlib deflate problem: rc=%d\n", zrc );
write_status_error ("zlib.deflate", gpg_error (GPG_ERR_INTERNAL));
g10_exit (2);
} }
n = zfx->outbufsize - zs->avail_out; n = zfx->outbufsize - zs->avail_out;
if( DBG_FILTER ) if( DBG_FILTER )
@ -116,7 +120,7 @@ do_compress( compress_filter_context_t *zfx, z_stream *zs, int flush, IOBUF a )
(unsigned)n, zrc ); (unsigned)n, zrc );
if( (rc=iobuf_write( a, zfx->outbuf, n )) ) { if( (rc=iobuf_write( a, zfx->outbuf, n )) ) {
log_debug("deflate: iobuf_write failed\n"); log_error ("deflate: iobuf_write failed\n");
return rc; return rc;
} }
} while( zs->avail_in || (flush == Z_FINISH && zrc != Z_STREAM_END) ); } while( zs->avail_in || (flush == Z_FINISH && zrc != Z_STREAM_END) );
@ -140,10 +144,12 @@ init_uncompress( compress_filter_context_t *zfx, z_stream *zs )
*/ */
if( (rc = zfx->algo == 1? inflateInit2( zs, -15) if( (rc = zfx->algo == 1? inflateInit2( zs, -15)
: inflateInit( zs )) != Z_OK ) { : inflateInit( zs )) != Z_OK ) {
log_fatal("zlib problem: %s\n", zs->msg? zs->msg : log_error ("zlib problem: %s\n", zs->msg? zs->msg :
rc == Z_MEM_ERROR ? "out of core" : rc == Z_MEM_ERROR ? "out of core" :
rc == Z_VERSION_ERROR ? "invalid lib version" : rc == Z_VERSION_ERROR ? "invalid lib version" :
"unknown error" ); "unknown error" );
write_status_error ("zlib.init.un", gpg_error (GPG_ERR_INTERNAL));
g10_exit (2);
} }
zfx->inbufsize = 2048; zfx->inbufsize = 2048;
@ -198,9 +204,11 @@ do_uncompress( compress_filter_context_t *zfx, z_stream *zs,
rc = -1; /* eof */ rc = -1; /* eof */
else if( zrc != Z_OK && zrc != Z_BUF_ERROR ) { else if( zrc != Z_OK && zrc != Z_BUF_ERROR ) {
if( zs->msg ) if( zs->msg )
log_fatal("zlib inflate problem: %s\n", zs->msg ); log_error ("zlib inflate problem: %s\n", zs->msg );
else else
log_fatal("zlib inflate problem: rc=%d\n", zrc ); log_error ("zlib inflate problem: rc=%d\n", zrc );
write_status_error ("zlib.inflate", gpg_error (GPG_ERR_BAD_DATA));
g10_exit (2);
} }
} while (zs->avail_out && zrc != Z_STREAM_END && zrc != Z_BUF_ERROR } while (zs->avail_out && zrc != Z_STREAM_END && zrc != Z_BUF_ERROR
&& !leave); && !leave);