NetBSD/usr.bin/gzip
kamil 2760f15b81 Correct Undefined Behavior in gzip(1)
Unportable left shift reported with MKSANITIZER=yes USE_SANITIZER=undefined:

# progress -zf ./games.tgz  tar -xp -C "./" -f -
/public/src.git/usr.bin/gzip/gzip.c:2126:33: runtime error: left shift of 251 by 24 places cannot be represented in type 'int'
100% |****************************************************************************************************************| 44500 KiB  119.69 MiB/s    00:00 ETA


Refactor the following code into something that is more clear
and fix signed integer shift, by casting all buf[] elements to
(unsigned int):

unsigned char buf[8];
uint32_t usize;
[...]
else {
    usize = buf[4] | buf[5] << 8 |
            buf[6] << 16 | buf[7] << 24;
[...]

New version:

    usize = buf[4];
    usize |= (unsigned int)buf[5] << 8;
    usize |= (unsigned int)buf[6] << 16;
    usize |= (unsigned int)buf[7] << 24;

Only the "<< 24" part needs explicit cast, but for consistency make the
integer promotion explicit and clear to a code reader.

Sponsored by <The NetBSD Foundation>
2018-06-12 00:42:17 +00:00
..
gzexe
gzexe.1
gzip.1 Add gunzip and zcat to the NAME section as well 2017-10-22 17:36:49 +00:00
gzip.c Correct Undefined Behavior in gzip(1) 2018-06-12 00:42:17 +00:00
Makefile
unbzip2.c add SIGINFO support. 2017-08-04 07:27:08 +00:00
unpack.c add SIGINFO support. 2017-08-04 07:27:08 +00:00
unxz.c add SIGINFO support. 2017-08-04 07:27:08 +00:00
zdiff
zdiff.1
zforce
zforce.1
zgrep
zgrep.1
zmore
zmore.1
znew
znew.1
zuncompress.c