linux/lib/xz
Lasse Collin 4f8d7abaa4 lib/xz: Validate the value before assigning it to an enum variable
This might matter, for example, if the underlying type of enum xz_check
was a signed char. In such a case the validation wouldn't have caught an
unsupported header. I don't know if this problem can occur in the kernel
on any arch but it's still good to fix it because some people might copy
the XZ code to their own projects from Linux instead of the upstream
XZ Embedded repository.

This change may increase the code size by a few bytes. An alternative
would have been to use an unsigned int instead of enum xz_check but
using an enumeration looks cleaner.

Link: https://lore.kernel.org/r/20211010213145.17462-3-xiang@kernel.org
Signed-off-by: Lasse Collin <lasse.collin@tukaani.org>
Signed-off-by: Gao Xiang <hsiangkao@linux.alibaba.com>
2021-10-19 23:44:30 +08:00
..
Kconfig docs: move remaining stuff under Documentation/*.txt to Documentation/staging 2020-06-19 14:17:05 -06:00
Makefile treewide: Add SPDX license identifier - Makefile/Kconfig 2019-05-21 10:50:46 +02:00
xz_crc32.c lib/: replace HTTP links with HTTPS ones 2020-08-12 10:58:00 -07:00
xz_dec_bcj.c lib/decompressors: fix spelling mistakes 2021-07-01 11:06:05 -07:00
xz_dec_lzma2.c lib/xz: Avoid overlapping memcpy() with invalid input with in-place decompression 2021-10-19 23:44:30 +08:00
xz_dec_stream.c lib/xz: Validate the value before assigning it to an enum variable 2021-10-19 23:44:30 +08:00
xz_dec_syms.c
xz_dec_test.c
xz_lzma2.h lib/: replace HTTP links with HTTPS ones 2020-08-12 10:58:00 -07:00
xz_private.h lib/xz: Put CRC32_POLY_LE in xz_private.h 2018-10-02 08:44:59 +10:00
xz_stream.h lib/: replace HTTP links with HTTPS ones 2020-08-12 10:58:00 -07:00