aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorXin LI <delphij@FreeBSD.org>2024-02-25 19:07:13 +0000
committerXin LI <delphij@FreeBSD.org>2024-02-25 19:07:28 +0000
commita7819ed7ade8bf37ad82b0b26da9237692430eef (patch)
tree665b8949618e2499cf3216b8d780ccb9e4c758d5
parent039b23c9238cdf8995ad978ae6342957c2f819fa (diff)
downloadsrc-a7819ed7ade8bf37ad82b0b26da9237692430eef.tar.gz
src-a7819ed7ade8bf37ad82b0b26da9237692430eef.zip
Vendor import of xz 5.6.0 (trimmed)vendor/xz/5.6.0vendor/xz
-rw-r--r--AUTHORS40
-rw-r--r--COPYING116
-rw-r--r--COPYING.0BSD11
-rw-r--r--COPYING.CC-BY-SA-4.0427
-rw-r--r--ChangeLog15122
-rw-r--r--README43
-rw-r--r--THANKS7
-rw-r--r--TODO4
-rw-r--r--doxygen/Doxyfile6
-rw-r--r--doxygen/footer.html13
-rwxr-xr-xdoxygen/update-doxygen6
-rw-r--r--src/common/mythread.h28
-rw-r--r--src/common/sysdefs.h18
-rw-r--r--src/common/tuklib_common.h27
-rw-r--r--src/common/tuklib_config.h2
-rw-r--r--src/common/tuklib_cpucores.c5
-rw-r--r--src/common/tuklib_cpucores.h5
-rw-r--r--src/common/tuklib_exit.c5
-rw-r--r--src/common/tuklib_exit.h9
-rw-r--r--src/common/tuklib_gettext.h5
-rw-r--r--src/common/tuklib_integer.h7
-rw-r--r--src/common/tuklib_mbstr.h5
-rw-r--r--src/common/tuklib_mbstr_fw.c5
-rw-r--r--src/common/tuklib_mbstr_width.c5
-rw-r--r--src/common/tuklib_open_stdxxx.c5
-rw-r--r--src/common/tuklib_open_stdxxx.h5
-rw-r--r--src/common/tuklib_physmem.c25
-rw-r--r--src/common/tuklib_physmem.h5
-rw-r--r--src/common/tuklib_progname.c5
-rw-r--r--src/common/tuklib_progname.h5
-rw-r--r--src/liblzma/api/lzma.h31
-rw-r--r--src/liblzma/api/lzma/base.h23
-rw-r--r--src/liblzma/api/lzma/bcj.h10
-rw-r--r--src/liblzma/api/lzma/block.h5
-rw-r--r--src/liblzma/api/lzma/check.h5
-rw-r--r--src/liblzma/api/lzma/container.h43
-rw-r--r--src/liblzma/api/lzma/delta.h5
-rw-r--r--src/liblzma/api/lzma/filter.h11
-rw-r--r--src/liblzma/api/lzma/hardware.h5
-rw-r--r--src/liblzma/api/lzma/index.h36
-rw-r--r--src/liblzma/api/lzma/index_hash.h5
-rw-r--r--src/liblzma/api/lzma/lzma12.h7
-rw-r--r--src/liblzma/api/lzma/stream_flags.h5
-rw-r--r--src/liblzma/api/lzma/version.h9
-rw-r--r--src/liblzma/api/lzma/vli.h5
-rw-r--r--src/liblzma/check/check.c5
-rw-r--r--src/liblzma/check/check.h5
-rw-r--r--src/liblzma/check/crc32_arm64.h119
-rw-r--r--src/liblzma/check/crc32_fast.c187
-rw-r--r--src/liblzma/check/crc32_small.c5
-rw-r--r--src/liblzma/check/crc32_table.c36
-rw-r--r--src/liblzma/check/crc32_table_be.h4
-rw-r--r--src/liblzma/check/crc32_table_le.h4
-rw-r--r--src/liblzma/check/crc32_tablegen.c21
-rw-r--r--src/liblzma/check/crc32_x86.S5
-rw-r--r--src/liblzma/check/crc64_fast.c450
-rw-r--r--src/liblzma/check/crc64_small.c5
-rw-r--r--src/liblzma/check/crc64_table.c16
-rw-r--r--src/liblzma/check/crc64_table_be.h4
-rw-r--r--src/liblzma/check/crc64_table_le.h4
-rw-r--r--src/liblzma/check/crc64_tablegen.c13
-rw-r--r--src/liblzma/check/crc64_x86.S5
-rw-r--r--src/liblzma/check/crc_common.h143
-rw-r--r--src/liblzma/check/crc_macros.h30
-rw-r--r--src/liblzma/check/crc_x86_clmul.h435
-rw-r--r--src/liblzma/check/sha256.c19
-rw-r--r--src/liblzma/common/alone_decoder.c5
-rw-r--r--src/liblzma/common/alone_decoder.h5
-rw-r--r--src/liblzma/common/alone_encoder.c5
-rw-r--r--src/liblzma/common/auto_decoder.c5
-rw-r--r--src/liblzma/common/block_buffer_decoder.c5
-rw-r--r--src/liblzma/common/block_buffer_encoder.c5
-rw-r--r--src/liblzma/common/block_buffer_encoder.h5
-rw-r--r--src/liblzma/common/block_decoder.c5
-rw-r--r--src/liblzma/common/block_decoder.h5
-rw-r--r--src/liblzma/common/block_encoder.c5
-rw-r--r--src/liblzma/common/block_encoder.h5
-rw-r--r--src/liblzma/common/block_header_decoder.c5
-rw-r--r--src/liblzma/common/block_header_encoder.c5
-rw-r--r--src/liblzma/common/block_util.c5
-rw-r--r--src/liblzma/common/common.c5
-rw-r--r--src/liblzma/common/common.h5
-rw-r--r--src/liblzma/common/easy_buffer_encoder.c5
-rw-r--r--src/liblzma/common/easy_decoder_memusage.c5
-rw-r--r--src/liblzma/common/easy_encoder.c5
-rw-r--r--src/liblzma/common/easy_encoder_memusage.c5
-rw-r--r--src/liblzma/common/easy_preset.c5
-rw-r--r--src/liblzma/common/easy_preset.h5
-rw-r--r--src/liblzma/common/file_info.c5
-rw-r--r--src/liblzma/common/filter_buffer_decoder.c5
-rw-r--r--src/liblzma/common/filter_buffer_encoder.c5
-rw-r--r--src/liblzma/common/filter_common.c14
-rw-r--r--src/liblzma/common/filter_common.h5
-rw-r--r--src/liblzma/common/filter_decoder.c13
-rw-r--r--src/liblzma/common/filter_decoder.h5
-rw-r--r--src/liblzma/common/filter_encoder.c39
-rw-r--r--src/liblzma/common/filter_encoder.h11
-rw-r--r--src/liblzma/common/filter_flags_decoder.c5
-rw-r--r--src/liblzma/common/filter_flags_encoder.c5
-rw-r--r--src/liblzma/common/hardware_cputhreads.c5
-rw-r--r--src/liblzma/common/hardware_physmem.c5
-rw-r--r--src/liblzma/common/index.c5
-rw-r--r--src/liblzma/common/index.h5
-rw-r--r--src/liblzma/common/index_decoder.c5
-rw-r--r--src/liblzma/common/index_decoder.h5
-rw-r--r--src/liblzma/common/index_encoder.c5
-rw-r--r--src/liblzma/common/index_encoder.h5
-rw-r--r--src/liblzma/common/index_hash.c5
-rw-r--r--src/liblzma/common/lzip_decoder.c5
-rw-r--r--src/liblzma/common/lzip_decoder.h5
-rw-r--r--src/liblzma/common/memcmplen.h24
-rw-r--r--src/liblzma/common/microlzma_decoder.c5
-rw-r--r--src/liblzma/common/microlzma_encoder.c5
-rw-r--r--src/liblzma/common/outqueue.c5
-rw-r--r--src/liblzma/common/outqueue.h5
-rw-r--r--src/liblzma/common/stream_buffer_decoder.c5
-rw-r--r--src/liblzma/common/stream_buffer_encoder.c5
-rw-r--r--src/liblzma/common/stream_decoder.c5
-rw-r--r--src/liblzma/common/stream_decoder.h5
-rw-r--r--src/liblzma/common/stream_decoder_mt.c5
-rw-r--r--src/liblzma/common/stream_encoder.c5
-rw-r--r--src/liblzma/common/stream_encoder_mt.c25
-rw-r--r--src/liblzma/common/stream_flags_common.c5
-rw-r--r--src/liblzma/common/stream_flags_common.h5
-rw-r--r--src/liblzma/common/stream_flags_decoder.c5
-rw-r--r--src/liblzma/common/stream_flags_encoder.c5
-rw-r--r--src/liblzma/common/string_conversion.c14
-rw-r--r--src/liblzma/common/vli_decoder.c5
-rw-r--r--src/liblzma/common/vli_encoder.c5
-rw-r--r--src/liblzma/common/vli_size.c5
-rw-r--r--src/liblzma/delta/delta_common.c5
-rw-r--r--src/liblzma/delta/delta_common.h5
-rw-r--r--src/liblzma/delta/delta_decoder.c5
-rw-r--r--src/liblzma/delta/delta_decoder.h5
-rw-r--r--src/liblzma/delta/delta_encoder.c5
-rw-r--r--src/liblzma/delta/delta_encoder.h5
-rw-r--r--src/liblzma/delta/delta_private.h5
-rw-r--r--src/liblzma/liblzma.pc.in6
-rw-r--r--src/liblzma/liblzma_generic.map7
-rw-r--r--src/liblzma/liblzma_linux.map7
-rw-r--r--src/liblzma/lz/lz_decoder.c48
-rw-r--r--src/liblzma/lz/lz_decoder.h116
-rw-r--r--src/liblzma/lz/lz_encoder.c13
-rw-r--r--src/liblzma/lz/lz_encoder.h21
-rw-r--r--src/liblzma/lz/lz_encoder_hash.h5
-rw-r--r--src/liblzma/lz/lz_encoder_hash_table.h4
-rw-r--r--src/liblzma/lz/lz_encoder_mf.c5
-rw-r--r--src/liblzma/lzma/fastpos.h5
-rw-r--r--src/liblzma/lzma/fastpos_table.c4
-rw-r--r--src/liblzma/lzma/fastpos_tablegen.c17
-rw-r--r--src/liblzma/lzma/lzma2_decoder.c5
-rw-r--r--src/liblzma/lzma/lzma2_decoder.h5
-rw-r--r--src/liblzma/lzma/lzma2_encoder.c8
-rw-r--r--src/liblzma/lzma/lzma2_encoder.h5
-rw-r--r--src/liblzma/lzma/lzma_common.h41
-rw-r--r--src/liblzma/lzma/lzma_decoder.c760
-rw-r--r--src/liblzma/lzma/lzma_decoder.h5
-rw-r--r--src/liblzma/lzma/lzma_encoder.c18
-rw-r--r--src/liblzma/lzma/lzma_encoder.h5
-rw-r--r--src/liblzma/lzma/lzma_encoder_optimum_fast.c5
-rw-r--r--src/liblzma/lzma/lzma_encoder_optimum_normal.c7
-rw-r--r--src/liblzma/lzma/lzma_encoder_presets.c5
-rw-r--r--src/liblzma/lzma/lzma_encoder_private.h9
-rw-r--r--src/liblzma/rangecoder/price.h5
-rw-r--r--src/liblzma/rangecoder/price_table.c4
-rw-r--r--src/liblzma/rangecoder/price_tablegen.c22
-rw-r--r--src/liblzma/rangecoder/range_common.h14
-rw-r--r--src/liblzma/rangecoder/range_decoder.h838
-rw-r--r--src/liblzma/rangecoder/range_encoder.h5
-rw-r--r--src/liblzma/simple/arm.c5
-rw-r--r--src/liblzma/simple/arm64.c5
-rw-r--r--src/liblzma/simple/armthumb.c5
-rw-r--r--src/liblzma/simple/ia64.c5
-rw-r--r--src/liblzma/simple/powerpc.c5
-rw-r--r--src/liblzma/simple/riscv.c755
-rw-r--r--src/liblzma/simple/simple_coder.c5
-rw-r--r--src/liblzma/simple/simple_coder.h14
-rw-r--r--src/liblzma/simple/simple_decoder.c5
-rw-r--r--src/liblzma/simple/simple_decoder.h5
-rw-r--r--src/liblzma/simple/simple_encoder.c5
-rw-r--r--src/liblzma/simple/simple_encoder.h5
-rw-r--r--src/liblzma/simple/simple_private.h5
-rw-r--r--src/liblzma/simple/sparc.c5
-rw-r--r--src/liblzma/simple/x86.c5
-rw-r--r--src/liblzma/validate_map.sh6
-rw-r--r--src/lzmainfo/lzmainfo.14
-rw-r--r--src/lzmainfo/lzmainfo.c5
-rw-r--r--src/xz/args.c159
-rw-r--r--src/xz/args.h8
-rw-r--r--src/xz/coder.c648
-rw-r--r--src/xz/coder.h31
-rw-r--r--src/xz/file_io.c144
-rw-r--r--src/xz/file_io.h21
-rw-r--r--src/xz/hardware.c11
-rw-r--r--src/xz/hardware.h5
-rw-r--r--src/xz/list.c31
-rw-r--r--src/xz/list.h5
-rw-r--r--src/xz/main.c91
-rw-r--r--src/xz/main.h5
-rw-r--r--src/xz/message.c94
-rw-r--r--src/xz/message.h15
-rw-r--r--src/xz/mytime.c105
-rw-r--r--src/xz/mytime.h11
-rw-r--r--src/xz/options.c7
-rw-r--r--src/xz/options.h5
-rw-r--r--src/xz/private.h26
-rw-r--r--src/xz/sandbox.c355
-rw-r--r--src/xz/sandbox.h43
-rw-r--r--src/xz/signals.c22
-rw-r--r--src/xz/signals.h5
-rw-r--r--src/xz/suffix.c17
-rw-r--r--src/xz/suffix.h5
-rw-r--r--src/xz/util.c36
-rw-r--r--src/xz/util.h19
-rw-r--r--src/xz/xz.1439
-rw-r--r--src/xzdec/xzdec.18
-rw-r--r--src/xzdec/xzdec.c160
217 files changed, 12849 insertions, 10706 deletions
diff --git a/AUTHORS b/AUTHORS
index 69bbfc3ef609..5012d0e01e83 100644
--- a/AUTHORS
+++ b/AUTHORS
@@ -9,15 +9,13 @@ Authors of XZ Utils
specifically the LZMA SDK <https://7-zip.org/sdk.html>. Without
this code, XZ Utils wouldn't exist.
- The SHA-256 implementation in liblzma is based on the code found from
- 7-Zip <https://7-zip.org/>, which has a modified version of the SHA-256
- code found from Crypto++ <https://www.cryptopp.com/>. The SHA-256 code
- in Crypto++ was written by Kevin Springle and Wei Dai.
+ The SHA-256 implementation in liblzma is based on code written by
+ Wei Dai in Crypto++ Library <https://www.cryptopp.com/>.
- Some scripts have been adapted from gzip. The original versions
- were written by Jean-loup Gailly, Charles Levert, and Paul Eggert.
- Andrew Dudman helped adapting the scripts and their man pages for
- XZ Utils.
+ A few scripts have been adapted from GNU gzip. The original
+ versions were written by Jean-loup Gailly, Charles Levert, and
+ Paul Eggert. Andrew Dudman helped adapting the scripts and their
+ man pages for XZ Utils.
The initial version of the threaded .xz decompressor was written
by Sebastian Andrzej Siewior.
@@ -25,15 +23,31 @@ Authors of XZ Utils
The initial version of the .lz (lzip) decoder was written
by Michał Górny.
- CLMUL-accelerated CRC code was contributed by Ilya Kurdyukov.
+ Architecture-specific CRC optimizations were contributed by
+ Ilya Kurdyukov, Hans Jansen, and Chenxi Mao.
Other authors:
- Jonathan Nieder
- Joachim Henke
- The GNU Autotools-based build system contains files from many authors,
- which I'm not trying to list here.
+ Many people have contributed improvements or reported bugs.
+ Most of these people are mentioned in the file THANKS.
- Several people have contributed fixes or reported bugs. Most of them
- are mentioned in the file THANKS.
+ The translations of the command line tools and man pages have been
+ contributed by many people via the Translation Project:
+
+ - https://translationproject.org/domain/xz.html
+ - https://translationproject.org/domain/xz-man.html
+
+ The authors of the translated man pages are in the header comments
+ of the man page files. In the source package, the authors of the
+ translations are in po/*.po and po4a/*.po files.
+
+ Third-party code whose authors aren't listed here:
+
+ - GNU getopt_long() in the 'lib' directory is included for
+ platforms that don't have a usable getopt_long().
+
+ - The build system files from GNU Autoconf, GNU Automake,
+ GNU Libtool, GNU Gettext, Autoconf Archive, and related files.
diff --git a/COPYING b/COPYING
index e54eeacfbf3f..a31477d62d31 100644
--- a/COPYING
+++ b/COPYING
@@ -6,71 +6,95 @@ XZ Utils Licensing
is a rough summary of which licenses apply to which parts of this
package (but check the individual files to be sure!):
- - liblzma is in the public domain.
+ - liblzma is under the BSD Zero Clause License (0BSD).
- - xz, xzdec, and lzmadec command line tools are in the public
- domain unless GNU getopt_long had to be compiled and linked
- in from the lib directory. The getopt_long code is under
- GNU LGPLv2.1+.
+ - The command line tools xz, xzdec, lzmadec, and lzmainfo are
+ under 0BSD except that, on systems that don't have a usable
+ getopt_long, GNU getopt_long is compiled and linked in from the
+ 'lib' directory. The getopt_long code is under GNU LGPLv2.1+.
- The scripts to grep, diff, and view compressed files have been
- adapted from gzip. These scripts and their documentation are
- under GNU GPLv2+.
-
- - All the documentation in the doc directory and most of the
- XZ Utils specific documentation files in other directories
- are in the public domain.
+ adapted from GNU gzip. These scripts (xzgrep, xzdiff, xzless,
+ and xzmore) are under GNU GPLv2+. The man pages of the scripts
+ are under 0BSD; they aren't based on the man pages of GNU gzip.
+
+ - Most of the XZ Utils specific documentation that is in
+ plain text files (like README, INSTALL, PACKAGERS, NEWS,
+ and ChangeLog) are under 0BSD unless stated otherwise in
+ the file itself. The files xz-file-format.txt and
+ lzma-file-format.xt are in the public domain but may
+ be distributed under the terms of 0BSD too.
+
+ - Doxygen-generated HTML version of the liblzma API documentation:
+ While Doxygen is under the GNU GPLv2, the license information
+ in Doxygen includes the following exception:
+
+ Documents produced by doxygen are derivative works
+ derived from the input used in their production;
+ they are not affected by this license.
Note: The JavaScript files (under the MIT license) have
- been removed from the Doxygen-generated HTML version of the
- liblzma API documentation. Doxygen itself is under the GNU GPL
- but the remaining files generated by Doxygen are not affected
- by the licenses used in Doxygen because Doxygen licensing has
- the following exception:
+ been removed from the Doxygen output.
- "Documents produced by doxygen are derivative works
- derived from the input used in their production;
- they are not affected by this license."
+ - The XZ logo (xz-logo.png) included in the Doxygen-generated
+ documentation is under the Creative Commons BY-SA 4.0 license.
- - Translated messages are in the public domain.
+ - Translated messages and man pages are under 0BSD except that
+ some old translations are in the public domain.
- - The build system contains public domain files, and files that
- are under GNU GPLv2+ or GNU GPLv3+. None of these files end up
- in the binaries being built.
+ - Test files and test code in the 'tests' directory, and
+ debugging utilities in the 'debug' directory are under
+ the BSD Zero Clause License (0BSD).
- - Test files and test code in the tests directory, and debugging
- utilities in the debug directory are in the public domain.
+ - The GNU Autotools based build system contains files that are
+ under GNU GPLv2+, GNU GPLv3+, and a few permissive licenses.
+ These files don't affect the licensing of the binaries being
+ built.
- - The extra directory may contain public domain files, and files
- that are under various free software licenses.
+ - The extra directory contain files that are under various
+ free software licenses.
- You can do whatever you want with the files that have been put into
- the public domain. If you find public domain legally problematic,
- take the previous sentence as a license grant. If you still find
- the lack of copyright legally problematic, you have too many
- lawyers.
+ For the files under the BSD Zero Clause License (0BSD), if
+ a copyright notice is needed, the following is sufficient:
- As usual, this software is provided "as is", without any warranty.
+ Copyright (C) The XZ Utils authors and contributors
- If you copy significant amounts of public domain code from XZ Utils
+ If you copy significant amounts of 0BSD-licensed code from XZ Utils
into your project, acknowledging this somewhere in your software is
polite (especially if it is proprietary, non-free software), but
- naturally it is not legally required. Here is an example of a good
- notice to put into "about box" or into documentation:
+ it is not legally required by the license terms. Here is an example
+ of a good notice to put into "about box" or into documentation:
- This software includes code from XZ Utils <https://tukaani.org/xz/>.
+ This software includes code from XZ Utils
+ <https://xz.tukaani.org/xz-utils/>.
The following license texts are included in the following files:
+ - COPYING.0BSD: BSD Zero Clause License
- COPYING.LGPLv2.1: GNU Lesser General Public License version 2.1
- COPYING.GPLv2: GNU General Public License version 2
- COPYING.GPLv3: GNU General Public License version 3
-
- Note that the toolchain (compiler, linker etc.) may add some code
- pieces that are copyrighted. Thus, it is possible that e.g. liblzma
- binary wouldn't actually be in the public domain in its entirety
- even though it contains no copyrighted code from the XZ Utils source
- package.
-
- If you have questions, don't hesitate to ask the author(s) for more
- information.
+ - COPYING.CC-BY-SA-4.0: Creative Commons Attribution-ShareAlike 4.0
+ International Public License
+
+ A note about old XZ Utils releases:
+
+ XZ Utils releases 5.4.6 and older and 5.5.1alpha have a
+ significant amount of code put into the public domain and
+ that obviously remains so. The switch from public domain to
+ 0BSD for newer releases was made in Febrary 2024 because
+ public domain has (real or perceived) legal ambiguities in
+ some jurisdictions.
+
+ There is very little *practical* difference between public
+ domain and 0BSD. The main difference likely is that one
+ shouldn't claim that 0BSD-licensed code is in the public
+ domain; 0BSD-licensed code is copyrighted but available under
+ an extremely permissive license. Neither 0BSD nor public domain
+ require retaining or reproducing author, copyright holder, or
+ license notices when distributing the software. (Compare to,
+ for example, BSD 2-Clause "Simplified" License which does have
+ such requirements.)
+
+ If you have questions, don't hesitate to ask for more information.
+ The contact information is in the README file.
diff --git a/COPYING.0BSD b/COPYING.0BSD
new file mode 100644
index 000000000000..4322122aecf1
--- /dev/null
+++ b/COPYING.0BSD
@@ -0,0 +1,11 @@
+Permission to use, copy, modify, and/or distribute this
+software for any purpose with or without fee is hereby granted.
+
+THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL
+WARRANTIES WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED
+WARRANTIES OF MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL
+THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT, INDIRECT, OR
+CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM
+LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT,
+NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN
+CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
diff --git a/COPYING.CC-BY-SA-4.0 b/COPYING.CC-BY-SA-4.0
new file mode 100644
index 000000000000..7d4f96c54aa1
--- /dev/null
+++ b/COPYING.CC-BY-SA-4.0
@@ -0,0 +1,427 @@
+Attribution-ShareAlike 4.0 International
+
+=======================================================================
+
+Creative Commons Corporation ("Creative Commons") is not a law firm and
+does not provide legal services or legal advice. Distribution of
+Creative Commons public licenses does not create a lawyer-client or
+other relationship. Creative Commons makes its licenses and related
+information available on an "as-is" basis. Creative Commons gives no
+warranties regarding its licenses, any material licensed under their
+terms and conditions, or any related information. Creative Commons
+disclaims all liability for damages resulting from their use to the
+fullest extent possible.
+
+Using Creative Commons Public Licenses
+
+Creative Commons public licenses provide a standard set of terms and
+conditions that creators and other rights holders may use to share
+original works of authorship and other material subject to copyright
+and certain other rights specified in the public license below. The
+following considerations are for informational purposes only, are not
+exhaustive, and do not form part of our licenses.
+
+ Considerations for licensors: Our public licenses are
+ intended for use by those authorized to give the public
+ permission to use material in ways otherwise restricted by
+ copyright and certain other rights. Our licenses are
+ irrevocable. Licensors should read and understand the terms
+ and conditions of the license they choose before applying it.
+ Licensors should also secure all rights necessary before
+ applying our licenses so that the public can reuse the
+ material as expected. Licensors should clearly mark any
+ material not subject to the license. This includes other CC-
+ licensed material, or material used under an exception or
+ limitation to copyright. More considerations for licensors:
+ wiki.creativecommons.org/Considerations_for_licensors
+
+ Considerations for the public: By using one of our public
+ licenses, a licensor grants the public permission to use the
+ licensed material under specified terms and conditions. If
+ the licensor's permission is not necessary for any reason--for
+ example, because of any applicable exception or limitation to
+ copyright--then that use is not regulated by the license. Our
+ licenses grant only permissions under copyright and certain
+ other rights that a licensor has authority to grant. Use of
+ the licensed material may still be restricted for other
+ reasons, including because others have copyright or other
+ rights in the material. A licensor may make special requests,
+ such as asking that all changes be marked or described.
+ Although not required by our licenses, you are encouraged to
+ respect those requests where reasonable. More considerations
+ for the public:
+ wiki.creativecommons.org/Considerations_for_licensees
+
+=======================================================================
+
+Creative Commons Attribution-ShareAlike 4.0 International Public
+License
+
+By exercising the Licensed Rights (defined below), You accept and agree
+to be bound by the terms and conditions of this Creative Commons
+Attribution-ShareAlike 4.0 International Public License ("Public
+License"). To the extent this Public License may be interpreted as a
+contract, You are granted the Licensed Rights in consideration of Your
+acceptance of these terms and conditions, and the Licensor grants You
+such rights in consideration of benefits the Licensor receives from
+making the Licensed Material available under these terms and
+conditions.
+
+
+Section 1 -- Definitions.
+
+ a. Adapted Material means material subject to Copyright and Similar
+ Rights that is derived from or based upon the Licensed Material
+ and in which the Licensed Material is translated, altered,
+ arranged, transformed, or otherwise modified in a manner requiring
+ permission under the Copyright and Similar Rights held by the
+ Licensor. For purposes of this Public License, where the Licensed
+ Material is a musical work, performance, or sound recording,
+ Adapted Material is always produced where the Licensed Material is
+ synched in timed relation with a moving image.
+
+ b. Adapter's License means the license You apply to Your Copyright
+ and Similar Rights in Your contributions to Adapted Material in
+ accordance with the terms and conditions of this Public License.
+
+ c. BY-SA Compatible License means a license listed at
+ creativecommons.org/compatiblelicenses, approved by Creative
+ Commons as essentially the equivalent of this Public License.
+
+ d. Copyright and Similar Rights means copyright and/or similar rights
+ closely related to copyright including, without limitation,
+ performance, broadcast, sound recording, and Sui Generis Database
+ Rights, without regard to how the rights are labeled or
+ categorized. For purposes of this Public License, the rights
+ specified in Section 2(b)(1)-(2) are not Copyright and Similar
+ Rights.
+
+ e. Effective Technological Measures means those measures that, in the
+ absence of proper authority, may not be circumvented under laws
+ fulfilling obligations under Article 11 of the WIPO Copyright
+ Treaty adopted on December 20, 1996, and/or similar international
+ agreements.
+
+ f. Exceptions and Limitations means fair use, fair dealing, and/or
+ any other exception or limitation to Copyright and Similar Rights
+ that applies to Your use of the Licensed Material.
+
+ g. License Elements means the license attributes listed in the name
+ of a Creative Commons Public License. The License Elements of this
+ Public License are Attribution and ShareAlike.
+
+ h. Licensed Material means the artistic or literary work, database,
+ or other material to which the Licensor applied this Public
+ License.
+
+ i. Licensed Rights means the rights granted to You subject to the
+ terms and conditions of this Public License, which are limited to
+ all Copyright and Similar Rights that apply to Your use of the
+ Licensed Material and that the Licensor has authority to license.
+
+ j. Licensor means the individual(s) or entity(ies) granting rights
+ under this Public License.
+
+ k. Share means to provide material to the public by any means or
+ process that requires permission under the Licensed Rights, such
+ as reproduction, public display, public performance, distribution,
+ dissemination, communication, or importation, and to make material
+ available to the public including in ways that members of the
+ public may access the material from a place and at a time
+ individually chosen by them.
+
+ l. Sui Generis Database Rights means rights other than copyright
+ resulting from Directive 96/9/EC of the European Parliament and of
+ the Council of 11 March 1996 on the legal protection of databases,
+ as amended and/or succeeded, as well as other essentially
+ equivalent rights anywhere in the world.
+
+ m. You means the individual or entity exercising the Licensed Rights
+ under this Public License. Your has a corresponding meaning.
+
+
+Section 2 -- Scope.
+
+ a. License grant.
+
+ 1. Subject to the terms and conditions of this Public License,
+ the Licensor hereby grants You a worldwide, royalty-free,
+ non-sublicensable, non-exclusive, irrevocable license to
+ exercise the Licensed Rights in the Licensed Material to:
+
+ a. reproduce and Share the Licensed Material, in whole or
+ in part; and
+
+ b. produce, reproduce, and Share Adapted Material.
+
+ 2. Exceptions and Limitations. For the avoidance of doubt, where
+ Exceptions and Limitations apply to Your use, this Public
+ License does not apply, and You do not need to comply with
+ its terms and conditions.
+
+ 3. Term. The term of this Public License is specified in Section
+ 6(a).
+
+ 4. Media and formats; technical modifications allowed. The
+ Licensor authorizes You to exercise the Licensed Rights in
+ all media and formats whether now known or hereafter created,
+ and to make technical modifications necessary to do so. The
+ Licensor waives and/or agrees not to assert any right or
+ authority to forbid You from making technical modifications
+ necessary to exercise the Licensed Rights, including
+ technical modifications necessary to circumvent Effective
+ Technological Measures. For purposes of this Public License,
+ simply making modifications authorized by this Section 2(a)
+ (4) never produces Adapted Material.
+
+ 5. Downstream recipients.
+
+ a. Offer from the Licensor -- Licensed Material. Every
+ recipient of the Licensed Material automatically
+ receives an offer from the Licensor to exercise the
+ Licensed Rights under the terms and conditions of this
+ Public License.
+
+ b. Additional offer from the Licensor -- Adapted Material.
+ Every recipient of Adapted Material from You
+ automatically receives an offer from the Licensor to
+ exercise the Licensed Rights in the Adapted Material
+ under the conditions of the Adapter's License You apply.
+
+ c. No downstream restrictions. You may not offer or impose
+ any additional or different terms or conditions on, or
+ apply any Effective Technological Measures to, the
+ Licensed Material if doing so restricts exercise of the
+ Licensed Rights by any recipient of the Licensed
+ Material.
+
+ 6. No endorsement. Nothing in this Public License constitutes or
+ may be construed as permission to assert or imply that You
+ are, or that Your use of the Licensed Material is, connected
+ with, or sponsored, endorsed, or granted official status by,
+ the Licensor or others designated to receive attribution as
+ provided in Section 3(a)(1)(A)(i).
+
+ b. Other rights.
+
+ 1. Moral rights, such as the right of integrity, are not
+ licensed under this Public License, nor are publicity,
+ privacy, and/or other similar personality rights; however, to
+ the extent possible, the Licensor waives and/or agrees not to
+ assert any such rights held by the Licensor to the limited
+ extent necessary to allow You to exercise the Licensed
+ Rights, but not otherwise.
+
+ 2. Patent and trademark rights are not licensed under this
+ Public License.
+
+ 3. To the extent possible, the Licensor waives any right to
+ collect royalties from You for the exercise of the Licensed
+ Rights, whether directly or through a collecting society
+ under any voluntary or waivable statutory or compulsory
+ licensing scheme. In all other cases the Licensor expressly
+ reserves any right to collect such royalties.
+
+
+Section 3 -- License Conditions.
+
+Your exercise of the Licensed Rights is expressly made subject to the
+following conditions.
+
+ a. Attribution.
+
+ 1. If You Share the Licensed Material (including in modified
+ form), You must:
+
+ a. retain the following if it is supplied by the Licensor
+ with the Licensed Material:
+
+ i. identification of the creator(s) of the Licensed
+ Material and any others designated to receive
+ attribution, in any reasonable manner requested by
+ the Licensor (including by pseudonym if
+ designated);
+
+ ii. a copyright notice;
+
+ iii. a notice that refers to this Public License;
+
+ iv. a notice that refers to the disclaimer of
+ warranties;
+
+ v. a URI or hyperlink to the Licensed Material to the
+ extent reasonably practicable;
+
+ b. indicate if You modified the Licensed Material and
+ retain an indication of any previous modifications; and
+
+ c. indicate the Licensed Material is licensed under this
+ Public License, and include the text of, or the URI or
+ hyperlink to, this Public License.
+
+ 2. You may satisfy the conditions in Section 3(a)(1) in any
+ reasonable manner based on the medium, means, and context in
+ which You Share the Licensed Material. For example, it may be
+ reasonable to satisfy the conditions by providing a URI or
+ hyperlink to a resource that includes the required
+ information.
+
+ 3. If requested by the Licensor, You must remove any of the
+ information required by Section 3(a)(1)(A) to the extent
+ reasonably practicable.
+
+ b. ShareAlike.
+
+ In addition to the conditions in Section 3(a), if You Share
+ Adapted Material You produce, the following conditions also apply.
+
+ 1. The Adapter's License You apply must be a Creative Commons
+ license with the same License Elements, this version or
+ later, or a BY-SA Compatible License.
+
+ 2. You must include the text of, or the URI or hyperlink to, the
+ Adapter's License You apply. You may satisfy this condition
+ in any reasonable manner based on the medium, means, and
+ context in which You Share Adapted Material.
+
+ 3. You may not offer or impose any additional or different terms
+ or conditions on, or apply any Effective Technological
+ Measures to, Adapted Material that restrict exercise of the
+ rights granted under the Adapter's License You apply.
+
+
+Section 4 -- Sui Generis Database Rights.
+
+Where the Licensed Rights include Sui Generis Database Rights that
+apply to Your use of the Licensed Material:
+
+ a. for the avoidance of doubt, Section 2(a)(1) grants You the right
+ to extract, reuse, reproduce, and Share all or a substantial
+ portion of the contents of the database;
+
+ b. if You include all or a substantial portion of the database
+ contents in a database in which You have Sui Generis Database
+ Rights, then the database in which You have Sui Generis Database
+ Rights (but not its individual contents) is Adapted Material,
+ including for purposes of Section 3(b); and
+
+ c. You must comply with the conditions in Section 3(a) if You Share
+ all or a substantial portion of the contents of the database.
+
+For the avoidance of doubt, this Section 4 supplements and does not
+replace Your obligations under this Public License where the Licensed
+Rights include other Copyright and Similar Rights.
+
+
+Section 5 -- Disclaimer of Warranties and Limitation of Liability.
+
+ a. UNLESS OTHERWISE SEPARATELY UNDERTAKEN BY THE LICENSOR, TO THE
+ EXTENT POSSIBLE, THE LICENSOR OFFERS THE LICENSED MATERIAL AS-IS
+ AND AS-AVAILABLE, AND MAKES NO REPRESENTATIONS OR WARRANTIES OF
+ ANY KIND CONCERNING THE LICENSED MATERIAL, WHETHER EXPRESS,
+ IMPLIED, STATUTORY, OR OTHER. THIS INCLUDES, WITHOUT LIMITATION,
+ WARRANTIES OF TITLE, MERCHANTABILITY, FITNESS FOR A PARTICULAR
+ PURPOSE, NON-INFRINGEMENT, ABSENCE OF LATENT OR OTHER DEFECTS,
+ ACCURACY, OR THE PRESENCE OR ABSENCE OF ERRORS, WHETHER OR NOT
+ KNOWN OR DISCOVERABLE. WHERE DISCLAIMERS OF WARRANTIES ARE NOT
+ ALLOWED IN FULL OR IN PART, THIS DISCLAIMER MAY NOT APPLY TO YOU.
+
+ b. TO THE EXTENT POSSIBLE, IN NO EVENT WILL THE LICENSOR BE LIABLE
+ TO YOU ON ANY LEGAL THEORY (INCLUDING, WITHOUT LIMITATION,
+ NEGLIGENCE) OR OTHERWISE FOR ANY DIRECT, SPECIAL, INDIRECT,
+ INCIDENTAL, CONSEQUENTIAL, PUNITIVE, EXEMPLARY, OR OTHER LOSSES,
+ COSTS, EXPENSES, OR DAMAGES ARISING OUT OF THIS PUBLIC LICENSE OR
+ USE OF THE LICENSED MATERIAL, EVEN IF THE LICENSOR HAS BEEN
+ ADVISED OF THE POSSIBILITY OF SUCH LOSSES, COSTS, EXPENSES, OR
+ DAMAGES. WHERE A LIMITATION OF LIABILITY IS NOT ALLOWED IN FULL OR
+ IN PART, THIS LIMITATION MAY NOT APPLY TO YOU.
+
+ c. The disclaimer of warranties and limitation of liability provided
+ above shall be interpreted in a manner that, to the extent
+ possible, most closely approximates an absolute disclaimer and
+ waiver of all liability.
+
+
+Section 6 -- Term and Termination.
+
+ a. This Public License applies for the term of the Copyright and
+ Similar Rights licensed here. However, if You fail to comply with
+ this Public License, then Your rights under this Public License
+ terminate automatically.
+
+ b. Where Your right to use the Licensed Material has terminated under
+ Section 6(a), it reinstates:
+
+ 1. automatically as of the date the violation is cured, provided
+ it is cured within 30 days of Your discovery of the
+ violation; or
+
+ 2. upon express reinstatement by the Licensor.
+
+ For the avoidance of doubt, this Section 6(b) does not affect any
+ right the Licensor may have to seek remedies for Your violations
+ of this Public License.
+
+ c. For the avoidance of doubt, the Licensor may also offer the
+ Licensed Material under separate terms or conditions or stop
+ distributing the Licensed Material at any time; however, doing so
+ will not terminate this Public License.
+
+ d. Sections 1, 5, 6, 7, and 8 survive termination of this Public
+ License.
+
+
+Section 7 -- Other Terms and Conditions.
+
+ a. The Licensor shall not be bound by any additional or different
+ terms or conditions communicated by You unless expressly agreed.
+
+ b. Any arrangements, understandings, or agreements regarding the
+ Licensed Material not stated herein are separate from and
+ independent of the terms and conditions of this Public License.
+
+
+Section 8 -- Interpretation.
+
+ a. For the avoidance of doubt, this Public License does not, and
+ shall not be interpreted to, reduce, limit, restrict, or impose
+ conditions on any use of the Licensed Material that could lawfully
+ be made without permission under this Public License.
+
+ b. To the extent possible, if any provision of this Public License is
+ deemed unenforceable, it shall be automatically reformed to the
+ minimum extent necessary to make it enforceable. If the provision
+ cannot be reformed, it shall be severed from this Public License
+ without affecting the enforceability of the remaining terms and
+ conditions.
+
+ c. No term or condition of this Public License will be waived and no
+ failure to comply consented to unless expressly agreed to by the
+ Licensor.
+
+ d. Nothing in this Public License constitutes or may be interpreted
+ as a limitation upon, or waiver of, any privileges and immunities
+ that apply to the Licensor or You, including from the legal
+ processes of any jurisdiction or authority.
+
+
+=======================================================================
+
+Creative Commons is not a party to its public
+licenses. Notwithstanding, Creative Commons may elect to apply one of
+its public licenses to material it publishes and in those instances
+will be considered the “Licensor.” The text of the Creative Commons
+public licenses is dedicated to the public domain under the CC0 Public
+Domain Dedication. Except for the limited purpose of indicating that
+material is shared under a Creative Commons public license or as
+otherwise permitted by the Creative Commons policies published at
+creativecommons.org/policies, Creative Commons does not authorize the
+use of the trademark "Creative Commons" or any other trademark or logo
+of Creative Commons without its prior written consent including,
+without limitation, in connection with any unauthorized modifications
+to any of its public licenses or any other arrangements,
+understandings, or agreements concerning use of licensed material. For
+the avoidance of doubt, this paragraph does not form part of the
+public licenses.
+
+Creative Commons may be contacted at creativecommons.org.
diff --git a/ChangeLog b/ChangeLog
index 4dd0978ef313..54b68744af86 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,14 +1,3582 @@
-commit 49053c0a649f4c8bd2b8d97ce915f401fbc0f3d9
+commit 2d7d862e3ffa8cec4fd3fdffcd84e984a17aa429
Author: Jia Tan <jiat0218@gmail.com>
-Date: 2023-10-31 22:30:29 +0800
+Date: 2024-02-24 15:55:08 +0800
- Bump version and soname for 5.4.5.
+ Bump version and soname for 5.6.0.
- src/liblzma/Makefile.am | 2 +-
- src/liblzma/api/lzma/version.h | 2 +-
+ src/liblzma/Makefile.am | 2 +-
+ src/liblzma/api/lzma/version.h | 6 +++---
+ src/liblzma/liblzma_generic.map | 2 +-
+ src/liblzma/liblzma_linux.map | 2 +-
+ 4 files changed, 6 insertions(+), 6 deletions(-)
+
+commit a18fb1edef0d0aac12a09eed05e9c448c777af7b
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2024-02-24 15:50:36 +0800
+
+ Add NEWS for 5.6.0.
+
+ NEWS | 143 +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
+ 1 file changed, 143 insertions(+)
+
+commit 24355c5280bc95e3d594432d60bb8432aa6af173
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2024-02-22 22:27:01 +0800
+
+ Translations: Remove obsolete and fuzzy matches from some translations.
+
+ The French and Brazilian Portuguese man page translations have not been
+ updated since the switch from public domain to 0BSD. The old GPLv2
+ strings have now been removed from these files.
+
+ po4a/fr.po | 4702 +++++++++++++++++++++++++++++++++++++----------------
+ po4a/pt_BR.po | 4987 ++++++++++++++++++++++++++++++++++++++++-----------------
+ 2 files changed, 6832 insertions(+), 2857 deletions(-)
+
+commit 02ca4a7d7b703e2ec63e00b70feec825e919dbc1
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2024-02-21 00:31:54 +0800
+
+ Translations: Patch man pages to avoid fuzzy matches.
+
+ This will be fixed in the next round of translations, but this avoids
+ having a fuzzy match or not fixing the English version.
+
+ po4a/de.po | 2 +-
+ po4a/ko.po | 2 +-
+ po4a/ro.po | 2 +-
+ po4a/uk.po | 2 +-
+ 4 files changed, 4 insertions(+), 4 deletions(-)
+
+commit 898aad9fc711e03452d24d9e2c5b7f77a6f9ce64
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2024-02-21 00:30:43 +0800
+
+ xzmore: Fix typo in xzmore.1.
+
+ Thanks to Yuri Chornoivan.
+
+ src/scripts/xzmore.1 | 2 +-
+ 1 file changed, 1 insertion(+), 1 deletion(-)
+
+commit 5631aa206c8d16b4eeab85a46b8b698f4fc4cdba
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2024-02-24 12:12:16 +0800
+
+ Translations: Update the Vietnamese translation.
+
+ po/vi.po | 505 ++++++++++++++++++++++++++++++++++++++-------------------------
+ 1 file changed, 309 insertions(+), 196 deletions(-)
+
+commit a65fd7ce9d6228e87faf61dc56a35984d0088248
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2024-02-24 12:06:40 +0800
+
+ Translations: Update the Esperanto translation.
+
+ po/eo.po | 502 ++++++++++++++++++++++++++++++++++++++-------------------------
+ 1 file changed, 306 insertions(+), 196 deletions(-)
+
+commit cf44e4b7f5dfdbf8c78aef377c10f71e274f63c0
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2024-02-23 23:09:59 +0800
+
+ Tests: Add a few test files.
+
+ tests/files/README | 19 +++++++++++++++++++
+ tests/files/bad-3-corrupt_lzma2.xz | Bin 0 -> 484 bytes
+ tests/files/bad-dict_size.lzma | Bin 0 -> 41 bytes
+ tests/files/good-2cat.xz | Bin 0 -> 136 bytes
+ tests/files/good-large_compressed.lzma | Bin 0 -> 35430 bytes
+ tests/files/good-small_compressed.lzma | Bin 0 -> 258 bytes
+ 6 files changed, 19 insertions(+)
+
+commit 39f4a1a86ad80b2d064b812cee42668e6c8b8c73
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2024-02-23 20:58:36 +0800
+
+ Tests: Add MicroLZMA test.
+
+ tests/Makefile.am | 4 +-
+ tests/test_microlzma.c | 548 +++++++++++++++++++++++++++++++++++++++++++++++++
+ 2 files changed, 551 insertions(+), 1 deletion(-)
+
+commit adaacafde6661496ca2814b1e94a3ba5186428cb
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2024-02-23 20:57:59 +0800
+
+ Build: Define HAVE_MICROLZMA when it is configured.
+
+ CMakeLists.txt | 4 ++++
+ configure.ac | 9 +++++++--
+ 2 files changed, 11 insertions(+), 2 deletions(-)
+
+commit eea78216d27182ca917bf00e02feaab058a4d21e
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2024-02-23 20:27:15 +0800
+
+ xz: Fix Capsicum sandbox compile error.
+
+ user_abort_pipe[] was still being used instead of the parameters.
+
+ src/xz/sandbox.c | 4 ++--
+ 1 file changed, 2 insertions(+), 2 deletions(-)
+
+commit 32b0a3ce19224f9074d01a4ffbc1655b05fcb82d
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2024-02-23 16:12:32 +0800
+
+ Build: Fix ARM64 CRC32 instruction feature test.
+
+ Old versions of Clang reported the unsupported function attribute and
+ __crc32d() function as warnings instead of errors, so the feature test
+ passed when it shouldn't have, causing a compile error at build time.
+ -Werror was added to this feature test to fix this. The change is not
+ needed for CMake because check_c_source_compiles() also performs
+ linking and the error is caught then.
+
+ Thanks to Sebastian Andrzej Siewior for reporting this.
+
+ configure.ac | 10 ++++++++++
+ 1 file changed, 10 insertions(+)
+
+commit 4c81c9611f8b2e1ad65eb7fa166afc570c58607e
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2024-02-22 19:16:35 +0200
+
+ CMake: Add LOCALEDIR to the windres workaround.
+
+ LOCALEDIR may contain spaces like in "C:\Program Files".
+
+ CMakeLists.txt | 16 +++++++++++-----
+ 1 file changed, 11 insertions(+), 5 deletions(-)
+
+commit de4337fd89ca7db5feb97b5c40143404f6e22986
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2024-02-22 15:18:25 +0200
+
+ xz: Landlock: Fix error message if input file is a directory.
+
+ If xz is given a directory, it should look like this:
+
+ $ xz /usr/bin
+ xz: /usr/bin: Is a directory, skipping
+
+ The Landlock rules didn't allow opening directories for reading:
+
+ $ xz /usr/bin
+ xz: /usr/bin: Permission denied
+
+ The simplest fix was to allow opening directories for reading.
+ While it's a bit silly to allow it solely for the error message,
+ it shouldn't make the sandbox significantly weaker.
+
+ The single-file use case (like when called from GNU tar) is
+ still as strict as possible: all Landlock restrictions are
+ enabled before (de)compression starts.
+
+ src/xz/sandbox.c | 15 ++++++++++++++-
+ 1 file changed, 14 insertions(+), 1 deletion(-)
+
+commit 120da10ae139ea52ca4275452adf8eda02d07cc8
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2024-02-22 14:41:29 +0200
+
+ liblzma: Disable branchless C version in range decoder.
+
+ Thanks to Sebastian Andrzej Siewior and Sam James for
+ benchmarking on various systems.
+
+ src/liblzma/rangecoder/range_decoder.h | 13 ++++++++++---
+ 1 file changed, 10 insertions(+), 3 deletions(-)
+
+commit 00440f52be9ac2c7438c7b0cb1082f12399632c6
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2024-02-21 17:41:32 +0200
+
+ INSTALL: Clarify that --disable-assembler affects only 32-bit x86.
+
+ INSTALL | 18 +++++++++---------
+ 1 file changed, 9 insertions(+), 9 deletions(-)
+
+commit 11405be84ea294497e12d03d7219f607063f4a00
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2024-02-19 18:41:37 +0200
+
+ Windows: build.bash: Include COPYING.0BSD in the package.
+
+ windows/build.bash | 2 +-
+ 1 file changed, 1 insertion(+), 1 deletion(-)
+
+commit c27cf64e3e27f4968431d65be7098a12a3a80d30
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2024-02-18 17:59:46 +0200
+
+ Windows: build.bash: include liblzma-crt-mixing.txt in the package.
+
+ windows/build.bash | 6 ++++--
+ 1 file changed, 4 insertions(+), 2 deletions(-)
+
+commit 8d38941baed05de4ff7cc775de14833108f62184
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2024-02-18 17:17:43 +0200
+
+ Windows: Major update to Windows build instructions.
+
+ INSTALL | 68 ++++-----
+ windows/INSTALL-MSVC.txt | 23 +--
+ windows/INSTALL-MinGW-w64_with_Autotools.txt | 49 +++++++
+ windows/INSTALL-MinGW-w64_with_CMake.txt | 203 +++++++++++++++++++++++++++
+ windows/INSTALL-MinGW.txt | 138 ------------------
+ windows/README-Windows.txt | 2 +
+ windows/build-with-cmake.bat | 35 +++++
+ windows/liblzma-crt-mixing.txt | 70 +++++++++
+ 8 files changed, 404 insertions(+), 184 deletions(-)
+
+commit 4b5b0d352348ff510ffb50a3b5b71788857d37a1
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2024-02-18 15:15:04 +0200
+
+ Windows: Update windows/README-Windows.txt.
+
+ It's for binary packages built with windows/build.bash.
+
+ windows/README-Windows.txt | 104 ++++++++++++++++++---------------------------
+ 1 file changed, 41 insertions(+), 63 deletions(-)
+
+commit 1ee716f74085223c8fbcae1d5a384e6bf53c0f6a
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2024-02-18 15:15:04 +0200
+
+ Windows: Update windows/build.bash.
+
+ Support for the old MinGW was dropped. Only MinGW-w64 with GCC
+ is supported now.
+
+ The script now supports also cross-compilation from GNU/Linux
+ (tests are not run). MSYS2 and also the old MSYS 1.0.11 work
+ for building on Windows. The i686 and x86_64 toolchains must
+ be in PATH to build both 32-bit and 64-bit versions.
+
+ Parallel builds are done if "nproc" from GNU coreutils is available.
+
+ MinGW-w64 runtime copyright information file was renamed from
+ COPYING-Windows.txt to COPYING.MinGW-w64-runtime.txt which
+ is the filename used by MinGW-w64 itself. Its existence
+ is now mandatory, it's checked at the beginning of the script.
+
+ The file TODO is no longer copied to the package.
+
+ windows/build.bash | 191 +++++++++++++++++++++++++++++++----------------------
+ 1 file changed, 112 insertions(+), 79 deletions(-)
+
+commit 60462e42609a1d961868a1d1ebecc713c6d27e2e
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2024-02-20 23:32:22 +0800
+
+ Translations: Update the Romanian man page translations.
+
+ po4a/ro.po | 1715 +++++++++++++++++++++++++++++++-----------------------------
+ 1 file changed, 875 insertions(+), 840 deletions(-)
+
+commit 10d733e5b8929c642e00891cfa9ead9c2cdd2e05
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2024-02-20 23:30:25 +0800
+
+ Translations: Update the Korean man page translations.
+
+ po4a/ko.po | 6 +++---
+ 1 file changed, 3 insertions(+), 3 deletions(-)
+
+commit 797a34b72ac6baff237d7a546fa941d8f78f2f62
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2024-02-20 21:03:53 +0800
+
+ Translations: Update the Spanish translation.
+
+ po/es.po | 6 +++---
+ 1 file changed, 3 insertions(+), 3 deletions(-)
+
+commit 5c3751d019f023e091df9a653e2bb1f6ea8b0d49
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2024-02-20 20:18:07 +0800
+
+ Translations: Update the Romanian translation.
+
+ po/ro.po | 470 ++++++++++++++++++++++++++++++---------------------------------
+ 1 file changed, 227 insertions(+), 243 deletions(-)
+
+commit e2d31154ecc750935436e8b62c6b073b2cfa84e3
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2024-02-20 20:15:50 +0800
+
+ Translations: Update the Croatian translation.
+
+ po/hr.po | 648 ++++++++++++++++++++++++++++++++++-----------------------------
+ 1 file changed, 355 insertions(+), 293 deletions(-)
+
+commit 704500f994d5ac271bfcfd592275c5a7da4dc8d2
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2024-02-20 20:05:44 +0800
+
+ Translations: Update the German man page translations.
+
+ po4a/de.po | 1696 +++++++++++++++++++++++++++++++-----------------------------
+ 1 file changed, 873 insertions(+), 823 deletions(-)
+
+commit 1cfd3dca3fef321b06db73c3c9e13f347c2e2f5f
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2024-02-20 19:58:25 +0800
+
+ Translations: Update the German translation.
+
+ po/de.po | 427 +++++++++++++++++++++++++++++++++------------------------------
+ 1 file changed, 225 insertions(+), 202 deletions(-)
+
+commit 28b9b3f16cc7c6e5b42e691994569c17f4561c9a
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2024-02-20 19:56:52 +0800
+
+ Translations: Update the Hungarian translation.
+
+ po/hu.po | 556 ++++++++++++++++++++++++++++++++++++++-------------------------
+ 1 file changed, 338 insertions(+), 218 deletions(-)
+
+commit 00b06cd0af6ad2ee93d3006bf80417db060c2b04
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2024-02-19 16:48:05 +0200
+
+ CMake: Fix building of lzmainfo when translations are enabled.
+
+ CMakeLists.txt | 2 ++
+ 1 file changed, 2 insertions(+)
+
+commit b0d1422b6037bfea6f6723683bd82a8e6d77026c
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2024-02-19 13:38:42 +0200
+
+ CMake: Don't assume that -fvisibility=hidden is supported outside Windows.
+
+ The original code was good enough for supporting GNU/Linux
+ and a few others but it wasn't very portable.
+
+ CMake doesn't support Solaris Studio's -xldscope=hidden.
+ If it ever does, things should still work with this commit
+ as Solaris Studio supports not only its own __global but also
+ the GNU C __attribute__((visibility("default"))). Support for the
+ attribute was added in 2007 to Sun Studio 12 compiler version 5.9.
+
+ CMakeLists.txt | 26 ++++++++++++++++++++++----
+ 1 file changed, 22 insertions(+), 4 deletions(-)
+
+commit 2ced9d34bef4dce52ecbbf84d0903ab0aae1442c
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2024-02-19 12:20:59 +0200
+
+ CMake: Revise the component splitting.
+
+ CMakeLists.txt | 57 +++++++++++++++++++++++++++++++--------------------------
+ 1 file changed, 31 insertions(+), 26 deletions(-)
+
+commit 426bdc709c169d39b31dec410016779de117ef69
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2024-02-17 21:45:07 +0200
+
+ CMake: Update the main comment and document CMAKE_BUILD_TYPE=Release.
+
+ CMakeLists.txt | 79 ++++++++++++++++++++++++++++++++++++++++++++++------------
+ 1 file changed, 63 insertions(+), 16 deletions(-)
+
+commit 4430e075f7ccfc47972d6ca0aa1c3779fc265e10
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2024-02-17 21:27:48 +0200
+
+ CMake: Use -O2 instead of -O3 in CMAKE_BUILD_TYPE=Release.
+
+ -O3 doesn't seem useful for speed but it makes the code bigger.
+ CMake makes is difficult for users to simply override the
+ optimization level: CFLAGS / CMAKE_C_FLAGS aren't helpful because
+ they go before CMAKE_C_FLAGS_RELEASE. Of course, users can override
+ CMAKE_C_FLAGS_RELEASE directly but then they have to remember to
+ add also -DNDEBUG to disable assertions.
+
+ This commit changes -O3 to -O2 in CMAKE_C_FLAGS_RELEASE if and only if
+ CMAKE_C_FLAGS_RELEASE cache variable doesn't already exist. So if
+ a custom value is passed on the command line (or reconfiguring an
+ already-configured build), the cache variable won't be modified.
+
+ CMakeLists.txt | 19 +++++++++++++++++++
+ 1 file changed, 19 insertions(+)
+
+commit 025eb6d7879e4c4e8cb29716b371e0f4c1aea660
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2024-02-18 14:59:52 +0200
+
+ CMake: Handle symbol versioning on MicroBlaze specially.
+
+ This is to match configure.ac.
+
+ CMakeLists.txt | 23 +++++++++++++++++++----
+ 1 file changed, 19 insertions(+), 4 deletions(-)
+
+commit 2edd1a35b2507d1ce68b52dbaebe23c4850a74ce
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2024-02-17 22:18:12 +0200
+
+ CMake: Keep build working even if lib/*.[ch] are removed.
+
+ CMakeLists.txt | 7 ++++++-
+ 1 file changed, 6 insertions(+), 1 deletion(-)
+
+commit d753e2ce4715552884afadc4ed6fbf8ccca6efac
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2024-02-17 18:10:40 +0200
+
+ CMake: Install documentation.
+
+ CMakeLists.txt | 32 ++++++++++++++++++++++++++++++++
+ 1 file changed, 32 insertions(+)
+
+commit 7a0405bea9cb0df9318b70f779f82b2c473e98ac
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2024-02-17 15:35:35 +0200
+
+ CMake: Bump maximum policy version to 3.28.
+
+ CMP0154 doesn't affect us since we don't use FILE_SET.
+
+ CMakeLists.txt | 2 +-
+ 1 file changed, 1 insertion(+), 1 deletion(-)
+
+commit c2264ffbe3892d28930b89b0123efc369cabc143
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2024-02-17 15:35:35 +0200
+
+ CMake: Build lzmainfo.
+
+ CMakeLists.txt | 54 ++++++++++++++++++++++++++++++++++++++++++++++++++++++
+ 1 file changed, 54 insertions(+)
+
+commit 998d0b29536094a89cf385a3b894e157db1ccefe
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2024-02-17 15:35:35 +0200
+
+ CMake: Build lzmadec.
+
+ CMakeLists.txt | 76 ++++++++++++++++++++++++++++++++--------------------------
+ 1 file changed, 42 insertions(+), 34 deletions(-)
+
+commit 74e8bc7417a0f37ca7ed5ee0127d33c69b3100b9
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2024-02-17 15:35:35 +0200
+
+ CMake: Add test_scripts.sh to the tests.
+
+ In contrast to Automake, skipping of this test when decoders
+ are disabled is handled at CMake side instead of test_scripts.sh
+ because CMake-build doesn't create config.h.
+
+ CMakeLists.txt | 14 ++++++++++++++
+ tests/test_scripts.sh | 13 ++++++++-----
+ 2 files changed, 22 insertions(+), 5 deletions(-)
+
+commit 4808f238a731befcd46c2117c62a1caaf4403989
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2024-02-17 15:35:35 +0200
+
+ CMake: Install scripts.
+
+ Compared to the Autotools-based build, this has simpler handling
+ for the shell (@POSIX_SHELL@) and extra PATH entry for the scripts
+ (configure has --enable-path-for-scripts=PREFIX). The simpler
+ metho should be enough for non-ancient systems and Solaris.
+
+ CMakeLists.txt | 83 +++++++++++++++++++++++++++++++++++++++++++++++++++++++++-
+ 1 file changed, 82 insertions(+), 1 deletion(-)
+
+commit 3462362ebd94d835c664e94ad8f414cfe7590ca7
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2024-02-17 15:35:35 +0200
+
+ Scripts: Use @PACKAGE_VERSION@ instead of @VERSION@.
+
+ PACKAGE_VERSION was already used in liblzma.pc.in.
+ This way only one version @foo@ is used.
+
+ src/scripts/xzdiff.in | 2 +-
+ src/scripts/xzgrep.in | 2 +-
+ src/scripts/xzless.in | 2 +-
+ src/scripts/xzmore.in | 2 +-
+ 4 files changed, 4 insertions(+), 4 deletions(-)
+
+commit 67610c245ba6c68cf65991693bab9312b7dc987b
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2024-02-17 15:35:35 +0200
+
+ CMake: Simplify symlink creation and install translated man pages.
+
+ It helps that cmake_install.cmake doesn't parallelize installation
+ so symlinks can be created so that the target is always known to
+ exist (a requirement on Windows in some cases).
+
+ This bumps the minimum CMake version from 3.13 to 3.14 to use
+ file(CREATE_LINK ...). It could be made to work on 3.13 by
+ calling "cmake -E create_symlink" but it's uglier code and
+ slower in "make install". 3.14 should be a reasonable version
+ to require nowadays, especially since the Autotools build
+ is still the primary build system for most OSes.
+
+ CMakeLists.txt | 195 +++++++++++++++++++++++++++++----------------------------
+ 1 file changed, 98 insertions(+), 97 deletions(-)
+
+commit 50cc1d8a5a8154428bf240c7e4972e32b17d99bf
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2024-02-17 15:35:35 +0200
+
+ CMake: Add support for building and installing xz with translations.
+
+ If gettext tools are available, the .po files listed in po/LINGUAS
+ are converted using msgfmt. This allows building with translations
+ directly from xz.git without Autotools.
+
+ If gettext tools aren't available, the Autotools-created .gmo files
+ in the "po" directory will be used. This allows CMake-based build
+ to use translations from Autotools-generated tarball.
+
+ If translation support is found (Intl_FOUND) but both the
+ gettext tools and the pre-generated .gmo files are missing,
+ then "make" will fail.
+
+ CMakeLists.txt | 68 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++--
+ 1 file changed, 66 insertions(+), 2 deletions(-)
+
+commit 746c471643009947f94a3494a1148f74c7381b56
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2024-02-19 11:58:33 +0200
+
+ liblzma: Remove commented-out code.
+
+ src/liblzma/rangecoder/range_decoder.h | 3 ---
+ 1 file changed, 3 deletions(-)
+
+commit 4ce300ce0884c6e552de2af9ae8050b47b01f0e7
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2024-02-17 23:07:35 +0200
+
+ xz: Delete old commented-out code.
+
+ src/xz/message.c | 19 -------------------
+ 1 file changed, 19 deletions(-)
+
+commit cae9a5e0bf422e6c5e64180805904f7ed02dc3aa
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2024-02-17 23:07:35 +0200
+
+ xz: Use stricter pledge(2) and Landlock sandbox.
+
+ This makes these sandboxing methods stricter when no files are
+ created or deleted. That is, it's a middle ground between the
+ initial sandbox and the strictest single-file-to-stdout sandbox:
+ this allows opening files for reading but output has to go to stdout.
+
+ src/xz/main.c | 46 +++++++++++++++++++++++++++++++++-------------
+ src/xz/sandbox.c | 32 ++++++++++++++++++++++++++++++++
+ src/xz/sandbox.h | 4 ++++
+ 3 files changed, 69 insertions(+), 13 deletions(-)
+
+commit 02e3505991233901575b7eabc06b2c6c62a96899
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2024-02-17 23:07:35 +0200
+
+ xz: Support Landlock ABI version 4.
+
+ Linux 6.7 added support for ABI version 4 which restricts
+ TCP connections which xz won't need and thus those can be
+ forbidden now. Since the ABI version is handled at runtime,
+ supporting version 4 won't cause any compatibility issues.
+
+ Note that new enough kernel headers are required to get
+ version 4 support enabled at build time.
+
+ src/xz/sandbox.c | 25 ++++++++++++++++++++-----
+ 1 file changed, 20 insertions(+), 5 deletions(-)
+
+commit 374868d81d473ab56556a1cfd6b1b36a1fab348b
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2024-02-17 23:07:35 +0200
+
+ xz: Move sandboxing code to sandbox.c and improve Landlock sandbox.
+
+ Landlock is now always used just like pledge(2) is: first in more
+ permissive mode and later (under certain common conditions) in
+ a strict mode that doesn't allow opening more files.
+
+ I put pledge(2) first in sandbox.c because it's the simplest API
+ to use and still somewhat fine-grained for basic applications.
+ So it's the simplest thing to understand for anyone reading sandbox.c.
+
+ CMakeLists.txt | 2 +
+ src/xz/Makefile.am | 2 +
+ src/xz/file_io.c | 170 +-----------------------------
+ src/xz/file_io.h | 6 --
+ src/xz/main.c | 50 +++------
+ src/xz/private.h | 6 +-
+ src/xz/sandbox.c | 295 +++++++++++++++++++++++++++++++++++++++++++++++++++++
+ src/xz/sandbox.h | 39 +++++++
+ 8 files changed, 357 insertions(+), 213 deletions(-)
+
+commit 7312dfbb02197c7f990c7a3cefd027a9387d1473
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2024-02-17 23:07:35 +0200
+
+ xz: Tweak comments.
+
+ src/xz/main.c | 4 +++-
+ 1 file changed, 3 insertions(+), 1 deletion(-)
+
+commit c701a5909ad9882469fbab4fab5d2d5556d3ba78
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2024-02-17 23:07:35 +0200
+
+ xz: Fix message_init() description.
+
+ Also explicitly initialize progress_automatic to make it clear
+ that it can be read before message_init() sets it. Static variable
+ was initialized to false by default already so this is only for
+ clarity.
+
+ src/xz/main.c | 3 ++-
+ src/xz/message.c | 2 +-
+ src/xz/message.h | 5 ++++-
+ 3 files changed, 7 insertions(+), 3 deletions(-)
+
+commit 9466306719f3b76e92fac4e55fbfd89ec92295fa
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2024-02-17 19:35:47 +0200
+
+ Build: Makefile.am: Sort EXTRA_DIST.
+
+ Dirs first, then files in case-sensitive ASCII order.
+
+ Makefile.am | 14 +++++++-------
+ 1 file changed, 7 insertions(+), 7 deletions(-)
+
+commit f3440e78c9517db75bfa52e1a378fad60b073bbe
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2024-02-17 19:25:05 +0200
+
+ Build: Don't install TODO.
+
+ Makefile.am | 2 +-
+ 1 file changed, 1 insertion(+), 1 deletion(-)
+
+commit a7a3b62e2ab03c82b2bd5c78da1d1fb8b8490381
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2024-02-18 01:09:11 +0800
+
+ Translations: Update the Korean man page translations.
+
+ po4a/ko.po | 1707 +++++++++++++++++++++++++++++++-----------------------------
+ 1 file changed, 871 insertions(+), 836 deletions(-)
+
+commit 9b315db2d5e74700f3dc0755eb86c27947c0b393
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2024-02-18 01:08:32 +0800
+
+ Translations: Update the Korean translation.
+
+ po/ko.po | 423 +++++++++++++++++++++++++++++++++------------------------------
+ 1 file changed, 223 insertions(+), 200 deletions(-)
+
+commit 56246607dff177b0410d140fcca4a42c865723dc
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2024-02-17 16:23:14 +0200
+
+ Build: Install translated lzmainfo man pages.
+
+ All other translated man pages were being installed but
+ lzmainfo had been forgotten.
+
+ src/lzmainfo/Makefile.am | 26 ++++++++++++++++++++++++++
+ 1 file changed, 26 insertions(+)
+
+commit f1d6b88aefcced538403c5c2606ba57065b16e70
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2024-02-17 16:01:32 +0200
+
+ liblzma: Avoid implementation-defined behavior in the RISC-V filter.
+
+ GCC docs promise that it works and a few other compilers do
+ too. Clang/LLVM is documented source code only but unsurprisingly
+ it behaves the same as others on x86-64 at least. But the
+ certainly-portable way is good enough here so use that.
+
+ src/liblzma/simple/riscv.c | 30 ++++++++++++++++++++++--------
+ 1 file changed, 22 insertions(+), 8 deletions(-)
+
+commit 843ddc5f617b91ae132d6bab0f2f2d9c9fcd214a
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2024-02-17 15:48:28 +0200
+
+ liblzma: Wrap a line exceeding 80 chars.
+
+ src/liblzma/rangecoder/range_decoder.h | 3 ++-
+ 1 file changed, 2 insertions(+), 1 deletion(-)
+
+commit e9053c907250c70d98b319d95fa54cb94fc76869
+Author: Sebastian Andrzej Siewior <sebastian@breakpoint.cc>
+Date: 2024-02-16 21:50:15 +0100
+
+ liblzma/rangecoder: Exclude x32 from the x86-64 optimisation.
+
+ The x32 port has a x86-64 ABI in term of all registers but uses only
+ 32bit pointer like x86-32. The assembly optimisation fails to compile on
+ x32. Given the state of x32 I suggest to exclude it from the
+ optimisation rather than trying to fix it.
+
+ Signed-off-by: Sebastian Andrzej Siewior <sebastian@breakpoint.cc>
+
+ src/liblzma/rangecoder/range_decoder.h | 2 +-
+ 1 file changed, 1 insertion(+), 1 deletion(-)
+
+commit 3d198fb13b87f8803442e5799d465f7434a70555
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2024-02-17 21:05:07 +0800
+
+ Translations: Update the Spanish translation.
+
+ po/es.po | 427 +++++++++++++++++++++++++++++++++------------------------------
+ 1 file changed, 226 insertions(+), 201 deletions(-)
+
+commit cf278bfe60a25b54b3786f06503bc61272970820
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2024-02-17 20:43:29 +0800
+
+ Translations: Update the Swedish translation.
+
+ po/sv.po | 434 +++++++++++++++++++++++++++++++++------------------------------
+ 1 file changed, 230 insertions(+), 204 deletions(-)
+
+commit b0f1a41be50560cc6cb528e8e96b02b2067c52c2
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2024-02-17 20:41:38 +0800
+
+ Translations: Update the Polish translation.
+
+ po/pl.po | 424 +++++++++++++++++++++++++++++++++------------------------------
+ 1 file changed, 224 insertions(+), 200 deletions(-)
+
+commit d74ed48b30c631b6a4c7e7858b06828293bf8520
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2024-02-17 20:41:02 +0800
+
+ Translations: Update the Ukrainian translation.
+
+ po/uk.po | 2 +-
+ 1 file changed, 1 insertion(+), 1 deletion(-)
+
+commit 711e22d5c5f3bac39ac904efb3ede874a66e2045
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2024-02-16 17:53:34 +0200
+
+ Translations: Use the same sentence in xz.pot-header that the TP uses.
+
+ po/xz.pot-header | 2 +-
+ 1 file changed, 1 insertion(+), 1 deletion(-)
+
+commit fb5f6aaf18584672d0fee5dbe41fd30fc6bf5422
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2024-02-16 22:53:46 +0800
+
+ Fix typos discovered by codespell.
+
+ AUTHORS | 2 +-
+ NEWS | 2 +-
+ src/liblzma/rangecoder/range_decoder.h | 4 ++--
+ 3 files changed, 4 insertions(+), 4 deletions(-)
+
+commit c64723bbb094e29b4edd98f6fcce866e1b569b42
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2024-02-16 22:52:41 +0800
+
+ Translations: Update the Ukrainian man page translations.
+
+ po4a/uk.po | 1710 +++++++++++++++++++++++++++++++-----------------------------
+ 1 file changed, 873 insertions(+), 837 deletions(-)
+
+commit 2895195ed0f68b245c7bd568c126ba6e685fa1d6
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2024-02-16 22:51:04 +0800
+
+ Translations: Update the Ukrainian translation.
+
+ po/uk.po | 466 ++++++++++++++++++++++++++++++---------------------------------
+ 1 file changed, 225 insertions(+), 241 deletions(-)
+
+commit 4c20781f4c8f04879b64d631a4f44b4909147bde
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2024-02-15 22:32:52 +0200
+
+ Translations: Omit the generic copyright line from man page headers.
+
+ po4a/update-po | 1 +
+ 1 file changed, 1 insertion(+)
+
+commit 4323bc3e0c1e1d2037d5e670a3bf6633e8a3031e
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2024-02-15 22:26:43 +0800
+
+ Update m4/.gitignore.
+
+ m4/.gitignore | 1 +
+ 1 file changed, 1 insertion(+)
+
+commit 5394a1665b7a108a54cb8b4ef3ebe59d3dbcca3a
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2024-02-14 21:11:49 +0200
+
+ Tests: tuktest.h: Treat Clang separately from GCC.
+
+ Don't assume that Clang defines __GNUC__ as the extensions
+ are available in clang-cl as well (and possibly in some other
+ Clang variants?).
+
+ tests/tuktest.h | 6 +++---
+ 1 file changed, 3 insertions(+), 3 deletions(-)
+
+commit cce7330b9f23485a0879422e0c3395a7065439ac
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2024-02-14 21:11:03 +0200
+
+ Tests: tuktest.h: Add a missing word to a comment.
+
+ tests/tuktest.h | 4 ++--
+ 1 file changed, 2 insertions(+), 2 deletions(-)
+
+commit 5dd8fc9452a3373cedc27379067ce638f992c741
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2024-02-14 21:10:10 +0200
+
+ Tests: tuktest.h: Fix the comment about STest.
+
+ tests/tuktest.h | 3 ++-
+ 1 file changed, 2 insertions(+), 1 deletion(-)
+
+commit 6f1790254a03c5edf0f2976f773220f070450acd
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2024-02-15 01:53:40 +0800
+
+ Bump version for 5.5.2beta.
+
+ src/liblzma/api/lzma/version.h | 4 ++--
+ src/liblzma/liblzma_generic.map | 2 +-
+ src/liblzma/liblzma_linux.map | 2 +-
+ 3 files changed, 4 insertions(+), 4 deletions(-)
+
+commit 924fdeedf48113fb1e0646d86bd89a356d21a055
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2024-02-14 19:46:11 +0200
+
+ liblzma: Fix validate_map.sh.
+
+ Adding the SPDX license identifier changed the line numbers.
+
+ src/liblzma/validate_map.sh | 2 +-
+ 1 file changed, 1 insertion(+), 1 deletion(-)
+
+commit 22140a2df6161b0110e6b4afa5ea0a07c5b60b01
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2024-02-14 19:38:34 +0200
+
+ Build: Start the generated ChangeLog from around 5.4.0 instead of 5.2.0.
+
+ Makefile.am | 2 +-
+ 1 file changed, 1 insertion(+), 1 deletion(-)
+
+commit 0b8cefa136c21d403a01b78517f4decb50172bdb
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2024-02-14 19:27:46 +0200
+
+ Fixed NEWS for 5.5.2beta.
+
+ NEWS | 8 ++++++--
+ 1 file changed, 6 insertions(+), 2 deletions(-)
+
+commit a4557bad96361d93ea171ed859ac5a696fca824f
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2024-02-14 19:21:45 +0200
+
+ liblzma: Silence warnings in --enable-small build.
+
+ src/liblzma/lzma/lzma_decoder.c | 2 ++
+ src/liblzma/rangecoder/range_decoder.h | 1 +
+ 2 files changed, 3 insertions(+)
+
+commit 38edf473236d00b3e100dc4c4f0bf43a4993fed2
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2024-02-14 19:15:58 +0200
+
+ Build: Install COPYING.0BSD as part of docs.
+
+ Makefile.am | 1 +
+ 1 file changed, 1 insertion(+)
+
+commit b74e10bd839bcdc239afb5300ffaee195f34c217
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2024-02-14 19:14:05 +0200
+
+ Docs: List COPYING.0BSD in README.
+
+ README | 1 +
+ 1 file changed, 1 insertion(+)
+
+commit dfdb60ffe933a1f1497d300dbb4513ed17ec6f0e
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2024-02-14 19:11:48 +0200
+
+ Docs: Include doc/examples/11_file_info.c in tarballs.
+
+ It was added in 2017 in c2e29f06a7d1e3ba242ac2fafc69f5d6e92f62cd
+ but it never got into any release tarballs because it was
+ forgotten to be added to Makefile.am.
+
+ Makefile.am | 1 +
+ 1 file changed, 1 insertion(+)
+
+commit 160b6862646d95dfdbd73ab7f1031ede0f54992d
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2024-02-14 19:05:58 +0200
+
+ liblzma: Silence a warning.
+
+ src/liblzma/rangecoder/range_decoder.h | 2 +-
+ 1 file changed, 1 insertion(+), 1 deletion(-)
+
+commit eeedd4d0925ea417add04ceb42a6c0829244b50c
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2024-02-14 18:32:27 +0200
+
+ Add NEWS for 5.5.2beta.
+
+ NEWS | 60 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
+ 1 file changed, 60 insertions(+)
+
+commit 8af7db854f903068d72a9a0d21103cb0c5027fa8
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2024-02-13 14:32:47 +0200
+
+ xz: Mention lzmainfo if trying to use 'lzma --list'.
+
+ This kind of fixes the problem reported here:
+ https://bugs.launchpad.net/ubuntu/+source/xz-utils/+bug/1291020
+
+ src/xz/list.c | 16 ++++++++++++++--
+ 1 file changed, 14 insertions(+), 2 deletions(-)
+
+commit 0668907ff736e4cd16738c10d39a2bc9e851aefb
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2024-02-14 14:58:36 +0200
+
+ liblzma: Add comments.
+
+ src/liblzma/lzma/lzma_decoder.c | 9 +++++++++
+ src/liblzma/rangecoder/range_decoder.h | 11 +++++++++--
+ 2 files changed, 18 insertions(+), 2 deletions(-)
+
+commit 109f1913d4824c8214d5bbd38ebebf62c37572da
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2024-02-13 17:00:17 +0200
+
+ Scripts: Add lz4 support to xzgrep and xzdiff.
+
+ src/scripts/xzdiff.1 | 8 +++++---
+ src/scripts/xzdiff.in | 14 +++++++++-----
+ src/scripts/xzgrep.1 | 6 ++++--
+ src/scripts/xzgrep.in | 1 +
+ 4 files changed, 19 insertions(+), 10 deletions(-)
+
+commit de55485cb23af56c5adbe3239b935c957ff8ac4f
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2024-02-13 14:05:13 +0200
+
+ liblzma: Choose the range decoder variants using a bitmask macro.
+
+ src/liblzma/rangecoder/range_decoder.h | 64 ++++++++++++++++++++++++++++------
+ 1 file changed, 53 insertions(+), 11 deletions(-)
+
+commit 0709c2b2d7c1d8f437b003f691880fd7810e5be5
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2024-02-13 11:38:10 +0200
+
+ xz: Fix outdated threading related info on the man page.
+
+ src/xz/xz.1 | 22 ++++++++++++++--------
+ 1 file changed, 14 insertions(+), 8 deletions(-)
+
+commit 3182a330c1512cc1f5c87b5c5a272578e60a5158
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2024-02-12 17:09:10 +0200
+
+ liblzma: Range decoder: Add x86-64 inline assembly.
+
+ It's compatible with GCC and Clang.
+
+ src/liblzma/rangecoder/range_decoder.h | 491 +++++++++++++++++++++++++++++++++
+ 1 file changed, 491 insertions(+)
+
+commit cba2edc991dffba7cd4891dbc1bd26cb950cf053
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2024-02-12 17:09:10 +0200
+
+ liblzma: Range decoder: Add branchless C code.
+
+ It's used only for basic bittrees and fixed-size reverse bittree
+ because those showed a clear benefit on x86-64 with GCC and Clang.
+ The other methods were more mixed and thus are commented out but
+ they should be tested on other archs.
+
+ src/liblzma/rangecoder/range_decoder.h | 76 ++++++++++++++++++++++++++++++++++
+ 1 file changed, 76 insertions(+)
+
+commit e290a72d6dee71faf3a90c9678b2f730083666a7
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2024-02-12 17:09:10 +0200
+
+ liblzma: Clarify a comment.
+
+ src/liblzma/lzma/lzma_decoder.c | 9 ++++++---
+ 1 file changed, 6 insertions(+), 3 deletions(-)
+
+commit 5e04706b91ca90d6befd4da24a588a55e631d4a9
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2024-02-12 17:09:10 +0200
+
+ liblzma: LZMA decoder: Optimize loop comparison.
+
+ But now it needs one more local variable.
+
+ src/liblzma/lzma/lzma_decoder.c | 5 ++---
+ src/liblzma/rangecoder/range_decoder.h | 10 +++++++++-
+ 2 files changed, 11 insertions(+), 4 deletions(-)
+
+commit 88276f9f2cb4871c7eb86952d93d07c1cf6caa66
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2024-02-12 17:09:10 +0200
+
+ liblzma: Optimize literal_subcoder() macro slightly.
+
+ src/liblzma/lzma/lzma_common.h | 22 ++++++++++++----------
+ src/liblzma/lzma/lzma_decoder.c | 12 ++++++------
+ src/liblzma/lzma/lzma_encoder.c | 6 +++---
+ src/liblzma/lzma/lzma_encoder_optimum_normal.c | 2 +-
+ src/liblzma/lzma/lzma_encoder_private.h | 4 ++--
+ 5 files changed, 24 insertions(+), 22 deletions(-)
+
+commit 5938f6de4d8ec9656776cd69e78ddfd6c3ad84e5
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2024-02-12 17:09:10 +0200
+
+ liblzma: LZ decoder: Add unlikely().
+
+ src/liblzma/lz/lz_decoder.h | 2 +-
+ 1 file changed, 1 insertion(+), 1 deletion(-)
+
+commit 9c252e3ed086c6b72590b2531586c42596d4a9d9
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2024-02-12 17:09:10 +0200
+
+ liblzma: LZ decoder: Remove a useless unlikely().
+
+ src/liblzma/lz/lz_decoder.h | 2 +-
+ 1 file changed, 1 insertion(+), 1 deletion(-)
+
+commit f3872a59475456c5d365cad9f1c5be514cfa54b5
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2024-02-12 17:09:10 +0200
+
+ liblzma: Optimize LZ decoder slightly.
+
+ Now extra buffer space is reserved so that repeating bytes for
+ any single match will never need to copy from two places (both
+ the beginning and the end of the buffer). This simplifies
+ dict_repeat() and helps a little with speed.
+
+ This seems to reduce .lzma decompression time about 2 %, so
+ with .xz and CRC it could be slightly less. The small things
+ add up still.
+
+ src/liblzma/lz/lz_decoder.c | 43 ++++++++++++-----
+ src/liblzma/lz/lz_decoder.h | 101 +++++++++++++++++++++-------------------
+ src/liblzma/lzma/lzma_decoder.c | 4 +-
+ 3 files changed, 88 insertions(+), 60 deletions(-)
+
+commit eb518446e578acf079abae5f1ce28db7b6e59bc1
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2024-02-12 17:09:10 +0200
+
+ liblzma: LZMA decoder: Get rid of next_state[].
+
+ It's not completely obvious if this is better in the decoder.
+ It should be good if compiler can avoid creating a branch
+ (like using CMOV on x86).
+
+ This also makes lzma_encoder.c use the new macros.
+
+ src/liblzma/lzma/lzma_common.h | 14 ++++++++++++++
+ src/liblzma/lzma/lzma_decoder.c | 30 ++++++++----------------------
+ src/liblzma/lzma/lzma_encoder.c | 4 ++--
+ 3 files changed, 24 insertions(+), 24 deletions(-)
+
+commit e0c0ee475c0800c08291ae45e0d66aa00d5ce604
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2024-02-12 17:09:10 +0200
+
+ liblzma: LZMA decoder improvements.
+
+ This adds macros for bittree decoding which prepares the code
+ for alternative C versions and inline assembly.
+
+ src/liblzma/lzma/lzma_decoder.c | 264 ++++++++++-----------------------
+ src/liblzma/rangecoder/range_common.h | 4 +
+ src/liblzma/rangecoder/range_decoder.h | 142 ++++++++++++++++--
+ 3 files changed, 210 insertions(+), 200 deletions(-)
+
+commit de5c5e417645ad8906ef914bc059d08c1462fc29
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2024-02-12 17:09:10 +0200
+
+ liblzma: Creates Non-resumable and Resumable modes for lzma_decoder.
+
+ The new decoder resumes the first decoder loop in the Resumable mode.
+ Then, the code executes in Non-resumable mode until it detects that it
+ cannot guarantee to have enough input/output to decode another symbol.
+
+ The Resumable mode is how the decoder has always worked. Before decoding
+ every input bit, it checks if there is enough space and will save its
+ location to be resumed later. When the decoder has more input/output,
+ it jumps back to the correct sequence in the Resumable mode code.
+
+ When the input/output buffers are large, the Resumable mode is much
+ slower than the Non-resumable because it has more branches and is harder
+ for the compiler to optimize since it is in a large switch block.
+
+ Early benchmarking shows significant time improvement (8-10% on gcc and
+ clang x86) by using the Non-resumable code as much as possible.
+
+ src/liblzma/lz/lz_decoder.h | 14 +-
+ src/liblzma/lzma/lzma_decoder.c | 720 ++++++++++++++++++++++++++++------------
+ 2 files changed, 521 insertions(+), 213 deletions(-)
+
+commit e446ab7a18abfde18f8d1cf02a914df72b1370e3
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2024-02-12 17:09:10 +0200
+
+ liblzma: Creates separate "safe" range decoder mode.
+
+ The new "safe" range decoder mode is the same as old range decoder, but
+ now the default behavior of the range decoder will not check if there is
+ enough input or output to complete the operation. When the buffers are
+ close to fully consumed, the "safe" operations must be used instead. This
+ will improve speed because it will reduce the number of branches needed
+ for most of the range decoder operations.
+
+ src/liblzma/lzma/lzma_decoder.c | 108 ++++++++-------------------------
+ src/liblzma/rangecoder/range_decoder.h | 77 +++++++++++++++++------
+ 2 files changed, 82 insertions(+), 103 deletions(-)
+
+commit 7f6d9ca329ff3e01d4b0be7366eb4f5c93da41b9
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2024-02-12 17:09:10 +0200
+
+ doxygen/footer.html: Add missing closing tags and don't open a new tab.
+
+ The footer template from Doxygen has the closing </body> </html>
+ as Doxygen doesn't add them otherwise.
+
+ target="_blank" was omitted as it's not useful here but
+ it can be slightly annoying as one cannot just go back
+ in the browser history.
+
+ Since the footer links to the license file in the same
+ directory and not to CC website, the rel attributes
+ can be omitted.
+
+ doxygen/footer.html | 6 ++++--
+ 1 file changed, 4 insertions(+), 2 deletions(-)
+
+commit 26d1527d34d52b0f5d632d4fb636fb33d0867e92
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2024-02-13 13:19:10 +0200
+
+ Tweak the expressions in AUTHORS.
+
+ AUTHORS | 31 +++++++++++++++++++++++--------
+ 1 file changed, 23 insertions(+), 8 deletions(-)
+
+commit d231d56580175fa040fdd3c6207a58243ce6217b
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2024-02-13 13:07:33 +0200
+
+ Translations: Add the man page translators into man page header comment.
+
+ It looked odd to only have the original English authors listed
+ in the header comments of the translated files.
+
+ po4a/.gitignore | 1 +
+ po4a/po4a.conf | 14 +++++++-------
+ po4a/update-po | 18 ++++++++++++++++++
+ 3 files changed, 26 insertions(+), 7 deletions(-)
+
+commit 6d35fcb936474fca1acaebfd9502c097b6fde88e
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2024-02-12 17:09:10 +0200
+
+ Translations: Translate also messages of lzmainfo.
+
+ lzmainfo has had translation support since 2009 at least but
+ it was never added to po/POTFILES.in so the messages weren't
+ translated. It's a very rarely needed tool so it's not too bad.
+
+ This also adds src/xz/mytime.c to po/POTFILES.in although there
+ are no translatable strings. It's simpler this way so that it
+ won't be forgotten if strings were ever added to that file.
+
+ po/POTFILES.in | 2 ++
+ 1 file changed, 2 insertions(+)
+
+commit a9f369dd54b05f9ac4e00ead9d765d04fc259868
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2024-02-12 17:09:10 +0200
+
+ Translations: Add custom .pot header with SPDX license identifier.
+
+ The same is used for both po/xz.pot and po4a/xz-man.pot.
+
+ Makefile.am | 1 +
+ po/xz.pot-header | 7 +++++++
+ po4a/update-po | 8 ++++++++
+ 3 files changed, 16 insertions(+)
+
+commit 469cd6653bb96e83c5cf1031c204d34566b15f44
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2024-02-12 17:09:10 +0200
+
+ Translations: po4a/update-po: Add copyright notice to xz-man.pot.
+
+ All man pages are under 0BSD now so this is simple now.
+
+ po4a/update-po | 2 +-
+ 1 file changed, 1 insertion(+), 1 deletion(-)
+
+commit 28ce45e38fbed4b5f54f2013e38dab47d22bf699
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2024-02-12 17:09:10 +0200
+
+ Update COPYING about the man pages of the scripts.
+
+ COPYING | 6 +++---
+ 1 file changed, 3 insertions(+), 3 deletions(-)
+
+commit e48287bf51afd5184ea74de1dcade9e153f873f7
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2024-02-12 17:09:10 +0200
+
+ xzdiff, xzgrep, and xzmore: Rewrite the man pages.
+
+ The main reason is a kind of silly one:
+
+ xz-man.pot contains strings from all man pages in XZ Utils.
+ The man pages of xzdiff, xzgrep, and xzmore were under GPLv2
+ and the rest under 0BSD. Thus xz-man.pot contained strings
+ under two licences. po4a creates the translated man pages
+ from the combined 0BSD+GPLv2 xz-man.pot.
+
+ I haven't liked this mixing in xz-man.pot but the
+ Translation Project requires that all man pages must be
+ in the same .pot file. So a separate xz-man-gpl.pot
+ wasn't an option.
+
+ Since these man pages are short, rewriting them was quick enough.
+ Now xz-man.pot is entirely under 0BSD and marking the per-file
+ licenses is simpler.
+
+ As a bonus, some wording hopefully is now slightly better
+ although it's perhaps a matter of taste.
+
+ NOTE: In xzgrep.1, the EXIT STATUS section was written by me
+ in the commit d796b6d7fdb8b7238b277056cf9146cce25db604 so that's
+ why that section could be taken as is from the old xzgrep.1.
+
+ src/scripts/xzdiff.1 | 94 ++++++++++++++++++++++++-----------------
+ src/scripts/xzgrep.1 | 116 ++++++++++++++++++++++++++++++++-------------------
+ src/scripts/xzmore.1 | 79 ++++++++++++++++++++---------------
+ 3 files changed, 173 insertions(+), 116 deletions(-)
+
+commit 3e551b111b8ae8150f1a1040364dbafc034f22be
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2024-02-12 17:09:10 +0200
+
+ xzless: Update man page slightly.
+
+ The xz tool can decompress three file formats and xzless
+ has always supported uncompressed files too.
+
+ src/scripts/xzless.1 | 8 ++++----
+ 1 file changed, 4 insertions(+), 4 deletions(-)
+
+commit 40f36da2262d13d6e1ba8449caa855512ae626d7
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2024-02-12 17:09:10 +0200
+
+ Translations: Change po/Makevars to add a copyright notice to po/xz.pot.
+
+ po/Makevars | 4 ++--
+ 1 file changed, 2 insertions(+), 2 deletions(-)
+
+commit 24192854e2ea5c06997431a98bda3c36c5da1497
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2024-02-12 17:09:10 +0200
+
+ Translations: Update po/Makevars to use the template from gettext 0.22.4.
+
+ Also add SPDX license identifier now that there is a known license.
+
+ po/Makevars | 51 ++++++++++++++++++++++++++++++++++++++++++++++-----
+ 1 file changed, 46 insertions(+), 5 deletions(-)
+
+commit b94154957370116480b43bcabca25fc52deb9853
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2024-02-12 17:09:10 +0200
+
+ liblzma: Include the SPDX license identifier 0BSD to generated files.
+
+ Perhaps the generated files aren't even copyrightable but
+ using the same license for them as for the rest of the liblzma
+ keeps things more consistent for tools that look for license info.
+
+ src/liblzma/check/crc32_table_be.h | 4 +++-
+ src/liblzma/check/crc32_table_le.h | 4 +++-
+ src/liblzma/check/crc32_tablegen.c | 16 ++++++++++------
+ src/liblzma/check/crc64_table_be.h | 4 +++-
+ src/liblzma/check/crc64_table_le.h | 4 +++-
+ src/liblzma/check/crc64_tablegen.c | 8 +++++---
+ src/liblzma/lz/lz_encoder_hash_table.h | 4 +++-
+ src/liblzma/lzma/fastpos_table.c | 4 +++-
+ src/liblzma/lzma/fastpos_tablegen.c | 12 +++++++-----
+ src/liblzma/rangecoder/price_table.c | 4 +++-
+ src/liblzma/rangecoder/price_tablegen.c | 12 +++++++-----
+ 11 files changed, 50 insertions(+), 26 deletions(-)
+
+commit 8e4ec794836bc1701d8c9bd5e347b8ce8cc5bbb4
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2024-02-12 17:09:10 +0200
+
+ liblzma: Fix compilation of price_tablegen.c.
+
+ It is built and run only manually so this didn't matter
+ unless one wanted to regenerate the price_table.c.
+
+ src/liblzma/rangecoder/price_tablegen.c | 5 +++++
+ src/liblzma/rangecoder/range_common.h | 5 ++++-
+ 2 files changed, 9 insertions(+), 1 deletion(-)
+
+commit e99bff3ffbcdf2634fd5bd13887627ec7dbfecaf
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2024-02-12 17:09:10 +0200
+
+ Add SPDX license identifiers to GPL, LGPL, and FSFULLR files.
+
+ extra/scanlzma/scanlzma.c | 2 ++
+ lib/Makefile.am | 2 ++
+ lib/getopt-cdefs.h | 2 ++
+ lib/getopt-core.h | 2 ++
+ lib/getopt-ext.h | 2 ++
+ lib/getopt-pfx-core.h | 2 ++
+ lib/getopt-pfx-ext.h | 2 ++
+ lib/getopt.c | 2 ++
+ lib/getopt.in.h | 2 ++
+ lib/getopt1.c | 2 ++
+ lib/getopt_int.h | 2 ++
+ m4/ax_pthread.m4 | 2 ++
+ m4/getopt.m4 | 2 ++
+ m4/posix-shell.m4 | 2 ++
+ m4/visibility.m4 | 2 ++
+ src/scripts/xzdiff.1 | 3 +--
+ src/scripts/xzdiff.in | 1 +
+ src/scripts/xzgrep.1 | 3 +--
+ src/scripts/xzgrep.in | 1 +
+ src/scripts/xzless.in | 1 +
+ src/scripts/xzmore.1 | 3 +--
+ src/scripts/xzmore.in | 1 +
+ 22 files changed, 37 insertions(+), 6 deletions(-)
+
+commit 22af94128b89a131f5e58ae69bee5e50227c15da
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2024-02-12 17:09:10 +0200
+
+ Add SPDX license identifier into 0BSD source code files.
+
+ .github/workflows/ci.yml | 2 ++
+ .github/workflows/windows-ci.yml | 2 ++
+ CMakeLists.txt | 2 ++
+ Makefile.am | 3 +--
+ autogen.sh | 1 +
+ build-aux/ci_build.sh | 3 ++-
+ build-aux/manconv.sh | 3 ++-
+ build-aux/version.sh | 3 ++-
+ cmake/remove-ordinals.cmake | 2 ++
+ cmake/tuklib_common.cmake | 4 ++++
+ cmake/tuklib_cpucores.cmake | 4 ++++
+ cmake/tuklib_integer.cmake | 4 ++++
+ cmake/tuklib_large_file_support.cmake | 4 ++++
+ cmake/tuklib_mbstr.cmake | 4 ++++
+ cmake/tuklib_physmem.cmake | 4 ++++
+ cmake/tuklib_progname.cmake | 4 ++++
+ configure.ac | 4 +++-
+ debug/Makefile.am | 3 +--
+ debug/crc32.c | 2 ++
+ debug/full_flush.c | 2 ++
+ debug/hex2bin.c | 2 ++
+ debug/known_sizes.c | 2 ++
+ debug/memusage.c | 2 ++
+ debug/repeat.c | 2 ++
+ debug/sync_flush.c | 2 ++
+ debug/translation.bash | 1 +
+ doc/examples/01_compress_easy.c | 2 ++
+ doc/examples/02_decompress.c | 2 ++
+ doc/examples/03_compress_custom.c | 2 ++
+ doc/examples/04_compress_easy_mt.c | 2 ++
+ doc/examples/11_file_info.c | 2 ++
+ doc/examples/Makefile | 3 +--
+ dos/Makefile | 2 ++
+ dos/config.h | 2 ++
+ doxygen/update-doxygen | 3 ++-
+ extra/7z2lzma/7z2lzma.bash | 3 ++-
+ m4/tuklib_common.m4 | 8 ++++++--
+ m4/tuklib_cpucores.m4 | 8 ++++++--
+ m4/tuklib_integer.m4 | 8 ++++++--
+ m4/tuklib_mbstr.m4 | 8 ++++++--
+ m4/tuklib_physmem.m4 | 8 ++++++--
+ m4/tuklib_progname.m4 | 8 ++++++--
+ po/POTFILES.in | 2 ++
+ po4a/po4a.conf | 2 ++
+ po4a/update-po | 3 ++-
+ src/Makefile.am | 3 +--
+ src/common/common_w32res.rc | 2 ++
+ src/common/mythread.h | 2 ++
+ src/common/sysdefs.h | 2 ++
+ src/common/tuklib_common.h | 2 ++
+ src/common/tuklib_config.h | 2 ++
+ src/common/tuklib_cpucores.c | 2 ++
+ src/common/tuklib_cpucores.h | 2 ++
+ src/common/tuklib_exit.c | 2 ++
+ src/common/tuklib_exit.h | 2 ++
+ src/common/tuklib_gettext.h | 2 ++
+ src/common/tuklib_integer.h | 2 ++
+ src/common/tuklib_mbstr.h | 2 ++
+ src/common/tuklib_mbstr_fw.c | 2 ++
+ src/common/tuklib_mbstr_width.c | 2 ++
+ src/common/tuklib_open_stdxxx.c | 2 ++
+ src/common/tuklib_open_stdxxx.h | 2 ++
+ src/common/tuklib_physmem.c | 2 ++
+ src/common/tuklib_physmem.h | 2 ++
+ src/common/tuklib_progname.c | 2 ++
+ src/common/tuklib_progname.h | 2 ++
+ src/liblzma/Makefile.am | 3 +--
+ src/liblzma/api/Makefile.am | 3 +--
+ src/liblzma/api/lzma.h | 2 ++
+ src/liblzma/api/lzma/base.h | 2 ++
+ src/liblzma/api/lzma/bcj.h | 2 ++
+ src/liblzma/api/lzma/block.h | 2 ++
+ src/liblzma/api/lzma/check.h | 2 ++
+ src/liblzma/api/lzma/container.h | 2 ++
+ src/liblzma/api/lzma/delta.h | 2 ++
+ src/liblzma/api/lzma/filter.h | 2 ++
+ src/liblzma/api/lzma/hardware.h | 2 ++
+ src/liblzma/api/lzma/index.h | 2 ++
+ src/liblzma/api/lzma/index_hash.h | 2 ++
+ src/liblzma/api/lzma/lzma12.h | 2 ++
+ src/liblzma/api/lzma/stream_flags.h | 2 ++
+ src/liblzma/api/lzma/version.h | 2 ++
+ src/liblzma/api/lzma/vli.h | 2 ++
+ src/liblzma/check/Makefile.inc | 4 ++--
+ src/liblzma/check/check.c | 2 ++
+ src/liblzma/check/check.h | 2 ++
+ src/liblzma/check/crc32_arm64.h | 2 ++
+ src/liblzma/check/crc32_fast.c | 2 ++
+ src/liblzma/check/crc32_small.c | 2 ++
+ src/liblzma/check/crc32_table.c | 2 ++
+ src/liblzma/check/crc32_tablegen.c | 2 ++
+ src/liblzma/check/crc32_x86.S | 2 ++
+ src/liblzma/check/crc64_fast.c | 2 ++
+ src/liblzma/check/crc64_small.c | 2 ++
+ src/liblzma/check/crc64_table.c | 2 ++
+ src/liblzma/check/crc64_tablegen.c | 2 ++
+ src/liblzma/check/crc64_x86.S | 2 ++
+ src/liblzma/check/crc_common.h | 2 ++
+ src/liblzma/check/crc_x86_clmul.h | 2 ++
+ src/liblzma/check/sha256.c | 2 ++
+ src/liblzma/common/Makefile.inc | 3 +--
+ src/liblzma/common/alone_decoder.c | 2 ++
+ src/liblzma/common/alone_decoder.h | 2 ++
+ src/liblzma/common/alone_encoder.c | 2 ++
+ src/liblzma/common/auto_decoder.c | 2 ++
+ src/liblzma/common/block_buffer_decoder.c | 2 ++
+ src/liblzma/common/block_buffer_encoder.c | 2 ++
+ src/liblzma/common/block_buffer_encoder.h | 2 ++
+ src/liblzma/common/block_decoder.c | 2 ++
+ src/liblzma/common/block_decoder.h | 2 ++
+ src/liblzma/common/block_encoder.c | 2 ++
+ src/liblzma/common/block_encoder.h | 2 ++
+ src/liblzma/common/block_header_decoder.c | 2 ++
+ src/liblzma/common/block_header_encoder.c | 2 ++
+ src/liblzma/common/block_util.c | 2 ++
+ src/liblzma/common/common.c | 2 ++
+ src/liblzma/common/common.h | 2 ++
+ src/liblzma/common/easy_buffer_encoder.c | 2 ++
+ src/liblzma/common/easy_decoder_memusage.c | 2 ++
+ src/liblzma/common/easy_encoder.c | 2 ++
+ src/liblzma/common/easy_encoder_memusage.c | 2 ++
+ src/liblzma/common/easy_preset.c | 2 ++
+ src/liblzma/common/easy_preset.h | 2 ++
+ src/liblzma/common/file_info.c | 2 ++
+ src/liblzma/common/filter_buffer_decoder.c | 2 ++
+ src/liblzma/common/filter_buffer_encoder.c | 2 ++
+ src/liblzma/common/filter_common.c | 2 ++
+ src/liblzma/common/filter_common.h | 2 ++
+ src/liblzma/common/filter_decoder.c | 2 ++
+ src/liblzma/common/filter_decoder.h | 2 ++
+ src/liblzma/common/filter_encoder.c | 2 ++
+ src/liblzma/common/filter_encoder.h | 2 ++
+ src/liblzma/common/filter_flags_decoder.c | 2 ++
+ src/liblzma/common/filter_flags_encoder.c | 2 ++
+ src/liblzma/common/hardware_cputhreads.c | 2 ++
+ src/liblzma/common/hardware_physmem.c | 2 ++
+ src/liblzma/common/index.c | 2 ++
+ src/liblzma/common/index.h | 2 ++
+ src/liblzma/common/index_decoder.c | 2 ++
+ src/liblzma/common/index_decoder.h | 2 ++
+ src/liblzma/common/index_encoder.c | 2 ++
+ src/liblzma/common/index_encoder.h | 2 ++
+ src/liblzma/common/index_hash.c | 2 ++
+ src/liblzma/common/lzip_decoder.c | 2 ++
+ src/liblzma/common/lzip_decoder.h | 2 ++
+ src/liblzma/common/memcmplen.h | 2 ++
+ src/liblzma/common/microlzma_decoder.c | 2 ++
+ src/liblzma/common/microlzma_encoder.c | 2 ++
+ src/liblzma/common/outqueue.c | 2 ++
+ src/liblzma/common/outqueue.h | 2 ++
+ src/liblzma/common/stream_buffer_decoder.c | 2 ++
+ src/liblzma/common/stream_buffer_encoder.c | 2 ++
+ src/liblzma/common/stream_decoder.c | 2 ++
+ src/liblzma/common/stream_decoder.h | 2 ++
+ src/liblzma/common/stream_decoder_mt.c | 2 ++
+ src/liblzma/common/stream_encoder.c | 2 ++
+ src/liblzma/common/stream_encoder_mt.c | 2 ++
+ src/liblzma/common/stream_flags_common.c | 2 ++
+ src/liblzma/common/stream_flags_common.h | 2 ++
+ src/liblzma/common/stream_flags_decoder.c | 2 ++
+ src/liblzma/common/stream_flags_encoder.c | 2 ++
+ src/liblzma/common/string_conversion.c | 2 ++
+ src/liblzma/common/vli_decoder.c | 2 ++
+ src/liblzma/common/vli_encoder.c | 2 ++
+ src/liblzma/common/vli_size.c | 2 ++
+ src/liblzma/delta/Makefile.inc | 3 +--
+ src/liblzma/delta/delta_common.c | 2 ++
+ src/liblzma/delta/delta_common.h | 2 ++
+ src/liblzma/delta/delta_decoder.c | 2 ++
+ src/liblzma/delta/delta_decoder.h | 2 ++
+ src/liblzma/delta/delta_encoder.c | 2 ++
+ src/liblzma/delta/delta_encoder.h | 2 ++
+ src/liblzma/delta/delta_private.h | 2 ++
+ src/liblzma/liblzma.pc.in | 3 +--
+ src/liblzma/liblzma_generic.map | 2 ++
+ src/liblzma/liblzma_linux.map | 2 ++
+ src/liblzma/liblzma_w32res.rc | 2 ++
+ src/liblzma/lz/Makefile.inc | 3 +--
+ src/liblzma/lz/lz_decoder.c | 2 ++
+ src/liblzma/lz/lz_decoder.h | 2 ++
+ src/liblzma/lz/lz_encoder.c | 2 ++
+ src/liblzma/lz/lz_encoder.h | 2 ++
+ src/liblzma/lz/lz_encoder_hash.h | 2 ++
+ src/liblzma/lz/lz_encoder_mf.c | 2 ++
+ src/liblzma/lzma/Makefile.inc | 3 +--
+ src/liblzma/lzma/fastpos.h | 2 ++
+ src/liblzma/lzma/fastpos_tablegen.c | 2 ++
+ src/liblzma/lzma/lzma2_decoder.c | 2 ++
+ src/liblzma/lzma/lzma2_decoder.h | 2 ++
+ src/liblzma/lzma/lzma2_encoder.c | 2 ++
+ src/liblzma/lzma/lzma2_encoder.h | 2 ++
+ src/liblzma/lzma/lzma_common.h | 2 ++
+ src/liblzma/lzma/lzma_decoder.c | 2 ++
+ src/liblzma/lzma/lzma_decoder.h | 2 ++
+ src/liblzma/lzma/lzma_encoder.c | 2 ++
+ src/liblzma/lzma/lzma_encoder.h | 2 ++
+ src/liblzma/lzma/lzma_encoder_optimum_fast.c | 2 ++
+ src/liblzma/lzma/lzma_encoder_optimum_normal.c | 2 ++
+ src/liblzma/lzma/lzma_encoder_presets.c | 2 ++
+ src/liblzma/lzma/lzma_encoder_private.h | 2 ++
+ src/liblzma/rangecoder/Makefile.inc | 3 +--
+ src/liblzma/rangecoder/price.h | 2 ++
+ src/liblzma/rangecoder/price_tablegen.c | 2 ++
+ src/liblzma/rangecoder/range_common.h | 2 ++
+ src/liblzma/rangecoder/range_decoder.h | 2 ++
+ src/liblzma/rangecoder/range_encoder.h | 2 ++
+ src/liblzma/simple/Makefile.inc | 3 +--
+ src/liblzma/simple/arm.c | 2 ++
+ src/liblzma/simple/arm64.c | 2 ++
+ src/liblzma/simple/armthumb.c | 2 ++
+ src/liblzma/simple/ia64.c | 2 ++
+ src/liblzma/simple/powerpc.c | 2 ++
+ src/liblzma/simple/riscv.c | 2 ++
+ src/liblzma/simple/simple_coder.c | 2 ++
+ src/liblzma/simple/simple_coder.h | 2 ++
+ src/liblzma/simple/simple_decoder.c | 2 ++
+ src/liblzma/simple/simple_decoder.h | 2 ++
+ src/liblzma/simple/simple_encoder.c | 2 ++
+ src/liblzma/simple/simple_encoder.h | 2 ++
+ src/liblzma/simple/simple_private.h | 2 ++
+ src/liblzma/simple/sparc.c | 2 ++
+ src/liblzma/simple/x86.c | 2 ++
+ src/liblzma/validate_map.sh | 1 +
+ src/lzmainfo/Makefile.am | 3 +--
+ src/lzmainfo/lzmainfo.c | 2 ++
+ src/lzmainfo/lzmainfo_w32res.rc | 2 ++
+ src/scripts/Makefile.am | 3 +--
+ src/xz/Makefile.am | 3 +--
+ src/xz/args.c | 2 ++
+ src/xz/args.h | 2 ++
+ src/xz/coder.c | 2 ++
+ src/xz/coder.h | 2 ++
+ src/xz/file_io.c | 2 ++
+ src/xz/file_io.h | 2 ++
+ src/xz/hardware.c | 2 ++
+ src/xz/hardware.h | 2 ++
+ src/xz/list.c | 2 ++
+ src/xz/list.h | 2 ++
+ src/xz/main.c | 2 ++
+ src/xz/main.h | 2 ++
+ src/xz/message.c | 2 ++
+ src/xz/message.h | 2 ++
+ src/xz/mytime.c | 2 ++
+ src/xz/mytime.h | 2 ++
+ src/xz/options.c | 2 ++
+ src/xz/options.h | 2 ++
+ src/xz/private.h | 2 ++
+ src/xz/signals.c | 2 ++
+ src/xz/signals.h | 2 ++
+ src/xz/suffix.c | 2 ++
+ src/xz/suffix.h | 2 ++
+ src/xz/util.c | 2 ++
+ src/xz/util.h | 2 ++
+ src/xz/xz_w32res.rc | 2 ++
+ src/xzdec/Makefile.am | 3 +--
+ src/xzdec/lzmadec_w32res.rc | 2 ++
+ src/xzdec/xzdec.c | 2 ++
+ src/xzdec/xzdec_w32res.rc | 2 ++
+ tests/Makefile.am | 3 +--
+ tests/bcj_test.c | 2 ++
+ tests/code_coverage.sh | 1 +
+ tests/create_compress_files.c | 2 ++
+ tests/ossfuzz/fuzz_common.h | 2 ++
+ tests/ossfuzz/fuzz_decode_alone.c | 2 ++
+ tests/ossfuzz/fuzz_decode_stream.c | 2 ++
+ tests/ossfuzz/fuzz_encode_stream.c | 2 ++
+ tests/test_bcj_exact_size.c | 2 ++
+ tests/test_block_header.c | 2 ++
+ tests/test_check.c | 2 ++
+ tests/test_compress.sh | 1 +
+ tests/test_compress_generated_abc | 1 +
+ tests/test_compress_generated_random | 1 +
+ tests/test_compress_generated_text | 1 +
+ tests/test_compress_prepared_bcj_sparc | 1 +
+ tests/test_compress_prepared_bcj_x86 | 1 +
+ tests/test_files.sh | 1 +
+ tests/test_filter_flags.c | 2 ++
+ tests/test_filter_str.c | 2 ++
+ tests/test_hardware.c | 2 ++
+ tests/test_index.c | 2 ++
+ tests/test_index_hash.c | 2 ++
+ tests/test_lzip_decoder.c | 2 ++
+ tests/test_memlimit.c | 2 ++
+ tests/test_scripts.sh | 1 +
+ tests/test_stream_flags.c | 2 ++
+ tests/test_suffix.sh | 1 +
+ tests/test_vli.c | 2 ++
+ tests/tests.h | 2 ++
+ tests/tuktest.h | 2 ++
+ windows/build.bash | 3 ++-
+ 290 files changed, 588 insertions(+), 58 deletions(-)
+
+commit 23de53421ea258cde6a3c33a038b1e9d08f771d1
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2024-02-12 23:25:54 +0200
+
+ liblzma: Sync the AUTHORS fix about SHA-256 to lzma.h.
+
+ src/liblzma/api/lzma.h | 10 ++++------
+ 1 file changed, 4 insertions(+), 6 deletions(-)
+
+commit 689e0228baeb95232430e90d628379db89583d71
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2024-02-12 17:09:10 +0200
+
+ Change most public domain parts to 0BSD.
+
+ Translations and doc/xz-file-format.txt and doc/lzma-file-format.txt
+ were not touched.
+
+ COPYING.0BSD was added.
+
+ .github/workflows/ci.yml | 3 -
+ .github/workflows/windows-ci.yml | 3 -
+ CMakeLists.txt | 3 -
+ COPYING | 112 ++++++++++++++-----------
+ COPYING.0BSD | 11 +++
+ Makefile.am | 3 -
+ PACKAGERS | 11 +--
+ autogen.sh | 3 -
+ build-aux/ci_build.sh | 3 -
+ build-aux/manconv.sh | 3 -
+ build-aux/version.sh | 3 -
+ cmake/remove-ordinals.cmake | 3 -
+ cmake/tuklib_common.cmake | 3 -
+ cmake/tuklib_cpucores.cmake | 3 -
+ cmake/tuklib_integer.cmake | 3 -
+ cmake/tuklib_large_file_support.cmake | 3 -
+ cmake/tuklib_mbstr.cmake | 3 -
+ cmake/tuklib_physmem.cmake | 3 -
+ cmake/tuklib_progname.cmake | 3 -
+ configure.ac | 3 -
+ debug/Makefile.am | 3 -
+ debug/crc32.c | 3 -
+ debug/full_flush.c | 3 -
+ debug/hex2bin.c | 3 -
+ debug/known_sizes.c | 3 -
+ debug/memusage.c | 3 -
+ debug/repeat.c | 3 -
+ debug/sync_flush.c | 3 -
+ debug/translation.bash | 3 -
+ doc/examples/01_compress_easy.c | 3 -
+ doc/examples/02_decompress.c | 3 -
+ doc/examples/03_compress_custom.c | 3 -
+ doc/examples/04_compress_easy_mt.c | 3 -
+ doc/examples/11_file_info.c | 3 -
+ doc/examples/Makefile | 3 -
+ dos/Makefile | 3 -
+ doxygen/update-doxygen | 3 -
+ extra/7z2lzma/7z2lzma.bash | 3 -
+ m4/tuklib_common.m4 | 3 -
+ m4/tuklib_cpucores.m4 | 3 -
+ m4/tuklib_integer.m4 | 3 -
+ m4/tuklib_mbstr.m4 | 3 -
+ m4/tuklib_physmem.m4 | 3 -
+ m4/tuklib_progname.m4 | 3 -
+ po4a/update-po | 3 -
+ src/Makefile.am | 3 -
+ src/common/common_w32res.rc | 3 -
+ src/common/mythread.h | 3 -
+ src/common/sysdefs.h | 3 -
+ src/common/tuklib_common.h | 3 -
+ src/common/tuklib_cpucores.c | 3 -
+ src/common/tuklib_cpucores.h | 3 -
+ src/common/tuklib_exit.c | 3 -
+ src/common/tuklib_exit.h | 3 -
+ src/common/tuklib_gettext.h | 3 -
+ src/common/tuklib_integer.h | 3 -
+ src/common/tuklib_mbstr.h | 3 -
+ src/common/tuklib_mbstr_fw.c | 3 -
+ src/common/tuklib_mbstr_width.c | 3 -
+ src/common/tuklib_open_stdxxx.c | 3 -
+ src/common/tuklib_open_stdxxx.h | 3 -
+ src/common/tuklib_physmem.c | 3 -
+ src/common/tuklib_physmem.h | 3 -
+ src/common/tuklib_progname.c | 3 -
+ src/common/tuklib_progname.h | 3 -
+ src/liblzma/Makefile.am | 3 -
+ src/liblzma/api/Makefile.am | 3 -
+ src/liblzma/api/lzma.h | 13 ++-
+ src/liblzma/api/lzma/base.h | 3 -
+ src/liblzma/api/lzma/bcj.h | 3 -
+ src/liblzma/api/lzma/block.h | 3 -
+ src/liblzma/api/lzma/check.h | 3 -
+ src/liblzma/api/lzma/container.h | 3 -
+ src/liblzma/api/lzma/delta.h | 3 -
+ src/liblzma/api/lzma/filter.h | 3 -
+ src/liblzma/api/lzma/hardware.h | 3 -
+ src/liblzma/api/lzma/index.h | 3 -
+ src/liblzma/api/lzma/index_hash.h | 3 -
+ src/liblzma/api/lzma/lzma12.h | 3 -
+ src/liblzma/api/lzma/stream_flags.h | 3 -
+ src/liblzma/api/lzma/version.h | 3 -
+ src/liblzma/api/lzma/vli.h | 3 -
+ src/liblzma/check/Makefile.inc | 3 -
+ src/liblzma/check/check.c | 3 -
+ src/liblzma/check/check.h | 3 -
+ src/liblzma/check/crc32_arm64.h | 3 -
+ src/liblzma/check/crc32_fast.c | 3 -
+ src/liblzma/check/crc32_small.c | 3 -
+ src/liblzma/check/crc32_table.c | 3 -
+ src/liblzma/check/crc32_tablegen.c | 3 -
+ src/liblzma/check/crc32_x86.S | 3 -
+ src/liblzma/check/crc64_fast.c | 3 -
+ src/liblzma/check/crc64_small.c | 3 -
+ src/liblzma/check/crc64_table.c | 3 -
+ src/liblzma/check/crc64_tablegen.c | 3 -
+ src/liblzma/check/crc64_x86.S | 3 -
+ src/liblzma/check/crc_common.h | 3 -
+ src/liblzma/check/crc_x86_clmul.h | 3 -
+ src/liblzma/check/sha256.c | 3 -
+ src/liblzma/common/Makefile.inc | 3 -
+ src/liblzma/common/alone_decoder.c | 3 -
+ src/liblzma/common/alone_decoder.h | 3 -
+ src/liblzma/common/alone_encoder.c | 3 -
+ src/liblzma/common/auto_decoder.c | 3 -
+ src/liblzma/common/block_buffer_decoder.c | 3 -
+ src/liblzma/common/block_buffer_encoder.c | 3 -
+ src/liblzma/common/block_buffer_encoder.h | 3 -
+ src/liblzma/common/block_decoder.c | 3 -
+ src/liblzma/common/block_decoder.h | 3 -
+ src/liblzma/common/block_encoder.c | 3 -
+ src/liblzma/common/block_encoder.h | 3 -
+ src/liblzma/common/block_header_decoder.c | 3 -
+ src/liblzma/common/block_header_encoder.c | 3 -
+ src/liblzma/common/block_util.c | 3 -
+ src/liblzma/common/common.c | 3 -
+ src/liblzma/common/common.h | 3 -
+ src/liblzma/common/easy_buffer_encoder.c | 3 -
+ src/liblzma/common/easy_decoder_memusage.c | 3 -
+ src/liblzma/common/easy_encoder.c | 3 -
+ src/liblzma/common/easy_encoder_memusage.c | 3 -
+ src/liblzma/common/easy_preset.c | 3 -
+ src/liblzma/common/easy_preset.h | 3 -
+ src/liblzma/common/file_info.c | 3 -
+ src/liblzma/common/filter_buffer_decoder.c | 3 -
+ src/liblzma/common/filter_buffer_encoder.c | 3 -
+ src/liblzma/common/filter_common.c | 3 -
+ src/liblzma/common/filter_common.h | 3 -
+ src/liblzma/common/filter_decoder.c | 3 -
+ src/liblzma/common/filter_decoder.h | 3 -
+ src/liblzma/common/filter_encoder.c | 3 -
+ src/liblzma/common/filter_encoder.h | 3 -
+ src/liblzma/common/filter_flags_decoder.c | 3 -
+ src/liblzma/common/filter_flags_encoder.c | 3 -
+ src/liblzma/common/hardware_cputhreads.c | 3 -
+ src/liblzma/common/hardware_physmem.c | 3 -
+ src/liblzma/common/index.c | 3 -
+ src/liblzma/common/index.h | 3 -
+ src/liblzma/common/index_decoder.c | 3 -
+ src/liblzma/common/index_decoder.h | 3 -
+ src/liblzma/common/index_encoder.c | 3 -
+ src/liblzma/common/index_encoder.h | 3 -
+ src/liblzma/common/index_hash.c | 3 -
+ src/liblzma/common/lzip_decoder.c | 3 -
+ src/liblzma/common/lzip_decoder.h | 3 -
+ src/liblzma/common/memcmplen.h | 3 -
+ src/liblzma/common/microlzma_decoder.c | 3 -
+ src/liblzma/common/microlzma_encoder.c | 3 -
+ src/liblzma/common/outqueue.c | 3 -
+ src/liblzma/common/outqueue.h | 3 -
+ src/liblzma/common/stream_buffer_decoder.c | 3 -
+ src/liblzma/common/stream_buffer_encoder.c | 3 -
+ src/liblzma/common/stream_decoder.c | 3 -
+ src/liblzma/common/stream_decoder.h | 3 -
+ src/liblzma/common/stream_decoder_mt.c | 3 -
+ src/liblzma/common/stream_encoder.c | 3 -
+ src/liblzma/common/stream_encoder_mt.c | 3 -
+ src/liblzma/common/stream_flags_common.c | 3 -
+ src/liblzma/common/stream_flags_common.h | 3 -
+ src/liblzma/common/stream_flags_decoder.c | 3 -
+ src/liblzma/common/stream_flags_encoder.c | 3 -
+ src/liblzma/common/string_conversion.c | 3 -
+ src/liblzma/common/vli_decoder.c | 3 -
+ src/liblzma/common/vli_encoder.c | 3 -
+ src/liblzma/common/vli_size.c | 3 -
+ src/liblzma/delta/Makefile.inc | 3 -
+ src/liblzma/delta/delta_common.c | 3 -
+ src/liblzma/delta/delta_common.h | 3 -
+ src/liblzma/delta/delta_decoder.c | 3 -
+ src/liblzma/delta/delta_decoder.h | 3 -
+ src/liblzma/delta/delta_encoder.c | 3 -
+ src/liblzma/delta/delta_encoder.h | 3 -
+ src/liblzma/delta/delta_private.h | 3 -
+ src/liblzma/liblzma.pc.in | 3 -
+ src/liblzma/liblzma_w32res.rc | 3 -
+ src/liblzma/lz/Makefile.inc | 3 -
+ src/liblzma/lz/lz_decoder.c | 3 -
+ src/liblzma/lz/lz_decoder.h | 3 -
+ src/liblzma/lz/lz_encoder.c | 3 -
+ src/liblzma/lz/lz_encoder.h | 3 -
+ src/liblzma/lz/lz_encoder_hash.h | 3 -
+ src/liblzma/lz/lz_encoder_mf.c | 3 -
+ src/liblzma/lzma/Makefile.inc | 3 -
+ src/liblzma/lzma/fastpos.h | 3 -
+ src/liblzma/lzma/fastpos_tablegen.c | 3 -
+ src/liblzma/lzma/lzma2_decoder.c | 3 -
+ src/liblzma/lzma/lzma2_decoder.h | 3 -
+ src/liblzma/lzma/lzma2_encoder.c | 3 -
+ src/liblzma/lzma/lzma2_encoder.h | 3 -
+ src/liblzma/lzma/lzma_common.h | 3 -
+ src/liblzma/lzma/lzma_decoder.c | 3 -
+ src/liblzma/lzma/lzma_decoder.h | 3 -
+ src/liblzma/lzma/lzma_encoder.c | 3 -
+ src/liblzma/lzma/lzma_encoder.h | 3 -
+ src/liblzma/lzma/lzma_encoder_optimum_fast.c | 3 -
+ src/liblzma/lzma/lzma_encoder_optimum_normal.c | 3 -
+ src/liblzma/lzma/lzma_encoder_presets.c | 3 -
+ src/liblzma/lzma/lzma_encoder_private.h | 3 -
+ src/liblzma/rangecoder/Makefile.inc | 3 -
+ src/liblzma/rangecoder/price.h | 3 -
+ src/liblzma/rangecoder/price_tablegen.c | 3 -
+ src/liblzma/rangecoder/range_common.h | 3 -
+ src/liblzma/rangecoder/range_decoder.h | 3 -
+ src/liblzma/rangecoder/range_encoder.h | 3 -
+ src/liblzma/simple/Makefile.inc | 3 -
+ src/liblzma/simple/arm.c | 3 -
+ src/liblzma/simple/arm64.c | 3 -
+ src/liblzma/simple/armthumb.c | 3 -
+ src/liblzma/simple/ia64.c | 3 -
+ src/liblzma/simple/powerpc.c | 3 -
+ src/liblzma/simple/riscv.c | 3 -
+ src/liblzma/simple/simple_coder.c | 3 -
+ src/liblzma/simple/simple_coder.h | 3 -
+ src/liblzma/simple/simple_decoder.c | 3 -
+ src/liblzma/simple/simple_decoder.h | 3 -
+ src/liblzma/simple/simple_encoder.c | 3 -
+ src/liblzma/simple/simple_encoder.h | 3 -
+ src/liblzma/simple/simple_private.h | 3 -
+ src/liblzma/simple/sparc.c | 3 -
+ src/liblzma/simple/x86.c | 3 -
+ src/liblzma/validate_map.sh | 3 -
+ src/lzmainfo/Makefile.am | 3 -
+ src/lzmainfo/lzmainfo.1 | 4 +-
+ src/lzmainfo/lzmainfo.c | 3 -
+ src/lzmainfo/lzmainfo_w32res.rc | 3 -
+ src/scripts/Makefile.am | 3 -
+ src/scripts/xzless.1 | 4 +-
+ src/xz/Makefile.am | 3 -
+ src/xz/args.c | 3 -
+ src/xz/args.h | 3 -
+ src/xz/coder.c | 3 -
+ src/xz/coder.h | 3 -
+ src/xz/file_io.c | 3 -
+ src/xz/file_io.h | 3 -
+ src/xz/hardware.c | 3 -
+ src/xz/hardware.h | 3 -
+ src/xz/list.c | 3 -
+ src/xz/list.h | 3 -
+ src/xz/main.c | 3 -
+ src/xz/main.h | 3 -
+ src/xz/message.c | 3 -
+ src/xz/message.h | 3 -
+ src/xz/mytime.c | 3 -
+ src/xz/mytime.h | 3 -
+ src/xz/options.c | 3 -
+ src/xz/options.h | 3 -
+ src/xz/private.h | 3 -
+ src/xz/signals.c | 3 -
+ src/xz/signals.h | 3 -
+ src/xz/suffix.c | 3 -
+ src/xz/suffix.h | 3 -
+ src/xz/util.c | 3 -
+ src/xz/util.h | 3 -
+ src/xz/xz.1 | 4 +-
+ src/xz/xz_w32res.rc | 3 -
+ src/xzdec/Makefile.am | 3 -
+ src/xzdec/lzmadec_w32res.rc | 3 -
+ src/xzdec/xzdec.1 | 4 +-
+ src/xzdec/xzdec.c | 3 -
+ src/xzdec/xzdec_w32res.rc | 3 -
+ tests/Makefile.am | 3 -
+ tests/bcj_test.c | 3 -
+ tests/code_coverage.sh | 3 -
+ tests/create_compress_files.c | 3 -
+ tests/files/README | 3 +-
+ tests/ossfuzz/fuzz_common.h | 3 -
+ tests/ossfuzz/fuzz_decode_alone.c | 3 -
+ tests/ossfuzz/fuzz_decode_stream.c | 3 -
+ tests/ossfuzz/fuzz_encode_stream.c | 3 -
+ tests/test_bcj_exact_size.c | 3 -
+ tests/test_block_header.c | 3 -
+ tests/test_check.c | 3 -
+ tests/test_compress.sh | 3 -
+ tests/test_files.sh | 3 -
+ tests/test_filter_flags.c | 3 -
+ tests/test_filter_str.c | 3 -
+ tests/test_hardware.c | 3 -
+ tests/test_index.c | 3 -
+ tests/test_index_hash.c | 3 -
+ tests/test_lzip_decoder.c | 3 -
+ tests/test_memlimit.c | 3 -
+ tests/test_scripts.sh | 3 -
+ tests/test_stream_flags.c | 3 -
+ tests/test_suffix.sh | 3 -
+ tests/test_vli.c | 3 -
+ tests/tests.h | 3 -
+ tests/tuktest.h | 3 -
+ windows/README-Windows.txt | 11 +--
+ windows/build.bash | 3 -
+ 288 files changed, 100 insertions(+), 911 deletions(-)
+
+commit 76946dc4336c831fe2cc26696a035d807dd3cf13
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2024-02-09 17:20:31 +0200
+
+ Fix SHA-256 authors.
+
+ The initial commit 5d018dc03549c1ee4958364712fb0c94e1bf2741
+ in 2007 had a comment in sha256.c that the code is based on
+ Crypto++ Library 5.5.1. In 2009 the Authors list in sha256.c
+ and the AUTHORS file was updated with information that the
+ code had come from Crypto++ but via 7-Zip. I know I had viewed
+ 7-Zip's SHA-256 code but back then the C code has been identical
+ enough with Crypto++, so I don't why I thought the author info
+ would need that extra step via 7-Zip for this single file.
+
+ Another error is that I had mixed sha.* and shacal2.* files
+ when checking for author info in Crypto++. The shacal2.* files
+ aren't related to liblzma's sha256.c and thus Kevin Springle's
+ code in Crypto++ isn't either.
+
+ AUTHORS | 6 ++----
+ src/liblzma/check/sha256.c | 14 ++++----------
+ 2 files changed, 6 insertions(+), 14 deletions(-)
+
+commit 21d9cbae9eecca28ce373d3d9464defd2cf5d851
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2024-02-09 17:20:31 +0200
+
+ Remove macosx/build.sh.
+
+ It was last updated in 2013.
+
+ Makefile.am | 1 -
+ macosx/build.sh | 113 --------------------------------------------------------
+ 2 files changed, 114 deletions(-)
+
+commit eac2c3c67f9113a225fb6667df862edd30366931
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2024-02-09 17:20:31 +0200
+
+ Doc: Remove doc/examples_old.
+
+ It was good to keep these around in parallel with the newer examples
+ but I think it's OK to remove the old ones at this point.
+
+ Makefile.am | 5 --
+ doc/examples_old/xz_pipe_comp.c | 127 --------------------------------------
+ doc/examples_old/xz_pipe_decomp.c | 123 ------------------------------------
+ 3 files changed, 255 deletions(-)
+
+commit 89ea1a22f4ed3685b053b7260bc5acf6c75d1664
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2024-02-13 22:38:58 +0800
+
+ Tests: Add RISC-V filter support in a few places.
+
+ tests/test_filter_flags.c | 6 ++++++
+ tests/test_filter_str.c | 6 ++++++
+ 2 files changed, 12 insertions(+)
+
+commit 45663443eb2b377e6171529380fee312f1adcdf4
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2024-02-13 22:37:07 +0800
+
+ liblzma: Fix build error if only RISC-V BCJ filter is enabled.
+
+ If any other BCJ filter was enabled for encoding or decoding, then this
+ was not a problem.
+
+ src/liblzma/common/string_conversion.c | 4 +++-
+ 1 file changed, 3 insertions(+), 1 deletion(-)
+
+commit 2f15597d677bc35743c777d4cf3bfa698b478681
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2024-02-13 22:56:24 +0800
+
+ Translations: Update the Korean translation.
+
+ po/ko.po | 526 ++++++++++++++++++++++++++++++++++-----------------------------
+ 1 file changed, 284 insertions(+), 242 deletions(-)
+
+commit df873143ad1615c6d6aaa1bf8808b1676091dfe3
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2024-02-13 01:55:53 +0800
+
+ Translations: Update the Korean man page translations.
+
+ po4a/ko.po | 1375 ++++++++++++++++++++++++++++++++++--------------------------
+ 1 file changed, 770 insertions(+), 605 deletions(-)
+
+commit b3f415eddb150341865a1af47959c3baba076b33
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2024-02-13 01:53:33 +0800
+
+ Translations: Update the Chinese (simplified) translation.
+
+ po/zh_CN.po | 424 ++++++++++++++++++++++++++++++++++++++----------------------
+ 1 file changed, 268 insertions(+), 156 deletions(-)
+
+commit 9860d418d296eb3c721e5384fb367c0499b579c8
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2024-02-09 23:21:01 +0200
+
+ xzless: Use ||- in LESSOPEN with with "less" 451 and newer.
+
+ src/scripts/xzless.in | 9 ++++++++-
+ 1 file changed, 8 insertions(+), 1 deletion(-)
+
+commit fd0692b0525e6c26b496492be9e2c865cab734f8
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2024-02-09 23:00:05 +0200
+
+ xzless: Use --show-preproc-errors with "less" 632 and newer.
+
+ This makes "less" show a warning if a decompression error occurred.
+
+ src/scripts/xzless.in | 11 +++++++++--
+ 1 file changed, 9 insertions(+), 2 deletions(-)
+
+commit adb073da76a920b5a81e6b32254f4ddb054dc57a
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2024-02-09 23:59:54 +0800
+
+ liblzma: Fix typo discovered by codespell.
+
+ src/liblzma/check/crc32_arm64.h | 2 +-
+ 1 file changed, 1 insertion(+), 1 deletion(-)
+
+commit 55d9fc883d221cbace951a370f1fb144698f8c2e
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2024-02-09 20:01:06 +0800
+
+ Translations: Update the Swedish translation.
+
+ po/sv.po | 420 ++++++++++++++++++++++++++++++++++++++-------------------------
+ 1 file changed, 254 insertions(+), 166 deletions(-)
+
+commit 55ba4a1ea321499c805eedfa811ffde690bae311
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2024-02-08 20:09:04 +0800
+
+ Translations: Update the Spanish translation.
+
+ po/es.po | 22 +++++++++++-----------
+ 1 file changed, 11 insertions(+), 11 deletions(-)
+
+commit 7f2293cd804a89d3c3b2d3ed573560ca9e1520ae
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2024-02-07 21:34:35 +0800
+
+ Translations: Update the Spanish translation.
+
+ po/es.po | 419 ++++++++++++++++++++++++++++++++++++++-------------------------
+ 1 file changed, 253 insertions(+), 166 deletions(-)
+
+commit f4af2036bc625739d6d33d9e1fede583a25c3828
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2024-02-07 21:28:32 +0800
+
+ Translations: Update the Polish translation.
+
+ po/pl.po | 411 ++++++++++++++++++++++++++++++++++++++-------------------------
+ 1 file changed, 249 insertions(+), 162 deletions(-)
+
+commit e5e93bb816043c559cddf03a3b7ba13bec353ee4
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2024-02-07 19:40:12 +0800
+
+ Translations: Update the German translation.
+
+ po/de.po | 396 ++++++++++++++++++++++++++++++++++++++-------------------------
+ 1 file changed, 242 insertions(+), 154 deletions(-)
+
+commit 28f18ff8e26902762fb007c13be235b4ac1ac071
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2024-02-07 19:27:25 +0800
+
+ Translations: Update the German man page translations.
+
+ po4a/de.po | 1353 +++++++++++++++++++++++++++++++++---------------------------
+ 1 file changed, 752 insertions(+), 601 deletions(-)
+
+commit cabfbc7947da05aa5dfe39bec9759e076f940e3c
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2024-02-06 23:44:06 +0800
+
+ Translations: Update the Romanian translation.
+
+ po/ro.po | 416 ++++++++++++++++++++++++++++++++++++++-------------------------
+ 1 file changed, 252 insertions(+), 164 deletions(-)
+
+commit bf20c94f5d748cea2147779f4fa7e2fd2eb8555e
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2024-02-06 23:45:02 +0800
+
+ Translations: Update the Romanian man page translations.
+
+ po4a/ro.po | 1759 +++++++++++++++++++++++++++++++++---------------------------
+ 1 file changed, 966 insertions(+), 793 deletions(-)
+
+commit 7c25ec9feb0241e4affb7432681cc4f5696f3a96
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2024-02-07 20:56:57 +0800
+
+ Translations: Update the Ukrainian translation.
+
+ po/uk.po | 397 ++++++++++++++++++++++++++++++++++++++-------------------------
+ 1 file changed, 242 insertions(+), 155 deletions(-)
+
+commit b3523250e9eef10b017473754c1e1c9e31f10374
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2024-02-06 23:30:03 +0800
+
+ Translations: Update the Ukrainian man page translations.
+
+ po4a/uk.po | 1363 ++++++++++++++++++++++++++++++++++--------------------------
+ 1 file changed, 764 insertions(+), 599 deletions(-)
+
+commit a5c177f514f4c90e0d2f6045636fca6c2e80a20d
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2024-02-02 01:39:28 +0800
+
+ Update AUTHORS.
+
+ AUTHORS | 3 ++-
+ 1 file changed, 2 insertions(+), 1 deletion(-)
+
+commit 7f68a68c19d0ae57bd0e802be0ea8f974e41299f
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2024-02-02 01:38:51 +0800
+
+ liblzma: Update Authors list in crc32_arm64.h.
+
+ src/liblzma/check/crc32_arm64.h | 1 +
+ 1 file changed, 1 insertion(+)
+
+commit 97f9ba50b84e67b3dcb5b17dd5d3e1d14f9ad1d0
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2024-02-01 16:07:03 +0800
+
+ liblzma: Check HAVE_USABLE_CLMUL before omitting CRC32 table.
+
+ This was split from the prior commit so it could be easily applied to
+ the 5.4 branch.
+
+ Closes: https://github.com/tukaani-project/xz/pull/77
+
+ src/liblzma/check/crc32_table.c | 4 ++--
+ 1 file changed, 2 insertions(+), 2 deletions(-)
+
+commit ca9015f4dead2c97b48f5a6933631b0a448b65b9
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2024-02-01 16:06:29 +0800
+
+ liblzma: Check HAVE_USABLE_CLMUL before omitting CRC64 table.
+
+ If liblzma is configured with --disable-clmul-crc
+ CFLAGS="-msse4.1 -mpclmul", then it will fail to compile because the
+ generic version must be used but the CRC tables were not included.
+
+ src/liblzma/check/crc64_table.c | 4 ++--
+ 1 file changed, 2 insertions(+), 2 deletions(-)
+
+commit 2f1552a91c825e87013925e1a67a0930e7aef592
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2024-01-23 18:02:13 +0800
+
+ liblzma: Only use ifunc in crcXX_fast.c if its needed.
+
+ The code was using HAVE_FUNC_ATTRIBUTE_IFUNC instead of CRC_USE_IFUNC.
+ With ARM64, ifunc is incompatible because it requires non-inline
+ function calls for runtime detection.
+
+ src/liblzma/check/crc32_fast.c | 6 +++---
+ src/liblzma/check/crc64_fast.c | 6 +++---
+ 2 files changed, 6 insertions(+), 6 deletions(-)
+
+commit 30a25f3742287697bc57a1bef86c19ecf5129322
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2024-01-22 22:08:45 +0800
+
+ Docs: Add --disable-arm64-crc32 description to INSTALL.
+
+ INSTALL | 12 +++++++++++-
+ 1 file changed, 11 insertions(+), 1 deletion(-)
+
+commit 1940f0ec28f08c0ac72c1413d9706fb82eabe6ad
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2024-01-22 21:36:09 +0800
+
+ liblzma: Omit CRC tables when not needed with ARM64 optimizations.
+
+ This is similar to the existing x86-64 CLMUL conditions to omit the
+ tables. They were slightly refactored to improve readability.
+
+ src/liblzma/check/crc32_table.c | 18 +++++++++++++++---
+ src/liblzma/check/crc64_table.c | 7 ++++++-
+ src/liblzma/check/crc_common.h | 5 ++++-
+ 3 files changed, 25 insertions(+), 5 deletions(-)
+
+commit 761f5b69a4c778c8bcb09279b845b07c28790575
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2024-01-22 20:54:56 +0800
+
+ liblzma: Rename crc32_aarch64.h to crc32_arm64.h.
+
+ Even though the proper name for the architecture is aarch64, this
+ project uses ARM64 throughout. So the rename is for consistency.
+
+ Additionally, crc32_arm64.h was slightly refactored for the following
+ changes:
+
+ * Added MSVC, FreeBSD, and macOS support in
+ is_arch_extension_supported().
+
+ * crc32_arch_optimized() now checks the size when aligning the
+ buffer.
+
+ * crc32_arch_optimized() loop conditions were slightly modified to
+ avoid both decrementing the size and incrementing the buffer
+ pointer.
+
+ * Use the intrinsic wrappers defined in <arm_acle.h> because GCC and
+ Clang name them differently.
+
+ * Minor spacing and comment changes.
+
+ CMakeLists.txt | 2 +-
+ src/liblzma/check/Makefile.inc | 2 +-
+ src/liblzma/check/crc32_aarch64.h | 109 ----------------------------------
+ src/liblzma/check/crc32_arm64.h | 119 ++++++++++++++++++++++++++++++++++++++
+ src/liblzma/check/crc32_fast.c | 3 +-
+ src/liblzma/check/crc64_fast.c | 3 -
+ 6 files changed, 122 insertions(+), 116 deletions(-)
+
+commit 455a08609caa3223066a717fb01bfa42c5dba47d
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2024-01-22 20:49:30 +0800
+
+ liblzma: Refactor crc_common.h.
+
+ The CRC_GENERIC is now split into CRC32_GENERIC and CRC64_GENERIC, since
+ the ARM64 optimizations will be different between CRC32 and CRC64.
+
+ For the same reason, CRC_ARCH_OPTIMIZED is split into
+ CRC32_ARCH_OPTIMIZED and CRC64_ARCH_OPTIMIZED.
+
+ ifunc will only be used with x86-64 CLMUL because the runtime detection
+ methods needed with ARM64 are not compatible with ifunc.
+
+ src/liblzma/check/crc32_fast.c | 8 +--
+ src/liblzma/check/crc64_fast.c | 8 +--
+ src/liblzma/check/crc_common.h | 108 ++++++++++++++++++++++++++++-------------
+ 3 files changed, 82 insertions(+), 42 deletions(-)
+
+commit 61908e816049af7a9f43ea804a57ee8570e2e644
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2024-01-22 00:42:28 +0800
+
+ CMake: Add support for ARM64 CRC32 instruction detection.
+
+ CMakeLists.txt | 50 ++++++++++++++++++++++++++++++++++++++++++++++++++
+ 1 file changed, 50 insertions(+)
+
+commit c5f6d79cc9515a7f22d7ea4860c6cc394b295732
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2024-01-22 00:36:47 +0800
+
+ Build: Add support for ARM64 CRC32 instruction detection.
+
+ This adds --enable-arm64-crc32/--disable-arm64-crc32 (enabled by
+ default) for using the ARM64 CRC32 instruction. This can be disabled if
+ one knows the binary will never need to run on an ARM64 machine
+ with this instruction extension.
+
+ configure.ac | 52 ++++++++++++++++++++++++++++++++++++++++++++++++++++
+ 1 file changed, 52 insertions(+)
+
+commit 849d0f282a6a890c5cf5a0e0f02980b12d9ebb0f
+Author: Chenxi Mao <chenxi.mao2013@gmail.com>
+Date: 2024-01-09 17:23:11 +0800
+
+ Speed up CRC32 calculation on ARM64
+
+ The CRC32 instructions in ARM64 can calculate the CRC32 result
+ for 8 bytes in a single operation, making the use of ARM64
+ instructions much faster compared to the general CRC32 algorithm.
+
+ Optimized CRC32 will be enabled if ARM64 has CRC extension
+ running on Linux.
+
+ Signed-off-by: Chenxi Mao <chenxi.mao2013@gmail.com>
+
+ CMakeLists.txt | 1 +
+ src/liblzma/check/Makefile.inc | 3 +-
+ src/liblzma/check/crc32_aarch64.h | 109 ++++++++++++++++++++++++++++++++++++++
+ src/liblzma/check/crc32_fast.c | 5 +-
+ src/liblzma/check/crc64_fast.c | 5 +-
+ src/liblzma/check/crc_common.h | 16 +++---
+ 6 files changed, 130 insertions(+), 9 deletions(-)
+
+commit b43c3e48bf6097095eef36d44cdbec811074940a
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2024-01-26 19:05:51 +0800
+
+ Bump version number for 5.5.1alpha.
+
+ src/liblzma/api/lzma/version.h | 2 +-
+ src/liblzma/liblzma_generic.map | 2 +-
+ src/liblzma/liblzma_linux.map | 2 +-
+ 3 files changed, 3 insertions(+), 3 deletions(-)
+
+commit c7a7ae1500ea90bd3c2d54533e4f433933eb598f
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2024-01-26 19:00:52 +0800
+
+ Add NEWS for 5.5.1alpha
+
+ NEWS | 80 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
+ 1 file changed, 80 insertions(+)
+
+commit 0ef8192e8d5af4e6200d5d4aee22d1f177f7a2df
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2024-01-26 18:54:24 +0800
+
+ Add NEWS for 5.4.6.
+
+ NEWS | 22 ++++++++++++++++++++++
+ 1 file changed, 22 insertions(+)
+
+commit 93de7e751d17731315a899264f2a7239d7d2d316
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2024-01-24 20:00:57 +0200
+
+ Move doc/logo/xz-logo.png to "doc" and Doxygen footer to "doxygen".
+
+ The footer isn't a complete HTML file so having it in the doxygen
+ directory is a tiny bit clearer.
+
+ Makefile.am | 2 +-
+ doc/{logo => }/xz-logo.png | Bin
+ doxygen/Doxyfile | 4 ++--
+ doc/logo/copyright.html => doxygen/footer.html | 0
+ 4 files changed, 3 insertions(+), 3 deletions(-)
+
+commit 00fa01698df51c58ae2acf8c7fa4e1fb159f75a9
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2024-01-09 17:05:01 +0800
+
+ README: Add COPYING.CC-BY-SA-4.0 entry to section 1.1.
+
+ The Overall documentation section (1.1) table spacing had to be adjusted
+ since the filename was very long.
+
+ README | 38 ++++++++++++++++++++------------------
+ 1 file changed, 20 insertions(+), 18 deletions(-)
+
+commit e280470040b27c5e58d78b25b9e2bb71fc6c3882
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2024-01-09 16:56:16 +0800
+
+ Build: Add the logo and license to the release.
+
+ Makefile.am | 2 ++
+ 1 file changed, 2 insertions(+)
+
+commit b1ee6cf259bb49ce91abe9f622294524e37edf4c
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2024-01-09 16:44:42 +0800
+
+ COPYING: Add the license for the XZ logo.
+
+ COPYING | 5 +
+ COPYING.CC-BY-SA-4.0 | 427 +++++++++++++++++++++++++++++++++++++++++++++++++++
+ 2 files changed, 432 insertions(+)
+
+commit 31293ae7074802cc7286089a89c7b552d930c97f
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2024-01-09 16:40:56 +0800
+
+ Doxygen: Added the XZ logo and copyright information.
+
+ The PROJECT_LOGO field is now used to include the XZ logo. The footer
+ of each page now lists the copyright information instead of the default
+ footer. The license is also copied to statisfy the copyright and so the
+ link in the documentation can be local.
+
+ doc/logo/copyright.html | 11 +++++++++++
+ doc/logo/xz-logo.png | Bin 0 -> 6771 bytes
+ doxygen/Doxyfile | 6 +++---
+ 3 files changed, 14 insertions(+), 3 deletions(-)
+
+commit 6daa4d0ea46a8441f21f609149f3633158bf4704
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2024-01-23 18:29:28 +0200
+
+ xz: Use threaded mode by defaut (as if --threads=0 was used).
+
+ This hopefully does more good than bad:
+
+ + It's faster by default.
+
+ + Only the threaded compressor creates files that
+ can be decompressed in threaded mode.
+
+ - Compression ratio is worse, usually not too much though.
+ When it matters, -T1 must be used.
+
+ - Memory usage increases.
+
+ - Scripts that assume single-threaded mode but don't use -T1 will
+ possibly use too much resources, for example, if they run
+ multiple xz processes in parallel to compress multiple files.
+
+ - Output from single-threaded and multi-threaded compressors
+ differ but such changes could happen for other reasons too
+ (they just haven't happened since 5.0.0).
+
+ src/xz/hardware.c | 6 +++++-
+ src/xz/message.c | 4 ++--
+ src/xz/xz.1 | 9 +++++++++
+ 3 files changed, 16 insertions(+), 3 deletions(-)
+
+commit a2dd2dc8e5307a7280bb99868bc478560facba2c
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2024-01-23 23:52:49 +0800
+
+ CI: Use RISC-V filter when building with BCJ support.
+
+ build-aux/ci_build.sh | 4 ++--
+ 1 file changed, 2 insertions(+), 2 deletions(-)
+
+commit 3060e1070b2421b26c0e17794c1307ec5622f11d
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2024-01-23 23:52:14 +0800
+
+ Tests: Use smaller dictionary size in RISC-V test files.
+
+ tests/files/good-1-riscv-lzma2-1.xz | Bin 7512 -> 7512 bytes
+ tests/files/good-1-riscv-lzma2-2.xz | Bin 7516 -> 7512 bytes
+ 2 files changed, 0 insertions(+), 0 deletions(-)
+
+commit 44ff2fa5c94dc345c4dd69195a19fc5238df60b3
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2024-01-23 23:50:57 +0800
+
+ Tests: Skip RISC-V test files if decoder was not built.
+
+ tests/test_files.sh | 5 +++++
+ 1 file changed, 5 insertions(+)
+
+commit 6133a3f30049d3beaf7d22535b1e5d38e109be4e
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2024-01-23 16:11:54 +0200
+
+ xz: Man page: Add more examples of LZMA2 options with BCJ filters.
+
+ src/xz/xz.1 | 38 +++++++++++++++++++++++++++++++-------
+ 1 file changed, 31 insertions(+), 7 deletions(-)
+
+commit 50255feeaabcc7e7db22b858a6bd64a9b5b4f16d
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2024-01-23 00:09:48 +0200
+
+ liblzma: RISC-V filter: Use byte-by-byte access.
+
+ Not all RISC-V processors support fast unaligned access so
+ it's better to read only one byte in the main loop. This can
+ be faster even on x86-64 when compared to reading 32 bits at
+ a time as half the time the address is only 16-bit aligned.
+
+ The downside is larger code size on archs that do support
+ fast unaligned access.
+
+ src/liblzma/simple/riscv.c | 114 +++++++++++++++++++++++++++++++++------------
+ 1 file changed, 84 insertions(+), 30 deletions(-)
+
+commit db5eb5f563e8baa8d912ecf576f53391ff861596
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2024-01-22 23:33:39 +0800
+
+ xz: Update xz -lvv for RISC-V filter.
+
+ Version 5.6.0 will be shown, even though upcoming alphas and betas
+ will be able to support this filter. 5.6.0 looks nicer in the output and
+ people shouldn't be encouraged to use an unstable version in production
+ in any way.
+
+ src/xz/list.c | 10 ++++++++++
+ 1 file changed, 10 insertions(+)
+
+commit e2870db5be1503e6a489fc3d47daf950d6f62723
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2024-01-22 23:33:39 +0800
+
+ Tests: Add two RISC-V Filter test files.
+
+ These test files achieve 100% code coverage in
+ src/liblzma/simple/riscv.c. They contain all of the instructions that
+ should be filtered and a few cases that should not.
+
+ tests/files/README | 8 ++++++++
+ tests/files/good-1-riscv-lzma2-1.xz | Bin 0 -> 7512 bytes
+ tests/files/good-1-riscv-lzma2-2.xz | Bin 0 -> 7516 bytes
+ 3 files changed, 8 insertions(+)
+
+commit b26a89869315ece2f6d9d10d32d45f672550f245
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2024-01-22 23:33:39 +0800
+
+ xz: Update message in --long-help for RISC-V Filter.
+
+ src/xz/message.c | 1 +
+ 1 file changed, 1 insertion(+)
+
+commit 283f778908873eca61388029fc418fa800c9d7d7
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2024-01-22 23:33:39 +0800
+
+ xz: Update the man page for the RISC-V Filter.
+
+ A special note was added to suggest using four-byte alignment when the
+ compressed instruction extension is not present in a RISC-V binary.
+
+ src/xz/xz.1 | 3 ++-
+ 1 file changed, 2 insertions(+), 1 deletion(-)
+
+commit ac3691ccca051d67f60b4a3b05b88e511d0b1b28
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2024-01-22 23:33:39 +0800
+
+ Tests: Add RISC-V Filter test in test_compress.sh.
+
+ tests/test_compress.sh | 1 +
+ 1 file changed, 1 insertion(+)
+
+commit 2959dbc7358efcf421ce51bc9cd7eae8fdd8fec4
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2024-01-22 23:33:39 +0800
+
+ liblzma: Update string_conversion.c to support RISC-V Filter.
+
+ src/liblzma/common/string_conversion.c | 5 +++++
+ 1 file changed, 5 insertions(+)
+
+commit 34372a5adbe5a7f6bf29498410ba3a463a720966
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2024-01-22 23:33:39 +0800
+
+ CMake: Support RISC-V BCJ Filter for encoding and decoding.
+
+ CMakeLists.txt | 1 +
+ 1 file changed, 1 insertion(+)
+
+commit 440a2eccb082dc13400c09e22308a58fef85146c
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2024-01-22 23:33:39 +0800
+
+ liblzma: Add RISC-V BCJ filter.
+
+ The new Filter ID is 0x0B.
+
+ Thanks to Chien Wong <m@xv97.com> for the initial version of the Filter,
+ the xz CLI updates, and the Autotools build system modifications.
+
+ Thanks to Igor Pavlov for his many contributions to the design of
+ the filter.
+
+ configure.ac | 4 +-
+ src/liblzma/api/lzma/bcj.h | 5 +
+ src/liblzma/common/filter_common.c | 9 +
+ src/liblzma/common/filter_decoder.c | 8 +
+ src/liblzma/common/filter_encoder.c | 10 +
+ src/liblzma/simple/Makefile.inc | 4 +
+ src/liblzma/simple/riscv.c | 688 ++++++++++++++++++++++++++++++++++++
+ src/liblzma/simple/simple_coder.h | 9 +
+ src/xz/args.c | 7 +
+ 9 files changed, 742 insertions(+), 2 deletions(-)
+
+commit 5540f4329bbdb4deb4850d4af48b18ad074bba19
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2024-01-19 23:08:14 +0800
+
+ Docs: Update .xz file format specification to 1.2.0.
+
+ The new RISC-V filter was added to the specification, in addition to
+ updating the specification URL.
+
+ doc/xz-file-format.txt | 29 +++++++++++++++++------------
+ 1 file changed, 17 insertions(+), 12 deletions(-)
+
+commit 22d86192f8cf00902a1f90ee2a83ca600794459b
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2024-01-19 23:08:14 +0800
+
+ xz: Update website URLs in the man pages.
+
+ src/xz/xz.1 | 6 +++---
+ src/xzdec/xzdec.1 | 4 ++--
+ 2 files changed, 5 insertions(+), 5 deletions(-)
+
+commit 6b63c4c6139fa1bb21b570521d3d2b4a608bc34d
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2024-01-19 23:08:14 +0800
+
+ liblzma: Update website URL.
+
+ dos/config.h | 2 +-
+ src/liblzma/api/lzma.h | 6 +++---
+ 2 files changed, 4 insertions(+), 4 deletions(-)
+
+commit fce4758018f3a3589236f3fe7999fd9dd08c77e9
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2024-01-19 23:08:14 +0800
+
+ Docs: Update website URLs.
+
+ .github/SECURITY.md | 2 +-
+ COPYING | 3 ++-
+ README | 4 ++--
+ doc/faq.txt | 2 +-
+ doc/lzma-file-format.txt | 18 +++++++++---------
+ windows/README-Windows.txt | 3 ++-
+ 6 files changed, 17 insertions(+), 15 deletions(-)
+
+commit c26812c5b2c8a2a47f43214afe6b0b840c73e4f5
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2024-01-19 23:08:14 +0800
+
+ Build: Update website URL.
+
+ CMakeLists.txt | 2 +-
+ configure.ac | 2 +-
2 files changed, 2 insertions(+), 2 deletions(-)
-commit 84c0cfc556287628df871703672879e530d0391f
+commit fbb3ce541ef79cad1710e88a27a5babb5f6f8e5b
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2024-01-11 15:01:50 +0200
+
+ liblzma: CRC: Add a comment to crc_x86_clmul.h about BUILDING_ macros.
+
+ src/liblzma/check/crc_x86_clmul.h | 6 ++++++
+ 1 file changed, 6 insertions(+)
+
+commit 4f518c1b6b7b7ce5dcefea81acd44d7a086a8882
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2024-01-11 15:22:36 +0200
+
+ liblzma: CRC: Remove crc_always_inline, use lzma_always_inline instead.
+
+ Now crc_simd_body() in crc_x86_clmul.h is only called once
+ in a translation unit, we no longer need to be so cautious
+ about ensuring the always-inline behavior.
+
+ src/liblzma/check/crc_common.h | 20 --------------------
+ src/liblzma/check/crc_x86_clmul.h | 2 +-
+ 2 files changed, 1 insertion(+), 21 deletions(-)
+
+commit 35c03ec6bf66f1b159964c9721a2dce0e2859b20
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2024-01-11 14:39:46 +0200
+
+ liblzma: CRC: Update CLMUL comments to more generic wording.
+
+ src/liblzma/check/crc32_fast.c | 16 ++++++++--------
+ src/liblzma/check/crc64_fast.c | 10 +++++-----
+ 2 files changed, 13 insertions(+), 13 deletions(-)
+
+commit 66f080e8016129576536482ac377e2ecac7a2b90
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2024-01-10 18:23:31 +0200
+
+ liblzma: Rename arch-specific CRC functions and macros.
+
+ CRC_CLMUL was split to CRC_ARCH_OPTIMIZED and CRC_X86_CLMUL.
+ CRC_ARCH_OPTIMIZED is defined when an arch-optimized version is used.
+ Currently the x86 CLMUL implementations are the only arch-optimized
+ versions, and these also use the CRC_x86_CLMUL macro to tell when
+ crc_x86_clmul.h needs to be included.
+
+ is_clmul_supported() was renamed to is_arch_extension_supported().
+ crc32_clmul() and crc64_clmul() were renamed to
+ crc32_arch_optimized() and crc64_arch_optimized().
+ This way the names make sense with arch-specific non-CLMUL
+ implementations as well.
+
+ src/liblzma/check/crc32_fast.c | 13 +++++++------
+ src/liblzma/check/crc64_fast.c | 13 +++++++------
+ src/liblzma/check/crc_common.h | 9 ++++++---
+ src/liblzma/check/crc_x86_clmul.h | 21 +++++++++++----------
+ 4 files changed, 31 insertions(+), 25 deletions(-)
+
+commit 3dbed75b0b9c7087c76fe687acb5cf582cd57b99
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2024-01-10 18:19:21 +0200
+
+ liblzma: Fix a comment in crc_common.h.
+
+ src/liblzma/check/crc_common.h | 3 ++-
+ 1 file changed, 2 insertions(+), 1 deletion(-)
+
+commit 419f55f9dfc2df8792902b8953d50690121afeea
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2023-10-20 23:35:10 +0300
+
+ liblzma: Avoid extern lzma_crc32_clmul() and lzma_crc64_clmul().
+
+ A CLMUL-only build will have the crcxx_clmul() inlined into
+ lzma_crcxx(). Previously a jump to the extern lzma_crcxx_clmul()
+ was needed. Notes about shared liblzma on ELF platforms:
+
+ - On platforms that support ifunc and -fvisibility=hidden, this
+ was silly because CLMUL-only build would have that single extra
+ jump instruction of extra overhead.
+
+ - On platforms that support neither -fvisibility=hidden nor linker
+ version script (liblzma*.map), jumping to lzma_crcxx_clmul()
+ would go via PLT so a few more instructions of overhead (still
+ not a big issue but silly nevertheless).
+
+ There was a downside with static liblzma too: if an application only
+ needs lzma_crc64(), static linking would make the linker include the
+ CLMUL code for both CRC32 and CRC64 from crc_x86_clmul.o even though
+ the CRC32 code wouldn't be needed, thus increasing code size of the
+ executable (assuming that -ffunction-sections isn't used).
+
+ Also, now compilers are likely to inline crc_simd_body()
+ even if they don't support the always_inline attribute
+ (or MSVC's __forceinline). Quite possibly all compilers
+ that build the code do support such an attribute. But now
+ it likely isn't a problem even if the attribute wasn't supported.
+
+ Now all x86-specific stuff is in crc_x86_clmul.h. If other archs
+ The other archs can then have their own headers with their own
+ is_clmul_supported() and crcxx_clmul().
+
+ Another bonus is that the build system doesn't need to care if
+ crc_clmul.c is needed.
+
+ is_clmul_supported() stays as inline function as it's not needed
+ when doing a CLMUL-only build (avoids a warning about unused function).
+
+ CMakeLists.txt | 7 +-
+ configure.ac | 1 -
+ src/liblzma/check/Makefile.inc | 6 +-
+ src/liblzma/check/crc32_fast.c | 9 ++-
+ src/liblzma/check/crc64_fast.c | 9 ++-
+ src/liblzma/check/crc_common.h | 64 ----------------
+ src/liblzma/check/{crc_clmul.c => crc_x86_clmul.h} | 86 ++++++++++++++++++----
+ 7 files changed, 91 insertions(+), 91 deletions(-)
+
+commit e3833e297dfb5021a197bda34ba2a795e30aaf8a
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2023-10-21 00:06:52 +0300
+
+ liblzma: crc_clmul.c: Add crc_attr_target macro.
+
+ This reduces the number of the complex #if directives.
+
+ src/liblzma/check/crc_clmul.c | 30 ++++++++++++++++--------------
+ 1 file changed, 16 insertions(+), 14 deletions(-)
+
+commit d164ac0e62904126f7920c25f9a2875c8cd28b97
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2023-10-20 22:49:48 +0300
+
+ liblzma: Simplify existing cases with lzma_attr_no_sanitize_address.
+
+ src/liblzma/check/crc_clmul.c | 12 +++---------
+ 1 file changed, 3 insertions(+), 9 deletions(-)
+
+commit 9523c1300d22fa715765c181cf991d14d6112fb1
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2023-10-20 21:53:35 +0300
+
+ liblzma: #define crc_attr_no_sanitize_address in crc_common.h.
+
+ src/liblzma/check/crc_common.h | 10 ++++++++++
+ 1 file changed, 10 insertions(+)
+
+commit 93d144f0930821590524247bd174afd38003d7f0
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2023-10-20 23:25:14 +0300
+
+ liblzma: CRC: Add empty lines.
+
+ And remove one too.
+
+ src/liblzma/check/crc32_fast.c | 2 ++
+ src/liblzma/check/crc64_fast.c | 3 +++
+ src/liblzma/check/crc_clmul.c | 1 -
+ 3 files changed, 5 insertions(+), 1 deletion(-)
+
+commit 0c7e854ffd27f1cec2e9b0e61601d6f90bfa10ae
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2023-10-20 23:19:33 +0300
+
+ liblzma: crc_clmul.c: Tidy up the location of MSVC pragma.
+
+ It makes no difference in practice.
+
+ src/liblzma/check/crc_clmul.c | 4 ++--
+ 1 file changed, 2 insertions(+), 2 deletions(-)
+
+commit 15cf3f04f270d707a5c91cc0208b23b6db42b774
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2023-12-20 21:16:24 +0200
+
+ Update THANKS.
+
+ THANKS | 1 +
+ 1 file changed, 1 insertion(+)
+
+commit cd64dd70d5665b6048829c45772d08606f44672e
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2023-12-20 21:15:16 +0200
+
+ liblzma: Use 8-byte method in memcmplen.h on ARM64.
+
+ It requires fast unaligned access to 64-bit integers
+ and a fast instruction to count leading zeros in
+ a 64-bit integer (__builtin_ctzll()). This perhaps
+ should be enabled on some other archs too.
+
+ Thanks to Chenxi Mao for the original patch:
+ https://github.com/tukaani-project/xz/pull/75 (the first commit)
+ According to the numbers there, this may improve encoding
+ speed by about 3-5 %.
+
+ This enables the 8-byte method on MSVC ARM64 too which
+ should work but wasn't tested.
+
+ src/liblzma/common/memcmplen.h | 18 ++++++++++--------
+ 1 file changed, 10 insertions(+), 8 deletions(-)
+
+commit 12c90c00f05e19da3c0c91d8cd8e0d0d45965606
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2023-12-20 21:01:06 +0200
+
+ liblzma: Check also for __clang__ in memcmplen.h.
+
+ This change hopefully makes no practical difference as Clang
+ likely was detected via __GNUC__ or _MSC_VER already.
+
+ src/liblzma/common/memcmplen.h | 3 ++-
+ 1 file changed, 2 insertions(+), 1 deletion(-)
+
+commit 133c5851eb917c6d99d0b623c1689c8518e65f38
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2023-12-21 21:39:08 +0800
+
+ Translations: Update the French translation.
+
+ po/fr.po | 632 +++++++++++++++++++++++++++++++++++++--------------------------
+ 1 file changed, 370 insertions(+), 262 deletions(-)
+
+commit 710cbc186cad0ac601c38bd6bf31167648a5581e
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2023-12-21 16:39:53 +0800
+
+ xz: Add a comment to Capsicum sandbox setup.
+
+ This comment is repeated in xzdec.c to help remind us why all the
+ capabilities are removed from stdin in certain situations.
+
+ src/xz/file_io.c | 1 +
+ 1 file changed, 1 insertion(+)
+
+commit 4e1c695676bafbaecc9fb307f6ee94138ae72c12
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2023-12-20 22:19:19 +0800
+
+ Docs: Update --enable-sandbox option in INSTALL.
+
+ xzdec now also uses the sandbox when its configured.
+
+ INSTALL | 17 ++++++++++-------
+ 1 file changed, 10 insertions(+), 7 deletions(-)
+
+commit ebddf20214143a8e002ab897e95e880bb4c5ac44
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2023-12-20 22:39:13 +0800
+
+ CMake: Move sandbox detection outside of xz section.
+
+ The sandbox is now enabled for xzdec as well, so it no longer belongs
+ in just the xz section. xz and xzdec are always built, except for older
+ MSVC versions, so there isn't a need to conditionally show the sandbox
+ configuration. CMake will do a little unecessary work on older MSVC
+ versions that can't build xz or xzdec, but this is a very small
+ downside.
+
+ CMakeLists.txt | 178 +++++++++++++++++++++++++++++++--------------------------
+ 1 file changed, 98 insertions(+), 80 deletions(-)
+
+commit 5feb09266fd2928ec0a4dcb98c1dc7f053111316
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2023-12-20 22:43:44 +0800
+
+ Build: Allow sandbox to be configured for just xzdec.
+
+ If xz is disabled, then xzdec can still use the sandbox.
+
+ configure.ac | 10 +++++-----
+ 1 file changed, 5 insertions(+), 5 deletions(-)
+
+commit d74fb5f060b76db709b50f5fd37490394e52f975
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2023-12-19 21:18:28 +0800
+
+ xzdec: Add sandbox support for Pledge, Capsicum, and Landlock.
+
+ A very strict sandbox is used when the last file is decompressed. The
+ likely most common use case of xzdec is to decompress a single file.
+ The Pledge sandbox is applied to the entire process with slightly more
+ relaxed promises, until the last file is processed.
+
+ Thanks to Christian Weisgerber for the initial patch adding Pledge
+ sandboxing.
+
+ src/xzdec/xzdec.c | 146 +++++++++++++++++++++++++++++++++++++++++++++++++++---
+ 1 file changed, 139 insertions(+), 7 deletions(-)
+
+commit b34b6a9912d6165e34ba0db151b7f9941d2e06d5
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2023-12-20 21:31:34 +0800
+
+ liblzma: Initialize lzma_lz_encoder pointers with NULL.
+
+ This fixes the recent change to lzma_lz_encoder that used memzero
+ instead of the NULL constant. On some compilers the NULL constant
+ (always 0) may not equal the NULL pointer (this only needs to guarentee
+ to not point to valid memory address).
+
+ Later code compares the pointers to the NULL pointer so we must
+ initialize them with the NULL pointer instead of 0 to guarentee
+ code correctness.
+
+ src/liblzma/lz/lz_encoder.c | 6 +++++-
+ 1 file changed, 5 insertions(+), 1 deletion(-)
+
+commit 183a62f0b540ff4d23cc19b2b6bc2525f0bd64df
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2023-12-16 20:51:38 +0800
+
+ liblzma: Set all values in lzma_lz_encoder to NULL after allocation.
+
+ The first member of lzma_lz_encoder doesn't necessarily need to be set
+ to NULL since it will always be set before anything tries to use it.
+ However the function pointer members must be set to NULL since other
+ functions rely on this NULL value to determine if this behavior is
+ supported or not.
+
+ This fixes a somewhat serious bug, where the options_update() and
+ set_out_limit() function pointers are not set to NULL. This seems to
+ have been forgotten since these function pointers were added many years
+ after the original two (code() and end()).
+
+ The problem is that by not setting this to NULL we are relying on the
+ memory allocation to zero things out if lzma_filters_update() is called
+ on a LZMA1 encoder. The function pointer for set_out_limit() is less
+ serious because there is not an API function that could call this in an
+ incorrect way. set_out_limit() is only called by the MicroLZMA encoder,
+ which must use LZMA1 where set_out_limit() is always set. Its currently
+ not possible to call set_out_limit() on an LZMA2 encoder at this time.
+
+ So calling lzma_filters_update() on an LZMA1 encoder had undefined
+ behavior since its possible that memory could be manipulated so the
+ options_update member pointed to a different instruction sequence.
+
+ This is unlikely to be a bug in an existing application since it relies
+ on calling lzma_filters_update() on an LZMA1 encoder in the first place.
+ For instance, it does not affect xz because lzma_filters_update() can
+ only be used when encoding to the .xz format.
+
+ This is fixed by using memzero() to set all members of lzma_lz_encoder
+ to NULL after it is allocated. This ensures this mistake will not occur
+ here in the future if any additional function pointers are added.
+
+ src/liblzma/lz/lz_encoder.c | 4 +---
+ 1 file changed, 1 insertion(+), 3 deletions(-)
+
+commit 1a1bb381db7a20cf86cb45a350e5cca35224d017
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2023-12-16 20:30:55 +0800
+
+ liblzma: Tweak a comment.
+
+ src/liblzma/lz/lz_encoder.c | 2 +-
+ 1 file changed, 1 insertion(+), 1 deletion(-)
+
+commit 55810780e04f759747b02683fb8020b8cd022a85
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2023-12-16 20:28:21 +0800
+
+ liblzma: Make parameter names in function definition match declaration.
+
+ lzma_raw_encoder() and lzma_raw_encoder_init() used "options" as the
+ parameter name instead of "filters" (used by the declaration). "filters"
+ is more clear since the parameter represents the list of filters passed
+ to the raw encoder, each of which contains filter options.
+
+ src/liblzma/common/filter_encoder.c | 8 ++++----
+ 1 file changed, 4 insertions(+), 4 deletions(-)
+
+commit 5dad6f628af742bab826819760deb677597445f7
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2023-12-16 20:18:47 +0800
+
+ liblzma: Improve lzma encoder init function consistency.
+
+ lzma_encoder_init() did not check for NULL options, but
+ lzma2_encoder_init() did. This is more of a code style improvement than
+ anything else to help make lzma_encoder_init() and lzma2_encoder_init()
+ more similar.
+
+ src/liblzma/lzma/lzma_encoder.c | 3 +++
+ 1 file changed, 3 insertions(+)
+
+commit e1b1a9d6370b788bd6078952c6c201e12bc27cbf
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2023-12-16 11:20:20 +0800
+
+ Docs: Update repository URL in Changelog.
+
+ ChangeLog | 2 +-
+ 1 file changed, 1 insertion(+), 1 deletion(-)
+
+commit f9b82bc64a9405e486575c65c1729229eb0a8198
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2023-12-15 16:56:31 +0800
+
+ CI: Update Upload Artifact Action.
+
+ .github/workflows/ci.yml | 2 +-
+ .github/workflows/windows-ci.yml | 2 +-
+ 2 files changed, 2 insertions(+), 2 deletions(-)
+
+commit d0b24efe6cdc47db5b0fdf6306f70a2e0e63e49e
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2023-12-07 21:48:07 +0800
+
+ Tests: Silence -Wsign-conversion warning on GCC version < 10.
+
+ Since GCC version 10, GCC no longer complains about simple implicit
+ integer conversions with Arithmetic operators.
+
+ For instance:
+
+ uint8_t a = 5;
+ uint32_t b = a + 5;
+
+ Give a warning on GCC 9 and earlier but this:
+
+ uint8_t a = 5;
+ uint32_t b = (a + 5) * 2;
+
+ Gives a warning with GCC 10+.
+
+ tests/test_block_header.c | 2 +-
+ 1 file changed, 1 insertion(+), 1 deletion(-)
+
+commit 4a972a8ee3ed88ac14067c1d2f15b78988e5dae8
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2023-12-06 18:39:03 +0800
+
+ Update THANKS.
+
+ THANKS | 1 +
+ 1 file changed, 1 insertion(+)
+
+commit ee2f48350099201694a7586e41d7aa2f09fc74da
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2023-12-06 18:30:25 +0800
+
+ Tests: Minor cleanups to OSS-Fuzz files.
+
+ Most of these fixes are small typos and tweaks. A few were caused by bad
+ advice from me. Here is the summary of what is changed:
+
+ - Author line edits
+
+ - Small comment changes/additions
+
+ - Using the return value in the error messages in the fuzz targets'
+ coder initialization code
+
+ - Removed fuzz_encode_stream.options. This set a max length, which may
+ prevent some worthwhile code paths from being properly exercised.
+
+ - Removed the max_len option from fuzz_decode_stream.options for the
+ same reason as fuzz_encode_stream. The alone decoder fuzz target still
+ has this restriction.
+
+ - Altered the dictionary contents for fuzz_lzma.dict. Instead of keeping
+ the properties static and varying the dictionary size, the properties
+ are varied and the dictionary size is kept small. The dictionary size
+ doesn't have much impact on the code paths but the properties do.
+
+ Closes: https://github.com/tukaani-project/xz/pull/73
+
+ tests/ossfuzz/Makefile | 3 ++
+ tests/ossfuzz/config/fuzz_decode_stream.options | 1 -
+ tests/ossfuzz/config/fuzz_lzma.dict | 34 +++++++++++-----------
+ tests/ossfuzz/fuzz_common.h | 16 +++++------
+ tests/ossfuzz/fuzz_decode_alone.c | 15 +++++-----
+ tests/ossfuzz/fuzz_decode_stream.c | 15 +++++-----
+ tests/ossfuzz/fuzz_encode_stream.c | 38 +++++++++++++++----------
+ 7 files changed, 66 insertions(+), 56 deletions(-)
+
+commit 483bb90eec7c83e1c2bcd06287714afd62d8c17d
+Author: Maksym Vatsyk <maksym.vatsyk@leviathansecurity.com>
+Date: 2023-12-05 16:31:09 +0100
+
+ Tests: Add fuzz_encode_stream ossfuzz target.
+
+ This fuzz target handles .xz stream encoding. The first byte of input
+ is used to dynamically set the preset level in order to increase the
+ fuzz coverage of complex critical code paths.
+
+ tests/ossfuzz/config/fuzz_encode_stream.options | 2 +
+ tests/ossfuzz/fuzz_encode_stream.c | 79 +++++++++++++++++++++++++
+ 2 files changed, 81 insertions(+)
+
+commit 7ca8c9869df82756c3128c4fcf1058da4d18aa48
+Author: Maksym Vatsyk <maksym.vatsyk@leviathansecurity.com>
+Date: 2023-12-04 17:23:24 +0100
+
+ Tests: Add fuzz_decode_alone OSS-Fuzz target
+
+ This fuzz target that handles LZMA alone decoding. A new fuzz
+ dictionary .dict was also created with common LZMA header values to
+ help speed up the discovery of valid headers.
+
+ tests/ossfuzz/config/fuzz_decode_alone.options | 3 ++
+ tests/ossfuzz/config/fuzz_lzma.dict | 22 ++++++++++++++
+ tests/ossfuzz/fuzz_decode_alone.c | 41 ++++++++++++++++++++++++++
+ 3 files changed, 66 insertions(+)
+
+commit 37581a77ad5a49615325b1d1925fdc402b1e1d5a
+Author: Maksym Vatsyk <maksym.vatsyk@leviathansecurity.com>
+Date: 2023-12-04 17:21:29 +0100
+
+ Tests: Update OSS-Fuzz Makefile.
+
+ All .c files can be built as separate fuzz targets. This simplifies
+ the Makefile by allowing us to use wildcards instead of having a
+ Makefile target for each fuzz target.
+
+ tests/ossfuzz/Makefile | 13 +++++++++----
+ 1 file changed, 9 insertions(+), 4 deletions(-)
+
+commit 28ce6a1c2a74866c51f7996a6869679c236d3c94
+Author: Maksym Vatsyk <maksym.vatsyk@leviathansecurity.com>
+Date: 2023-12-04 17:20:08 +0100
+
+ Tests: Move common OSS-Fuzz target code to .h file.
+
+ tests/ossfuzz/fuzz_common.h | 56 ++++++++++++++++++++++++++++++++++++
+ tests/ossfuzz/fuzz_decode_stream.c | 59 ++++++++++----------------------------
+ 2 files changed, 71 insertions(+), 44 deletions(-)
+
+commit bf0521ea1591c25b9d510c1b8be86073e9d847c6
+Author: Maksym Vatsyk <maksym.vatsyk@leviathansecurity.com>
+Date: 2023-12-04 17:18:20 +0100
+
+ Tests: Rename OSS-Fuzz files.
+
+ tests/ossfuzz/config/fuzz.options | 2 --
+ tests/ossfuzz/config/fuzz_decode_stream.options | 3 +++
+ tests/ossfuzz/config/{fuzz.dict => fuzz_xz.dict} | 0
+ tests/ossfuzz/{fuzz.c => fuzz_decode_stream.c} | 0
+ 4 files changed, 3 insertions(+), 2 deletions(-)
+
+commit 685094b8e1c1aa1bf934de0366ca42ef599d25f7
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2023-11-30 23:10:43 +0800
+
+ Update THANKS.
+
+ THANKS | 1 +
+ 1 file changed, 1 insertion(+)
+
+commit 3b3023e00b0071e10f589bbc3674e0ec432b8add
+Author: Kian-Meng Ang <kianmeng@cpan.org>
+Date: 2023-11-30 23:01:19 +0800
+
+ Tests: Fix typos
+
+ tests/test_index.c | 2 +-
+ tests/test_lzip_decoder.c | 4 ++--
+ 2 files changed, 3 insertions(+), 3 deletions(-)
+
+commit 424d46ead8cbc0da57f406b76926ec4ed47437f5
+Author: Kian-Meng Ang <kianmeng@cpan.org>
+Date: 2023-11-30 22:59:47 +0800
+
+ xz: Fix typo
+
+ src/xz/file_io.c | 2 +-
+ 1 file changed, 1 insertion(+), 1 deletion(-)
+
+commit 35558adf9c45e5597f2c8dbd969885dd484038d2
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2023-11-30 20:41:00 +0800
+
+ Update THANKS.
+
+ THANKS | 1 +
+ 1 file changed, 1 insertion(+)
+
+commit fd170e8557727bed6bec0518c16415064d972e4e
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2023-11-22 21:20:12 +0800
+
+ CI: Test musl libc builds on Ubuntu runner.
+
+ .github/workflows/ci.yml | 19 +++++++++++++++++--
+ 1 file changed, 17 insertions(+), 2 deletions(-)
+
+commit db2b4aa068a492c0013279a4ed43803e8ff9bb3e
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2023-11-22 21:12:15 +0800
+
+ CI: Allow ci_build.sh to set a different C compiler.
+
+ build-aux/ci_build.sh | 11 ++++++++++-
+ 1 file changed, 10 insertions(+), 1 deletion(-)
+
+commit ff7badef53c2cd698d4b72b945f34dfd0835e13c
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2023-11-24 21:19:12 +0800
+
+ CMake: Use consistent indentation with check_c_source_compiles().
+
+ CMakeLists.txt | 4 ++--
+ 1 file changed, 2 insertions(+), 2 deletions(-)
+
+commit d4af167570f2c14b002ee18a39d5b1e7e5a892b1
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2023-11-22 20:33:36 +0800
+
+ CMake: Change __attribute__((__ifunc__())) detection.
+
+ This renames ALLOW_ATTR_IFUNC to USE_ATTR_IFUNC and applies the ifunc
+ detection changes that were made to the Autotools build.
+
+ Fixes: https://github.com/tukaani-project/xz/issues/70
+
+ CMakeLists.txt | 53 +++++++++++++++++++++++++++++++++++++++++++++--------
+ 1 file changed, 45 insertions(+), 8 deletions(-)
+
+commit 20ecee40a0053fd16371ef0628046bf45e548d72
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2023-11-24 20:19:11 +0800
+
+ Docs: Update INSTALL for --enable_ifunc change.
+
+ INSTALL | 16 ++++++++--------
+ 1 file changed, 8 insertions(+), 8 deletions(-)
+
+commit ffb456593d695d70052a2f71c7a2e6269217d194
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2023-11-21 20:56:55 +0800
+
+ Build: Change --enable-ifunc handling.
+
+ Some compilers support __attribute__((__ifunc__())) even though the
+ dynamic linker does not. The compiler is able to create the binary
+ but it will fail on startup. So it is not enough to just test if
+ the attribute is supported.
+
+ The default value for enable_ifunc is now auto, which will attempt
+ to compile a program using __attribute__((__ifunc__())). There are
+ additional checks in this program if glibc is being used or if it
+ is running on FreeBSD.
+
+ Setting --enable-ifunc will skip this test and always enable
+ __attribute__((__ifunc__())), even if is not supported.
+
+ configure.ac | 61 +++++++++++++++++++++++++++++++++++++++++++-----------------
+ 1 file changed, 44 insertions(+), 17 deletions(-)
+
+commit 12b89bcc9915090eb42ae638e565af44b6832a23
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2023-11-23 17:39:10 +0200
+
+ xz: Tweak a comment.
+
+ src/xz/util.c | 4 ++--
+ 1 file changed, 2 insertions(+), 2 deletions(-)
+
+commit 2ab2e4b5a542eab93902985ce4e642719a8b7a4e
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2023-11-23 22:13:39 +0800
+
+ xz: Use is_tty() in message.c.
+
+ src/xz/message.c | 7 +------
+ 1 file changed, 1 insertion(+), 6 deletions(-)
+
+commit 584e3a258f32d579b1d07f99b4dc6e856c10ac7e
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2023-11-23 22:04:35 +0800
+
+ xz: Create separate is_tty() function.
+
+ The new is_tty() will report if a file descriptor is a terminal or not.
+ On POSIX systems, it is a wrapper around isatty(). However, the native
+ Windows implementation of isatty() will return true for all character
+ devices, not just terminals. So is_tty() has a special case for Windows
+ so it can use alternative Windows API functions to determine if a file
+ descriptor is a terminal.
+
+ This fixes a bug with MSVC and MinGW-w64 builds that refused to read from
+ or write to non-terminal character devices because xz thought it was a
+ terminal. For instance:
+
+ xz foo -c > /dev/null
+
+ would fail because /dev/null was assumed to be a terminal.
+
+ src/xz/util.c | 30 +++++++++++++++++++++++-------
+ src/xz/util.h | 14 ++++++++++++++
+ 2 files changed, 37 insertions(+), 7 deletions(-)
+
+commit 6b05f827f50e686537e9a23c49c5aa4c0aa6b23d
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2023-11-22 20:39:41 +0800
+
+ tuklib_integer: Fix typo discovered by codespell.
+
+ Based on internet dictionary searches, 'choise' is an outdated spelling
+ of 'choice'.
+
+ src/common/tuklib_integer.h | 2 +-
+ 1 file changed, 1 insertion(+), 1 deletion(-)
+
+commit 659aca0d695807c0762d4101765189e4e33d1e2c
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2023-11-17 19:35:19 +0200
+
+ xz: Move the check for --suffix with --format=raw a few lines earlier.
+
+ Now it reads from argv[] instead of args->arg_names.
+
+ src/xz/args.c | 44 ++++++++++++++++++++++----------------------
+ 1 file changed, 22 insertions(+), 22 deletions(-)
+
+commit ca278eb2b7f5a4940f5ab18955297b398d423824
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2023-11-17 20:35:11 +0800
+
+ Tests: Create test_suffix.sh.
+
+ This tests some complicated interactions with the --suffix= option.
+ The suffix option must be used with --format=raw, but can optionally
+ be used to override the default .xz suffix.
+
+ This test also verifies some recent bugs have been correctly solved
+ and to hopefully avoid further regressions in the future.
+
+ tests/Makefile.am | 2 +
+ tests/test_suffix.sh | 189 +++++++++++++++++++++++++++++++++++++++++++++++++++
+ 2 files changed, 191 insertions(+)
+
+commit 2a732aba22da1b0d4a1241cb32280ed010ba03ce
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2023-11-17 20:19:26 +0800
+
+ xz: Fix a bug with --files and --files0 in raw mode without a suffix.
+
+ The following command caused a segmentation fault:
+
+ xz -Fraw --lzma1 --files=foo
+
+ when foo was a valid file. The usage of --files or --files0 was not
+ being checked when compressing or decompressing in raw mode without a
+ suffix. The suffix checking code was meant to validate that all files
+ to be processed are "-" (if not writing to standard out), meaning the
+ data is only coming from standard in. In this case, there were no file
+ names to check since --files and --files0 store their file name in a
+ different place.
+
+ Later code assumed the suffix was set and caused a segmentation fault.
+ Now, the above command results in an error.
+
+ src/xz/args.c | 5 +++++
+ 1 file changed, 5 insertions(+)
+
+commit 299920bab9ae258a247366339264e8aefca9e3ce
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2023-11-17 20:04:58 +0800
+
+ Tests: Fix typo in a comment.
+
+ tests/test_files.sh | 2 +-
+ 1 file changed, 1 insertion(+), 1 deletion(-)
+
+commit f481523baac946fa3bc13d79186ffaf0c0b818a7
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2023-11-15 23:40:13 +0800
+
+ xz: Refactor suffix test with raw format.
+
+ The previous version set opt_stdout, but this caused an issue with
+ copying an input file to standard out when decompressing an unknown file
+ type. The following needs to result in an error:
+
+ echo foo | xz -df
+
+ since -c, --stdout is not used. This fixes the previous error by not
+ setting opt_stdout.
+
+ src/xz/args.c | 38 +++++++++++++-------------------------
+ 1 file changed, 13 insertions(+), 25 deletions(-)
+
+commit 837ea40b1c9d4998cac4500b55171bf33e0c31a6
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2023-11-14 20:27:46 +0800
+
+ xz: Move suffix check after stdout mode is detected.
+
+ This fixes a bug introduced in cc5aa9ab138beeecaee5a1e81197591893ee9ca0
+ when the suffix check was initially moved. This caused a situation that
+ previously worked:
+
+ echo foo | xz -Fraw --lzma1 | wc -c
+
+ to fail because the old code knew that this would write to standard out
+ so a suffix was not needed.
+
+ src/xz/args.c | 16 ++++++++--------
+ 1 file changed, 8 insertions(+), 8 deletions(-)
+
+commit d4f4a4d040ef47a5e82dffd0f067e92716606ddf
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2023-11-14 20:27:04 +0800
+
+ xz: Detect when all data will be written to standard out earlier.
+
+ If the -c, --stdout argument is not used, then we can still detect when
+ the data will be written to standard out if all of the provided
+ filenames are "-" (denoting standard in) or if no filenames are
+ provided.
+
+ src/xz/args.c | 21 +++++++++++++++++++++
+ 1 file changed, 21 insertions(+)
+
+commit 2ade7246e7ba729a91460d2fab0f4c7b89d3998b
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2023-11-09 01:21:53 +0800
+
+ liblzma: Add missing comments to lz_encoder.h.
+
+ src/liblzma/lz/lz_encoder.h | 6 +++++-
+ 1 file changed, 5 insertions(+), 1 deletion(-)
+
+commit 5fe1450603dc625340b8b7866fb4a83ff748ad06
Author: Jia Tan <jiat0218@gmail.com>
Date: 2023-11-01 20:18:30 +0800
@@ -17,7 +3585,7 @@ Date: 2023-11-01 20:18:30 +0800
NEWS | 74 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
1 file changed, 74 insertions(+)
-commit d90ed84db9770712e2421e170076b43bda9b64a7
+commit 46007049cd42e606543dbe650feb17bdf4469c29
Author: Lasse Collin <lasse.collin@tukaani.org>
Date: 2023-10-31 21:41:09 +0200
@@ -37,7 +3605,7 @@ Date: 2023-10-31 21:41:09 +0200
src/liblzma/lzma/fastpos_tablegen.c | 2 ++
1 file changed, 2 insertions(+)
-commit 9b1268538b0b2c6c0a121f95165de65fc71ad23c
+commit 148e20607e95781558bdfc823ecba07b7af4b590
Author: Jia Tan <jiat0218@gmail.com>
Date: 2023-10-31 21:51:40 +0800
@@ -46,7 +3614,20 @@ Date: 2023-10-31 21:51:40 +0800
configure.ac | 9 +++++----
1 file changed, 5 insertions(+), 4 deletions(-)
-commit 068ee436f4a8a706125ef43e8228b30001b1554e
+commit 8c36ab79cbf23104ce7a3d533d5ac98cd492e57c
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2023-10-30 18:09:53 +0200
+
+ liblzma: Add a note why crc_always_inline exists for now.
+
+ Solaris Studio is a possible example (not tested) which
+ supports the always_inline attribute but might not get
+ detected by the common.h #ifdefs.
+
+ src/liblzma/check/crc_common.h | 5 +++++
+ 1 file changed, 5 insertions(+)
+
+commit e7a86b94cd247435ac96bc79ba528b690b9ca388
Author: Lasse Collin <lasse.collin@tukaani.org>
Date: 2023-10-22 17:59:11 +0300
@@ -55,7 +3636,7 @@ Date: 2023-10-22 17:59:11 +0300
src/liblzma/common/memcmplen.h | 3 +--
1 file changed, 1 insertion(+), 2 deletions(-)
-commit 6cdf0a7b7974baf58c1fd20ec3278f3b84ae56e5
+commit dcfe5632992fb7f06f921da13fcdd84f83d0d285
Author: Lasse Collin <lasse.collin@tukaani.org>
Date: 2023-10-30 17:43:03 +0200
@@ -64,7 +3645,7 @@ Date: 2023-10-30 17:43:03 +0200
src/liblzma/common/common.h | 17 +++++++++++++++++
1 file changed, 17 insertions(+)
-commit 33daad3961a4f07f3902b40f13e823e6e43e85da
+commit 41113fe30a47f6fd3e30cb4494dd538e86212edf
Author: Lasse Collin <lasse.collin@tukaani.org>
Date: 2023-10-22 17:15:32 +0300
@@ -79,7 +3660,7 @@ Date: 2023-10-22 17:15:32 +0300
src/liblzma/rangecoder/price.h | 1 +
5 files changed, 13 insertions(+)
-commit 6961a5ac7df178bfc2b7a181c40575847bc3035f
+commit a2f5ca706acc6f7715b8d260a8c6ed50d7717478
Author: Lasse Collin <lasse.collin@tukaani.org>
Date: 2023-10-22 17:08:39 +0300
@@ -119,7 +3700,7 @@ Date: 2023-10-22 17:08:39 +0300
src/liblzma/common/common.h | 11 +++++++++++
1 file changed, 11 insertions(+)
-commit 5b9e16764905d06fa8e8339ba185ddfee304e5fb
+commit 2c7ee92e44e1e66f0a427555233eb22c78f6c4f8
Author: Lasse Collin <lasse.collin@tukaani.org>
Date: 2023-09-30 22:54:28 +0300
@@ -137,7 +3718,7 @@ Date: 2023-09-30 22:54:28 +0300
src/liblzma/api/lzma/version.h | 2 +-
2 files changed, 3 insertions(+), 3 deletions(-)
-commit 36fabdbe67c8a8fbdc3ac695a91fc443a1328cc4
+commit 597f49b61475438a43a417236989b2acc968a686
Author: Lasse Collin <lasse.collin@tukaani.org>
Date: 2023-09-27 00:58:17 +0300
@@ -153,7 +3734,7 @@ Date: 2023-09-27 00:58:17 +0300
cmake/tuklib_large_file_support.cmake | 52 +++++++++++++++++++++++++++++++++++
2 files changed, 58 insertions(+), 1 deletion(-)
-commit 989c8c354cbd2d20fbae4a432a3e31f5bc1cb9bf
+commit 1bc548b8210366e44ba35b0b11577a8e328c1228
Author: Lasse Collin <lasse.collin@tukaani.org>
Date: 2023-09-30 02:14:25 +0300
@@ -166,7 +3747,7 @@ Date: 2023-09-30 02:14:25 +0300
CMakeLists.txt | 21 +++++++++++++++++++++
1 file changed, 21 insertions(+)
-commit 983f3b458dc79c5976a4237fdfe4f8079f8d8830
+commit 2add71966f891d315105d6245f724ed4f43a4eff
Author: Lasse Collin <lasse.collin@tukaani.org>
Date: 2023-09-30 01:13:13 +0300
@@ -180,7 +3761,7 @@ Date: 2023-09-30 01:13:13 +0300
CMakeLists.txt | 26 +++++++++++++++-----------
1 file changed, 15 insertions(+), 11 deletions(-)
-commit 4083c8e9501a48934a5fb563d2c3ce2ae143cd27
+commit a7d1b2825c49dc83f1910eeb8ba0f1dfbd886d91
Author: Lasse Collin <lasse.collin@tukaani.org>
Date: 2023-09-29 20:46:11 +0300
@@ -195,7 +3776,7 @@ Date: 2023-09-29 20:46:11 +0300
src/liblzma/liblzma.pc.in | 1 +
1 file changed, 1 insertion(+)
-commit 661549ecb7a9b136d72a01c137d9776c75d52d51
+commit 80e0750e3996c1c659e972ce9cf789ca2e99f702
Author: Lasse Collin <lasse.collin@tukaani.org>
Date: 2023-09-27 22:46:20 +0300
@@ -205,7 +3786,7 @@ Date: 2023-09-27 22:46:20 +0300
cmake/remove-ordinals.cmake | 26 ++++++++++++++++++++++++++
2 files changed, 46 insertions(+)
-commit 0e546eb4da05c52b7d257e5bd85e15c51c4d86a3
+commit 08d12595f486890cf601b87f36ee0ddbce57728e
Author: Lasse Collin <lasse.collin@tukaani.org>
Date: 2023-10-26 21:44:42 +0300
@@ -216,7 +3797,7 @@ Date: 2023-10-26 21:44:42 +0300
CMakeLists.txt | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)
-commit da4d04e4d6e199d28b58bd2e0df4e120c52dd5d7
+commit e67aaf698de75c73443a5ec786781cbf2034461d
Author: Lasse Collin <lasse.collin@tukaani.org>
Date: 2023-10-01 19:10:57 +0300
@@ -228,7 +3809,53 @@ Date: 2023-10-01 19:10:57 +0300
CMakeLists.txt | 1 +
1 file changed, 1 insertion(+)
-commit 007558a358c48a0175cc8d47d11798d7967282ab
+commit 88588b1246d8c26ffbc138b3e5c413c5f14c3179
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2023-10-25 19:13:25 +0300
+
+ Build: Detect -fsanitize= in CFLAGS and incompatible build options.
+
+ Now configure will fail if -fsanitize= is found in CFLAGS
+ and sanitizer-incompatible ifunc or Landlock sandboxing
+ would be used. These are incompatible with one or more sanitizers.
+ It's simpler to reject all -fsanitize= uses instead of trying to
+ pass those that might not cause problems.
+
+ CMake-based build was updated similarly. It lets the configuration
+ finish (SEND_ERROR instead of FATAL_ERROR) so that both error
+ messages can be seen at once.
+
+ CMakeLists.txt | 29 +++++++++++++++++++++++++++++
+ configure.ac | 37 +++++++++++++++++++++++++++++++++----
+ 2 files changed, 62 insertions(+), 4 deletions(-)
+
+commit 5e3d890f8862a7d4fbef5e38e11b6c9fbd98f468
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2023-10-24 00:50:08 +0800
+
+ CI: Disable sandboxing in fsanitize=address,undefined job.
+
+ The sandboxing on Linux now supports Landlock, which restricts all
+ supported filesystem actions after xz opens the files it needs. The
+ sandbox is only enabled when one file is input and we are writing to
+ standard out. With fsanitize=address,undefined, the instrumentation
+ needs to read additional files after the sandbox is in place. This
+ forces all xz based test to fail, so the sandbox must instead be
+ disabled.
+
+ .github/workflows/ci.yml | 8 ++++++--
+ 1 file changed, 6 insertions(+), 2 deletions(-)
+
+commit b1408987ea832e2760e478ae960a636df17a1363
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2023-10-24 00:15:39 +0800
+
+ CI: Allow disabling the sandbox in ci_build.sh.
+
+ build-aux/ci_build.sh | 5 ++++-
+ 1 file changed, 4 insertions(+), 1 deletion(-)
+
+commit 91c435cf1c7a1e893706d4d716dfd361621ed824
Author: Lasse Collin <lasse.collin@tukaani.org>
Date: 2023-10-11 19:47:44 +0300
@@ -242,7 +3869,34 @@ Date: 2023-10-11 19:47:44 +0300
CMakeLists.txt | 10 +++++++---
1 file changed, 7 insertions(+), 3 deletions(-)
-commit 7d01de67ee3dd76cfc12c23220e2e4cdc59708f1
+commit fa1609eb9393ecd30decfed4891c907829f06710
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2023-10-09 22:28:49 +0300
+
+ Docs: Update INSTALL about sandboxing support.
+
+ INSTALL | 7 ++++++-
+ 1 file changed, 6 insertions(+), 1 deletion(-)
+
+commit 8276c7f41c671eee4aa3239490658b23dcfd3021
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2023-10-09 22:07:52 +0300
+
+ xz: Support basic sandboxing with Linux Landlock (ABI versions 1-3).
+
+ It is enabled only when decompressing one file to stdout,
+ similar to how Capsicum is used.
+
+ Landlock was added in Linux 5.13.
+
+ CMakeLists.txt | 12 +++++++++++-
+ configure.ac | 11 ++++++++---
+ src/xz/file_io.c | 58 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++
+ src/xz/main.c | 19 +++++++++++++++++++
+ src/xz/private.h | 3 ++-
+ 5 files changed, 98 insertions(+), 5 deletions(-)
+
+commit 3a1e9fd031b9320d769d63b503ef4e82e1b6ea8c
Author: Lasse Collin <lasse.collin@tukaani.org>
Date: 2023-10-09 21:12:31 +0300
@@ -253,7 +3907,7 @@ Date: 2023-10-09 21:12:31 +0300
CMakeLists.txt | 19 ++++++++++---------
1 file changed, 10 insertions(+), 9 deletions(-)
-commit f8edcf3da689aad4b21e139197725450f2c456a0
+commit bf011352528ae3539ea7b780b45b96736ee57a99
Author: Lasse Collin <lasse.collin@tukaani.org>
Date: 2023-10-09 20:59:24 +0300
@@ -270,7 +3924,167 @@ Date: 2023-10-09 20:59:24 +0300
CMakeLists.txt | 28 ++++++++++++++--------------
1 file changed, 14 insertions(+), 14 deletions(-)
-commit 1695021e4a233a9388ddd428654c1447f0ea3bfb
+commit 3f53870c249945d657ca3d75e0993e6267d71f75
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2023-10-09 18:37:32 +0300
+
+ CMake: Add sandboxing support.
+
+ CMakeLists.txt | 50 +++++++++++++++++++++++++++++++++++++++++++++++++-
+ 1 file changed, 49 insertions(+), 1 deletion(-)
+
+commit 2e2cd11535ad77364cf021297e0b3f162fa3a3d0
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2023-10-09 18:13:08 +0300
+
+ Simplify detection of Capsicum support.
+
+ This removes support for FreeBSD 10.0 and 10.1 which used
+ <sys/capability.h> instead of <sys/capsicum.h>. Support for
+ FreeBSD 10.1 ended on 2016-12-31. So now FreeBSD >= 10.2 is
+ required to enable Capsicum support.
+
+ This also removes support for Capsicum on Linux (libcaprights)
+ which seems to have been unmaintained since 2017 and Linux 4.11:
+ https://github.com/google/capsicum-linux
+
+ configure.ac | 4 +--
+ m4/ax_check_capsicum.m4 | 85 -------------------------------------------------
+ src/xz/Makefile.am | 2 +-
+ src/xz/file_io.c | 14 +++-----
+ src/xz/private.h | 2 +-
+ 5 files changed, 9 insertions(+), 98 deletions(-)
+
+commit c57858b60e186d020b2dbaf7aabd9b32c71da824
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2023-09-25 01:46:36 +0300
+
+ xz/Windows: Allow clock_gettime with POSIX threads.
+
+ If winpthreads are used for threading, it's OK to use clock_gettime()
+ from winpthreads too.
+
+ src/xz/mytime.c | 9 ++++++---
+ 1 file changed, 6 insertions(+), 3 deletions(-)
+
+commit dd32f628bb5541ef4e8ce66966ef456a1934084c
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2023-09-25 01:39:26 +0300
+
+ mythread.h: Make MYTHREAD_POSIX compatible with MinGW-w64's winpthreads.
+
+ This might be almost useless but it doesn't need much extra code either.
+
+ src/common/mythread.h | 23 ++++++++++++++++++++++-
+ 1 file changed, 22 insertions(+), 1 deletion(-)
+
+commit 680e52cdd086e92691d8a0bca2c98815565f60ca
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2023-09-23 03:06:36 +0300
+
+ CMake: Check for clock_gettime() even on Windows.
+
+ This mirrors configure.ac although currently MinGW-w64 builds
+ don't use clock_gettime() even if it is found.
+
+ CMakeLists.txt | 44 +++++++++++++++++++++-----------------------
+ 1 file changed, 21 insertions(+), 23 deletions(-)
+
+commit 1c1a8c3ee4dad0064dbe63b8dbc4ac4bc679f419
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2023-09-23 03:23:32 +0300
+
+ Build: Check for clock_gettime() even if not using POSIX threads.
+
+ See the new comment in the code.
+
+ This also makes the check for clock_gettime() run with MinGW-w64
+ with which we don't want to use clock_gettime(). The previous
+ commit already took care of this situation.
+
+ configure.ac | 31 ++++++++++++++++++-------------
+ 1 file changed, 18 insertions(+), 13 deletions(-)
+
+commit 46fd991cd2808ef62554853864c946232e7547f0
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2023-09-24 22:58:53 +0300
+
+ xz/Windows: Ensure that clock_gettime() isn't used with MinGW-w64.
+
+ This commit alone doesn't change anything in the real-world:
+
+ - configure.ac currently checks for clock_gettime() only
+ when using pthreads.
+
+ - CMakeLists.txt doesn't check for clock_gettime() on Windows.
+
+ So clock_gettime() wasn't used with MinGW-w64 before either.
+
+ clock_gettime() provides monotonic time and it's better than
+ gettimeofday() in this sense. But clock_gettime() is defined
+ in winpthreads, and liblzma or xz needs nothing else from
+ winpthreads. By avoiding clock_gettime(), we avoid the dependency on
+ libwinpthread-1.dll or the need to link against the static version.
+
+ As a bonus, GetTickCount64() and MinGW-w64's gettimeofday() can be
+ faster than clock_gettime(CLOCK_MONOTONIC, &tv). The resolution
+ is more than good enough for the progress indicator in xz.
+
+ src/xz/mytime.c | 9 +++++++--
+ 1 file changed, 7 insertions(+), 2 deletions(-)
+
+commit cdb4d91f2464b50c985ef7b9517314ea237ddda7
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2023-09-24 00:21:22 +0300
+
+ xz/Windows: Use GetTickCount64() with MinGW-w64 if using Vista threads.
+
+ src/xz/mytime.c | 14 +++++++++++---
+ 1 file changed, 11 insertions(+), 3 deletions(-)
+
+commit 988e09f27b9b04a43d45d10f92782e0092ee27a9
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2023-10-20 19:17:46 +0800
+
+ liblzma: Move is_clmul_supported() back to crc_common.h.
+
+ This partially reverts creating crc_clmul.c
+ (8c0f9376f58c0696d5d6719705164d35542dd891) where is_clmul_supported()
+ was moved, extern'ed, and renamed to lzma_is_clmul_supported(). This
+ caused a problem when the function call to lzma_is_clmul_supported()
+ results in a call through the PLT. ifunc resolvers run very early in
+ the dynamic loading sequence, so the PLT may not be setup properly at
+ this point. Whether the PLT is used or not for
+ lzma_is_clmul_supported() depened upon the compiler-toolchain used and
+ flags.
+
+ In liblzma compiled with GCC, for instance, GCC will go through the PLT
+ for function calls internal to liblzma if the version scripts and
+ symbol visibility hiding are not used. If lazy-binding is disabled,
+ then it would have made any program linked with liblzma fail during
+ dynamic loading in the ifunc resolver.
+
+ src/liblzma/check/crc32_fast.c | 2 +-
+ src/liblzma/check/crc64_fast.c | 2 +-
+ src/liblzma/check/crc_clmul.c | 45 ------------------------------------
+ src/liblzma/check/crc_common.h | 52 +++++++++++++++++++++++++++++++++++++++---
+ 4 files changed, 51 insertions(+), 50 deletions(-)
+
+commit 105c7ca90d4152942e0798580a37f736d02faa22
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2023-10-19 16:23:32 +0800
+
+ Build: Remove check for COND_CHECK_CRC32 in check/Makefile.inc.
+
+ Currently crc32 is always enabled, so COND_CHECK_CRC32 must always be
+ set. Because of this, it makes the recent change to conditionally
+ compile check/crc_clmul.c appear wrong since that file has CLMUL
+ implementations for both CRC32 and CRC64.
+
+ src/liblzma/check/Makefile.inc | 4 ++--
+ 1 file changed, 2 insertions(+), 2 deletions(-)
+
+commit 139757170468f0f1fafdf0a8ffa74363d1ea1d0c
Author: Jia Tan <jiat0218@gmail.com>
Date: 2023-10-19 16:09:01 +0800
@@ -282,10 +4096,67 @@ Date: 2023-10-19 16:09:01 +0800
This mirrors our Autotools build --disable-clmul-crc functionality.
- CMakeLists.txt | 40 +++++++++++++++++++++++-----------------
- 1 file changed, 23 insertions(+), 17 deletions(-)
+ CMakeLists.txt | 44 +++++++++++++++++++++++++-------------------
+ 1 file changed, 25 insertions(+), 19 deletions(-)
+
+commit c60b25569d414bb73b705977a4dd342f8f9f1965
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2023-10-19 00:22:50 +0800
+
+ liblzma: Fix -fsanitize=address failure with crc_clmul functions.
+
+ After forcing crc_simd_body() to always be inlined it caused
+ -fsanitize=address to fail for lzma_crc32_clmul() and
+ lzma_crc64_clmul(). The __no_sanitize_address__ attribute was added
+ to lzma_crc32_clmul() and lzma_crc64_clmul(), but not removed from
+ crc_simd_body(). ASAN and inline functions behavior has changed over
+ the years for GCC specifically, so while strictly required we will
+ keep __attribute__((__no_sanitize_address__)) on crc_simd_body() in
+ case this becomes a requirement in the future.
+
+ Older GCC versions refuse to inline a function with ASAN if the
+ caller and callee do not agree on sanitization flags
+ (https://gcc.gnu.org/bugzilla/show_bug.cgi?id=89124#c3). If the
+ function was forced to be inlined, it will not compile if the callee
+ function has __no_sanitize_address__ but the caller doesn't.
-commit 5056bc51071d1a07097c5667a0d5bd85242e31b9
+ src/liblzma/check/crc_clmul.c | 6 ++++++
+ 1 file changed, 6 insertions(+)
+
+commit 9a78971261bc67622cbd7dae02f6966968ac1393
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2023-10-14 20:16:13 +0300
+
+ tuklib_integer: Update the CMake test for fast unaligned access.
+
+ cmake/tuklib_integer.cmake | 69 ++++++++++++++++++++++++++++++++++++----------
+ 1 file changed, 54 insertions(+), 15 deletions(-)
+
+commit 2f81ac852bc5aafc91c8e2adc66b5114761703c4
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2023-09-23 23:28:48 +0300
+
+ Build: Enabled unaligned access by default on PowerPC64LE and some RISC-V.
+
+ PowerPC64LE wasn't tested but it seems like a safe change.
+ POWER8 supports unaligned access in little endian mode. Testing
+ on godbolt.org shows that GCC uses unaligned access by default.
+
+ The RISC-V macro __riscv_misaligned_fast is very new and not
+ in any stable compiler release yet.
+
+ Documentation in INSTALL was updated to match.
+
+ Documentation about an autodetection bug when using ARM64 GCC
+ with -mstrict-align was added to INSTALL.
+
+ CMake files weren't updated yet.
+
+ INSTALL | 39 +++++++++++++++++++++++++++++++++++++--
+ m4/tuklib_integer.m4 | 34 +++++++++++++++++++++++++++-------
+ 2 files changed, 64 insertions(+), 9 deletions(-)
+
+commit c8f715f1bca4c30db814fcf1fd2fe88b8992ede2
Author: Lasse Collin <lasse.collin@tukaani.org>
Date: 2023-10-14 17:56:59 +0300
@@ -298,7 +4169,7 @@ Date: 2023-10-14 17:56:59 +0300
src/common/tuklib_integer.h | 256 ++++++++++++++++++++++++++++++++------------
1 file changed, 189 insertions(+), 67 deletions(-)
-commit 9e14743ee5ba79181076bc33952245d5b18fbc58
+commit 6828242735cbf61b93d140383336e1e51a006f2d
Author: Lasse Collin <lasse.collin@tukaani.org>
Date: 2023-09-23 02:21:49 +0300
@@ -307,7 +4178,233 @@ Date: 2023-09-23 02:21:49 +0300
src/common/tuklib_integer.h | 34 ++++++++++++++++++++++++++++++++++
1 file changed, 34 insertions(+)
-commit 4cc91ceb3992ef4f51302b56178c3b2c2aeaaaad
+commit 1c8884f0af28b3a4690bb573cdf3240a8ec73416
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2023-10-18 19:57:10 +0800
+
+ liblzma: Set the MSVC optimization fix to only cover lzma_crc64_clmul().
+
+ After testing a 32-bit Release build on MSVC, only lzma_crc64_clmul()
+ has the bug. crc_simd_body() and lzma_crc32_clmul() do not need the
+ optimizations disabled.
+
+ src/liblzma/check/crc_clmul.c | 30 +++++++++++++++---------------
+ 1 file changed, 15 insertions(+), 15 deletions(-)
+
+commit 5ce0f7a48bdf5c3b45430850a4487307afac6143
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2023-10-18 14:30:00 +0300
+
+ liblzma: CRC_USE_GENERIC_FOR_SMALL_INPUTS cannot be used with ifunc.
+
+ src/liblzma/check/crc_common.h | 4 +++-
+ 1 file changed, 3 insertions(+), 1 deletion(-)
+
+commit 27735380491bb5ce0d0f41d5244d89c1d0825f6b
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2023-10-17 21:53:11 +0300
+
+ liblzma: Include common.h in crc_common.h.
+
+ crc_common.h depends on common.h. The headers include common.h except
+ when there is a reason to not do so.
+
+ src/liblzma/check/crc_clmul.c | 1 -
+ src/liblzma/check/crc_common.h | 3 +++
+ 2 files changed, 3 insertions(+), 1 deletion(-)
+
+commit e13b7947b92355c334edd594295d3a2c99c4bca1
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2023-10-18 01:23:26 +0800
+
+ liblzma: Add include guards to crc_common.h.
+
+ src/liblzma/check/crc_common.h | 5 +++++
+ 1 file changed, 5 insertions(+)
+
+commit 40abd88afcc61a8157fcd12d78d491caeb8e12be
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2023-10-18 22:50:25 +0800
+
+ liblzma: Add the crc_always_inline macro to crc_simd_body().
+
+ Forcing this to be inline has a significant speed improvement at the
+ cost of a few repeated instructions. The compilers tested on did not
+ inline this function since it is large and is used twice in the same
+ translation unit.
+
+ src/liblzma/check/crc_clmul.c | 2 +-
+ 1 file changed, 1 insertion(+), 1 deletion(-)
+
+commit a5966c276bd6fa975f0389f8a8dc61393de750b0
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2023-10-18 22:48:19 +0800
+
+ liblzma: Create crc_always_inline macro.
+
+ This macro must be used instead of the inline keyword. On MSVC, it is
+ a replacement for __forceinline which is an MSVC specific keyword that
+ should not be used with inline (it will issue a warning if it is).
+
+ It does not use a build system check to determine if
+ __attribute__((__always_inline__)) since all compilers that can use
+ CLMUL extensions (except the special case for MSVC) should support this
+ attribute. If this assumption is incorrect then it will result in a bug
+ report instead of silently producing slow code.
+
+ src/liblzma/check/crc_common.h | 15 +++++++++++++++
+ 1 file changed, 15 insertions(+)
+
+commit 96b663f67c0e738a99ba8f35d9f4ced9add74544
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2023-10-14 13:23:23 +0800
+
+ liblzma: Refactor CRC comments.
+
+ A detailed description of the three dispatch methods was added. Also,
+ duplicated comments now only appear in crc32_fast.c or were removed from
+ both crc32_fast.c and crc64_fast.c if they appeared in crc_clmul.c.
+
+ src/liblzma/check/crc32_fast.c | 64 +++++++++++++++++++++++++++++-------------
+ src/liblzma/check/crc64_fast.c | 61 ++++++----------------------------------
+ 2 files changed, 53 insertions(+), 72 deletions(-)
+
+commit 8c0f9376f58c0696d5d6719705164d35542dd891
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2023-10-14 12:17:57 +0800
+
+ liblzma: Create crc_clmul.c.
+
+ Both crc32_clmul() and crc64_clmul() are now exported from
+ crc32_clmul.c as lzma_crc32_clmul() and lzma_crc64_clmul(). This
+ ensures that is_clmul_supported() (now lzma_is_clmul_supported()) is
+ not duplicated between crc32_fast.c and crc64_fast.c.
+
+ Also, it encapsulates the complexity of the CLMUL implementations into a
+ single file and reduces the complexity of crc32_fast.c and crc64_fast.c.
+ Before, CLMUL code was present in crc32_fast.c, crc64_fast.c, and
+ crc_common.h.
+
+ During the conversion, various cleanups were applied to code (thanks to
+ Lasse Collin) including:
+
+ - Require using semicolons with MASK_/L/H/LH macros.
+ - Variable typing and const handling improvements.
+ - Improvements to comments.
+ - Fixes to the pragmas used.
+ - Removed unneeded variables.
+ - Whitespace improvements.
+ - Fixed CRC_USE_GENERIC_FOR_SMALL_INPUTS handling.
+ - Silenced warnings and removed the need for some #pragmas
+
+ CMakeLists.txt | 6 +-
+ configure.ac | 6 +-
+ src/liblzma/check/Makefile.inc | 3 +
+ src/liblzma/check/crc32_fast.c | 120 +-----------
+ src/liblzma/check/crc64_fast.c | 128 +------------
+ src/liblzma/check/crc_clmul.c | 414 +++++++++++++++++++++++++++++++++++++++++
+ src/liblzma/check/crc_common.h | 190 +------------------
+ 7 files changed, 444 insertions(+), 423 deletions(-)
+
+commit a3ebc2c516b09616638060806c841bd4bcf7bce3
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2023-10-14 10:23:03 +0800
+
+ liblzma: Define CRC_USE_IFUNC in crc_common.h.
+
+ When ifunc is supported, we can define a simpler macro instead of
+ repeating the more complex check in both crc32_fast.c and crc64_fast.c.
+
+ src/liblzma/check/crc32_fast.c | 3 +--
+ src/liblzma/check/crc64_fast.c | 3 +--
+ src/liblzma/check/crc_common.h | 5 +++++
+ 3 files changed, 7 insertions(+), 4 deletions(-)
+
+commit f1cd9d7194f005cd66ec03c6635ceae75f90ef17
+Author: Hans Jansen <hansjansen162@outlook.com>
+Date: 2023-10-12 19:37:01 +0200
+
+ liblzma: Added crc32_clmul to crc32_fast.c.
+
+ src/liblzma/check/crc32_fast.c | 247 ++++++++++++++++++++++++++++++++++++++--
+ src/liblzma/check/crc32_table.c | 19 +++-
+ 2 files changed, 255 insertions(+), 11 deletions(-)
+
+commit 93e6fb08b22c7c13be2dd1e7274fe78413436254
+Author: Hans Jansen <hansjansen162@outlook.com>
+Date: 2023-10-12 19:23:40 +0200
+
+ liblzma: Moved CLMUL CRC logic to crc_common.h.
+
+ crc64_fast.c was updated to use the code from crc_common.h instead.
+
+ src/liblzma/check/crc64_fast.c | 257 ++---------------------------------------
+ src/liblzma/check/crc_common.h | 230 +++++++++++++++++++++++++++++++++++-
+ 2 files changed, 240 insertions(+), 247 deletions(-)
+
+commit 233885a437f8b55a5c8442984ebc0aaa579e92de
+Author: Hans Jansen <hansjansen162@outlook.com>
+Date: 2023-10-12 19:07:50 +0200
+
+ liblzma: Rename crc_macros.h to crc_common.h.
+
+ CMakeLists.txt | 2 +-
+ src/liblzma/check/Makefile.inc | 2 +-
+ src/liblzma/check/crc32_fast.c | 2 +-
+ src/liblzma/check/crc64_fast.c | 2 +-
+ src/liblzma/check/{crc_macros.h => crc_common.h} | 2 +-
+ 5 files changed, 5 insertions(+), 5 deletions(-)
+
+commit 37947d4a7565b87e4cec8b89229d35b0a3f8d2cd
+Author: Gabriela Gutierrez <gabigutierrez@google.com>
+Date: 2023-09-26 15:55:13 +0000
+
+ CI: Bump and ref actions by commit SHA in windows-ci.yml
+
+ Referencing actions by commit SHA in GitHub workflows guarantees you are using an immutable version. Actions referenced by tags and branches are more vulnerable to attacks, such as the tag being moved to a malicious commit or a malicious commit being pushed to the branch.
+
+ It's important to make sure the SHA's are from the original repositories and not forks.
+
+ For reference:
+
+ https://github.com/msys2/setup-msys2/releases/tag/v2.20.1
+ https://github.com/msys2/setup-msys2/commit/27b3aa77f672cb6b3054121cfd80c3d22ceebb1d
+
+ https://github.com/actions/checkout/releases/tag/v4.1.0
+ https://github.com/actions/checkout/commit/8ade135a41bc03ea155e62e844d188df1ea18608
+
+ https://github.com/actions/upload-artifact/releases/tag/v3.1.3
+ https://github.com/actions/upload-artifact/commit/a8a3f3ad30e3422c9c7b888a15615d19a852ae32
+
+ Signed-off-by: Gabriela Gutierrez <gabigutierrez@google.com>
+
+ .github/workflows/windows-ci.yml | 6 +++---
+ 1 file changed, 3 insertions(+), 3 deletions(-)
+
+commit f28cc9bd481ce493da11f98c18526d324211599a
+Author: Gabriela Gutierrez <gabigutierrez@google.com>
+Date: 2023-09-26 14:35:08 +0000
+
+ CI: Bump and ref actions by commit SHA in ci.yml
+
+ Referencing actions by commit SHA in GitHub workflows guarantees you are using an immutable version. Actions referenced by tags and branches are more vulnerable to attacks, such as the tag being moved to a malicious commit or a malicious commit being pushed to the branch.
+
+ It's important to make sure the SHA's are from the original repositories and not forks.
+
+ For reference:
+
+ https://github.com/actions/checkout/releases/tag/v4.1.0
+ https://github.com/actions/checkout/commit/8ade135a41bc03ea155e62e844d188df1ea18608
+
+ https://github.com/actions/upload-artifact/releases/tag/v3.1.3
+ https://github.com/actions/upload-artifact/commit/a8a3f3ad30e3422c9c7b888a15615d19a852ae32
+
+ Signed-off-by: Gabriela Gutierrez <gabigutierrez@google.com>
+
+ .github/workflows/ci.yml | 4 ++--
+ 1 file changed, 2 insertions(+), 2 deletions(-)
+
+commit f74f1740067b75042497edbfa6ea457ff75484b9
Author: Jia Tan <jiat0218@gmail.com>
Date: 2023-10-12 20:12:18 +0800
@@ -320,7 +4417,7 @@ Date: 2023-10-12 20:12:18 +0800
m4/visibility.m4 | 9 +++++++--
1 file changed, 7 insertions(+), 2 deletions(-)
-commit 1824a6007cb1c8d5d7abcc7bf649148bc06fa72c
+commit 5c4bca521e6fb435898a0012b3276eee70a6dadf
Author: Lasse Collin <lasse.collin@tukaani.org>
Date: 2023-10-06 19:36:35 +0300
@@ -329,7 +4426,49 @@ Date: 2023-10-06 19:36:35 +0300
THANKS | 1 +
1 file changed, 1 insertion(+)
-commit 8fdc71a27d07b10a3da52432432e080b6d577642
+commit d91cb6e884c73d0b05d7e7d68ad4e6eb29f4b44b
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2023-10-06 18:55:57 +0300
+
+ CMake/Windows: Fix when the windres workaround is applied.
+
+ CMake doesn't set WIN32 on CYGWIN but the workaround is
+ probably needed on Cygwin too. Same for MSYS and MSYS2.
+
+ The workaround must not be used with Clang that is acting in
+ MSVC mode. This fixes it by checking for the known environments
+ that need the workaround instead of using "NOT MSVC".
+
+ Thanks to Martin Storsjö.
+ https://github.com/tukaani-project/xz/commit/0570308ddd9c0e39e85597ebc0e31d4fc81d436f#commitcomment-129098431
+
+ CMakeLists.txt | 6 +++---
+ 1 file changed, 3 insertions(+), 3 deletions(-)
+
+commit 01e34aa1171b04f8b28960b1cc6135a903e0c13d
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2023-09-29 22:11:54 +0800
+
+ CI: Disable CLANG64 MSYS2 environment until bug is resolved.
+
+ lld 17.0.1 searches for libraries to link first in the toolchain
+ directories before the local directory when building. The is a problem
+ for us because liblzma.a is installed in MSYS2 CLANG64 by default and
+ xz.exe will thus use the installed library instead of the one being
+ built.
+
+ This causes tests to fail when they are expecting features to be
+ disabled. More importantly, it will compile xz.exe with an incorrect
+ liblzma and could cause unexpected behavior by being unable to update
+ liblzma code in static builds. The CLANG64 environment can be tested
+ again once this is fixed.
+
+ Link to bug: https://github.com/llvm/llvm-project/issues/67779.
+
+ .github/workflows/windows-ci.yml | 8 +++++---
+ 1 file changed, 5 insertions(+), 3 deletions(-)
+
+commit 30d0c35327f3639cb11224872aa58fdbf0b1526e
Author: Jia Tan <jiat0218@gmail.com>
Date: 2023-09-29 20:14:39 +0800
@@ -343,7 +4482,19 @@ Date: 2023-09-29 20:14:39 +0800
CMakeLists.txt | 6 +++---
1 file changed, 3 insertions(+), 3 deletions(-)
-commit 38171492ded6426ddf53d0c200fa8c93fcd02a60
+commit 506d03127a8565442b028ec991e1578124fd3025
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2023-09-29 19:58:44 +0800
+
+ CMake: Specify LINKER_LANGUAGE for libgnu target to fix Ninja Generator.
+
+ CMake is unable to guess the linker language for just a header file so
+ it must be explicitly set.
+
+ CMakeLists.txt | 6 ++++++
+ 1 file changed, 6 insertions(+)
+
+commit 0570308ddd9c0e39e85597ebc0e31d4fc81d436f
Author: Lasse Collin <lasse.collin@tukaani.org>
Date: 2023-09-27 19:54:35 +0300
@@ -355,32 +4506,46 @@ Date: 2023-09-27 19:54:35 +0300
LLVM 16.0.6 has the old behavior and there likely won't be more
16.x releases. So we can simply check for >= 17.0.0.
- The workaround must not be used with Clang that is acting in
- MSVC mode. This checks for the known environments that need
- the workaround instead of using "NOT MSVC".
-
See also:
https://github.com/llvm/llvm-project/commit/2bcc0fdc58a220cb9921b47ec8a32c85f2511a47
CMakeLists.txt | 26 ++++++++++++++------------
1 file changed, 14 insertions(+), 12 deletions(-)
-commit 1bce6fe48334b5df33d0487a9cbe41950122230e
+commit 5a9af95f85a7e5d4f9c10cb8cf737651a921f1d1
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2023-09-26 21:47:13 +0300
+
+ liblzma: Update a comment.
+
+ The C standards don't allow an empty translation unit which can be
+ avoided by declaring something, without exporting any symbols.
+
+ When I committed f644473a211394447824ea00518d0a214ff3f7f2 I had
+ a feeling that some specific toolchain somewhere didn't like
+ empty object files (assembler or maybe "ar" complained) but
+ I cannot find anything to confirm this now. Quite likely I
+ remembered nonsense. I leave this here as a note to my future self. :-)
+
+ src/liblzma/check/crc64_table.c | 3 +--
+ 1 file changed, 1 insertion(+), 2 deletions(-)
+
+commit 8ebaf3f665ddc7e4f19c613005050dde5ccbe499
Author: Jia Tan <jiat0218@gmail.com>
Date: 2023-09-27 00:02:11 +0800
liblzma: Avoid compiler warning without creating extra symbol.
When the generic fast crc64 method is used, then we omit
- lzma_crc64_table[][].
-
- The C standards don't allow an empty translation unit which can be
- avoided by declaring something, without exporting any symbols.
+ lzma_crc64_table[][]. Similar to
+ d9166b52cf3458a4da3eb92224837ca8fc208d79, we can avoid compiler warnings
+ with -Wempty-translation-unit (Clang) or -pedantic (GCC) by creating a
+ never used typedef instead of an extra symbol.
- src/liblzma/check/crc64_table.c | 6 ++----
- 1 file changed, 2 insertions(+), 4 deletions(-)
+ src/liblzma/check/crc64_table.c | 3 +--
+ 1 file changed, 1 insertion(+), 2 deletions(-)
-commit dce95a593e6cd9779110aa1e314abd8b35c75f6b
+commit 092d21db2e5eea19fe079264ce48c178989c7606
Author: Lasse Collin <lasse.collin@tukaani.org>
Date: 2023-09-26 17:24:15 +0300
@@ -389,7 +4554,29 @@ Date: 2023-09-26 17:24:15 +0300
configure.ac | 10 ++++++++--
1 file changed, 8 insertions(+), 2 deletions(-)
-commit f3c32762ae309afa2fe330e7fb397acfdedc4d37
+commit a37a2763383e6c204fe878e1416dd35e7711d3a9
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2023-09-26 15:00:43 +0300
+
+ Build: Fix __attribute__((ifunc(...))) detection with clang -Wall.
+
+ Now if user-supplied CFLAGS contains -Wall -Wextra -Wpedantic
+ the two checks that need -Werror will still work.
+
+ At CMake side there is add_compile_options(-Wall -Wextra)
+ but it didn't affect the -Werror tests. So with both Autotools
+ and CMake only user-supplied CFLAGS could make the checks fail
+ when they shouldn't.
+
+ This is not a full fix as things like -Wunused-macros in
+ user-supplied CFLAGS will still cause problems with both
+ GCC and Clang.
+
+ CMakeLists.txt | 8 ++++++++
+ configure.ac | 8 ++++++++
+ 2 files changed, 16 insertions(+)
+
+commit 9c42f936939b813f25d0ff4e99c3eb9c2d17a0d2
Author: Lasse Collin <lasse.collin@tukaani.org>
Date: 2023-09-26 13:51:31 +0300
@@ -400,14 +4587,14 @@ Date: 2023-09-26 13:51:31 +0300
configure.ac | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)
-commit 7dd57f2f2c8fde93fa42b4dbf6d9860717723b41
+commit 9f1444a8a5c0e724b2c7ef83424f642f07a95982
Author: Lasse Collin <lasse.collin@tukaani.org>
Date: 2023-09-26 13:14:37 +0300
- Build: Silence Autoconf warning.
+ Build: Silence two Autoconf warnings.
- There was a use of AC_COMPILE_IFELSE that didn't use
- AC_LANG_SOURCE and Autoconf warned about this. The omission
+ There were two uses of AC_COMPILE_IFELSE that didn't use
+ AC_LANG_SOURCE and Autoconf warned about these. The omission
had been intentional but it turned out that this didn't do
what I thought it would.
@@ -431,16 +4618,26 @@ Date: 2023-09-26 13:14:37 +0300
these two tests because these tests must use -Werror.
CC=clang CFLAGS=-Weverything is the most extreme example.
It enables -Wreserved-macro-identifier which warns about
+ #define __EXTENSIONS__ 1 because it begins with two underscores.
It's possible to write a test file that passes -Weverything but
it becomes impossible when Autoconf inserts confdefs.h.
So this commit adds AC_LANG_SOURCE to silence Autoconf warnings.
A different solution is needed for -Werror tests.
- configure.ac | 5 ++---
- 1 file changed, 2 insertions(+), 3 deletions(-)
+ configure.ac | 9 ++++-----
+ 1 file changed, 4 insertions(+), 5 deletions(-)
+
+commit 519e47c2818acde571fadc79551294527fe6cc22
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2023-09-26 01:17:11 +0800
+
+ CMake: Remove accidental extra newline.
+
+ CMakeLists.txt | 1 -
+ 1 file changed, 1 deletion(-)
-commit edec253e418562f3164a01ecc8805295fa022efa
+commit bbb42412da6a02705ba3e668e90840c2683e4e67
Author: Jia Tan <jiat0218@gmail.com>
Date: 2023-09-26 00:47:26 +0800
@@ -452,7 +4649,7 @@ Date: 2023-09-26 00:47:26 +0800
tests/Makefile.am | 7 +------
1 file changed, 1 insertion(+), 6 deletions(-)
-commit 46cb133ce7360496eecca1255b364c05f0205855
+commit d265f6b75691c6c8fa876eb5320c3ff5aed17dfa
Author: Jia Tan <jiat0218@gmail.com>
Date: 2023-09-26 00:43:43 +0800
@@ -463,7 +4660,233 @@ Date: 2023-09-26 00:43:43 +0800
CMakeLists.txt | 1 -
1 file changed, 1 deletion(-)
-commit 4ae13cfe0dedb8ddc3cf9ded8cd1ac09361b3bd1
+commit 9fb5de41f2fb654ca952d4bda15cf3777c2b720f
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2023-09-24 22:10:41 +0800
+
+ Scripts: Change quoting style from `...' to '...'.
+
+ src/scripts/xzdiff.in | 2 +-
+ src/scripts/xzgrep.in | 2 +-
+ 2 files changed, 2 insertions(+), 2 deletions(-)
+
+commit eaebdef4d4de3c088b0905f42626b74e0d23abf3
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2023-09-24 22:10:18 +0800
+
+ xz: Change quoting style from `...' to '...'.
+
+ src/xz/args.c | 6 +++---
+ src/xz/file_io.c | 2 +-
+ src/xz/main.c | 4 ++--
+ src/xz/message.c | 14 +++++++-------
+ src/xz/options.c | 2 +-
+ src/xz/suffix.c | 2 +-
+ src/xz/util.c | 6 +++---
+ 7 files changed, 18 insertions(+), 18 deletions(-)
+
+commit f6667702bf075a05fbe336dbf3576ad1a82ec645
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2023-09-24 22:09:47 +0800
+
+ liblzma: Change quoting style from `...' to '...'.
+
+ This was done for both internal and API headers.
+
+ src/liblzma/api/lzma/base.h | 18 +++++++++---------
+ src/liblzma/api/lzma/container.h | 10 +++++-----
+ src/liblzma/api/lzma/filter.h | 6 +++---
+ src/liblzma/api/lzma/index.h | 8 ++++----
+ src/liblzma/api/lzma/lzma12.h | 2 +-
+ src/liblzma/lz/lz_encoder.h | 2 +-
+ src/liblzma/rangecoder/range_decoder.h | 2 +-
+ 7 files changed, 24 insertions(+), 24 deletions(-)
+
+commit be012b8097a4eaee335b51357d6befa745f753ce
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2023-09-24 22:09:16 +0800
+
+ Build: Change quoting style from `...' to '...'.
+
+ configure.ac | 18 +++++++++---------
+ dos/config.h | 6 +++---
+ m4/getopt.m4 | 2 +-
+ m4/tuklib_progname.m4 | 2 +-
+ windows/build.bash | 2 +-
+ 5 files changed, 15 insertions(+), 15 deletions(-)
+
+commit ce162db07f03495bd333696e66883c8f36abdc1e
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2023-09-24 22:05:02 +0800
+
+ Docs: Change quoting style from `...' to '...'.
+
+ These days the ` and ' do not look symmetric. This quoting style has
+ been changed in various apps over the years including the GNU tools.
+
+ INSTALL | 6 +++---
+ doc/examples/01_compress_easy.c | 2 +-
+ doc/examples/11_file_info.c | 16 ++++++++--------
+ 3 files changed, 12 insertions(+), 12 deletions(-)
+
+commit db17656721e43939bfa4ec13506e7c76f4b86da6
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2023-09-24 21:25:01 +0800
+
+ lib: Silence -Wsign-conversion in getopt.c.
+
+ lib/getopt.c | 6 +++---
+ 1 file changed, 3 insertions(+), 3 deletions(-)
+
+commit a6234f677d66888f435010bc0b67de6a32fefcf6
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2023-09-24 20:48:52 +0800
+
+ Build: Update getopt.m4 from Gnulib.
+
+ This file was modified from upstream since we do not need to replace
+ getopt() and can avoid complexity and feature tests.
+
+ m4/getopt.m4 | 79 ++++++++++++++++++++++++++++++------------------------------
+ 1 file changed, 39 insertions(+), 40 deletions(-)
+
+commit 84808b68f1075e8603a8ef95d361a61fdc6a5b10
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2023-09-26 00:09:53 +0800
+
+ CMake: Add /lib to include path.
+
+ CMakeLists.txt | 5 +++++
+ 1 file changed, 5 insertions(+)
+
+commit 01804a0b4b64e0f33568e947e0579263808c59d3
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2023-09-24 20:36:34 +0800
+
+ CMake: Update libgnu target with new header files.
+
+ CMakeLists.txt | 5 +++++
+ 1 file changed, 5 insertions(+)
+
+commit d34558388fe1d8929f6478d61dc322eb4f2900af
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2023-09-23 00:47:52 +0800
+
+ lib: Update Makefile.am for new header files.
+
+ lib/Makefile.am | 12 +++++++++++-
+ 1 file changed, 11 insertions(+), 1 deletion(-)
+
+commit 52bf644bdf536e20fcc743b712cede135e05eec5
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2023-09-24 20:34:03 +0800
+
+ lib: Update getopt1.c from Gnulib.
+
+ The only difference was maintaining the conditional inclusion for
+ config.h.
+
+ lib/getopt1.c | 56 ++++++++++++++++++++++----------------------------------
+ 1 file changed, 22 insertions(+), 34 deletions(-)
+
+commit 7e884c00d0093c38339f17fb1d280eec493f42ca
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2023-09-23 03:27:00 +0800
+
+ lib: Update getopt.in.h from Gnulib with modifications.
+
+ We can still avoid modifying the contents of this file during
+ configuration to simplify the build systems. Gnulib added replacements
+ for inclusions guards for Cygwin. Cygwin should not need getopt_long
+ replacement so this feature can be omitted.
+
+ <unistd.h> is conditionally included to avoid MSVC since it is not
+ available.
+
+ The definition for _GL_ARG_NONNULL was also copied into this file from
+ Gnulib since this stage is usually done during gnulib-tool.
+
+ lib/getopt.in.h | 228 +++++++-------------------------------------------------
+ 1 file changed, 29 insertions(+), 199 deletions(-)
+
+commit cff05f82066ca3ce9425dafdb086325a8eef8de3
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2023-09-23 00:31:55 +0800
+
+ lib: Update getopt_int.h from Gnulib.
+
+ lib/getopt_int.h | 109 ++++++++++++++++++++++++-------------------------------
+ 1 file changed, 48 insertions(+), 61 deletions(-)
+
+commit 04bd86a4b010d43c6a016a3857ecb38dc1d5b024
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2023-09-23 00:27:23 +0800
+
+ lib: Update getopt.c from Gnulib with modifications.
+
+ The code maintains the prior modifications of conditionally including
+ config.h and disabling NLS support.
+
+ _GL_UNUSED is repalced with the simple cast to void trick. _GL_UNUSED
+ is only used for these two parameters so its simpler than having to
+ define it.
+
+ lib/getopt.c | 1134 +++++++++++++++++++---------------------------------------
+ 1 file changed, 377 insertions(+), 757 deletions(-)
+
+commit 56b42be7287844db20b3a3bc1372c6ae8c040d63
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2023-09-23 00:18:56 +0800
+
+ lib: Add getopt-cdefs.h for getopt_long update.
+
+ This was modified slightly from Gnulib. In Gnulib, it expects the
+ @HAVE_SYS_CDEFS_H@ to be replaced. Instead, we can set HAVE_SYS_CDEFS_H
+ on systems that have it and avoid copying another file into the build
+ directory. Since we are not using gnulib-tool, copying extra files
+ requires extra build system updates (and special handling with CMake) so
+ we should avoid when possible.
+
+ lib/getopt-cdefs.h | 70 ++++++++++++++++++++++++++++++++++++++++++++++++++++++
+ 1 file changed, 70 insertions(+)
+
+commit 9834e591a4cf9dc2f49e42e26bf28d1d247bc196
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2023-09-23 00:15:25 +0800
+
+ lib: Copy new header files from Gnulib without modification.
+
+ The getopt related files have changed from Gnulib by splitting up
+ getopt.in.h into more modular header files. We could have kept
+ everything in just getopt.in.h, but this will help us continue to update
+ in the future.
+
+ lib/getopt-core.h | 96 +++++++++++++++++++++++++++++++++++++++++++++++++++
+ lib/getopt-ext.h | 77 +++++++++++++++++++++++++++++++++++++++++
+ lib/getopt-pfx-core.h | 66 +++++++++++++++++++++++++++++++++++
+ lib/getopt-pfx-ext.h | 70 +++++++++++++++++++++++++++++++++++++
+ 4 files changed, 309 insertions(+)
+
+commit 5b7a6f06e93d99d6635a740fd2e12fab66096c93
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2023-09-22 21:16:52 +0300
+
+ Windows: Update the version requirement comments from Win95 to W2k.
+
+ windows/README-Windows.txt | 10 ++++------
+ windows/build.bash | 6 +++---
+ 2 files changed, 7 insertions(+), 9 deletions(-)
+
+commit e582f8e0fee46e7cd967f42f465d6bb608b73bc1
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2023-09-22 21:12:54 +0300
+
+ tuklib_physmem: Comment out support for Windows versions older than 2000.
+
+ src/common/tuklib_physmem.c | 20 +++++++++-----------
+ 1 file changed, 9 insertions(+), 11 deletions(-)
+
+commit 7d73d1f0e08f96c4ab7aac91b958e37a3dadf07a
Author: Lasse Collin <lasse.collin@tukaani.org>
Date: 2023-09-24 16:32:32 +0300
@@ -472,7 +4895,7 @@ Date: 2023-09-24 16:32:32 +0300
src/common/sysdefs.h | 10 +++++++++-
1 file changed, 9 insertions(+), 1 deletion(-)
-commit 660c8c29e57d30dbd5009ef1f0ec1bbe195ccef6
+commit 2a9929af0ab7e6c0ab725565034afe3293e51d71
Author: Lasse Collin <lasse.collin@tukaani.org>
Date: 2023-09-22 02:33:29 +0300
@@ -502,7 +4925,7 @@ Date: 2023-09-22 02:33:29 +0300
src/xz/file_io.c | 35 ++++++++++++++++++++++++++++-------
1 file changed, 28 insertions(+), 7 deletions(-)
-commit b7ce6e80786fc0c08ed129e8ee262ea96a5473a1
+commit 01311b81f03cce1c0ce847a3d556f84dbd439343
Author: Lasse Collin <lasse.collin@tukaani.org>
Date: 2023-09-21 20:42:52 +0300
@@ -511,7 +4934,7 @@ Date: 2023-09-21 20:42:52 +0300
CMakeLists.txt | 6 ++++--
1 file changed, 4 insertions(+), 2 deletions(-)
-commit 1595f454d5c8257c668cccd6a86dd68175d5c430
+commit 152d0771ddd0cffcac9042ad1a66f110d228eee2
Author: Lasse Collin <lasse.collin@tukaani.org>
Date: 2023-09-21 20:36:31 +0300
@@ -520,7 +4943,86 @@ Date: 2023-09-21 20:36:31 +0300
CMakeLists.txt | 1 +
1 file changed, 1 insertion(+)
-commit 5be6275f19784cdd5a954f0188045c8ff4934d54
+commit 6df988cceffaa3100b428ed816fad334935b27bf
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2023-09-12 23:53:25 +0300
+
+ MSVC: Remove Visual Studio project files and update INSTALL-MSVC.txt.
+
+ CMake is now the preferred build file generator when building
+ with MSVC.
+
+ windows/INSTALL-MSVC.txt | 37 ++--
+ windows/vs2013/config.h | 157 ---------------
+ windows/vs2013/liblzma.vcxproj | 363 ---------------------------------
+ windows/vs2013/liblzma_dll.vcxproj | 398 ------------------------------------
+ windows/vs2013/xz_win.sln | 48 -----
+ windows/vs2017/config.h | 157 ---------------
+ windows/vs2017/liblzma.vcxproj | 363 ---------------------------------
+ windows/vs2017/liblzma_dll.vcxproj | 398 ------------------------------------
+ windows/vs2017/xz_win.sln | 48 -----
+ windows/vs2019/config.h | 157 ---------------
+ windows/vs2019/liblzma.vcxproj | 364 ---------------------------------
+ windows/vs2019/liblzma_dll.vcxproj | 399 -------------------------------------
+ windows/vs2019/xz_win.sln | 51 -----
+ 13 files changed, 12 insertions(+), 2928 deletions(-)
+
+commit edd563daf0da1d00018684614803c77ab62efcd6
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2023-09-21 19:17:40 +0300
+
+ CMake: Require VS2015 or later for building xzdec.
+
+ xzdec might build with VS2013 but it hasn't been tested.
+ It was never supported before and VS2013 is old anyway
+ so for simplicity only liblzma is supported with VS2013.
+
+ CMakeLists.txt | 2 +-
+ 1 file changed, 1 insertion(+), 1 deletion(-)
+
+commit daea64d158a7151ca6c255a0e4554c6d521cd589
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2023-09-12 23:43:49 +0300
+
+ CMake: Allow building xz with Visual Studio 2015 and later.
+
+ Building the command line tools xz and xzdec with the combination
+ of CMake + Visual Studio 2015/2017/2019/2022 works now.
+
+ VS2013 update 2 should still be able to build liblzma.
+ VS2013 cannot build the xz command line tool because xz
+ needs snprintf() that roughly conforms to C99.
+ VS2013 is old and no extra code will be added to support it.
+
+ Thanks to Kelvin Lee and Jia Tan for testing.
+
+ CMakeLists.txt | 2 +-
+ 1 file changed, 1 insertion(+), 1 deletion(-)
+
+commit 8c2d197c940d246849b2ec48109bb22e54036927
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2023-09-12 23:34:31 +0300
+
+ MSVC: #define inline and restrict only when needed.
+
+ This also drops the check for _WIN32 as that shouldn't be needed.
+
+ src/common/sysdefs.h | 13 ++++++++-----
+ 1 file changed, 8 insertions(+), 5 deletions(-)
+
+commit af66cd585902045e5689a0418103ec81f19f1d0a
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2023-09-12 22:16:56 +0300
+
+ CMake: Add support for replacement getopt_long (lib/getopt*).
+
+ Thanks to Jia Tan for the initial work. I added the libgnu target
+ and made a few related minor edits.
+
+ CMakeLists.txt | 54 +++++++++++++++++++++++++++++++++++++++++++++++-------
+ 1 file changed, 47 insertions(+), 7 deletions(-)
+
+commit e3288fdb45c580cb849f6799cf419c4922004ae5
Author: Lasse Collin <lasse.collin@tukaani.org>
Date: 2023-09-12 21:12:34 +0300
@@ -535,7 +5037,23 @@ Date: 2023-09-12 21:12:34 +0300
CMakeLists.txt | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)
-commit e515643d7524851d1eb7dab73453e26d8521324c
+commit aff1b479c7b168652bd20305ceed4317d5db6661
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2023-09-12 20:55:10 +0300
+
+ lib/getopt*.c: Include <config.h> only HAVE_CONFIG_H is defined.
+
+ The CMake-based build doesn't use config.h.
+
+ Up-to-date getopt_long in Gnulib is LGPLv2 so at some
+ point it could be included in XZ Utils too but for now
+ this commit is enough to make CMake-based build possible.
+
+ lib/getopt.c | 4 +++-
+ lib/getopt1.c | 4 +++-
+ 2 files changed, 6 insertions(+), 2 deletions(-)
+
+commit aa0cd585d2ed1455d35732798e0d90e3520e8ba5
Author: Lasse Collin <lasse.collin@tukaani.org>
Date: 2023-09-08 19:08:57 +0300
@@ -544,7 +5062,7 @@ Date: 2023-09-08 19:08:57 +0300
doxygen/Doxyfile | 7 +++++--
1 file changed, 5 insertions(+), 2 deletions(-)
-commit e3478ae4f36cd06522a2fef023860893f068434d
+commit ee7709bae53637e1765ce142ef102914f1423cb5
Author: Lasse Collin <lasse.collin@tukaani.org>
Date: 2023-09-11 18:47:26 +0300
@@ -558,7 +5076,7 @@ Date: 2023-09-11 18:47:26 +0300
src/liblzma/common/memcmplen.h | 3 ++-
3 files changed, 10 insertions(+), 7 deletions(-)
-commit b71b8922ef3971e5ccffd1e213888d44abe21d11
+commit 217958d88713b5dc73d366d24dd64b2b311b86fe
Author: Lasse Collin <lasse.collin@tukaani.org>
Date: 2023-09-11 19:03:35 +0300
@@ -582,7 +5100,7 @@ Date: 2023-09-11 19:03:35 +0300
src/xzdec/xzdec.c | 9 ++++++---
7 files changed, 37 insertions(+), 25 deletions(-)
-commit 359e5c6cb128dab64ea6070d21d1c240f96cea6b
+commit 18a66fbac031c98f9c2077fc88846e4d07849197
Author: Lasse Collin <lasse.collin@tukaani.org>
Date: 2023-09-11 18:53:31 +0300
@@ -607,7 +5125,121 @@ Date: 2023-09-11 18:53:31 +0300
src/xz/util.h | 4 ++--
3 files changed, 6 insertions(+), 6 deletions(-)
-commit 589b4cba22fccb1dbc919df5d134aefb2b5a6b01
+commit 74b0e900c92d5b222b36f474f1efa431f8e262f7
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2023-09-08 18:41:25 +0300
+
+ Build: Omit -Wc99-c11-compat since it warns about _Noreturn.
+
+ configure.ac | 1 -
+ 1 file changed, 1 deletion(-)
+
+commit 90c94dddfd57b7d744bfad64c54e10d15778144b
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2023-09-08 18:19:26 +0300
+
+ tuklib: Update tuklib_attr_noreturn for C11/C17 and C23.
+
+ This makes no difference for GCC or Clang as they support
+ GNU C's __attribute__((__noreturn__)) but this helps with MSVC:
+
+ - VS 2019 version 16.7 and later support _Noreturn if the
+ options /std:c11 or /std:c17 are used. This gets handled
+ with the check for __STDC_VERSION__ >= 201112.
+
+ - When MSVC isn't in C11/C17 mode, __declspec(noreturn) is used.
+
+ C23 will deprecate _Noreturn (and <stdnoreturn.h>)
+ for [[noreturn]]. This commit anticipates that but
+ the final __STDC_VERSION__ value isn't known yet.
+
+ src/common/tuklib_common.h | 22 +++++++++++++++++++++-
+ src/common/tuklib_exit.h | 4 ++--
+ 2 files changed, 23 insertions(+), 3 deletions(-)
+
+commit 189f72581329ab281ad6af37f60135910cb1b146
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2023-09-11 17:22:44 +0300
+
+ Update THANKS.
+
+ THANKS | 1 +
+ 1 file changed, 1 insertion(+)
+
+commit 79334e7f20f2bf9e0de095835b48868f1238f584
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2023-09-05 22:42:10 +0300
+
+ MSVC: xz: Make file_io.c and file_io.h compatible with MSVC.
+
+ Thanks to Kelvin Lee for the original patches
+ and testing the modifications I made.
+
+ src/xz/file_io.c | 26 ++++++++++++++++++++++++++
+ src/xz/file_io.h | 10 ++++++++++
+ 2 files changed, 36 insertions(+)
+
+commit c660b8d78b7bda43b12b285550d8c70e8ccec698
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2023-09-05 21:33:35 +0300
+
+ MSVC: xz: Use GetTickCount64() to implement mytime_now().
+
+ It's available since Windows Vista.
+
+ src/xz/mytime.c | 11 +++++++++--
+ 1 file changed, 9 insertions(+), 2 deletions(-)
+
+commit 5c6f892d411670e3060f4bc309402617a209e57c
+Author: Kelvin Lee <kiyolee@gmail.com>
+Date: 2023-09-05 15:05:09 +0300
+
+ MSVC: xz: Use _stricmp() instead of strcasecmp() in suffix.c.
+
+ src/xz/suffix.c | 10 ++++++++--
+ 1 file changed, 8 insertions(+), 2 deletions(-)
+
+commit e241051f50044259d174e8b4633dd9a1c4478408
+Author: Kelvin Lee <kiyolee@gmail.com>
+Date: 2023-09-05 15:01:10 +0300
+
+ MSVC: xz: Use _isatty() from <io.h> to implement isatty().
+
+ src/xz/message.c | 5 +++++
+ src/xz/util.c | 5 +++++
+ 2 files changed, 10 insertions(+)
+
+commit d14bba8fc2be02a9fed8c9bcaaf61103451755f8
+Author: Kelvin Lee <kiyolee@gmail.com>
+Date: 2023-09-05 15:10:31 +0300
+
+ MSVC: xz: Use _fileno() instead of fileno().
+
+ src/xz/private.h | 4 ++++
+ 1 file changed, 4 insertions(+)
+
+commit c4edd367678e6a38c42b149856159bf417da7fe1
+Author: Kelvin Lee <kiyolee@gmail.com>
+Date: 2023-09-05 15:00:07 +0300
+
+ MSVC: xzdec: Use _fileno and _setmode.
+
+ src/xzdec/xzdec.c | 4 ++++
+ 1 file changed, 4 insertions(+)
+
+commit cfd1054b9b539ee92524901e95d7bb5a1fe670a0
+Author: Kelvin Lee <kiyolee@gmail.com>
+Date: 2023-09-05 14:37:50 +0300
+
+ MSVC: Don't #include <unistd.h>.
+
+ lib/getopt.c | 4 +++-
+ lib/getopt.in.h | 4 +++-
+ src/xz/private.h | 5 ++++-
+ src/xzdec/xzdec.c | 5 ++++-
+ 4 files changed, 14 insertions(+), 4 deletions(-)
+
+commit adef92f23563a2cc088b31ddee9040ecc96bc996
Author: Lasse Collin <lasse.collin@tukaani.org>
Date: 2023-09-19 14:03:45 +0300
@@ -616,7 +5248,19 @@ Date: 2023-09-19 14:03:45 +0300
THANKS | 1 +
1 file changed, 1 insertion(+)
-commit 43728ed2267e921fbdfa699ee1e91b105ab0e98b
+commit 953e775941a25bfcfa353f802b13e66acb1edf2c
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2023-09-14 21:13:23 +0800
+
+ CI: Enable CLMUL in address sanitization test.
+
+ The crc64_clmul() function should be ignored by the address sanitizer
+ now so these builds should still pass.
+
+ .github/workflows/ci.yml | 12 ++++--------
+ 1 file changed, 4 insertions(+), 8 deletions(-)
+
+commit f167e79bc98f3f56af2e767b83aa81c2d2b9ed77
Author: Lasse Collin <lasse.collin@tukaani.org>
Date: 2023-09-14 16:35:46 +0300
@@ -625,7 +5269,7 @@ Date: 2023-09-14 16:35:46 +0300
THANKS | 1 +
1 file changed, 1 insertion(+)
-commit caf00e0988ba47842cfd93dfbb17f7d30120d6e7
+commit 4f44ef86758a41a8ec814096f4cb6ee6de04c82e
Author: Lasse Collin <lasse.collin@tukaani.org>
Date: 2023-09-14 16:34:07 +0300
@@ -637,7 +5281,7 @@ Date: 2023-09-14 16:34:07 +0300
src/liblzma/check/crc64_fast.c | 8 ++++++++
1 file changed, 8 insertions(+)
-commit a70e96d2da761b8b3a77bf14e08002d871e5950b
+commit 7379bb3eed428c0ae734d0cc4a1fd04359d53f08
Author: Jia Tan <jiat0218@gmail.com>
Date: 2023-09-12 22:36:12 +0800
@@ -651,7 +5295,7 @@ Date: 2023-09-12 22:36:12 +0800
CMakeLists.txt | 18 ++++++++++--------
1 file changed, 10 insertions(+), 8 deletions(-)
-commit d5275d83bd2a9701c5feb8666785007c074b1359
+commit 5d691fe58286b92d704c0dc5cd0c4df22881c6c6
Author: Jia Tan <jiat0218@gmail.com>
Date: 2023-09-12 22:34:06 +0800
@@ -663,7 +5307,7 @@ Date: 2023-09-12 22:34:06 +0800
CMakeLists.txt | 8 +++-----
1 file changed, 3 insertions(+), 5 deletions(-)
-commit 1f6e7c68fbdeeaa9482fc77de090be63d90912fd
+commit eccf12866527b8d24c7d7f92f755142be8ef9b11
Author: Lasse Collin <lasse.collin@tukaani.org>
Date: 2023-08-31 19:50:05 +0300
@@ -678,7 +5322,7 @@ Date: 2023-08-31 19:50:05 +0300
src/xz/util.c | 89 ++++++++++++++++++++++++++++++-----------------------------
1 file changed, 45 insertions(+), 44 deletions(-)
-commit ef71f83973a20cc28a3221f85681922026ea33f5
+commit f7093cd9d130477c234b40aeda613964171f8f21
Author: Lasse Collin <lasse.collin@tukaani.org>
Date: 2023-08-31 18:14:43 +0300
@@ -691,19 +5335,19 @@ Date: 2023-08-31 18:14:43 +0300
src/xz/file_io.h | 4 ++--
2 files changed, 4 insertions(+), 5 deletions(-)
-commit cf8ba7c3a89e37736b926dfbe85dffeff725db47
+commit 74c3449d8b816a724b12ebce7417e00fb597309a
Author: Jia Tan <jiat0218@gmail.com>
Date: 2023-08-28 23:14:45 +0800
Tests: Improve invalid unpadded size check in test_lzma_index_append().
This check was extended to test the code added to fix a failing assert
- in 68bda971bb8b666a009331455fcedb4e18d837a4.
+ in ae5c07b22a6b3766b84f409f1b6b5c100469068a.
tests/test_index.c | 26 +++++++++++++++++++++++---
1 file changed, 23 insertions(+), 3 deletions(-)
-commit 4a4180ce74788e97e90b9aab579bfd7c6dce3f59
+commit 2544274a8b8a27f4ea6c457d2c4c32eb1e4cd336
Author: Jia Tan <jiat0218@gmail.com>
Date: 2023-08-28 21:54:41 +0800
@@ -712,7 +5356,7 @@ Date: 2023-08-28 21:54:41 +0800
tests/test_index.c | 6 +++---
1 file changed, 3 insertions(+), 3 deletions(-)
-commit 4b23b84b89e39a5117e16f66c3b01db4f08ed3e7
+commit 49be29d6380b94e6fb26e511dd2cdbd9afce0f8b
Author: Jia Tan <jiat0218@gmail.com>
Date: 2023-08-28 21:52:54 +0800
@@ -721,7 +5365,7 @@ Date: 2023-08-28 21:52:54 +0800
THANKS | 1 +
1 file changed, 1 insertion(+)
-commit 773f1e8622cb1465df528cb16a749517650acd93
+commit 721e3d9f7a82f59f32795d5fb97e0210d1aa839a
Author: Jia Tan <jiat0218@gmail.com>
Date: 2023-08-28 21:50:16 +0800
@@ -735,7 +5379,7 @@ Date: 2023-08-28 21:50:16 +0800
src/liblzma/common/index.h | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)
-commit 68bda971bb8b666a009331455fcedb4e18d837a4
+commit ae5c07b22a6b3766b84f409f1b6b5c100469068a
Author: Jia Tan <jiat0218@gmail.com>
Date: 2023-08-28 21:31:25 +0800
@@ -775,16 +5419,25 @@ Date: 2023-08-28 21:31:25 +0800
src/liblzma/common/index.c | 6 ++++++
1 file changed, 6 insertions(+)
-commit b41bb79c602481d7ea93d65f5b3e3f08dc54233b
+commit 1057765aaabfe0f1397b8094531846655376ae38
Author: Jia Tan <jiat0218@gmail.com>
Date: 2023-08-28 22:18:29 +0800
Translations: Update the Esperanto translation.
+ po/eo.po | 4 ++--
+ 1 file changed, 2 insertions(+), 2 deletions(-)
+
+commit f2e94d064f305bb8ad77ca70f91d93e55f5cf856
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2023-08-26 20:10:23 +0800
+
+ Translations: Update the Esperanto translation.
+
po/eo.po | 47 +++++++++++++++++++++++++++++------------------
1 file changed, 29 insertions(+), 18 deletions(-)
-commit 6614e6d4bf8e2b5af6eb73930148e0ffc8d2265a
+commit 2b871f4dbffe3801d0da3f89806b5935f758d5f3
Author: Jia Tan <jiat0218@gmail.com>
Date: 2023-08-09 20:55:36 +0800
@@ -796,16 +5449,16 @@ Date: 2023-08-09 20:55:36 +0800
INSTALL | 6 ++++--
1 file changed, 4 insertions(+), 2 deletions(-)
-commit bfb623ad96fa6f1dbc0c560403c4296e3c8e26c9
+commit 356ad5b26b4196f085ce3afa1869154ca81faad8
Author: Jia Tan <jiat0218@gmail.com>
Date: 2023-08-09 20:54:15 +0800
CMake: Conditionally allow win95 threads and --enable-small.
- CMakeLists.txt | 27 +++++++++++++++++++--------
- 1 file changed, 19 insertions(+), 8 deletions(-)
+ CMakeLists.txt | 28 ++++++++++++++++++++--------
+ 1 file changed, 20 insertions(+), 8 deletions(-)
-commit e919ebb29ac9f5270cd7176a39d0d3b4cea875a9
+commit de574404c4c2f87aca049f232c38526e3ce092aa
Author: Jia Tan <jiat0218@gmail.com>
Date: 2023-08-09 20:35:16 +0800
@@ -824,7 +5477,7 @@ Date: 2023-08-09 20:35:16 +0800
configure.ac | 21 +++++++++++++--------
1 file changed, 13 insertions(+), 8 deletions(-)
-commit c0c0cd4a483a672b66a13761583bc4f84d86d501
+commit 6bf33b704cd31dccf25e68480464aa22d3fcad5a
Author: Jamaika1 <lukaszcz18@wp.pl>
Date: 2023-08-08 14:07:59 +0200
@@ -837,7 +5490,22 @@ Date: 2023-08-08 14:07:59 +0200
src/common/mythread.h | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)
-commit d93fbefcc48a8737fdf5678ce66d1c1d605752a0
+commit 80cb961e5380a3878246d41341ff91378ca59e05
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2023-08-04 22:17:11 +0800
+
+ codespell: Add .codespellrc to set default options.
+
+ The .codespellrc allows setting default options to avoid false positive
+ matches, set additional dictionaries, etc. For now, codespell can be
+ used locally before committing doc and comment changes.
+
+ It should help prevent silly errors and fix up commits in the future.
+
+ .codespellrc | 24 ++++++++++++++++++++++++
+ 1 file changed, 24 insertions(+)
+
+commit cd678a6077358935249b64a4a16fe8d17434f9c9
Author: Jia Tan <jiat0218@gmail.com>
Date: 2023-08-03 20:10:21 +0800
@@ -846,7 +5514,7 @@ Date: 2023-08-03 20:10:21 +0800
tests/test_lzip_decoder.c | 36 ++++++++++++++++++++++++------------
1 file changed, 24 insertions(+), 12 deletions(-)
-commit 65981d8e45741fd1502e007609469e1d60312e69
+commit 1cac5ed4fa45c9861d745b02d80575cb2ff01d81
Author: Jia Tan <jiat0218@gmail.com>
Date: 2023-08-03 15:56:20 +0800
@@ -855,7 +5523,7 @@ Date: 2023-08-03 15:56:20 +0800
po/zh_CN.po | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)
-commit a108ed589171d683c34238a87e358b87f69e39a0
+commit 16068f6c30b888cdb873f6285af941d00f95741d
Author: Lasse Collin <lasse.collin@tukaani.org>
Date: 2023-08-02 17:15:12 +0300
@@ -864,17 +5532,7 @@ Date: 2023-08-02 17:15:12 +0300
src/xz/xz.1 | 1 -
1 file changed, 1 deletion(-)
-commit 03c51c5c08fe3579d8bbc8eea8251a1128001330
-Author: Jia Tan <jiat0218@gmail.com>
-Date: 2023-08-02 20:32:20 +0800
-
- Bump version and soname for 5.4.4.
-
- src/liblzma/Makefile.am | 2 +-
- src/liblzma/api/lzma/version.h | 2 +-
- 2 files changed, 2 insertions(+), 2 deletions(-)
-
-commit d7fa3f1b58a77f79b1a4e12452418b5555632e18
+commit 9ae4371b5106189486e850ce777e40f7b6021c0b
Author: Jia Tan <jiat0218@gmail.com>
Date: 2023-08-02 20:30:07 +0800
@@ -883,7 +5541,7 @@ Date: 2023-08-02 20:30:07 +0800
NEWS | 43 +++++++++++++++++++++++++++++++++++++++++++
1 file changed, 43 insertions(+)
-commit 6a1093c0004c42eeaef312456c295671496dd67a
+commit e8c2203b2c76466d8d3387c5212b46151de8e605
Author: Lasse Collin <lasse.collin@tukaani.org>
Date: 2023-08-02 15:19:43 +0300
@@ -896,7 +5554,7 @@ Date: 2023-08-02 15:19:43 +0300
build-aux/manconv.sh | 4 ++--
1 file changed, 2 insertions(+), 2 deletions(-)
-commit f6f9f5651a7e2d89f588981533155ab850e063f7
+commit 9a706167b0d903d92fd134895acb4bc6a5e3e688
Author: Lasse Collin <lasse.collin@tukaani.org>
Date: 2023-08-01 19:10:43 +0300
@@ -905,7 +5563,7 @@ Date: 2023-08-01 19:10:43 +0300
THANKS | 1 +
1 file changed, 1 insertion(+)
-commit 0dd83ba8767dad722e0f0f94e0e4146e290a28cb
+commit 33e25a0f5650754c38bed640deedefe3b4fec5ef
Author: Lasse Collin <lasse.collin@tukaani.org>
Date: 2023-08-01 18:22:24 +0300
@@ -914,7 +5572,7 @@ Date: 2023-08-01 18:22:24 +0300
THANKS | 1 +
1 file changed, 1 insertion(+)
-commit 4170a80785cc69edfc5fdfe498bed5f40db6a7ef
+commit 81db3b889830132334d1f2129bdc93177ac2ca7d
Author: ChanTsune <41658782+ChanTsune@users.noreply.github.com>
Date: 2023-08-01 18:17:17 +0300
@@ -934,7 +5592,19 @@ Date: 2023-08-01 18:17:17 +0300
src/common/mythread.h | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)
-commit 0db6fbe0be1545a4f25fcd6993371155b37bbb26
+commit 71c638c611324e606d324c8189fef8fe79db6991
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2023-08-01 21:58:51 +0800
+
+ Add newline to end of .gitignore.
+
+ Newline was accidentally removed in commit
+ 01cbb7f023ee7fda8ddde04bd17cf7d3c2418706.
+
+ .gitignore | 2 +-
+ 1 file changed, 1 insertion(+), 1 deletion(-)
+
+commit 42df7c7aa1cca385e509eb33c65136e61890f0bf
Author: Dimitri Papadopoulos Orfanos <3234522+DimitriPapadopoulos@users.noreply.github.com>
Date: 2023-07-31 14:02:21 +0200
@@ -960,7 +5630,7 @@ Date: 2023-07-31 14:02:21 +0200
tests/test_vli.c | 2 +-
18 files changed, 29 insertions(+), 29 deletions(-)
-commit 84a3a1f4e4f146b3b5fa73fe708cacb0d9f829f3
+commit 01cbb7f023ee7fda8ddde04bd17cf7d3c2418706
Author: Jia Tan <jiat0218@gmail.com>
Date: 2023-07-26 20:26:23 +0800
@@ -969,7 +5639,7 @@ Date: 2023-07-26 20:26:23 +0800
.gitignore | 4 ++++
1 file changed, 4 insertions(+)
-commit 962b3d41e0c27355ba3052ef7b7d9a887de807e5
+commit f97a1afd564c48ad9cb94682e10972a72e11fa08
Author: Jia Tan <jiat0218@gmail.com>
Date: 2023-07-28 22:03:08 +0800
@@ -987,7 +5657,66 @@ Date: 2023-07-28 22:03:08 +0800
CMakeLists.txt | 82 +++++++++++++++++++++++++++++++++++++++++++++++++++++-----
1 file changed, 75 insertions(+), 7 deletions(-)
-commit 19899340cf74d98304f9f5b726c72e85c7017d72
+commit 7190f4cc7c9ade5b9b3675d0cbfa3b6d6ec9cb4f
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2023-07-28 21:56:48 +0800
+
+ CI: Fix windows-ci dependency installation.
+
+ All of the MSYS2 environments need make, and it does not come with the
+ toolchain package. The toolchain package will install the needed
+ compiler toolchains since without this package CMake cannot properly
+ generate the Makefiles.
+
+ .github/workflows/windows-ci.yml | 6 +++---
+ 1 file changed, 3 insertions(+), 3 deletions(-)
+
+commit a048f472cd9a2245265cb292853cbbcdd4f02001
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2023-07-28 21:54:22 +0800
+
+ CI: Update ci_build.sh CMake to always make Unix Makefiles.
+
+ The default for many of the MSYS2 environments is for CMake to create
+ Ninja build files. This would complicate the build script since we would
+ need a different command to run the tests. Its simpler to always use
+ Unix Makefiles so that "make test" is always a usable target for
+ testing.
+
+ build-aux/ci_build.sh | 4 ++--
+ 1 file changed, 2 insertions(+), 2 deletions(-)
+
+commit 7870396a0ca945473aa0d1d790f4cbef456610bd
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2023-07-25 20:17:23 +0800
+
+ CI: Test CMake builds and test framework with MSYS2.
+
+ .github/workflows/windows-ci.yml | 32 ++++++++++++++++++++------------
+ 1 file changed, 20 insertions(+), 12 deletions(-)
+
+commit 6497d1f8875cb7e3007f714336cc09c06fed235b
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2023-07-25 20:14:53 +0800
+
+ CI: Windows CI rename system matrix variable -> msys2_env.
+
+ Calling the MSYS2 environment "system" was a bit vague and should be
+ more specific.
+
+ .github/workflows/windows-ci.yml | 15 +++++----------
+ 1 file changed, 5 insertions(+), 10 deletions(-)
+
+commit 785e4121d9b2921ad36bd3af1cf61fa20a9265bd
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2023-07-24 23:11:45 +0800
+
+ CI: Add Clang64 MSYS2 environment to Windows CI.
+
+ .github/workflows/windows-ci.yml | 1 +
+ 1 file changed, 1 insertion(+)
+
+commit d9166b52cf3458a4da3eb92224837ca8fc208d79
Author: Jia Tan <jiat0218@gmail.com>
Date: 2023-07-24 21:43:44 +0800
@@ -1002,7 +5731,53 @@ Date: 2023-07-24 21:43:44 +0800
src/liblzma/Makefile.am | 6 +++++-
1 file changed, 5 insertions(+), 1 deletion(-)
-commit ef7fbe83937abd7f55f1637c1d08b559f1d3d6cc
+commit db5019d691f980d622fb56fdcf383af2c3519c98
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2023-07-22 18:37:56 +0800
+
+ Translations: Update the Vietnamese translation.
+
+ po/vi.po | 45 ++++++++++++++++++++++++++++-----------------
+ 1 file changed, 28 insertions(+), 17 deletions(-)
+
+commit f3a055f762ba5b71b746fc2d44a6ababde2c61b5
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2023-07-22 14:55:42 +0800
+
+ CI: Add Windows runner for Autotools builds with MSYS2.
+
+ Only a subset of the tests run by the Linux and MacOS Autotools builds
+ are run. The most interesting tests are the ones that disable threads,
+ encoders, and decoders.
+
+ The Windows runner will only be run manually since these tests will
+ likely take much longer than the Linux and MacOS runners. This runner
+ should be used before merging any large features and before releases.
+
+ Currently the clang64 environment fails to due to a warning and
+ -Werror is enabled for the CI tests. This is still an early version
+ since the CMake build can be done for MSVC and optionally each of the
+ MSYS2 environments. GitHub does not allow manually running the CI tests
+ unless the workflow is checked on the default branch so checking in a
+ minimum version is a good idea.
+
+ Thanks to Arthur S for the original proposing the original patch.
+
+ Closes: https://github.com/tukaani-project/xz/pull/34
+
+ .github/workflows/windows-ci.yml | 119 +++++++++++++++++++++++++++++++++++++++
+ 1 file changed, 119 insertions(+)
+
+commit 556536a3525df9e5ed78b8c7057991cfa9edfac8
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2023-07-21 22:11:01 +0800
+
+ CI: Add argument to ci_build.sh to pass flags to autogen.sh.
+
+ build-aux/ci_build.sh | 9 +++++++--
+ 1 file changed, 7 insertions(+), 2 deletions(-)
+
+commit 39a32d36fc465c4e70f13192eea380e518ba6e8a
Author: Jia Tan <jiat0218@gmail.com>
Date: 2023-07-21 18:05:44 +0800
@@ -1014,7 +5789,7 @@ Date: 2023-07-21 18:05:44 +0800
tests/test_files.sh | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)
-commit e49815ba7aa610b72e8724025eceee23c27e7b23
+commit 194d12724b30fe42789d12a0184f9d412c449347
Author: Jia Tan <jiat0218@gmail.com>
Date: 2023-07-20 22:11:13 +0800
@@ -1023,16 +5798,7 @@ Date: 2023-07-20 22:11:13 +0800
tests/test_compress.sh | 1 +
1 file changed, 1 insertion(+)
-commit db5b57b827c2b084586c51da1b8a3ab0984bdb40
-Author: Jia Tan <jiat0218@gmail.com>
-Date: 2023-07-22 18:37:56 +0800
-
- Translations: Update the Vietnamese translation.
-
- po/vi.po | 45 ++++++++++++++++++++++++++++-----------------
- 1 file changed, 28 insertions(+), 17 deletions(-)
-
-commit e6ba5014081c98cb068253b3e5f9e372dd157f3c
+commit d850365c444368102c69beaddf849ed463c33467
Author: Jia Tan <jiat0218@gmail.com>
Date: 2023-07-20 20:30:05 +0800
@@ -1041,7 +5807,7 @@ Date: 2023-07-20 20:30:05 +0800
po/hr.po | 49 ++++++++++++++++++++++++++++++-------------------
1 file changed, 30 insertions(+), 19 deletions(-)
-commit 82657a1f10a25050a3e9c246c41deb785cccba3a
+commit 24049eb7acf6d42a60f00efe4e7289fe8e1797fe
Author: Jia Tan <jiat0218@gmail.com>
Date: 2023-07-20 20:28:32 +0800
@@ -1050,7 +5816,7 @@ Date: 2023-07-20 20:28:32 +0800
po4a/ko.po | 1255 ++++++++++++++++++++++++++++++------------------------------
1 file changed, 629 insertions(+), 626 deletions(-)
-commit fab35907d13efbe7c457e00a310123335d7bae3e
+commit 4d4a4fa07de6cb9d913fb2f97712fddda2527b49
Author: Jia Tan <jiat0218@gmail.com>
Date: 2023-07-20 20:25:24 +0800
@@ -1059,7 +5825,7 @@ Date: 2023-07-20 20:25:24 +0800
po/ko.po | 45 ++++++++++++++++++++++++++++-----------------
1 file changed, 28 insertions(+), 17 deletions(-)
-commit f530fe1964c34797fa3b775ec5804d68007c1579
+commit 237f06d9c55cf438a7538a598354bcf103f23711
Author: Jia Tan <jiat0218@gmail.com>
Date: 2023-07-20 20:24:05 +0800
@@ -1068,7 +5834,7 @@ Date: 2023-07-20 20:24:05 +0800
po/pl.po | 47 +++++++++++++++++++++++++++++------------------
1 file changed, 29 insertions(+), 18 deletions(-)
-commit 10b3500cc2617aabdbc802a63164ce0a3683ad2b
+commit 80c2c832136656d5ac7a1bca8bc42d95e13d281a
Author: Jia Tan <jiat0218@gmail.com>
Date: 2023-07-20 20:22:23 +0800
@@ -1077,7 +5843,7 @@ Date: 2023-07-20 20:22:23 +0800
po4a/de.po | 1255 ++++++++++++++++++++++++++++++------------------------------
1 file changed, 629 insertions(+), 626 deletions(-)
-commit 3d14e8a34dba176f975326924ae28a3ab5fee165
+commit fdbde14503ca03069d3649aa51926f5f796b89d8
Author: Jia Tan <jiat0218@gmail.com>
Date: 2023-07-20 20:18:44 +0800
@@ -1086,7 +5852,7 @@ Date: 2023-07-20 20:18:44 +0800
po/de.po | 47 +++++++++++++++++++++++++++++------------------
1 file changed, 29 insertions(+), 18 deletions(-)
-commit bdcc180a2da15039c47455c1cafd1ce9aff442e4
+commit 9f3bf5ff5b2b5cf0b252a2bf381238ca49dc4101
Author: Jia Tan <jiat0218@gmail.com>
Date: 2023-07-20 20:17:10 +0800
@@ -1095,7 +5861,7 @@ Date: 2023-07-20 20:17:10 +0800
po/zh_CN.po | 47 +++++++++++++++++++++++++++++------------------
1 file changed, 29 insertions(+), 18 deletions(-)
-commit 844240350d33cb46ba8827b74dc8758e2abed9e5
+commit 376938c588011567c74f1d5a160c0ccce6336d46
Author: Jia Tan <jiat0218@gmail.com>
Date: 2023-07-20 20:15:47 +0800
@@ -1104,7 +5870,7 @@ Date: 2023-07-20 20:15:47 +0800
po/sv.po | 47 +++++++++++++++++++++++++++++------------------
1 file changed, 29 insertions(+), 18 deletions(-)
-commit bdc7952bcfbc20c134f723ff5cbf84ab690fb4fc
+commit 26b0bc6eb82c84559936a7c7080de5c71c8276f8
Author: Jia Tan <jiat0218@gmail.com>
Date: 2023-07-20 20:14:00 +0800
@@ -1113,7 +5879,7 @@ Date: 2023-07-20 20:14:00 +0800
po4a/uk.po | 1253 ++++++++++++++++++++++++++++++------------------------------
1 file changed, 628 insertions(+), 625 deletions(-)
-commit 143396e070c8d8afb56e3a5f688b214222cf71e0
+commit 2d02c8b7640b54f3c5aa1c8b5990ba56f322393b
Author: Jia Tan <jiat0218@gmail.com>
Date: 2023-07-20 20:09:15 +0800
@@ -1122,7 +5888,7 @@ Date: 2023-07-20 20:09:15 +0800
po/uk.po | 45 ++++++++++++++++++++++++++++-----------------
1 file changed, 28 insertions(+), 17 deletions(-)
-commit 1b8146d64eaac51b40079f5788b85c1eb79e35de
+commit f881018b503fd334331c24a09075429558abbce1
Author: Jia Tan <jiat0218@gmail.com>
Date: 2023-07-20 20:06:57 +0800
@@ -1131,7 +5897,7 @@ Date: 2023-07-20 20:06:57 +0800
po/es.po | 47 +++++++++++++++++++++++++++++------------------
1 file changed, 29 insertions(+), 18 deletions(-)
-commit f947ce09d79ef8fa6549d350c4d72e4a8a9fa697
+commit 791fe6d3ffd6877fa5f852be69d9251397dfaa31
Author: Jia Tan <jiat0218@gmail.com>
Date: 2023-07-20 20:05:19 +0800
@@ -1140,7 +5906,7 @@ Date: 2023-07-20 20:05:19 +0800
po/ro.po | 48 ++++++++++++++++++++++++++++++------------------
1 file changed, 30 insertions(+), 18 deletions(-)
-commit f681301a368def3f597a7c7bea7cb3f7a2f933e7
+commit 8827e90704f699fe08bb5bed56b1717a2bc0eb77
Author: Jia Tan <jiat0218@gmail.com>
Date: 2023-07-20 20:02:56 +0800
@@ -1149,28 +5915,40 @@ Date: 2023-07-20 20:02:56 +0800
po4a/ro.po | 1254 ++++++++++++++++++++++++++++++------------------------------
1 file changed, 629 insertions(+), 625 deletions(-)
-commit 8bc3146c6be920b56283f4ee846456cb34ae4b6f
+commit 0184d344fa4f215cd345bb131db9068e077c69b8
Author: Jia Tan <jiat0218@gmail.com>
-Date: 2023-07-13 21:26:47 +0800
+Date: 2023-07-19 23:36:00 +0800
- xz: Update man page Authors and date.
+ liblzma: Suppress -Wunused-function warning.
+
+ Clang 16.0.0 and earlier have a bug that the ifunc resolver function
+ triggers the -Wunused-function warning. The resolver function is static
+ and only "used" by the __attribute__((__ifunc()__)).
+
+ At this time, the bug is still unresolved, but has been reported:
+ https://github.com/llvm/llvm-project/issues/63957
+
+ This is not a problem in GCC.
- src/xz/xz.1 | 5 +++--
- 1 file changed, 3 insertions(+), 2 deletions(-)
+ src/liblzma/check/crc64_fast.c | 10 ++++++++++
+ 1 file changed, 10 insertions(+)
-commit c2905540ef905412b54c76488758712d3e2a0f9d
+commit 43845fa70fc751736c44c18f4cee42d49bfd1392
Author: Jia Tan <jiat0218@gmail.com>
-Date: 2023-07-18 23:19:09 +0800
+Date: 2023-07-18 22:52:25 +0800
- xz: Slight reword in xz man page for consistency.
+ liblzma: Reword lzma_str_list_filters() documentation.
- Changed will print => prints in xz --robot --version description to
- match --robot --info-memory description.
+ This further improves the documentation from commit
+ f36ca7982f6bd5e9827219ed4f3c5a1fbf5d7bdf. The previous wording of
+ "supported options" was slightly misleading since the options that are
+ printed are the ones that are relevant for encoding/decoding. It is not
+ about which options can or must be specified.
- src/xz/xz.1 | 2 +-
+ src/liblzma/api/lzma/filter.h | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)
-commit 2600d3352449faf57d9cb3fa00cbe40548a1310f
+commit 818701ba1c9dff780b7fbf28f9ab8eb11a25dd67
Author: Jia Tan <jiat0218@gmail.com>
Date: 2023-07-18 22:49:57 +0800
@@ -1182,22 +5960,7 @@ Date: 2023-07-18 22:49:57 +0800
src/liblzma/common/string_conversion.c | 4 ++--
1 file changed, 2 insertions(+), 2 deletions(-)
-commit 98fc14541eec3e1dcf694075c8533f19a3cee552
-Author: Jia Tan <jiat0218@gmail.com>
-Date: 2023-05-13 21:21:54 +0800
-
- liblzma: Reword lzma_str_list_filters() documentation.
-
- Reword "options required" to "options read". The previous wording
- may have suggested that the options listed were all required when
- the filters are used for encoding or decoding. Now it should be
- more clear that the options listed are the ones relevant for
- encoding or decoding.
-
- src/liblzma/api/lzma/filter.h | 2 +-
- 1 file changed, 1 insertion(+), 1 deletion(-)
-
-commit 1ac79b4cbaecf3f4930a5d8ce6f7e1f2b63c2a01
+commit b6b7d065853cd4c3f5b8d9be8aea0b6dcb0fe090
Author: Lasse Collin <lasse.collin@tukaani.org>
Date: 2023-07-18 17:37:33 +0300
@@ -1209,7 +5972,7 @@ Date: 2023-07-18 17:37:33 +0300
src/xz/message.c | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)
-commit 97851be2c6c64494f23c3a735601c13d4387820b
+commit be644042c3066d8e7a2834f989671ba74d27f749
Author: Lasse Collin <lasse.collin@tukaani.org>
Date: 2023-07-18 14:35:33 +0300
@@ -1221,7 +5984,7 @@ Date: 2023-07-18 14:35:33 +0300
src/xz/list.c | 11 ++++++-----
4 files changed, 18 insertions(+), 14 deletions(-)
-commit b406828a6dfd3caa4f77efe3ff3e3eea263eee62
+commit 97fd5cb669ee0afc48d2087675ab166aff89eaa2
Author: Lasse Collin <lasse.collin@tukaani.org>
Date: 2023-07-18 13:57:54 +0300
@@ -1233,7 +5996,7 @@ Date: 2023-07-18 13:57:54 +0300
src/liblzma/common/memcmplen.h | 4 ++--
1 file changed, 2 insertions(+), 2 deletions(-)
-commit ef4a07ad9434f81417395f6fe0bb331e027a703b
+commit 40392c19f71985852d75997f109dea97177d6f3f
Author: Lasse Collin <lasse.collin@tukaani.org>
Date: 2023-07-18 13:49:43 +0300
@@ -1242,25 +6005,20 @@ Date: 2023-07-18 13:49:43 +0300
src/liblzma/common/memcmplen.h | 4 ++--
1 file changed, 2 insertions(+), 2 deletions(-)
-commit 64ee0caaea06654b28afaee850fb187a11bf9cb2
+commit abc1d5601b7e419ebc28a1ab4b268613b52e6f98
Author: Jia Tan <jiat0218@gmail.com>
-Date: 2023-06-28 20:22:38 +0800
+Date: 2023-07-18 00:51:48 +0800
- liblzma: Prevent warning for MSYS2 Windows build.
-
- In lzma_memcmplen(), the <intrin.h> header file is only included if
- _MSC_VER and _M_X64 are both defined but _BitScanForward64() was
- previously used if _M_X64 was defined. GCC for MSYS2 defines _M_X64 but
- not _MSC_VER so _BitScanForward64() was used without including
- <intrin.h>.
-
- Now, lzma_memcmplen() will use __builtin_ctzll() for MSYS2 GCC builds as
- expected.
+ xz: Update Authors list in a few files.
- src/liblzma/common/memcmplen.h | 6 ++++--
- 1 file changed, 4 insertions(+), 2 deletions(-)
+ src/xz/args.c | 3 ++-
+ src/xz/args.h | 3 ++-
+ src/xz/coder.c | 3 ++-
+ src/xz/coder.h | 3 ++-
+ src/xz/message.c | 3 ++-
+ 5 files changed, 10 insertions(+), 5 deletions(-)
-commit ba177057643dae6e9c167ee26471181c199c8a00
+commit 289034a168878baa9df6ff6e159110aade69cba5
Author: Jia Tan <jiat0218@gmail.com>
Date: 2023-07-14 23:20:33 +0800
@@ -1277,7 +6035,7 @@ Date: 2023-07-14 23:20:33 +0800
INSTALL | 81 +++++++++++++++++++++++++++++++++++++++++++++++++++--------------
1 file changed, 64 insertions(+), 17 deletions(-)
-commit 0745b900fafa5ac2c31e8ec3cfba3053457c8b1f
+commit 1119e5f5a519b0ab71c81fc4dc84c0cc72abe513
Author: Jia Tan <jiat0218@gmail.com>
Date: 2023-07-14 21:10:27 +0800
@@ -1289,9 +6047,9 @@ Date: 2023-07-14 21:10:27 +0800
README | 4 ++++
1 file changed, 4 insertions(+)
-commit c972d44103c4edf88e73917ef08bde69db9d06cb
+commit f99e2e4e53b7ea89e4eef32ddd4882e0416357c9
Author: Jia Tan <jiat0218@gmail.com>
-Date: 2023-07-18 13:27:46 +0300
+Date: 2023-07-13 23:32:10 +0800
xz: Fix typo in man page.
@@ -1302,7 +6060,307 @@ Date: 2023-07-18 13:27:46 +0300
src/xz/xz.1 | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)
-commit 6e21f1b4e2c580b64d258e3b81ac9e44d53b9283
+commit f907705eb1f6c5edaafc9668a34c51a989932f1d
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2023-07-13 21:46:12 +0800
+
+ xz: Minor clean up for coder.c
+
+ * Moved max_block_list_size from a global to local variable.
+ * Reworded error message in validate_block_list_filter().
+ * Removed helper function filter_chain_error().
+ * Changed 1 << X to 1U << X in many places
+
+ src/xz/coder.c | 53 +++++++++++++++++++++--------------------------------
+ 1 file changed, 21 insertions(+), 32 deletions(-)
+
+commit 9adc9e56157ecbf2948e5036df8567809b9ae177
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2023-07-13 21:26:47 +0800
+
+ xz: Update man page Authors and date.
+
+ src/xz/xz.1 | 5 +++--
+ 1 file changed, 3 insertions(+), 2 deletions(-)
+
+commit c12e429f2635da8d8f5749e5f733f451baca6945
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2023-06-20 20:32:59 +0800
+
+ xz: Add a section to man page for robot mode --filters-help.
+
+ src/xz/xz.1 | 32 ++++++++++++++++++++++++++++++--
+ 1 file changed, 30 insertions(+), 2 deletions(-)
+
+commit e10f2db5d10300c16fa482a136ed31c1aa6e8e8d
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2023-06-19 23:11:41 +0800
+
+ xz: Slight reword in xz man page for consistency.
+
+ Changed will print => prints in xz --robot --version description to
+ match --robot --info-memory description.
+
+ src/xz/xz.1 | 2 +-
+ 1 file changed, 1 insertion(+), 1 deletion(-)
+
+commit f5dc172a402fa946f3c45a16929d7fe14c9f5e81
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2023-06-19 23:07:10 +0800
+
+ xz: Reorder robot mode subsections in the man page.
+
+ The order is now consistent with the order the command line arguments
+ are documented earlier in the man page. The new order is:
+ 1. --list
+ 2. --info-memory
+ 3. --version
+
+ Instead of the previous order:
+ 1. --version
+ 2. --info-memory
+ 3. --list
+
+ src/xz/xz.1 | 192 ++++++++++++++++++++++++++++++------------------------------
+ 1 file changed, 96 insertions(+), 96 deletions(-)
+
+commit 9628be23aef2784249fd9f3199799d785d2ec5cc
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2023-05-13 00:46:50 +0800
+
+ xz: Update man page for new --filters-help option.
+
+ src/xz/xz.1 | 10 ++++++++++
+ 1 file changed, 10 insertions(+)
+
+commit a165d7df1964121eb9df715e6f836a31c865beef
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2023-05-13 00:44:41 +0800
+
+ xz: Add a new --filters-help option.
+
+ The --filters-help can be used to help create filter chains with the
+ --filters and --filtersX options. The message in --long-help is too
+ short to fully explain the syntax to construct complex filter chains.
+
+ In --robot mode, xz will only print the output from liblzma function
+ lzma_str_list_filters.
+
+ src/xz/args.c | 8 ++++++++
+ src/xz/message.c | 30 ++++++++++++++++++++++++++++++
+ src/xz/message.h | 5 +++++
+ 3 files changed, 43 insertions(+)
+
+commit 95f1a414b156ee35d3e71862a14915fdd138f913
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2023-04-21 20:28:11 +0800
+
+ xz: Update the man page for --block-list and --filtersX
+
+ The --block-list option description needed updating since the new
+ --filtersX option changes how it can be used. The new entry for
+ --filters1=FILTERS ... --filter9=FILTERS was created right after
+ the --filters option.
+
+ src/xz/xz.1 | 106 +++++++++++++++++++++++++++++++++++++++++++++---------------
+ 1 file changed, 80 insertions(+), 26 deletions(-)
+
+commit 47a63cad2aa778280e0c1926b7159427ea028cb1
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2023-04-21 19:50:14 +0800
+
+ xz: Update --long-help for the new --filtersX option.
+
+ src/xz/message.c | 12 ++++++++++--
+ 1 file changed, 10 insertions(+), 2 deletions(-)
+
+commit 8b9913a13daca2550d02dfdcdc9be15f55ca4d13
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2023-06-17 20:46:21 +0800
+
+ xz: Ignore filter chains that are set but never used in --block-list.
+
+ If a filter chain is set but not used in --block-list, it introduced
+ unexpected behavior such as requiring an unneeded amount of memory to
+ compress, reducing the number of threads in multi-threaded encoding, and
+ printing an incorrect amount of memory needed to decompress.
+
+ This also renames filters_init_mask => filters_used_mask. A filter is
+ assumed to be used if it is specified in --filtersX until
+ coder_set_compression_settings() determines which filters are referenced
+ in --block-list.
+
+ src/xz/coder.c | 66 ++++++++++++++++++++++++++++++++++++++++++----------------
+ 1 file changed, 48 insertions(+), 18 deletions(-)
+
+commit 183819bfd9efac8c184d9bf123325719b7eee30f
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2023-05-13 20:11:13 +0800
+
+ xz: Set the Block size for mt encoding correctly.
+
+ When opt_block_size is not used, the Block size for mt encoder is
+ derived from the minimum of the largest Block specified by
+ --block-list and the recommended Block size on all filter chains
+ calculated by lzma_mt_block_size(). This avoids using unnecessary
+ memory and ensures that all Blocks are large enough for the most memory
+ needy filter chain.
+
+ src/xz/coder.c | 68 +++++++++++++++++++++++++++++++++++++++++++++++++++++++++-
+ 1 file changed, 67 insertions(+), 1 deletion(-)
+
+commit afb2dbec3d857b026486b75e42a4728e12d234cb
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2023-05-11 00:09:41 +0800
+
+ xz: Validate --flush-timeout for all specified filter chains.
+
+ src/xz/coder.c | 24 ++++++++++++++++--------
+ 1 file changed, 16 insertions(+), 8 deletions(-)
+
+commit 5f0c5a04388f8334962c70bc37a8c2ff8f605e0a
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2023-05-13 19:54:33 +0800
+
+ xz: Allows --block-list filters to scale down memory usage.
+
+ Previously, only the default filter chain could have its memory usage
+ adjusted. The filter chains specified with --filtersX were not checked
+ for memory usage. Now, all used filter chains will be adjusted if
+ necessary.
+
+ src/xz/coder.c | 269 +++++++++++++++++++++++++++++++++++++++++++++------------
+ 1 file changed, 214 insertions(+), 55 deletions(-)
+
+commit 479fd58d60622331fcbe48fddf756927b9f80d9a
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2023-05-10 21:50:33 +0800
+
+ xz: Do not include block splitting if encoders are disabled.
+
+ The block splitting logic and split_block() function are not needed if
+ encoders are disabled. This will help slightly reduce the binary size
+ when built without encoders and allow split_block() to use functions
+ that require encoders being enabled.
+
+ src/xz/coder.c | 29 ++++++++++++++++++++---------
+ 1 file changed, 20 insertions(+), 9 deletions(-)
+
+commit f86ede22500f7ae024ec3ec3f3489ab5a857a3b3
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2023-05-10 22:38:59 +0800
+
+ xz: Free filters[] in debug mode.
+
+ This will only free filter chains created with --filters1-9 since the
+ default filter chain may be set from a static function variable. The
+ complexity to free the default filter chain is not worth the burden on
+ code maintenance.
+
+ src/xz/coder.c | 10 ++++++++++
+ 1 file changed, 10 insertions(+)
+
+commit f281cd0d692ac0c70fc7669b80dddb863ea947e1
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2023-05-13 19:28:23 +0800
+
+ xz: Add a message if --block-list is used outside of xz compresssion.
+
+ --block-list is only supported with compression in xz format. This avoids
+ silently ignoring when --block-list is unused.
+
+ src/xz/args.c | 11 +++++++++++
+ 1 file changed, 11 insertions(+)
+
+commit d6af7f347077b22403133239592e478931307759
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2023-04-18 20:29:09 +0800
+
+ xz: Create command line options for filters[1-9].
+
+ The new command line options are meant to be combined with --block-list.
+ They work as an optional extension to --block-list to specify a custom
+ filter chain for each block listed. The new options allow the creation
+ of up to 9 reusable filter chains. For instance:
+
+ xz --block-list=1:10MiB,3:5MiB,,2:5MiB,1:0 --filters1=delta--lzma2 \
+ --filters2=x86--lzma2 --filters3=arm64--lzma2
+
+ Will create the following blocks:
+ 1. A block of size 10 MiB with filter chain delta, lzma2.
+ 2. A block of size 5 MiB with filter chain arm64, lzma2.
+ 3. A block of size 5 MiB with filter chain arm64, lzma2.
+ 4. A block of size 5 MiB with filter chain x86, lzma2.
+ 5. A block containing the rest of the file contents with filter chain
+ delta, lzma2.
+
+ src/xz/args.c | 82 ++++++++++++++++++++++---
+ src/xz/coder.c | 188 ++++++++++++++++++++++++++++++++++++++++++---------------
+ src/xz/coder.h | 20 +++++-
+ 3 files changed, 230 insertions(+), 60 deletions(-)
+
+commit 072d29250113268536719ad0e040ab8a66fb6435
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2023-05-13 19:36:09 +0800
+
+ xz: Use lzma_filters_free() in forget_filter_chain().
+
+ This is a little cleaner than the previous implementation of
+ forget_filter_chain(). It is also more consistent since
+ lzma_str_to_filters() will always terminate the filter chain so there
+ is no need to terminate it later in coder_set_compression_settings().
+
+ src/xz/coder.c | 18 ++++++++++--------
+ 1 file changed, 10 insertions(+), 8 deletions(-)
+
+commit 3d21da5cff4b511633cb6e0d8a1090485c0c1059
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2023-04-17 22:22:45 +0800
+
+ xz: Separate string to filter conversion into a helper function.
+
+ Converting from string to filter will also need to be done for block
+ specific filter chains.
+
+ src/xz/coder.c | 33 ++++++++++++++++++++-------------
+ 1 file changed, 20 insertions(+), 13 deletions(-)
+
+commit a6583726e5f950278f96abcf79c04f1056810be6
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2023-01-06 00:03:35 +0800
+
+ Tests: Use new --filters option in test_compress.sh
+
+ tests/test_compress.sh | 20 ++++++++++----------
+ 1 file changed, 10 insertions(+), 10 deletions(-)
+
+commit 5f3b898d07cc9b7160c7c88b3120b7edabb8a5b0
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2023-01-06 00:03:06 +0800
+
+ xz: Update --long-help and man page for new --filters option.
+
+ src/xz/message.c | 6 ++++++
+ src/xz/xz.1 | 41 ++++++++++++++++++++++++++++++++++++-----
+ 2 files changed, 42 insertions(+), 5 deletions(-)
+
+commit 9ded880a0221f4d1256845fc4ab957ffd377c760
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2023-01-06 00:02:29 +0800
+
+ xz: Add --filters option to CLI.
+
+ The --filters option uses the new lzma_str_to_filters() function
+ to convert a string into a full filter chain. Using this option
+ will reset all previous filters set by --preset, --[filter], or
+ --filters.
+
+ src/xz/args.c | 9 +++++++--
+ src/xz/coder.c | 50 ++++++++++++++++++++++++++++++++++++++++++++++++--
+ src/xz/coder.h | 3 +++
+ 3 files changed, 58 insertions(+), 4 deletions(-)
+
+commit 2c189bb00af73dc7ba1a67a9d274d5be03ee3a88
Author: Jia Tan <jiat0218@gmail.com>
Date: 2023-07-14 21:30:25 +0800
@@ -1322,7 +6380,7 @@ Date: 2023-07-14 21:30:25 +0800
tests/test_files.sh | 2 +-
2 files changed, 3 insertions(+), 3 deletions(-)
-commit 26c37d290c0884a4518a26b949575420a77fb938
+commit 80a6b9bcad016c99c9ba3f3eeb4a619fcadfd357
Author: Jia Tan <jiat0218@gmail.com>
Date: 2023-07-10 20:56:28 +0800
@@ -1331,7 +6389,21 @@ Date: 2023-07-10 20:56:28 +0800
po/zh_TW.po | 659 ++++++++++++++++++++++++++++++++++--------------------------
1 file changed, 377 insertions(+), 282 deletions(-)
-commit 2ec65181e28335692a3a4fac4fefc4303111d355
+commit 17f8844e6fc355abf997d77637a7447c4f7bbcbd
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2023-07-08 21:24:19 +0800
+
+ liblzma: Remove non-portable empty initializer.
+
+ Commit 78704f36e74205857c898a351c757719a6c8b666 added an empty
+ initializer {} to prevent a warning. The empty initializer is a GNU
+ extension and results in a build failure on MSVC. The -wpedantic flag
+ warns about empty initializers.
+
+ src/liblzma/common/stream_encoder_mt.c | 2 +-
+ 1 file changed, 1 insertion(+), 1 deletion(-)
+
+commit 3aca4f629cd577f0c54f594d5d88722edf0b0413
Author: Jia Tan <jiat0218@gmail.com>
Date: 2023-07-08 20:03:59 +0800
@@ -1340,7 +6412,7 @@ Date: 2023-07-08 20:03:59 +0800
po/vi.po | 620 +++++++++++++++++++++++++++++++++++----------------------------
1 file changed, 349 insertions(+), 271 deletions(-)
-commit c44c7e7590db1b89c97e106f5c516bf69189e233
+commit 66bdcfa85fef2911cc80f5f30fed3f9610faccb4
Author: Jia Tan <jiat0218@gmail.com>
Date: 2023-06-28 20:46:31 +0800
@@ -1353,7 +6425,7 @@ Date: 2023-06-28 20:46:31 +0800
tests/test_index.c | 11 +++++++++++
1 file changed, 11 insertions(+)
-commit b9499c94fccc03eba5311b5305f04149a7c5af65
+commit fe3bd438fb119f9bad3f08dc29d331e4956196e1
Author: Jia Tan <jiat0218@gmail.com>
Date: 2023-06-28 20:43:29 +0800
@@ -1366,7 +6438,7 @@ Date: 2023-06-28 20:43:29 +0800
tests/test_block_header.c | 38 ++++++++++++++++++++++----------------
1 file changed, 22 insertions(+), 16 deletions(-)
-commit 1155471651ad456c5f90aee6435931fae65682bf
+commit 78704f36e74205857c898a351c757719a6c8b666
Author: Jia Tan <jiat0218@gmail.com>
Date: 2023-06-28 20:31:11 +0800
@@ -1386,7 +6458,150 @@ Date: 2023-06-28 20:31:11 +0800
src/liblzma/common/stream_encoder_mt.c | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)
-commit 62dd1c9bf0c66679ceeebc8b99bca136ca43bcb9
+commit e3356a204c5ae02db3ec4552b6c1be354e9b6142
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2023-06-28 20:22:38 +0800
+
+ liblzma: Prevent warning for MSYS2 Windows build.
+
+ In lzma_memcmplen(), the <intrin.h> header file is only included if
+ _MSC_VER and _M_X64 are both defined but _BitScanForward64() was
+ previously used if _M_X64 was defined. GCC for MSYS2 defines _M_X64 but
+ not _MSC_VER so _BitScanForward64() was used without including
+ <intrin.h>.
+
+ Now, lzma_memcmplen() will use __builtin_ctzll() for MSYS2 GCC builds as
+ expected.
+
+ src/liblzma/common/memcmplen.h | 6 ++++--
+ 1 file changed, 4 insertions(+), 2 deletions(-)
+
+commit 45e250a9e9f3c3e8e8af2983366b170bf54f890e
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2023-06-28 21:01:22 +0800
+
+ CI: Add test with -fsanitize=address,undefined.
+
+ ci_build.sh was updated to accept disabling of __attribute__ ifunc
+ and CLMUL. This will allow -fsanitize=address to pass because ifunc
+ is incompatible with -fsanitize=address. The CLMUL implementation has
+ optimizations that potentially read past the buffer and mask out the
+ unwanted bytes.
+
+ This test will only run on Autotools Linux.
+
+ .github/workflows/ci.yml | 23 +++++++++++++++++++----
+ build-aux/ci_build.sh | 8 +++++++-
+ 2 files changed, 26 insertions(+), 5 deletions(-)
+
+commit 596ee722cd7ddf0afae584fc06365adc0e735977
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2023-06-28 20:16:04 +0800
+
+ CI: Upgrade checkout action from v2 to v3.
+
+ .github/workflows/ci.yml | 2 +-
+ 1 file changed, 1 insertion(+), 1 deletion(-)
+
+commit 86118ea320f867e09e98a8682cc08cbbdfd640e2
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2023-06-27 23:38:32 +0800
+
+ Update THANKS.
+
+ THANKS | 1 +
+ 1 file changed, 1 insertion(+)
+
+commit 3d1fdddf92321b516d55651888b9c669e254634e
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2023-06-27 17:27:09 +0300
+
+ Docs: Document the configure option --disable-ifunc in INSTALL.
+
+ INSTALL | 8 ++++++++
+ 1 file changed, 8 insertions(+)
+
+commit b4cf7a2822e8d30eb2b12a1a07fd04383b10ade3
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2023-06-27 17:24:49 +0300
+
+ Minor tweaks to style and comments.
+
+ CMakeLists.txt | 8 ++++----
+ configure.ac | 9 +++++----
+ 2 files changed, 9 insertions(+), 8 deletions(-)
+
+commit 23fb9e3a329117c2968c1e7388b6ef07c782dba1
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2023-06-27 17:19:49 +0300
+
+ CMake: Rename CHECK_ATTR_IFUNC to ALLOW_ATTR_IFUNC.
+
+ It's so that there's a clear difference in wording compared
+ to liblzma's integrity check types.
+
+ CMakeLists.txt | 6 +++---
+ 1 file changed, 3 insertions(+), 3 deletions(-)
+
+commit ee44863ae88e377a5df10db007ba9bfadde3d314
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2023-06-27 17:05:23 +0300
+
+ liblzma: Add ifunc implementation to crc64_fast.c.
+
+ The ifunc method avoids indirection via the function pointer
+ crc64_func. This works on GNU/Linux and probably on FreeBSD too.
+ The previous __attribute((__constructor__)) method is kept for
+ compatibility with ELF platforms which do support ifunc.
+
+ The ifunc method has some limitations, for example, building
+ liblzma with -fsanitize=address will result in segfaults.
+ The configure option --disable-ifunc must be used for such builds.
+
+ Thanks to Hans Jansen for the original patch.
+ Closes: https://github.com/tukaani-project/xz/pull/53
+
+ src/liblzma/check/crc64_fast.c | 35 ++++++++++++++++++++++++++---------
+ 1 file changed, 26 insertions(+), 9 deletions(-)
+
+commit b72d21202402a603db6d512fb9271cfa83249639
+Author: Hans Jansen <hansjansen162@outlook.com>
+Date: 2023-06-22 19:49:30 +0200
+
+ Add ifunc check to CMakeLists.txt
+
+ CMake build system will now verify if __attribute__((__ifunc__())) can be
+ used in the build system. If so, HAVE_FUNC_ATTRIBUTE_IFUNC will be
+ defined to 1.
+
+ CMakeLists.txt | 19 +++++++++++++++++++
+ 1 file changed, 19 insertions(+)
+
+commit 23b5c36fb71904bfbe16bb20f976da38dadf6c3b
+Author: Hans Jansen <hansjansen162@outlook.com>
+Date: 2023-06-22 19:46:55 +0200
+
+ Add ifunc check to configure.ac
+
+ configure.ac will now verify if __attribute__((__ifunc__())) can be used in
+ the build system. If so, HAVE_FUNC_ATTRIBUTE_IFUNC will be defined to 1.
+
+ configure.ac | 28 ++++++++++++++++++++++++++++
+ 1 file changed, 28 insertions(+)
+
+commit dbb3a536ed9873ffa0870321f6873e564c6a9da8
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2023-06-07 00:18:30 +0800
+
+ CI: Add apt update command before installing dependencies.
+
+ Without the extra command, all of the CI tests were automatically
+ failing because the Ubuntu servers could not be reached properly.
+
+ .github/workflows/ci.yml | 8 ++++++--
+ 1 file changed, 6 insertions(+), 2 deletions(-)
+
+commit 6bcd516812331de42b347922913230895bebad34
Author: Jia Tan <jiat0218@gmail.com>
Date: 2023-06-07 00:10:38 +0800
@@ -1395,7 +6610,7 @@ Date: 2023-06-07 00:10:38 +0800
THANKS | 1 +
1 file changed, 1 insertion(+)
-commit d04eb78ab3892d3678c180437dd66379efa051fd
+commit 0d94ba69220d894d2a86081821d2d7a89df5a10b
Author: Benjamin Buch <bebuch@users.noreply.github.com>
Date: 2023-06-06 15:32:45 +0200
@@ -1403,8 +6618,8 @@ Date: 2023-06-06 15:32:45 +0200
Boost iostream uses `find_package` in quiet mode and then again uses
`find_package` with required. This second call triggers a
- `add_library cannot create imported target "LibLZMA::LibLZMA"
- because another target with the same name already exists.`
+ `add_library cannot create imported target "ZLIB::ZLIB" because another
+ target with the same name already exists.`
This can simply be fixed by skipping the alias part on secondary
`find_package` runs.
@@ -1412,7 +6627,7 @@ Date: 2023-06-06 15:32:45 +0200
CMakeLists.txt | 16 +++++++++-------
1 file changed, 9 insertions(+), 7 deletions(-)
-commit 12ea1fb29763dd72376aca73d69621aff01eaa7f
+commit 045d7aae286ecd2ce163be9e0d9041343a03f89a
Author: Jia Tan <jiat0218@gmail.com>
Date: 2023-05-31 20:26:42 +0800
@@ -1421,7 +6636,7 @@ Date: 2023-05-31 20:26:42 +0800
po/eo.po | 185 +++++++++++++++++++++++++++++++--------------------------------
1 file changed, 92 insertions(+), 93 deletions(-)
-commit a4d45c07c1e4aa0ea9410b4eed7301c97e960319
+commit b0cc7c2dcefe4cbc4e1e697598c14fb687ed0b78
Author: Jia Tan <jiat0218@gmail.com>
Date: 2023-05-31 20:25:00 +0800
@@ -1430,7 +6645,7 @@ Date: 2023-05-31 20:25:00 +0800
po/hr.po | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)
-commit f51b7bcea6f948db9529b3e6d850e76a30cc0e96
+commit af045ef6f848f02cd14c9ad195a5f87bb0c02dce
Author: Jia Tan <jiat0218@gmail.com>
Date: 2023-05-31 20:15:53 +0800
@@ -1439,7 +6654,7 @@ Date: 2023-05-31 20:15:53 +0800
po/zh_CN.po | 317 ++++++++++++++++++++++++++++++------------------------------
1 file changed, 157 insertions(+), 160 deletions(-)
-commit d5b81c19a7594fbb913bb3450360bc2145f29568
+commit e6b92d5817fe91ad27a0f7f57bd0f2144311e383
Author: Jia Tan <jiat0218@gmail.com>
Date: 2023-05-17 23:12:13 +0800
@@ -1448,7 +6663,7 @@ Date: 2023-05-17 23:12:13 +0800
po4a/de.po | 52 ++++++++++++----------------------------------------
1 file changed, 12 insertions(+), 40 deletions(-)
-commit 36860a3e30d5675b4dba3a343159458d8864bceb
+commit 592961ccdbba39c7d60fe37e36764232feb57c60
Author: Jia Tan <jiat0218@gmail.com>
Date: 2023-05-17 23:09:18 +0800
@@ -1457,7 +6672,7 @@ Date: 2023-05-17 23:09:18 +0800
po/de.po | 189 +++++++++++++++++++++++++++++++--------------------------------
1 file changed, 94 insertions(+), 95 deletions(-)
-commit f05641ef0d4990c4c58f459039d412475b94b37d
+commit 13572cb2c391f5b7503e333c6e05b20bd5bbb524
Author: Jia Tan <jiat0218@gmail.com>
Date: 2023-05-17 20:30:01 +0800
@@ -1466,7 +6681,7 @@ Date: 2023-05-17 20:30:01 +0800
po/hr.po | 187 +++++++++++++++++++++++++++++++--------------------------------
1 file changed, 93 insertions(+), 94 deletions(-)
-commit b852f6f11d43cafce871cd158c80488f86619a63
+commit 4e6e425ea8f097c6fb43e69cc9540294dca3680d
Author: Jia Tan <jiat0218@gmail.com>
Date: 2023-05-17 20:26:54 +0800
@@ -1475,7 +6690,7 @@ Date: 2023-05-17 20:26:54 +0800
po4a/ko.po | 3015 ++++++++++++------------------------------------------------
1 file changed, 568 insertions(+), 2447 deletions(-)
-commit fdcb78fb6f5313eda363869690685471d7ab9731
+commit d5ef1f6faf7c270f60093629257150085ecf19ca
Author: Jia Tan <jiat0218@gmail.com>
Date: 2023-05-17 20:13:01 +0800
@@ -1484,7 +6699,7 @@ Date: 2023-05-17 20:13:01 +0800
po/ko.po | 319 +++++++++++++++++++++++++++++++--------------------------------
1 file changed, 158 insertions(+), 161 deletions(-)
-commit 9e39cebe3ccdd4bc320ce6e7eea989bdd167c8b2
+commit e22d0b0f2e301e7906d0106689d967ed84362028
Author: Jia Tan <jiat0218@gmail.com>
Date: 2023-05-16 23:49:09 +0800
@@ -1493,7 +6708,7 @@ Date: 2023-05-16 23:49:09 +0800
po/es.po | 319 +++++++++++++++++++++++++++++++--------------------------------
1 file changed, 158 insertions(+), 161 deletions(-)
-commit 7a578d1d8293fc1cf7c6f9df76bc6a0e55c51a14
+commit f50da74d52d01f6cfd826a921249e289cf671678
Author: Jia Tan <jiat0218@gmail.com>
Date: 2023-05-16 23:47:23 +0800
@@ -1502,7 +6717,7 @@ Date: 2023-05-16 23:47:23 +0800
po/ro.po | 195 ++++++++++++++++++++++++++++++++-------------------------------
1 file changed, 98 insertions(+), 97 deletions(-)
-commit 362320fea5383bae179763763625532bad6d10e8
+commit 4b9ad60a7305e9841b7cb4ea611bdf5fa7271696
Author: Jia Tan <jiat0218@gmail.com>
Date: 2023-05-16 23:45:43 +0800
@@ -1511,7 +6726,7 @@ Date: 2023-05-16 23:45:43 +0800
po4a/ro.po | 19 ++++++++++---------
1 file changed, 10 insertions(+), 9 deletions(-)
-commit 29c5a870be23d0a565b959404b34a8b1babef7df
+commit cb6fd57f889c5d9fab36ae8c9e10083a5fe32dea
Author: Jia Tan <jiat0218@gmail.com>
Date: 2023-05-16 23:43:51 +0800
@@ -1520,7 +6735,7 @@ Date: 2023-05-16 23:43:51 +0800
po4a/uk.po | 12 ++++++------
1 file changed, 6 insertions(+), 6 deletions(-)
-commit 5ee57572773207371712b1bbcd9b5b8c1baad2cc
+commit c3e8fcbc2db4861f92ad15606c995bd255803c52
Author: Jia Tan <jiat0218@gmail.com>
Date: 2023-05-16 23:37:54 +0800
@@ -1529,7 +6744,7 @@ Date: 2023-05-16 23:37:54 +0800
po/uk.po | 321 +++++++++++++++++++++++++++++++--------------------------------
1 file changed, 159 insertions(+), 162 deletions(-)
-commit dfc257bdb224780d3c8cdeca5a8e52848b9adc0a
+commit 27b81b84fcedbc55aa6e6b21004c44070b15b038
Author: Jia Tan <jiat0218@gmail.com>
Date: 2023-05-16 23:07:35 +0800
@@ -1538,7 +6753,7 @@ Date: 2023-05-16 23:07:35 +0800
po/pl.po | 316 +++++++++++++++++++++++++++++++--------------------------------
1 file changed, 155 insertions(+), 161 deletions(-)
-commit f6df4c4ab7378d2971ae1606f4eecc011ea5fc6d
+commit 8024ad636a65ed6ea95c94d57255be4c6724d6ed
Author: Jia Tan <jiat0218@gmail.com>
Date: 2023-05-16 22:52:14 +0800
@@ -1547,7 +6762,7 @@ Date: 2023-05-16 22:52:14 +0800
po/sv.po | 319 +++++++++++++++++++++++++++++++--------------------------------
1 file changed, 158 insertions(+), 161 deletions(-)
-commit 25da22e0521ec698dae4eb5e994b4cd3f4708b60
+commit 6699a29673f227c4664826db485ed9f7596320d2
Author: Jia Tan <jiat0218@gmail.com>
Date: 2023-05-16 21:21:38 +0800
@@ -1556,7 +6771,21 @@ Date: 2023-05-16 21:21:38 +0800
po/eo.po | 34 +++++++++++++++++-----------------
1 file changed, 17 insertions(+), 17 deletions(-)
-commit 4f57a9c9915b7b9267885cf9fca58e5c8208458d
+commit f36ca7982f6bd5e9827219ed4f3c5a1fbf5d7bdf
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2023-05-13 21:21:54 +0800
+
+ liblzma: Slightly rewords lzma_str_list_filters() documentation.
+
+ Reword "options required" to "supported options". The previous may have
+ suggested that the options listed were all required anytime a filter is
+ used for encoding or decoding. The reword makes this more clear that
+ adjusting the options is optional.
+
+ src/liblzma/api/lzma/filter.h | 2 +-
+ 1 file changed, 1 insertion(+), 1 deletion(-)
+
+commit 3374a5359e52f1671d8f831d65827d5020fe2595
Author: Jia Tan <jiat0218@gmail.com>
Date: 2023-05-11 23:49:23 +0800
@@ -1568,26 +6797,47 @@ Date: 2023-05-11 23:49:23 +0800
src/liblzma/api/lzma/container.h | 5 +++--
1 file changed, 3 insertions(+), 2 deletions(-)
-commit 238b4e5458b4bd2cadefb768b8ea7c6b70a191ac
+commit 8f236574986e7c414c0ea059f441982d1387e6a4
Author: Jia Tan <jiat0218@gmail.com>
-Date: 2023-05-04 20:38:52 +0800
+Date: 2023-05-09 20:20:06 +0800
- Translations: Update the Croatian translation.
+ liblzma: Exports lzma_mt_block_size() as an API function.
+
+ The lzma_mt_block_size() was previously just an internal function for
+ the multithreaded .xz encoder. It is used to provide a recommended Block
+ size for a given filter chain.
+
+ This function is helpful to determine the maximum Block size for the
+ multithreaded .xz encoder when one wants to change the filters between
+ blocks. Then, this determined Block size can be provided to
+ lzma_stream_encoder_mt() in the lzma_mt options parameter when
+ intializing the coder. This requires one to know all the filter chains
+ they are using before starting to encode (or at least the filter chain
+ that will need the largest Block size), but that isn't a bad limitation.
- po/hr.po | 6 +++---
- 1 file changed, 3 insertions(+), 3 deletions(-)
+ src/liblzma/api/lzma/container.h | 28 ++++++++++++++++++++++++++++
+ src/liblzma/common/filter_encoder.c | 16 ++++++++++------
+ src/liblzma/common/filter_encoder.h | 6 +-----
+ src/liblzma/common/stream_encoder_mt.c | 20 +++++++++-----------
+ src/liblzma/liblzma_generic.map | 5 +++++
+ src/liblzma/liblzma_linux.map | 5 +++++
+ src/liblzma/lzma/lzma2_encoder.c | 3 +++
+ 7 files changed, 61 insertions(+), 22 deletions(-)
-commit 0cee63c3c6c4f9084a5e7fa7c15a1863ac8e5ffc
+commit d0f33d672a4da7985ebb5ba8d829f885de49c171
Author: Jia Tan <jiat0218@gmail.com>
-Date: 2023-05-04 19:50:42 +0800
+Date: 2023-05-08 22:58:09 +0800
- Bump version and soname for 5.4.3.
+ liblzma: Creates IS_ENC_DICT_SIZE_VALID() macro.
+
+ This creates an internal liblzma macro to test if the dictionary size
+ is valid for encoding.
- src/liblzma/Makefile.am | 2 +-
- src/liblzma/api/lzma/version.h | 2 +-
- 2 files changed, 2 insertions(+), 2 deletions(-)
+ src/liblzma/lz/lz_encoder.c | 4 +---
+ src/liblzma/lz/lz_encoder.h | 8 ++++++++
+ 2 files changed, 9 insertions(+), 3 deletions(-)
-commit 01f937ea9a49005c5091c0165fa0c1e572dd1749
+commit c247d06e1f6cada9a76f4f6225cbd97ea760f52f
Author: Jia Tan <jiat0218@gmail.com>
Date: 2023-05-02 20:39:56 +0800
@@ -1596,7 +6846,46 @@ Date: 2023-05-02 20:39:56 +0800
NEWS | 10 ++++++++++
1 file changed, 10 insertions(+)
-commit e9b9ea953179502d5245b4e6ca4f5ffe9d5797b1
+commit 77050b78364ffb6b0f129e742b7c31602d725c08
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2023-05-02 20:39:37 +0800
+
+ Add NEWS for 5.2.12.
+
+ NEWS | 14 ++++++++++++++
+ 1 file changed, 14 insertions(+)
+
+commit 713e15e43eb6279a7ab4bbad3d1325ebfdcf09a0
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2023-05-04 20:38:52 +0800
+
+ Translations: Update the Croatian translation.
+
+ po/hr.po | 6 +++---
+ 1 file changed, 3 insertions(+), 3 deletions(-)
+
+commit 9ad64bdf309844b6ca6c3e8a4dfb6dbaedda0ca9
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2023-05-04 20:30:25 +0800
+
+ tuklib_integer.h: Reverts previous commit.
+
+ Previous commit 6be460dde07113fe3f08f814b61ddc3264125a96 would cause an
+ error if the integer size was 32 bit.
+
+ src/common/tuklib_integer.h | 4 ++--
+ 1 file changed, 2 insertions(+), 2 deletions(-)
+
+commit 6be460dde07113fe3f08f814b61ddc3264125a96
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2023-05-04 19:25:20 +0800
+
+ tuklib_integer.h: Changes two other UINT_MAX == UINT32_MAX to >=.
+
+ src/common/tuklib_integer.h | 4 ++--
+ 1 file changed, 2 insertions(+), 2 deletions(-)
+
+commit 44c0c5eae990a22ef04e9b88c1a15838a0d00878
Author: Lasse Collin <lasse.collin@tukaani.org>
Date: 2023-05-03 22:46:42 +0300
@@ -1609,7 +6898,25 @@ Date: 2023-05-03 22:46:42 +0300
src/common/tuklib_integer.h | 4 ++--
1 file changed, 2 insertions(+), 2 deletions(-)
-commit be6e39a8622f0d905072874ec25b1ffd155b12e1
+commit 2cf5ae5b5b279b0b2e69ca4724e7bd705865fe68
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2023-04-25 20:06:15 +0800
+
+ CI: Adds a build and test for small configuration.
+
+ .github/workflows/ci.yml | 5 +++++
+ 1 file changed, 5 insertions(+)
+
+commit 16b81a057a87c2f18e6ed6447f003af0cbdcfe43
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2023-04-25 20:05:26 +0800
+
+ CI: ci_build.sh allows configuring small build.
+
+ build-aux/ci_build.sh | 7 ++++++-
+ 1 file changed, 6 insertions(+), 1 deletion(-)
+
+commit 78ccd93951f9e988d447bcdd70b24f6df5448d1d
Author: Jia Tan <jiat0218@gmail.com>
Date: 2023-04-20 20:15:00 +0800
@@ -1618,7 +6925,7 @@ Date: 2023-04-20 20:15:00 +0800
THANKS | 1 +
1 file changed, 1 insertion(+)
-commit 9e343a46cf87a345799222c0b0b3a6f3358dde0c
+commit f41df2ac2fed347d3f107f3533e76e000d29c6cb
Author: Jia Tan <jiat0218@gmail.com>
Date: 2023-04-19 22:22:16 +0800
@@ -1636,7 +6943,7 @@ Date: 2023-04-19 22:22:16 +0800
src/liblzma/common/memcmplen.h | 10 ++++++++++
2 files changed, 16 insertions(+)
-commit 12321a9390acc076b414035a46df9d7545ac379f
+commit 7062348bf35c1e4cbfee00ad9fffb4a21aa6eff7
Author: Jia Tan <jiat0218@gmail.com>
Date: 2023-04-19 21:59:03 +0800
@@ -1652,7 +6959,7 @@ Date: 2023-04-19 21:59:03 +0800
src/common/tuklib_integer.h | 6 +++---
1 file changed, 3 insertions(+), 3 deletions(-)
-commit d1f0e01c395960efd6c29ff144eda4f4c8c1c6d3
+commit 3938718ce3773c90755785c0df8777f133b7ae29
Author: Lasse Collin <lasse.collin@tukaani.org>
Date: 2023-04-14 18:42:33 +0300
@@ -1663,7 +6970,7 @@ Date: 2023-04-14 18:42:33 +0300
src/liblzma/api/lzma.h | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)
-commit 8204c5d1304e1e3b7487801b4acaf8e3179a6c52
+commit 2a89670ab295e377f8b44f5bda6d198deb8ea285
Author: Jia Tan <jiat0218@gmail.com>
Date: 2023-04-13 20:45:19 +0800
@@ -1672,7 +6979,69 @@ Date: 2023-04-13 20:45:19 +0800
src/liblzma/common/alone_encoder.c | 11 -----------
1 file changed, 11 deletions(-)
-commit 32980d1562bc031013306be1c787761fa63da87d
+commit 0fbb2b87a7b5a1dd9d0f4a5e84ac7919557dbe81
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2023-04-07 20:46:41 +0800
+
+ Docs: Add missing word to SECURITY.md.
+
+ .github/SECURITY.md | 2 +-
+ 1 file changed, 1 insertion(+), 1 deletion(-)
+
+commit fb9c50f38a17bf37581de4034b36c8df8ec90a87
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2023-04-07 20:43:22 +0800
+
+ Update THANKS.
+
+ THANKS | 1 +
+ 1 file changed, 1 insertion(+)
+
+commit 537c6cd8a9db0dd6b13683e64ddac2943190d715
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2023-04-07 20:42:12 +0800
+
+ Docs: Minor edits to SECURITY.md.
+
+ .github/SECURITY.md | 25 ++++++++++++++++++++-----
+ 1 file changed, 20 insertions(+), 5 deletions(-)
+
+commit 6549df8dd53f358345957e232648fdb699930074
+Author: Gabriela Gutierrez <gabigutierrez@google.com>
+Date: 2023-04-07 12:08:30 +0000
+
+ Docs: Create SECURITY.md
+
+ Signed-off-by: Gabriela Gutierrez <gabigutierrez@google.com>
+
+ .github/SECURITY.md | 14 ++++++++++++++
+ 1 file changed, 14 insertions(+)
+
+commit d0faa85df5a5d253a4625d45313cf5e9277e6cd2
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2023-03-28 22:48:24 +0800
+
+ CI: Tests for disabling threading on CMake builds.
+
+ .github/workflows/ci.yml | 3 ---
+ build-aux/ci_build.sh | 4 ++--
+ 2 files changed, 2 insertions(+), 5 deletions(-)
+
+commit 8be5cc3b1359d88b4b30a39067466c0ae0bfbc4d
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2023-03-28 22:45:42 +0800
+
+ CI: Removes CMakeCache.txt between builds.
+
+ If the cache file is not removed, CMake will not reset configurations
+ back to their default values. In order to make the tests independent, it
+ is simplest to purge the cache. Unfortunatly, this will slow down the
+ tests a little and repeat some checks.
+
+ build-aux/ci_build.sh | 2 ++
+ 1 file changed, 2 insertions(+)
+
+commit 2cb6028fc31de082b7f927632363bb1426b61aaa
Author: Jia Tan <jiat0218@gmail.com>
Date: 2023-03-28 22:32:40 +0800
@@ -1684,7 +7053,7 @@ Date: 2023-03-28 22:32:40 +0800
CMakeLists.txt | 33 ++++++++++++++++++++++-----------
1 file changed, 22 insertions(+), 11 deletions(-)
-commit 023907faa965476fb921a6344253c50e0ba795f9
+commit 4d7fac0b07cc722825ba8d7838c558827e635611
Author: Jia Tan <jiat0218@gmail.com>
Date: 2023-03-28 22:25:33 +0800
@@ -1704,7 +7073,48 @@ Date: 2023-03-28 22:25:33 +0800
CMakeLists.txt | 144 +++++++++++++++++++++++++++++++++++++++++----------------
1 file changed, 104 insertions(+), 40 deletions(-)
-commit ba176d77cbb164b13006516660fc1ff6c59dedb5
+commit 20cd905d898c1494dee42b78530769bb9c9f8076
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2023-03-24 23:05:48 +0800
+
+ CI: Runs CMake feature tests.
+
+ Now, CMake will run similar feature disable tests that the Autotools
+ version did before. In order to do this without repeating lines in
+ ci.yml, it now makes sense to use the GitHub Workflow matrix to create
+ a loop.
+
+ .github/workflows/ci.yml | 169 +++++++++++++++--------------------------------
+ 1 file changed, 55 insertions(+), 114 deletions(-)
+
+commit 4fabdb269f1fc5624b3b94a170c4efb329d1d229
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2023-03-24 20:35:11 +0800
+
+ CI: ci_build.sh allows CMake features to be configured.
+
+ Also included various clean ups for style and helper functions for
+ repeated work.
+
+ build-aux/ci_build.sh | 233 +++++++++++++++++++++++++++++++-------------------
+ 1 file changed, 143 insertions(+), 90 deletions(-)
+
+commit cf3d1f130e50cf63da4bb1031771605f6f443b6a
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2023-03-24 20:06:33 +0800
+
+ CI: Change ci_build.sh to use bash instead of sh.
+
+ This script is only meant to be run as part of the CI build/test process
+ on machines that are known to have bash (Ubuntu and MacOS). If this
+ assumption changes in the future, then the bash specific commands will
+ need to be replaced with a more portable option. For now, it is
+ convenient to use bash commands.
+
+ build-aux/ci_build.sh | 2 +-
+ 1 file changed, 1 insertion(+), 1 deletion(-)
+
+commit ddfe164368e779c40d061aa4ccc376129e92f8e1
Author: Jia Tan <jiat0218@gmail.com>
Date: 2023-03-24 20:05:59 +0800
@@ -1713,7 +7123,7 @@ Date: 2023-03-24 20:05:59 +0800
CMakeLists.txt | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)
-commit c99d697df800e9bc47e09facf88bcfdb9e0264a5
+commit 116e81f002c503d3c3cd12726db8f9116e58ef25
Author: Jia Tan <jiat0218@gmail.com>
Date: 2023-03-22 15:42:04 +0800
@@ -1722,7 +7132,7 @@ Date: 2023-03-22 15:42:04 +0800
src/liblzma/lzma/Makefile.inc | 5 +----
1 file changed, 1 insertion(+), 4 deletions(-)
-commit 54a2fd8c850e626343b79c4cc8fcac2f638ec890
+commit 0ba234f692772595329d225462d391fe2c199d0a
Author: Lasse Collin <lasse.collin@tukaani.org>
Date: 2023-03-23 15:14:29 +0200
@@ -1735,7 +7145,7 @@ Date: 2023-03-23 15:14:29 +0200
CMakeLists.txt | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)
-commit 622d0fdc02d5f565c2872d79bc70c669c95c8284
+commit b0891684b4436aed31510fddcbb218d513bd5489
Author: Jia Tan <jiat0218@gmail.com>
Date: 2023-03-21 23:36:00 +0800
@@ -1744,7 +7154,7 @@ Date: 2023-03-21 23:36:00 +0800
CMakeLists.txt | 9 +++++++--
1 file changed, 7 insertions(+), 2 deletions(-)
-commit 3e2dc523c596cd770a6a7c58cacc0d0d8761e853
+commit 2c1a830efb61d9d65906a09c9ee3ce27c2c49227
Author: Jia Tan <jiat0218@gmail.com>
Date: 2023-02-25 11:46:50 +0800
@@ -1758,7 +7168,7 @@ Date: 2023-02-25 11:46:50 +0800
CMakeLists.txt | 528 ++++++++++++++++++++++++++++++++++++++++++---------------
1 file changed, 391 insertions(+), 137 deletions(-)
-commit 0c053f97337fa4ead77acefb577e8e86f8ef388d
+commit 8be136f667aaeb8f9e16fbd57a83cb282f0c27ff
Author: Lasse Collin <lasse.collin@tukaani.org>
Date: 2023-03-21 14:07:51 +0200
@@ -1770,7 +7180,7 @@ Date: 2023-03-21 14:07:51 +0200
configure.ac | 3 +++
1 file changed, 3 insertions(+)
-commit 915d4f6058d52f84d2b58b0a5f3c8272eaa6c1bd
+commit 53cc475f2652d9e390ca002018dfd0af0626ef80
Author: Lasse Collin <lasse.collin@tukaani.org>
Date: 2023-03-21 14:04:37 +0200
@@ -1784,7 +7194,7 @@ Date: 2023-03-21 14:04:37 +0200
configure.ac | 30 +++++++++++++++---------------
1 file changed, 15 insertions(+), 15 deletions(-)
-commit b848c039586ed2cddb6fb033680dac107cc5143f
+commit 3b8890a40233b6c783bb101ec14405e786871775
Author: Lasse Collin <lasse.collin@tukaani.org>
Date: 2023-03-21 13:12:03 +0200
@@ -1793,7 +7203,7 @@ Date: 2023-03-21 13:12:03 +0200
THANKS | 1 +
1 file changed, 1 insertion(+)
-commit c775ba1602a74f29dbc2088bbe4d02c23fc32ba1
+commit 5a5bd7f871818029d5ccbe189f087f591258c294
Author: Lasse Collin <lasse.collin@tukaani.org>
Date: 2023-03-21 13:11:49 +0200
@@ -1823,7 +7233,7 @@ Date: 2023-03-21 13:11:49 +0200
configure.ac | 16 ++++++++--------
1 file changed, 8 insertions(+), 8 deletions(-)
-commit 0673c9ec98b6bae12b33dc295564514aaa26e2fc
+commit dfe1710784c0a3c3a90c17b80c9e1fe19b5fce06
Author: Lasse Collin <lasse.collin@tukaani.org>
Date: 2023-03-19 22:45:59 +0200
@@ -1835,17 +7245,7 @@ Date: 2023-03-19 22:45:59 +0200
src/liblzma/common/memcmplen.h | 3 ++-
1 file changed, 2 insertions(+), 1 deletion(-)
-commit 6ca8046ecbc7a1c81ee08f544bfd1414819fb2e8
-Author: Jia Tan <jiat0218@gmail.com>
-Date: 2023-03-18 23:22:06 +0800
-
- Bump version and soname for 5.4.2.
-
- src/liblzma/Makefile.am | 2 +-
- src/liblzma/api/lzma/version.h | 2 +-
- 2 files changed, 2 insertions(+), 2 deletions(-)
-
-commit ce4f246600db10e77fc93d492ea045b4c9830bc6
+commit f0c580c5fc38bf49a184b48d76c1d8c057d499ce
Author: Jia Tan <jiat0218@gmail.com>
Date: 2023-03-18 22:10:57 +0800
@@ -1854,7 +7254,16 @@ Date: 2023-03-18 22:10:57 +0800
NEWS | 48 ++++++++++++++++++++++++++++++++++++++++++++++++
1 file changed, 48 insertions(+)
-commit 3634fe330788fc0df217acdb6581031a851600a3
+commit af4925e6043113ec9b5f9c0cf13abf2a18ccb1f6
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2023-03-18 22:10:12 +0800
+
+ Add NEWS for 5.2.11.
+
+ NEWS | 27 +++++++++++++++++++++++++++
+ 1 file changed, 27 insertions(+)
+
+commit 5a7b930efa7f9849d8da8397e8e5d8638f92be40
Author: Lasse Collin <lasse.collin@tukaani.org>
Date: 2023-03-18 16:00:54 +0200
@@ -1863,7 +7272,7 @@ Date: 2023-03-18 16:00:54 +0200
COPYING.GPLv3 | 8 ++++----
1 file changed, 4 insertions(+), 4 deletions(-)
-commit 97679d25ce7cb014328f1455bb338903c003d54f
+commit b473a92891f7e991398a3b5eff305f6f2b6d7293
Author: Lasse Collin <lasse.collin@tukaani.org>
Date: 2023-03-18 15:51:57 +0200
@@ -1881,7 +7290,7 @@ Date: 2023-03-18 15:51:57 +0200
windows/INSTALL-MinGW.txt | 10 +++++-----
8 files changed, 19 insertions(+), 19 deletions(-)
-commit 01a67e89a56c3ebf5f6681bd06f0edc22a1ae594
+commit 8b2f6001b4f412c259a7883427f2f2c8cea98ea8
Author: Jia Tan <jiat0218@gmail.com>
Date: 2023-03-18 00:40:28 +0800
@@ -1890,7 +7299,7 @@ Date: 2023-03-18 00:40:28 +0800
CMakeLists.txt | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)
-commit 5dca3f5cbab31105196c89cd6df0a9bbc3307c05
+commit 76e2315e14c399c15cc90e7930fd4d3d086b0227
Author: Lasse Collin <lasse.collin@tukaani.org>
Date: 2023-03-17 18:36:22 +0200
@@ -1899,7 +7308,7 @@ Date: 2023-03-17 18:36:22 +0200
windows/build.bash | 3 ++-
1 file changed, 2 insertions(+), 1 deletion(-)
-commit ae252862b30b509ab88b2bbcaa08e8d51b57e928
+commit 133cf55edc5ce92952d2709abd992e48ef1f45ee
Author: Lasse Collin <lasse.collin@tukaani.org>
Date: 2023-03-17 08:53:38 +0200
@@ -1915,7 +7324,7 @@ Date: 2023-03-17 08:53:38 +0200
windows/vs2019/liblzma_dll.vcxproj | 2 ++
6 files changed, 12 insertions(+)
-commit 147d282cc3733e2723df82622b6540ddfb52635e
+commit 75c9ca450fab6982fda9286b168081c9d54126cd
Author: Lasse Collin <lasse.collin@tukaani.org>
Date: 2023-03-17 08:43:51 +0200
@@ -1926,7 +7335,7 @@ Date: 2023-03-17 08:43:51 +0200
CMakeLists.txt | 2 ++
1 file changed, 2 insertions(+)
-commit 4523a5ee29f45c0256af67a15771bc8bbd25ba53
+commit 0cc3313bd4e569c51e686e5aab8c40c35241d34b
Author: Lasse Collin <lasse.collin@tukaani.org>
Date: 2023-03-17 08:41:36 +0200
@@ -1936,7 +7345,7 @@ Date: 2023-03-17 08:41:36 +0200
m4/tuklib_integer.m4 | 4 ++--
2 files changed, 5 insertions(+), 6 deletions(-)
-commit 82aacb40367dc580b09c5a7b270f6c98b63e49b9
+commit 5e57e3301319f20c35f8111dea73fa58403b96b1
Author: Lasse Collin <lasse.collin@tukaani.org>
Date: 2023-03-17 00:02:30 +0200
@@ -1945,7 +7354,7 @@ Date: 2023-03-17 00:02:30 +0200
.gitignore | 3 ++-
1 file changed, 2 insertions(+), 1 deletion(-)
-commit 5d022c24921eec938604a8cb10d70aa08dbd8575
+commit 0007394d54e21bf30abb9a5e09cbc1e8d44a73ac
Author: Lasse Collin <lasse.collin@tukaani.org>
Date: 2023-03-14 20:04:03 +0200
@@ -1954,7 +7363,7 @@ Date: 2023-03-14 20:04:03 +0200
po4a/update-po | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)
-commit 896295117324f323c0b8db6a31ad6ebfaa88793d
+commit 509157c80c500426ec853bd992d684ebafc8500c
Author: Jia Tan <jiat0218@gmail.com>
Date: 2023-03-17 01:30:36 +0800
@@ -1972,7 +7381,7 @@ Date: 2023-03-17 01:30:36 +0800
doxygen/update-doxygen | 18 +++++++++---------
5 files changed, 22 insertions(+), 22 deletions(-)
-commit 94097157fae308b2c1a5edb4e8597c68b45eeaea
+commit fd90e2f4c29180b44e33c7ef726f94e4eae54ed3
Author: Jia Tan <jiat0218@gmail.com>
Date: 2023-03-16 22:07:15 +0800
@@ -1984,7 +7393,19 @@ Date: 2023-03-16 22:07:15 +0800
src/liblzma/api/lzma/bcj.h | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)
-commit da16d0b73b79d7785ece6f78a577fadd1fb59d0e
+commit 4f50763b981f9056c5f1763dfb26cfa4a26a181d
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2023-03-16 21:44:02 +0800
+
+ CI: Add doxygen as a dependency.
+
+ Autogen now requires --no-doxygen or having doxygen installed to run
+ without errors.
+
+ .github/workflows/ci.yml | 5 ++---
+ 1 file changed, 2 insertions(+), 3 deletions(-)
+
+commit f68f4b27f62f53fdac570885a1f4f23367ce6599
Author: Lasse Collin <lasse.collin@tukaani.org>
Date: 2023-03-15 19:19:13 +0200
@@ -1993,7 +7414,7 @@ Date: 2023-03-15 19:19:13 +0200
COPYING | 11 +++++++++++
1 file changed, 11 insertions(+)
-commit e57c74f9ef19201f72c106f2c347596f40229936
+commit 8979308528c1f45cb9ee52d511f05232b4ad90a1
Author: Jia Tan <jiat0218@gmail.com>
Date: 2023-03-16 21:41:09 +0800
@@ -2002,7 +7423,7 @@ Date: 2023-03-16 21:41:09 +0800
PACKAGERS | 22 ++++++++++++++++------
1 file changed, 16 insertions(+), 6 deletions(-)
-commit 7e2fa48bb73edb25457232e2e62a4f81c6b95281
+commit 55ba6e93004842ae0a0792214a23504267ad8f43
Author: Jia Tan <jiat0218@gmail.com>
Date: 2023-03-16 21:38:32 +0800
@@ -2041,7 +7462,7 @@ Date: 2023-03-16 21:38:32 +0800
src/liblzma/api/lzma/vli.h | 2 --
15 files changed, 2 insertions(+), 29 deletions(-)
-commit d42977c7acfdf7fd9acc8803cf411eca7dc10478
+commit 16f21255597f6a57e5692780f962cdc090f62b8c
Author: Jia Tan <jiat0218@gmail.com>
Date: 2023-03-16 21:37:32 +0800
@@ -2054,7 +7475,7 @@ Date: 2023-03-16 21:37:32 +0800
autogen.sh | 35 +++++++++++++++++++++++++++++------
1 file changed, 29 insertions(+), 6 deletions(-)
-commit 8fc712fcf41d821069c670f22b8bf628e7a4a877
+commit 1321852a3be7196bd7fcfd146221a5669e46407c
Author: Jia Tan <jiat0218@gmail.com>
Date: 2023-03-16 21:35:55 +0800
@@ -2078,7 +7499,7 @@ Date: 2023-03-16 21:35:55 +0800
doxygen/update-doxygen | 111 +++++++++++++++++++++++++++++++++++++++++++++++++
2 files changed, 112 insertions(+)
-commit 77d2c025d19fbac7277c63239cfb1338f02c66c0
+commit b1216a7772952d2fe7fe9c6acfcbd98d30abbc7b
Author: Jia Tan <jiat0218@gmail.com>
Date: 2023-03-16 21:34:36 +0800
@@ -2094,9 +7515,9 @@ Date: 2023-03-16 21:34:36 +0800
Makefile.am | 18 ++++++++++++++++++
1 file changed, 18 insertions(+)
-commit 9af8f6f947a43974a4ff025f4c896f2fb4c91b4f
-Author: Jia Tan <jiat0218@gmail.com>
-Date: 2023-01-03 20:37:30 +0800
+commit c97d12f300b2a94c9f54a44c8931c8bc08cf0a73
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2023-03-16 21:23:48 +0800
Doxygen: Refactor Doxyfile.in to doxygen/Doxyfile.
@@ -2113,14 +7534,13 @@ Date: 2023-01-03 20:37:30 +0800
internal is for people who want to understand how xz and liblzma work.
It might be useful for people who want to contribute to the project.
- .gitignore | 3 +-
- Doxyfile.in | 1234 -------------------------
- Makefile.am | 1 -
- configure.ac | 1 -
- doxygen/Doxyfile | 2684 ++++++++++++++++++++++++++++++++++++++++++++++++++++++
- 5 files changed, 2686 insertions(+), 1237 deletions(-)
+ .gitignore | 3 +-
+ Makefile.am | 1 -
+ configure.ac | 40 ---
+ Doxyfile.in => doxygen/Doxyfile | 721 +++++++++++++++++++++++++---------------
+ 4 files changed, 456 insertions(+), 309 deletions(-)
-commit 1c558a26928b753fcf1c0d4bce9c0643285edd86
+commit 1b7661faa4bbf4a54c6b75900b5059835c382a0f
Author: Jia Tan <jiat0218@gmail.com>
Date: 2023-02-28 23:22:36 +0800
@@ -2129,7 +7549,17 @@ Date: 2023-02-28 23:22:36 +0800
tests/tests.h | 75 -----------------------------------------------------------
1 file changed, 75 deletions(-)
-commit 7479a69a45a1b8fdb9a209e11f247dce11ac1ba0
+commit af55191102f01e76de658c881299f0909ca0feda
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2022-12-29 21:52:15 +0800
+
+ liblzma: Defines masks for return values from lzma_index_checks().
+
+ src/liblzma/api/lzma/index.h | 23 +++++++++++++++++++++++
+ tests/test_index.c | 22 +++++++++++-----------
+ 2 files changed, 34 insertions(+), 11 deletions(-)
+
+commit 8f38cdd9ab71e2a9d5a9787550222b7578243b73
Author: Jia Tan <jiat0218@gmail.com>
Date: 2023-01-12 22:29:07 +0800
@@ -2142,7 +7572,20 @@ Date: 2023-01-12 22:29:07 +0800
tests/test_index.c | 2036 ++++++++++++++++++++++++++++++++++++++--------------
1 file changed, 1492 insertions(+), 544 deletions(-)
-commit fd56d5353360279c10e8e5e05f5bc6ea03f64584
+commit 717aa3651ce582807f379d8654c2516e1594df77
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2023-03-11 18:42:08 +0200
+
+ xz: Simplify the error-label in Capsicum sandbox code.
+
+ Also remove unneeded "sandbox_allowed = false;" as this code
+ will never be run more than once (making it work with multiple
+ input files isn't trivial).
+
+ src/xz/file_io.c | 27 ++++++++++++---------------
+ 1 file changed, 12 insertions(+), 15 deletions(-)
+
+commit a0eecc235d3ba8ad3453da98b46c7bc3e644de75
Author: Lasse Collin <lasse.collin@tukaani.org>
Date: 2023-03-07 19:59:23 +0200
@@ -2151,63 +7594,69 @@ Date: 2023-03-07 19:59:23 +0200
src/xz/file_io.c | 8 ++++++++
1 file changed, 8 insertions(+)
-commit d1bdaaebc68cae7f0ba457fa990b520df2186fd1
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2023-03-11 19:31:40 +0200
+commit 916448d624aaf55cef0fc3e53754affb8c4f309d
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2023-03-08 23:08:46 +0800
- xz: Don't fail if Capsicum is enabled but kernel doesn't support it.
-
- (This commit combines related commits from the master branch.)
-
- If Capsicum support is missing from the kernel or xz is being run
- in an emulator that lacks Capsicum suport, the syscalls will fail
- and set errno to ENOSYS. Previously xz would display and error and
- exit, making xz unusable. Now it will check for ENOSYS and run
- without sandbox support. Other tools like ssh behave similarly.
-
- Displaying a warning for missing Capsicum support was considered
- but such extra output would quickly become annoying. It would also
- break test_scripts.sh in "make check".
-
- Also move cap_enter() to be the first step instead of the last one.
- This matches the example in the cap_rights_limit(2) man page. With
- the current code it shouldn't make any practical difference though.
+ Revert: "Add warning if Capsicum sandbox system calls are unsupported."
- Thanks to Xin Li for the bug report, suggesting a fix, and testing:
- https://github.com/tukaani-project/xz/pull/43
+ The warning causes the exit status to be 2, so this will cause problems
+ for many scripted use cases for xz. The sandbox usage is already very
+ limited already, so silently disabling this allows it to be more usable.
+
+ src/xz/file_io.c | 10 ++++------
+ 1 file changed, 4 insertions(+), 6 deletions(-)
+
+commit 01587dda2a8f13fef7e12fd624e6d05da5f9624f
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2023-03-07 20:02:22 +0800
+
+ xz: Fix -Wunused-label in io_sandbox_enter().
- Thanks to Jia Tan for most of the original commits.
+ Thanks to Xin Li for recommending the fix.
- src/xz/file_io.c | 15 ++++++++++++---
- 1 file changed, 12 insertions(+), 3 deletions(-)
+ src/xz/file_io.c | 4 ++--
+ 1 file changed, 2 insertions(+), 2 deletions(-)
-commit 5d351c69c19d212ddd2cf1f3bdb24900820c6776
+commit 5fb936786601a1cd013a5d436adde65982b1e13c
Author: Jia Tan <jiat0218@gmail.com>
-Date: 2023-02-04 21:06:35 +0800
+Date: 2023-03-06 21:37:45 +0800
- Build: Adjust CMake version search regex.
+ xz: Add warning if Capsicum sandbox system calls are unsupported.
- Now, the LZMA_VERSION_MAJOR, LZMA_VERSION_MINOR, and LZMA_VERSION_PATCH
- macros do not need to be on consecutive lines in version.h. They can be
- separated by more whitespace, comments, or even other content, as long
- as they appear in the proper order (major, minor, patch).
+ The warning is only used when errno == ENOSYS. Otherwise, xz still
+ issues a fatal error.
- CMakeLists.txt | 2 ++
+ src/xz/file_io.c | 2 ++
1 file changed, 2 insertions(+)
-commit b82d4831e3f2339c4cdbc47776c99462088c11b7
+commit 61ee82cb1232a402c82282bbae42821f2b952b0d
Author: Jia Tan <jiat0218@gmail.com>
-Date: 2023-01-26 09:50:21 +0800
+Date: 2023-03-06 21:27:53 +0800
- liblzma: Improve documentation for version.h.
+ xz: Skip Capsicum sandbox system calls when they are unsupported.
- Specified parameter and return values for API functions and documented
- a few more of the macros.
+ If a system has the Capsicum header files but does not actually
+ implement the system calls, then this would render xz unusable. Instead,
+ we can check if errno == ENOSYS and not issue a fatal error.
- src/liblzma/api/lzma/version.h | 29 ++++++++++++++++++++++-------
- 1 file changed, 22 insertions(+), 7 deletions(-)
+ src/xz/file_io.c | 22 +++++++++++++++++-----
+ 1 file changed, 17 insertions(+), 5 deletions(-)
+
+commit f070722b57ba975a0dff36492d766f03026b1d21
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2023-03-06 21:08:26 +0800
+
+ xz: Reorder cap_enter() to beginning of capsicum sandbox code.
+
+ cap_enter() puts the process into the sandbox. If later calls to
+ cap_rights_limit() fail, then the process can still have some extra
+ protections.
+
+ src/xz/file_io.c | 6 +++---
+ 1 file changed, 3 insertions(+), 3 deletions(-)
-commit 2caba3efe3e0c2d7c6dca00e22c56812326a34e6
+commit f1ab1f6b339d16a53ac53efeb97779ecd2bae70f
Author: Jia Tan <jiat0218@gmail.com>
Date: 2023-02-24 23:46:23 +0800
@@ -2225,7 +7674,7 @@ Date: 2023-02-24 23:46:23 +0800
src/liblzma/api/lzma/lzma12.h | 5 +++++
1 file changed, 5 insertions(+)
-commit 594f904673ba55a833adfa60bbab6b60d4902d08
+commit 4b7fb3bf41a0ca4c97fad3799949a2aa61b13b99
Author: Lasse Collin <lasse.collin@tukaani.org>
Date: 2023-02-27 18:38:35 +0200
@@ -2238,7 +7687,7 @@ Date: 2023-02-27 18:38:35 +0200
CMakeLists.txt | 8 ++++++++
1 file changed, 8 insertions(+)
-commit 88101143cb774bca6b7006c8335b09dc3f334140
+commit 9aa7fdeb04c486d2700967090956af88fdccab7e
Author: Jia Tan <jiat0218@gmail.com>
Date: 2023-02-24 18:10:37 +0800
@@ -2251,7 +7700,7 @@ Date: 2023-02-24 18:10:37 +0800
tests/test_vli.c | 2 ++
1 file changed, 2 insertions(+)
-commit 4042dbf03a06e019ccdd1e9d1b94cf613d62d5a9
+commit 3cf72c4bcba5370f07477c9b9b62ae33069ef9a9
Author: Jia Tan <jiat0218@gmail.com>
Date: 2023-02-06 21:46:43 +0800
@@ -2263,7 +7712,7 @@ Date: 2023-02-06 21:46:43 +0800
src/liblzma/api/lzma/filter.h | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)
-commit 3971f5c5024750ce8286891c6f79ae1661047483
+commit 002006be62d77c706565fa6ec828bea64be302da
Author: Jia Tan <jiat0218@gmail.com>
Date: 2023-02-06 21:45:37 +0800
@@ -2275,7 +7724,7 @@ Date: 2023-02-06 21:45:37 +0800
src/liblzma/api/lzma/filter.h | 8 ++------
1 file changed, 2 insertions(+), 6 deletions(-)
-commit 5e61b39432752b6cd1a7b518f0f9e4f0c3f0f242
+commit 463d9359b8595f01d44ada1739d75aeb87f36524
Author: Jia Tan <jiat0218@gmail.com>
Date: 2023-02-06 21:44:45 +0800
@@ -2284,7 +7733,7 @@ Date: 2023-02-06 21:44:45 +0800
src/liblzma/api/lzma/filter.h | 10 +++++-----
1 file changed, 5 insertions(+), 5 deletions(-)
-commit 8a53533869defa1191b41f176a0312cb53a139e2
+commit 01441df92c0fd6a6c02fe5ac27982a54ce887cc0
Author: Jia Tan <jiat0218@gmail.com>
Date: 2023-02-06 21:35:06 +0800
@@ -2301,7 +7750,7 @@ Date: 2023-02-06 21:35:06 +0800
src/liblzma/api/lzma/filter.h | 226 ++++++++++++++++++++++++++----------------
1 file changed, 143 insertions(+), 83 deletions(-)
-commit 6d05b08b17ac8cb93165ee8f310fdd925b0b258f
+commit 805b45cd60bfd5da3d3d89077de3789df179b324
Author: Lasse Collin <lasse.collin@tukaani.org>
Date: 2023-02-23 20:46:16 +0200
@@ -2310,7 +7759,7 @@ Date: 2023-02-23 20:46:16 +0200
THANKS | 1 +
1 file changed, 1 insertion(+)
-commit dfc9a54082e0fc7b3b796ea15336b5075acc79d5
+commit 30e95bb44c36ae26b2ab12a94343b215fec285e7
Author: Lasse Collin <lasse.collin@tukaani.org>
Date: 2023-02-21 22:57:10 +0200
@@ -2394,7 +7843,7 @@ Date: 2023-02-21 22:57:10 +0200
src/liblzma/simple/simple_coder.c | 6 ++++--
10 files changed, 77 insertions(+), 23 deletions(-)
-commit f6dce49cb656b358e2fb2a3032e35e20af34dc84
+commit fa9065fac54194fe0407fc7f0cc9633fdce13c21
Author: Jia Tan <jiat0218@gmail.com>
Date: 2023-02-07 00:00:44 +0800
@@ -2403,7 +7852,7 @@ Date: 2023-02-07 00:00:44 +0800
src/liblzma/api/lzma/container.h | 20 +++++++++-----------
1 file changed, 9 insertions(+), 11 deletions(-)
-commit 173d240bb4763aedc8c01df4d9c83e311d954c33
+commit 00a721b63d82dfb658dca8d8cb599d8a245c663f
Author: Jia Tan <jiat0218@gmail.com>
Date: 2023-02-07 00:00:09 +0800
@@ -2412,7 +7861,7 @@ Date: 2023-02-07 00:00:09 +0800
src/liblzma/api/lzma/container.h | 13 ++++++-------
1 file changed, 6 insertions(+), 7 deletions(-)
-commit 17797bacde3f7264048ef0976c137a600148d6cf
+commit 5b1c171d4ffe89ef18fa31509bb0185d6fd11d39
Author: Jia Tan <jiat0218@gmail.com>
Date: 2023-02-06 23:42:08 +0800
@@ -2421,7 +7870,7 @@ Date: 2023-02-06 23:42:08 +0800
src/liblzma/api/lzma/container.h | 9 ++++++---
1 file changed, 6 insertions(+), 3 deletions(-)
-commit 37da0e727161b401b8bfd8dccf163a4b2fc0460b
+commit dbd47622eb99fefb3538a22baec3def002aa56f5
Author: Jia Tan <jiat0218@gmail.com>
Date: 2023-01-26 23:17:41 +0800
@@ -2432,7 +7881,7 @@ Date: 2023-01-26 23:17:41 +0800
src/liblzma/api/lzma/container.h | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)
-commit b8331077c626e6bf14f4671d09b561146eaf816a
+commit 14cd30806d69e55906073745bcce3ee50e0ec942
Author: Jia Tan <jiat0218@gmail.com>
Date: 2023-01-26 23:16:34 +0800
@@ -2445,7 +7894,7 @@ Date: 2023-01-26 23:16:34 +0800
src/liblzma/api/lzma/container.h | 146 +++++++++++++++++++++++++--------------
1 file changed, 93 insertions(+), 53 deletions(-)
-commit b9a3511bb61d3b6ce49abd33dce6155a573f5272
+commit c9c8bfae3502842dcead85eeb2b951b437c2cd88
Author: Jia Tan <jiat0218@gmail.com>
Date: 2023-02-22 20:59:41 +0800
@@ -2454,7 +7903,7 @@ Date: 2023-02-22 20:59:41 +0800
CMakeLists.txt | 1 +
1 file changed, 1 insertion(+)
-commit cd82ef2fb48b174c57cd03b84a9a0f978772cb89
+commit b9f171dd00a3cc32b6d41ea8e082cf545640ec2a
Author: Lasse Collin <lasse.collin@tukaani.org>
Date: 2023-02-17 20:56:49 +0200
@@ -2463,7 +7912,7 @@ Date: 2023-02-17 20:56:49 +0200
THANKS | 1 +
1 file changed, 1 insertion(+)
-commit 076e911ba25cadf2cbdfbd0f65991a002e210c0b
+commit 2ee86d20e49985b903b78ebcfa3fa672e73e93aa
Author: Lasse Collin <lasse.collin@tukaani.org>
Date: 2023-02-17 20:48:28 +0200
@@ -2506,7 +7955,7 @@ Date: 2023-02-17 20:48:28 +0200
configure.ac | 12 ++++++++++--
1 file changed, 10 insertions(+), 2 deletions(-)
-commit bc34e5ac9996667d2c1ec9a7895ec5931ac4caea
+commit d831072cceca458d94d2d5da201862f6d43a417b
Author: Lasse Collin <lasse.collin@tukaani.org>
Date: 2023-02-16 21:09:00 +0200
@@ -2526,7 +7975,7 @@ Date: 2023-02-16 21:09:00 +0200
src/liblzma/api/lzma/stream_flags.h | 6 +++---
4 files changed, 14 insertions(+), 14 deletions(-)
-commit d31fbd28be5b79eb682db50004b0fb7aad5299ec
+commit f029daea39c215fd7d5cb6b6798818b055cf5b22
Author: Jia Tan <jiat0218@gmail.com>
Date: 2023-02-17 00:54:33 +0800
@@ -2535,7 +7984,7 @@ Date: 2023-02-17 00:54:33 +0800
src/liblzma/api/lzma/bcj.h | 14 +++++++-------
1 file changed, 7 insertions(+), 7 deletions(-)
-commit 701e9be6bede19771895f756082db0c017f86f07
+commit a5de68bac2bb7e1b9119e6cea7d761a22ea73e9c
Author: Jia Tan <jiat0218@gmail.com>
Date: 2023-02-17 00:44:44 +0800
@@ -2544,7 +7993,7 @@ Date: 2023-02-17 00:44:44 +0800
src/liblzma/api/lzma/bcj.h | 43 ++++++++++++++++++++++---------------------
1 file changed, 22 insertions(+), 21 deletions(-)
-commit 762c4d0b62d2694cf3a01e030fdfe68e09e7b503
+commit efa498c13b883810497e0ea8a169efd6f48f5026
Author: Jia Tan <jiat0218@gmail.com>
Date: 2023-02-17 00:36:05 +0800
@@ -2561,7 +8010,7 @@ Date: 2023-02-17 00:36:05 +0800
src/liblzma/api/lzma/stream_flags.h | 32 +++++++++++++--------------
7 files changed, 95 insertions(+), 95 deletions(-)
-commit 0ce1db0223854d94b4a0d17737ac0486a75d9e6a
+commit 718b22a6c5e3ee5de123323ea798872381f9320e
Author: Lasse Collin <lasse.collin@tukaani.org>
Date: 2023-02-16 17:59:50 +0200
@@ -2576,11 +8025,11 @@ Date: 2023-02-16 17:59:50 +0200
src/liblzma/check/crc64_fast.c | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)
-commit d83da006b3e8dbad9112e6cde6b27049d193c9ec
+commit 87c53553fa7d50f777b4edfa99f2083628f590fe
Author: Jia Tan <jiat0218@gmail.com>
Date: 2023-02-16 21:04:54 +0800
- liblzma: Improve documentation for stream_flags.h
+ liblzma: Improve documentation for stream_flags.h
Standardizing each function to always specify parameters and return
values. Also moved the parameters and return values to the end of each
@@ -2591,7 +8040,7 @@ Date: 2023-02-16 21:04:54 +0800
src/liblzma/api/lzma/stream_flags.h | 76 ++++++++++++++++++++++---------------
1 file changed, 46 insertions(+), 30 deletions(-)
-commit 2796bb4736f645d34939b5d62d5958f534e41e69
+commit 13d99e75a543e9e5f8633cc241eae55b91a3b242
Author: Jia Tan <jiat0218@gmail.com>
Date: 2023-02-14 21:50:16 +0800
@@ -2602,7 +8051,7 @@ Date: 2023-02-14 21:50:16 +0800
src/liblzma/api/lzma/lzma12.h | 32 +++++++++++++++++++++++---------
1 file changed, 23 insertions(+), 9 deletions(-)
-commit ebebaa8d9381afea440eb1b01917117551adf68f
+commit 43ec344c868f930e96879eb9e49212cce92a9884
Author: Jia Tan <jiat0218@gmail.com>
Date: 2023-01-27 22:44:06 +0800
@@ -2615,7 +8064,7 @@ Date: 2023-01-27 22:44:06 +0800
src/liblzma/api/lzma/check.h | 41 ++++++++++++++++++++++++++++-------------
1 file changed, 28 insertions(+), 13 deletions(-)
-commit 765fa2865aab97ea713c1715922e322b3cf599a7
+commit 9c71db4e884fd49aea3d1e711036bff45ca66487
Author: Jia Tan <jiat0218@gmail.com>
Date: 2023-02-08 21:33:52 +0800
@@ -2626,7 +8075,7 @@ Date: 2023-02-08 21:33:52 +0800
src/liblzma/api/lzma/index.h | 177 ++++++++++++++++++++++++++++++-------------
1 file changed, 126 insertions(+), 51 deletions(-)
-commit 918e208af5960728b6def01e692b395f7d8e3701
+commit 421f2f2e160720f6009e3b6a125cafe2feaa9419
Author: Jia Tan <jiat0218@gmail.com>
Date: 2023-02-08 20:35:32 +0800
@@ -2635,7 +8084,7 @@ Date: 2023-02-08 20:35:32 +0800
src/liblzma/api/lzma/index.h | 4 ++--
1 file changed, 2 insertions(+), 2 deletions(-)
-commit 1f157d214bc09338876d2467b549935679abc0bf
+commit b67539484981351d501b68de5e925425e50c59b1
Author: Jia Tan <jiat0218@gmail.com>
Date: 2023-02-08 20:30:23 +0800
@@ -2647,7 +8096,7 @@ Date: 2023-02-08 20:30:23 +0800
src/liblzma/api/lzma/index.h | 9 ++++++++-
1 file changed, 8 insertions(+), 1 deletion(-)
-commit 28757fa46d8e0f0a9c17628b2b6af9bcb3cd96fc
+commit 0c9e4fc2ad6d88d54f299240fcc5a2ce7d695d96
Author: Jia Tan <jiat0218@gmail.com>
Date: 2023-01-21 21:32:03 +0800
@@ -2659,7 +8108,7 @@ Date: 2023-01-21 21:32:03 +0800
src/liblzma/api/lzma/base.h | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)
-commit 135d5a1a65a9e199b9a5550c1f788cf43cd81018
+commit 816fec125aa74bcef46512c73acc6d9e5a700d15
Author: Jia Tan <jiat0218@gmail.com>
Date: 2023-01-21 00:29:38 +0800
@@ -2671,7 +8120,16 @@ Date: 2023-01-21 00:29:38 +0800
src/liblzma/api/lzma/base.h | 30 +++++++++++++++++++++++++-----
1 file changed, 25 insertions(+), 5 deletions(-)
-commit 2287d5668384e289d51e72724997dc920483768e
+commit 862dacef1a4e7e1b28d465956fa4244ed01df154
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2023-02-14 00:12:34 +0800
+
+ liblzma: Add one more missing [out] annotation in vli.h
+
+ src/liblzma/api/lzma/vli.h | 2 +-
+ 1 file changed, 1 insertion(+), 1 deletion(-)
+
+commit 867b08ae4254bf55dd1f7fd502cc618231b92f75
Author: Jia Tan <jiat0218@gmail.com>
Date: 2023-02-14 00:08:33 +0800
@@ -2680,10 +8138,10 @@ Date: 2023-02-14 00:08:33 +0800
Added [out] annotations to parameters that are pointers and can have
their value changed. Also added a clarification to lzma_vli_is_valid.
- src/liblzma/api/lzma/vli.h | 15 ++++++++-------
- 1 file changed, 8 insertions(+), 7 deletions(-)
+ src/liblzma/api/lzma/vli.h | 13 +++++++------
+ 1 file changed, 7 insertions(+), 6 deletions(-)
-commit 7124b8a16ae60cb2e93218ff531868eebd673bde
+commit 90d0e628ff11e5030bcc4fc000bca056adda6603
Author: Jia Tan <jiat0218@gmail.com>
Date: 2023-02-10 21:38:02 +0800
@@ -2695,7 +8153,7 @@ Date: 2023-02-10 21:38:02 +0800
src/liblzma/api/lzma/delta.h | 8 ++++++++
1 file changed, 8 insertions(+)
-commit 59c7bb8931159fdb1a31bbbeaed0e6984e2d3c81
+commit 9255fffdb13e59874bf7f95c370c410ad3a7e114
Author: Jia Tan <jiat0218@gmail.com>
Date: 2023-02-10 21:35:23 +0800
@@ -2707,7 +8165,64 @@ Date: 2023-02-10 21:35:23 +0800
src/liblzma/api/lzma/index_hash.h | 36 +++++++++++++++++++++++++++---------
1 file changed, 27 insertions(+), 9 deletions(-)
-commit e970c28ac3cb2e8051925f81db2fe953664c2645
+commit 1dbe12b90cff79bb51923733ac0840747b4b4131
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2023-02-07 19:07:45 +0200
+
+ xz: Improve the comment about start_time in mytime.c.
+
+ start_time is relative to an arbitary point in time, it's not
+ time of day, so using it for anything else than time differences
+ wouldn't make sense.
+
+ src/xz/mytime.c | 15 ++++++++++-----
+ 1 file changed, 10 insertions(+), 5 deletions(-)
+
+commit 7673ef5aa80c1af7fb693360dd82f527b46c2c56
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2023-02-04 21:06:35 +0800
+
+ Build: Adjust CMake version search regex.
+
+ Now, the LZMA_VERSION_MAJOR, LZMA_VERSION_MINOR, and LZMA_VERSION_PATCH
+ macros do not need to be on consecutive lines in version.h. They can be
+ separated by more whitespace, comments, or even other content, as long
+ as they appear in the proper order (major, minor, patch).
+
+ CMakeLists.txt | 2 ++
+ 1 file changed, 2 insertions(+)
+
+commit b8bce89be7fb5bffe5fef4a2782ca9b2b107eaac
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2023-02-04 12:01:23 +0800
+
+ xz: Add a comment clarifying the use of start_time in mytime.c.
+
+ src/xz/mytime.c | 5 +++++
+ 1 file changed, 5 insertions(+)
+
+commit 912af91b10a18fb9bb3167247ecaaefca8248ee9
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2023-01-26 09:50:21 +0800
+
+ liblzma: Improve documentation for version.h.
+
+ Specified parameter and return values for API functions and documented
+ a few more of the macros.
+
+ src/liblzma/api/lzma/version.h | 29 ++++++++++++++++++++++-------
+ 1 file changed, 22 insertions(+), 7 deletions(-)
+
+commit 850adec171203cd22b57d016084d713f72ae5307
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2023-02-03 22:52:55 +0800
+
+ Docs: Omit SIGTSTP not handled from TODO.
+
+ TODO | 4 ----
+ 1 file changed, 4 deletions(-)
+
+commit 2c78a83c6faec70154d9eb78022a618ed62cdcb3
Author: Jia Tan <jiat0218@gmail.com>
Date: 2023-02-03 00:33:32 +0800
@@ -2720,7 +8235,7 @@ Date: 2023-02-03 00:33:32 +0800
src/liblzma/common/string_conversion.c | 7 +++++++
1 file changed, 7 insertions(+)
-commit 85e01266a96689448abb249da6c6abc3afcd4a4e
+commit e01f01b9af1c074463b92694a16ecc16a31907c0
Author: Jia Tan <jiat0218@gmail.com>
Date: 2023-02-03 00:32:47 +0800
@@ -2734,7 +8249,7 @@ Date: 2023-02-03 00:32:47 +0800
tests/test_filter_str.c | 593 ++++++++++++++++++++++++++++++++++++++++++++++++
3 files changed, 596 insertions(+)
-commit 3fa0f3ba12dd3383f62dbfa18a864f9b4217fa0a
+commit 8dfc029e7a4ce45809c30313dc0e502f0d22be26
Author: Jia Tan <jiat0218@gmail.com>
Date: 2023-01-22 08:49:00 +0800
@@ -2743,7 +8258,7 @@ Date: 2023-01-22 08:49:00 +0800
src/liblzma/common/string_conversion.c | 4 ++--
1 file changed, 2 insertions(+), 2 deletions(-)
-commit 32dbe045d74e94f75c53236fa2a6c0454d7b6d9e
+commit 54ad83c1ae2180dcc0cb2445b181dc1e9732a5d6
Author: Jia Tan <jiat0218@gmail.com>
Date: 2023-02-03 00:20:20 +0800
@@ -2756,7 +8271,7 @@ Date: 2023-02-03 00:20:20 +0800
src/liblzma/api/lzma/block.h | 15 +++++++++++----
1 file changed, 11 insertions(+), 4 deletions(-)
-commit ccf12acbfa7331b1bbb99ec55879186eb35f879f
+commit f680e771b3eb2a46310fe85b3e000ac3a1a0640f
Author: Jia Tan <jiat0218@gmail.com>
Date: 2023-02-03 00:12:24 +0800
@@ -2765,7 +8280,7 @@ Date: 2023-02-03 00:12:24 +0800
src/liblzma/api/lzma/block.h | 3 +++
1 file changed, 3 insertions(+)
-commit 6a0b168dd9dc1ef437255c4bfdc6eff8b96fdb24
+commit 504cf4af895fd45aad0c56eb3b49d90acd54465b
Author: Jia Tan <jiat0218@gmail.com>
Date: 2023-02-03 00:11:37 +0800
@@ -2774,7 +8289,7 @@ Date: 2023-02-03 00:11:37 +0800
src/liblzma/api/lzma/block.h | 3 ++-
1 file changed, 2 insertions(+), 1 deletion(-)
-commit 84ce36f90e68471fec1f0e61cd93ac7ed9ab4883
+commit 115b720fb521f99aa832d06b2c12b7f8c6c50680
Author: Jia Tan <jiat0218@gmail.com>
Date: 2023-02-03 00:11:07 +0800
@@ -2783,7 +8298,7 @@ Date: 2023-02-03 00:11:07 +0800
src/liblzma/api/lzma/block.h | 13 +++++++++++--
1 file changed, 11 insertions(+), 2 deletions(-)
-commit d6620774682830d606f57109861b6763805b3492
+commit 85ea0979adcf808a3830aefbe7a4ec884e542ea1
Author: Jia Tan <jiat0218@gmail.com>
Date: 2023-02-03 00:10:34 +0800
@@ -2792,7 +8307,7 @@ Date: 2023-02-03 00:10:34 +0800
src/liblzma/api/lzma/block.h | 3 ++-
1 file changed, 2 insertions(+), 1 deletion(-)
-commit 880adb5aa25f66a53d81c2f3acc716f7a4d373d1
+commit 1f7ab90d9ce224230a04de6b921ad6e2029023a8
Author: Jia Tan <jiat0218@gmail.com>
Date: 2023-02-03 00:07:23 +0800
@@ -2806,7 +8321,7 @@ Date: 2023-02-03 00:07:23 +0800
src/liblzma/api/lzma/block.h | 96 ++++++++++++++++++++++++++++++++++----------
1 file changed, 75 insertions(+), 21 deletions(-)
-commit b5b1b1f061c342271e4977ce5cba604a19c0ca52
+commit c563a4bc554a96bd0b6aab3c139715b7ec8f6ca3
Author: Jia Tan <jiat0218@gmail.com>
Date: 2023-02-01 23:38:30 +0800
@@ -2820,7 +8335,84 @@ Date: 2023-02-01 23:38:30 +0800
src/liblzma/api/lzma/filter.h | 5 +++--
1 file changed, 3 insertions(+), 2 deletions(-)
-commit e904e778b82b14f2779aab80d6c8f3c01a3fc54b
+commit 315c64c7e18acc59a745b68148188a73e998252b
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2023-02-01 21:43:33 +0800
+
+ CI: Update .gitignore for artifacts directory in build-aux.
+
+ The workflow action for our CI pipeline can only reference artifacts in
+ the source directory, so we should ignore these files if the ci_build.sh
+ is run locally.
+
+ .gitignore | 1 +
+ 1 file changed, 1 insertion(+)
+
+commit 2c1341f4fa06e7f487d61142aa354c433e17ec7f
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2023-02-01 21:36:46 +0800
+
+ CI: Add quotes around variables in a few places.
+
+ build-aux/ci_build.sh | 6 +++---
+ 1 file changed, 3 insertions(+), 3 deletions(-)
+
+commit 3a401b0e0c7a2658af7801dd0690256ef24149e0
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2023-02-01 21:36:22 +0800
+
+ CI: Upload test logs as artifacts if a test fails.
+
+ .github/workflows/ci.yml | 60 ++++++++++++++++++++++++++++++++++--------------
+ build-aux/ci_build.sh | 31 ++++++++++++++++++++-----
+ 2 files changed, 68 insertions(+), 23 deletions(-)
+
+commit 610dde15a88f12cc540424eb3eb3ed61f3876f74
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2023-01-27 20:02:49 +0200
+
+ xz: Use clock_gettime() even if CLOCK_MONOTONIC isn't available.
+
+ mythread.h and thus liblzma already does it.
+
+ src/xz/mytime.c | 11 ++++++++---
+ src/xz/private.h | 3 +--
+ 2 files changed, 9 insertions(+), 5 deletions(-)
+
+commit 2e02877288f6576cd4595e9ac7684f867cd47d68
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2023-01-27 19:41:19 +0200
+
+ po4a/po4a.conf: Sort the language identifiers in alphabetical order.
+
+ po4a/po4a.conf | 2 +-
+ 1 file changed, 1 insertion(+), 1 deletion(-)
+
+commit ff592c616eda274215b485cf1b8d34f060c9f3be
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2023-01-26 18:29:17 +0200
+
+ xz: Add SIGTSTP handler for progress indicator time keeping.
+
+ This way, if xz is stopped the elapsed time and estimated time
+ remaining won't get confused by the amount of time spent in
+ the stopped state.
+
+ This raises SIGSTOP. It's not clear to me if this is the correct way.
+ POSIX and glibc docs say that SIGTSTP shouldn't stop the process if
+ it is orphaned but this commit doesn't attempt to handle that.
+
+ Search for SIGTSTP in section 2.4.3:
+
+ https://pubs.opengroup.org/onlinepubs/9699919799/functions/V2_chap02.html
+
+ src/xz/mytime.c | 56 +++++++++++++++++++++++++++++++++++++++++++++++++++++++-
+ src/xz/mytime.h | 6 ++++++
+ src/xz/private.h | 12 ++++++++++++
+ src/xz/signals.c | 17 ++++++++++++++++-
+ 4 files changed, 89 insertions(+), 2 deletions(-)
+
+commit 3b1c8ac8d1d553cbb1fb22b545d2b1424c752b76
Author: Jia Tan <jiat0218@gmail.com>
Date: 2023-01-27 20:14:51 +0800
@@ -2832,7 +8424,28 @@ Date: 2023-01-27 20:14:51 +0800
po4a/pt_BR.po | 3677 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++
2 files changed, 3678 insertions(+), 1 deletion(-)
-commit e9c47e79c9584ba1126f5fa0dbe6c96e67411aa6
+commit a15a7552f9f67c4e402f5d2967324e0ccfd6fccc
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2023-01-26 17:51:06 +0200
+
+ Build: Avoid different quoting style in --enable-doxygen doc.
+
+ configure.ac | 10 +++++-----
+ 1 file changed, 5 insertions(+), 5 deletions(-)
+
+commit af5a4bd5afc089d9697756dded38feafaa987ae4
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2023-01-26 17:39:46 +0200
+
+ tuklib_physmem: Check for __has_warning before GCC version.
+
+ Clang can be configured to fake a too high GCC version so
+ this way it's more robust.
+
+ src/common/tuklib_physmem.c | 6 +++---
+ 1 file changed, 3 insertions(+), 3 deletions(-)
+
+commit f35d98e20609e0be6a04ae2604bfb7cb9d5bd5e4
Author: Jia Tan <jiat0218@gmail.com>
Date: 2023-01-24 20:48:50 +0800
@@ -2847,7 +8460,53 @@ Date: 2023-01-24 20:48:50 +0800
src/liblzma/api/lzma/filter.h | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)
-commit 99575947a58a60416c570eb78038d18a1ea4cef4
+commit 2f78ecc5939b3d97ddfc2a6bd31b50108a28d0a2
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2023-01-23 23:44:58 +0200
+
+ Revert "tuklib_common: Define __has_warning if it is not defined."
+
+ This reverts commit 82e3c968bfa10e3ff13333bd9cbbadb5988d6766.
+
+ Macros in the reserved namespace (_foo or __foo) shouldn't be #defined
+ without a very good reason. Here the alternative would have been
+ to #define tuklib_has_warning(str) to an approriate value.
+
+ Also the tuklib_* files should stay namespace clean if possible.
+
+ src/common/tuklib_common.h | 7 -------
+ 1 file changed, 7 deletions(-)
+
+commit 8366cf8738e8b7bb74c967d07bf0fd2a1878e575
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2023-01-23 23:38:34 +0200
+
+ tuklib_physmem: Clean up the way -Wcast-function-type is silenced on Windows.
+
+ __has_warning and other __has_foo macros are meant to become
+ compiler-agnostic so it's not good to check for __clang__ with it.
+
+ This also relied on tuklib_common.h for #defining __has_warning
+ which was confusing as #defining reserved macros is generally
+ not a good idea.
+
+ src/common/tuklib_physmem.c | 17 +++++++++++++----
+ 1 file changed, 13 insertions(+), 4 deletions(-)
+
+commit 683a3c7e2fcd922200c31078e5c9dd1348e90941
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2023-01-24 00:05:38 +0200
+
+ xz: Flip the return value of suffix_is_set to match the documentation.
+
+ Also edit style to match the existing coding style in the project.
+
+ src/xz/args.c | 6 +++---
+ src/xz/suffix.c | 2 +-
+ src/xz/suffix.h | 1 +
+ 3 files changed, 5 insertions(+), 4 deletions(-)
+
+commit cc5aa9ab138beeecaee5a1e81197591893ee9ca0
Author: Jia Tan <jiat0218@gmail.com>
Date: 2023-01-07 21:55:06 +0800
@@ -2855,10 +8514,10 @@ Date: 2023-01-07 21:55:06 +0800
src/xz/args.c | 8 ++++++++
src/xz/suffix.c | 26 ++++++++------------------
- src/xz/suffix.h | 8 ++++++++
- 3 files changed, 24 insertions(+), 18 deletions(-)
+ src/xz/suffix.h | 7 +++++++
+ 3 files changed, 23 insertions(+), 18 deletions(-)
-commit 76dec92fcca4a9ccd2063ed6d5d9e3474665baad
+commit 9663141274e01592a281a7f2df5d7a31a1dac8bf
Author: Jia Tan <jiat0218@gmail.com>
Date: 2023-01-20 21:53:14 +0800
@@ -2876,7 +8535,37 @@ Date: 2023-01-20 21:53:14 +0800
src/liblzma/api/lzma/stream_flags.h | 28 ++++++++++++++++++++++++
7 files changed, 173 insertions(+)
-commit bd213d06ebf92cf42eeb97e7c578bddc857f8ea8
+commit 6327a045f34d48fc5afc58ba0d32a82c94403049
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2022-12-20 21:39:59 +0800
+
+ Doxygen: Update Doxyfile.in from 1.4.7 to 1.8.17.
+
+ A few Doxygen tags were obsolete from 1.4.7. Version 1.8.17 released
+ in 2019, so this should be compatible with resonable modern distros.
+ The purpose of Doxygen these days is for docs on the website, so it
+ doesn't necessarily have to work for everyone. Just when the maintainers
+ want to update the docs.
+
+ Doxyfile.in | 2523 ++++++++++++++++++++++++++++++++++++++++++++---------------
+ 1 file changed, 1893 insertions(+), 630 deletions(-)
+
+commit bbf71b69ebf9d0d62a0af150a5c37d193b8159ad
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2023-01-03 20:37:30 +0800
+
+ Doxygen: Make Doxygen only produce liblzma API documentation by default.
+
+ Doxygen is now configurable in autotools only with
+ --enable-doxygen=[api|all]. The default is "api", which will only
+ generate HTML output for liblzma API functions. The LaTex documentation
+ output was also disabled.
+
+ Doxyfile.in | 18 +++++++++---------
+ configure.ac | 39 +++++++++++++++++++++++++++++++++++++++
+ 2 files changed, 48 insertions(+), 9 deletions(-)
+
+commit 6fcf4671b6047113c583a0919fc850987a4ec5f4
Author: Jia Tan <jiat0218@gmail.com>
Date: 2022-12-21 23:59:43 +0800
@@ -2901,7 +8590,7 @@ Date: 2022-12-21 23:59:43 +0800
src/liblzma/api/lzma/vli.h | 5 +++--
14 files changed, 42 insertions(+), 28 deletions(-)
-commit 257dbff0ba1a7bc45a74d203ece015c9f70c88cd
+commit b43ff180fb2e372adce876bfa155fc9bcf0c3db4
Author: Jia Tan <jiat0218@gmail.com>
Date: 2023-01-19 20:35:09 +0800
@@ -2913,10 +8602,48 @@ Date: 2023-01-19 20:35:09 +0800
this causes a cast-function-type warning, so the best solution is to
simply ignore the warning.
- src/common/tuklib_physmem.c | 18 ++++++++++++++++++
- 1 file changed, 18 insertions(+)
+ src/common/tuklib_physmem.c | 9 +++++++++
+ 1 file changed, 9 insertions(+)
+
+commit 82e3c968bfa10e3ff13333bd9cbbadb5988d6766
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2023-01-19 20:32:40 +0800
+
+ tuklib_common: Define __has_warning if it is not defined.
+
+ clang supports the __has_warning macro to determine if the version of
+ clang compiling the code supports a given warning. If we do not define
+ it for other compilers, it may cause a preprocessor error.
+
+ src/common/tuklib_common.h | 7 +++++++
+ 1 file changed, 7 insertions(+)
-commit 720ad4a44282a7ee59aa9920eaf495d85d245d97
+commit b2ba1a489df451cdcd93b2334e319dd06778de19
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2023-01-18 22:11:05 +0800
+
+ CI: Reorder 32-bit build first for Linux autotool builds.
+
+ The 32-bit build needs to be first so the configure cache only needs to
+ be reset one time. The 32-bit build sets the CFLAGS env variable, so any
+ build using that flag after will fail unless the cache is reset.
+
+ .github/workflows/ci.yml | 17 ++++++++++++-----
+ 1 file changed, 12 insertions(+), 5 deletions(-)
+
+commit dd1c1135741057c91e8d018be9ec4d43968b0e64
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2023-01-18 21:51:43 +0800
+
+ CI: Enable --config-cache in autotool builds.
+
+ If CFLAGS are set in a build, the cache must be cleared with
+ "make distclean", or by deleting the cache file.
+
+ build-aux/ci_build.sh | 2 +-
+ 1 file changed, 1 insertion(+), 1 deletion(-)
+
+commit d3e11477053764c003eec2daa5198c747d70ff69
Author: Jia Tan <jiat0218@gmail.com>
Date: 2023-01-16 21:35:45 +0800
@@ -2925,7 +8652,7 @@ Date: 2023-01-16 21:35:45 +0800
src/xz/coder.h | 3 ++-
1 file changed, 2 insertions(+), 1 deletion(-)
-commit 88dc19163421282369c0989e997c05f9a447edc6
+commit 123255b6ed15f4428b2aa92e4962015a5362f6bf
Author: Jia Tan <jiat0218@gmail.com>
Date: 2023-01-16 20:55:10 +0800
@@ -2939,7 +8666,7 @@ Date: 2023-01-16 20:55:10 +0800
src/xz/args.c | 3 ++-
1 file changed, 2 insertions(+), 1 deletion(-)
-commit 039e0ab13efb144642f9d99eeeb9c668e76bb430
+commit 571919c47b9ff5171ede84378620ed0a9aeb98c0
Author: Jia Tan <jiat0218@gmail.com>
Date: 2023-01-13 20:37:06 +0800
@@ -2948,7 +8675,70 @@ Date: 2023-01-13 20:37:06 +0800
po/pt_BR.po | 603 ++++++++++++++++++++++++++++++++++--------------------------
1 file changed, 344 insertions(+), 259 deletions(-)
-commit 718f7a60e740b26b8353965edaaddc7d4deb4d85
+commit 81cb02e2c22bbc036cdfaa2d2c4176f6bd60d3cf
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2023-01-12 23:43:06 +0800
+
+ CI: Disable shared and nls from various jobs in autotool runners.
+
+ Disabling shared library generation and linking should help speed up the
+ runners. The shared library is still being tested in the 32 bit build
+ and the full feature.
+
+ Disabling nls is to check for any unexpected warnings or errors.
+
+ .github/workflows/ci.yml | 56 ++++++++++++++++++++++++------------------------
+ 1 file changed, 28 insertions(+), 28 deletions(-)
+
+commit 58a052198a7bcaf6e958f87fad72e69e19a2579b
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2023-01-12 23:39:19 +0800
+
+ CI: Reorder the 32-bit job in the Ubuntu runner.
+
+ Run the 32 bit job sooner since this is a more interesting test than
+ some of the later jobs.
+
+ .github/workflows/ci.yml | 10 +++++-----
+ 1 file changed, 5 insertions(+), 5 deletions(-)
+
+commit 4110a998b83459fe2bc9bc1bec30ad68afa8f797
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2023-01-12 23:09:03 +0800
+
+ CI: Allow disabling Native Language Support.
+
+ build-aux/ci_build.sh | 9 ++++++++-
+ 1 file changed, 8 insertions(+), 1 deletion(-)
+
+commit 0dec634e705b5bf89a37c5d62d71e8511d480058
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2023-01-12 23:02:20 +0800
+
+ CI: Only run autogen.sh if it has not already run.
+
+ build-aux/ci_build.sh | 11 ++++++++---
+ 1 file changed, 8 insertions(+), 3 deletions(-)
+
+commit 32287dc8def94df4546e903495d14c132bd54cc4
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2023-01-12 22:58:36 +0800
+
+ CI: Allow disabling shared library in autotools builds.
+
+ build-aux/ci_build.sh | 9 ++++++++-
+ 1 file changed, 8 insertions(+), 1 deletion(-)
+
+commit 77d1ebcc99ddd82a300d1838f608150221931dcd
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2023-01-12 22:44:18 +0800
+
+ CI: Improve Usage readability and add -h option.
+
+ build-aux/ci_build.sh | 15 +++++++++++++--
+ 1 file changed, 13 insertions(+), 2 deletions(-)
+
+commit a8bb8358d10b059274f3cf993d9b8f490bafb268
Author: Lasse Collin <lasse.collin@tukaani.org>
Date: 2023-01-12 13:04:05 +0200
@@ -2961,7 +8751,7 @@ Date: 2023-01-12 13:04:05 +0200
configure.ac | 1 -
1 file changed, 1 deletion(-)
-commit 3ccedb09724c998c39d708c945f6da5852c39e13
+commit 52dc033d0bde0d19e3912303c6c74bae559d6498
Author: Lasse Collin <lasse.collin@tukaani.org>
Date: 2023-01-12 06:05:58 +0200
@@ -2973,7 +8763,7 @@ Date: 2023-01-12 06:05:58 +0200
src/xz/file_io.c | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)
-commit 09fbd2f0527def89e839c8907de4fe7ef6bc5019
+commit b1a6d180a363d57b2b1c89526ff3f0782bf863d3
Author: Lasse Collin <lasse.collin@tukaani.org>
Date: 2023-01-12 06:01:12 +0200
@@ -2983,7 +8773,7 @@ Date: 2023-01-12 06:01:12 +0200
src/xz/list.c | 4 ++--
2 files changed, 3 insertions(+), 3 deletions(-)
-commit 683d3f178ef1487b5418be49f331b0131a101b40
+commit 31c21c734b7c7d7428a3da7402a2cb7bc2587339
Author: Lasse Collin <lasse.collin@tukaani.org>
Date: 2023-01-12 05:38:48 +0200
@@ -2996,7 +8786,7 @@ Date: 2023-01-12 05:38:48 +0200
src/liblzma/lz/lz_encoder_mf.c | 7 ++++---
1 file changed, 4 insertions(+), 3 deletions(-)
-commit 2b8062ef94a38d0f9ad0d1b309e8748db52f5c15
+commit 37fbdfb7263522c11c7ad2685413d6295532581d
Author: Lasse Collin <lasse.collin@tukaani.org>
Date: 2023-01-12 04:46:45 +0200
@@ -3005,7 +8795,7 @@ Date: 2023-01-12 04:46:45 +0200
src/common/mythread.h | 4 ++--
1 file changed, 2 insertions(+), 2 deletions(-)
-commit b16b9c0d22227012518595c2222facc73bd833a8
+commit 5ce6ddc221d0bfb57d810d845bb65fb0aac0b008
Author: Lasse Collin <lasse.collin@tukaani.org>
Date: 2023-01-12 04:17:24 +0200
@@ -3020,7 +8810,7 @@ Date: 2023-01-12 04:17:24 +0200
configure.ac | 36 +++++++++++++++++++++++++++++++-----
1 file changed, 31 insertions(+), 5 deletions(-)
-commit c47ecd6d3909d0d3ff48dfd6e2ee41e7c7130b94
+commit bfc3a0a8ac16de90049c1b1ba1445a7626d0230c
Author: Lasse Collin <lasse.collin@tukaani.org>
Date: 2023-01-12 04:14:18 +0200
@@ -3041,7 +8831,7 @@ Date: 2023-01-12 04:14:18 +0200
tests/tests.h | 9 +++++++++
4 files changed, 17 insertions(+), 8 deletions(-)
-commit 34e13ce015232968731de2a9ec3440a08b0084b1
+commit 49245bb31e215ad455a1ab85e4ed6783152dc522
Author: Lasse Collin <lasse.collin@tukaani.org>
Date: 2023-01-12 03:51:07 +0200
@@ -3056,7 +8846,7 @@ Date: 2023-01-12 03:51:07 +0200
tests/test_stream_flags.c | 10 +++++-----
2 files changed, 8 insertions(+), 8 deletions(-)
-commit 6671d0fe46b77f0fafce860836b7a12dc3cda14a
+commit 3f13bf6b9e8624cbe6d6e3e82d6c98a3ed1ad571
Author: Lasse Collin <lasse.collin@tukaani.org>
Date: 2023-01-12 03:19:59 +0200
@@ -3071,7 +8861,7 @@ Date: 2023-01-12 03:19:59 +0200
src/liblzma/common/stream_encoder_mt.c | 2 +-
2 files changed, 6 insertions(+), 4 deletions(-)
-commit d3e833ca1d2abda54648494c33aca73a40a47efe
+commit 6c886cc5b3c90c6a75e6be8b1278ec2261e452a6
Author: Lasse Collin <lasse.collin@tukaani.org>
Date: 2023-01-12 03:11:40 +0200
@@ -3082,7 +8872,7 @@ Date: 2023-01-12 03:11:40 +0200
src/xz/options.c | 4 ++--
3 files changed, 4 insertions(+), 8 deletions(-)
-commit 977dd2e26bc50efec8d30fb90380394042d24558
+commit a0e7fb1c1ea658b67f30517f5d1975efd0226dba
Author: Lasse Collin <lasse.collin@tukaani.org>
Date: 2023-01-12 03:04:28 +0200
@@ -3091,7 +8881,7 @@ Date: 2023-01-12 03:04:28 +0200
tests/test_lzip_decoder.c | 4 ++--
1 file changed, 2 insertions(+), 2 deletions(-)
-commit c55157ed7437ab14f2afb7fecf331e321f2edf9a
+commit c0f8d6782f29e219fd496dd23f6a033270509d5c
Author: Lasse Collin <lasse.collin@tukaani.org>
Date: 2023-01-12 03:03:55 +0200
@@ -3100,17 +8890,7 @@ Date: 2023-01-12 03:03:55 +0200
tests/test_lzip_decoder.c | 13 +++++++------
1 file changed, 7 insertions(+), 6 deletions(-)
-commit 18b845e69752c975dfeda418ec00eda22605c2ee
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2023-01-11 18:52:54 +0200
-
- Bump version and soname for 5.4.1.
-
- src/liblzma/Makefile.am | 2 +-
- src/liblzma/api/lzma/version.h | 2 +-
- 2 files changed, 2 insertions(+), 2 deletions(-)
-
-commit 4080bbb844fb36701ffb978f0c41ea2c2c9f8960
+commit 62efd48a825e8f439e84c85e165d8774ddc68fd2
Author: Jia Tan <jiat0218@gmail.com>
Date: 2023-01-11 23:58:16 +0800
@@ -3119,44 +8899,7 @@ Date: 2023-01-11 23:58:16 +0800
NEWS | 70 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
1 file changed, 70 insertions(+)
-commit 674c89fdb8c457ebc3a0652e235d8b6cd7b7dee2
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2023-01-10 11:56:11 +0200
-
- sysdefs.h: Don't include strings.h anymore.
-
- On some platforms src/xz/suffix.c may need <strings.h> for
- strcasecmp() but suffix.c includes the header when it needs it.
-
- Unless there is an old system that otherwise supports enough C99
- to build XZ Utils but doesn't have C89/C90-compatible <string.h>,
- there should be no need to include <strings.h> in sysdefs.h.
-
- src/common/sysdefs.h | 6 ------
- 1 file changed, 6 deletions(-)
-
-commit 2a6b938084fac9ddb39cd69c9beeed15c3b6f6f6
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2023-01-10 11:23:41 +0200
-
- xz: Include <strings.h> in suffix.c if needed for strcasecmp().
-
- SUSv2 and POSIX.1‐2017 declare only a few functions in <strings.h>.
- Of these, strcasecmp() is used on some platforms in suffix.c.
- Nothing else in the project needs <strings.h> (at least if
- building on a modern system).
-
- sysdefs.h currently includes <strings.h> if HAVE_STRINGS_H is
- defined and suffix.c relied on this.
-
- Note that dos/config.h doesn't #define HAVE_STRINGS_H even though
- DJGPP does have strings.h. It isn't needed with DJGPP as strcasecmp()
- is also in <string.h> in DJGPP.
-
- src/xz/suffix.c | 3 +++
- 1 file changed, 3 insertions(+)
-
-commit aea639e81beb548e3114c74b6d9a894d6e036189
+commit d1561c47ec8cd3844a785d3741dc932f9b9c5790
Author: Jia Tan <jiat0218@gmail.com>
Date: 2023-01-11 22:46:48 +0800
@@ -3169,7 +8912,7 @@ Date: 2023-01-11 22:46:48 +0800
src/xz/message.c | 9 +++++++++
1 file changed, 9 insertions(+)
-commit e3b42bfcb0f67988beee7c7022fed0361282be45
+commit 8c0f115cc489331c48df77beca92fe378039d919
Author: Jia Tan <jiat0218@gmail.com>
Date: 2023-01-11 20:58:31 +0800
@@ -3178,7 +8921,7 @@ Date: 2023-01-11 20:58:31 +0800
tests/test_filter_flags.c | 4 ++--
1 file changed, 2 insertions(+), 2 deletions(-)
-commit 21625b7e11d004788e40eb5eb88d9d89f65fe347
+commit 25035813d1d596fde692addc33e7f715f1fe55eb
Author: Jia Tan <jiat0218@gmail.com>
Date: 2023-01-11 20:42:29 +0800
@@ -3192,7 +8935,7 @@ Date: 2023-01-11 20:42:29 +0800
tests/test_filter_flags.c | 13 ++++++++++---
1 file changed, 10 insertions(+), 3 deletions(-)
-commit c337983e928682d56ce3470b286a8d5b8646e0ad
+commit 0b8fa310cf56fec55663f62340e49e8e1441594f
Author: Lasse Collin <lasse.collin@tukaani.org>
Date: 2023-01-10 22:14:03 +0200
@@ -3213,7 +8956,7 @@ Date: 2023-01-10 22:14:03 +0200
src/liblzma/check/crc64_fast.c | 18 ++++++++++++++++++
1 file changed, 18 insertions(+)
-commit b7fb438ea0e3ee02e3a164f3b72fae456cbe34d7
+commit 765354b50c2886fc0d294d6be3b207f7ae2ada70
Author: Jia Tan <jiat0218@gmail.com>
Date: 2023-01-11 01:18:50 +0800
@@ -3225,7 +8968,7 @@ Date: 2023-01-11 01:18:50 +0800
tests/test_block_header.c | 4 ++++
1 file changed, 4 insertions(+)
-commit 68e9ef036d18d7c3952bff0b391d5989b86934da
+commit 7c23c05befdcc73231c0d6632a7d943dbeaea1aa
Author: Jia Tan <jiat0218@gmail.com>
Date: 2023-01-11 01:08:03 +0800
@@ -3237,16 +8980,43 @@ Date: 2023-01-11 01:08:03 +0800
tests/test_index_hash.c | 4 +---
1 file changed, 1 insertion(+), 3 deletions(-)
-commit a387707cd8cdefbffb5b7429bda4b7fcc192954a
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2023-01-10 00:33:14 +0200
+commit 57464bb4ebd6c00dc8b19803f05ea55ddd0826f6
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2023-01-11 00:54:45 +0800
- Windows: Update INSTALL-MSVC.txt to recommend CMake over project files.
+ CI/CD: Add 32-bit build and test steps to Ubuntu autotools runner.
+
+ If all goes well, Mac autotools and Linux and Mac CMake will be added
+ later for 32-bit builds.
- windows/INSTALL-MSVC.txt | 19 ++++++++++++-------
- 1 file changed, 12 insertions(+), 7 deletions(-)
+ .github/workflows/ci.yml | 7 ++++++-
+ 1 file changed, 6 insertions(+), 1 deletion(-)
+
+commit 923eb689a4b863b6cca8df6360d4962aae994edf
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2023-01-11 00:51:01 +0800
+
+ CI/CD: Enables warnings as errors in autotool build.
+
+ This will help us catch warnings and potential bugs in builds that are
+ not often tested by us.
+
+ build-aux/ci_build.sh | 2 +-
+ 1 file changed, 1 insertion(+), 1 deletion(-)
+
+commit feae5528a30c006b6e2f96a95116e20b983703fc
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2023-01-11 00:48:35 +0800
+
+ CI/CD: Add -f argument to set CFLAGS in ci_build.sh.
+
+ For now, the suggested option is for -m32 only, but this can be updated
+ later if other flags are deemed useful.
+
+ build-aux/ci_build.sh | 8 ++++++--
+ 1 file changed, 6 insertions(+), 2 deletions(-)
-commit 52902ad69518255a14b0144f0a2379e06fde5b6e
+commit cfabb62a4874c146e7d6f30445637602545bc054
Author: Lasse Collin <lasse.collin@tukaani.org>
Date: 2023-01-10 12:47:16 +0200
@@ -3263,7 +9033,44 @@ Date: 2023-01-10 12:47:16 +0200
src/liblzma/check/crc64_fast.c | 6 ------
1 file changed, 6 deletions(-)
-commit e81b9fc48ca70f9228308d3f1871cd81f9a5a496
+commit 0b64215170dd3562f207ef26f794755bcd600526
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2023-01-10 11:56:11 +0200
+
+ sysdefs.h: Don't include strings.h anymore.
+
+ On some platforms src/xz/suffix.c may need <strings.h> for
+ strcasecmp() but suffix.c includes the header when it needs it.
+
+ Unless there is an old system that otherwise supports enough C99
+ to build XZ Utils but doesn't have C89/C90-compatible <string.h>,
+ there should be no need to include <strings.h> in sysdefs.h.
+
+ src/common/sysdefs.h | 6 ------
+ 1 file changed, 6 deletions(-)
+
+commit ec2fc39fe4f4e6e242b3a669585049763968cdeb
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2023-01-10 11:23:41 +0200
+
+ xz: Include <strings.h> in suffix.c if needed for strcasecmp().
+
+ SUSv2 and POSIX.1‐2017 declare only a few functions in <strings.h>.
+ Of these, strcasecmp() is used on some platforms in suffix.c.
+ Nothing else in the project needs <strings.h> (at least if
+ building on a modern system).
+
+ sysdefs.h currently includes <strings.h> if HAVE_STRINGS_H is
+ defined and suffix.c relied on this.
+
+ Note that dos/config.h doesn't #define HAVE_STRINGS_H even though
+ DJGPP does have strings.h. It isn't needed with DJGPP as strcasecmp()
+ is also in <string.h> in DJGPP.
+
+ src/xz/suffix.c | 3 +++
+ 1 file changed, 3 insertions(+)
+
+commit 7049c4a76c805ad27d6cf4ee119a2ef2a7add59f
Author: Lasse Collin <lasse.collin@tukaani.org>
Date: 2023-01-10 10:05:13 +0200
@@ -3272,7 +9079,7 @@ Date: 2023-01-10 10:05:13 +0200
src/common/sysdefs.h | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)
-commit 6e89ab58b031aa046308a0b3504ff0a5be042571
+commit 194a5fab69277d9e804a6113b5f676b8666b3a61
Author: Lasse Collin <lasse.collin@tukaani.org>
Date: 2023-01-10 10:04:06 +0200
@@ -3288,24 +9095,45 @@ Date: 2023-01-10 10:04:06 +0200
src/common/sysdefs.h | 8 ++------
1 file changed, 2 insertions(+), 6 deletions(-)
-commit 65c59ad429aa59f9df0326d9fc82931ba4a9d123
+commit 5e34774c31d1b7509b5cb77a3be9973adec59ea0
Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2023-01-10 08:50:26 +0200
+Date: 2023-01-10 08:29:32 +0200
- CMake/Windows: Add a workaround for windres from GNU binutils.
+ CMake: Fix appending to CMAKE_RC_FLAGS.
- This is combined from the following commits in the master branch:
- 443dfebced041adc88f10d824188eeef5b5821a9
- 6b117d3b1fe91eb26d533ab16a2e552f84148d47
- 5e34774c31d1b7509b5cb77a3be9973adec59ea0
+ It's a string, not a list. It only worked when the variable was empty.
- Thanks to Iouri Kharon for the bug report, the original patch,
- and testing.
+ Thanks to Iouri Kharon.
- CMakeLists.txt | 32 +++++++++++++++++++++++++++++++-
- 1 file changed, 31 insertions(+), 1 deletion(-)
+ CMakeLists.txt | 2 +-
+ 1 file changed, 1 insertion(+), 1 deletion(-)
-commit 43521e77acc907863fa4f94aae276366172cb9ee
+commit 6e652ceb18c615c578c869db300fa0756788b4e0
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2023-01-10 00:33:14 +0200
+
+ Windows: Update INSTALL-MSVC.txt to recommend CMake over project files.
+
+ windows/INSTALL-MSVC.txt | 19 ++++++++++++-------
+ 1 file changed, 12 insertions(+), 7 deletions(-)
+
+commit 6b117d3b1fe91eb26d533ab16a2e552f84148d47
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2023-01-09 23:41:25 +0200
+
+ CMake: Fix windres issues again.
+
+ At least on some systems, GNU windres needs --use-temp-file
+ in addition to the \x20 hack to avoid spaces in the command line
+ argument. Hovever, that \x20 syntax is broken with llvm-windres
+ version 15.0.0 (results in "XZx20Utils") but luckily it works
+ with a regular space. Thus it is best to limit the workarounds
+ to GNU toolchain on Windows.
+
+ CMakeLists.txt | 35 +++++++++++++++++++++++------------
+ 1 file changed, 23 insertions(+), 12 deletions(-)
+
+commit 0c210ca7f489e971e94e1ddc72b0b0806e3c7935
Author: Lasse Collin <lasse.collin@tukaani.org>
Date: 2023-01-06 22:53:38 +0200
@@ -3332,7 +9160,7 @@ Date: 2023-01-06 22:53:38 +0200
tests/test_filter_flags.c | 153 +++++++++++++++++++++++-----------------------
1 file changed, 78 insertions(+), 75 deletions(-)
-commit 6b44cead95d767414272dc3a67898a36bfdf95b3
+commit 5c9fdd3bf53a9655f5eb2807d662b3af0d5e1865
Author: Jia Tan <jiat0218@gmail.com>
Date: 2022-12-29 23:33:33 +0800
@@ -3343,7 +9171,32 @@ Date: 2022-12-29 23:33:33 +0800
tests/test_filter_flags.c | 655 ++++++++++++++++++++++++++++++++--------------
1 file changed, 457 insertions(+), 198 deletions(-)
-commit 1bbefa9659b202ba31bd244a9d0e4f0d37ff3ed7
+commit 36edc65ab4cf10a131f239acbd423b4510ba52d5
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2023-01-09 12:22:05 +0200
+
+ liblzma: CLMUL CRC64: Workaround a bug in MSVC (VS2015-2022).
+
+ I haven't tested with MSVC myself and there doesn't seem to be
+ information about the problem online, so I'm relying on the bug report.
+
+ Thanks to Iouri Kharon for the bug report and the patch.
+
+ src/liblzma/check/crc64_fast.c | 6 ++++++
+ 1 file changed, 6 insertions(+)
+
+commit 790a12a95a78ff82d8c6d4efe3b789851ca9470d
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2023-01-09 11:27:24 +0200
+
+ CMake: Fix a copypaste error in xzdec Windows resource file handling.
+
+ It was my mistake. Thanks to Iouri Kharon for the bug report.
+
+ CMakeLists.txt | 4 ++--
+ 1 file changed, 2 insertions(+), 2 deletions(-)
+
+commit 0e1545fea39c0514c7b7032a0a3592a9a33d2848
Author: Lasse Collin <lasse.collin@tukaani.org>
Date: 2023-01-08 00:32:29 +0200
@@ -3356,7 +9209,16 @@ Date: 2023-01-08 00:32:29 +0200
tests/tuktest.h | 4 ++--
1 file changed, 2 insertions(+), 2 deletions(-)
-commit ce3a3fbc7c2c399aeed644d54f3bd56ac914dfee
+commit 69d5d78c6904668eb09a131da86276beec3281f8
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2023-01-08 00:24:23 +0200
+
+ Update THANKS.
+
+ THANKS | 1 +
+ 1 file changed, 1 insertion(+)
+
+commit dd38655f80c113c9db73b9ed370dc900e1c4dc41
Author: Lasse Collin <lasse.collin@tukaani.org>
Date: 2023-01-07 21:57:11 +0200
@@ -3368,16 +9230,7 @@ Date: 2023-01-07 21:57:11 +0200
CMakeLists.txt | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)
-commit 99fcd57f2ea35eaa94e09f674d5364329c880fa2
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2023-01-08 00:24:23 +0200
-
- Update THANKS.
-
- THANKS | 1 +
- 1 file changed, 1 insertion(+)
-
-commit c0c13d9d82eb8a4302c8bbb8b4c5178d285fe9ab
+commit a890a637bee9193d5b690aefa9a59eba5b8532ae
Author: Lasse Collin <lasse.collin@tukaani.org>
Date: 2023-01-07 19:50:35 +0200
@@ -3386,18 +9239,7 @@ Date: 2023-01-07 19:50:35 +0200
THANKS | 1 +
1 file changed, 1 insertion(+)
-commit 3d45987451b1c3bb42697b29341824c0e5484cba
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2023-01-09 11:27:24 +0200
-
- CMake: Fix a copypaste error in xzdec Windows resource file handling.
-
- It was my mistake. Thanks to Iouri Kharon for the bug report.
-
- CMakeLists.txt | 4 ++--
- 1 file changed, 2 insertions(+), 2 deletions(-)
-
-commit 706bce5018d7cf83094e13454a0731169ec119b5
+commit 6e38e595dd56ac1800478cef1f6f754d0eba0d2e
Author: Lasse Collin <lasse.collin@tukaani.org>
Date: 2023-01-07 19:50:03 +0200
@@ -3411,21 +9253,18 @@ Date: 2023-01-07 19:50:03 +0200
CMakeLists.txt | 16 ++++++++++++++++
1 file changed, 16 insertions(+)
-commit e96dee55df04113c33b387ccdb6cb70935422d91
+commit 443dfebced041adc88f10d824188eeef5b5821a9
Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2023-01-09 12:22:05 +0200
+Date: 2023-01-07 19:48:52 +0200
- liblzma: CLMUL CRC64: Workaround a bug in MSVC (VS2015-2022).
-
- I haven't tested with MSVC myself and there doesn't seem to be
- information about the problem online, so I'm relying on the bug report.
+ CMake/Windows: Add a workaround for windres from GNU binutils.
- Thanks to Iouri Kharon for the bug report and the patch.
+ Thanks to Iouri Kharon for the bug report and the original patch.
- src/liblzma/check/crc64_fast.c | 6 ++++++
- 1 file changed, 6 insertions(+)
+ CMakeLists.txt | 21 ++++++++++++++++++++-
+ 1 file changed, 20 insertions(+), 1 deletion(-)
-commit 52bc1ee34dda9bb6fb40175e5952863066681b77
+commit ceb805011747d04a915f3f39e4bed9eed151c634
Author: Lasse Collin <lasse.collin@tukaani.org>
Date: 2023-01-07 19:31:15 +0200
@@ -3440,69 +9279,132 @@ Date: 2023-01-07 19:31:15 +0200
configure.ac | 8 ++++++--
2 files changed, 8 insertions(+), 3 deletions(-)
-commit bad44cfe19e8be8ae76755369be2a34abcd2b4fa
+commit 8d372bd94066b1a5b0570b2550f83c2868486adf
Author: Jia Tan <jiat0218@gmail.com>
-Date: 2022-12-29 00:25:18 +0800
+Date: 2023-01-07 21:05:15 +0800
- Tests: Creates test_index_hash.c
-
- Tests all API functions exported from index_hash.h. Does not have a
- dedicated test for lzma_index_hash_end.
+ CI/CD: Split CMake Linux and MacOS build phase to build and test.
- [Minor edits were made by Lasse Collin.]
+ The phase split was only done for Autotools before, so should also
+ apply to CMake.
- .gitignore | 1 +
- CMakeLists.txt | 2 +
- tests/Makefile.am | 3 +
- tests/test_index_hash.c | 388 ++++++++++++++++++++++++++++++++++++++++++++++++
- 4 files changed, 394 insertions(+)
+ .github/workflows/ci.yml | 8 ++++++--
+ 1 file changed, 6 insertions(+), 2 deletions(-)
-commit 692ccdf5516dfe55fb6e9c5cdfb31f4c02c1ecd1
+commit 747c7f2b34bd498f6702c6875500a26b06201772
Author: Jia Tan <jiat0218@gmail.com>
-Date: 2023-01-05 20:57:25 +0800
+Date: 2023-01-07 11:16:55 +0800
- liblzma: Remove common.h include from common/index.h.
+ CI/CD: Reduce job runners to 4 instead of using matrix strategy.
- common/index.h is needed by liblzma internally and tests. common.h will
- include and define many things that are not needed by the tests.
+ The old version used too many runners that resulted in unnecessary
+ dependency downloads. Now, the runners are reused for the different
+ configurations for each OS and build system.
+
+ .github/workflows/ci.yml | 95 ++++++++++++++++++++++++++++++++++++++++++------
+ 1 file changed, 83 insertions(+), 12 deletions(-)
+
+commit 4de35fd6b58d46fc887c78faf163f6a37b790c45
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2023-01-07 10:07:20 +0800
+
+ CI/CD: Add new -p (PHASE) argument to ci_build.sh
- Also, this prevents include order problems because both common.h and
- lzma.h define LZMA_API. On most platforms it results only in a warning
- but on Windows it would break the build as the definition in common.h
- must be used only for building liblzma itself.
+ The new PHASE argument can be build, test, or all. all is the default.
+ This way, the CI/CD script can differentiate between the build and test
+ phases to make it easier to track down errors when they happen.
- src/liblzma/common/index.c | 1 +
- src/liblzma/common/index.h | 9 +++++++--
- src/liblzma/common/index_decoder.h | 1 +
- src/liblzma/common/stream_buffer_encoder.c | 1 +
- 4 files changed, 10 insertions(+), 2 deletions(-)
+ build-aux/ci_build.sh | 140 +++++++++++++++++++++++++++-----------------------
+ 1 file changed, 76 insertions(+), 64 deletions(-)
-commit 2ac7bafc8f07c1edefe96a4a7a040ddfff0eb5bb
+commit 6fd39664de47801e670a16617863196bfbde4755
+Merge: 78e0561d fc0c7884
Author: Jia Tan <jiat0218@gmail.com>
-Date: 2022-08-17 20:20:16 +0800
+Date: 2023-01-07 00:10:50 +0800
- liblzma: Add NULL check to lzma_index_hash_append.
+ Merge pull request #7 from tukaani-project/tuktest_index_hash
- This is for consistency with lzma_index_append.
+ Tuktest index hash
- src/liblzma/common/index_hash.c | 2 +-
+commit fc0c788469159f634f09ff23c8cef6925c91da57
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2023-01-06 17:58:48 +0200
+
+ Tests: test_index_hash: Add an assert_uint_eq().
+
+ tests/test_index_hash.c | 3 +++
+ 1 file changed, 3 insertions(+)
+
+commit d550304f5343b3a082da265107cd820e0d81dc71
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2023-01-06 17:55:06 +0200
+
+ Tests: test_index_hash: Fix a memory leak.
+
+ tests/test_index_hash.c | 2 ++
+ 1 file changed, 2 insertions(+)
+
+commit 02608f74ea1f2d2d56585711ff241c34b4ad0937
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2023-01-06 17:53:03 +0200
+
+ Tests: test_index_hash: Don't treat pointers as booleans.
+
+ tests/test_index_hash.c | 6 +++---
+ 1 file changed, 3 insertions(+), 3 deletions(-)
+
+commit 056766c8601a3808bea1761f6cc833197a35a3e0
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2023-01-06 17:51:41 +0200
+
+ Tests: test_index_hash: Fix a typo in a comment.
+
+ tests/test_index_hash.c | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)
-commit db714d30e0c74d1dd4af1a23ed62b44e0e8e4efc
-Author: Jia Tan <jiat0218@gmail.com>
-Date: 2022-08-17 17:59:51 +0800
+commit 873e684028ba9738f071c5236db7d452ed797b4c
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2023-01-06 17:44:29 +0200
- liblzma: Replaced hardcoded 0x0 index indicator byte with macro
+ Tests: test_index_hash: Avoid the variable name "index".
+
+ It can trigger warnings from -Wshadow on some systems.
- src/liblzma/common/index.h | 3 +++
- src/liblzma/common/index_decoder.c | 2 +-
- src/liblzma/common/index_encoder.c | 2 +-
- src/liblzma/common/index_hash.c | 2 +-
- src/liblzma/common/stream_decoder.c | 3 ++-
- src/liblzma/common/stream_decoder_mt.c | 2 +-
- 6 files changed, 9 insertions(+), 5 deletions(-)
+ tests/test_index_hash.c | 16 ++++++++--------
+ 1 file changed, 8 insertions(+), 8 deletions(-)
+
+commit d1f24c35874eeba8432d75aa77b06c50375ed937
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2023-01-06 17:35:50 +0200
+
+ Tests: test_index_hash: Use the word "Record" instead of "entry".
+
+ tests/test_index_hash.c | 102 ++++++++++++++++++++++++------------------------
+ 1 file changed, 51 insertions(+), 51 deletions(-)
+
+commit b93f7c5cbb02b42024ac866fc0af541de3d816e2
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2023-01-06 17:35:05 +0200
+
+ Tests: test_index_hash: Tweak comments and style.
+
+ The words defined in the .xz file format specification
+ begin with capital letter to emphasize that they have
+ a specific meaning.
+
+ tests/test_index_hash.c | 62 ++++++++++++++++++++++++++-----------------------
+ 1 file changed, 33 insertions(+), 29 deletions(-)
+
+commit c48b24fc06d98569adb72f13c2e8e5ff30bb8036
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2023-01-06 17:17:37 +0200
+
+ Tests: test_index_hash: Use INDEX_INDICATOR constant instead of 0.
+
+ tests/test_index_hash.c | 2 +-
+ 1 file changed, 1 insertion(+), 1 deletion(-)
-commit 39d2585dcd3e827cfc3c46025ab6708c4aeb36c6
+commit 78e0561dfebaa9d5e34558de537efcda890e0629
Author: Jia Tan <jiat0218@gmail.com>
Date: 2023-01-06 20:43:31 +0800
@@ -3511,7 +9413,7 @@ Date: 2023-01-06 20:43:31 +0800
src/common/mythread.h | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)
-commit 3f0130aa288e4ed57ace609517db9700a41223af
+commit e834e1e934ed0af673598d8c0c34afb2af56bee0
Author: Jia Tan <jiat0218@gmail.com>
Date: 2023-01-06 20:35:55 +0800
@@ -3528,7 +9430,24 @@ Date: 2023-01-06 20:35:55 +0800
windows/vs2019/liblzma_dll.vcxproj | 1 +
6 files changed, 6 insertions(+)
-commit f204d1050a515d17851eed9049862ce5a9c729c1
+commit 84f9687cbae972c2c342e10bf69f8ec8f70ae111
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2023-01-05 20:57:25 +0800
+
+ liblzma: Remove common.h include from common/index.h.
+
+ common/index.h is needed by liblzma internally and tests. common.h will
+ include and define many things that are not needed by the tests. Also,
+ this prevents include order problems because common.h will redefine
+ LZMA_API resulting in a warning.
+
+ src/liblzma/common/index.c | 1 +
+ src/liblzma/common/index.h | 9 +++++++--
+ src/liblzma/common/index_decoder.h | 1 +
+ src/liblzma/common/stream_buffer_encoder.c | 1 +
+ 4 files changed, 10 insertions(+), 2 deletions(-)
+
+commit 7657ce1c3c4abff7560336a7b687d98e0e2bd14f
Author: Lasse Collin <lasse.collin@tukaani.org>
Date: 2023-01-04 22:40:54 +0200
@@ -3537,7 +9456,7 @@ Date: 2023-01-04 22:40:54 +0200
THANKS | 1 +
1 file changed, 1 insertion(+)
-commit 34a9c2d650d6c30bd88e1b21910dd863209aa884
+commit aafd67fba045ab99683971263a5a26fb2a6e8ce2
Author: Lasse Collin <lasse.collin@tukaani.org>
Date: 2023-01-04 18:40:28 +0200
@@ -3546,7 +9465,7 @@ Date: 2023-01-04 18:40:28 +0200
tests/test_compress.sh | 12 +++++++-----
1 file changed, 7 insertions(+), 5 deletions(-)
-commit 761c208d58e0c3daa0f46e68b406adfc318d2a46
+commit 52380678f42364daa4510f92f6d3b18ec98c3638
Author: Jia Tan <jiat0218@gmail.com>
Date: 2023-01-04 23:58:58 +0800
@@ -3562,7 +9481,7 @@ Date: 2023-01-04 23:58:58 +0800
tests/test_compress_prepared_bcj_x86 | 2 +-
4 files changed, 16 insertions(+), 10 deletions(-)
-commit 8a7cbc074547e55e57f4f3696f69bedeb05e14c4
+commit d0eb345bb7d148a62883ee299adec2b74a0f6f3b
Author: Jia Tan <jiat0218@gmail.com>
Date: 2023-01-03 21:02:38 +0800
@@ -3574,7 +9493,7 @@ Date: 2023-01-03 21:02:38 +0800
po4a/po4a.conf | 2 +-
2 files changed, 5553 insertions(+), 1 deletion(-)
-commit ca2af49bb8be5995eb0e6a3abf457622626d49a7
+commit c4145978d95ebf1690c778d354e15f7c2823d7a8
Author: Jia Tan <jiat0218@gmail.com>
Date: 2023-01-03 20:47:27 +0800
@@ -3583,7 +9502,24 @@ Date: 2023-01-03 20:47:27 +0800
po/eo.po | 620 ++++++++++++++++++++++++++++++++++-----------------------------
1 file changed, 332 insertions(+), 288 deletions(-)
-commit bfba3394aed03311fe9a746d3141b2e16d8b9325
+commit 4103a2e78ac60b00c888485cd967a5fe5d1b917c
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2023-01-02 17:20:47 +0200
+
+ Bump version and soname for 5.5.0alpha.
+
+ 5.5.0alpha won't be released, it's just to mark that
+ the branch is not for stable 5.4.x.
+
+ Once again there is no API/ABI stability for new features
+ in devel versions. The major soname won't be bumped even
+ if API/ABI of new features breaks between devel releases.
+
+ src/liblzma/Makefile.am | 2 +-
+ src/liblzma/api/lzma/version.h | 4 ++--
+ 2 files changed, 3 insertions(+), 3 deletions(-)
+
+commit 73c9e6d6b970ccc3d5ad61dcaa21cba050e5df0a
Author: Lasse Collin <lasse.collin@tukaani.org>
Date: 2023-01-02 17:05:07 +0200
@@ -3593,7 +9529,7 @@ Date: 2023-01-02 17:05:07 +0200
m4/tuklib_progname.m4 | 2 +-
2 files changed, 2 insertions(+), 2 deletions(-)
-commit 507648ad114c2ae0cd6d181063e1ac07e8106718
+commit bb740e3b117f1a3c65152d01e5755523a908ecb1
Author: Jia Tan <jiat0218@gmail.com>
Date: 2023-01-02 22:33:48 +0800
@@ -3612,7 +9548,55 @@ Date: 2023-01-02 22:33:48 +0800
src/common/tuklib_progname.h | 2 +-
4 files changed, 8 insertions(+), 6 deletions(-)
-commit ab5229d32adfec1f3fbc95228d9dd6f560732ab5
+commit 064cd385a716abc78d93a3612411a82d69ceb221
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2022-12-29 00:30:52 +0800
+
+ Adds test_index_hash to .gitignore.
+
+ .gitignore | 1 +
+ 1 file changed, 1 insertion(+)
+
+commit 3959162baec074511d83ba0fec1284c3ed724799
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2022-12-29 00:25:18 +0800
+
+ Tests: Creates test_index_hash.c
+
+ Tests all API functions exported from index_hash.h. Does not have a
+ dedicated test for lzma_index_hash_end.
+
+ CMakeLists.txt | 2 +
+ tests/Makefile.am | 3 +
+ tests/test_index_hash.c | 379 ++++++++++++++++++++++++++++++++++++++++++++++++
+ 3 files changed, 384 insertions(+)
+
+commit f16e12d5e755d371247202fcccbcccd1ec16b2cf
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2022-08-17 20:20:16 +0800
+
+ liblzma: Add NULL check to lzma_index_hash_append.
+
+ This is for consistency with lzma_index_append.
+
+ src/liblzma/common/index_hash.c | 2 +-
+ 1 file changed, 1 insertion(+), 1 deletion(-)
+
+commit 203b008eb220208981902e0db541c02d1c1c9f5e
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2022-08-17 17:59:51 +0800
+
+ liblzma: Replaced hardcoded 0x0 index indicator byte with macro
+
+ src/liblzma/common/index.h | 3 +++
+ src/liblzma/common/index_decoder.c | 2 +-
+ src/liblzma/common/index_encoder.c | 2 +-
+ src/liblzma/common/index_hash.c | 2 +-
+ src/liblzma/common/stream_decoder.c | 3 ++-
+ src/liblzma/common/stream_decoder_mt.c | 2 +-
+ 6 files changed, 9 insertions(+), 5 deletions(-)
+
+commit dfecda875211f737d0db92dc1d3c58a3a2afb0c0
Author: Lasse Collin <lasse.collin@tukaani.org>
Date: 2022-12-30 20:10:08 +0200
@@ -3621,7 +9605,7 @@ Date: 2022-12-30 20:10:08 +0200
tests/test_check.c | 27 +++++++++++++++++++++++++++
1 file changed, 27 insertions(+)
-commit 8791826f31733fda0a13b411c2ed930faaeb25aa
+commit ce96bb20435212fe797d6d84738fb9fd4ea13cc7
Author: Lasse Collin <lasse.collin@tukaani.org>
Date: 2022-12-30 19:36:49 +0200
@@ -3630,7 +9614,7 @@ Date: 2022-12-30 19:36:49 +0200
tests/test_lzip_decoder.c | 8 ++++++--
1 file changed, 6 insertions(+), 2 deletions(-)
-commit c410d812ea12bfc74f6b727c1a799478c79f19ca
+commit 2fcba17fc4d7eda8fc60567169cf2a0e6fcfb2f8
Author: Jia Tan <jiat0218@gmail.com>
Date: 2022-12-29 01:55:19 +0800
@@ -3641,7 +9625,7 @@ Date: 2022-12-29 01:55:19 +0800
src/xz/mytime.c | 4 +++-
1 file changed, 3 insertions(+), 1 deletion(-)
-commit 501c6013d4a59fae5d4368e9657c4885493db809
+commit f82294c8318a7a0990583d51ac5c7de682ad36ef
Author: Jia Tan <jiat0218@gmail.com>
Date: 2022-12-29 01:15:27 +0800
@@ -3654,7 +9638,7 @@ Date: 2022-12-29 01:15:27 +0800
src/common/mythread.h | 8 +++++++-
1 file changed, 7 insertions(+), 1 deletion(-)
-commit 9e3cb514b5b95bd235dcdff3db4436f57444ee4f
+commit 74dae7d30091e906d6a92a57952dea4354473f9b
Author: Jia Tan <jiat0218@gmail.com>
Date: 2022-12-29 01:10:53 +0800
@@ -3673,7 +9657,7 @@ Date: 2022-12-29 01:10:53 +0800
src/xz/mytime.c | 5 ++---
4 files changed, 11 insertions(+), 11 deletions(-)
-commit 6fc3e5467911572fa9af4021ea46396261aae796
+commit 7339e39dc060df6eda74a2c5b69961befc3d5d24
Author: Jia Tan <jiat0218@gmail.com>
Date: 2022-12-28 01:14:07 +0800
@@ -3685,7 +9669,22 @@ Date: 2022-12-28 01:14:07 +0800
po4a/uk.po | 3676 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++
2 files changed, 3677 insertions(+), 1 deletion(-)
-commit e84f2ab7f8bc38cd8f8befa0bb398656c3c11f8e
+commit 9f05c27a58ce8cd7803079aa295e41c24665ce6e
+Author: Jia Tan <jiat0218@gmail.com>
+Date: 2022-12-23 00:34:48 +0800
+
+ CI/CD: Create initial version of CI/CD workflow.
+
+ The CI/CD workflow will only execute on Ubuntu and MacOS latest version.
+ The workflow will attempt to build with autotools and CMake and execute
+ the tests. The workflow will run for all pull requests and pushes done
+ to the master branch.
+
+ .github/workflows/ci.yml | 72 ++++++++++++++++++++++++
+ build-aux/ci_build.sh | 141 +++++++++++++++++++++++++++++++++++++++++++++++
+ 2 files changed, 213 insertions(+)
+
+commit 1275ebfba74230dbd028049141423c79c8b83b8f
Author: Jia Tan <jiat0218@gmail.com>
Date: 2022-12-22 23:14:53 +0800
@@ -3694,7 +9693,7 @@ Date: 2022-12-22 23:14:53 +0800
src/liblzma/common/filter_encoder.c | 7 +++++--
1 file changed, 5 insertions(+), 2 deletions(-)
-commit b14b8dbba9a3b232787ae218b46430b9246383dd
+commit 7c9ff5f1667a16733163b75dfd4b509662c387f4
Author: Jia Tan <jiat0218@gmail.com>
Date: 2022-12-21 21:12:03 +0800
@@ -3705,7 +9704,7 @@ Date: 2022-12-21 21:12:03 +0800
tests/test_lzip_decoder.c | 471 ++++++++++++++++++++++++++++++++++++++++++++++
3 files changed, 474 insertions(+)
-commit 09a114805e1d4f9a02a06cee7dbf2f5014d1f710
+commit 799ead162de63b8400733603d3abcd2e1977bdca
Author: Jia Cheong Tan <jiat0218@gmail.com>
Date: 2022-12-20 22:05:21 +0800
@@ -3717,7 +9716,7 @@ Date: 2022-12-20 22:05:21 +0800
.gitignore | 2 ++
1 file changed, 2 insertions(+)
-commit d3e6fe44196bf9478ad193522e2b48febf2eca6b
+commit 5f7ce42a16b1e86ca8408b5c670c25e2a12acc4e
Author: Jia Tan <jiat0218@gmail.com>
Date: 2022-12-20 20:46:44 +0800
@@ -3731,16 +9730,7 @@ Date: 2022-12-20 20:46:44 +0800
src/liblzma/common/microlzma_encoder.c | 3 ++-
1 file changed, 2 insertions(+), 1 deletion(-)
-commit b55a27b46f52524a4a8d9cdef03e6689cefc1375
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-12-16 18:30:02 +0200
-
- liblzma: Update authors list in arm64.c.
-
- src/liblzma/simple/arm64.c | 1 +
- 1 file changed, 1 insertion(+)
-
-commit 2fd28d2b7cec3468324a6f15eff7e73c285b1d7d
+commit 8ace358d65059152d9a1f43f4770170d29d35754
Author: Jia Tan <jiat0218@gmail.com>
Date: 2022-12-16 20:58:55 +0800
@@ -3752,6 +9742,15 @@ Date: 2022-12-16 20:58:55 +0800
.gitignore | 23 +++++++++++++++++++++++
1 file changed, 23 insertions(+)
+commit 8fd225a2c149f30aeac377e68eb5abf6b28300ad
+Author: Lasse Collin <lasse.collin@tukaani.org>
+Date: 2022-12-16 18:30:02 +0200
+
+ liblzma: Update authors list in arm64.c.
+
+ src/liblzma/simple/arm64.c | 1 +
+ 1 file changed, 1 insertion(+)
+
commit b69da6d4bb6bb11fc0cf066920791990d2b22a06
Author: Lasse Collin <lasse.collin@tukaani.org>
Date: 2022-12-13 20:37:17 +0200
@@ -3763,7994 +9762,3 @@ Date: 2022-12-13 20:37:17 +0200
src/liblzma/liblzma_generic.map | 2 +-
src/liblzma/liblzma_linux.map | 2 +-
4 files changed, 6 insertions(+), 6 deletions(-)
-
-commit 20869eb3fb280ff4f271ef527b12b6bf68b05e19
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-12-13 20:29:39 +0200
-
- Update INSTALL: CMake on Windows isn't experimental anymore.
-
- Using CMake to build liblzma should work on a few other OSes
- but building the command line tools is still subtly broken.
-
- It is known that shared library versioning may differ between
- CMake and Libtool builds on some OSes, most notably Darwin.
-
- INSTALL | 10 ++++------
- 1 file changed, 4 insertions(+), 6 deletions(-)
-
-commit cbbd84451944e3e8c63acfaa3c923f6d8aff7852
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-12-13 19:47:53 +0200
-
- Add NEWS for 5.4.0.
-
- NEWS | 202 +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
- 1 file changed, 202 insertions(+)
-
-commit c3e94d37e8d10a3e96019864b6f5d7b578db2c14
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-12-13 17:41:20 +0200
-
- Fix a typo in NEWS.
-
- NEWS | 2 +-
- 1 file changed, 1 insertion(+), 1 deletion(-)
-
-commit 0d2a2e0a545c3da2b3e9500f1e531eb903087245
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-12-13 17:41:03 +0200
-
- Add NEWS for 5.2.10.
-
- NEWS | 12 ++++++++++++
- 1 file changed, 12 insertions(+)
-
-commit 177ece1c8eb007188fb1b04eff09ca2193fbdea6
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-12-13 12:30:45 +0200
-
- Tests: Fix a typo in tests/files/README.
-
- tests/files/README | 2 +-
- 1 file changed, 1 insertion(+), 1 deletion(-)
-
-commit 60f45bdbaa6b07558b3f4baac285739b0c6342f5
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-12-13 12:30:09 +0200
-
- Tests: Add two ARM64 test files.
-
- tests/files/README | 7 +++++++
- tests/files/good-1-arm64-lzma2-1.xz | Bin 0 -> 512 bytes
- tests/files/good-1-arm64-lzma2-2.xz | Bin 0 -> 488 bytes
- tests/test_files.sh | 5 +++++
- 4 files changed, 12 insertions(+)
-
-commit f5e419550619c548c7c35d7e367cf00580a56521
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-12-12 22:44:21 +0200
-
- Translations: Update the Catalan translation.
-
- po/ca.po | 657 +++++++++++++++++++++++++++++----------------------------------
- 1 file changed, 306 insertions(+), 351 deletions(-)
-
-commit 0fb9d355da3789b1757040af475b4e6bbc8b8af8
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-12-12 19:18:12 +0200
-
- Update THANKS.
-
- THANKS | 1 +
- 1 file changed, 1 insertion(+)
-
-commit e5b6c161c61a37c54dcb76a99bbb83ac4abe02dc
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-12-12 19:07:58 +0200
-
- Update AUTHORS.
-
- AUTHORS | 12 ++++++++++++
- 1 file changed, 12 insertions(+)
-
-commit f2d98e691099d82054d5f3071ef6f5e809932e44
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-12-12 15:31:14 +0200
-
- Docs: Omit multi-threaded decompress from TODO.
-
- The TODO file outdated still.
-
- TODO | 2 --
- 1 file changed, 2 deletions(-)
-
-commit b42908c42a4cc091db45a7e5ba0e0ecceaa3f6da
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-12-11 21:16:09 +0200
-
- Docs: Update xz-file-format.txt to 1.1.0 for ARM64 filter.
-
- doc/xz-file-format.txt | 29 ++++++++++++++++++++++-------
- 1 file changed, 22 insertions(+), 7 deletions(-)
-
-commit 854f2f5946b353cb0963fd6dfd54d363adc89b9f
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-12-11 21:13:57 +0200
-
- xz: Rename --experimental-arm64 to --arm64.
-
- src/xz/args.c | 2 +-
- 1 file changed, 1 insertion(+), 1 deletion(-)
-
-commit 31dbd1e5fb65831915a7bbb531c3f19aea8d57a5
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-12-11 21:13:06 +0200
-
- liblzma: Change LZMA_FILTER_ARM64 to the official Filter ID 0x0A.
-
- src/liblzma/api/lzma/bcj.h | 6 +-----
- 1 file changed, 1 insertion(+), 5 deletions(-)
-
-commit 01b3549e523edac899ec4925b282ceddd20da116
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-12-08 19:24:22 +0200
-
- xz: Make args_info.files_name a const pointer.
-
- src/xz/args.c | 2 +-
- src/xz/args.h | 2 +-
- 2 files changed, 2 insertions(+), 2 deletions(-)
-
-commit bc665b84ea6bf7946394a08122177efe41b26a5f
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-12-08 19:18:16 +0200
-
- xz: Don't modify argv[].
-
- The code that parses --memlimit options and --block-list modified
- the argv[] when parsing the option string from optarg. This was
- visible in "ps auxf" and such and could be confusing. I didn't
- understand it back in the day when I wrote that code. Now a copy
- is allocated when modifiable strings are needed.
-
- src/xz/args.c | 23 +++++++++++++++++++----
- 1 file changed, 19 insertions(+), 4 deletions(-)
-
-commit a13064e1c290de7933db72b6dffbd65cfce59c9f
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-12-08 18:18:57 +0200
-
- Translations: Update the German man page translations.
-
- po4a/de.po | 4570 ++++++++++++++++++------------------------------------------
- 1 file changed, 1374 insertions(+), 3196 deletions(-)
-
-commit 8bdbe42a8d0d75dff70206b923fc4bce5c69a40a
-Author: Jia Tan <jiat0218@gmail.com>
-Date: 2022-12-06 23:05:56 +0800
-
- Translations: Update the German translation.
-
- po/de.po | 586 ++++++++++++++++++++++++++++++++++-----------------------------
- 1 file changed, 315 insertions(+), 271 deletions(-)
-
-commit 5c304b57c24ef40ff57f864301065f0244c05bde
-Author: Jia Tan <jiat0218@gmail.com>
-Date: 2022-12-06 23:04:25 +0800
-
- Translations: Update the Turkish translation.
-
- po/tr.po | 221 +++++++++++++++++++++++++++++++--------------------------------
- 1 file changed, 108 insertions(+), 113 deletions(-)
-
-commit 6d86781fdb937970486500447ebb49b98244235b
-Author: Jia Tan <jiat0218@gmail.com>
-Date: 2022-12-06 23:02:11 +0800
-
- Translations: Update the Croatian translation.
-
- po/hr.po | 228 +++++++++++++++++++++++++++++++--------------------------------
- 1 file changed, 113 insertions(+), 115 deletions(-)
-
-commit 7a5b4b8075eb36026b1796f04ffed5830c42396a
-Author: Jia Tan <jiat0218@gmail.com>
-Date: 2022-12-06 22:56:30 +0800
-
- Translations: Add Romanian translation of man pages.
-
- Thanks to Remus-Gabriel Chelu.
-
- po4a/po4a.conf | 2 +-
- po4a/ro.po | 3692 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++
- 2 files changed, 3693 insertions(+), 1 deletion(-)
-
-commit c6977e7400088177556e8771bcb839eb7d90caa3
-Author: Jia Tan <jiat0218@gmail.com>
-Date: 2022-12-06 22:52:13 +0800
-
- Translations: Update the Romanian translation.
-
- po/ro.po | 294 +++++++++++++++++++++++++++++++--------------------------------
- 1 file changed, 147 insertions(+), 147 deletions(-)
-
-commit ac2a747e939c2cbccff7a49c399769af5e02d2ab
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-12-08 17:30:09 +0200
-
- liblzma: Check for unexpected NULL pointers in block_header_decode().
-
- The API docs gave an impression that such checks are done
- but they actually weren't done. In practice it made little
- difference since the calling code has a bug if these are NULL.
-
- Thanks to Jia Tan for the original patch that checked for
- block->filters == NULL.
-
- src/liblzma/common/block_header_decoder.c | 4 ++++
- 1 file changed, 4 insertions(+)
-
-commit 24790f49ae66938c1c7574315e1c0aba1ed5ed25
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-12-01 20:59:32 +0200
-
- Bump version number for 5.3.5beta.
-
- This also sorts the symbol names alphabetically in liblzma_*.map.
-
- src/liblzma/api/lzma/version.h | 4 ++--
- src/liblzma/liblzma_generic.map | 10 +++++-----
- src/liblzma/liblzma_linux.map | 10 +++++-----
- 3 files changed, 12 insertions(+), 12 deletions(-)
-
-commit 7e53c5bcb3c2c17f47c096c06ff6b1481e6ecafa
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-12-01 20:57:26 +0200
-
- Add NEWS for 5.3.5beta.
-
- NEWS | 43 +++++++++++++++++++++++++++++++++++++++++++
- 1 file changed, 43 insertions(+)
-
-commit 5865f2aaac326fcbd9f8a7d62defa230e4cb644e
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-12-01 20:57:09 +0200
-
- Update THANKS.
-
- THANKS | 3 +++
- 1 file changed, 3 insertions(+)
-
-commit 62b270988ec67314d69976df484d2974c6eacfda
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-12-01 20:04:17 +0200
-
- liblzma: Use __has_attribute(__symver__) to fix Clang detection.
-
- If someone sets up Clang to define __GNUC__ to 10 or greater
- then symvers broke. __has_attribute is supported by such GCC
- and Clang versions that don't support __symver__ so this should
- be much better and simpler way to detect if __symver__ is
- actually supported.
-
- Thanks to Tomasz Gajc for the bug report.
-
- src/liblzma/common/common.h | 15 ++++++++++++++-
- 1 file changed, 14 insertions(+), 1 deletion(-)
-
-commit f9ca7d45162664ddd9fb70e19335c2426e5d75bb
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-12-01 18:51:52 +0200
-
- liblzma: Omit zero-skipping from ARM64 filter.
-
- It has some complicated downsides and its usefulness is more limited
- than I originally thought. So this change is bad for certain very
- specific situations but a generic solution that works for other
- filters (and is otherwise better too) is planned anyway. And this
- way 7-Zip can use the same compatible filter for the .7z format.
-
- This is still marked as experimental with a new temporary Filter ID.
-
- src/liblzma/api/lzma/bcj.h | 2 +-
- src/liblzma/simple/arm64.c | 81 +++++++++++++---------------------------------
- 2 files changed, 24 insertions(+), 59 deletions(-)
-
-commit 5baec3f0a9c85e6abf45c0f652f699b074129a8b
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-12-01 18:13:27 +0200
-
- xz: Omit the special notes about ARM64 filter on the man page.
-
- src/xz/xz.1 | 5 ++---
- 1 file changed, 2 insertions(+), 3 deletions(-)
-
-commit 0c3627b51862eb0dcdd4fc283d046250571991c6
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-12-01 18:12:03 +0200
-
- liblzma: Don't be over-specific in lzma_str_to_filters API doc.
-
- src/liblzma/api/lzma/filter.h | 3 +--
- 1 file changed, 1 insertion(+), 2 deletions(-)
-
-commit 94adf057f27b1970f493dc99cd166407d7255639
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-12-01 17:54:23 +0200
-
- liblzma: Silence unused variable warning when BCJ filters are disabled.
-
- Thanks to Jia Tan for the original patch.
-
- src/liblzma/common/string_conversion.c | 15 +++++++++++++++
- 1 file changed, 15 insertions(+)
-
-commit c68af4441744e5ffc41a472e1be9c9d53a1d9780
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-12-01 17:38:03 +0200
-
- Translations: Update the Chinese (simplified) translation.
-
- po/zh_CN.po | 608 ++++++++++++++++++++++++++++++++++--------------------------
- 1 file changed, 348 insertions(+), 260 deletions(-)
-
-commit 3be6942e5c27d29995d41da52fbe274e4ce4a537
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-11-30 18:55:03 +0200
-
- Add NEWS for 5.2.9.
-
- NEWS | 34 ++++++++++++++++++++++++++++++++++
- 1 file changed, 34 insertions(+)
-
-commit 7c16e312cb2f40b81154c0e5be13a3c6b8da485d
-Author: Jia Tan <jiat0218@gmail.com>
-Date: 2022-11-30 23:33:08 +0800
-
- xz: Remove message_filters_to_str function prototype from message.h.
-
- This was forgotten from 7484744af6cbabe81e92af7d9e061dfd597fff7b.
-
- src/xz/message.h | 16 ----------------
- 1 file changed, 16 deletions(-)
-
-commit 764955e2d4f2a5e8d6d6fec63af694f799e050e7
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-11-30 18:08:34 +0200
-
- Change the bug report address.
-
- It forwards to me and Jia Tan.
-
- Also update the IRC reference in README as #tukaani was moved
- to Libera Chat long ago.
-
- CMakeLists.txt | 2 +-
- README | 11 +++++------
- configure.ac | 2 +-
- dos/config.h | 2 +-
- windows/README-Windows.txt | 2 +-
- 5 files changed, 9 insertions(+), 10 deletions(-)
-
-commit c21983c76031e01da01ad3c6cc716fe4b8a75070
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-11-30 17:50:17 +0200
-
- Build: Add string_conversion.c to CMake, DOS, and VS files.
-
- CMakeLists.txt | 1 +
- dos/Makefile | 1 +
- windows/vs2013/liblzma.vcxproj | 1 +
- windows/vs2013/liblzma_dll.vcxproj | 1 +
- windows/vs2017/liblzma.vcxproj | 1 +
- windows/vs2017/liblzma_dll.vcxproj | 1 +
- windows/vs2019/liblzma.vcxproj | 1 +
- windows/vs2019/liblzma_dll.vcxproj | 1 +
- 8 files changed, 8 insertions(+)
-
-commit 30be0c35d24eb5175459d69dbf7d92e2b087ef82
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-11-30 17:38:32 +0200
-
- Update to HTTPS URLs in AUTHORS.
-
- AUTHORS | 6 +++---
- 1 file changed, 3 insertions(+), 3 deletions(-)
-
-commit 0a72b9ca2fe20082da9b7128fe0d908af947a851
-Author: Jia Tan <jiat0218@gmail.com>
-Date: 2022-11-30 00:52:06 +0800
-
- liblzma: Improve documentation for string to filter functions.
-
- src/liblzma/api/lzma/filter.h | 17 +++++++++--------
- 1 file changed, 9 insertions(+), 8 deletions(-)
-
-commit a6e21fcede3b196160a52dd294d965c508a4bb33
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-11-29 22:27:42 +0200
-
- liblzma: Two fixes to lzma_str_list_filters() API docs.
-
- Thanks to Jia Tan.
-
- src/liblzma/api/lzma/filter.h | 6 +++---
- 1 file changed, 3 insertions(+), 3 deletions(-)
-
-commit 7484744af6cbabe81e92af7d9e061dfd597fff7b
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-11-28 21:57:47 +0200
-
- xz: Use lzma_str_from_filters().
-
- Two uses: Displaying encoder filter chain when compressing with -vv,
- and displaying the decoder filter chain in --list -vv.
-
- src/xz/list.c | 28 ++++++---
- src/xz/message.c | 175 +++----------------------------------------------------
- 2 files changed, 28 insertions(+), 175 deletions(-)
-
-commit cedeeca2ea6ada5b0411b2ae10d7a859e837f203
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-11-28 21:37:48 +0200
-
- liblzma: Add lzma_str_to_filters, _from_filters, and _list_filters.
-
- lzma_str_to_filters() uses static error messages which makes
- them not very precise. It tells the position in the string
- where an error occurred though which helps quite a bit if
- applications take advantage of it. Dynamic error messages can
- be added later with a new flag if it seems important enough.
-
- src/liblzma/api/lzma/filter.h | 258 +++++++
- src/liblzma/common/Makefile.inc | 1 +
- src/liblzma/common/string_conversion.c | 1302 ++++++++++++++++++++++++++++++++
- src/liblzma/liblzma_generic.map | 3 +
- src/liblzma/liblzma_linux.map | 3 +
- 5 files changed, 1567 insertions(+)
-
-commit 072ebf7b1335421193ffa9d4a70d5533786b8995
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-11-28 21:02:19 +0200
-
- liblzma: Make lzma_validate_chain() available outside filter_common.c.
-
- src/liblzma/common/filter_common.c | 8 ++++----
- src/liblzma/common/filter_common.h | 3 +++
- 2 files changed, 7 insertions(+), 4 deletions(-)
-
-commit 5f22bd2d37e3bd01a5d701b51750eb51f09c11bf
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-11-28 10:51:03 +0200
-
- liblzma: Remove lzma_lz_decoder_uncompressed() as it's now unused.
-
- src/liblzma/lz/lz_decoder.c | 14 --------------
- src/liblzma/lz/lz_decoder.h | 3 ---
- 2 files changed, 17 deletions(-)
-
-commit cee83206465b95729ab649aa2f57fdbde8dcaf89
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-11-28 10:48:53 +0200
-
- liblzma: Use LZMA1EXT feature in lzma_microlzma_decoder().
-
- Here too this avoids the slightly ugly method to set
- the uncompressed size.
-
- Also moved the setting of dict_size to the struct initializer.
-
- src/liblzma/common/microlzma_decoder.c | 15 ++++++++-------
- 1 file changed, 8 insertions(+), 7 deletions(-)
-
-commit e310e8b6a490dfb468f4ed68feff246d776b323c
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-11-28 10:28:20 +0200
-
- liblzma: Use LZMA1EXT feature in lzma_alone_decoder().
-
- This avoids the need to use the slightly ugly method to
- set the uncompressed size.
-
- src/liblzma/common/alone_decoder.c | 18 +++++++++++++-----
- 1 file changed, 13 insertions(+), 5 deletions(-)
-
-commit 33b8a24b6646a9dbfd8358405aec466b13078559
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-11-27 23:16:21 +0200
-
- liblzma: Add LZMA_FILTER_LZMA1EXT to support LZMA1 without end marker.
-
- Some file formats need support for LZMA1 streams that don't use
- the end of payload marker (EOPM) alias end of stream (EOS) marker.
- So far liblzma API has supported decompressing such streams via
- lzma_alone_decoder() when .lzma header specifies a known
- uncompressed size. Encoding support hasn't been available in the API.
-
- Instead of adding a new LZMA1-only API for this purpose, this commit
- adds a new filter ID for use with raw encoder and decoder. The main
- benefit of this approach is that then also filter chains are possible,
- for example, if someone wants to implement support for .7z files that
- use the x86 BCJ filter with LZMA1 (not BCJ2 as that isn't supported
- in liblzma).
-
- src/liblzma/api/lzma/lzma12.h | 123 ++++++++++++++++++++++++++++++--
- src/liblzma/common/filter_common.c | 7 ++
- src/liblzma/common/filter_decoder.c | 6 ++
- src/liblzma/common/filter_encoder.c | 9 +++
- src/liblzma/lzma/lzma2_encoder.c | 2 +-
- src/liblzma/lzma/lzma_decoder.c | 26 ++++++-
- src/liblzma/lzma/lzma_encoder.c | 40 +++++++++--
- src/liblzma/lzma/lzma_encoder.h | 3 +-
- src/liblzma/lzma/lzma_encoder_private.h | 3 +
- 9 files changed, 204 insertions(+), 15 deletions(-)
-
-commit 9a304bf1e45b3ddf61aaeaa7c764915b34618ede
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-11-27 18:43:07 +0200
-
- liblzma: Avoid unneeded use of void pointer in LZMA decoder.
-
- src/liblzma/lzma/lzma_decoder.c | 3 +--
- src/liblzma/lzma/lzma_decoder.h | 2 +-
- 2 files changed, 2 insertions(+), 3 deletions(-)
-
-commit 218394958c7683f892275bb40eae880620feebcc
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-11-27 18:20:33 +0200
-
- liblzma: Pass the Filter ID to LZ encoder and decoder.
-
- This allows using two Filter IDs with the same
- initialization function and data structures.
-
- src/liblzma/common/alone_decoder.c | 1 +
- src/liblzma/common/alone_encoder.c | 1 +
- src/liblzma/common/common.h | 7 +++++--
- src/liblzma/common/lzip_decoder.c | 1 +
- src/liblzma/common/microlzma_decoder.c | 1 +
- src/liblzma/common/microlzma_encoder.c | 1 +
- src/liblzma/lz/lz_decoder.c | 5 +++--
- src/liblzma/lz/lz_decoder.h | 3 ++-
- src/liblzma/lz/lz_encoder.c | 5 +++--
- src/liblzma/lz/lz_encoder.h | 3 ++-
- src/liblzma/lzma/lzma2_decoder.c | 3 ++-
- src/liblzma/lzma/lzma2_encoder.c | 3 ++-
- src/liblzma/lzma/lzma_decoder.c | 2 +-
- src/liblzma/lzma/lzma_encoder.c | 2 +-
- 14 files changed, 26 insertions(+), 12 deletions(-)
-
-commit 1663c7676b76f4c514031797f3db1896e8100f7f
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-11-27 01:03:16 +0200
-
- liblzma: Remove two FIXME comments.
-
- src/liblzma/common/filter_encoder.c | 4 ++--
- 1 file changed, 2 insertions(+), 2 deletions(-)
-
-commit 11fe708db783ac36ebeeb85da164e29e8c300910
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-11-26 22:25:30 +0200
-
- xz: Use lzma_filters_free().
-
- src/xz/list.c | 8 ++------
- 1 file changed, 2 insertions(+), 6 deletions(-)
-
-commit e782af9110d8499c7ac2929bc871540eefea5ea1
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-11-26 22:21:13 +0200
-
- liblzma: Use lzma_filters_free() in more places.
-
- src/liblzma/common/block_header_decoder.c | 20 ++------------------
- src/liblzma/common/stream_decoder.c | 4 +---
- src/liblzma/common/stream_decoder_mt.c | 22 +++++-----------------
- 3 files changed, 8 insertions(+), 38 deletions(-)
-
-commit 90caaded2dc6db1d6a55b01160d7e87f4a423628
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-11-25 18:04:37 +0200
-
- liblzma: Omit simple coder init functions if they are disabled.
-
- src/liblzma/simple/arm.c | 4 ++++
- src/liblzma/simple/armthumb.c | 4 ++++
- src/liblzma/simple/ia64.c | 4 ++++
- src/liblzma/simple/powerpc.c | 4 ++++
- src/liblzma/simple/sparc.c | 4 ++++
- src/liblzma/simple/x86.c | 4 ++++
- 6 files changed, 24 insertions(+)
-
-commit 5cd9f0df78cc4f8a7807bf6104adea13034fbb45
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-11-24 23:24:59 +0200
-
- xz: Allow nice_len 2 and 3 even if match finder requires 3 or 4.
-
- Now that liblzma accepts these, we avoid the extra check and
- there's one message less for translators too.
-
- src/xz/options.c | 5 -----
- 1 file changed, 5 deletions(-)
-
-commit 3be88ae071371caa279b44e13f4836fb178fe4ae
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-11-24 23:23:55 +0200
-
- liblzma: Allow nice_len 2 and 3 even if match finder requires 3 or 4.
-
- That is, if the specified nice_len is smaller than the minimum
- of the match finder, silently use the match finder's minimum value
- instead of reporting an error. The old behavior is annoying to users
- and it complicates xz options handling too.
-
- src/liblzma/lz/lz_encoder.c | 14 +++++++++-----
- src/liblzma/lz/lz_encoder.h | 9 +++++++++
- src/liblzma/lzma/lzma_encoder.c | 11 ++++++++---
- 3 files changed, 26 insertions(+), 8 deletions(-)
-
-commit 93439cfafe1768b3b18d67d2356ef7e7559bba59
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-11-24 16:25:10 +0200
-
- liblzma: Add lzma_filters_update() support to the multi-threaded encoder.
-
- A tiny downside of this is that now a 1-4 tiny allocations are made
- for every Block because each worker thread needs its own copy of
- the filter chain.
-
- src/liblzma/api/lzma/filter.h | 36 +++++++------
- src/liblzma/common/stream_encoder_mt.c | 96 +++++++++++++++++++++++++++++++---
- 2 files changed, 109 insertions(+), 23 deletions(-)
-
-commit 17ac51e689794eb41cab3e80946fec689caea2d2
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-11-24 14:53:22 +0200
-
- Update THANKS.
-
- THANKS | 1 +
- 1 file changed, 1 insertion(+)
-
-commit 06824396b2b6c84f3a235cb7c19c2a9701167797
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-11-24 14:52:44 +0200
-
- Build: Don't put GNU/Linux-specific symbol versions into static liblzma.
-
- It not only makes no sense to put symbol versions into a static library
- but it can also cause breakage.
-
- By default Libtool #defines PIC if building a shared library and
- doesn't define it for static libraries. This is documented in the
- Libtool manual. It can be overriden using --with-pic or --without-pic.
- configure.ac detects if --with-pic or --without-pic is used and then
- gives an error if neither --disable-shared nor --disable-static was
- used at the same time. Thus, in normal situations it works to build
- both shared and static library at the same time on GNU/Linux,
- only --with-pic or --without-pic requires that only one type of
- library is built.
-
- Thanks to John Paul Adrian Glaubitz from Debian for reporting
- the problem that occurred on ia64:
- https://www.mail-archive.com/xz-devel@tukaani.org/msg00610.html
-
- CMakeLists.txt | 5 +-
- configure.ac | 143 +++++++++++++++++++++++++++++---------------
- src/liblzma/common/common.h | 12 ++++
- 3 files changed, 111 insertions(+), 49 deletions(-)
-
-commit e1acf7107291f8b3d6d609a7133331ff36d35d14
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-11-24 01:32:16 +0200
-
- liblzma: Refactor to use lzma_filters_free().
-
- lzma_filters_free() sets the options to NULL and ids to
- LZMA_VLI_UNKNOWN so there is no need to do it by caller;
- the filter arrays will always be left in a safe state.
-
- Also use memcpy() instead of a loop to copy a filter chain
- when it is known to be safe to copy LZMA_FILTERS_MAX + 1
- (even if the elements past the terminator might be uninitialized).
-
- src/liblzma/common/stream_encoder.c | 16 ++++------------
- src/liblzma/common/stream_encoder_mt.c | 11 ++---------
- 2 files changed, 6 insertions(+), 21 deletions(-)
-
-commit cb05dbcf8b868441ec805016222f3fd77f1c5caa
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-11-24 01:26:37 +0200
-
- liblzma: Fix another invalid free() after memory allocation failure.
-
- This time it can happen when lzma_stream_encoder_mt() is used
- to reinitialize an existing multi-threaded Stream encoder
- and one of 1-4 tiny allocations in lzma_filters_copy() fail.
-
- It's very similar to the previous bug
- 10430fbf3820dafd4eafd38ec8be161a6978ed2b, happening with
- an array of lzma_filter structures whose old options are freed
- but the replacement never arrives due to a memory allocation
- failure in lzma_filters_copy().
-
- src/liblzma/common/stream_encoder_mt.c | 4 ++++
- 1 file changed, 4 insertions(+)
-
-commit 75f1a6c26df4ce329da0882786403e3ccf5cd898
-Author: Jia Tan <jiat0218@gmail.com>
-Date: 2022-05-05 20:53:42 +0800
-
- liblzma: Add support for LZMA_SYNC_FLUSH in the Block encoder.
-
- The documentation mentions that lzma_block_encoder() supports
- LZMA_SYNC_FLUSH but it was never added to supported_actions[]
- in the internal structure. Because of this, LZMA_SYNC_FLUSH could
- not be used with the Block encoder unless it was the next coder
- after something like stream_encoder() or stream_encoder_mt().
-
- src/liblzma/common/block_encoder.c | 1 +
- 1 file changed, 1 insertion(+)
-
-commit d0901645170b638c517f5c50866b6ef48f491c65
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-11-24 01:02:50 +0200
-
- liblzma: Add new API function lzma_filters_free().
-
- This is small but convenient and should have been added
- a long time ago.
-
- src/liblzma/api/lzma/filter.h | 21 +++++++++++++++++++++
- src/liblzma/common/filter_common.c | 26 ++++++++++++++++++++++++++
- src/liblzma/liblzma_generic.map | 1 +
- src/liblzma/liblzma_linux.map | 1 +
- 4 files changed, 49 insertions(+)
-
-commit ae1f8a723dcde2f2c5cf444bcbb5fc5026b3c3c5
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-11-24 00:02:31 +0200
-
- CMake: Don't use symbol versioning with static library.
-
- CMakeLists.txt | 10 +++++++---
- 1 file changed, 7 insertions(+), 3 deletions(-)
-
-commit 48c1b99dc537a27e1ca929d8837e778e5ba32191
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-11-23 21:55:22 +0200
-
- liblzma: Add lzma_attr_warn_unused_result to lzma_filters_copy().
-
- src/liblzma/api/lzma/filter.h | 3 ++-
- 1 file changed, 2 insertions(+), 1 deletion(-)
-
-commit 10430fbf3820dafd4eafd38ec8be161a6978ed2b
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-11-23 21:26:21 +0200
-
- liblzma: Fix invalid free() after memory allocation failure.
-
- The bug was in the single-threaded .xz Stream encoder
- in the code that is used for both re-initialization and for
- lzma_filters_update(). To trigger it, an application had
- to either re-initialize an existing encoder instance with
- lzma_stream_encoder() or use lzma_filters_update(), and
- then one of the 1-4 tiny allocations in lzma_filters_copy()
- (called from stream_encoder_update()) must fail. An error
- was correctly reported but the encoder state was corrupted.
-
- This is related to the recent fix in
- f8ee61e74eb40600445fdb601c374d582e1e9c8a which is good but
- it wasn't enough to fix the main problem in stream_encoder.c.
-
- src/liblzma/common/stream_encoder.c | 39 +++++++++++++++++++++++++++++--------
- 1 file changed, 31 insertions(+), 8 deletions(-)
-
-commit cafd6dc397ca8b5b5f7775e8d6876b8fe70f8e70
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-11-22 16:37:15 +0200
-
- liblzma: Fix language in a comment.
-
- src/liblzma/common/stream_encoder.c | 2 +-
- 1 file changed, 1 insertion(+), 1 deletion(-)
-
-commit c392bf8ccba857baaf50399c4b460119befacd54
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-11-22 11:20:17 +0200
-
- liblzma: Fix infinite loop in LZMA encoder init with dict_size >= 2 GiB.
-
- The encoder doesn't support dictionary sizes larger than 1536 MiB.
- This is validated, for example, when calculating the memory usage
- via lzma_raw_encoder_memusage(). It is also enforced by the LZ
- part of the encoder initialization. However, LZMA encoder with
- LZMA_MODE_NORMAL did an unsafe calculation with dict_size before
- such validation and that results in an infinite loop if dict_size
- was 2 << 30 or greater.
-
- src/liblzma/lzma/lzma_encoder.c | 19 +++++++++++++++----
- 1 file changed, 15 insertions(+), 4 deletions(-)
-
-commit f50534c973a591ccf65485adfc827a8a7126ca6c
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-11-21 13:02:33 +0200
-
- liblzma: Fix two Doxygen commands in the API headers.
-
- These were caught by clang -Wdocumentation.
-
- src/liblzma/api/lzma/hardware.h | 2 +-
- src/liblzma/api/lzma/index_hash.h | 2 +-
- 2 files changed, 2 insertions(+), 2 deletions(-)
-
-commit 649d4872ed2f55196114a061d45b416fc4353569
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-11-19 19:09:55 +0200
-
- xz: Refactor duplicate code from hardware_memlimit_mtenc_get().
-
- src/xz/hardware.c | 2 +-
- 1 file changed, 1 insertion(+), 1 deletion(-)
-
-commit d327743bb547a53364e5951a16e5f1663fe4b9ff
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-11-19 19:06:13 +0200
-
- xz: Add support --threads=+N so that -T+1 gives threaded mode.
-
- src/xz/args.c | 18 +++++++++++++++---
- src/xz/hardware.c | 17 +++++++++++++++--
- src/xz/hardware.h | 1 +
- src/xz/xz.1 | 21 ++++++++++++++++++++-
- 4 files changed, 51 insertions(+), 6 deletions(-)
-
-commit a11a2b8b5e830ba682c1d81aaa7078842b296995
-Author: Jia Tan <jiat0218@gmail.com>
-Date: 2022-11-19 23:18:04 +0800
-
- CMake: Adds test_memlimit to CMake tests
-
- CMakeLists.txt | 1 +
- 1 file changed, 1 insertion(+)
-
-commit 2af8d9e9b3f44f62d19e7c39297ec63af2e8c64f
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-11-15 19:10:21 +0200
-
- Translations: Update the Korean translation.
-
- po/ko.po | 652 ++++++++++++++++++++++++++++++++++++---------------------------
- 1 file changed, 371 insertions(+), 281 deletions(-)
-
-commit 16ac05677292f7e21a4feaddcfb2ab062ea5f385
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-11-15 19:09:28 +0200
-
- Translations: Update the Turkish translation.
-
- po/tr.po | 568 ++++++++++++++++++++++++++++++++++-----------------------------
- 1 file changed, 310 insertions(+), 258 deletions(-)
-
-commit b9a67d9a5fa207062d4aa8a01639234609315d31
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-11-15 10:58:39 +0200
-
- Bump version number for 5.3.4alpha.
-
- src/liblzma/api/lzma/version.h | 2 +-
- src/liblzma/liblzma_generic.map | 2 +-
- src/liblzma/liblzma_linux.map | 2 +-
- 3 files changed, 3 insertions(+), 3 deletions(-)
-
-commit 5b999ba289b3280457b7386b9ac65dbbdf1575a5
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-11-15 10:54:40 +0200
-
- Add NEWS for 5.3.4alpha.
-
- NEWS | 96 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
- 1 file changed, 96 insertions(+)
-
-commit ce8db9e37da4f6c87691c5066f51f91f2411c44a
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-11-15 10:54:08 +0200
-
- Add NEWS for 5.2.8.
-
- NEWS | 79 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
- 1 file changed, 79 insertions(+)
-
-commit b56bc8251d2736224af6bdaaae734ceb8926a879
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-11-14 23:19:57 +0200
-
- Revert "liblzma: Simple/BCJ filters: Allow disabling generic BCJ options."
-
- This reverts commit 177bdc922cb17bd0fd831ab8139dfae912a5c2b8
- and also does equivalent change to arm64.c.
-
- Now that ARM64 filter will use lzma_options_bcj, this change
- is not needed anymore.
-
- src/liblzma/simple/arm.c | 2 +-
- src/liblzma/simple/arm64.c | 2 +-
- src/liblzma/simple/armthumb.c | 2 +-
- src/liblzma/simple/ia64.c | 2 +-
- src/liblzma/simple/powerpc.c | 2 +-
- src/liblzma/simple/simple_coder.c | 4 ++--
- src/liblzma/simple/simple_private.h | 2 +-
- src/liblzma/simple/sparc.c | 2 +-
- src/liblzma/simple/x86.c | 3 +--
- 9 files changed, 10 insertions(+), 11 deletions(-)
-
-commit 8370ec8edf9ddf8d1d9fef03d8d1027503ec4c35
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-11-14 23:14:41 +0200
-
- Replace the experimental ARM64 filter with a new experimental version.
-
- This is incompatible with the previous version.
-
- This has space/tab fixes in filter_*.c and bcj.h too.
-
- src/liblzma/api/lzma/bcj.h | 41 +-----
- src/liblzma/common/filter_common.c | 14 +-
- src/liblzma/common/filter_decoder.c | 12 +-
- src/liblzma/common/filter_encoder.c | 17 +--
- src/liblzma/simple/arm64.c | 283 ++++++++++++++----------------------
- src/liblzma/simple/simple_decoder.h | 4 -
- src/liblzma/simple/simple_encoder.h | 2 -
- src/xz/args.c | 2 +-
- src/xz/message.c | 13 +-
- src/xz/options.c | 39 -----
- src/xz/options.h | 7 -
- 11 files changed, 147 insertions(+), 287 deletions(-)
-
-commit f644473a211394447824ea00518d0a214ff3f7f2
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-11-14 21:34:57 +0200
-
- liblzma: Add fast CRC64 for 32/64-bit x86 using SSSE3 + SSE4.1 + CLMUL.
-
- It also works on E2K as it supports these intrinsics.
-
- On x86-64 runtime detection is used so the code keeps working on
- older processors too. A CLMUL-only build can be done by using
- -msse4.1 -mpclmul in CFLAGS and this will reduce the library
- size since the generic implementation and its 8 KiB lookup table
- will be omitted.
-
- On 32-bit x86 this isn't used by default for now because by default
- on 32-bit x86 the separate assembly file crc64_x86.S is used.
- If --disable-assembler is used then this new CLMUL code is used
- the same way as on 64-bit x86. However, a CLMUL-only build
- (-msse4.1 -mpclmul) won't omit the 8 KiB lookup table on
- 32-bit x86 due to a currently-missing check for disabled
- assembler usage.
-
- The configure.ac check should be such that the code won't be
- built if something in the toolchain doesn't support it but
- --disable-clmul-crc option can be used to unconditionally
- disable this feature.
-
- CLMUL speeds up decompression of files that have compressed very
- well (assuming CRC64 is used as a check type). It is know that
- the CLMUL code is significantly slower than the generic code for
- tiny inputs (especially 1-8 bytes but up to 16 bytes). If that
- is a real-world problem then there is already a commented-out
- variant that uses the generic version for small inputs.
-
- Thanks to Ilya Kurdyukov for the original patch which was
- derived from a white paper from Intel [1] (published in 2009)
- and public domain code from [2] (released in 2016).
-
- [1] https://www.intel.com/content/dam/www/public/us/en/documents/white-papers/fast-crc-computation-generic-polynomials-pclmulqdq-paper.pdf
- [2] https://github.com/rawrunprotected/crc
-
- CMakeLists.txt | 26 ++-
- INSTALL | 12 ++
- configure.ac | 59 +++++-
- src/liblzma/check/crc64_fast.c | 449 +++++++++++++++++++++++++++++++++++++++-
- src/liblzma/check/crc64_table.c | 21 +-
- 5 files changed, 554 insertions(+), 13 deletions(-)
-
-commit 3b466bc79672bb2b06d1245a500588e6026e0ba0
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-11-14 20:14:34 +0200
-
- Translations: Update the Swedish translation one more time.
-
- po/sv.po | 6 +++---
- 1 file changed, 3 insertions(+), 3 deletions(-)
-
-commit e963379a8622ebdff6ce78e76b803bcd1e1d16d6
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-11-14 19:34:15 +0200
-
- Translations: Update the Swedish translation again.
-
- po/sv.po | 16 ++++++++--------
- 1 file changed, 8 insertions(+), 8 deletions(-)
-
-commit a4bc689a823a2254f29ac9d233170add5121b307
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-11-14 19:07:45 +0200
-
- Translations: Update the Swedish translation.
-
- po/sv.po | 671 ++++++++++++++++++++++++++++++++++++---------------------------
- 1 file changed, 382 insertions(+), 289 deletions(-)
-
-commit bbf2073d824ab4ba33bed4b77f467435abd333a5
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-11-14 18:58:09 +0200
-
- Translations: Update the Ukrainian translation.
-
- po/uk.po | 618 ++++++++++++++++++++++++++++++++++++---------------------------
- 1 file changed, 354 insertions(+), 264 deletions(-)
-
-commit ac10b1b3622e70881595586edfb8a3ebdcd76bb6
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-11-14 17:58:07 +0200
-
- Build: Omit x86_64 from --enable-assembler.
-
- It didn't do anything. There are only 32-bit x86 assembly files
- and it feels likely that new files won't be added as intrinsics
- in C are more portable across toolchains and OSes.
-
- configure.ac | 6 ++----
- 1 file changed, 2 insertions(+), 4 deletions(-)
-
-commit eb0f1450ad9f23dac03050d9c8375980240aee21
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-11-14 16:00:52 +0200
-
- liblzma: Use __attribute__((__constructor__)) if available.
-
- This uses it for CRC table initializations when using --disable-small.
- It avoids mythread_once() overhead. It also means that then
- --disable-small --disable-threads is thread-safe if this attribute
- is supported.
-
- CMakeLists.txt | 15 +++++++++++++++
- INSTALL | 4 +++-
- configure.ac | 31 ++++++++++++++++++++++++++++---
- src/liblzma/check/crc32_small.c | 7 +++++++
- src/liblzma/check/crc64_small.c | 5 +++++
- src/liblzma/lz/lz_encoder.c | 2 +-
- 6 files changed, 59 insertions(+), 5 deletions(-)
-
-commit 6553f49b11dafad35c73b05f12e14865ea1fd8a1
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-11-12 21:19:52 +0200
-
- Translations: Update the Romanian translation.
-
- po/ro.po | 651 +++++++++++++++++++++++++++++++++++++--------------------------
- 1 file changed, 380 insertions(+), 271 deletions(-)
-
-commit db97e69e12393becc29f8febd53133d0d36989bd
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-11-12 21:17:45 +0200
-
- Translations: Update the Hungarian translation.
-
- po/hu.po | 625 ++++++++++++++++++++++++++++++++++++---------------------------
- 1 file changed, 357 insertions(+), 268 deletions(-)
-
-commit 2bbb9c0f3829a8b121b36998d273a6c6f92000f4
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-11-11 17:58:57 +0200
-
- Translations: Update the Finnish translation.
-
- po/fi.po | 610 ++++++++++++++++++++++++++++++++++++---------------------------
- 1 file changed, 348 insertions(+), 262 deletions(-)
-
-commit 3c8cbb8137b6f8ed9416c1209d73cdbcb015251f
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-11-11 17:58:18 +0200
-
- Translations: Update the Croatian translation.
-
- po/hr.po | 680 +++++++++++++++++++++++++++++++++++----------------------------
- 1 file changed, 381 insertions(+), 299 deletions(-)
-
-commit 26c3359eac0988d6f3986735cd1363bec1678e8e
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-11-11 17:57:18 +0200
-
- Translations: Update the Polish translation.
-
- po/pl.po | 569 ++++++++++++++++++++++++++++++++++-----------------------------
- 1 file changed, 309 insertions(+), 260 deletions(-)
-
-commit 577e467b137c735afb8de6ae71ac7a73c2960cc4
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-11-11 17:56:44 +0200
-
- Translations: Update the Spanish translation.
-
- po/es.po | 598 ++++++++++++++++++++++++++++++++++++---------------------------
- 1 file changed, 344 insertions(+), 254 deletions(-)
-
-commit f9b4ff6e9a0f1678650775582d3e4fe782abce97
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-11-11 17:16:03 +0200
-
- Update THANKS.
-
- THANKS | 1 +
- 1 file changed, 1 insertion(+)
-
-commit a39961ef211e1bf030b17edeea3cff29fe263b67
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-11-11 17:15:25 +0200
-
- liblzma: Fix building with Intel ICC (the classic compiler).
-
- It claims __GNUC__ >= 10 but doesn't support __symver__ attribute.
-
- Thanks to Stephen Sachs.
-
- src/liblzma/common/common.h | 2 +-
- 1 file changed, 1 insertion(+), 1 deletion(-)
-
-commit c715f683dcb1a817d565da292cddfbceda643e12
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-11-11 14:35:58 +0200
-
- liblzma: Fix incorrect #ifdef for x86 SSE2 support.
-
- __SSE2__ is the correct macro for SSE2 support with GCC, Clang,
- and ICC. __SSE2_MATH__ means doing floating point math with SSE2
- instead of 387. Often the latter macro is defined if the first
- one is but it was still a bug.
-
- src/liblzma/common/memcmplen.h | 3 +--
- 1 file changed, 1 insertion(+), 2 deletions(-)
-
-commit bd334ae56afe7f642ad4d0f1ac19e74e82daa1ce
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-11-11 13:27:06 +0200
-
- Add NEWS for 5.2.7 (forgotten cherry-pick from v5.2).
-
- NEWS | 74 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
- 1 file changed, 74 insertions(+)
-
-commit 3c7860cf49de6f81046b3a4034a89f3a4803a576
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-11-11 13:16:21 +0200
-
- xzdiff: Add support for .lz files.
-
- The other scripts don't need changes for .lz support because
- in those scripts it is enough that xz supports .lz.
-
- src/scripts/xzdiff.in | 10 +++++-----
- 1 file changed, 5 insertions(+), 5 deletions(-)
-
-commit d76c752a6d77052e5ad57ade555082585f7ac5d8
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-11-11 12:23:58 +0200
-
- Scripts: Ignore warnings from xz.
-
- In practice this means making the scripts work when
- the input files have an unsupported check type which
- isn't a problem in practice unless support for
- some check types has been disabled at build time.
-
- src/scripts/xzdiff.in | 5 +++--
- src/scripts/xzgrep.in | 2 +-
- src/scripts/xzless.in | 4 ++--
- src/scripts/xzmore.in | 4 ++--
- 4 files changed, 8 insertions(+), 7 deletions(-)
-
-commit 6552535afd1fe29d726ab6e68cf14ce3624fd48c
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-11-10 12:34:43 +0200
-
- Translations: Rename poa4/fr_FR.po to po4a/fr.po.
-
- That's how it is preferred at the Translation Project.
- On my system /usr/share/man/fr_FR doesn't contain any
- other man pages than XZ Utils while /usr/share/man/fr
- has quite a few, so this will fix that too.
-
- Thanks to Benno Schulenberg from the Translation Project.
-
- po4a/{fr_FR.po => fr.po} | 0
- po4a/po4a.conf | 2 +-
- 2 files changed, 1 insertion(+), 1 deletion(-)
-
-commit 0918159ce4c75bfb60aff0193b559f8a9f41d25a
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-11-09 18:48:50 +0200
-
- xz: Update the man page about BCJ filters, including upcoming --arm64.
-
- The --arm64 isn't actually implemented yet in the form
- described in this commit.
-
- Thanks to Jia Tan.
-
- src/xz/xz.1 | 66 +++++++++++++++++++++++++++----------------------------------
- 1 file changed, 29 insertions(+), 37 deletions(-)
-
-commit ba2ae3596f6be1587495f33b367488f6e00e56f1
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-11-09 18:14:14 +0200
-
- xz: Add --arm64 to --long-help and omit endianness from ARM(-Thumb).
-
- Modern 32-bit ARM in big endian mode use little endian for
- instruction encoding still, so the filters work on such
- executables too. It's likely less confusing for users this way.
-
- The --arm64 option hasn't been implemented yet (there is
- --experimental-arm64 but it's different). The --arm64 option
- is added now anyway because this is the likely result and the
- strings need to be ready for translators.
-
- Thanks to Jia Tan.
-
- src/xz/message.c | 5 +++--
- 1 file changed, 3 insertions(+), 2 deletions(-)
-
-commit 802d57d9215d9c81dbee86edb43c9e93a7f7ec55
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-11-09 15:12:13 +0200
-
- Windows: Update the VS project files for ARM64 and .lz support.
-
- windows/vs2013/config.h | 9 +++++++++
- windows/vs2013/liblzma.vcxproj | 5 ++++-
- windows/vs2013/liblzma_dll.vcxproj | 5 ++++-
- windows/vs2017/config.h | 9 +++++++++
- windows/vs2017/liblzma.vcxproj | 3 +++
- windows/vs2017/liblzma_dll.vcxproj | 3 +++
- windows/vs2019/config.h | 9 +++++++++
- windows/vs2019/liblzma.vcxproj | 5 ++++-
- windows/vs2019/liblzma_dll.vcxproj | 5 ++++-
- 9 files changed, 49 insertions(+), 4 deletions(-)
-
-commit 5846aeda05972bc803c6094821ae836229ebe691
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-11-09 14:57:48 +0200
-
- DOS: Update Makefile and config.h to include ARM64 and .lz support.
-
- dos/Makefile | 2 ++
- dos/config.h | 9 +++++++++
- 2 files changed, 11 insertions(+)
-
-commit 781da8d6c44de6aa278c916375250668a0b107f2
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-11-09 14:45:05 +0200
-
- CMake: Add lzip decoder files and #define to the build.
-
- CMakeLists.txt | 3 +++
- 1 file changed, 3 insertions(+)
-
-commit df8ad4af65a9c4846b108550d0083770a69dee64
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-11-09 14:41:56 +0200
-
- Docs: Update INSTALL and also add new prohibited options to PACKAGERS.
-
- INSTALL | 49 +++++++++++++++++++++++++++++++++++++++++--------
- PACKAGERS | 2 ++
- 2 files changed, 43 insertions(+), 8 deletions(-)
-
-commit c8ef089c149afaab413c3a51be827dd1d11afe0e
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-10-20 17:39:06 +0300
-
- Tests: Test the .lz files in test_files.sh.
-
- tests/test_files.sh | 25 +++++++++++++++++++++++++
- 1 file changed, 25 insertions(+)
-
-commit c8f70ebb4628ceb6cb29cc9195d9deadf69d2bd7
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-10-20 15:35:59 +0300
-
- Tests: Add .lz (lzip) test files.
-
- tests/files/README | 109 +++++++++++++++++++++++++++++----
- tests/files/bad-1-v0-uncomp-size.lz | Bin 0 -> 42 bytes
- tests/files/bad-1-v1-crc32.lz | Bin 0 -> 50 bytes
- tests/files/bad-1-v1-dict-1.lz | Bin 0 -> 50 bytes
- tests/files/bad-1-v1-dict-2.lz | Bin 0 -> 50 bytes
- tests/files/bad-1-v1-magic-1.lz | Bin 0 -> 50 bytes
- tests/files/bad-1-v1-magic-2.lz | Bin 0 -> 50 bytes
- tests/files/bad-1-v1-member-size.lz | Bin 0 -> 50 bytes
- tests/files/bad-1-v1-trailing-magic.lz | Bin 0 -> 54 bytes
- tests/files/bad-1-v1-uncomp-size.lz | Bin 0 -> 50 bytes
- tests/files/good-1-v0-trailing-1.lz | Bin 0 -> 59 bytes
- tests/files/good-1-v0.lz | Bin 0 -> 42 bytes
- tests/files/good-1-v1-trailing-1.lz | Bin 0 -> 67 bytes
- tests/files/good-1-v1-trailing-2.lz | Bin 0 -> 70 bytes
- tests/files/good-1-v1.lz | Bin 0 -> 50 bytes
- tests/files/good-2-v0-v1.lz | Bin 0 -> 78 bytes
- tests/files/good-2-v1-v0.lz | Bin 0 -> 78 bytes
- tests/files/good-2-v1-v1.lz | Bin 0 -> 86 bytes
- tests/files/unsupported-1-v234.lz | Bin 0 -> 50 bytes
- 19 files changed, 98 insertions(+), 11 deletions(-)
-
-commit 731db13e6fa3ad3e3fc786c0ccf6eac4cce6865f
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-10-19 22:32:51 +0300
-
- xz: Remove the commented-out FORMAT_GZIP, gzip, .gz, and .tgz.
-
- src/xz/args.c | 2 --
- src/xz/coder.h | 1 -
- src/xz/suffix.c | 9 ---------
- 3 files changed, 12 deletions(-)
-
-commit 3176f992c55b8d788c4633809aaf9447376a5a12
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-10-08 21:28:15 +0300
-
- xz: Add .lz (lzip) decompression support.
-
- If configured with --disable-lzip-decoder then --long-help will
- still list `lzip' in --format but I left it like that since
- due to translations it would be messy to have two help strings.
- Features are disabled only in special situations so wrong help
- in such a situation shouldn't matter much.
-
- Thanks to Michał Górny for the original patch.
-
- src/xz/args.c | 9 ++++++++
- src/xz/coder.c | 68 +++++++++++++++++++++++++++++++++++++++++++++++++++++---
- src/xz/coder.h | 3 +++
- src/xz/message.c | 2 +-
- src/xz/suffix.c | 26 ++++++++++++++++++----
- src/xz/xz.1 | 46 +++++++++++++++++++++++++++++++++-----
- 6 files changed, 141 insertions(+), 13 deletions(-)
-
-commit 034086e1ae1459210837a24e04878435c86dc41b
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-10-08 00:29:20 +0300
-
- liblzma: Add .lz support to lzma_auto_decoder().
-
- Thanks to Michał Górny for the original patch.
-
- src/liblzma/api/lzma/container.h | 10 ++++++----
- src/liblzma/common/Makefile.inc | 3 ++-
- src/liblzma/common/auto_decoder.c | 23 +++++++++++++++++------
- src/liblzma/common/lzip_decoder.h | 22 ++++++++++++++++++++++
- 4 files changed, 47 insertions(+), 11 deletions(-)
-
-commit 0538db038f3cdc352007dacb42454aa1806b8e40
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-10-06 15:50:20 +0300
-
- liblzma: Add .lz (lzip) decompression support (format versions 0 and 1).
-
- Support for format version 0 was removed from lzip 1.18 for some
- reason. .lz format version 0 files are rare (and old) but some
- source packages were released in this format, and some people might
- have personal files in this format too. It's very little extra code
- to support it along side format version 1 so this commits adds
- support for both.
-
- The Sync Flush marker extentension to the original .lz format
- version 1 isn't supported. It would require changes to the
- LZMA decoder itself. Such files are very rare anyway.
-
- See the API doc for lzma_lzip_decoder() for more details about
- the .lz format support.
-
- Thanks to Michał Górny for the original patch.
-
- configure.ac | 21 ++
- src/liblzma/api/lzma/container.h | 62 +++++-
- src/liblzma/common/Makefile.inc | 5 +
- src/liblzma/common/lzip_decoder.c | 413 ++++++++++++++++++++++++++++++++++++++
- src/liblzma/liblzma_generic.map | 1 +
- src/liblzma/liblzma_linux.map | 1 +
- 6 files changed, 501 insertions(+), 2 deletions(-)
-
-commit 633d48a075b9ce4b9c08a7a56a7eb4cabc18100c
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-11-09 14:17:23 +0200
-
- liblzma: Add the missing Makefile.inc change for --disable-microlzma.
-
- This was forgotten from commit 59c4d6e1390f6f4176f43ac1dad1f7ac03c449b8.
-
- src/liblzma/common/Makefile.inc | 12 ++++++++++--
- 1 file changed, 10 insertions(+), 2 deletions(-)
-
-commit 724285dadbdc88765c8fb83eab9816575a260966
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-11-09 14:10:52 +0200
-
- xz: Add comments about stdin and src_st.st_size.
-
- "xz -v < regular_file > out.xz" doesn't display the percentage
- and estimated remaining time because it doesn't even try to
- check the input file size when input is read from stdin.
- This could be improved but for now there's just a comment
- to remind about it.
-
- src/xz/coder.c | 9 +++++++++
- src/xz/file_io.c | 4 ++++
- 2 files changed, 13 insertions(+)
-
-commit f723eec68b0e44234910f669a29119de33018967
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-11-09 12:48:22 +0200
-
- xz: Fix displaying of file sizes in progress indicator in passthru mode.
-
- It worked for one input file since the counters are zero when
- xz starts but they weren't reset when starting a new file in
- passthru mode. For example, if files A, B, and C are one byte each,
- then "xz -dcvf A B C" would show file sizes as 1, 2, and 3 bytes
- instead of 1, 1, and 1 byte.
-
- src/xz/coder.c | 6 +++++-
- 1 file changed, 5 insertions(+), 1 deletion(-)
-
-commit 69265d0f223ddf1d66f799b8b047df22923e376f
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-11-09 11:27:20 +0200
-
- xz: Add a comment why --to-stdout is not in --help.
-
- It is on the man page still.
-
- src/xz/message.c | 3 +++
- 1 file changed, 3 insertions(+)
-
-commit fe6b8852a3c6a0eb5a3c33512e0a69af257d3bc7
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-11-08 23:05:37 +0200
-
- xz: Make xz -lvv show that the upcoming --arm64 needs 5.4.0 to decompress.
-
- src/xz/list.c | 20 +++++++++++++++-----
- 1 file changed, 15 insertions(+), 5 deletions(-)
-
-commit fb3f05ac9f2b4b0e3643401960fbeab31997ac7a
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-11-08 22:26:54 +0200
-
- Docs: Update faq.txt a little.
-
- doc/faq.txt | 66 ++++++++++++++++++++++++++++++++++++++++---------------------
- 1 file changed, 43 insertions(+), 23 deletions(-)
-
-commit 05331f091ec3b68eccbfb2a9a7a576072768fb4b
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-11-08 16:57:17 +0200
-
- Translations: Update Turkish translation.
-
- po/tr.po | 2 +-
- 1 file changed, 1 insertion(+), 1 deletion(-)
-
-commit ed3a4822963b4940d84e6f44d47277c394fc046d
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-11-08 14:55:32 +0200
-
- Translations: Update Croatian translation.
-
- po/hr.po | 190 ++++++++++++++++++++++++++++++++-------------------------------
- 1 file changed, 96 insertions(+), 94 deletions(-)
-
-commit 4746f5ec721316bc4c6fec9905b2902e0360e0af
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-11-08 14:13:03 +0200
-
- liblzma: Update API docs about decoder flags.
-
- src/liblzma/api/lzma/container.h | 21 +++++++++++++++++----
- 1 file changed, 17 insertions(+), 4 deletions(-)
-
-commit 8779a9db5d0cec00c9dc9e9965dd2dda04f9d80d
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-11-08 14:01:50 +0200
-
- liblzma: Use the return_if_error() macro in alone_decoder.c.
-
- src/liblzma/common/alone_decoder.c | 6 ++----
- 1 file changed, 2 insertions(+), 4 deletions(-)
-
-commit 3f4990b6822961e75cd9b4e2e82b1df63f6f8fcc
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-11-08 14:00:58 +0200
-
- liblzma: Fix a comment in auto_decoder.c.
-
- src/liblzma/common/auto_decoder.c | 4 ++--
- 1 file changed, 2 insertions(+), 2 deletions(-)
-
-commit 026a5897c72a2041ae08ceec54ce8b1cdeb51334
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-11-08 13:43:19 +0200
-
- xz: Initialize the pledge(2) sandbox at the very beginning of main().
-
- It feels better that the initializations are sandboxed too.
- They don't do anything that the pledge() call wouldn't allow.
-
- src/xz/main.c | 27 ++++++++++++++-------------
- 1 file changed, 14 insertions(+), 13 deletions(-)
-
-commit 49a59f6ca001c3ce9affa2c162b437aad021b4d5
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-11-07 22:51:16 +0200
-
- xz: Extend --robot --info-memory output.
-
- Now it includes everything that the human-readable --info-memory shows.
-
- src/xz/hardware.c | 24 +++++++++++++++---------
- src/xz/xz.1 | 47 +++++++++++++++++++++++++++++++++++++++++------
- 2 files changed, 56 insertions(+), 15 deletions(-)
-
-commit 5e2450c75cbac966c62cf2231c824f2cc91ddba8
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-11-07 17:22:04 +0200
-
- liblzma: Include cached memory in reported memusage in threaded decoder.
-
- This affects lzma_memusage() and lzma_memlimit_set() when used
- with the threaded decompressor. Now all allocations are reported
- by lzma_memusage() (so it's not misleading) and lzma_memlimit_set()
- cannot lower the limit below that value.
-
- The alternative would have been to allow lowering the limit if
- doing so is possible by freeing the cached memory but since
- the primary use case of lzma_memlimit_set() is to increase
- memlimit after LZMA_MEMLIMIT_ERROR this simple approach
- was selected.
-
- The cached memory was always included when enforcing
- the memory usage limit while decoding.
-
- Thanks to Jia Tan.
-
- src/liblzma/common/stream_decoder_mt.c | 22 +++++++++++++++++++---
- 1 file changed, 19 insertions(+), 3 deletions(-)
-
-commit 1fc6e7dd1fabdb60124d449b99273330ccab3ff1
-Author: Jia Tan <jiat0218@gmail.com>
-Date: 2022-11-07 16:24:14 +0200
-
- xz: Avoid a compiler warning in progress_speed() in message.c.
-
- This should be smaller too since it avoids the string constants.
-
- src/xz/message.c | 9 +++------
- 1 file changed, 3 insertions(+), 6 deletions(-)
-
-commit cf118c014683069b5dbe91898acdc40f2f0a1f5d
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-10-31 16:26:05 +0200
-
- Build: Clarify comment in configure.ac about SSE2.
-
- configure.ac | 5 ++++-
- 1 file changed, 4 insertions(+), 1 deletion(-)
-
-commit aad3c609ffb72f581a7a2b67be3ad70b2b327840
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-10-31 16:16:37 +0200
-
- Build: Remove obsolete commented-out lines from configure.ac.
-
- configure.ac | 4 ----
- 1 file changed, 4 deletions(-)
-
-commit e53e0e2186c6b8ce866bd19aec52f1c318ed31ba
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-10-31 13:31:58 +0200
-
- Windows: Fix mythread_once() macro with Vista threads.
-
- Don't call InitOnceComplete() if initialization was already done.
-
- So far mythread_once() has been needed only when building
- with --enable-small. windows/build.bash does this together
- with --disable-threads so the Vista-specific mythread_once()
- is never needed by those builds. VS project files or
- CMake-builds don't support HAVE_SMALL builds at all.
-
- src/common/mythread.h | 7 ++++---
- 1 file changed, 4 insertions(+), 3 deletions(-)
-
-commit 48dde3bab9dc04081acb5aa7cf7c5044b8a49f58
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-10-31 11:54:44 +0200
-
- liblzma: Silence -Wconversion warning from crc64_fast.c.
-
- src/liblzma/check/crc64_fast.c | 5 +++--
- 1 file changed, 3 insertions(+), 2 deletions(-)
-
-commit a243c617ff249d915ac123de4f536b80322c1fdb
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-10-31 11:49:47 +0200
-
- CMake: Sync tuklib_cpucores.cmake with tuklib_cpucores.m4.
-
- This was forgotten from commit 2611c4d90535652d3eb7ef4a026a6691276fab43.
-
- cmake/tuklib_cpucores.cmake | 5 +++++
- 1 file changed, 5 insertions(+)
-
-commit 05c72de06fcaaedc78f8abba7d5ec568ddcf1e75
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-10-27 15:49:18 +0300
-
- Tests: test_files.sh: Make it not fail if features were disabled at build.
-
- It now tries to test as many files as easily possible.
- The exit status indicates skipping if any of the files were
- skipped. This way it is easy to notice if something is being
- skipped when it isn't expected.
-
- tests/test_files.sh | 50 ++++++++++++++++++++++++++++++++++++++++++++++----
- 1 file changed, 46 insertions(+), 4 deletions(-)
-
-commit b3459327a51f4b8239d19e6c34b4e0c6bc2d81de
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-10-27 15:30:13 +0300
-
- Tests: test_files.sh: Suppress an expected warning from the log.
-
- xz (but not xzdec) will normally warn about unsupported check
- but since we are testing specifically such a file, it's better
- to silence that warning so that it doesn't look suspicious in
- test_files.sh.log.
-
- The use of -q and -Q in xzdec is just for consistency and
- doesn't affect the result at least for now.
-
- tests/test_files.sh | 4 ++--
- 1 file changed, 2 insertions(+), 2 deletions(-)
-
-commit 798c86e4231e0835ab76ccd0810c8ea30833b2ce
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-10-27 15:27:50 +0300
-
- Tests: test_files.sh: Print the reason for skipping if xz & xzdec missing.
-
- tests/test_files.sh | 1 +
- 1 file changed, 1 insertion(+)
-
-commit c1dd8524e1af07f16b790463899de06a6a5fcc08
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-10-27 01:12:40 +0300
-
- Tests: Keep test_compress_* working when some filters are unavailable.
-
- tests/test_compress.sh | 34 ++++++++++++++++++++--------------
- 1 file changed, 20 insertions(+), 14 deletions(-)
-
-commit ce30ada91951d0746879ae438da11f1ee8a90aa0
-Author: Jia Tan <jiat0218@gmail.com>
-Date: 2022-10-23 21:01:08 +0800
-
- Tests: test_bcj_exact_size skips properly now if PowerPC filter disabled.
-
- tests/test_bcj_exact_size.c | 3 +++
- 1 file changed, 3 insertions(+)
-
-commit 89c5cfcacaca7130509fac836e2f30c46b824502
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-10-26 00:05:57 +0300
-
- Tests: Test also unsupported-*.xz.
-
- tests/test_files.sh | 37 +++++++++++++++++++++++++++++++++++++
- 1 file changed, 37 insertions(+)
-
-commit a4b214b93ac741edef9c41e55865b0b867ca2587
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-10-25 23:45:03 +0300
-
- Build: Use AC_CONFIG_HEADERS instead of the ancient AC_CONFIG_HEADER.
-
- We require Autoconf >= 2.69 and that has AC_CONFIG_HEADERS.
-
- There is a warning about AC_PROG_CC_C99 being obsolete but
- it cannot be removed because it is needed with Autoconf 2.69.
-
- configure.ac | 2 +-
- 1 file changed, 1 insertion(+), 1 deletion(-)
-
-commit 04f299b64e73f50afc188c2590ebebc6b73ed744
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-10-25 23:31:44 +0300
-
- Build: Update m4/ax_pthread.m4 from Autoconf Archive.
-
- m4/ax_pthread.m4 | 29 ++++++++++++++++++++++-------
- 1 file changed, 22 insertions(+), 7 deletions(-)
-
-commit 59c4d6e1390f6f4176f43ac1dad1f7ac03c449b8
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-10-25 23:28:34 +0300
-
- Build: Add configure option --disable-microlzma.
-
- MicroLZMA was made for EROFS and used by erofs-utils.
- It might be used by something else in the future but
- those wanting a smaller build for specific situations
- can now disable this rarely-needed feature.
-
- configure.ac | 22 ++++++++++++++++++++++
- 1 file changed, 22 insertions(+)
-
-commit 054ccd6d14b2cc6eddc56897af280d3221414150
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-10-25 23:09:11 +0300
-
- xz: Fix --single-stream with an empty .xz Stream.
-
- Example:
-
- $ xz -dc --single-stream good-0-empty.xz
- xz: good-0-empty.xz: Internal error (bug)
-
- The code, that is tries to catch some input file issues early,
- didn't anticipate LZMA_STREAM_END which is possible in that
- code only when --single-stream is used.
-
- src/xz/coder.c | 9 +++++++++
- 1 file changed, 9 insertions(+)
-
-commit 563288ea705e83ff5cb292adf794650c263bca1d
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-10-25 21:11:58 +0300
-
- xz: Add support for OpenBSD's pledge() sandbox.
-
- configure.ac | 12 +++++++++---
- src/xz/file_io.c | 11 +++++++++++
- src/xz/main.c | 13 +++++++++++++
- src/xz/private.h | 2 +-
- 4 files changed, 34 insertions(+), 4 deletions(-)
-
-commit f9913e8ee2ba0b1e4ff4d0aa4c001aae305ed944
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-10-25 19:07:17 +0300
-
- xz: Fix decompressor behavior if input uses an unsupported check type.
-
- Now files with unsupported check will make xz display
- a warning, set the exit status to 2 (unless --no-warn is used),
- and then decompress the file normally. This is how it was
- supposed to work since the beginning but this was broken by
- the commit 231c3c7098f1099a56abb8afece76fc9b8699f05, that is,
- a little before 5.0.0 was released. The buggy behavior displayed
- a message, set exit status 1 (error), and xz didn't attempt to
- to decompress the file.
-
- This doesn't matter today except for special builds that disable
- CRC64 or SHA-256 at build time (but such builds should be used
- in special situations only). The bug matters if new check type
- is added in the future and an old xz version is used to decompress
- such a file; however, it's likely that such files would use a new
- filter too and an old xz wouldn't be able to decompress the file
- anyway.
-
- The first hunk in the commit is the actual fix. The second hunk
- is a cleanup since LZMA_TELL_ANY_CHECK isn't used in xz.
-
- There is a test file for unsupported check type but it wasn't
- used by test_files.sh, perhaps due to different behavior between
- xz and the simpler xzdec.
-
- src/xz/coder.c | 19 +++++++++++++++----
- 1 file changed, 15 insertions(+), 4 deletions(-)
-
-commit aa4fe145b9486adc454f44fd3e09be9add808a0f
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-10-25 18:36:19 +0300
-
- xz: Clarify the man page: input file isn't removed if an error occurs.
-
- src/xz/xz.1 | 5 +++--
- 1 file changed, 3 insertions(+), 2 deletions(-)
-
-commit 8b46ae8cdeddfd7dc01fec92971b8696e9a96c5d
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-10-25 18:30:55 +0300
-
- xz: Refactor to remove is_empty_filename().
-
- Long ago it was used in list.c too but nowadays it's needed
- only in io_open_src() so it's nicer to avoid a separate function.
-
- src/xz/file_io.c | 4 +++-
- src/xz/util.c | 12 ------------
- src/xz/util.h | 4 ----
- 3 files changed, 3 insertions(+), 17 deletions(-)
-
-commit 85624015978b0de294cff3df79006df987c552b1
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-10-25 18:23:54 +0300
-
- xz: If input file cannot be removed, treat it as a warning, not error.
-
- Treating it as a warning (message + exit status 2) matches gzip
- and it seems more logical as at that point the output file has
- already been successfully closed. When it's a warning it is
- possible to suppress it with --no-warn.
-
- src/xz/file_io.c | 4 ++--
- 1 file changed, 2 insertions(+), 2 deletions(-)
-
-commit fda9f85f52c546f7ca0313cf89481da4707fecb3
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-10-24 16:25:09 +0300
-
- liblzma: Threaded decoder: Stop the worker threads on errors.
-
- It's waste of CPU time and electricity to leave the unfinished
- worker threads running when it is known that their output will
- get ignored.
-
- src/liblzma/common/stream_decoder_mt.c | 33 ++++++++++++++++++++++++++-------
- 1 file changed, 26 insertions(+), 7 deletions(-)
-
-commit 2611c4d90535652d3eb7ef4a026a6691276fab43
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-10-20 20:22:50 +0300
-
- tuklib_cpucores: Use HW_NCPUONLINE on OpenBSD.
-
- On OpenBSD the number of cores online is often less
- than what HW_NCPU would return because OpenBSD disables
- simultaneous multi-threading (SMT) by default.
-
- Thanks to Christian Weisgerber.
-
- m4/tuklib_cpucores.m4 | 5 +++++
- src/common/tuklib_cpucores.c | 9 +++++++++
- 2 files changed, 14 insertions(+)
-
-commit 424ac91c7e0419393ff2bde4f62e21fa611c776d
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-10-19 19:39:35 +0300
-
- Tests: Skip tests in test_*.sh if encoders and/or decoders are disabled.
-
- This isn't perfect as the scripts can still fail if only
- certain filters are disabled. This is still an improvement
- as now "make check" has better behavior when all encoders
- or decoders are disabled.
-
- Grepping ../config.h is simple and fairly clean but it only
- works if config.h was created. CMake builds don't create
- config.h but they don't use these test scripts either.
-
- Thanks to Sebastian Andrzej Siewior for reporting the problem.
- Thanks to Jia Tan for the original patch which grepped xz
- error messages instead of config.h.
-
- tests/test_compress.sh | 12 ++++++++++++
- tests/test_files.sh | 11 +++++++++++
- tests/test_scripts.sh | 11 +++++++++++
- 3 files changed, 34 insertions(+)
-
-commit ca8bf9d7c5a30be8ba1eeb106fd892f19e83ed09
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-10-19 18:54:34 +0300
-
- Test: Remove the (exit 1) lines.
-
- I suspect that I used these in the original version because
- Autoconf's manual describes that such a trick is needed in
- some specific situations for portability reasons. None of those
- situations listed on Autoconf 2.71 manual apply to these test
- scripts though so this cleans them up.
-
- tests/test_compress.sh | 10 ----------
- tests/test_files.sh | 9 ---------
- tests/test_scripts.sh | 6 ------
- 3 files changed, 25 deletions(-)
-
-commit 82fcb7cfc17ce62f79ebc7ca2374e1daca5e4d5e
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-10-19 17:14:57 +0300
-
- Tests: Fix a warning in test_memlimit.c when decoders are disabled.
-
- tests/test_memlimit.c | 3 +++
- 1 file changed, 3 insertions(+)
-
-commit b5f8271b45b9b0e59485ffba3640ca3418835ec4
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-10-19 17:11:46 +0300
-
- Tests: Add test_memlimit to .gitignore.
-
- Thanks to Jia Tan.
-
- .gitignore | 1 +
- 1 file changed, 1 insertion(+)
-
-commit 6a86e81cab202d0a812a7b2e9efacaf70c58ba38
-Author: Jia Tan <jiat0218@gmail.com>
-Date: 2022-10-06 21:53:09 +0300
-
- Tests: Refactor test_stream_flags.c.
-
- Converts test_stream_flags to tuktest. Also the test will now
- compile and skip properly if encoders or decoders are disabled.
-
- Thanks to Sebastian Andrzej Siewior.
-
- tests/test_stream_flags.c | 533 ++++++++++++++++++++++++++++++++++++----------
- 1 file changed, 416 insertions(+), 117 deletions(-)
-
-commit 827ac5b4821491fd3afe0d0e1ddac326253aeb66
-Author: Jia Tan <jiat0218@gmail.com>
-Date: 2022-10-06 17:00:38 +0800
-
- Tests: Refactor test_block_header.c.
-
- test_block_header now achieves higher test coverage. Also the
- test will now compile and skip properly if encoders or decoders
- are disabled.
-
- Thanks to Sebastian Andrzej Siewior.
-
- tests/test_block_header.c | 486 +++++++++++++++++++++++++++++++++++-----------
- 1 file changed, 370 insertions(+), 116 deletions(-)
-
-commit 84963318952064a93bfc52edd6b0ef70593384ee
-Author: Jia Tan <jiat0218@gmail.com>
-Date: 2022-10-05 23:54:12 +0800
-
- Tests: Fix compilation issues.
-
- test_bcj_exact_size, test_check, test_hardware, and test_index will
- all now compile and skip properly if encoders or decoders are disabled.
-
- Also fixed a small typo (disabed -> disabled).
-
- Thanks to Sebastian Andrzej Siewior.
-
- tests/test_bcj_exact_size.c | 20 ++++++++++++++------
- tests/test_check.c | 8 +++++++-
- tests/test_hardware.c | 2 +-
- tests/test_index.c | 6 ++++++
- tests/test_memlimit.c | 16 +++++++++++++++-
- tests/test_vli.c | 13 +++++++++++++
- 6 files changed, 56 insertions(+), 9 deletions(-)
-
-commit 7dcabeec63d46b436fa5f043c3d1f09d0e15be16
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-10-05 16:20:47 +0300
-
- Tests: Include mythread.h in the tests that use MYTHREAD_ENABLED.
-
- tests/test_check.c | 1 +
- tests/test_hardware.c | 1 +
- tests/test_memlimit.c | 1 +
- 3 files changed, 3 insertions(+)
-
-commit 14af758a770c7781af18fb66d6d21ee5b1c27f04
-Author: Jia Tan <jiat0218@gmail.com>
-Date: 2022-10-05 20:57:16 +0800
-
- liblzma: Fix a compilation issue when encoders are disabled.
-
- When encoders were disabled and threading enabled, outqueue.c and
- outqueue.h were not compiled. The multi threaded decoder required
- these files, so compilation failed.
-
- src/liblzma/common/Makefile.inc | 7 ++++---
- 1 file changed, 4 insertions(+), 3 deletions(-)
-
-commit 6ca5c354bd4620aa7f81da68870eef1b1f26288f
-Author: Jia Tan <jiat0218@gmail.com>
-Date: 2022-10-05 16:41:38 +0800
-
- Tests: Fix compilation error when threading support has been disabled.
-
- Now tests that require threading are skipped when threading
- support has been disabled.
-
- Thanks to Sebastian Andrzej Siewior.
-
- tests/test_check.c | 4 ++++
- tests/test_hardware.c | 4 ++++
- tests/test_memlimit.c | 4 ++++
- 3 files changed, 12 insertions(+)
-
-commit fae37ad2affd8fe8871f4ff93d5cab5ec14d5e58
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-10-05 14:26:00 +0300
-
- tuklib_integer: Add 64-bit endianness-converting reads and writes.
-
- Also update the comment in liblzma's memcmplen.h.
-
- Thanks to Michał Górny for the original patch for the reads.
-
- m4/tuklib_integer.m4 | 8 ++++----
- src/common/tuklib_integer.h | 46 ++++++++++++++++++++++++++++++++++++++++--
- src/liblzma/common/memcmplen.h | 9 +++------
- 3 files changed, 51 insertions(+), 12 deletions(-)
-
-commit 508a44372c5b0dede8863fd0d358d4a9d8645c95
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-09-30 12:06:13 +0300
-
- liblzma: Add API doc note about the .xz decoder LZMA_MEMLIMIT_ERROR bug.
-
- The bug was fixed in 660739f99ab211edec4071de98889fb32ed04e98.
-
- src/liblzma/api/lzma/base.h | 11 +++++++++++
- 1 file changed, 11 insertions(+)
-
-commit 8cc9874a7974cd575aee44f218836f7acdbeb0ed
-Author: Jia Tan <jiat0218@gmail.com>
-Date: 2022-09-21 16:15:50 +0800
-
- liblzma: Add dest and src NULL checks to lzma_index_cat.
-
- The documentation states LZMA_PROG_ERROR can be returned from
- lzma_index_cat. Previously, lzma_index_cat could not return
- LZMA_PROG_ERROR. Now, the validation is similar to
- lzma_index_append, which does a NULL check on the index
- parameter.
-
- src/liblzma/common/index.c | 3 +++
- 1 file changed, 3 insertions(+)
-
-commit afd5a8bf5374eba82804a999e1ea7af680784086
-Author: Jia Tan <jiat0218@gmail.com>
-Date: 2022-09-21 20:29:28 +0800
-
- Tests: Create a test for the lzma_index_cat bug.
-
- tests/test_index.c | 43 ++++++++++++++++++++++++++++++++++++++++++-
- 1 file changed, 42 insertions(+), 1 deletion(-)
-
-commit 3d5a99ca373a4e86faf671226ca6487febb9eeac
-Author: Jia Tan <jiat0218@gmail.com>
-Date: 2022-09-21 19:28:53 +0800
-
- liblzma: Fix copying of check type statistics in lzma_index_cat().
-
- The check type of the last Stream in dest was never copied to
- dest->checks (the code tried to copy it but it was done too late).
- This meant that the value returned by lzma_index_checks() would
- only include the check type of the last Stream when multiple
- lzma_indexes had been concatenated.
-
- In xz --list this meant that the summary would only list the
- check type of the last Stream, so in this sense this was only
- a visual bug. However, it's possible that some applications
- use this information for purposes other than merely showing
- it to the users in an informational message. I'm not aware of
- such applications though and it's quite possible that such
- applications don't exist.
-
- Regular streamed decompression in xz or any other application
- doesn't use lzma_index_cat() and so this bug cannot affect them.
-
- src/liblzma/common/index.c | 7 ++++++-
- 1 file changed, 6 insertions(+), 1 deletion(-)
-
-commit a61d32172789735350a941e23baf6b587c49e5d9
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-09-28 12:20:41 +0300
-
- tuklib_physmem: Fix Unicode builds on Windows.
-
- Thanks to ArSaCiA Game.
-
- src/common/tuklib_physmem.c | 2 +-
- 1 file changed, 1 insertion(+), 1 deletion(-)
-
-commit 5a4d3548ab214fdca364d5c734baf1d1fab47308
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-09-28 11:12:07 +0300
-
- Tests: Add test_memlimit.c to test restarting after LZMA_MEMLIMIT_ERROR.
-
- tests/Makefile.am | 2 +
- tests/test_memlimit.c | 151 ++++++++++++++++++++++++++++++++++++++++++++++++++
- 2 files changed, 153 insertions(+)
-
-commit 660739f99ab211edec4071de98889fb32ed04e98
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-09-28 11:05:15 +0300
-
- liblzma: Stream decoder: Fix restarting after LZMA_MEMLIMIT_ERROR.
-
- If lzma_code() returns LZMA_MEMLIMIT_ERROR it is now possible
- to use lzma_memlimit_set() to increase the limit and continue
- decoding. This was supposed to work from the beginning but
- there was a bug. With other decoders (.lzma or threaded .xz)
- this already worked correctly.
-
- src/liblzma/common/stream_decoder.c | 16 +++++++++++++---
- 1 file changed, 13 insertions(+), 3 deletions(-)
-
-commit 7e68fda58c74ad9e5b876cc22fcbe80fc0e4747b
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-09-28 11:00:23 +0300
-
- liblzma: Stream decoder: Fix comments.
-
- src/liblzma/common/stream_decoder.c | 12 +++++-------
- 1 file changed, 5 insertions(+), 7 deletions(-)
-
-commit f664cb25841fc1c478b819034a224a558e2ac6e7
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-09-20 16:58:22 +0300
-
- liblzma: ARM64: Add comments.
-
- src/liblzma/simple/arm64.c | 13 +++++++++++++
- 1 file changed, 13 insertions(+)
-
-commit b557b4a0eea05470fae8ba5ef4ad5a6dfb36ac41
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-09-20 16:27:50 +0300
-
- liblzma: ARM64: Fix wrong comment in API doc.
-
- Thanks to Jia Tan.
-
- src/liblzma/api/lzma/bcj.h | 4 ++--
- 1 file changed, 2 insertions(+), 2 deletions(-)
-
-commit d5b0906fa55157f48c200188a3951d80df9cb308
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-09-19 20:24:26 +0300
-
- xz: Add --experimental-arm64[=width=WIDTH].
-
- It will be renamed to --arm64 once it is stable.
-
- Man page or --long-help weren't updated yet.
-
- src/xz/args.c | 7 +++++++
- src/xz/message.c | 7 +++++++
- src/xz/options.c | 39 +++++++++++++++++++++++++++++++++++++++
- src/xz/options.h | 7 +++++++
- 4 files changed, 60 insertions(+)
-
-commit ecb966de308c255bb4735a7307ef9901c643a9de
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-09-19 19:34:56 +0300
-
- liblzma: Add experimental ARM64 BCJ filter with a temporary Filter ID.
-
- That is, the Filter ID will be changed once the design is final.
- The current version will be removed. So files created with the
- tempoary Filter ID won't be supported in the future.
-
- CMakeLists.txt | 3 +
- configure.ac | 4 +-
- src/liblzma/api/lzma/bcj.h | 35 +++++-
- src/liblzma/common/filter_common.c | 9 ++
- src/liblzma/common/filter_decoder.c | 8 ++
- src/liblzma/common/filter_encoder.c | 11 ++
- src/liblzma/simple/Makefile.inc | 4 +
- src/liblzma/simple/arm64.c | 227 ++++++++++++++++++++++++++++++++++++
- src/liblzma/simple/simple_coder.h | 9 ++
- src/liblzma/simple/simple_decoder.h | 4 +
- src/liblzma/simple/simple_encoder.h | 2 +
- 11 files changed, 313 insertions(+), 3 deletions(-)
-
-commit 177bdc922cb17bd0fd831ab8139dfae912a5c2b8
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-09-17 22:42:18 +0300
-
- liblzma: Simple/BCJ filters: Allow disabling generic BCJ options.
-
- This will be needed for the ARM64 BCJ filter as it will use
- its own options struct.
-
- src/liblzma/simple/arm.c | 2 +-
- src/liblzma/simple/armthumb.c | 2 +-
- src/liblzma/simple/ia64.c | 2 +-
- src/liblzma/simple/powerpc.c | 2 +-
- src/liblzma/simple/simple_coder.c | 4 ++--
- src/liblzma/simple/simple_private.h | 2 +-
- src/liblzma/simple/sparc.c | 2 +-
- src/liblzma/simple/x86.c | 3 ++-
- 8 files changed, 10 insertions(+), 9 deletions(-)
-
-commit c3592d0a55114144686ecf960cb516d6b31c98e9
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-09-16 17:08:53 +0300
-
- Tests: Add a test file for lzma_index_append() integer overflow bug.
-
- This test fails before commit 18d7facd3802b55c287581405c4d49c98708c136.
-
- test_files.sh now runs xz -l for bad-3-index-uncomp-overflow.xz
- because only then the previously-buggy code path gets tested.
- Normal decompression doesn't use lzma_index_append() at all.
- Instead, lzma_index_hash functions are used and those already
- did the overflow check.
-
- tests/files/README | 10 ++++++++++
- tests/files/bad-3-index-uncomp-overflow.xz | Bin 0 -> 132 bytes
- tests/test_files.sh | 8 ++++++++
- 3 files changed, 18 insertions(+)
-
-commit 982b29f828079a2a26253a40e975127a40a7d2bd
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-09-16 15:10:07 +0300
-
- Translations: Add Turkish translation.
-
- po/LINGUAS | 1 +
- po/tr.po | 977 +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
- 2 files changed, 978 insertions(+)
-
-commit 1fc088d9f6d1697924aaeac8cd1fb9918d1532e2
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-09-16 14:09:07 +0300
-
- Update THANKS.
-
- THANKS | 1 +
- 1 file changed, 1 insertion(+)
-
-commit 097c7b67ce86ff16a7cef7631b39e5ca4ee3d420
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-09-16 14:07:03 +0300
-
- xzgrep: Fix compatibility with old shells.
-
- Running the current xzgrep on Slackware 10.1 with GNU bash 3.00.15:
-
- xzgrep: line 231: syntax error near unexpected token `;;'
-
- On SCO OpenServer 5.0.7 with Korn Shell 93r:
-
- syntax error at line 231 : `;;' unexpected
-
- Turns out that some old shells don't like apostrophes (') inside
- command substitutions. For example, the following fails:
-
- x=$(echo foo
- # asdf'zxcv
- echo bar)
- printf '%s\n' "$x"
-
- The problem was introduced by commits
- 69d1b3fc29677af8ade8dc15dba83f0589cb63d6 (2022-03-29),
- bd7b290f3fe4faeceb7d3497ed9bf2e6ed5e7dc5 (2022-07-18), and
- a648978b20495b7aa4a8b029c5a810b5ad9d08ff (2022-07-19).
- 5.2.6 is the only stable release that included
- this problem.
-
- Thanks to Kevin R. Bulgrien for reporting the problem
- on SCO OpenServer 5.0.7 and for providing the fix.
-
- src/scripts/xzgrep.in | 6 +++---
- 1 file changed, 3 insertions(+), 3 deletions(-)
-
-commit f2d084fe3f0d6d71488bfc6987f26542f67bfd99
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-09-09 14:12:30 +0300
-
- Tests: Silence warnings about unused functions from tuktest.h.
-
- Warnings about unused tuktest_run_test conveniently tell which
- test programs haven't been converted to tuktest.h yet but I
- silenced that warning too for now anyway.
-
- It is fine to use __attribute__((__unused__)) even when the
- function is actually used because the attribute only means
- that the function might be unused.
-
- tests/tuktest.h | 10 ++++++++++
- 1 file changed, 10 insertions(+)
-
-commit f8ee61e74eb40600445fdb601c374d582e1e9c8a
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-09-09 13:51:57 +0300
-
- liblzma: lzma_filters_copy: Keep dest[] unmodified if an error occurs.
-
- lzma_stream_encoder() and lzma_stream_encoder_mt() always assumed
- this. Before this patch, failing lzma_filters_copy() could result
- in free(invalid_pointer) or invalid memory reads in stream_encoder.c
- or stream_encoder_mt.c.
-
- To trigger this, allocating memory for a filter options structure
- has to fail. These are tiny allocations so in practice they very
- rarely fail.
-
- Certain badness in the filter chain array could also make
- lzma_filters_copy() fail but both stream_encoder.c and
- stream_encoder_mt.c validate the filter chain before
- trying to copy it, so the crash cannot occur this way.
-
- src/liblzma/api/lzma/filter.h | 4 +++-
- src/liblzma/common/filter_common.c | 18 ++++++++++++------
- 2 files changed, 15 insertions(+), 7 deletions(-)
-
-commit 18d7facd3802b55c287581405c4d49c98708c136
-Author: Jia Tan <jiat0218@gmail.com>
-Date: 2022-09-02 20:18:55 +0800
-
- liblzma: lzma_index_append: Add missing integer overflow check.
-
- The documentation in src/liblzma/api/lzma/index.h suggests that
- both the unpadded (compressed) size and the uncompressed size
- are checked for overflow, but only the unpadded size was checked.
- The uncompressed check is done first since that is more likely to
- occur than the unpadded or index field size overflows.
-
- src/liblzma/common/index.c | 4 ++++
- 1 file changed, 4 insertions(+)
-
-commit 9ac06cb5b85274d18f9f70d82cf2d8c9c1151bd4
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-09-08 15:11:08 +0300
-
- Update THANKS.
-
- THANKS | 1 +
- 1 file changed, 1 insertion(+)
-
-commit ba3e4ba2de034ae93a513f9c3a0823b80cdb66dc
-Author: Jia Tan <jiat0218@gmail.com>
-Date: 2022-09-08 15:07:00 +0300
-
- CMake: Clarify a comment about Windows symlinks without file extension.
-
- CMakeLists.txt | 7 +++----
- 1 file changed, 3 insertions(+), 4 deletions(-)
-
-commit 17485e884ce5c74315f29a8a1507bc706cd5cd1d
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-09-08 15:02:41 +0300
-
- CMake: Update for liblzma_*.map files and fix wrong common_w32res.rc dep.
-
- The previous commit split liblzma.map into liblzma_linux.map and
- liblzma_generic.map. This commit updates the CMake build for those.
-
- common_w32res.rc dependency was listed under Linux/FreeBSD while
- obviously it belongs to Windows when building a DLL.
-
- CMakeLists.txt | 24 +++++++++++++++++++-----
- 1 file changed, 19 insertions(+), 5 deletions(-)
-
-commit 913ddc5572b9455fa0cf299be2e35c708840e922
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-09-04 23:23:00 +0300
-
- liblzma: Vaccinate against an ill patch from RHEL/CentOS 7.
-
- RHEL/CentOS 7 shipped with 5.1.2alpha, including the threaded
- encoder that is behind #ifdef LZMA_UNSTABLE in the API headers.
- In 5.1.2alpha these symbols are under XZ_5.1.2alpha in liblzma.map.
- API/ABI compatibility tracking isn't done between development
- releases so newer releases didn't have XZ_5.1.2alpha anymore.
-
- Later RHEL/CentOS 7 updated xz to 5.2.2 but they wanted to keep
- the exported symbols compatible with 5.1.2alpha. After checking
- the ABI changes it turned out that >= 5.2.0 ABI is backward
- compatible with the threaded encoder functions from 5.1.2alpha
- (but not vice versa as fixes and extensions to these functions
- were made between 5.1.2alpha and 5.2.0).
-
- In RHEL/CentOS 7, XZ Utils 5.2.2 was patched with
- xz-5.2.2-compat-libs.patch to modify liblzma.map:
-
- - XZ_5.1.2alpha was added with lzma_stream_encoder_mt and
- lzma_stream_encoder_mt_memusage. This matched XZ Utils 5.1.2alpha.
-
- - XZ_5.2 was replaced with XZ_5.2.2. It is clear that this was
- an error; the intention was to keep using XZ_5.2 (XZ_5.2.2
- has never been used in XZ Utils). So XZ_5.2.2 lists all
- symbols that were listed under XZ_5.2 before the patch.
- lzma_stream_encoder_mt and _mt_memusage are included too so
- they are listed both here and under XZ_5.1.2alpha.
-
- The patch didn't add any __asm__(".symver ...") lines to the .c
- files. Thus the resulting liblzma.so exports the threaded encoder
- functions under XZ_5.1.2alpha only. Listing the two functions
- also under XZ_5.2.2 in liblzma.map has no effect without
- matching .symver lines.
-
- The lack of XZ_5.2 in RHEL/CentOS 7 means that binaries linked
- against unpatched XZ Utils 5.2.x won't run on RHEL/CentOS 7.
- This is unfortunate but this alone isn't too bad as the problem
- is contained within RHEL/CentOS 7 and doesn't affect users
- of other distributions. It could also be fixed internally in
- RHEL/CentOS 7.
-
- The second problem is more serious: In XZ Utils 5.2.2 the API
- headers don't have #ifdef LZMA_UNSTABLE for obvious reasons.
- This is true in RHEL/CentOS 7 version too. Thus now programs
- using new APIs can be compiled without an extra #define. However,
- the programs end up depending on symbol version XZ_5.1.2alpha
- (and possibly also XZ_5.2.2) instead of XZ_5.2 as they would
- with an unpatched XZ Utils 5.2.2. This means that such binaries
- won't run on other distributions shipping XZ Utils >= 5.2.0 as
- they don't provide XZ_5.1.2alpha or XZ_5.2.2; they only provide
- XZ_5.2 (and XZ_5.0). (This includes RHEL/CentOS 8 as the patch
- luckily isn't included there anymore with XZ Utils 5.2.4.)
-
- Binaries built by RHEL/CentOS 7 users get distributed and then
- people wonder why they don't run on some other distribution.
- Seems that people have found out about the patch and been copying
- it to some build scripts, seemingly curing the symptoms but
- actually spreading the illness further and outside RHEL/CentOS 7.
-
- The ill patch seems to be from late 2016 (RHEL 7.3) and in 2017 it
- had spread at least to EasyBuild. I heard about the events only
- recently. :-(
-
- This commit splits liblzma.map into two versions: one for
- GNU/Linux and another for other OSes that can use symbol versioning
- (FreeBSD, Solaris, maybe others). The Linux-specific file and the
- matching additions to .c files add full compatibility with binaries
- that have been built against a RHEL/CentOS-patched liblzma. Builds
- for OSes other than GNU/Linux won't get the vaccine as they should
- be immune to the problem (I really hope that no build script uses
- the RHEL/CentOS 7 patch outside GNU/Linux).
-
- The RHEL/CentOS compatibility symbols XZ_5.1.2alpha and XZ_5.2.2
- are intentionally put *after* XZ_5.2 in liblzma_linux.map. This way
- if one forgets to #define HAVE_SYMBOL_VERSIONS_LINUX when building,
- the resulting liblzma.so.5 will have lzma_stream_encoder_mt@@XZ_5.2
- since XZ_5.2 {...} is the first one that lists that function.
- Without HAVE_SYMBOL_VERSIONS_LINUX @XZ_5.1.2alpha and @XZ_5.2.2
- will be missing but that's still a minor problem compared to
- only having lzma_stream_encoder_mt@@XZ_5.1.2alpha!
-
- The "local: *;" line was moved to XZ_5.0 so that it doesn't need
- to be moved around. It doesn't matter where it is put.
-
- Having two similar liblzma_*.map files is a bit silly as it is,
- at least for now, easily possible to generate the generic one
- from the Linux-specific file. But that adds extra steps and
- increases the risk of mistakes when supporting more than one
- build system. So I rather maintain two files in parallel and let
- validate_map.sh check that they are in sync when "make mydist"
- is run.
-
- This adds .symver lines for lzma_stream_encoder_mt@XZ_5.2.2 and
- lzma_stream_encoder_mt_memusage@XZ_5.2.2 even though these
- weren't exported by RHEL/CentOS 7 (only @@XZ_5.1.2alpha was
- for these two). I added these anyway because someone might
- misunderstand the RHEL/CentOS 7 patch and think that @XZ_5.2.2
- (@@XZ_5.2.2) versions were exported too.
-
- At glance one could suggest using __typeof__ to copy the function
- prototypes when making aliases. However, this doesn't work trivially
- because __typeof__ won't copy attributes (lzma_nothrow, lzma_pure)
- and it won't change symbol visibility from hidden to default (done
- by LZMA_API()). Attributes could be copied with __copy__ attribute
- but that needs GCC 9 and a fallback method would be needed anyway.
-
- This uses __symver__ attribute with GCC >= 10 and
- __asm__(".symver ...") with everything else. The attribute method
- is required for LTO (-flto) support with GCC. Using -flto with
- GCC older than 10 is now broken on GNU/Linux and will not be fixed
- (can silently result in a broken liblzma build that has dangerously
- incorrect symbol versions). LTO builds with Clang seem to work
- with the traditional __asm__(".symver ...") method.
-
- Thanks to Boud Roukema for reporting the problem and discussing
- the details and testing the fix.
-
- configure.ac | 23 +++-
- src/liblzma/Makefile.am | 10 +-
- src/liblzma/common/block_buffer_encoder.c | 18 ++++
- src/liblzma/common/common.c | 14 +++
- src/liblzma/common/common.h | 28 +++++
- src/liblzma/common/hardware_cputhreads.c | 12 +++
- src/liblzma/common/stream_encoder_mt.c | 42 ++++++++
- src/liblzma/{liblzma.map => liblzma_generic.map} | 6 +-
- src/liblzma/liblzma_linux.map | 131 +++++++++++++++++++++++
- src/liblzma/validate_map.sh | 113 +++++++++++++++++--
- 10 files changed, 382 insertions(+), 15 deletions(-)
-
-commit 80a1a8bb838842a2be343bd88ad1462c21c5e2c9
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-08-31 16:42:04 +0300
-
- CMake: Add xz symlinks.
-
- These are a minor thing especially since the xz build has
- some real problems still like lack of large file support
- on 32-bit systems but I'll commit this since the code exists.
-
- Thanks to Jia Tan.
-
- CMakeLists.txt | 38 +++++++++++++++++++++++++++++++++++++-
- 1 file changed, 37 insertions(+), 1 deletion(-)
-
-commit a4193bb6d85d7765b1b87faeab3e50106d3ab2e9
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-08-31 16:29:38 +0300
-
- CMake: Put xz man page install under if(UNIX) like is for xzdec.
-
- Thanks to Jia Tan.
-
- CMakeLists.txt | 8 +++++---
- 1 file changed, 5 insertions(+), 3 deletions(-)
-
-commit c1555b1a221a1427d4d650647531016d754bc4da
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-08-22 18:16:40 +0300
-
- Bump version number for 5.3.3alpha.
-
- src/liblzma/api/lzma/version.h | 2 +-
- src/liblzma/liblzma.map | 2 +-
- 2 files changed, 2 insertions(+), 2 deletions(-)
-
-commit 44fedddc11c3f6ec2f7fe35a3e38f15ca93f90eb
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-08-22 18:13:56 +0300
-
- Add NEWS for 5.3.3alpha.
-
- NEWS | 119 +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
- 1 file changed, 119 insertions(+)
-
-commit a93e235d7ca764cc19f8f9f9063b40ff361c3cfa
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-07-12 17:59:41 +0300
-
- Translations: Add Portuguese translation.
-
- Jia Tan made white-space changes and also changed "Language: pt_BR\n"
- to pt. The translator wasn't reached so I'm hoping these changes
- are OK and will commit it without translator's approval.
-
- Thanks to Pedro Albuquerque and Jia Tan.
-
- po/LINGUAS | 1 +
- po/pt.po | 1001 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
- 2 files changed, 1002 insertions(+)
-
-commit e7cf5a946f25e40d77f45e41f0dee7d42a04e9ae
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-07-10 21:16:40 +0300
-
- Translations: Add Serbian translation.
-
- Quite a few white-space changes were made by Jia Tan to make
- this look good. Contacting the translator didn't succeed so
- I'm committing this without getting translator's approval.
-
- Thanks to Мирослав Николић (Miroslav Nikolic) and Jia Tan.
-
- po/LINGUAS | 1 +
- po/sr.po | 987 +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
- 2 files changed, 988 insertions(+)
-
-commit cc8617ab53b1f2a4da212fa76c92fe538269c5de
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-07-04 23:51:36 +0300
-
- Translations: Add Swedish translation.
-
- Thanks to Sebastian Rasmussen and Jia Tan.
-
- po/LINGUAS | 1 +
- po/sv.po | 983 +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
- 2 files changed, 984 insertions(+)
-
-commit c613598c358b640682d0ca2aed38fa7df763e8c7
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-07-04 23:40:27 +0300
-
- Translations: Add Esperanto translation.
-
- Thanks to Keith Bowes and Jia Tan.
-
- po/LINGUAS | 1 +
- po/eo.po | 984 +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
- 2 files changed, 985 insertions(+)
-
-commit 659a587d678f21e98e91d2751c31d4ce050c081a
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-07-01 00:22:33 +0300
-
- Translations: Add Catalan translation.
-
- Thanks to Jordi Mas and Jia Tan.
-
- po/LINGUAS | 1 +
- po/ca.po | 1076 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
- 2 files changed, 1077 insertions(+)
-
-commit 739fd8c9bdf1d85f57d56642aad87148d4779530
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-06-30 17:47:08 +0300
-
- Translations: Add Ukrainian translation.
-
- Thanks to Yuri Chornoivan and Jia Tan.
-
- po/LINGUAS | 1 +
- po/uk.po | 996 +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
- 2 files changed, 997 insertions(+)
-
-commit 73280550b111930c62a667e56add8fd574f80bc8
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-06-30 17:45:26 +0300
-
- Translators: Add Romanian translation.
-
- Thanks to Remus-Gabriel Chelu and Jia Tan.
-
- po/LINGUAS | 1 +
- po/ro.po | 1016 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
- 2 files changed, 1017 insertions(+)
-
-commit 2465f5b825152714b2c357d96c2422c31109d320
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-06-29 18:33:32 +0300
-
- Translations: Update Brazilian Portuguese translation.
-
- One msgstr was changed. The diff is long due to changes
- in the source code line numbers in the comments.
-
- Thanks to Rafael Fontenelle.
-
- po/pt_BR.po | 186 ++++++++++++++++++++++++++++++------------------------------
- 1 file changed, 92 insertions(+), 94 deletions(-)
-
-commit 434e1ffd3e62719d509da10b646216f5ef53fe4d
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-06-29 18:04:44 +0300
-
- Translations: Add Croatian translation.
-
- Thanks to Božidar Putanec and Jia Tan.
-
- po/LINGUAS | 1 +
- po/hr.po | 987 +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
- 2 files changed, 988 insertions(+)
-
-commit 0732d0f7065c9bd48bfe4f5983144ae970c4a499
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-06-29 17:58:48 +0300
-
- Translations: Add Spanish translation.
-
- Thanks to Cristian Othón Martínez Vera and Jia Tan.
-
- po/LINGUAS | 1 +
- po/es.po | 984 +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
- 2 files changed, 985 insertions(+)
-
-commit 9899b0f82bc130998d1f1f618a6ab805b73f2696
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-06-29 17:49:43 +0300
-
- Translations: Add Korean translation.
-
- Thanks to Seong-ho Cho and Jia Tan.
-
- po/LINGUAS | 1 +
- po/ko.po | 972 +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
- 2 files changed, 973 insertions(+)
-
-commit 65217eaf6bd195f3ef027d4ac55d57b7d133d69f
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2020-03-16 21:57:21 +0200
-
- Translations: Rebuild cs.po to avoid incorrect fuzzy strings.
-
- "make dist" updates the .po files and the fuzzy strings would
- result in multiple very wrong translations.
-
- po/cs.po | 592 ++++++++++++++++++++++++++++++++++-----------------------------
- 1 file changed, 322 insertions(+), 270 deletions(-)
-
-commit e56ff423ee7af9e648e16b132f0d835d2cb4db26
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2020-03-16 17:30:39 +0200
-
- Translations: Add partial Danish translation.
-
- I made a few minor white space changes without getting them
- approved by the Danish translation team.
-
- po/LINGUAS | 1 +
- po/da.po | 896 +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
- 2 files changed, 897 insertions(+)
-
-commit 43e09c62e77cb8807d932c81de4decbdb956e184
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2020-03-11 22:37:54 +0200
-
- Translations: Add hu, zh_CN, and zh_TW.
-
- I made a few white space changes to these without getting them
- approved by the translation teams. (I tried to contact the hu and
- zh_TW teams but didn't succeed. I didn't contact the zh_CN team.)
-
- po/LINGUAS | 3 +
- po/hu.po | 985 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
- po/zh_CN.po | 963 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
- po/zh_TW.po | 956 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
- 4 files changed, 2907 insertions(+)
-
-commit 982b6b198ae1ffe6093236dd8a3d03d1415b912b
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2020-03-11 14:33:30 +0200
-
- Translations: Update vi.po to match the file from the TP.
-
- The translated strings haven't been updated but word wrapping
- is different.
-
- po/vi.po | 407 ++++++++++++++++++++++++++++-----------------------------------
- 1 file changed, 179 insertions(+), 228 deletions(-)
-
-commit 801f39691fc4abc6dd33d7653d498781b593f3eb
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2020-03-11 14:18:03 +0200
-
- Translations: Add fi and pt_BR, and update de, fr, it, and pl.
-
- The German translation isn't identical to the file in
- the Translation Project but the changes (white space changes
- only) were approved by the translator Mario Blättermann.
-
- po/LINGUAS | 2 +
- po/de.po | 476 ++++++++++++++--------------
- po/fi.po | 974 +++++++++++++++++++++++++++++++++++++++++++++++++++++++++
- po/fr.po | 272 ++++++++--------
- po/it.po | 479 ++++++++++++----------------
- po/pl.po | 239 +++++++-------
- po/pt_BR.po | 1001 +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
- 7 files changed, 2697 insertions(+), 746 deletions(-)
-
-commit 311e4f85ede5d2f0bb71f3ad70b5b7db1b5adf33
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-08-22 17:27:19 +0300
-
- xz: Try to clarify --memlimit-mt-decompress vs. --memlimit-compress.
-
- src/xz/xz.1 | 31 +++++++++++++++++++------------
- 1 file changed, 19 insertions(+), 12 deletions(-)
-
-commit df23c31000283c00e5ef1ca32a0bc3bb757bd707
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-08-22 16:46:18 +0300
-
- CMake: Add liblzma tests.
-
- Thanks to Jia Tan for the patch.
-
- CMakeLists.txt | 53 ++++++++++++++++++++++++++++++++++++++++++++++++++++-
- 1 file changed, 52 insertions(+), 1 deletion(-)
-
-commit 02a777f9c422d3b5ec895078530bb1a2b6f7bdf5
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-08-19 23:32:22 +0300
-
- xz: Revise --info-memory output.
-
- The strings could be more descriptive but it's good
- to have some version of this committed now.
-
- --robot mode wasn't changed yet.
-
- src/xz/hardware.c | 32 ++++++++++++++++++++++++++------
- src/xz/xz.1 | 1 +
- 2 files changed, 27 insertions(+), 6 deletions(-)
-
-commit f864f6d42eab57ea8ed82cc2dd19a03b51377442
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-08-19 23:12:02 +0300
-
- xz: Update the man page for threaded decompression and memlimits.
-
- This documents the changes made in commits
- 6c6da57ae2aa962aabde6892442227063d87e88c,
- cad299008cf73ec566f0662a9cf2b94f86a99659, and
- 898faa97287a756231c663a3ed5165672b417207.
-
- The --info-memory bit hasn't been finished yet
- even though it's already mentioned in this commit
- under --memlimit-mt-decompress and --threads.
-
- src/xz/xz.1 | 148 +++++++++++++++++++++++++++++++++++++++++++++++++-----------
- 1 file changed, 121 insertions(+), 27 deletions(-)
-
-commit d13bfcc0056617dd648f655a01653932fad7067f
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-08-18 17:49:16 +0300
-
- Build: Include the CMake files in the distribution.
-
- This was supposed to be done in 2020 with 5.2.5 release
- already but it was noticed only today. 5.2.5 and 5.2.6
- even mention experiemental CMake support in the NEWS entries.
-
- Thanks to Olivier B. for reporting the problem.
-
- Makefile.am | 2 ++
- 1 file changed, 2 insertions(+)
-
-commit e66787bcfefdb93f19c974f895f65969a77937b0
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-08-18 17:38:05 +0300
-
- Windows: Fix broken liblzma.dll build with Visual Studio project files.
-
- The bug was introduced in 352ba2d69af2136bc814aa1df1a132559d445616
- "Windows: Fix building of resource files when config.h isn't used."
-
- That commit fixed liblzma.dll build with CMake while keeping it
- working with Autotools on Windows but the VS project files were
- forgotten.
-
- I haven't tested these changes.
-
- Thanks to Olivier B. for reporting the bug and for the initial patch.
-
- windows/vs2013/liblzma_dll.vcxproj | 6 ++++++
- windows/vs2017/liblzma_dll.vcxproj | 6 ++++++
- windows/vs2019/liblzma_dll.vcxproj | 6 ++++++
- 3 files changed, 18 insertions(+)
-
-commit c4e8e5fb311225b8b48d34157891a640b2535e0c
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-08-18 17:16:49 +0300
-
- liblzma: Threaded decoder: Improve LZMA_FAIL_FAST when LZMA_FINISH is used.
-
- It will now return LZMA_DATA_ERROR (not LZMA_OK or LZMA_BUF_ERROR)
- if LZMA_FINISH is used and there isn't enough input to finish
- decoding the Block Header or the Block. The use of LZMA_DATA_ERROR
- is simpler and the less risky than LZMA_BUF_ERROR but this might
- be changed before 5.4.0.
-
- src/liblzma/api/lzma/container.h | 6 +++++
- src/liblzma/common/stream_decoder_mt.c | 42 ++++++++++++++++++++++++++++++++++
- 2 files changed, 48 insertions(+)
-
-commit 6dcf606e7efa2b259f0262f9e2f61e00116842d3
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-08-12 18:31:47 +0300
-
- Add NEWS for 5.2.6.
-
- NEWS | 121 +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
- 1 file changed, 121 insertions(+)
-
-commit 413b86fcf8934fae5a004f378a9483d37d8fcaab
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-08-12 14:28:41 +0300
-
- Add Jia Tan to AUTHORS.
-
- AUTHORS | 2 +-
- 1 file changed, 1 insertion(+), 1 deletion(-)
-
-commit 352672732c346c546ff3c26d0605bc0ed1c8b7c7
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-07-25 19:28:26 +0300
-
- Build: Start the generated ChangeLog from around 5.2.0 instead of 5.0.0.
-
- This makes ChangeLog smaller.
-
- Makefile.am | 2 +-
- 1 file changed, 1 insertion(+), 1 deletion(-)
-
-commit 6f6d11225d6016be2bbb55d845b66f6b04d048df
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-07-25 19:11:05 +0300
-
- Translations: Change the copyright comment string to use with po4a.
-
- This affects the second line in po4a/xz-man.pot. The man pages of
- xzdiff, xzgrep, and xzmore are from GNU gzip and under GNU GPLv2+
- while the rest of the man pages are in the public domain.
-
- po4a/update-po | 2 +-
- 1 file changed, 1 insertion(+), 1 deletion(-)
-
-commit 61f8ec804abdb4c5dac01e8ae9b90c7be58a5c24
-Author: Jia Tan <jiat0218@gmail.com>
-Date: 2022-07-25 18:30:05 +0300
-
- liblzma: Refactor lzma_mf_is_supported() to use a switch-statement.
-
- src/liblzma/lz/lz_encoder.c | 32 ++++++++++++++------------------
- 1 file changed, 14 insertions(+), 18 deletions(-)
-
-commit 4d80b463a1251aa22eabc87d2732fec13b1adda6
-Author: Jia Tan <jiat0218@gmail.com>
-Date: 2022-07-25 18:20:01 +0300
-
- Build: Don't allow empty LIST in --enable-match-finders=LIST.
-
- It's enforced only when a match finder is needed, that is,
- when LZMA1 or LZMA2 encoder is enabled.
-
- configure.ac | 4 ++++
- 1 file changed, 4 insertions(+)
-
-commit 9cc721af5436908f2d5a828aebbc4050a32a3487
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-07-24 13:27:48 +0300
-
- xz: Update the man page that change to --keep will be in 5.2.6.
-
- src/xz/xz.1 | 4 ++--
- 1 file changed, 2 insertions(+), 2 deletions(-)
-
-commit b81bf0c7d1873e52a4086a9abb494471d652cb55
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-07-19 23:23:54 +0300
-
- Update THANKS.
-
- THANKS | 1 +
- 1 file changed, 1 insertion(+)
-
-commit 340cf1ec3927767046b8293a49da3db4e393f426
-Author: Nicholas Jackson <nickajacks1@gmail.com>
-Date: 2022-07-17 17:39:23 -0700
-
- CMake: Add missing source file to liblzma build
-
- CMakeLists.txt | 1 +
- 1 file changed, 1 insertion(+)
-
-commit d796b6d7fdb8b7238b277056cf9146cce25db604
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-07-19 23:19:49 +0300
-
- xzgrep man page: Document exit statuses.
-
- src/scripts/xzgrep.1 | 15 ++++++++++++++-
- 1 file changed, 14 insertions(+), 1 deletion(-)
-
-commit 923bf96b55e5216a6c8df9d8331934f54784390e
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-07-19 23:13:24 +0300
-
- xzgrep: Improve error handling, especially signals.
-
- xzgrep wouldn't exit on SIGPIPE or SIGQUIT when it clearly
- should have. It's quite possible that it's not perfect still
- but at least it's much better.
-
- If multiple exit statuses compete, now it tries to pick
- the largest of value.
-
- Some comments were added.
-
- The exit status handling of signals is still broken if the shell
- uses values larger than 255 in $? to indicate that a process
- died due to a signal ***and*** their "exit" command doesn't take
- this into account. This seems to work well with the ksh and yash
- versions I tried. However, there is a report in gzip/zgrep that
- OpenSolaris 5.11 (not 5.10) has a problem with "exit" truncating
- the argument to 8 bits:
-
- https://debbugs.gnu.org/cgi/bugreport.cgi?bug=22900#25
-
- Such a bug would break xzgrep but I didn't add a workaround
- at least for now. 5.11 is old and I don't know if the problem
- exists in modern descendants, or if the problem exists in other
- ksh implementations in use.
-
- src/scripts/xzgrep.in | 72 +++++++++++++++++++++++++++++++++++++--------------
- 1 file changed, 53 insertions(+), 19 deletions(-)
-
-commit a648978b20495b7aa4a8b029c5a810b5ad9d08ff
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-07-19 00:10:55 +0300
-
- xzgrep: Make the fix for ZDI-CAN-16587 more robust.
-
- I don't know if this can make a difference in the real world
- but it looked kind of suspicious (what happens with sed
- implementations that cannot process very long lines?).
- At least this commit shouldn't make it worse.
-
- src/scripts/xzgrep.in | 5 ++++-
- 1 file changed, 4 insertions(+), 1 deletion(-)
-
-commit bd7b290f3fe4faeceb7d3497ed9bf2e6ed5e7dc5
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-07-18 21:52:31 +0300
-
- xzgrep: Use grep -H --label when available (GNU, *BSDs).
-
- It avoids the use of sed for prefixing filenames to output lines.
- Using sed for that is slower and prone to security bugs so now
- the sed method is only used as a fallback.
-
- This also fixes an actual bug: When grepping a binary file,
- GNU grep nowadays prints its diagnostics to stderr instead of
- stdout and thus the sed-method for prefixing the filename doesn't
- work. So with this commit grepping binary files gives reasonable
- output with GNU grep now.
-
- This was inspired by zgrep but the implementation is different.
-
- src/scripts/xzgrep.in | 21 +++++++++++++++++++++
- 1 file changed, 21 insertions(+)
-
-commit b56729af9f1a596e57aeefd7570d8d7dce5c9f52
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-07-18 21:10:25 +0300
-
- xzgrep: Use -e to specify the pattern to grep.
-
- Now we don't need the separate test for adding the -q option
- as it can be added directly in the two places where it's needed.
-
- src/scripts/xzgrep.in | 12 ++++--------
- 1 file changed, 4 insertions(+), 8 deletions(-)
-
-commit bad61b5997e6647911974022bfb72f3d4818a594
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-07-18 19:18:48 +0300
-
- Scripts: Use printf instead of echo in a few places.
-
- It's a good habbit as echo has some portability corner cases
- when the string contents can be anything.
-
- src/scripts/xzdiff.in | 6 +++---
- src/scripts/xzgrep.in | 4 ++--
- src/scripts/xzless.in | 4 ++--
- src/scripts/xzmore.in | 8 ++++----
- 4 files changed, 11 insertions(+), 11 deletions(-)
-
-commit 6a4a4a7d2667837dc824c26fcb19ed6ca5aff645
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-07-17 21:36:25 +0300
-
- xzgrep: Add more LC_ALL=C to avoid bugs with multibyte characters.
-
- Also replace one use of expr with printf.
-
- The rationale for LC_ALL=C was already mentioned in
- 69d1b3fc29677af8ade8dc15dba83f0589cb63d6 that fixed a security
- issue. However, unrelated uses weren't changed in that commit yet.
-
- POSIX says that with sed and such tools one should use LC_ALL=C
- to ensure predictable behavior when strings contain byte sequences
- that aren't valid multibyte characters in the current locale. See
- under "Application usage" in here:
-
- https://pubs.opengroup.org/onlinepubs/9699919799/utilities/sed.html
-
- With GNU sed invalid multibyte strings would work without this;
- it's documented in its Texinfo manual. Some other implementations
- aren't so forgiving.
-
- src/scripts/xzgrep.in | 14 ++++++++------
- 1 file changed, 8 insertions(+), 6 deletions(-)
-
-commit b48f9d615f2c2e8d2f6e253d0e48ee66d0652b68
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-07-17 20:55:16 +0300
-
- xzgrep: Fix parsing of certain options.
-
- Fix handling of "xzgrep -25 foo" (in GNU grep "grep -25 foo" is
- an alias for "grep -C25 foo"). xzgrep would treat "foo" as filename
- instead of as a pattern. This bug was fixed in zgrep in gzip in 2012.
-
- Add -E, -F, -G, and -P to the "no argument required" list.
-
- Add -X to "argument required" list. It is an
- intentionally-undocumented GNU grep option so this isn't
- an important option for xzgrep but it seems that other grep
- implementations (well, those that I checked) don't support -X
- so I hope this change is an improvement still.
-
- grep -d (grep --directories=ACTION) requires an argument. In
- contrast to zgrep, I kept -d in the "no argument required" list
- because it's not supported in xzgrep (or zgrep). This way
- "xzgrep -d" gives an error about option being unsupported instead
- of telling that it requires an argument. Both zgrep and xzgrep
- tell that it's unsupported if an argument is specified.
-
- Add comments.
-
- src/scripts/xzgrep.in | 19 +++++++++++++++++--
- 1 file changed, 17 insertions(+), 2 deletions(-)
-
-commit 2d2201bc6315deda4d43625aa510972467bd51d4
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-07-14 20:33:05 +0300
-
- Tests: Add the .lzma files to test_files.sh.
-
- tests/test_files.sh | 20 ++++++++++++++++++++
- 1 file changed, 20 insertions(+)
-
-commit ce5549a591bf126300618879f5b24023351baff6
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-07-14 19:37:42 +0300
-
- Tests: Add .lzma test files.
-
- tests/files/README | 63 ++++++++++++++++-----
- tests/files/bad-too_big_size-with_eopm.lzma | Bin 0 -> 37 bytes
- tests/files/bad-too_small_size-without_eopm-1.lzma | Bin 0 -> 31 bytes
- tests/files/bad-too_small_size-without_eopm-2.lzma | Bin 0 -> 31 bytes
- tests/files/bad-too_small_size-without_eopm-3.lzma | Bin 0 -> 36 bytes
- tests/files/bad-unknown_size-without_eopm.lzma | Bin 0 -> 31 bytes
- tests/files/good-known_size-with_eopm.lzma | Bin 0 -> 37 bytes
- tests/files/good-known_size-without_eopm.lzma | Bin 0 -> 31 bytes
- tests/files/good-unknown_size-with_eopm.lzma | Bin 0 -> 37 bytes
- 9 files changed, 50 insertions(+), 13 deletions(-)
-
-commit 107c93ee5cad51a6ea0cee471209bfe8d76deaa3
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-07-14 18:12:38 +0300
-
- liblzma: Rename a variable and improve a comment.
-
- src/liblzma/lzma/lzma_decoder.c | 13 +++++++++----
- 1 file changed, 9 insertions(+), 4 deletions(-)
-
-commit 511feb5eadb988d641b025d597f4fac7502003b8
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-07-13 22:24:41 +0300
-
- Update THANKS.
-
- THANKS | 1 +
- 1 file changed, 1 insertion(+)
-
-commit 9595a3119b9faf0ce01375329cad8bbf85c35ea2
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-07-13 22:24:07 +0300
-
- liblzma: Add optional autodetection of LZMA end marker.
-
- Turns out that this is needed for .lzma files as the spec in
- LZMA SDK says that end marker may be present even if the size
- is stored in the header. Such files are rare but exist in the
- real world. The code in liblzma is so old that the spec didn't
- exist in LZMA SDK back then and I had understood that such
- files weren't possible (the lzma tool in LZMA SDK didn't
- create such files).
-
- This modifies the internal API so that LZMA decoder can be told
- if EOPM is allowed even when the uncompressed size is known.
- It's allowed with .lzma and not with other uses.
-
- Thanks to Karl Beldan for reporting the problem.
-
- doc/lzma-file-format.txt | 11 +++-
- src/liblzma/common/alone_decoder.c | 2 +-
- src/liblzma/common/microlzma_decoder.c | 2 +-
- src/liblzma/lz/lz_decoder.c | 10 +++-
- src/liblzma/lz/lz_decoder.h | 8 +--
- src/liblzma/lzma/lzma2_decoder.c | 2 +-
- src/liblzma/lzma/lzma_decoder.c | 99 ++++++++++++++++++++++++----------
- 7 files changed, 95 insertions(+), 39 deletions(-)
-
-commit 0c0f8e9761eb6eaf199082cf144db7ac5f9d8cb2
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-07-12 18:53:04 +0300
-
- xz: Document the special memlimit case of 2000 MiB on MIPS32.
-
- See commit fc3d3a7296ef58bb799a73943636b8bfd95339f7.
-
- src/xz/xz.1 | 8 ++++++--
- 1 file changed, 6 insertions(+), 2 deletions(-)
-
-commit d1bfa3dc703325ecd974167e864a8712fdfe936e
-Author: Jia Tan <jiat0218@gmail.com>
-Date: 2022-07-01 21:19:26 +0800
-
- Created script to generate code coverage reports.
-
- The script uses lcov and genhtml after running the tests
- to show the code coverage statistics. The script will create
- a coverage directory where it is run. It can be run both in
- and out of the source directory.
-
- .gitignore | 4 +++
- tests/code_coverage.sh | 79 ++++++++++++++++++++++++++++++++++++++++++++++++++
- 2 files changed, 83 insertions(+)
-
-commit 86a30b0255d8064169fabfd213d907016d2f9f2a
-Author: Jia Tan <jiat0218@gmail.com>
-Date: 2022-06-16 17:32:19 +0300
-
- Tests: Add more tests into test_check.
-
- tests/test_check.c | 279 +++++++++++++++++++++++++++++++++++++++++++++++++++--
- tests/tests.h | 23 +++++
- 2 files changed, 295 insertions(+), 7 deletions(-)
-
-commit 82e30fed66a89706388a8c15dc954d84e63f38fa
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-06-16 15:02:57 +0300
-
- Tests: Use char[][24] array for enum_strings_lzma_ret.
-
- Array of pointers to short strings is a bit pointless here
- and now it's fully const.
-
- tests/tests.h | 2 +-
- 1 file changed, 1 insertion(+), 1 deletion(-)
-
-commit 5ba9459e6c4a29f6870ca78ce8ac6e519d59c41e
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-06-16 14:12:14 +0300
-
- Tests: tuktest.h: Add tuktest_error_impl to help with error conditions.
-
- tests/tuktest.h | 72 +++++++++++++++++++++++++--------------------------------
- 1 file changed, 32 insertions(+), 40 deletions(-)
-
-commit b339892668da20aea22a93668c82b87a38e4a97f
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-06-16 13:29:59 +0300
-
- Tests: tuktest.h: Rename file_from_* and use tuktest_malloc there.
-
- tests/test_bcj_exact_size.c | 4 +---
- tests/tuktest.h | 52 +++++++++++++++++++++------------------------
- 2 files changed, 25 insertions(+), 31 deletions(-)
-
-commit d8b63a0ad68d1c461eb373466679ebc41fbc207d
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-06-16 13:08:19 +0300
-
- Tests: tuktest.h: Add malloc wrapper with automatic freeing.
-
- tests/tuktest.h | 124 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++
- 1 file changed, 124 insertions(+)
-
-commit 1d51536a4b19a8fae768f8eb462fc2238cb36d53
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-06-16 11:47:37 +0300
-
- Tests: tuktest.h: Move a function.
-
- tests/tuktest.h | 44 ++++++++++++++++++++++----------------------
- 1 file changed, 22 insertions(+), 22 deletions(-)
-
-commit 70c7555f6403553ee35539e869de0025592d8564
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-06-14 22:21:15 +0300
-
- Tests: test_vli: Remove an invalid test-assertion.
-
- lzma_vli is unsigned so trying a signed value results in
- a compiler warning from -Wsign-conversion. (lzma_vli)-1
- equals to LZMA_VLI_UNKNOWN anyway which is the next assertion.
-
- tests/test_vli.c | 2 --
- 1 file changed, 2 deletions(-)
-
-commit 154b73c5a1092c3f785e01666b564ad7ff1be555
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-06-14 22:10:10 +0300
-
- Tests: test_vli: Add const where appropriate.
-
- tests/test_vli.c | 53 ++++++++++++++++++++++++++++-------------------------
- 1 file changed, 28 insertions(+), 25 deletions(-)
-
-commit 0354d6cce3ff98ea6f927107baf216253f6ce2bb
-Author: Jia Tan <jiat75@gmail.com>
-Date: 2022-06-13 20:27:03 +0800
-
- Added vli tests to .gitignore
-
- .gitignore | 1 +
- 1 file changed, 1 insertion(+)
-
-commit a08f5ccf6bdc20ef70e41f6f3321618ef146f96e
-Author: Jia Tan <jiat0218@gmail.com>
-Date: 2022-06-12 11:31:40 +0800
-
- Created tests for all functions exported in vli.h
-
- Achieved 100% code coverage vli_encoder.c, vli_decoder.c, and vli_size.c
-
- tests/Makefile.am | 4 +-
- tests/test_vli.c | 308 ++++++++++++++++++++++++++++++++++++++++++++++++++++++
- 2 files changed, 311 insertions(+), 1 deletion(-)
-
-commit 1e3eb61815a91c0a1bfbb802e2d95593f523491f
-Author: jiat75 <jiat0218@gmail.com>
-Date: 2022-06-03 21:24:54 +0800
-
- Added parallel test artifacts to .gitignore
-
- .gitignore | 2 ++
- 1 file changed, 2 insertions(+)
-
-commit 00e3613f1212eaa84e721585fdb4de6967cf2476
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-06-14 21:29:21 +0300
-
- Tests: Use good-1-empty-bcj-lzma2.xz in test_bcj_exact_size.
-
- It's much nicer this way so that the test data isn't a hardcoded
- table inside the C file.
-
- tests/test_bcj_exact_size.c | 19 +++++++------------
- 1 file changed, 7 insertions(+), 12 deletions(-)
-
-commit 86bab755be252bfd3e0a9aee8e7b83a9bbb23ed0
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-06-14 21:26:13 +0300
-
- Tests: Add file reading helpers to tuktest.h.
-
- tests/tuktest.h | 183 +++++++++++++++++++++++++++++++++++++++++++++++++++++---
- 1 file changed, 176 insertions(+), 7 deletions(-)
-
-commit 83d2337b72dbf391c6f3b41889eea99e51679105
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-06-14 18:21:57 +0300
-
- Tests: tuktest.h: Move a printf from a macro to a helper function.
-
- tests/tuktest.h | 26 ++++++++++++++++++--------
- 1 file changed, 18 insertions(+), 8 deletions(-)
-
-commit f9e8176ea7d520797a2db2d49a5a632c285674a8
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-06-14 17:20:49 +0300
-
- Tests: Add test file good-1-empty-bcj-lzma2.xz.
-
- This is from test_bcj_exact_size.c.
- It's good to have it as a standalone file.
-
- tests/files/README | 5 +++++
- tests/files/good-1-empty-bcj-lzma2.xz | Bin 0 -> 52 bytes
- 2 files changed, 5 insertions(+)
-
-commit aa75c5563a760aea3aa23d997d519e702e82726b
-Author: Jia Tan <jiat0218@gmail.com>
-Date: 2022-06-10 21:35:18 +0800
-
- Tests: Created tests for hardware functions.
-
- Created tests for all API functions exported in
- src/liblzma/api/lzma/hardware.h. The tests are fairly trivial
- but are helpful because they will inform users if their machines
- cannot support these functions. They also improve the code
- coverage metrics.
-
- .gitignore | 1 +
- tests/Makefile.am | 2 ++
- tests/test_hardware.c | 45 +++++++++++++++++++++++++++++++++++++++++++++
- 3 files changed, 48 insertions(+)
-
-commit 5c8ffdca20813939818843476fb212dfae8838a3
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-06-02 21:01:45 +0300
-
- Tests: Convert test_check to tuktest.
-
- Thanks to Jia Tan for help with all the tests.
-
- tests/test_check.c | 67 +++++++++++++++++++++++++++---------------------------
- 1 file changed, 33 insertions(+), 34 deletions(-)
-
-commit faf5ff8899d539b4dcd2a7e5280cb820a4746c86
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-06-02 20:31:03 +0300
-
- Tests: Convert test_block_header to tuktest.
-
- tests/test_block_header.c | 89 +++++++++++++++++++++++++++--------------------
- 1 file changed, 52 insertions(+), 37 deletions(-)
-
-commit 754d39fbebee3782258d42f154a223d3c5770ec7
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-06-02 20:28:23 +0300
-
- Tests: Convert test_bcj_exact_size to tuktest.
-
- The compress() and decompress() functions were merged because
- the later depends on the former so they need to be a single
- test case.
-
- tests/test_bcj_exact_size.c | 75 +++++++++++++++++++++++++--------------------
- 1 file changed, 41 insertions(+), 34 deletions(-)
-
-commit 96da21470f9570cd08286906a050a7c22631775b
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-06-02 20:27:00 +0300
-
- Tests: Include tuktest.h in tests.h.
-
- This breaks -Werror because none of the tests so far use
- tuktest.h and thus there are warnings about unused variables
- and functions.
-
- tests/tests.h | 47 +++++++++++++++++++++++------------------------
- 1 file changed, 23 insertions(+), 24 deletions(-)
-
-commit df71ba1c991f60c3269aaadd398247e632714626
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-06-02 20:25:21 +0300
-
- Tests: Add tuktest.h mini-test-framework.
-
- tests/Makefile.am | 1 +
- tests/tuktest.h | 752 ++++++++++++++++++++++++++++++++++++++++++++++++++++++
- 2 files changed, 753 insertions(+)
-
-commit 4773608554d1b684a05ff9c1d879cf5c42266d33
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-05-23 21:31:36 +0300
-
- Build: Enable Automake's parallel test harness.
-
- It has been the default for quite some time already and
- the old serial harness isn't discouraged. The downside is
- that with parallel tests one cannot print progress info or
- other diagnostics to the terminal; all output from the tests
- will be in the log files only. But now that the compression
- tests are separated the parallel tests will speed things up.
-
- configure.ac | 2 +-
- 1 file changed, 1 insertion(+), 1 deletion(-)
-
-commit 9a6dd6d46f7f256a5573e5d874c1052033ed7b05
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-05-23 21:17:47 +0300
-
- Tests: Split test_compress.sh into separate test unit for each file.
-
- test_compress.sh now takes one command line argument:
- a filename to be tested. If it begins with "compress_generated_"
- the file will be created with create_compress_files.
-
- This will allow parallel execution of the slow tests.
-
- tests/Makefile.am | 11 +++-
- tests/test_compress.sh | 91 +++++++++++++++++++---------------
- tests/test_compress_generated_abc | 3 ++
- tests/test_compress_generated_random | 3 ++
- tests/test_compress_generated_text | 3 ++
- tests/test_compress_prepared_bcj_sparc | 3 ++
- tests/test_compress_prepared_bcj_x86 | 3 ++
- 7 files changed, 77 insertions(+), 40 deletions(-)
-
-commit c7758ac9c734707514dd34f254173ebac5eea7f8
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-05-23 20:32:49 +0300
-
- Test: Make create_compress_files.c a little more flexible.
-
- If a command line argument is given, then only the test file
- of that type is created. It's quite dumb in sense that unknown
- names don't give an error but it's good enough here.
-
- Also use EXIT_FAILURE instead of 1 as exit status for errors.
-
- tests/create_compress_files.c | 25 +++++++++++++++----------
- 1 file changed, 15 insertions(+), 10 deletions(-)
-
-commit 4a8e4a7b0ad4b03c0ac6862716c3457452cdaf8c
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-05-23 20:17:42 +0300
-
- Tests: Remove unneeded commented lines from test_compress.sh.
-
- tests/test_compress.sh | 13 -------------
- 1 file changed, 13 deletions(-)
-
-commit 2ee50d150ee009f36135540b459e6ff328549725
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-05-23 20:16:00 +0300
-
- Tests: Remove progress indicator from test_compress.sh.
-
- It will be useless with Automake's parallel tests.
-
- tests/test_compress.sh | 9 ---------
- 1 file changed, 9 deletions(-)
-
-commit 2ce4f36f179a81d0c6e182a409f363df759d1ad0
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-05-23 19:37:18 +0300
-
- liblzma: Silence a warning.
-
- The actual initialization is done via mythread_sync and seems
- that GCC doesn't necessarily see that it gets initialized there.
-
- src/liblzma/common/stream_decoder_mt.c | 2 +-
- 1 file changed, 1 insertion(+), 1 deletion(-)
-
-commit 5d8f3764ef43c35910e6d7003c0900a961ef6544
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-04-14 20:53:16 +0300
-
- xz: Fix build with --disable-threads.
-
- src/xz/hardware.c | 4 ++++
- 1 file changed, 4 insertions(+)
-
-commit 1d592897278b172d8549aa29c3a1f3a4f432a9b9
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-04-14 14:50:17 +0300
-
- xz: Change the cap of the default -T0 memlimit for 32-bit xz.
-
- The SIZE_MAX / 3 was 1365 MiB. 1400 MiB gives little more room
- and it looks like a round (artificial) number in --info-memory
- once --info-memory is made to display it.
-
- Also, using #if avoids useless code on 64-bit builds.
-
- src/xz/hardware.c | 4 +++-
- 1 file changed, 3 insertions(+), 1 deletion(-)
-
-commit c77fe55ddb7752ed0fec46967c5ec9a72632ea0c
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-04-14 14:20:46 +0300
-
- xz: Add a default soft memory usage limit for --threads=0.
-
- This is a soft limit in sense that it only affects the number of
- threads. It never makes xz fail and it never makes xz change
- settings that would affect the compressed output.
-
- The idea is to make -T0 have more reasonable behavior when
- the system has very many cores or when a memory-hungry
- compression options are used. This also helps with 32-bit xz,
- preventing it from running out of address space.
-
- The downside of this commit is that now the number of threads
- might become too low compared to what the user expected. I
- hope this to be an acceptable compromise as the old behavior
- has been a source of well-argued complaints for a long time.
-
- src/xz/coder.c | 28 ++++++++++++++++++++++++++--
- src/xz/hardware.c | 38 +++++++++++++++++++++++++++++---------
- src/xz/hardware.h | 27 +++++++++++++++++++++++++++
- 3 files changed, 82 insertions(+), 11 deletions(-)
-
-commit 0adc13bfe32c14f3e4c6ce9f2d4fdf4112ab53f4
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-04-14 12:59:09 +0300
-
- xz: Make -T0 use multithreaded mode on single-core systems.
-
- The main problem withi the old behavior is that the compressed
- output is different on single-core systems vs. multicore systems.
- This commit fixes it by making -T0 one thread in multithreaded mode
- on single-core systems.
-
- The downside of this is that it uses more memory. However, if
- --memlimit-compress is used, xz can (thanks to the previous commit)
- drop to the single-threaded mode still.
-
- src/xz/coder.c | 18 +++++++++---------
- src/xz/hardware.c | 14 ++++++++++++++
- src/xz/hardware.h | 4 ++++
- 3 files changed, 27 insertions(+), 9 deletions(-)
-
-commit 898faa97287a756231c663a3ed5165672b417207
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-04-14 12:38:00 +0300
-
- xz: Changes to --memlimit-compress and --no-adjust.
-
- In single-threaded mode, --memlimit-compress can make xz scale down
- the LZMA2 dictionary size to meet the memory usage limit. This
- obviously affects the compressed output. However, if xz was in
- threaded mode, --memlimit-compress could make xz reduce the number
- of threads but it wouldn't make xz switch from multithreaded mode
- to single-threaded mode or scale down the LZMA2 dictionary size.
- This seemed illogical and there was even a "FIXME?" about it.
-
- Now --memlimit-compress can make xz switch to single-threaded
- mode if one thread in multithreaded mode uses too much memory.
- If memory usage is still too high, then the LZMA2 dictionary
- size can be scaled down too.
-
- The option --no-adjust was also changed so that it no longer
- prevents xz from scaling down the number of threads as that
- doesn't affect compressed output (only performance). After
- this commit --no-adjust only prevents adjustments that affect
- compressed output, that is, with --no-adjust xz won't switch
- from multithreaded mode to single-threaded mode and won't
- scale down the LZMA2 dictionary size.
-
- The man page wasn't updated yet.
-
- src/xz/coder.c | 63 +++++++++++++++++++++++++++++++++++++++-------------------
- 1 file changed, 43 insertions(+), 20 deletions(-)
-
-commit cad299008cf73ec566f0662a9cf2b94f86a99659
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-04-11 22:20:49 +0300
-
- xz: Add --memlimit-mt-decompress along with a default limit value.
-
- --memlimit-mt-decompress allows specifying the limit for
- multithreaded decompression. This matches memlimit_threading in
- liblzma. This limit can only affect the number of threads being
- used; it will never prevent xz from decompressing a file. The
- old --memlimit-decompress option is still used at the same time.
-
- If the value of --memlimit-decompress (the default value or
- one specified by the user) is less than the value of
- --memlimit-mt-decompress , then --memlimit-mt-decompress is
- reduced to match --memlimit-decompress.
-
- Man page wasn't updated yet.
-
- src/xz/args.c | 24 +++++++++++++++-------
- src/xz/coder.c | 34 ++++++++++---------------------
- src/xz/hardware.c | 60 ++++++++++++++++++++++++++++++++++++++++++++++++++-----
- src/xz/hardware.h | 17 ++++++++++------
- src/xz/message.c | 4 +++-
- 5 files changed, 97 insertions(+), 42 deletions(-)
-
-commit fe87b4cd5364f5bbb6a75a0299f1500c852d7c9a
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-04-06 23:11:59 +0300
-
- liblzma: Threaded decoder: Improve setting of pending_error.
-
- It doesn't need to be done conditionally. The comments try
- to explain it.
-
- src/liblzma/common/stream_decoder_mt.c | 51 +++++++++++++++++++++++-----------
- 1 file changed, 35 insertions(+), 16 deletions(-)
-
-commit 90621da7f6e1bfd6d91d60415eae04b2bca274c2
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-04-06 12:39:49 +0300
-
- liblzma: Add a new flag LZMA_FAIL_FAST for threaded decoder.
-
- In most cases if the input file is corrupt the application won't
- care about the uncompressed content at all. With this new flag
- the threaded decoder will return an error as soon as any thread
- has detected an error; it won't wait to copy out the data before
- the location of the error.
-
- I don't plan to use this in xz to keep the behavior consistent
- between single-threaded and multi-threaded modes.
-
- src/liblzma/api/lzma/container.h | 25 ++++++++++++++++-
- src/liblzma/common/common.h | 7 +++--
- src/liblzma/common/stream_decoder_mt.c | 50 +++++++++++++++++++---------------
- 3 files changed, 56 insertions(+), 26 deletions(-)
-
-commit 64b6d496dc815a176d8307f418f6834a26783484
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-04-05 12:24:57 +0300
-
- liblzma: Threaded decoder: Always wait for output if LZMA_FINISH is used.
-
- This makes the behavior consistent with the single-threaded
- decoder when handling truncated .xz files.
-
- Thanks to Jia Tan for finding this issue.
-
- src/liblzma/common/stream_decoder_mt.c | 26 ++++++++++++++++++++++++--
- 1 file changed, 24 insertions(+), 2 deletions(-)
-
-commit e671bc8828b9c0c5406c3a22c541301d0eb54518
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-04-02 21:49:59 +0300
-
- liblzma: Threaded decoder: Support zpipe.c-style decoding loop.
-
- This makes it possible to call lzma_code() in a loop that only
- reads new input when lzma_code() didn't fill the output buffer
- completely. That isn't the calling style suggested by the
- liblzma example program 02_decompress.c so perhaps the usefulness
- of this feature is limited.
-
- Also, it is possible to write such a loop so that it works
- with the single-threaded decoder but not with the threaded
- decoder even after this commit, or so that it works only if
- lzma_mt.timeout = 0.
-
- The zlib tutorial <https://zlib.net/zlib_how.html> is a well-known
- example of a loop where more input is read only when output isn't
- full. Porting this as is to liblzma would work with the
- single-threaded decoder (if LZMA_CONCATENATED isn't used) but it
- wouldn't work with threaded decoder even after this commit because
- the loop assumes that no more output is possible when it cannot
- read more input ("if (strm.avail_in == 0) break;"). This cannot
- be fixed at liblzma side; the loop has to be modified at least
- a little.
-
- I'm adding this in any case because the actual code is simple
- and short and should have no harmful side-effects in other
- situations.
-
- src/liblzma/common/stream_decoder_mt.c | 77 +++++++++++++++++++++++++++++-----
- 1 file changed, 67 insertions(+), 10 deletions(-)
-
-commit 2ba8173e27be4793edb46497e499ac2ae753a316
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-03-31 00:05:07 +0300
-
- Update THANKS.
-
- THANKS | 1 +
- 1 file changed, 1 insertion(+)
-
-commit 69d1b3fc29677af8ade8dc15dba83f0589cb63d6
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-03-29 19:19:12 +0300
-
- xzgrep: Fix escaping of malicious filenames (ZDI-CAN-16587).
-
- Malicious filenames can make xzgrep to write to arbitrary files
- or (with a GNU sed extension) lead to arbitrary code execution.
-
- xzgrep from XZ Utils versions up to and including 5.2.5 are
- affected. 5.3.1alpha and 5.3.2alpha are affected as well.
- This patch works for all of them.
-
- This bug was inherited from gzip's zgrep. gzip 1.12 includes
- a fix for zgrep.
-
- The issue with the old sed script is that with multiple newlines,
- the N-command will read the second line of input, then the
- s-commands will be skipped because it's not the end of the
- file yet, then a new sed cycle starts and the pattern space
- is printed and emptied. So only the last line or two get escaped.
-
- One way to fix this would be to read all lines into the pattern
- space first. However, the included fix is even simpler: All lines
- except the last line get a backslash appended at the end. To ensure
- that shell command substitution doesn't eat a possible trailing
- newline, a colon is appended to the filename before escaping.
- The colon is later used to separate the filename from the grep
- output so it is fine to add it here instead of a few lines later.
-
- The old code also wasn't POSIX compliant as it used \n in the
- replacement section of the s-command. Using \<newline> is the
- POSIX compatible method.
-
- LC_ALL=C was added to the two critical sed commands. POSIX sed
- manual recommends it when using sed to manipulate pathnames
- because in other locales invalid multibyte sequences might
- cause issues with some sed implementations. In case of GNU sed,
- these particular sed scripts wouldn't have such problems but some
- other scripts could have, see:
-
- info '(sed)Locale Considerations'
-
- This vulnerability was discovered by:
- cleemy desu wayo working with Trend Micro Zero Day Initiative
-
- Thanks to Jim Meyering and Paul Eggert discussing the different
- ways to fix this and for coordinating the patch release schedule
- with gzip.
-
- src/scripts/xzgrep.in | 20 ++++++++++++--------
- 1 file changed, 12 insertions(+), 8 deletions(-)
-
-commit bd93b776c1bd15e90661033c918cdeb354dbcc38
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-03-26 01:02:44 +0200
-
- liblzma: Fix a deadlock in threaded decoder.
-
- If a worker thread has consumed all input so far and it's
- waiting on thr->cond and then the main thread enables
- partial update for that thread, the code used to deadlock.
- This commit allows one dummy decoding pass to occur in this
- situation which then also does the partial update.
-
- As part of the fix, this moves thr->progress_* updates to
- avoid the second thr->mutex locking.
-
- Thanks to Jia Tan for finding, debugging, and reporting the bug.
-
- src/liblzma/common/stream_decoder_mt.c | 71 +++++++++++++++++++++++++---------
- 1 file changed, 52 insertions(+), 19 deletions(-)
-
-commit e0394e94230f208682ac1e1f4c41f22f9ad79916
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-03-23 16:34:00 +0200
-
- Update THANKS.
-
- THANKS | 1 +
- 1 file changed, 1 insertion(+)
-
-commit 487c77d48760564b1949c5067630b675b87be4de
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-03-23 16:28:55 +0200
-
- liblzma: Threaded decoder: Don't stop threads on LZMA_TIMED_OUT.
-
- LZMA_TIMED_OUT is not an error and thus stopping threads on
- LZMA_TIMED_OUT breaks the decoder badly.
-
- Thanks to Jia Tan for finding the bug and for the patch.
-
- src/liblzma/common/stream_decoder_mt.c | 2 +-
- 1 file changed, 1 insertion(+), 1 deletion(-)
-
-commit 6c6da57ae2aa962aabde6892442227063d87e88c
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-03-07 00:36:16 +0200
-
- xz: Add initial support for threaded decompression.
-
- If threading support is enabled at build time, this will
- use lzma_stream_decoder_mt() even for single-threaded mode.
- With memlimit_threading=0 the behavior should be identical.
-
- This needs some work like adding --memlimit-threading=LIMIT.
-
- The original patch from Sebastian Andrzej Siewior included
- a method to get currently available RAM on Linux. It might
- be one way to go but as it is Linux-only, the available-RAM
- approach needs work for portability or using a fallback method
- on other OSes.
-
- The man page wasn't updated yet.
-
- src/xz/coder.c | 36 +++++++++++++++++++++++++++++++++++-
- 1 file changed, 35 insertions(+), 1 deletion(-)
-
-commit 4cce3e27f529af33e0e7749a8cbcec59954946b5
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-03-06 23:36:20 +0200
-
- liblzma: Add threaded .xz decompressor.
-
- I realize that this is about a decade late.
-
- Big thanks to Sebastian Andrzej Siewior for the original patch.
- I made a bunch of smaller changes but after a while quite a few
- things got rewritten. So any bugs in the commit were created by me.
-
- src/liblzma/api/lzma/container.h | 90 +-
- src/liblzma/common/Makefile.inc | 5 +
- src/liblzma/common/common.h | 4 +
- src/liblzma/common/stream_decoder_mt.c | 1814 ++++++++++++++++++++++++++++++++
- src/liblzma/liblzma.map | 1 +
- 5 files changed, 1907 insertions(+), 7 deletions(-)
-
-commit 717631b9788dc9c100ee0c87d3c14a2782638ff4
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-03-06 16:54:23 +0200
-
- liblzma: Fix docs: lzma_block_decoder() cannot return LZMA_UNSUPPORTED_CHECK.
-
- If Check is unsupported, it will be silently ignored.
- It's the caller's job to handle it.
-
- src/liblzma/api/lzma/block.h | 3 ---
- 1 file changed, 3 deletions(-)
-
-commit 1a4bb97a00936535e30ac61945aeee38882b5d1a
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-03-06 16:41:19 +0200
-
- liblzma: Add new output queue (lzma_outq) features.
-
- Add lzma_outq_clear_cache2() which may leave one buffer allocated
- in the cache.
-
- Add lzma_outq_outbuf_memusage() to get the memory needed for
- a single lzma_outbuf. This is now used internally in outqueue.c too.
-
- Track both the total amount of memory allocated and the amount of
- memory that is in active use (not in cache).
-
- In lzma_outbuf, allow storing the current input position that
- matches the current output position. This way the main thread
- can notice when no more output is possible without first providing
- more input.
-
- Allow specifying return code for lzma_outq_read() in a finished
- lzma_outbuf.
-
- src/liblzma/common/outqueue.c | 43 +++++++++++++++++++++++++++++++++++-------
- src/liblzma/common/outqueue.h | 44 ++++++++++++++++++++++++++++++++++++++++++-
- 2 files changed, 79 insertions(+), 8 deletions(-)
-
-commit ddbc6f58c2de388eed24cd7ea91b523d397da5f4
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-03-06 15:18:58 +0200
-
- liblzma: Index hash: Change return value type of hash_append() to void.
-
- src/liblzma/common/index_hash.c | 11 +++++------
- 1 file changed, 5 insertions(+), 6 deletions(-)
-
-commit 20e7a33e2d59c6a814447d3991f21e2702174b20
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-02-22 03:42:57 +0200
-
- liblzma: Minor addition to lzma_vli_size() API doc.
-
- Thanks to Jia Tan.
-
- src/liblzma/api/lzma/vli.h | 2 ++
- 1 file changed, 2 insertions(+)
-
-commit 4f78f5fcf63592f2d77e921cfe0d5de300867374
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-02-22 02:04:18 +0200
-
- liblzma: Check the return value of lzma_index_append() in threaded encoder.
-
- If lzma_index_append() failed (most likely memory allocation failure)
- it could have gone unnoticed and the resulting .xz file would have
- an incorrect Index. Decompressing such a file would produce the
- correct uncompressed data but then an error would occur when
- verifying the Index field.
-
- src/liblzma/common/stream_encoder_mt.c | 7 +++++--
- 1 file changed, 5 insertions(+), 2 deletions(-)
-
-commit 5313ad66b40aab822ddca3e9905254cb99a4080d
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-02-22 01:37:39 +0200
-
- Update THANKS.
-
- THANKS | 1 +
- 1 file changed, 1 insertion(+)
-
-commit 865e0a3689a25a7ee8eecae1a34c1775e3aa676e
-Author: Ed Maste <emaste@FreeBSD.org>
-Date: 2022-02-11 15:25:46 +0000
-
- liblzma: Use non-executable stack on FreeBSD as on Linux
-
- src/liblzma/check/crc32_x86.S | 4 ++--
- src/liblzma/check/crc64_x86.S | 4 ++--
- 2 files changed, 4 insertions(+), 4 deletions(-)
-
-commit 1c9a5786d206b4abc8e427326651c8174baea753
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-02-20 20:36:27 +0200
-
- liblzma: Make Block decoder catch certain types of errors better.
-
- Now it limits the input and output buffer sizes that are
- passed to a raw decoder. This way there's no need to check
- if the sizes can grow too big or overflow when updating
- Compressed Size and Uncompressed Size counts. This also means
- that a corrupt file cannot cause the raw decoder to process
- useless extra input or output that would exceed the size info
- in Block Header (and thus cause LZMA_DATA_ERROR anyway).
-
- More importantly, now the size information is verified more
- carefully in case raw decoder returns LZMA_OK. This doesn't
- really matter with the current single-threaded .xz decoder
- as the errors would be detected slightly later anyway. But
- this helps avoiding corner cases in the upcoming threaded
- decompressor, and it might help other Block decoder uses
- outside liblzma too.
-
- The test files bad-1-lzma2-{9,10,11}.xz test these conditions.
- With the single-threaded .xz decoder the only difference is
- that LZMA_DATA_ERROR is detected in a difference place now.
-
- src/liblzma/common/block_decoder.c | 79 ++++++++++++++++++++++++++------------
- 1 file changed, 54 insertions(+), 25 deletions(-)
-
-commit 555de11873eb00c9b94a8be70645db502e5a9dbd
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-02-20 19:38:55 +0200
-
- Tests: Add bad-1-lzma2-11.xz.
-
- tests/files/README | 5 +++++
- tests/files/bad-1-lzma2-11.xz | Bin 0 -> 64 bytes
- 2 files changed, 5 insertions(+)
-
-commit f0da507f22e7f4e3edb75b45b74d344244ca03fb
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-02-18 18:51:10 +0200
-
- Translations: Fix po4a failure with the French man page translations.
-
- Thanks to Mario Blättermann for the patch.
-
- po4a/fr_FR.po | 6 ++++--
- 1 file changed, 4 insertions(+), 2 deletions(-)
-
-commit f7711d228c3c32395460c82498c60a9f730d0239
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-02-07 01:14:37 +0200
-
- Translations: Add French translation of man pages.
-
- This matches xz-utils 5.2.5-2 in Debian.
-
- The translation was done by "bubu", proofread by the debian-l10n-french
- mailing list contributors, and submitted to me on the xz-devel mailing
- list by Jean-Pierre Giraud. Thanks to everyone!
-
- po4a/fr_FR.po | 3541 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++
- po4a/po4a.conf | 2 +-
- 2 files changed, 3542 insertions(+), 1 deletion(-)
-
-commit 6468f7e41a8e9c611e4ba8d34e2175c5dacdbeb4
-Author: jiat75 <jiat0218@gmail.com>
-Date: 2022-01-28 20:47:55 +0800
-
- liblzma: Add NULL checks to LZMA and LZMA2 properties encoders.
-
- Previously lzma_lzma_props_encode() and lzma_lzma2_props_encode()
- assumed that the options pointers must be non-NULL because the
- with these filters the API says it must never be NULL. It is
- good to do these checks anyway.
-
- src/liblzma/lzma/lzma2_encoder.c | 3 +++
- src/liblzma/lzma/lzma_encoder.c | 3 +++
- 2 files changed, 6 insertions(+)
-
-commit 2523c30705f49eabd27b854aa656ae87cc224808
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2022-02-06 23:19:32 +0200
-
- liblzma: Fix uint64_t vs. size_t confusion.
-
- This broke 32-bit builds due to a pointer type mismatch.
-
- This bug was introduced with the output-size-limited encoding
- in 625f4c7c99b2fcc4db9e7ab2deb4884790e2e17c.
-
- Thanks to huangqinjin for the bug report.
-
- src/liblzma/rangecoder/range_encoder.h | 11 +++++++----
- 1 file changed, 7 insertions(+), 4 deletions(-)
-
-commit 2bd36c91d03e03b31a4f12fd0afc100ae32d66e2
-Author: huangqinjin <huangqinjin@gmail.com>
-Date: 2021-12-13 20:49:21 +0800
-
- CMake: Keep compatible with Windows 95 for 32-bit build.
-
- CMakeLists.txt | 12 +++++++++++-
- 1 file changed, 11 insertions(+), 1 deletion(-)
-
-commit 2024fbf2794885277d05378d40b2b8015a7c3b40
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2021-11-13 21:04:05 +0200
-
- xzgrep: Update man page timestamp.
-
- src/scripts/xzgrep.1 | 2 +-
- 1 file changed, 1 insertion(+), 1 deletion(-)
-
-commit 400e7a239a53282cedaad927a41f3463d7f542e5
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2021-11-13 18:23:24 +0200
-
- Update THANKS.
-
- THANKS | 1 +
- 1 file changed, 1 insertion(+)
-
-commit 3a512c7787b2642ca946f4adc6e9a0a5d9b0d5a0
-Author: Ville Skyttä <ville.skytta@iki.fi>
-Date: 2021-11-13 10:11:57 +0200
-
- xzgrep: use `grep -E/-F` instead of `egrep` and `fgrep`
-
- `egrep` and `fgrep` have been deprecated in GNU grep since 2007, and in
- current post 3.7 Git they have been made to emit obsolescence warnings:
- https://git.savannah.gnu.org/cgit/grep.git/commit/?id=a9515624709865d480e3142fd959bccd1c9372d1
-
- src/scripts/xzgrep.1 | 8 ++++----
- src/scripts/xzgrep.in | 4 ++--
- 2 files changed, 6 insertions(+), 6 deletions(-)
-
-commit edf525e2b1840dcaf377df472c67d8f11f8ace1b
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2021-10-28 23:02:11 +0300
-
- Bump the version number for 5.3.2alpha.
-
- src/liblzma/api/lzma/version.h | 2 +-
- src/liblzma/liblzma.map | 2 +-
- 2 files changed, 2 insertions(+), 2 deletions(-)
-
-commit ea8c948655a86290524efe59cff067e06a886709
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2021-10-28 22:59:52 +0300
-
- Add NEWS for 5.3.2alpha.
-
- NEWS | 86 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
- 1 file changed, 86 insertions(+)
-
-commit 52435f302f4724157ec50b4210cbe42b285c3cbc
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2021-10-27 23:27:48 +0300
-
- Update THANKS.
-
- THANKS | 1 +
- 1 file changed, 1 insertion(+)
-
-commit f2aea1d5a504b2021bf47a238390e4f12bdd518d
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2021-10-27 23:23:11 +0300
-
- xz: Change the coding style of the previous commit.
-
- It isn't any better now but it's consistent with
- the rest of the code base.
-
- src/xz/file_io.c | 11 ++++++-----
- 1 file changed, 6 insertions(+), 5 deletions(-)
-
-commit 892b16cc282f5b4e1c49871b326f4db25c5b4d81
-Author: Alexander Bluhm <alexander.bluhm@gmx.net>
-Date: 2021-10-05 23:33:16 +0200
-
- xz: Avoid fchown(2) failure.
-
- OpenBSD does not allow to change the group of a file if the user
- does not belong to this group. In contrast to Linux, OpenBSD also
- fails if the new group is the same as the old one. Do not call
- fchown(2) in this case, it would change nothing anyway.
-
- This fixes an issue with Perl Alien::Build module.
- https://github.com/PerlAlien/Alien-Build/issues/62
-
- src/xz/file_io.c | 8 +++++++-
- 1 file changed, 7 insertions(+), 1 deletion(-)
-
-commit 2b509c868cae3988bf21cd693fbf9021cdc85628
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2021-09-17 17:31:11 +0300
-
- liblzma: Fix liblzma.map for the lzma_microlzma_* symbols.
-
- This should have been part of d267d109c370a40b502e73f8664b154b15e4f253.
-
- Thanks to Gao Xiang.
-
- src/liblzma/liblzma.map | 4 ++--
- 1 file changed, 2 insertions(+), 2 deletions(-)
-
-commit cacb06a954b58255dfc084a0bc9708f43a0fd6d6
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2021-09-09 22:21:07 +0300
-
- Update THANKS.
-
- THANKS | 1 +
- 1 file changed, 1 insertion(+)
-
-commit 6928aac9da6ba612780b9f72ba1d6ecbe1e8b54e
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2021-09-09 21:41:51 +0300
-
- liblzma: Use _MSVC_LANG to detect when "noexcept" can be used with MSVC.
-
- By default, MSVC always sets __cplusplus to 199711L. The real
- C++ standard version is available in _MSVC_LANG (or one could
- use /Zc:__cplusplus to set __cplusplus correctly).
-
- Fixes <https://sourceforge.net/p/lzmautils/discussion/708858/thread/f6bc3b108a/>.
-
- Thanks to Dan Weiss.
-
- src/liblzma/api/lzma.h | 3 ++-
- 1 file changed, 2 insertions(+), 1 deletion(-)
-
-commit d267d109c370a40b502e73f8664b154b15e4f253
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2021-09-05 20:38:12 +0300
-
- liblzma: Rename EROFS LZMA to MicroLZMA.
-
- It still exists primarily for EROFS but MicroLZMA is
- a more generic name (that hopefully doesn't clash with
- something that already exists).
-
- src/liblzma/api/lzma/container.h | 33 +++++++++++++---------
- src/liblzma/common/Makefile.inc | 4 +--
- .../{erofs_decoder.c => microlzma_decoder.c} | 32 ++++++++++-----------
- .../{erofs_encoder.c => microlzma_encoder.c} | 30 ++++++++++----------
- 4 files changed, 52 insertions(+), 47 deletions(-)
-
-commit 3247e95115acb95bc27f41e8cf4501db5b0b4309
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2021-06-04 19:02:38 +0300
-
- xzdiff: Update the man page about the exit status.
-
- This was forgotten from 194029ffaf74282a81f0c299c07f73caca3232ca.
-
- src/scripts/xzdiff.1 | 4 ++--
- 1 file changed, 2 insertions(+), 2 deletions(-)
-
-commit 96f5a28a46fc93ac4e296808ac0f8631d05498bc
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2021-06-04 18:52:48 +0300
-
- xzless: Fix less(1) version detection when it contains a dot.
-
- Sometimes the version number from "less -V" contains a dot,
- sometimes not. xzless failed detect the version number when
- it does contain a dot. This fixes it.
-
- Thanks to nick87720z for reporting this. Apparently it had been
- reported here <https://bugs.gentoo.org/489362> in 2013.
-
- src/scripts/xzless.in | 2 +-
- 1 file changed, 1 insertion(+), 1 deletion(-)
-
-commit 5fb5212d816addbc523d0798cb482fdd0484f8fa
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2021-04-11 19:58:10 +0300
-
- Update THANKS.
-
- THANKS | 2 ++
- 1 file changed, 2 insertions(+)
-
-commit fc3d3a7296ef58bb799a73943636b8bfd95339f7
-Author: Ivan A. Melnikov <iv@altlinux.org>
-Date: 2021-04-09 11:45:10 +0300
-
- Reduce maximum possible memory limit on MIPS32
-
- Due to architectural limitations, address space available to a single
- userspace process on MIPS32 is limited to 2 GiB, not 4, even on systems
- that have more physical RAM -- e.g. 64-bit systems with 32-bit
- userspace, or systems that use XPA (an extension similar to x86's PAE).
-
- So, for MIPS32, we have to impose stronger memory limits. I've chosen
- 2000MiB to give the process some headroom.
-
- src/xz/hardware.c | 6 ++++++
- 1 file changed, 6 insertions(+)
-
-commit e7da44d5151e21f153925781ad29334ae0786101
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2021-02-13 23:31:27 +0200
-
- CMake: Use interface library for better FindLibLZMA compatibility.
-
- https://www.mail-archive.com/xz-devel@tukaani.org/msg00446.html
-
- Thanks to Markus Rickert.
-
- CMakeLists.txt | 11 +++++++++--
- 1 file changed, 9 insertions(+), 2 deletions(-)
-
-commit a61dd82ada39030f41b4ffca9ea551714908bedc
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2021-01-30 18:36:04 +0200
-
- CMake: Try to improve compatibility with the FindLibLZMA module.
-
- The naming conflict with FindLibLZMA module gets worse.
- Not avoiding it in the first place was stupid.
-
- Normally find_package(LibLZMA) will use the module and
- find_package(liblzma 5.2.5 REQUIRED CONFIG) will use the config
- file even with a case insensitive file system. However, if
- CMAKE_FIND_PACKAGE_PREFER_CONFIG is TRUE and the file system
- is case insensitive, find_package(LibLZMA) will find our liblzma
- config file instead of using FindLibLZMA module.
-
- One big problem with this is that FindLibLZMA uses
- LibLZMA::LibLZMA and we use liblzma::liblzma as the target
- name. With target names CMake happens to be case sensitive.
- To workaround this, this commit adds
-
- add_library(LibLZMA::LibLZMA ALIAS liblzma::liblzma)
-
- to the config file. Then both spellings work.
-
- To make the behavior consistent between case sensitive and
- insensitive file systems, the config and related files are
- renamed from liblzmaConfig.cmake to liblzma-config.cmake style.
- With this style CMake looks for lowercase version of the package
- name so find_package(LiBLzmA 5.2.5 REQUIRED CONFIG) will work
- to find our config file.
-
- There are other differences between our config file and
- FindLibLZMA so it's still possible that things break for
- reasons other than the spelling of the target name. Hopefully
- those situations aren't too common.
-
- When the config file is available, it should always give as good or
- better results as FindLibLZMA so this commit doesn't affect the
- recommendation to use find_package(liblzma 5.2.5 REQUIRED CONFIG)
- which explicitly avoids FindLibLZMA.
-
- Thanks to Markus Rickert.
-
- CMakeLists.txt | 21 +++++++++++++--------
- 1 file changed, 13 insertions(+), 8 deletions(-)
-
-commit 5b7bc1b8ae766a76710ca1b99f909cf52c697f05
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2021-01-29 21:19:43 +0200
-
- Update THANKS.
-
- THANKS | 1 +
- 1 file changed, 1 insertion(+)
-
-commit 6c6f0db340dcb8bb424411cedba713405d55f6b8
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2021-01-29 21:19:08 +0200
-
- liblzma: Fix unitialized variable.
-
- This was introduced two weeks ago in the commit
- 625f4c7c99b2fcc4db9e7ab2deb4884790e2e17c.
-
- Thanks to Nathan Moinvaziri.
-
- src/liblzma/lzma/lzma_encoder.c | 1 +
- 1 file changed, 1 insertion(+)
-
-commit bb1d5c1fdd30550d4221ecd336e0be1206132a5c
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2021-01-24 22:32:41 +0200
-
- Tests: Add bad-1-lzma2-10.xz and also modify -9.xz.
-
- tests/files/README | 11 +++++++++--
- tests/files/bad-1-lzma2-10.xz | Bin 0 -> 60 bytes
- tests/files/bad-1-lzma2-9.xz | Bin 72 -> 72 bytes
- 3 files changed, 9 insertions(+), 2 deletions(-)
-
-commit 6b8abc84a5469792e0355d0bfc0784d41cfdfef7
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2021-01-24 19:22:35 +0200
-
- liblzma: Fix a wrong comment in stream_encoder_mt.c.
-
- src/liblzma/common/stream_encoder_mt.c | 10 +++++++---
- 1 file changed, 7 insertions(+), 3 deletions(-)
-
-commit 939fc5ed654aac25fe0c8684b2df8dbeadb2de1e
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2021-01-24 18:51:51 +0200
-
- Tests: Add bad-1-lzma2-9.xz.
-
- tests/files/README | 4 ++++
- tests/files/bad-1-lzma2-9.xz | Bin 0 -> 72 bytes
- 2 files changed, 4 insertions(+)
-
-commit fdd30032f8531ac89519b48c21d810ecf06825f6
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2021-01-24 17:02:00 +0200
-
- Tests: Add bad-1-check-crc32-2.xz.
-
- tests/files/README | 7 +++++++
- tests/files/bad-1-check-crc32-2.xz | Bin 0 -> 72 bytes
- 2 files changed, 7 insertions(+)
-
-commit db465419ae26ec7fb9b9472183911ff521620c77
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2021-01-17 19:20:50 +0200
-
- liblzma: In EROFS LZMA decoder, verify that comp_size matches at the end.
-
- When the uncompressed size is known to be exact, after decompressing
- the stream exactly comp_size bytes of input must have been consumed.
- This is a minor improvement to error detection.
-
- src/liblzma/common/erofs_decoder.c | 7 ++++++-
- 1 file changed, 6 insertions(+), 1 deletion(-)
-
-commit 774cc0118ba2496581cb2621505a04bb6598cc75
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2021-01-17 18:53:34 +0200
-
- liblzma: Make EROFS LZMA decoder work when exact uncomp_size isn't known.
-
- The caller must still not specify an uncompressed size bigger
- than the actual uncompressed size.
-
- As a downside, this now needs the exact compressed size.
-
- src/liblzma/api/lzma/container.h | 23 ++++++++---
- src/liblzma/common/erofs_decoder.c | 80 ++++++++++++++++++++++++++++++++++----
- 2 files changed, 91 insertions(+), 12 deletions(-)
-
-commit 421b0aa352da244075db10205cf33712f91b9835
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2021-01-14 20:57:11 +0200
-
- liblzma: Fix missing normalization in rc_encode_dummy().
-
- Without this fix it could attempt to create too much output.
-
- src/liblzma/rangecoder/range_encoder.h | 7 ++++++-
- 1 file changed, 6 insertions(+), 1 deletion(-)
-
-commit 601ec0311e769fc704daaaa7dac0ca840aff080e
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2021-01-14 20:07:01 +0200
-
- liblzma: Add EROFS LZMA encoder and decoder.
-
- Right now this is just a planned extra-compact format for use
- in the EROFS file system in Linux. At this point it's possible
- that the format will either change or be abandoned and removed
- completely.
-
- The special thing about the encoder is that it uses the
- output-size-limited encoding added in the previous commit.
- EROFS uses fixed-sized blocks (e.g. 4 KiB) to hold compressed
- data so the compressors must be able to create valid streams
- that fill the given block size.
-
- src/liblzma/api/lzma/container.h | 76 +++++++++++++++++++
- src/liblzma/common/Makefile.inc | 2 +
- src/liblzma/common/erofs_decoder.c | 148 +++++++++++++++++++++++++++++++++++++
- src/liblzma/common/erofs_encoder.c | 139 ++++++++++++++++++++++++++++++++++
- src/liblzma/liblzma.map | 2 +
- 5 files changed, 367 insertions(+)
-
-commit 625f4c7c99b2fcc4db9e7ab2deb4884790e2e17c
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2021-01-13 19:16:32 +0200
-
- liblzma: Add rough support for output-size-limited encoding in LZMA1.
-
- With this it is possible to encode LZMA1 data without EOPM so that
- the encoder will encode as much input as it can without exceeding
- the specified output size limit. The resulting LZMA1 stream will
- be a normal LZMA1 stream without EOPM. The actual uncompressed size
- will be available to the caller via the uncomp_size pointer.
-
- One missing thing is that the LZMA layer doesn't inform the LZ layer
- when the encoding is finished and thus the LZ may read more input
- when it won't be used. However, this doesn't matter if encoding is
- done with a single call (which is the planned use case for now).
- For proper multi-call encoding this should be improved.
-
- This commit only adds the functionality for internal use.
- Nothing uses it yet.
-
- src/liblzma/common/common.h | 11 +++
- src/liblzma/lz/lz_encoder.c | 16 ++++
- src/liblzma/lz/lz_encoder.h | 4 +
- src/liblzma/lzma/lzma_encoder.c | 127 +++++++++++++++++++++++---------
- src/liblzma/lzma/lzma_encoder_private.h | 12 +++
- src/liblzma/rangecoder/range_encoder.h | 111 ++++++++++++++++++++++++++++
- 6 files changed, 246 insertions(+), 35 deletions(-)
-
-commit 9cdabbeea891e8f1e7741b076f7db6ac05ae392a
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2021-01-11 23:57:11 +0200
-
- Scripts: Add zstd support to xzdiff.
-
- src/scripts/xzdiff.1 | 6 ++++--
- src/scripts/xzdiff.in | 16 +++++++++++-----
- 2 files changed, 15 insertions(+), 7 deletions(-)
-
-commit d9ec3add97cf4c999a7f594c6529680227b6c274
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2021-01-11 23:41:30 +0200
-
- Update THANKS.
-
- THANKS | 2 ++
- 1 file changed, 2 insertions(+)
-
-commit 074259f4f3966aeac6edb205fecbc1a8d2b58bb2
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2021-01-11 23:41:16 +0200
-
- xz: Make --keep accept symlinks, hardlinks, and setuid/setgid/sticky.
-
- Previously this required using --force but that has other
- effects too which might be undesirable. Changing the behavior
- of --keep has a small risk of breaking existing scripts but
- since this is a fairly special corner case I expect the
- likehood of breakage to be low enough.
-
- I think the new behavior is more logical. The only reason for
- the old behavior was to be consistent with gzip and bzip2.
-
- Thanks to Vincent Lefevre and Sebastian Andrzej Siewior.
-
- src/xz/file_io.c | 9 +++++----
- src/xz/xz.1 | 16 +++++++++++++++-
- 2 files changed, 20 insertions(+), 5 deletions(-)
-
-commit 73c555b3077c19dda29b6f4592ced2af876f8333
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2021-01-11 23:28:52 +0200
-
- Scripts: Fix exit status of xzgrep.
-
- Omit the -q option from xz, gzip, and bzip2. With xz this shouldn't
- matter. With gzip it's important because -q makes gzip replace SIGPIPE
- with exit status 2. With bzip2 it's important because with -q bzip2
- is completely silent if input is corrupt while other decompressors
- still give an error message.
-
- Avoiding exit status 2 from gzip is important because bzip2 uses
- exit status 2 to indicate corrupt input. Before this commit xzgrep
- didn't recognize corrupt .bz2 files because xzgrep was treating
- exit status 2 as SIGPIPE for gzip compatibility.
-
- zstd still needs -q because otherwise it is noisy in normal
- operation.
-
- The code to detect real SIGPIPE didn't check if the exit status
- was due to a signal (>= 128) and so could ignore some other exit
- status too.
-
- src/scripts/xzgrep.in | 20 +++++++++++++-------
- 1 file changed, 13 insertions(+), 7 deletions(-)
-
-commit 194029ffaf74282a81f0c299c07f73caca3232ca
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2021-01-11 22:01:51 +0200
-
- Scripts: Fix exit status of xzdiff/xzcmp.
-
- This is a minor fix since this affects only the situation when
- the files differ and the exit status is something else than 0.
- In such case there could be SIGPIPE from a decompression tool
- and that would result in exit status of 2 from xzdiff/xzcmp
- while the correct behavior would be to return 1 or whatever
- else diff or cmp may have returned.
-
- This commit omits the -q option from xz/gzip/bzip2/lzop arguments.
- I'm not sure why the -q was used in the first place, perhaps it
- hides warnings in some situation that I cannot see at the moment.
- Hopefully the removal won't introduce a new bug.
-
- With gzip the -q option was harmful because it made gzip return 2
- instead of >= 128 with SIGPIPE. Ignoring exit status 2 (warning
- from gzip) isn't practical because bzip2 uses exit status 2 to
- indicate corrupt input file. It's better if SIGPIPE results in
- exit status >= 128.
-
- With bzip2 the removal of -q seems to be good because with -q
- it prints nothing if input is corrupt. The other tools aren't
- silent in this situation even with -q. On the other hand, if
- zstd support is added, it will need -q since otherwise it's
- noisy in normal situations.
-
- Thanks to Étienne Mollier and Sebastian Andrzej Siewior.
-
- src/scripts/xzdiff.in | 35 +++++++++++++++++++++--------------
- 1 file changed, 21 insertions(+), 14 deletions(-)
-
-commit f7fa309e1f7178d04c7bedc03b73077639371e97
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2021-01-09 21:14:36 +0200
-
- liblzma: Make lzma_outq usable for threaded decompression too.
-
- Before this commit all output queue buffers were allocated as
- a single big allocation. Now each buffer is allocated separately
- when needed. Used buffers are cached to avoid reallocation
- overhead but the cache will keep only one buffer size at a time.
- This should make things work OK in the decompression where most
- of the time the buffer sizes will be the same but with some less
- common files the buffer sizes may vary.
-
- While this should work fine, it's still a bit preliminary
- and may even get reverted if it turns out to be useless for
- decompression.
-
- src/liblzma/common/outqueue.c | 268 +++++++++++++++++++++------------
- src/liblzma/common/outqueue.h | 138 ++++++++++++-----
- src/liblzma/common/stream_encoder_mt.c | 52 ++++---
- 3 files changed, 301 insertions(+), 157 deletions(-)
-
-commit a35a69d693ce37d4ba7c1855bda7d9cfa13d1778
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2020-12-23 17:15:49 +0200
-
- Update THANKS.
-
- THANKS | 1 +
- 1 file changed, 1 insertion(+)
-
-commit 4fd79b90c52396d70e0b1206ceb1a873a0ad2589
-Author: H.J. Lu <hjl.tools@gmail.com>
-Date: 2020-12-23 06:49:04 -0800
-
- liblzma: Enable Intel CET in x86 CRC assembly codes
-
- When Intel CET is enabled, we need to include <cet.h> in assembly codes
- to mark Intel CET support and add _CET_ENDBR to indirect jump targets.
-
- Tested on Intel Tiger Lake under CET enabled Linux.
-
- src/liblzma/check/crc32_x86.S | 9 +++++++++
- src/liblzma/check/crc64_x86.S | 9 +++++++++
- 2 files changed, 18 insertions(+)
-
-commit bb3b8c6a23e25db79f862b1de325c56052e0354b
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2020-12-16 18:33:29 +0200
-
- Update THANKS.
-
- THANKS | 1 +
- 1 file changed, 1 insertion(+)
-
-commit 21588ca34af98738954fc12ded1b89d7294ef646
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2020-12-16 18:30:14 +0200
-
- Build: Don't build bundles on Apple OSes.
-
- Thanks to Daniel Packard.
-
- CMakeLists.txt | 3 +++
- 1 file changed, 3 insertions(+)
-
-commit d05b0c42dd8b38d8c6b8193c8af50e9bd3d16f28
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2020-12-05 22:44:03 +0200
-
- Update THANKS.
-
- THANKS | 1 +
- 1 file changed, 1 insertion(+)
-
-commit 1890351f3423627ba5c4c495402f32d7e9ed90b7
-Author: Adam Borowski <kilobyte@angband.pl>
-Date: 2020-09-25 03:35:18 +0200
-
- Scripts: Add zstd support to xzgrep.
-
- Thanks to Adam Borowski.
-
- src/scripts/xzgrep.1 | 9 ++++++---
- src/scripts/xzgrep.in | 1 +
- 2 files changed, 7 insertions(+), 3 deletions(-)
-
-commit 2f108abb3d82e4e2313b438dae9c0c7c7a6366f2
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2020-11-17 20:51:48 +0200
-
- CMake: Fix compatibility with CMake 3.13.
-
- The syntax "if(DEFINED CACHE{FOO})" requires CMake 3.14.
- In some other places the code treats the cache variables
- like normal variables already (${FOO} or if(FOO) is used,
- not ${CACHE{FOO}).
-
- Thanks to ygrek for reporting the bug on IRC.
-
- CMakeLists.txt | 2 +-
- cmake/tuklib_cpucores.cmake | 4 ++--
- cmake/tuklib_physmem.cmake | 4 ++--
- 3 files changed, 5 insertions(+), 5 deletions(-)
-
-commit 5af726a79273fafa5de5745b117e567f21c90e49
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2020-11-01 22:56:43 +0200
-
- Update THANKS.
-
- THANKS | 4 +++-
- 1 file changed, 3 insertions(+), 1 deletion(-)
-
-commit 4575d9d365c756ec189899f9f743e0b3515ce72d
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2020-11-01 22:34:25 +0200
-
- xz: Avoid unneeded \f escapes on the man page.
-
- I don't want to use \c in macro arguments but groff_man(7)
- suggests that \f has better portability. \f would be needed
- for the .TP strings for portability reasons anyway.
-
- Thanks to Bjarni Ingi Gislason.
-
- src/xz/xz.1 | 31 ++++++++++++++++++++++---------
- 1 file changed, 22 insertions(+), 9 deletions(-)
-
-commit 620b32f5339f86710cb4435e01ecdac972ccac73
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2020-11-01 19:09:53 +0200
-
- xz: Use non-breaking spaces when intentionally using more than one space.
-
- This silences some style checker warnings. Seems that spaces
- in the beginning of a line don't need this treatment.
-
- Thanks to Bjarni Ingi Gislason.
-
- src/xz/xz.1 | 2 +-
- 1 file changed, 1 insertion(+), 1 deletion(-)
-
-commit cb1f34988c8a4130485091b2f8b641303d8f701b
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2020-11-01 18:49:37 +0200
-
- xz: Protect the ellipsis (...) on the man page with \&.
-
- This does it only when ... appears outside macro calls.
-
- Thanks to Bjarni Ingi Gislason.
-
- src/xz/xz.1 | 4 ++--
- 1 file changed, 2 insertions(+), 2 deletions(-)
-
-commit 5d224da3da87400f2fab313abbd7c710e7169ef9
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2020-11-01 18:41:21 +0200
-
- xz: Avoid the abbreviation "e.g." on the man page.
-
- A few are simply omitted, most are converted to "for example"
- and surrounded with commas. Sounds like that this is better
- style, for example, man-pages(7) recommends avoiding such
- abbreviations except in parenthesis.
-
- Thanks to Bjarni Ingi Gislason.
-
- src/xz/xz.1 | 66 ++++++++++++++++++++++++++++++-------------------------------
- 1 file changed, 33 insertions(+), 33 deletions(-)
-
-commit 90457dbe3e5717660f5b81f8c604860fc5137c0c
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2020-07-12 23:10:03 +0300
-
- xz man page: Change \- (minus) to \(en (en-dash) for a numeric range.
-
- Docs of ancient troff/nroff mention \(em (em-dash) but not \(en
- and \- was used for both minus and en-dash. I don't know how
- portable \(en is nowadays but it can be changed back if someone
- complains. At least GNU groff and OpenBSD's mandoc support it.
-
- Thanks to Bjarni Ingi Gislason for the patch.
-
- src/xz/xz.1 | 16 ++++++++--------
- 1 file changed, 8 insertions(+), 8 deletions(-)
-
-commit 352ba2d69af2136bc814aa1df1a132559d445616
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2020-07-12 20:46:24 +0300
-
- Windows: Fix building of resource files when config.h isn't used.
-
- Now CMake + Visual Studio works for building liblzma.dll.
-
- Thanks to Markus Rickert.
-
- src/common/common_w32res.rc | 4 +++-
- 1 file changed, 3 insertions(+), 1 deletion(-)
-
-commit a9e2a87f1d61dcf684d809bf08c8ebea93f8a480
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2020-04-06 19:31:50 +0300
-
- src/scripts/xzgrep.1: Filenames to xzgrep are optional.
-
- xzgrep --help was correct already.
-
- src/scripts/xzgrep.1 | 2 +-
- 1 file changed, 1 insertion(+), 1 deletion(-)
-
-commit a7ba275d9b855d186abb29eb7a4f4cb6d9ca6fe0
-Author: Bjarni Ingi Gislason <bjarniig@rhi.hi.is>
-Date: 2020-03-26 22:17:31 +0000
-
- src/script/xzgrep.1: Remove superfluous '.RB'
-
- Output is from: test-groff -b -e -mandoc -T utf8 -rF0 -t -w w -z
-
- [ "test-groff" is a developmental version of "groff" ]
-
- Input file is ./src/scripts/xzgrep.1
-
- <src/scripts/xzgrep.1>:20 (macro RB): only 1 argument, but more are expected
- <src/scripts/xzgrep.1>:23 (macro RB): only 1 argument, but more are expected
- <src/scripts/xzgrep.1>:26 (macro RB): only 1 argument, but more are expected
- <src/scripts/xzgrep.1>:29 (macro RB): only 1 argument, but more are expected
- <src/scripts/xzgrep.1>:32 (macro RB): only 1 argument, but more are expected
-
- "abc..." does not mean the same as "abc ...".
-
- The output from nroff and troff is unchanged except for the space
- between "file" and "...".
-
- Signed-off-by: Bjarni Ingi Gislason <bjarniig@rhi.hi.is>
-
- src/scripts/xzgrep.1 | 12 ++++++------
- 1 file changed, 6 insertions(+), 6 deletions(-)
-
-commit 133d498db0f4b14f066d192d64dbcade45deae6b
-Author: Bjarni Ingi Gislason <bjarniig@rhi.hi.is>
-Date: 2020-03-30 21:56:36 +0000
-
- xzgrep.1: Delete superfluous '.PP'
-
- Summary:
-
- mandoc -T lint xzgrep.1 :
- mandoc: xzgrep.1:79:2: WARNING: skipping paragraph macro: PP empty
-
- There is no change in the output of "nroff" and "troff".
-
- Signed-off-by: Bjarni Ingi Gislason <bjarniig@rhi.hi.is>
-
- src/scripts/xzgrep.1 | 1 -
- 1 file changed, 1 deletion(-)
-
-commit 057839ca982f886387b66746bffe749cb14fd8cd
-Author: Bjarni Ingi Gislason <bjarniig@rhi.hi.is>
-Date: 2020-03-26 21:16:18 +0000
-
- src/xz/xz.1: Correct misused two-fonts macros
-
- Output is from: test-groff -b -e -mandoc -T utf8 -rF0 -t -w w -z
-
- [ "test-groff" is a developmental version of "groff" ]
-
- Input file is ./src/xz/xz.1
-
- <src/xz/xz.1>:408 (macro BR): only 1 argument, but more are expected
- <src/xz/xz.1>:1009 (macro BR): only 1 argument, but more are expected
- <src/xz/xz.1>:1743 (macro BR): only 1 argument, but more are expected
- <src/xz/xz.1>:1920 (macro BR): only 1 argument, but more are expected
- <src/xz/xz.1>:2213 (macro BR): only 1 argument, but more are expected
-
- Output from nroff and troff is unchanged, except for a font change of a
- full stop (.).
-
- Signed-off-by: Bjarni Ingi Gislason <bjarniig@rhi.hi.is>
-
- src/xz/xz.1 | 10 +++++-----
- 1 file changed, 5 insertions(+), 5 deletions(-)
-
-commit b8e12f5ab4c9fd3cb09a4330b2861f6b979ababd
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2020-03-23 18:07:50 +0200
-
- Typo fixes from fossies.org.
-
- https://fossies.org/linux/misc/xz-5.2.5.tar.xz/codespell.html
-
- Makefile.am | 2 +-
- doc/examples/01_compress_easy.c | 2 +-
- src/liblzma/api/lzma/base.h | 2 +-
- src/liblzma/check/crc32_x86.S | 2 +-
- src/liblzma/common/index.c | 2 +-
- src/xz/xz.1 | 4 ++--
- 6 files changed, 7 insertions(+), 7 deletions(-)
-
-commit 869b9d1b4edd6df07f819d360d306251f8147353
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2020-03-17 16:24:28 +0200
-
- Update NEWS for 5.2.5.
-
- NEWS | 105 +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
- 1 file changed, 105 insertions(+)
-
-commit a048e3a92d238c65f050a765174d9c75417231d4
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2020-03-16 20:01:37 +0200
-
- README: Update outdated sections.
-
- README | 21 +++++++++++----------
- 1 file changed, 11 insertions(+), 10 deletions(-)
-
-commit 29aed815ad4f98f3e4d355faa76a244ecd8ce716
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2020-03-16 19:39:45 +0200
-
- README: Mention that man pages can be translated.
-
- README | 7 ++++---
- 1 file changed, 4 insertions(+), 3 deletions(-)
-
-commit 7fa7653940cc9dcfcbce2fbc5166ea343ad4e3c1
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2020-03-16 16:43:29 +0200
-
- Update INSTALL.generic from Automake 1.16.1.
-
- INSTALL.generic | 321 ++++++++++++++++++++++++++++----------------------------
- 1 file changed, 162 insertions(+), 159 deletions(-)
-
-commit 9bd317ef03ab9b3e6a927c27c2e9c4ac041182f0
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2020-03-15 15:27:22 +0200
-
- Update INSTALL for Windows and DOS and add preliminary info for z/OS.
-
- INSTALL | 51 +++++++++++++++++++++++++++++++++++++++++----------
- 1 file changed, 41 insertions(+), 10 deletions(-)
-
-commit a3148c0446dc7fa96363752df414d22539c9007b
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2020-03-15 15:26:20 +0200
-
- Build: Update m4/ax_pthread.m4 from Autoconf Archive (again).
-
- m4/ax_pthread.m4 | 219 +++++++++++++++++++++++++++++--------------------------
- 1 file changed, 117 insertions(+), 102 deletions(-)
-
-commit 7812002dd3ed319e42a14662a8531802cca8ca67
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2020-03-11 21:15:35 +0200
-
- xz: Never use thousand separators in DJGPP builds.
-
- DJGPP 2.05 added support for thousands separators but it's
- broken at least under WinXP with Finnish locale that uses
- a non-breaking space as the thousands separator. Workaround
- by disabling thousands separators for DJGPP builds.
-
- src/xz/util.c | 14 ++++++++++++--
- 1 file changed, 12 insertions(+), 2 deletions(-)
-
-commit 7c8f688bf7fccd65d396e0130cbf4ea5dff5c56f
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2020-03-11 19:38:08 +0200
-
- DOS: Update dos/Makefile for DJGPP 2.05.
-
- It doesn't need -fgnu89-inline like 2.04beta did.
-
- dos/Makefile | 4 +---
- 1 file changed, 1 insertion(+), 3 deletions(-)
-
-commit 319ca928d73de87940c54e30bffe69f9fa65efdf
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2020-03-11 19:36:07 +0200
-
- DOS: Update instructions in dos/INSTALL.txt.
-
- dos/INSTALL.txt | 59 ++++++++++++++++++++++++++++-----------------------------
- 1 file changed, 29 insertions(+), 30 deletions(-)
-
-commit cb6b227ce39932824812ccd8a0647bd968de27d2
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2020-03-11 17:58:51 +0200
-
- DOS: Update config.h.
-
- The added defines assume GCC >= 4.8.
-
- dos/config.h | 8 ++++++++
- 1 file changed, 8 insertions(+)
-
-commit 4572d53e16e87eee375bc5624de2fd59bb0ae9cd
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2020-03-02 13:54:33 +0200
-
- liblzma: Fix a comment and RC_SYMBOLS_MAX.
-
- The comment didn't match the value of RC_SYMBOLS_MAX and the value
- itself was slightly larger than actually needed. The only harm
- about this was that memory usage was a few bytes larger.
-
- src/liblzma/rangecoder/range_encoder.h | 4 ++--
- 1 file changed, 2 insertions(+), 2 deletions(-)
-
-commit 265daa873c0d871f5f23f9b56e133a6f20045a0a
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2020-02-27 20:58:52 +0200
-
- Build: Make CMake build fail if tuklib_cpucores or tuklib_physmem fails.
-
- CMakeLists.txt | 18 ++++++++++++++++++
- 1 file changed, 18 insertions(+)
-
-commit 7c8b904527cdbe61248c80edcc2e20d840c4fef9
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2020-02-27 20:24:27 +0200
-
- Build: Add support for --no-po4a option to autogen.sh.
-
- Normally, if po4a isn't available, autogen.sh will return
- with non-zero exit status. The option --no-po4a can be useful
- when one knows that po4a isn't available but wants autogen.sh
- to still return with zero exit status.
-
- autogen.sh | 11 ++++++++++-
- 1 file changed, 10 insertions(+), 1 deletion(-)
-
-commit 292a5c0f9c9b3a66f5a5c652dc46381836d4537f
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2020-02-25 21:35:14 +0200
-
- Update THANKS.
-
- THANKS | 1 +
- 1 file changed, 1 insertion(+)
-
-commit 474320e9908786ba2021035f9013191e16cde08a
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2020-02-25 20:42:31 +0200
-
- Build: Fix bugs in the CMake files.
-
- Seems that the phrase "add more quotes" from sh/bash scripting
- applies to CMake as well. E.g. passing an unquoted list ${FOO}
- to a function that expects one argument results in only the
- first element of the list being passed as an argument and
- the rest get ignored. Adding quotes helps ("${FOO}").
-
- list(INSERT ...) is weird. Inserting an empty string to an empty
- variable results in empty list, but inserting it to a non-empty
- variable does insert an empty element to the list.
-
- Since INSERT requires at least one element,
- "${CMAKE_THREAD_LIBS_INIT}" needs to be quoted in CMakeLists.txt.
- It might result in an empty element in the list. It seems to not
- matter as empty elements consistently get ignored in that variable.
- In fact, calling cmake_check_push_state() and cmake_check_pop_state()
- will strip the empty elements from CMAKE_REQUIRED_LIBRARIES!
-
- In addition to quoting fixes, this fixes checks for the cache
- variables in tuklib_cpucores.cmake and tuklib_physmem.cmake.
-
- Thanks to Martin Matuška for testing and reporting the problems.
- These fixes aren't tested yet but hopefully they soon will be.
-
- CMakeLists.txt | 52 ++++++++++++++++++++++-----------------------
- cmake/tuklib_common.cmake | 8 ++++---
- cmake/tuklib_cpucores.cmake | 30 ++++++++++++++------------
- cmake/tuklib_integer.cmake | 34 +++++++++++++++--------------
- cmake/tuklib_mbstr.cmake | 6 +++---
- cmake/tuklib_physmem.cmake | 29 +++++++++++++------------
- cmake/tuklib_progname.cmake | 4 ++--
- 7 files changed, 85 insertions(+), 78 deletions(-)
-
-commit 7e3493d40eac0c3fa3d5124097745a70e15c41f6
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2020-02-24 23:38:16 +0200
-
- Build: Add very limited experimental CMake support.
-
- This does *NOT* replace the Autotools-based build system in
- the foreseeable future. See the comment in the beginning
- of CMakeLists.txt.
-
- So far this has been tested only on GNU/Linux but I commit
- it anyway to make it easier for others to test. Since I
- haven't played much with CMake before, it's likely that
- there are things that have been done in a silly or wrong
- way and need to be fixed.
-
- CMakeLists.txt | 643 ++++++++++++++++++++++++++++++++++++++++++++
- cmake/tuklib_common.cmake | 47 ++++
- cmake/tuklib_cpucores.cmake | 173 ++++++++++++
- cmake/tuklib_integer.cmake | 100 +++++++
- cmake/tuklib_mbstr.cmake | 20 ++
- cmake/tuklib_physmem.cmake | 149 ++++++++++
- cmake/tuklib_progname.cmake | 19 ++
- 7 files changed, 1151 insertions(+)
-
-commit 21bd4701fca3e9002ce78bc135debca369ed8545
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2020-02-24 23:37:07 +0200
-
- Update m4/.gitignore.
-
- m4/.gitignore | 1 +
- 1 file changed, 1 insertion(+)
-
-commit e094d1d0f196a91ec703e8d0055948feef349ae8
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2020-02-24 23:29:35 +0200
-
- tuklib: Omit an unneeded <sys/types.h> from a tests.
-
- tuklib_cpucores.c and tuklib_physmem.c don't include <sys/types.h>
- even via other files in this package, so clearly that header isn't
- needed in the tests either (no one has reported build problems due
- to a missing header in a .c file).
-
- m4/tuklib_cpucores.m4 | 1 -
- m4/tuklib_physmem.m4 | 1 -
- 2 files changed, 2 deletions(-)
-
-commit b3ed19a55fe99a45bd77614e149d39d18498075c
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2020-02-24 23:01:00 +0200
-
- liblzma: Remove unneeded <sys/types.h> from fastpos_tablegen.c.
-
- This file only generates fastpos_table.c.
- It isn't built as a part of liblzma.
-
- src/liblzma/lzma/fastpos_tablegen.c | 1 -
- 1 file changed, 1 deletion(-)
-
-commit 7b8982b29179b3c586e0456dc9ecbd4f58dcea59
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2020-02-22 14:15:07 +0200
-
- Use defined(__GNUC__) before __GNUC__ in preprocessor lines.
-
- This should silence the equivalent of -Wundef in compilers that
- don't define __GNUC__.
-
- src/common/sysdefs.h | 3 ++-
- src/liblzma/api/lzma.h | 5 +++--
- 2 files changed, 5 insertions(+), 3 deletions(-)
-
-commit 43dfe04e6209c691cf4fbe3072d4ee91271748f1
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2020-02-21 17:40:02 +0200
-
- liblzma: Add more uses of lzma_memcmplen() to the normal mode of LZMA.
-
- This gives a tiny encoder speed improvement. This could have been done
- in 2014 after the commit 544aaa3d13554e8640f9caf7db717a96360ec0f6 but
- it was forgotten.
-
- src/liblzma/lzma/lzma_encoder_optimum_normal.c | 16 ++++++++++------
- 1 file changed, 10 insertions(+), 6 deletions(-)
-
-commit 59e6eb4840b9f52fa3a61544974017279b448216
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2020-02-21 17:01:15 +0200
-
- Build: Add visibility.m4 from gnulib.
-
- Appears that this file used to get included as a side effect of
- gettext. After the change to gettext version requirements this file
- no longer got copied to the package and so the build was broken.
-
- m4/.gitignore | 1 -
- m4/visibility.m4 | 77 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++
- 2 files changed, 77 insertions(+), 1 deletion(-)
-
-commit 7fe3ef2eaa53d439cec043727ea1998f4ff0e22a
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2020-02-21 16:10:44 +0200
-
- xz: Silence a warning when sig_atomic_t is long int.
-
- It can be true at least on z/OS.
-
- src/xz/signals.c | 2 +-
- 1 file changed, 1 insertion(+), 1 deletion(-)
-
-commit b0a2a77d10940c42b449d47a005bfc2e50ab5db8
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2020-02-21 15:59:26 +0200
-
- xz: Avoid unneeded access of a volatile variable.
-
- src/xz/signals.c | 2 +-
- 1 file changed, 1 insertion(+), 1 deletion(-)
-
-commit 524c2f12c762032b819757aeda8af7c47c4cabce
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2020-02-21 01:24:18 +0200
-
- tuklib_integer.m4: Optimize the check order.
-
- The __builtin byteswapping is the preferred one so check for it first.
-
- m4/tuklib_integer.m4 | 56 +++++++++++++++++++++++++++-------------------------
- 1 file changed, 29 insertions(+), 27 deletions(-)
-
-commit 57360bb4fd79b358b36d2877db26ac828d1fdfcb
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2020-02-20 18:54:04 +0200
-
- tuklib_exit: Add missing header.
-
- strerror() needs <string.h> which happened to be included via
- tuklib_common.h -> tuklib_config.h -> sysdefs.h if HAVE_CONFIG_H
- was defined. This wasn't tested without config.h before so it
- had worked fine.
-
- src/common/tuklib_exit.c | 1 +
- 1 file changed, 1 insertion(+)
-
-commit fddd31175e74a538997a939d930462fde17d2dd4
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2020-02-18 19:12:35 +0200
-
- Revert the previous commit and add a comment.
-
- The previous commit broke crc32_tablegen.c.
-
- If the whole package is built without config.h (with defines
- set on the compiler command line) this should still work fine
- as long as these headers conform to C99 well enough.
-
- src/common/tuklib_config.h | 17 ++++++++++-------
- 1 file changed, 10 insertions(+), 7 deletions(-)
-
-commit 4e4e9fbb7e66d45319525ac224bff48fbdd0cf6e
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2020-02-17 23:37:20 +0200
-
- Do not check for HAVE_CONFIG_H in tuklib_config.h.
-
- In XZ Utils sysdefs.h takes care of it and the required headers.
-
- src/common/tuklib_config.h | 15 +++++++--------
- 1 file changed, 7 insertions(+), 8 deletions(-)
-
-commit 2d4cef954feba82073951358466a1d614141cf33
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2020-02-16 11:18:28 +0200
-
- sysdefs.h: Omit the conditionals around string.h and limits.h.
-
- string.h is used unconditionally elsewhere in the project and
- configure has always stopped if limits.h is missing, so these
- headers must have been always available even on the weirdest
- systems.
-
- src/common/sysdefs.h | 8 ++------
- 1 file changed, 2 insertions(+), 6 deletions(-)
-
-commit feb9c1969bc3eb33d4ecb72cfa897f92dae84939
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2020-02-15 15:07:11 +0200
-
- Build: Bump Autoconf and Libtool version requirements.
-
- There is no specific reason for this other than blocking
- the most ancient versions. These are still old:
-
- Autoconf 2.69 (2012)
- Automake 1.12 (2012)
- gettext 0.19.6 (2015)
- Libtool 2.4 (2010)
-
- configure.ac | 4 ++--
- 1 file changed, 2 insertions(+), 2 deletions(-)
-
-commit 3d576cf92158d62790017ad7f2dd6dc1dd6b42bb
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2020-02-15 03:08:32 +0200
-
- Build: Use AM_GNU_GETTEXT_REQUIRE_VERSION and require 0.19.6.
-
- This bumps the version requirement from 0.19 (from 2014) to
- 0.19.6 (2015).
-
- Using only the old AM_GNU_GETTEXT_VERSION results in old
- gettext infrastructure being placed in the package. By using
- both macros we get the latest gettext files while the other
- programs in the Autotools family can still see the old macro.
-
- configure.ac | 6 +++++-
- 1 file changed, 5 insertions(+), 1 deletion(-)
-
-commit fa792b8befaf7cb3960b655e0a9410da866d756f
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2020-02-14 20:42:06 +0200
-
- Translations: Add German translation of the man pages.
-
- Thanks to Mario Blättermann.
-
- po4a/de.po | 5532 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++
- po4a/po4a.conf | 2 +-
- 2 files changed, 5533 insertions(+), 1 deletion(-)
-
-commit 6f7211b6bb47a895b47f533282dba9ee9a1b0c8b
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2020-02-07 15:32:21 +0200
-
- Build: Add support for translated man pages using po4a.
-
- The dependency on po4a is optional. It's never required to install
- the translated man pages when xz is built from a release tarball.
- If po4a is missing when building from xz.git, the translated man
- pages won't be generated but otherwise the build will work normally.
-
- The translations are only updated automatically by autogen.sh and
- by "make mydist". This makes it easy to keep po4a as an optional
- dependency and ensures that I won't forget to put updated
- translations to a release tarball.
-
- The translated man pages aren't installed if --disable-nls is used.
-
- The installation of translated man pages abuses Automake internals
- by calling "install-man" with redefined dist_man_MANS and man_MANS.
- This makes the hairy script code slightly less hairy. If it breaks
- some day, this code needs to be fixed; don't blame Automake developers.
-
- Also, this adds more quotes to the existing shell script code in
- the Makefile.am "-hook"s.
-
- Makefile.am | 4 ++++
- autogen.sh | 8 ++++---
- po4a/.gitignore | 2 ++
- po4a/po4a.conf | 14 +++++++++++
- po4a/update-po | 45 ++++++++++++++++++++++++++++++++++
- src/scripts/Makefile.am | 64 +++++++++++++++++++++++++++++++++++++------------
- src/xz/Makefile.am | 50 +++++++++++++++++++++++++++-----------
- src/xzdec/Makefile.am | 55 ++++++++++++++++++++++++++++++++----------
- 8 files changed, 197 insertions(+), 45 deletions(-)
-
-commit 426f9e5819ff7710a5ff573a96c02940be65d52f
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2020-02-06 17:31:38 +0200
-
- Update THANKS.
-
- THANKS | 1 +
- 1 file changed, 1 insertion(+)
-
-commit e3a4481d020e4de89efa037f335cf50f3ca55592
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2020-02-05 22:35:06 +0200
-
- Update tests/.gitignore.
-
- .gitignore | 4 ++++
- 1 file changed, 4 insertions(+)
-
-commit 07208de92f2d5bca764f6d0ebe9d9866051dc4ef
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2020-02-05 22:28:51 +0200
-
- Update m4/.gitignore.
-
- m4/.gitignore | 1 +
- 1 file changed, 1 insertion(+)
-
-commit c91fbf223db46c3b3cb9df769863a1a60cd9c908
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2020-02-05 20:47:38 +0200
-
- Update THANKS.
-
- THANKS | 1 +
- 1 file changed, 1 insertion(+)
-
-commit 15a133b6d1a3eab4faf6eb52a71fdc56bd65846f
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2020-02-05 20:40:14 +0200
-
- xz: Make it a fatal error if enabling the sandbox fails.
-
- Perhaps it's too drastic but on the other hand it will let me
- learn about possible problems if people report the errors.
- This won't be backported to the v5.2 branch.
-
- src/xz/file_io.c | 2 +-
- 1 file changed, 1 insertion(+), 1 deletion(-)
-
-commit af0fb386ef55db66654ae39e2deec6e04190c4ff
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2020-02-05 20:33:50 +0200
-
- xz: Comment out annoying sandboxing messages.
-
- src/xz/file_io.c | 10 +++++++---
- 1 file changed, 7 insertions(+), 3 deletions(-)
-
-commit 986d8c9b52b824474088e5bb3b6940651660f0e2
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2020-02-05 19:33:37 +0200
-
- Build: Workaround a POSIX shell detection problem on Solaris.
-
- I don't know if the problem is in gnulib's gl_POSIX_SHELL macro
- or if xzgrep does something that isn't in POSIX. The workaround
- adds a special case for Solaris: if /usr/xpg4/bin/sh exists and
- gl_cv_posix_shell wasn't overriden on the configure command line,
- use that shell for xzgrep and other scripts. That shell is known
- to work and exists on most Solaris systems.
-
- configure.ac | 10 ++++++++++
- 1 file changed, 10 insertions(+)
-
-commit 6629ed929cc7d45a11e385f357ab58ec15e7e4ad
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2020-02-03 22:03:50 +0200
-
- Build: Update m4/ax_pthread.m4 from Autoconf Archive.
-
- m4/ax_pthread.m4 | 398 ++++++++++++++++++++++++++++++++++++++-----------------
- 1 file changed, 279 insertions(+), 119 deletions(-)
-
-commit 353970510895f6a80adfe60cf71b70a95adfa8bc
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2020-02-01 19:56:18 +0200
-
- xz: Limit --memlimit-compress to at most 4020 MiB for 32-bit xz.
-
- See the code comment for reasoning. It's far from perfect but
- hopefully good enough for certain cases while hopefully doing
- nothing bad in other situations.
-
- At presets -5 ... -9, 4020 MiB vs. 4096 MiB makes no difference
- on how xz scales down the number of threads.
-
- The limit has to be a few MiB below 4096 MiB because otherwise
- things like "xz --lzma2=dict=500MiB" won't scale down the dict
- size enough and xz cannot allocate enough memory. With
- "ulimit -v $((4096 * 1024))" on x86-64, the limit in xz had
- to be no more than 4085 MiB. Some safety margin is good though.
-
- This is hack but it should be useful when running 32-bit xz on
- a 64-bit kernel that gives full 4 GiB address space to xz.
- Hopefully this is enough to solve this:
-
- https://bugzilla.redhat.com/show_bug.cgi?id=1196786
-
- FreeBSD has a patch that limits the result in tuklib_physmem()
- to SIZE_MAX on 32-bit systems. While I think it's not the way
- to do it, the results on --memlimit-compress have been good. This
- commit should achieve practically identical results for compression
- while leaving decompression and tuklib_physmem() and thus
- lzma_physmem() unaffected.
-
- src/xz/hardware.c | 32 +++++++++++++++++++++++++++++++-
- src/xz/xz.1 | 21 ++++++++++++++++++++-
- 2 files changed, 51 insertions(+), 2 deletions(-)
-
-commit ba76d67585f88677af9f48b48e7bdc3bb7687def
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2020-01-26 20:53:25 +0200
-
- xz: Set the --flush-timeout deadline when the first input byte arrives.
-
- xz --flush-timeout=2000, old version:
-
- 1. xz is started. The next flush will happen after two seconds.
- 2. No input for one second.
- 3. A burst of a few kilobytes of input.
- 4. No input for one second.
- 5. Two seconds have passed and flushing starts.
-
- The first second counted towards the flush-timeout even though
- there was no pending data. This can cause flushing to occur more
- often than needed.
-
- xz --flush-timeout=2000, after this commit:
-
- 1. xz is started.
- 2. No input for one second.
- 3. A burst of a few kilobytes of input. The next flush will
- happen after two seconds counted from the time when the
- first bytes of the burst were read.
- 4. No input for one second.
- 5. No input for another second.
- 6. Two seconds have passed and flushing starts.
-
- src/xz/coder.c | 6 +-----
- src/xz/file_io.c | 6 +++++-
- src/xz/mytime.c | 1 -
- 3 files changed, 6 insertions(+), 7 deletions(-)
-
-commit fd47fd62bbb1bfd13ab63869137971d8b390025f
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2020-01-26 20:19:19 +0200
-
- xz: Move flush_needed from mytime.h to file_pair struct in file_io.h.
-
- src/xz/coder.c | 3 ++-
- src/xz/file_io.c | 3 ++-
- src/xz/file_io.h | 3 +++
- src/xz/mytime.c | 3 ---
- src/xz/mytime.h | 4 ----
- 5 files changed, 7 insertions(+), 9 deletions(-)
-
-commit 815035681063d5774d3640fc20b8ede783dd574e
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2020-01-26 14:49:22 +0200
-
- xz: coder.c: Make writing output a separate function.
-
- The same code sequence repeats so it's nicer as a separate function.
- Note that in one case there was no test for opt_mode != MODE_TEST,
- but that was only because that condition would always be true, so
- this commit doesn't change the behavior there.
-
- src/xz/coder.c | 30 +++++++++++++++++-------------
- 1 file changed, 17 insertions(+), 13 deletions(-)
-
-commit 5a49e081a098455bcdbd95cefb90e9b18780fe58
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2020-01-26 14:13:42 +0200
-
- xz: Fix semi-busy-waiting in xz --flush-timeout.
-
- When input blocked, xz --flush-timeout=1 would wake up every
- millisecond and initiate flushing which would have nothing to
- flush and thus would just waste CPU time. The fix disables the
- timeout when no input has been seen since the previous flush.
-
- src/xz/coder.c | 4 ++++
- src/xz/file_io.c | 15 +++++++++++----
- src/xz/file_io.h | 4 ++++
- 3 files changed, 19 insertions(+), 4 deletions(-)
-
-commit dcca70fe9fa3c4bec56cf9c79e966166c9a9cf6a
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2020-01-26 13:47:31 +0200
-
- xz: Refactor io_read() a bit.
-
- src/xz/file_io.c | 17 ++++++++---------
- 1 file changed, 8 insertions(+), 9 deletions(-)
-
-commit 4ae9ab70cd3214395756435d13d8d000368ca2cb
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2020-01-26 13:37:08 +0200
-
- xz: Update a comment in file_io.h.
-
- src/xz/file_io.h | 5 ++++-
- 1 file changed, 4 insertions(+), 1 deletion(-)
-
-commit 3333ba4a6795a55cf0375329ba08152bd7fcbd46
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2020-01-26 13:27:51 +0200
-
- xz: Move the setting of flush_needed in file_io.c to a nicer location.
-
- src/xz/file_io.c | 6 ++----
- 1 file changed, 2 insertions(+), 4 deletions(-)
-
-commit cf2df0f05ac98c1158c6e48145900b773223605d
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2020-01-19 21:54:33 +0200
-
- Use $(LIB_FUZZING_ENGINE) in tests/ossfuzz/Makefile.
-
- https://github.com/google/oss-fuzz/pull/3219#issuecomment-573751048
-
- Thanks to Bhargava Shastry for sending the patch.
-
- tests/ossfuzz/Makefile | 2 +-
- 1 file changed, 1 insertion(+), 1 deletion(-)
-
-commit 7136f1735c60ac6967c4b8e277fcde53d485234f
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2019-12-31 00:41:28 +0200
-
- Rename unaligned_read32ne to read32ne, and similarly for the others.
-
- src/common/tuklib_integer.h | 64 +++++++++++++++----------------
- src/liblzma/common/alone_encoder.c | 2 +-
- src/liblzma/common/block_header_decoder.c | 2 +-
- src/liblzma/common/block_header_encoder.c | 2 +-
- src/liblzma/common/memcmplen.h | 9 ++---
- src/liblzma/common/stream_flags_decoder.c | 6 +--
- src/liblzma/common/stream_flags_encoder.c | 8 ++--
- src/liblzma/lz/lz_encoder_hash.h | 2 +-
- src/liblzma/lzma/lzma_decoder.c | 2 +-
- src/liblzma/lzma/lzma_encoder.c | 2 +-
- src/liblzma/lzma/lzma_encoder_private.h | 3 +-
- src/liblzma/simple/simple_decoder.c | 2 +-
- src/liblzma/simple/simple_encoder.c | 2 +-
- tests/test_block_header.c | 4 +-
- tests/test_stream_flags.c | 6 +--
- 15 files changed, 54 insertions(+), 62 deletions(-)
-
-commit 5e78fcbf2eb21936022c9c5c3625d4da76f4b241
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2019-12-31 00:29:48 +0200
-
- Rename read32ne to aligned_read32ne, and similarly for the others.
-
- Using the aligned methods requires more care to ensure that
- the address really is aligned, so it's nicer if the aligned
- methods are prefixed. The next commit will remove the unaligned_
- prefix from the unaligned methods which in liblzma are used in
- more places than the aligned ones.
-
- src/common/tuklib_integer.h | 56 +++++++++++++++++++++---------------------
- src/liblzma/check/crc32_fast.c | 4 +--
- src/liblzma/check/crc64_fast.c | 4 +--
- 3 files changed, 32 insertions(+), 32 deletions(-)
-
-commit 77bc5bc6dd67056cfd5888520ac930cfc57b4516
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2019-12-31 00:18:24 +0200
-
- Revise tuklib_integer.h and .m4.
-
- Add a configure option --enable-unsafe-type-punning to get the
- old non-conforming memory access methods. It can be useful with
- old compilers or in some other less typical situations but
- shouldn't normally be used.
-
- Omit the packed struct trick for unaligned access. While it's
- best in some cases, this is simpler. If the memcpy trick doesn't
- work, one can request unsafe type punning from configure.
-
- Because CRC32/CRC64 code needs fast aligned reads, if no very
- safe way to do it is found, type punning is used as a fallback.
- This sucks but since it currently works in practice, it seems to
- be the least bad option. It's never needed with GCC >= 4.7 or
- Clang >= 3.6 since these support __builtin_assume_aligned and
- thus fast aligned access can be done with the memcpy trick.
-
- Other things:
- - Support GCC/Clang __builtin_bswapXX
- - Cleaner bswap fallback macros
- - Minor cleanups
-
- m4/tuklib_integer.m4 | 46 ++++-
- src/common/tuklib_integer.h | 488 ++++++++++++++++++++++++--------------------
- 2 files changed, 316 insertions(+), 218 deletions(-)
-
-commit 8b72950a6b2e2a36c2d8fdc8857564b57191b088
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2019-12-29 22:51:58 +0200
-
- Tests: Hopefully fix test_check.c to work on EBCDIC systems.
-
- Thanks to Daniel Richard G.
-
- tests/test_check.c | 9 +++++++--
- 1 file changed, 7 insertions(+), 2 deletions(-)
-
-commit 43ce4ea7c762238d3df9717b34126d3e0d7cd51c
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2019-09-24 23:02:40 +0300
-
- Scripts: Put /usr/xpg4/bin to the beginning of PATH on Solaris.
-
- This adds a configure option --enable-path-for-scripts=PREFIX
- which defaults to empty except on Solaris it is /usr/xpg4/bin
- to make POSIX grep and others available. The Solaris case had
- been documented in INSTALL with a manual fix but it's better
- to do this automatically since it is needed on most Solaris
- systems anyway.
-
- Thanks to Daniel Richard G.
-
- INSTALL | 43 +++++++++++++++++++++++++++++++++++--------
- configure.ac | 26 ++++++++++++++++++++++++++
- src/scripts/xzdiff.in | 1 +
- src/scripts/xzgrep.in | 1 +
- src/scripts/xzless.in | 1 +
- src/scripts/xzmore.in | 1 +
- 6 files changed, 65 insertions(+), 8 deletions(-)
-
-commit 6a89e656ebedd53a10cd1a063a32a9e4ade0da1f
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2019-07-12 18:57:43 +0300
-
- Fix comment typos in tuklib_mbstr* files.
-
- src/common/tuklib_mbstr.h | 2 +-
- src/common/tuklib_mbstr_fw.c | 2 +-
- src/common/tuklib_mbstr_width.c | 2 +-
- 3 files changed, 3 insertions(+), 3 deletions(-)
-
-commit ac0b4212656a48ef0c187c0c941d40ac9489ae36
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2019-07-12 18:30:46 +0300
-
- Add missing include to tuklib_mbstr_width.c.
-
- It didn't matter in XZ Utils because sysdefs.h
- includes string.h anyway.
-
- src/common/tuklib_mbstr_width.c | 1 +
- 1 file changed, 1 insertion(+)
-
-commit 72a443281fb0b91aebf8cdff2ab1f7c07b081240
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2019-07-12 18:10:57 +0300
-
- Update tuklib base headers to include stdbool.h.
-
- src/common/tuklib_common.h | 2 +-
- src/common/tuklib_config.h | 1 +
- 2 files changed, 2 insertions(+), 1 deletion(-)
-
-commit de1f47b2b40e960b7bc3acba754f66dd19705921
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2019-06-28 00:54:31 +0300
-
- xz: Automatically align the strings in --info-memory.
-
- This makes it easier to translate the strings.
-
- Also, the string for amount of RAM was shortened.
-
- src/xz/hardware.c | 45 ++++++++++++++++++++++++++++++++++-----------
- 1 file changed, 34 insertions(+), 11 deletions(-)
-
-commit 8ce679125dbd0e2058d8f886e738d7f19a45cab5
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2019-06-25 23:15:21 +0300
-
- liblzma: Fix a buggy comment.
-
- src/liblzma/lz/lz_encoder_mf.c | 2 +-
- 1 file changed, 1 insertion(+), 1 deletion(-)
-
-commit fc77929e92e869f6869bf88931066103fd75f376
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2019-06-25 00:16:06 +0300
-
- configure.ac: Fix a typo in a comment.
-
- configure.ac | 2 +-
- 1 file changed, 1 insertion(+), 1 deletion(-)
-
-commit e873902641794210ad7db59743f98e3e1cd6139f
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2019-06-25 00:08:13 +0300
-
- Tests: Silence warnings from clang -Wassign-enum.
-
- Also changed 999 to 99 so it fits even if lzma_check happened
- to be 8 bits wide.
-
- tests/test_block_header.c | 3 ++-
- tests/test_stream_flags.c | 2 +-
- 2 files changed, 3 insertions(+), 2 deletions(-)
-
-commit d499e467d99efeaae688564eedc4548837c1416a
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2019-06-24 23:52:17 +0300
-
- liblzma: Add a comment.
-
- src/liblzma/common/stream_encoder_mt.c | 2 +-
- 1 file changed, 1 insertion(+), 1 deletion(-)
-
-commit a12b13c5f0d54c684fa8446f93fdac08ab2a716b
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2019-06-24 23:45:21 +0300
-
- liblzma: Silence clang -Wmissing-variable-declarations.
-
- src/liblzma/check/crc32_table.c | 3 +++
- src/liblzma/check/crc64_table.c | 3 +++
- 2 files changed, 6 insertions(+)
-
-commit 1b4675cebf7471f7cc9b7072c950e3de97147063
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2019-06-24 23:25:41 +0300
-
- Add LZMA_RET_INTERNAL1..8 to lzma_ret and use one for LZMA_TIMED_OUT.
-
- LZMA_TIMED_OUT is *internally* used as a value for lzma_ret
- enumeration. Previously it was #defined to 32 and cast to lzma_ret.
- That way it wasn't visible in the public API, but this was hackish.
-
- Now the public API has eight LZMA_RET_INTERNALx members and
- LZMA_TIMED_OUT is #defined to LZMA_RET_INTERNAL1. This way
- the code is cleaner overall although the public API has a few
- extra mysterious enum members.
-
- src/liblzma/api/lzma/base.h | 15 ++++++++++++++-
- src/liblzma/common/common.c | 4 +---
- src/liblzma/common/common.h | 5 ++---
- src/xz/message.c | 8 ++++++++
- 4 files changed, 25 insertions(+), 7 deletions(-)
-
-commit 159c43875eb25deea626ed651274464bae3e32ef
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2019-06-24 22:57:43 +0300
-
- xz: Silence a warning from clang -Wsign-conversion in main.c.
-
- src/xz/main.c | 2 +-
- 1 file changed, 1 insertion(+), 1 deletion(-)
-
-commit 466cfcd3e52f6750ce28a635997f3dd84fb18515
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2019-06-24 22:52:20 +0300
-
- xz: Make "headings" static in list.c.
-
- Caught by clang -Wmissing-variable-declarations.
-
- src/xz/list.c | 2 +-
- 1 file changed, 1 insertion(+), 1 deletion(-)
-
-commit 608517b9b76c41fac6613dbda1193d6f41338e19
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2019-06-24 22:47:39 +0300
-
- liblzma: Remove incorrect uses of lzma_attribute((__unused__)).
-
- Caught by clang -Wused-but-marked-unused.
-
- src/liblzma/common/alone_decoder.c | 3 +--
- src/liblzma/common/alone_encoder.c | 3 +--
- src/liblzma/lz/lz_decoder.c | 3 +--
- 3 files changed, 3 insertions(+), 6 deletions(-)
-
-commit c2d2ab6a9d41a2b55d047c5b710aacf80d219255
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2019-06-24 20:53:55 +0300
-
- Tests: Silence a warning from -Wsign-conversion.
-
- tests/create_compress_files.c | 8 ++++----
- 1 file changed, 4 insertions(+), 4 deletions(-)
-
-commit 2402f7873dcae719d0ebddd23bb579074519ac52
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2019-06-24 20:45:49 +0300
-
- xz: Fix an integer overflow with 32-bit off_t.
-
- Or any off_t which isn't very big (like signed 64 bit integer
- that most system have). A small off_t could overflow if the
- file being decompressed had long enough run of zero bytes,
- which would result in corrupt output.
-
- src/xz/file_io.c | 11 +++++++++--
- 1 file changed, 9 insertions(+), 2 deletions(-)
-
-commit 4fd3a8dd0b60f029e1c66a0ee634f9e9fda3caa9
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2019-06-24 01:24:17 +0300
-
- xz: Cleanup io_seek_src() a bit.
-
- lseek() returns -1 on error and checking for -1 is nicer.
-
- src/xz/file_io.c | 4 +---
- 1 file changed, 1 insertion(+), 3 deletions(-)
-
-commit dfda7cf6afa486e10df035327d68753896dfb48a
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2019-06-24 00:57:23 +0300
-
- Tests: Remove a duplicate branch from tests/tests.h.
-
- The duplication was introduced about eleven years ago and
- should have been cleaned up back then already.
-
- This was caught by -Wduplicated-branches.
-
- tests/tests.h | 9 ++-------
- 1 file changed, 2 insertions(+), 7 deletions(-)
-
-commit 1d4a904d8fb634bd5a04f7fbdd17d3739f3d8866
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2019-06-24 00:40:45 +0300
-
- xz: Change io_seek_src and io_pread arguments from off_t to uint64_t.
-
- This helps fixing warnings from -Wsign-conversion and makes the
- code look better too.
-
- src/xz/file_io.c | 16 ++++++++++++----
- src/xz/file_io.h | 4 ++--
- src/xz/list.c | 9 ++++-----
- 3 files changed, 18 insertions(+), 11 deletions(-)
-
-commit 50120deb0159fcb53ee1a6caffb2bb81a1ecd990
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2019-06-24 00:12:38 +0300
-
- xz: list.c: Fix some warnings from -Wsign-conversion.
-
- src/xz/list.c | 7 ++++---
- 1 file changed, 4 insertions(+), 3 deletions(-)
-
-commit d0a78751eb54fb1572002746c533936a118e4e42
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2019-06-23 23:22:45 +0300
-
- tuklib_mbstr_width: Fix a warning from -Wsign-conversion.
-
- src/common/tuklib_mbstr_width.c | 2 +-
- 1 file changed, 1 insertion(+), 1 deletion(-)
-
-commit 7883d73530b4b2a701ddd7d50c35676cbc158039
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2019-06-23 23:19:34 +0300
-
- xz: Fix some of the warnings from -Wsign-conversion.
-
- src/xz/args.c | 4 ++--
- src/xz/coder.c | 4 ++--
- src/xz/file_io.c | 5 +++--
- src/xz/message.c | 4 ++--
- src/xz/mytime.c | 4 ++--
- src/xz/options.c | 2 +-
- src/xz/util.c | 4 ++--
- 7 files changed, 14 insertions(+), 13 deletions(-)
-
-commit c2b994fe3d35e9e575c28869a2f7f534f2495d05
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2019-06-23 22:27:45 +0300
-
- tuklib_cpucores: Silence warnings from -Wsign-conversion.
-
- src/common/tuklib_cpucores.c | 10 +++++-----
- 1 file changed, 5 insertions(+), 5 deletions(-)
-
-commit 07c4fa9e1a195e0543f271380c8de22a3ab145ff
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2019-06-23 21:40:47 +0300
-
- xzdec: Fix warnings from -Wsign-conversion.
-
- src/xzdec/xzdec.c | 2 +-
- 1 file changed, 1 insertion(+), 1 deletion(-)
-
-commit dfac2c9a1d7d4a2b8a5d7c9c6d567dee48318bcf
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2019-06-23 21:38:56 +0300
-
- liblzma: Fix warnings from -Wsign-conversion.
-
- Also, more parentheses were added to the literal_subcoder
- macro in lzma_comon.h (better style but no functional change
- in the current usage).
-
- src/liblzma/common/block_header_decoder.c | 2 +-
- src/liblzma/delta/delta_decoder.c | 2 +-
- src/liblzma/lzma/fastpos.h | 2 +-
- src/liblzma/lzma/lzma2_decoder.c | 8 ++++----
- src/liblzma/lzma/lzma_common.h | 3 ++-
- src/liblzma/lzma/lzma_decoder.c | 16 ++++++++--------
- src/liblzma/simple/arm.c | 6 +++---
- src/liblzma/simple/armthumb.c | 8 ++++----
- src/liblzma/simple/ia64.c | 2 +-
- src/liblzma/simple/powerpc.c | 9 +++++----
- src/liblzma/simple/x86.c | 2 +-
- 11 files changed, 31 insertions(+), 29 deletions(-)
-
-commit 41838dcc26375f6aa393a63e4d81e2f4d223de07
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2019-06-23 19:33:55 +0300
-
- tuklib_integer: Silence warnings from -Wsign-conversion.
-
- src/common/tuklib_integer.h | 6 +++---
- 1 file changed, 3 insertions(+), 3 deletions(-)
-
-commit 3ce05d235f736d392347a05086b8033416874b87
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2019-06-20 19:40:30 +0300
-
- tuklib_integer: Fix usage of conv macros.
-
- Use a temporary variable instead of e.g.
- conv32le(unaligned_read32ne(buf)) because the macro can
- evaluate its argument multiple times.
-
- src/common/tuklib_integer.h | 12 ++++++++----
- 1 file changed, 8 insertions(+), 4 deletions(-)
-
-commit b525b0c0ef40cd89b69294c9b8d57f4a8db58e1f
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2019-06-03 20:44:19 +0300
-
- Update THANKS.
-
- THANKS | 1 +
- 1 file changed, 1 insertion(+)
-
-commit 039a168e8cf201d5104a25ec41f0cf25eda6cc53
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2019-06-03 20:41:54 +0300
-
- liblzma: Fix comments.
-
- Thanks to Bruce Stark.
-
- src/liblzma/common/alone_encoder.c | 4 ++--
- src/liblzma/common/block_util.c | 2 +-
- src/liblzma/common/common.c | 2 +-
- src/liblzma/common/filter_common.h | 2 +-
- src/liblzma/common/filter_decoder.h | 2 +-
- src/liblzma/common/filter_flags_encoder.c | 2 +-
- 6 files changed, 7 insertions(+), 7 deletions(-)
-
-commit c460f6defebc5a81bbca90adc2476154ca244f69
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2019-06-02 00:50:59 +0300
-
- liblzma: Fix one more unaligned read to use unaligned_read16ne().
-
- src/liblzma/lz/lz_encoder_hash.h | 2 +-
- 1 file changed, 1 insertion(+), 1 deletion(-)
-
-commit c81d77c537f0b8c8672868e1dc6cf7290ce4a25b
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2019-06-01 21:41:55 +0300
-
- Update THANKS.
-
- THANKS | 1 +
- 1 file changed, 1 insertion(+)
-
-commit 386394fc9fcde2615391f804eaa466749f96f4ef
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2019-06-01 21:36:13 +0300
-
- liblzma: memcmplen: Use ctz32() from tuklib_integer.h.
-
- The same compiler-specific #ifdefs are already in tuklib_integer.h
-
- src/liblzma/common/memcmplen.h | 10 +---------
- 1 file changed, 1 insertion(+), 9 deletions(-)
-
-commit 264ab971ce2994baac41b1579c9c35aba7743fc8
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2019-06-01 21:30:03 +0300
-
- tuklib_integer: Cleanup MSVC-specific code.
-
- src/common/tuklib_integer.h | 20 +++++++++-----------
- 1 file changed, 9 insertions(+), 11 deletions(-)
-
-commit 33773c6f2a8711d4aa6656795db52c59a28580ec
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2019-06-01 19:01:21 +0300
-
- liblzma: Use unaligned_readXXne functions instead of type punning.
-
- Now gcc -fsanitize=undefined should be clean.
-
- Thanks to Jeffrey Walton.
-
- src/liblzma/common/memcmplen.h | 12 ++++++------
- src/liblzma/lzma/lzma_encoder_private.h | 2 +-
- 2 files changed, 7 insertions(+), 7 deletions(-)
-
-commit e5f13a66567b1987e0aae42c6fdcd277bb5810ba
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2019-06-01 18:46:54 +0300
-
- tuklib_integer: Autodetect support for unaligned access on ARM.
-
- The result is used as the default for --enable-unaligned-access.
- The test should work with GCC and Clang.
-
- m4/tuklib_integer.m4 | 11 +++++++++++
- 1 file changed, 11 insertions(+)
-
-commit 3bc112c2d38d5f348bce7bc2422286b1692c7490
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2019-06-01 18:41:16 +0300
-
- tuklib_integer: Improve unaligned memory access.
-
- Now memcpy() or GNU C packed structs for unaligned access instead
- of type punning. See the comment in this commit for details.
-
- Avoiding type punning with unaligned access is needed to
- silence gcc -fsanitize=undefined.
-
- New functions: unaliged_readXXne and unaligned_writeXXne where
- XX is 16, 32, or 64.
-
- src/common/tuklib_integer.h | 180 +++++++++++++++++++++++++++++++++++++++++---
- 1 file changed, 168 insertions(+), 12 deletions(-)
-
-commit 2a22de439ec63da1927b640eda309296a1e8dce5
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2019-05-13 20:05:17 +0300
-
- liblzma: Avoid memcpy(NULL, foo, 0) because it is undefined behavior.
-
- I should have always known this but I didn't. Here is an example
- as a reminder to myself:
-
- int mycopy(void *dest, void *src, size_t n)
- {
- memcpy(dest, src, n);
- return dest == NULL;
- }
-
- In the example, a compiler may assume that dest != NULL because
- passing NULL to memcpy() would be undefined behavior. Testing
- with GCC 8.2.1, mycopy(NULL, NULL, 0) returns 1 with -O0 and -O1.
- With -O2 the return value is 0 because the compiler infers that
- dest cannot be NULL because it was already used with memcpy()
- and thus the test for NULL gets optimized out.
-
- In liblzma, if a null-pointer was passed to memcpy(), there were
- no checks for NULL *after* the memcpy() call, so I cautiously
- suspect that it shouldn't have caused bad behavior in practice,
- but it's hard to be sure, and the problematic cases had to be
- fixed anyway.
-
- Thanks to Jeffrey Walton.
-
- src/liblzma/common/common.c | 6 +++++-
- src/liblzma/lz/lz_decoder.c | 12 +++++++++---
- src/liblzma/simple/simple_coder.c | 10 +++++++++-
- 3 files changed, 23 insertions(+), 5 deletions(-)
-
-commit d3fc850cfedc058247d9e334ce59bbc8f2286d8a
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2019-05-11 20:56:08 +0300
-
- Update THANKS.
-
- THANKS | 1 +
- 1 file changed, 1 insertion(+)
-
-commit 4adb8288ab61d5f14e212007b8742df0710baf73
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2019-05-11 20:54:12 +0300
-
- xz: Update xz man page date.
-
- src/xz/xz.1 | 2 +-
- 1 file changed, 1 insertion(+), 1 deletion(-)
-
-commit 2fb0ddaa557ce86e38fe06439930fa8665f092fd
-Author: Antoine Cœur <antoine.coeur@ef.com>
-Date: 2019-05-08 13:30:57 +0800
-
- spelling
-
- Doxyfile.in | 2 +-
- NEWS | 2 +-
- doc/examples/11_file_info.c | 2 +-
- src/liblzma/api/lzma/block.h | 2 +-
- src/liblzma/api/lzma/hardware.h | 2 +-
- src/liblzma/api/lzma/lzma12.h | 2 +-
- src/liblzma/api/lzma/vli.h | 2 +-
- src/liblzma/common/file_info.c | 4 ++--
- src/liblzma/common/hardware_physmem.c | 2 +-
- src/liblzma/common/index.c | 4 ++--
- src/liblzma/common/stream_encoder_mt.c | 2 +-
- src/liblzma/common/vli_decoder.c | 2 +-
- src/liblzma/lz/lz_decoder.c | 2 +-
- src/scripts/xzgrep.in | 2 +-
- src/xz/args.c | 2 +-
- src/xz/coder.c | 4 ++--
- src/xz/list.c | 4 ++--
- src/xz/main.c | 2 +-
- src/xz/mytime.h | 2 +-
- src/xz/private.h | 2 +-
- src/xz/xz.1 | 2 +-
- windows/build.bash | 2 +-
- 22 files changed, 26 insertions(+), 26 deletions(-)
-
-commit 4ed339606156bd313ed99237485cb8ed0362d64f
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2019-05-01 18:43:10 +0300
-
- xz: In xz -lvv look at the widths of the check names too.
-
- Now the widths of the check names is used to adjust the width
- of the Check column. This way there no longer is a need to restrict
- the widths of the check names to be at most ten terminal-columns.
-
- src/xz/list.c | 32 ++++++++++++++++++++++++++------
- 1 file changed, 26 insertions(+), 6 deletions(-)
-
-commit 2f4281a1001dcf7fdf1418c0c0d246c16561fb65
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2019-05-01 18:33:25 +0300
-
- xz: Fix xz -lvv column alignment to look at the translated strings.
-
- src/xz/list.c | 4 ++--
- 1 file changed, 2 insertions(+), 2 deletions(-)
-
-commit 01d01b7c7c0b8eaf7f780a5584ec52c22d10fa4a
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2019-05-01 16:52:36 +0300
-
- Update THANKS.
-
- THANKS | 1 +
- 1 file changed, 1 insertion(+)
-
-commit 64030c6b17f7743df03a9948a0ccfcdf40c6b97c
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2019-05-01 16:43:16 +0300
-
- Windows: Update VS version in windows/vs2019/config.h.
-
- windows/vs2019/config.h | 2 +-
- 1 file changed, 1 insertion(+), 1 deletion(-)
-
-commit 2dc9117f5fbfab31444a3ca1e55795ccfa8a9f51
-Author: Julien Marrec <julien.marrec@gmail.com>
-Date: 2019-04-25 17:44:06 +0200
-
- Windows: Upgrade solution itself
-
- windows/vs2019/xz_win.sln | 7 +++++--
- 1 file changed, 5 insertions(+), 2 deletions(-)
-
-commit ac31413916fa9b11bab17f0f0aa63e2869360f6f
-Author: Julien Marrec <julien.marrec@gmail.com>
-Date: 2019-04-25 17:40:24 +0200
-
- Windows: Upgrade solution with VS2019
-
- windows/vs2019/liblzma.vcxproj | 15 ++++++++-------
- windows/vs2019/liblzma_dll.vcxproj | 15 ++++++++-------
- 2 files changed, 16 insertions(+), 14 deletions(-)
-
-commit be25a0c37ba92a20c390b4d17fe502457fe96b71
-Author: Julien Marrec <julien.marrec@gmail.com>
-Date: 2019-04-25 17:39:32 +0200
-
- Windows: Duplicate windows/vs2017 before upgrading
-
- windows/vs2019/config.h | 148 ++++++++++++++
- windows/vs2019/liblzma.vcxproj | 356 ++++++++++++++++++++++++++++++++++
- windows/vs2019/liblzma_dll.vcxproj | 385 +++++++++++++++++++++++++++++++++++++
- windows/vs2019/xz_win.sln | 48 +++++
- 4 files changed, 937 insertions(+)
-
-commit d0e58b3a51e8e616f3dc26ec7b7e4aa0fa6991ad
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2019-03-04 22:49:04 +0200
-
- README: Update translation instructions.
-
- XZ Utils is now part of the Translation Project
- <https://translationproject.org/>.
-
- README | 32 +++++++++++++-------------------
- 1 file changed, 13 insertions(+), 19 deletions(-)
-
-commit a750c35a7d45a16c11c1d40fecee8443c32a9996
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2019-03-04 21:20:39 +0200
-
- xz: Automatically align column headings in xz -lvv.
-
- src/xz/list.c | 263 ++++++++++++++++++++++++++++++++++++++++++++++------------
- 1 file changed, 212 insertions(+), 51 deletions(-)
-
-commit 6cb42e8aa1dc37bf403a9f5acbd07e86036b7e77
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2019-03-04 01:07:59 +0200
-
- xz: Automatically align strings ending in a colon in --list output.
-
- This should avoid alignment errors in translations with these
- strings.
-
- src/xz/list.c | 114 +++++++++++++++++++++++++++++++++++++++++++++++++++-------
- 1 file changed, 102 insertions(+), 12 deletions(-)
-
-commit 1e3f29b62f2c03e50fc9ebea7b83c1497dd35484
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2019-01-13 17:29:23 +0200
-
- Windows/VS2017: Omit WindowsTargetPlatformVersion from project files.
-
- I understood that if a WTPV is specified, it's often wrong
- because different VS installations have different SDK version
- installed. Omitting the WTPV tag makes VS2017 default to
- Windows SDK 8.1 which often is also missing, so in any case
- people may need to specify the WTPV before building. But some
- day in the future a missing WTPV tag will start to default to
- the latest installed SDK which sounds reasonable:
-
- https://developercommunity.visualstudio.com/content/problem/140294/windowstargetplatformversion-makes-it-impossible-t.html
-
- Thanks to "dom".
-
- windows/INSTALL-MSVC.txt | 4 ++++
- windows/vs2017/liblzma.vcxproj | 1 -
- windows/vs2017/liblzma_dll.vcxproj | 1 -
- 3 files changed, 4 insertions(+), 2 deletions(-)
-
-commit 4d86076332aece6314063d3712a5f364172bbb0f
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2018-12-20 20:42:29 +0200
-
- Update THANKS.
-
- THANKS | 1 +
- 1 file changed, 1 insertion(+)
-
-commit b55d79461d1f6aeaac03c7dae84481e5eb8bea4c
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2018-12-14 20:34:30 +0200
-
- xz: Fix a crash in progress indicator when in passthru mode.
-
- "xz -dcfv not_an_xz_file" crashed (all four options are
- required to trigger it). It caused xz to call
- lzma_get_progress(&strm, ...) when no coder was initialized
- in strm. In this situation strm.internal is NULL which leads
- to a crash in lzma_get_progress().
-
- The bug was introduced when xz started using lzma_get_progress()
- to get progress info for multi-threaded compression, so the
- bug is present in versions 5.1.3alpha and higher.
-
- Thanks to Filip Palian <Filip.Palian@pjwstk.edu.pl> for
- the bug report.
-
- src/xz/coder.c | 11 +++++++----
- src/xz/message.c | 18 ++++++++++++++++--
- src/xz/message.h | 3 ++-
- 3 files changed, 25 insertions(+), 7 deletions(-)
-
-commit 4ae5526de013efd1021686fa80bdd10cf1cb9c56
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2018-11-22 17:20:31 +0200
-
- xz: Update man page timestamp.
-
- src/xz/xz.1 | 2 +-
- 1 file changed, 1 insertion(+), 1 deletion(-)
-
-commit 6a36d0d5f49e0080ff64dd9ef250abd489bea2ad
-Author: Pavel Raiskup <praiskup@redhat.com>
-Date: 2018-11-22 15:14:34 +0100
-
- 'have have' typos
-
- src/xz/signals.c | 2 +-
- src/xz/xz.1 | 2 +-
- 2 files changed, 2 insertions(+), 2 deletions(-)
-
-commit 9eca51ef805ed8002a851df1b4995d71826c8b6e
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2018-11-02 20:40:48 +0200
-
- Update THANKS.
-
- THANKS | 1 +
- 1 file changed, 1 insertion(+)
-
-commit 106d1a663d4ba42b63231caa289f531548df81c1
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2018-11-02 20:18:45 +0200
-
- Tests: Add a fuzz test program and a config file for OSS-Fuzz.
-
- Thanks to Bhargava Shastry and Github user pdknsk.
-
- tests/Makefile.am | 1 +
- tests/ossfuzz/Makefile | 7 ++++
- tests/ossfuzz/config/fuzz.dict | 2 +
- tests/ossfuzz/config/fuzz.options | 2 +
- tests/ossfuzz/fuzz.c | 82 +++++++++++++++++++++++++++++++++++++++
- 5 files changed, 94 insertions(+)
-
-commit a18ae42a79a19b1394b41eb3e238139fd28012ec
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2018-10-26 22:49:10 +0300
-
- liblzma: Don't verify header CRC32s if building for fuzz testing.
-
- FUZZING_BUILD_MODE_UNSAFE_FOR_PRODUCTION is #defined when liblzma
- is being built for fuzz testing.
-
- Most fuzzed inputs would normally get rejected because of incorrect
- CRC32 and the actual header decoding code wouldn't get fuzzed.
- Disabling CRC32 checks avoids this problem. The fuzzer program
- must still use LZMA_IGNORE_CHECK flag to disable verification of
- integrity checks of uncompressed data.
-
- src/liblzma/common/block_header_decoder.c | 5 ++++-
- src/liblzma/common/index_decoder.c | 5 ++++-
- src/liblzma/common/index_hash.c | 5 ++++-
- src/liblzma/common/stream_flags_decoder.c | 10 ++++++++--
- 4 files changed, 20 insertions(+), 5 deletions(-)
-
-commit f76f7516d6a1c832f61810c82e92d151cc80966c
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2018-07-27 18:10:44 +0300
-
- xzless: Rename unused variables to silence static analysers.
-
- In this particular case I don't see this affecting readability
- of the code.
-
- Thanks to Pavel Raiskup.
-
- src/scripts/xzless.in | 2 +-
- 1 file changed, 1 insertion(+), 1 deletion(-)
-
-commit 3cbcaeb07eb7543735befd6f507fdb5fa4363cff
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2018-07-27 16:02:58 +0300
-
- liblzma: Remove an always-true condition from lzma_index_cat().
-
- This should help static analysis tools to see that newg
- isn't leaked.
-
- Thanks to Pavel Raiskup.
-
- src/liblzma/common/index.c | 4 ++--
- 1 file changed, 2 insertions(+), 2 deletions(-)
-
-commit 76762ae6098ec55c326f4b4b4a42e8c1918ee81f
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2018-05-19 21:23:25 +0300
-
- liblzma: Improve lzma_properties_decode() API documentation.
-
- src/liblzma/api/lzma/filter.h | 7 ++++---
- 1 file changed, 4 insertions(+), 3 deletions(-)
-
-commit 2267f5b0d20a5d24e93fcd9f72ea7eeb0d89708c
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2018-04-29 18:58:19 +0300
-
- Bump the version number to 5.3.1alpha.
-
- src/liblzma/api/lzma/version.h | 2 +-
- src/liblzma/liblzma.map | 2 +-
- 2 files changed, 2 insertions(+), 2 deletions(-)
-
-commit cee3021d30704858e4bdd22240e7d28e570d7451
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2018-04-29 18:48:00 +0300
-
- extra/scanlzma: Fix compiler warnings.
-
- extra/scanlzma/scanlzma.c | 6 +++++-
- 1 file changed, 5 insertions(+), 1 deletion(-)
-
-commit c5c7ceb08a011b97d261798033e2c39613a69eb7
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2018-04-29 18:44:47 +0300
-
- DOS: Add file_info.c to the list of files to build.
-
- dos/Makefile | 1 +
- 1 file changed, 1 insertion(+)
-
-commit 114cab97af766b21e0fc8620479202fb1e7a5e41
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2018-04-29 18:33:10 +0300
-
- Update NEWS for 5.3.1alpha.
-
- NEWS | 11 +++++++++++
- 1 file changed, 11 insertions(+)
-
-commit b8139e11c512bbf32bf58ab0689f9bb6c52819da
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2018-04-29 18:15:37 +0300
-
- Add NEWS for 5.2.4.
-
- NEWS | 27 +++++++++++++++++++++++++++
- 1 file changed, 27 insertions(+)
-
-commit 47b59d47cfd904a420fbd45629d168ca1973721d
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2018-02-06 19:36:30 +0200
-
- Update THANKS.
-
- THANKS | 2 ++
- 1 file changed, 2 insertions(+)
-
-commit bc197991690ede24ab143665b5b0f0f9cb35cc46
-Author: Ben Boeckel <mathstuf@gmail.com>
-Date: 2018-01-29 13:58:18 -0500
-
- nothrow: use noexcept for C++11 and newer
-
- In C++11, the `throw()` specifier is deprecated and `noexcept` is
- preffered instead.
-
- src/liblzma/api/lzma.h | 6 +++++-
- 1 file changed, 5 insertions(+), 1 deletion(-)
-
-commit fb6d4f83cb6e144734f2a4216bb117bd56dc3cb5
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2018-02-06 18:02:48 +0200
-
- liblzma: Remove incorrect #ifdef from range_common.h.
-
- In most cases it was harmless but it could affect some
- custom build systems.
-
- Thanks to Pippijn van Steenhoven.
-
- src/liblzma/rangecoder/range_common.h | 4 +---
- 1 file changed, 1 insertion(+), 3 deletions(-)
-
-commit bc577d35c2d0ed17f554d2d8107b2a2a9abbac76
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2018-01-10 22:10:39 +0200
-
- Update THANKS.
-
- THANKS | 1 +
- 1 file changed, 1 insertion(+)
-
-commit 713bbc1a80f26d34c96ed3dbb9887362204de3a1
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2018-01-10 21:54:27 +0200
-
- tuklib_integer: New Intel C compiler needs immintrin.h.
-
- Thanks to Melanie Blower (Intel) for the patch.
-
- src/common/tuklib_integer.h | 11 +++++++++++
- 1 file changed, 11 insertions(+)
-
-commit a0ee1afbd99da138b559cb27fa2022e7f1ab44f3
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2017-09-24 20:04:24 +0300
-
- Update THANKS.
-
- THANKS | 1 +
- 1 file changed, 1 insertion(+)
-
-commit a1e2c568de29c0b57d873eab40a2879b749da429
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2017-09-16 20:36:20 +0300
-
- Windows: Fix paths in VS project files.
-
- Some paths use slashes instead of backslashes as directory
- separators... now it should work (I tested VS2013 version).
-
- windows/vs2013/liblzma.vcxproj | 12 ++++++------
- windows/vs2013/liblzma_dll.vcxproj | 24 ++++++++++++------------
- windows/vs2017/liblzma.vcxproj | 12 ++++++------
- windows/vs2017/liblzma_dll.vcxproj | 24 ++++++++++++------------
- 4 files changed, 36 insertions(+), 36 deletions(-)
-
-commit cea5cf8d26c9d1dc30a808614d79c0b25640e15e
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2017-09-16 12:56:20 +0300
-
- Windows: Update VS2017 project files to include file info decoder.
-
- windows/vs2017/liblzma.vcxproj | 2 ++
- windows/vs2017/liblzma_dll.vcxproj | 2 ++
- 2 files changed, 4 insertions(+)
-
-commit 95d563db3ee497b223e522b699c4d4c29943eef0
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2017-09-16 12:54:23 +0300
-
- Windows: Add project files for VS2017.
-
- These files match the v5.2 branch (no file info decoder).
-
- windows/vs2017/config.h | 148 ++++++++++++++
- windows/vs2017/liblzma.vcxproj | 355 ++++++++++++++++++++++++++++++++++
- windows/vs2017/liblzma_dll.vcxproj | 384 +++++++++++++++++++++++++++++++++++++
- windows/vs2017/xz_win.sln | 48 +++++
- 4 files changed, 935 insertions(+)
-
-commit ab72416d62ea8f50ad31d5b8545fcb6a2bf96b73
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2017-09-16 12:45:50 +0300
-
- Windows: Update VS2013 project files to include file info decoder.
-
- windows/vs2013/liblzma.vcxproj | 2 ++
- windows/vs2013/liblzma_dll.vcxproj | 2 ++
- 2 files changed, 4 insertions(+)
-
-commit 82388980187b0e3794d187762054200bbdcc9a53
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2017-09-16 12:39:43 +0300
-
- Windows: Move VS2013 files into windows/vs2013 directory.
-
- windows/{ => vs2013}/config.h | 0
- windows/{ => vs2013}/liblzma.vcxproj | 278 +++++++++++++++---------------
- windows/{ => vs2013}/liblzma_dll.vcxproj | 280 +++++++++++++++----------------
- windows/{ => vs2013}/xz_win.sln | 0
- 4 files changed, 279 insertions(+), 279 deletions(-)
-
-commit 94e3f986aa4e14b4ff01ac24857f499630d6d180
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2017-08-14 20:08:33 +0300
-
- Fix or hide warnings from GCC 7's -Wimplicit-fallthrough.
-
- src/liblzma/lzma/lzma_decoder.c | 6 ++++++
- src/xz/list.c | 2 ++
- 2 files changed, 8 insertions(+)
-
-commit 0b0e1e6803456aac641a59332200f8e95e2b7ea8
-Author: Alexey Tourbin <alexey.tourbin@gmail.com>
-Date: 2017-05-16 23:56:35 +0300
-
- Docs: Fix a typo in a comment in doc/examples/02_decompress.c.
-
- doc/examples/02_decompress.c | 2 +-
- 1 file changed, 1 insertion(+), 1 deletion(-)
-
-commit a015cd1f90116e655be4eaf4aad42c4c911c2807
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2017-05-23 18:34:43 +0300
-
- xz: Fix "xz --list --robot missing_or_bad_file.xz".
-
- It ended up printing an uninitialized char-array when trying to
- print the check names (column 7) on the "totals" line.
-
- This also changes the column 12 (minimum xz version) to
- 50000002 (xz 5.0.0) instead of 0 when there are no valid
- input files.
-
- Thanks to kidmin for the bug report.
-
- src/xz/list.c | 8 ++++++--
- 1 file changed, 6 insertions(+), 2 deletions(-)
-
-commit c2e29f06a7d1e3ba242ac2fafc69f5d6e92f62cd
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2017-04-24 20:20:11 +0300
-
- Docs: Add doc/examples/11_file_info.c.
-
- doc/examples/11_file_info.c | 206 ++++++++++++++++++++++++++++++++++++++++++++
- doc/examples/Makefile | 3 +-
- 2 files changed, 208 insertions(+), 1 deletion(-)
-
-commit 1520f6ec808896375ac7bf778c449e0f7dea5f46
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2017-04-24 19:48:47 +0300
-
- Build: Omit pre-5.0.0 entries from the generated ChangeLog.
-
- It makes ChangeLog significantly smaller.
-
- Makefile.am | 3 ++-
- 1 file changed, 2 insertions(+), 1 deletion(-)
-
-commit 8269782283806c90a8509c2ac2a308344f70e171
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2017-04-24 19:48:23 +0300
-
- xz: Use lzma_file_info_decoder() for --list.
-
- src/xz/list.c | 254 ++++++++++------------------------------------------------
- 1 file changed, 44 insertions(+), 210 deletions(-)
-
-commit e353d0b1cc0d3997ae5048faa8e6786414953e06
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2017-04-24 19:35:50 +0300
-
- liblzma: Add lzma_file_info_decoder().
-
- src/liblzma/api/lzma/index.h | 66 ++++
- src/liblzma/common/Makefile.inc | 1 +
- src/liblzma/common/file_info.c | 855 ++++++++++++++++++++++++++++++++++++++++
- src/liblzma/liblzma.map | 7 +-
- 4 files changed, 928 insertions(+), 1 deletion(-)
-
-commit 144ef9e19e9496c995b21505dd1e111c442968d1
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2017-04-24 19:30:22 +0300
-
- Update the Git repository URL to HTTPS in ChangeLog.
-
- ChangeLog | 2 +-
- 1 file changed, 1 insertion(+), 1 deletion(-)
-
-commit 8c9842c265993d7dd4039f732d3546267fb5ecc4
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2017-04-21 15:05:16 +0300
-
- liblzma: Rename LZMA_SEEK to LZMA_SEEK_NEEDED and seek_in to seek_pos.
-
- src/liblzma/api/lzma/base.h | 18 +++++++++---------
- src/liblzma/common/common.c | 2 +-
- src/xz/message.c | 2 +-
- 3 files changed, 11 insertions(+), 11 deletions(-)
-
-commit 662b27c417cab248cb365dd7682121bdec4d5ae7
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2017-04-19 22:17:35 +0300
-
- Update the home page URLs to HTTPS.
-
- COPYING | 2 +-
- README | 2 +-
- configure.ac | 2 +-
- doc/faq.txt | 4 ++--
- dos/config.h | 2 +-
- src/common/common_w32res.rc | 2 +-
- src/xz/xz.1 | 6 +++---
- src/xzdec/xzdec.1 | 4 ++--
- windows/README-Windows.txt | 2 +-
- windows/config.h | 2 +-
- 10 files changed, 14 insertions(+), 14 deletions(-)
-
-commit c28f0b3d00af87b92dda229831548d8eb0067d1d
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2017-04-05 18:47:22 +0300
-
- xz: Add io_seek_src().
-
- src/xz/file_io.c | 20 +++++++++++++++++---
- src/xz/file_io.h | 13 +++++++++++++
- 2 files changed, 30 insertions(+), 3 deletions(-)
-
-commit bba477257d7319c8764890f3669175b866d24944
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2017-03-30 22:01:54 +0300
-
- xz: Use POSIX_FADV_RANDOM for in "xz --list" mode.
-
- xz --list is random access so POSIX_FADV_SEQUENTIAL was clearly
- wrong.
-
- src/xz/file_io.c | 10 ++++++++--
- 1 file changed, 8 insertions(+), 2 deletions(-)
-
-commit 310d19816d1652b0c8bb1b82574d46345d924752
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2017-03-30 20:03:05 +0300
-
- liblzma: Make lzma_index_decoder_init() visible to other liblzma funcs.
-
- This is to allow other functions to use it without going
- via the public API (lzma_index_decoder()).
-
- src/liblzma/common/Makefile.inc | 1 +
- src/liblzma/common/index_decoder.c | 10 +++++-----
- src/liblzma/common/index_decoder.h | 24 ++++++++++++++++++++++++
- 3 files changed, 30 insertions(+), 5 deletions(-)
-
-commit a27920002dbc469f778a134fc665b7c3ea73701b
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2017-03-30 20:00:09 +0300
-
- liblzma: Add generic support for input seeking (LZMA_SEEK).
-
- Also mention LZMA_SEEK in xz/message.c to silence a warning.
-
- src/liblzma/api/lzma/base.h | 31 ++++++++++++++++++++++++++++++-
- src/liblzma/common/common.c | 12 +++++++++++-
- src/xz/message.c | 1 +
- 3 files changed, 42 insertions(+), 2 deletions(-)
-
-commit a0b1dda409bc3e6e2957a2651663fc411d2caf2d
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2017-03-30 19:47:45 +0300
-
- liblzma: Fix lzma_memlimit_set(strm, 0).
-
- The 0 got treated specially in a buggy way and as a result
- the function did nothing. The API doc said that 0 was supposed
- to return LZMA_PROG_ERROR but it didn't.
-
- Now 0 is treated as if 1 had been specified. This is done because
- 0 is already used to indicate an error from lzma_memlimit_get()
- and lzma_memusage().
-
- In addition, lzma_memlimit_set() no longer checks that the new
- limit is at least LZMA_MEMUSAGE_BASE. It's counter-productive
- for the Index decoder and was actually needed only by the
- auto decoder. Auto decoder has now been modified to check for
- LZMA_MEMUSAGE_BASE.
-
- src/liblzma/api/lzma/base.h | 7 ++++++-
- src/liblzma/common/auto_decoder.c | 3 +++
- src/liblzma/common/common.c | 6 ++++--
- 3 files changed, 13 insertions(+), 3 deletions(-)
-
-commit 84462afaada61379f5878e46f8f00e25a1cdcf29
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2017-03-30 19:16:55 +0300
-
- liblzma: Similar memlimit fix for stream_, alone_, and auto_decoder.
-
- src/liblzma/api/lzma/container.h | 21 +++++++++++++++++----
- src/liblzma/common/alone_decoder.c | 5 +----
- src/liblzma/common/auto_decoder.c | 5 +----
- src/liblzma/common/stream_decoder.c | 5 +----
- 4 files changed, 20 insertions(+), 16 deletions(-)
-
-commit cbc74017939690d13441b8926bb743fb03211b83
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2017-03-30 18:58:18 +0300
-
- liblzma: Fix handling of memlimit == 0 in lzma_index_decoder().
-
- It returned LZMA_PROG_ERROR, which was done to avoid zero as
- the limit (because it's a special value elsewhere), but using
- LZMA_PROG_ERROR is simply inconvenient and can cause bugs.
-
- The fix/workaround is to treat 0 as if it were 1 byte. It's
- effectively the same thing. The only weird consequence is
- that then lzma_memlimit_get() will return 1 even when 0 was
- specified as the limit.
-
- This fixes a very rare corner case in xz --list where a specific
- memory usage limit and a multi-stream file could print the
- error message "Internal error (bug)" instead of saying that
- the memory usage limit is too low.
-
- src/liblzma/api/lzma/index.h | 18 +++++++++++-------
- src/liblzma/common/index_decoder.c | 4 ++--
- 2 files changed, 13 insertions(+), 9 deletions(-)
-
-commit 78ae13bced912b1b92ae927992c99cbcc463cae7
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2016-12-30 13:25:10 +0200
-
- Update NEWS for 5.2.3.
-
- NEWS | 39 +++++++++++++++++++++++++++++++++++++++
- 1 file changed, 39 insertions(+)
-
-commit 0297863fdb453aed1a25eb025f3ba7bacbbb1357
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2016-12-26 20:55:52 +0200
-
- Document --enable-sandbox configure option in INSTALL.
-
- INSTALL | 23 +++++++++++++++++++++++
- 1 file changed, 23 insertions(+)
-
-commit d4a0462abe5478193521c14625e1c81fead87f9f
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2016-11-21 20:24:50 +0200
-
- liblzma: Avoid multiple definitions of lzma_coder structures.
-
- Only one definition was visible in a translation unit.
- It avoided a few casts and temp variables but seems that
- this hack doesn't work with link-time optimizations in compilers
- as it's not C99/C11 compliant.
-
- Fixes:
- http://www.mail-archive.com/xz-devel@tukaani.org/msg00279.html
-
- src/liblzma/common/alone_decoder.c | 44 +++++----
- src/liblzma/common/alone_encoder.c | 34 ++++---
- src/liblzma/common/auto_decoder.c | 35 ++++---
- src/liblzma/common/block_decoder.c | 41 ++++----
- src/liblzma/common/block_encoder.c | 40 ++++----
- src/liblzma/common/common.h | 18 ++--
- src/liblzma/common/index_decoder.c | 33 ++++---
- src/liblzma/common/index_encoder.c | 16 ++--
- src/liblzma/common/stream_decoder.c | 50 +++++-----
- src/liblzma/common/stream_encoder.c | 56 ++++++-----
- src/liblzma/common/stream_encoder_mt.c | 124 ++++++++++++++-----------
- src/liblzma/delta/delta_common.c | 25 ++---
- src/liblzma/delta/delta_decoder.c | 6 +-
- src/liblzma/delta/delta_encoder.c | 12 ++-
- src/liblzma/delta/delta_private.h | 4 +-
- src/liblzma/lz/lz_decoder.c | 60 ++++++------
- src/liblzma/lz/lz_decoder.h | 13 ++-
- src/liblzma/lz/lz_encoder.c | 57 +++++++-----
- src/liblzma/lz/lz_encoder.h | 9 +-
- src/liblzma/lzma/lzma2_decoder.c | 32 ++++---
- src/liblzma/lzma/lzma2_encoder.c | 51 +++++-----
- src/liblzma/lzma/lzma_decoder.c | 27 +++---
- src/liblzma/lzma/lzma_encoder.c | 29 +++---
- src/liblzma/lzma/lzma_encoder.h | 9 +-
- src/liblzma/lzma/lzma_encoder_optimum_fast.c | 3 +-
- src/liblzma/lzma/lzma_encoder_optimum_normal.c | 23 ++---
- src/liblzma/lzma/lzma_encoder_private.h | 6 +-
- src/liblzma/simple/arm.c | 2 +-
- src/liblzma/simple/armthumb.c | 2 +-
- src/liblzma/simple/ia64.c | 2 +-
- src/liblzma/simple/powerpc.c | 2 +-
- src/liblzma/simple/simple_coder.c | 61 ++++++------
- src/liblzma/simple/simple_private.h | 12 +--
- src/liblzma/simple/sparc.c | 2 +-
- src/liblzma/simple/x86.c | 15 +--
- 35 files changed, 532 insertions(+), 423 deletions(-)
-
-commit a01794c52add98263b49119842c3e7141d1b9ced
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2016-10-24 18:53:25 +0300
-
- Update THANKS.
-
- THANKS | 1 +
- 1 file changed, 1 insertion(+)
-
-commit df8f446e3ad47e5148b8c8d8b6e519d3ce29cb9d
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2016-10-24 18:51:36 +0300
-
- tuklib_cpucores: Add support for sched_getaffinity().
-
- It's available in glibc (GNU/Linux, GNU/kFreeBSD). It's better
- than sysconf(_SC_NPROCESSORS_ONLN) because sched_getaffinity()
- gives the number of cores available to the process instead of
- the total number of cores online.
-
- As a side effect, this commit fixes a bug on GNU/kFreeBSD where
- configure would detect the FreeBSD-specific cpuset_getaffinity()
- but it wouldn't actually work because on GNU/kFreeBSD it requires
- using -lfreebsd-glue when linking. Now the glibc-specific function
- will be used instead.
-
- Thanks to Sebastian Andrzej Siewior for the original patch
- and testing.
-
- m4/tuklib_cpucores.m4 | 30 +++++++++++++++++++++++++++++-
- src/common/tuklib_cpucores.c | 9 +++++++++
- 2 files changed, 38 insertions(+), 1 deletion(-)
-
-commit 446e4318fa79788e09299d5953b5dd428953d14b
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2016-06-30 20:27:36 +0300
-
- xz: Fix copying of timestamps on Windows.
-
- xz used to call utime() on Windows, but its result gets lost
- on close(). Using _futime() seems to work.
-
- Thanks to Martok for reporting the bug:
- http://www.mail-archive.com/xz-devel@tukaani.org/msg00261.html
-
- configure.ac | 2 +-
- src/xz/file_io.c | 18 ++++++++++++++++++
- 2 files changed, 19 insertions(+), 1 deletion(-)
-
-commit 1b0ac0c53c761263e91e34195cb21dfdcfeac0bd
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2016-06-16 22:46:02 +0300
-
- xz: Silence warnings from -Wlogical-op.
-
- Thanks to Evan Nemerson.
-
- src/xz/file_io.c | 12 ++++++++++--
- 1 file changed, 10 insertions(+), 2 deletions(-)
-
-commit c83b7a03342c3325ff10400b22ee21edfcd1e026
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2016-04-10 20:55:49 +0300
-
- Build: Fix = to += for xz_SOURCES in src/xz/Makefile.am.
-
- Thanks to Christian Kujau.
-
- src/xz/Makefile.am | 2 +-
- 1 file changed, 1 insertion(+), 1 deletion(-)
-
-commit ade31a2bfb95c94d05fbfc0ecbba5d6377f2506e
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2016-04-10 20:54:17 +0300
-
- Build: Bump GNU Gettext version requirement to 0.19.
-
- It silences a few warnings and most people probably have
- 0.19 even on stable distributions.
-
- Thanks to Christian Kujau.
-
- configure.ac | 2 +-
- 1 file changed, 1 insertion(+), 1 deletion(-)
-
-commit ac398c3bafa6e4c80e20571373a96947db863b3d
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2016-03-13 20:21:49 +0200
-
- liblzma: Disable external SHA-256 by default.
-
- This is the sane thing to do. The conflict with OpenSSL
- on some OSes and especially that the OS-provided versions
- can be significantly slower makes it clear that it was
- a mistake to have the external SHA-256 support enabled by
- default.
-
- Those who want it can now pass --enable-external-sha256 to
- configure. INSTALL was updated with notes about OSes where
- this can be a bad idea.
-
- The SHA-256 detection code in configure.ac had some bugs that
- could lead to a build failure in some situations. These were
- fixed, although it doesn't matter that much now that the
- external SHA-256 is disabled by default.
-
- MINIX >= 3.2.0 uses NetBSD's libc and thus has SHA256_Init
- in libc instead of libutil. Support for the libutil version
- was removed.
-
- INSTALL | 36 ++++++++++++++++++++++
- configure.ac | 76 +++++++++++++++++++++++------------------------
- src/liblzma/check/check.h | 16 ++++------
- 3 files changed, 79 insertions(+), 49 deletions(-)
-
-commit 6fd5ecb589a9fdd7a576ea48c4850d496bab9ce5
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2016-03-10 20:27:05 +0200
-
- Update THANKS.
-
- THANKS | 1 +
- 1 file changed, 1 insertion(+)
-
-commit 473ef0dc69a30e64d5fa0d34aca02f7309faa3e9
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2016-03-10 20:26:49 +0200
-
- Build: Avoid SHA256_Init on FreeBSD and MINIX 3.
-
- On FreeBSD 10 and older, SHA256_Init from libmd conflicts
- with libcrypto from OpenSSL. The OpenSSL version has
- different sizeof(SHA256_CTX) and it can cause weird
- problems if wrong SHA256_Init gets used.
-
- Looking at the source, MINIX 3 seems to have a similar issue but
- I'm not sure. To be safe, I disabled SHA256_Init on MINIX 3 too.
-
- NetBSD has SHA256_Init in libc and they had a similar problem,
- but they already fixed it in 2009.
-
- Thanks to Jim Wilcoxson for the bug report that helped
- in finding the problem.
-
- configure.ac | 27 +++++++++++++++++++++------
- 1 file changed, 21 insertions(+), 6 deletions(-)
-
-commit faf302137e54d605b44ecf0373cb51a6403a2de1
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2015-11-08 20:16:10 +0200
-
- tuklib_physmem: Hopefully silence a warning on Windows.
-
- src/common/tuklib_physmem.c | 3 ++-
- 1 file changed, 2 insertions(+), 1 deletion(-)
-
-commit e52e9151cf8613022d1de4712ff39dbcb666e991
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2015-11-04 23:17:43 +0200
-
- Update THANKS.
-
- THANKS | 1 +
- 1 file changed, 1 insertion(+)
-
-commit 14115f84a38161d55eaa2d070f08739bde37e966
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2015-11-04 23:14:00 +0200
-
- liblzma: Make Valgrind happier with optimized (gcc -O2) liblzma.
-
- When optimizing, GCC can reorder code so that an uninitialized
- value gets used in a comparison, which makes Valgrind unhappy.
- It doesn't happen when compiled with -O0, which I tend to use
- when running Valgrind.
-
- Thanks to Rich Prohaska. I remember this being mentioned long
- ago by someone else but nothing was done back then.
-
- src/liblzma/lz/lz_encoder.c | 4 ++++
- 1 file changed, 4 insertions(+)
-
-commit f4c95ba94beb71a608eb6eadbf82b44f53a0260e
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2015-11-03 20:55:45 +0200
-
- liblzma: Rename lzma_presets.c back to lzma_encoder_presets.c.
-
- It would be too annoying to update other build systems
- just because of this.
-
- src/liblzma/lzma/Makefile.inc | 2 +-
- src/liblzma/lzma/{lzma_presets.c => lzma_encoder_presets.c} | 2 +-
- 2 files changed, 2 insertions(+), 2 deletions(-)
-
-commit c7bc20a6f3e71920871d48db31a79ab58b5a0a4b
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2015-11-03 20:47:07 +0200
-
- Build: Disable xzdec, lzmadec, and lzmainfo when they cannot be built.
-
- They all need decoder support and if that isn't available,
- there's no point trying to build them.
-
- configure.ac | 3 +++
- 1 file changed, 3 insertions(+)
-
-commit 5cbca1205deeb6fb7afe7a864fa68a57466d928a
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2015-11-03 20:35:19 +0200
-
- Build: Simplify $enable_{encoders,decoders} usage a bit.
-
- configure.ac | 6 ++++--
- 1 file changed, 4 insertions(+), 2 deletions(-)
-
-commit af13781886c8e7a0aabebb5141ea282dc364f5c6
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2015-11-03 20:31:31 +0200
-
- Windows/MSVC: Update config.h.
-
- windows/config.h | 6 ++++++
- 1 file changed, 6 insertions(+)
-
-commit 9fa5949330f162c5a2f6653f83025327837e8f39
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2015-11-03 20:29:58 +0200
-
- DOS: Update config.h.
-
- dos/config.h | 6 ++++++
- 1 file changed, 6 insertions(+)
-
-commit cb3111e3ed84152912b5138d690c8d9f00c6ef02
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2015-11-03 20:29:33 +0200
-
- xz: Make xz buildable even when encoders or decoders are disabled.
-
- The patch is quite long but it's mostly about adding new #ifdefs
- to omit code when encoders or decoders have been disabled.
-
- This adds two new #defines to config.h: HAVE_ENCODERS and
- HAVE_DECODERS.
-
- configure.ac | 4 ++++
- src/xz/Makefile.am | 8 ++++++--
- src/xz/args.c | 16 ++++++++++++++++
- src/xz/coder.c | 33 +++++++++++++++++++++++++--------
- src/xz/main.c | 9 +++++++--
- src/xz/private.h | 5 ++++-
- 6 files changed, 62 insertions(+), 13 deletions(-)
-
-commit 4cc584985c0b7a13901da1b7a64ef9f7cc36e8ab
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2015-11-03 18:06:40 +0200
-
- Build: Build LZMA1/2 presets also when only decoder is wanted.
-
- People shouldn't rely on the presets when decoding raw streams,
- but xz uses the presets as the starting point for raw decoder
- options anyway.
-
- lzma_encocder_presets.c was renamed to lzma_presets.c to
- make it clear it's not used solely by the encoder code.
-
- src/liblzma/lzma/Makefile.inc | 6 +++++-
- src/liblzma/lzma/{lzma_encoder_presets.c => lzma_presets.c} | 3 ++-
- 2 files changed, 7 insertions(+), 2 deletions(-)
-
-commit 23ed1d41489f632155bbc9660f323d57e09da180
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2015-11-03 17:54:48 +0200
-
- Build: Fix configure to handle LZMA1 dependency with LZMA2.
-
- Now it gives an error if LZMA1 encoder/decoder is missing
- when LZMA2 encoder/decoder was requested. Even better would
- be LZMA2 implicitly enabling LZMA1 but it would need more code.
-
- configure.ac | 5 -----
- 1 file changed, 5 deletions(-)
-
-commit b0bc3e03852af13419ea2960881824258d451117
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2015-11-03 17:41:54 +0200
-
- Build: Don't omit lzma_cputhreads() unless using --disable-threads.
-
- Previously it was omitted if encoders were disabled
- with --disable-encoders. It didn't make sense and
- it also broke the build.
-
- src/liblzma/common/Makefile.inc | 5 ++++-
- 1 file changed, 4 insertions(+), 1 deletion(-)
-
-commit c6bf438ab39e0fb4a47d3c81725c227919502726
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2015-11-02 18:16:51 +0200
-
- liblzma: Fix a build failure related to external SHA-256 support.
-
- If an appropriate header and structure were found by configure,
- but a library with a usable SHA-256 functions wasn't, the build
- failed.
-
- src/liblzma/check/check.h | 32 +++++++++++++++++++++++---------
- 1 file changed, 23 insertions(+), 9 deletions(-)
-
-commit e18adc56f2262aa9394d46681e9e4b9981ed5e97
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2015-11-02 15:19:10 +0200
-
- xz: Always close the file before trying to delete it.
-
- unlink() can return EBUSY in errno for open files on some
- operating systems and file systems.
-
- src/xz/file_io.c | 25 ++++++++++++-------------
- 1 file changed, 12 insertions(+), 13 deletions(-)
-
-commit 282e768a1484e88c8b7ec35655ee4959954ec87a
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2015-10-12 21:08:42 +0300
-
- Update THANKS.
-
- THANKS | 1 +
- 1 file changed, 1 insertion(+)
-
-commit 372e402713a1d4337ffce5f56d5c5c9ed99a66d0
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2015-10-12 21:07:41 +0300
-
- Tests: Add tests for the two bugs fixed in index.c.
-
- tests/test_index.c | 30 ++++++++++++++++++++++++++++++
- 1 file changed, 30 insertions(+)
-
-commit 21515d79d778b8730a434f151b07202d52a04611
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2015-10-12 20:45:15 +0300
-
- liblzma: Fix lzma_index_dup() for empty Streams.
-
- Stream Flags and Stream Padding weren't copied from
- empty Streams.
-
- src/liblzma/common/index.c | 11 ++++++-----
- 1 file changed, 6 insertions(+), 5 deletions(-)
-
-commit 09f395b6b360c0b13e8559eece1d179b908ebd3a
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2015-10-12 20:31:44 +0300
-
- liblzma: Add a note to index.c for those using static analyzers.
-
- src/liblzma/common/index.c | 3 +++
- 1 file changed, 3 insertions(+)
-
-commit 3bf857edfef51374f6f3fffae3d817f57d3264a0
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2015-10-12 20:29:09 +0300
-
- liblzma: Fix a memory leak in error path of lzma_index_dup().
-
- lzma_index_dup() calls index_dup_stream() which, in case of
- an error, calls index_stream_end() to free memory allocated
- by index_stream_init(). However, it illogically didn't
- actually free the memory. To make it logical, the tree
- handling code was modified a bit in addition to changing
- index_stream_end().
-
- Thanks to Evan Nemerson for the bug report.
-
- src/liblzma/common/index.c | 18 +++++++++---------
- 1 file changed, 9 insertions(+), 9 deletions(-)
-
-commit 7f05803979b4b79642d5be4218a79da7a0b12c47
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2015-09-29 13:57:28 +0300
-
- Update NEWS for 5.2.2.
-
- NEWS | 18 ++++++++++++++++++
- 1 file changed, 18 insertions(+)
-
-commit 397fcc0946315b55c3c6d80e37e82a2a78bc15c1
-Author: Hauke Henningsen <sqrt@entless.org>
-Date: 2015-08-17 04:59:54 +0200
-
- Update German translation, mostly wrt orthography
-
- Provide an update of the German translation.
- * A lot of compound words were previously written with spaces, while
- German orthography is relatively clear in that the components
- should not be separated.
- * When referring to the actual process of (de)compression rather than the
- concept, replace “(De-)Kompression” with “(De-)Komprimierung”.
- Previously, both forms were used in this context and are now used in a
- manner consistent with “Komprimierung” being more likely to refer to
- a process.
- * Consistently translate “standard input”/“output”
- * Use “Zeichen” instead of false friend “Charakter” for “character”
- * Insert commas around relative clauses (as required in German)
- * Some other minor corrections
- * Capitalize “ß” as “ẞ”
- * Consistently start option descriptions in --help with capital letters
-
- Acked-By: Andre Noll <maan@tuebingen.mpg.de>
-
- * Update after msgmerge
-
- po/de.po | 383 ++++++++++++++++++++++++++++++++-------------------------------
- 1 file changed, 196 insertions(+), 187 deletions(-)
-
-commit cbc9e39bae715accb44168930a71888480aad569
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2015-08-11 13:23:04 +0300
-
- Build: Minor Cygwin cleanup.
-
- Some tests used "cygwin*" and some used "cygwin". I changed
- them all to use "cygwin". Shouldn't affect anything in practice.
-
- configure.ac | 6 +++---
- 1 file changed, 3 insertions(+), 3 deletions(-)
-
-commit bcacd8ce7a031566858e5e03c1009064c3f1c89e
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2015-08-11 13:21:52 +0300
-
- Build: Support building of MSYS2 binaries.
-
- configure.ac | 16 +++++++++++-----
- 1 file changed, 11 insertions(+), 5 deletions(-)
-
-commit 0275a5398c01d57b724dec7fea52dec3bd6edc6c
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2015-08-09 21:06:26 +0300
-
- Windows: Define DLL_EXPORT when building liblzma.dll with MSVC.
-
- src/liblzma/common/common.h uses it to set __declspec(dllexport)
- for the API symbols.
-
- Thanks to Adam Walling.
-
- windows/liblzma_dll.vcxproj | 12 ++++++------
- 1 file changed, 6 insertions(+), 6 deletions(-)
-
-commit a74525cf9b945fb0b370e64cf406104beb31729b
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2015-08-09 21:02:20 +0300
-
- Windows: Omit unneeded header files from MSVC project files.
-
- windows/liblzma.vcxproj | 5 -----
- windows/liblzma_dll.vcxproj | 5 -----
- 2 files changed, 10 deletions(-)
-
-commit fbbb295a91caf39faf8838c8c39526e4cb4dc121
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2015-07-12 20:48:19 +0300
-
- liblzma: A MSVC-specific hack isn't needed with MSVC 2013 and newer.
-
- src/liblzma/api/lzma.h | 18 +++++++++++++-----
- 1 file changed, 13 insertions(+), 5 deletions(-)
-
-commit 713dbe5c230fe00865a54f5c32358ea30f9a1156
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2015-06-19 20:38:55 +0300
-
- Update THANKS.
-
- THANKS | 2 ++
- 1 file changed, 2 insertions(+)
-
-commit 3a5d755d055d51f99c523b4c2952727e1e69cfa1
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2015-06-19 20:21:30 +0300
-
- Windows: Update the docs.
-
- INSTALL | 29 ++++++++-----
- windows/INSTALL-MSVC.txt | 47 ++++++++++++++++++++++
- windows/{INSTALL-Windows.txt => INSTALL-MinGW.txt} | 2 +-
- 3 files changed, 67 insertions(+), 11 deletions(-)
-
-commit b0798c6aa6184efcefd0bdcca20f96121a13feda
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2015-06-19 17:25:31 +0300
-
- Windows: Add MSVC project files for building liblzma.
-
- Thanks to Adam Walling for creating these files.
-
- windows/liblzma.vcxproj | 359 ++++++++++++++++++++++++++++++++++++++++
- windows/liblzma_dll.vcxproj | 388 ++++++++++++++++++++++++++++++++++++++++++++
- windows/xz_win.sln | 48 ++++++
- 3 files changed, 795 insertions(+)
-
-commit 9b02a4ffdac1b9f066658ec4c95c0834f4cd2fb7
-Author: Andre Noll <maan@tuebingen.mpg.de>
-Date: 2015-05-28 15:50:00 +0200
-
- Fix typo in German translation.
-
- As pointed out by Robert Pollak, there's a typo in the German
- translation of the compression preset option (-0 ... -9) help text.
- "The compressor" translates to "der Komprimierer", and the genitive
- form is "des Komprimierers". The old word makes no sense at all.
-
- po/de.po | 2 +-
- 1 file changed, 1 insertion(+), 1 deletion(-)
-
-commit c7f4041f6b8f4729f88d3bc888b2a4080ae51f72
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2015-05-13 20:57:55 +0300
-
- Tests: Fix a memory leak in test_bcj_exact_size.
-
- Thanks to Cristian Rodríguez.
-
- tests/test_bcj_exact_size.c | 1 +
- 1 file changed, 1 insertion(+)
-
-commit 17b29d4f0ae0f780fbd69e15a398dc478d8492f8
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2015-05-12 18:08:24 +0300
-
- Fix NEWS about threading in 5.2.0.
-
- Thanks to Andy Hochhaus.
-
- NEWS | 3 ++-
- 1 file changed, 2 insertions(+), 1 deletion(-)
-
-commit 49c26920d6e2d85e5c6123e34958aed2e77485ad
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2015-05-11 21:26:16 +0300
-
- xz: Document that threaded decompression hasn't been implemented yet.
-
- src/xz/xz.1 | 10 +++++++++-
- 1 file changed, 9 insertions(+), 1 deletion(-)
-
-commit 5b2458cb244ed237efe4de1ebcf06e1b3a1f4256
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2015-04-20 20:20:29 +0300
-
- Update THANKS.
-
- THANKS | 1 +
- 1 file changed, 1 insertion(+)
-
-commit 6bd0349c58451b13442e8f463e35de83548bf985
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2015-04-20 19:59:18 +0300
-
- Revert "xz: Use pipe2() if available."
-
- This reverts commit 7a11c4a8e5e15f13d5fa59233b3172e65428efdd.
- It is a problem when libc has pipe2() but the kernel is too
- old to have pipe2() and thus pipe2() fails. In xz it's pointless
- to have a fallback for non-functioning pipe2(); it's better to
- avoid pipe2() completely.
-
- Thanks to Michael Fox for the bug report.
-
- configure.ac | 4 ++--
- src/xz/file_io.c | 9 +--------
- 2 files changed, 3 insertions(+), 10 deletions(-)
-
-commit fc0df0f8db87dff45543708a711e17d29c37f632
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2015-04-01 14:45:25 +0300
-
- xz: Fix the Capsicum rights on user_abort_pipe.
-
- src/xz/file_io.c | 6 +++++-
- 1 file changed, 5 insertions(+), 1 deletion(-)
-
-commit 57393615b31b3788dd77280452d845bcc12d33af
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2015-03-31 22:20:11 +0300
-
- Update THANKS.
-
- THANKS | 1 +
- 1 file changed, 1 insertion(+)
-
-commit 1238381143a9a7ce84839c2582ccd56ff750a440
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2015-03-31 22:19:34 +0300
-
- xz: Add support for sandboxing with Capsicum.
-
- The sandboxing is used conditionally as described in main.c.
- This isn't optimal but it was much easier to implement than
- a full sandboxing solution and it still covers the most common
- use cases where xz is writing to standard output. This should
- have practically no effect on performance even with small files
- as fork() isn't needed.
-
- C and locale libraries can open files as needed. This has been
- fine in the past, but it's a problem with things like Capsicum.
- io_sandbox_enter() tries to ensure that various locale-related
- files have been loaded before cap_enter() is called, but it's
- possible that there are other similar problems which haven't
- been seen yet.
-
- Currently Capsicum is available on FreeBSD 10 and later
- and there is a port to Linux too.
-
- Thanks to Loganaden Velvindron for help.
-
- configure.ac | 41 +++++++++++++++++++++++++++
- src/xz/Makefile.am | 2 +-
- src/xz/file_io.c | 81 ++++++++++++++++++++++++++++++++++++++++++++++++++++++
- src/xz/file_io.h | 6 ++++
- src/xz/main.c | 18 ++++++++++++
- src/xz/private.h | 4 +++
- 6 files changed, 151 insertions(+), 1 deletion(-)
-
-commit 29a087fb5a0c879f0b1bc4c6b989f7b87bacdf9e
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2015-03-31 21:12:30 +0300
-
- Fix bugs and otherwise improve ax_check_capsicum.m4.
-
- AU_ALIAS was removed because the new version is incompatible
- with the old version.
-
- It no longer checks for <sys/capability.h> separately.
- It's enough to test for it as part of AC_CHECK_DECL.
- The defines HAVE_CAPSICUM_SYS_CAPSICUM_H and
- HAVE_CAPSICUM_SYS_CAPABILITY_H were removed as unneeded.
- HAVE_SYS_CAPSICUM_H from AC_CHECK_HEADERS is enough.
-
- It no longer does a useless search for the Capsicum library
- if the header wasn't found.
-
- Fixed a bug in ACTION-IF-FOUND (the first argument). Specifying
- the argument omitted the default action but the given action
- wasn't used instead.
-
- AC_DEFINE([HAVE_CAPSICUM]) is now always called when Capsicum
- support is found. Previously it was part of the default
- ACTION-IF-FOUND which a custom action would override. Now
- the default action only prepends ${CAPSICUM_LIB} to LIBS.
-
- The documentation was updated.
-
- Since there as no serial number, "#serial 2" was added.
-
- m4/ax_check_capsicum.m4 | 103 ++++++++++++++++++++++++------------------------
- 1 file changed, 51 insertions(+), 52 deletions(-)
-
-commit 6e845c6a3eddf2fde9db5a29950421dff60a43ac
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2015-03-31 19:20:24 +0300
-
- Add m4/ax_check_capsicum.m4 for detecting Capsicum support.
-
- The file was loaded from this web page:
- https://github.com/google/capsicum-test/blob/dev/autoconf/m4/ax_check_capsicum.m4
-
- Thanks to Loganaden Velvindron for pointing it out for me.
-
- m4/ax_check_capsicum.m4 | 86 +++++++++++++++++++++++++++++++++++++++++++++++++
- 1 file changed, 86 insertions(+)
-
-commit 3717885f9ef2c06f1bcbad9f4c2ed2d5695f844e
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2015-03-30 22:44:02 +0300
-
- Bump version to 5.3.0alpha and soname to 5.3.99.
-
- The idea of 99 is that it looks a bit weird in this context.
- For new features there's no API/ABI stability in devel versions.
-
- src/liblzma/Makefile.am | 2 +-
- src/liblzma/api/lzma/version.h | 6 +++---
- 2 files changed, 4 insertions(+), 4 deletions(-)
-
-commit eccd8155e107c5ada03d13e7730675cdf1a44ddc
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2015-03-29 22:14:47 +0300
-
- Update THANKS.
-
- THANKS | 1 +
- 1 file changed, 1 insertion(+)
-
-commit 25263fd9e7a8a913395cb93d7c104cd48c2b4a00
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2015-03-29 22:13:48 +0300
-
- Fix the detection of installed RAM on QNX.
-
- The earlier version compiled but didn't actually work
- since sysconf(_SC_PHYS_PAGES) always fails (or so I was told).
-
- Thanks to Ole André Vadla Ravnås for the patch and testing.
-
- m4/tuklib_physmem.m4 | 6 +++---
- src/common/tuklib_physmem.c | 14 +++++++++++++-
- 2 files changed, 16 insertions(+), 4 deletions(-)
-
-commit 4c544d2410903d38402221cb783ed85585b6a007
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2015-03-27 22:39:07 +0200
-
- Fix CPU core count detection on QNX.
-
- It tried to use sysctl() on QNX but
- - it broke the build because sysctl() needs -lsocket on QNX;
- - sysctl() doesn't work for detecting the core count on QNX
- even if it compiled.
-
- sysconf() works. An alternative would have been to use
- QNX-specific SYSPAGE_ENTRY(num_cpu) from <sys/syspage.h>.
-
- Thanks to Ole André Vadla Ravnås.
-
- m4/tuklib_cpucores.m4 | 15 +++++++++++----
- 1 file changed, 11 insertions(+), 4 deletions(-)
-
-commit e0ea6737b03e83ccaff4514d00e31bb926f8f0f3
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2015-03-07 22:05:57 +0200
-
- xz: size_t/uint32_t cleanup in options.c.
-
- src/xz/options.c | 12 ++++++------
- 1 file changed, 6 insertions(+), 6 deletions(-)
-
-commit 8bcca29a65335fd679c13814b70b35b68fa5daed
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2015-03-07 22:04:23 +0200
-
- xz: Fix a comment and silence a warning in message.c.
-
- src/xz/message.c | 5 +++--
- 1 file changed, 3 insertions(+), 2 deletions(-)
-
-commit f243f5f44c6b19a7c289a0ec73a03ee08364cb5b
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2015-03-07 22:01:00 +0200
-
- liblzma: Silence more uint32_t vs. size_t warnings.
-
- src/liblzma/lz/lz_encoder.c | 2 +-
- src/liblzma/lzma/lzma_encoder.c | 2 +-
- 2 files changed, 2 insertions(+), 2 deletions(-)
-
-commit 7f0a4c50f4a374c40acf4b86848f301ad1e82d34
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2015-03-07 19:54:00 +0200
-
- xz: Make arg_count an unsigned int to silence a warning.
-
- Actually the value of arg_count cannot exceed INT_MAX
- but it's nicer as an unsigned int.
-
- src/xz/args.h | 2 +-
- src/xz/main.c | 2 +-
- 2 files changed, 2 insertions(+), 2 deletions(-)
-
-commit f6ec46801588b1be29c07c9db98558b521304002
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2015-03-07 19:33:17 +0200
-
- liblzma: Fix a warning in index.c.
-
- src/liblzma/common/index.c | 4 +++-
- 1 file changed, 3 insertions(+), 1 deletion(-)
-
-commit a24518971cc621315af142dd3bb7614fab04ad27
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2015-02-26 20:46:14 +0200
-
- Build: Fix a CR+LF problem when running autoreconf -fi on OS/2.
-
- build-aux/version.sh | 2 +-
- 1 file changed, 1 insertion(+), 1 deletion(-)
-
-commit dec11497a71518423b5ff0e759100cf8aadf6c7b
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2015-02-26 16:53:44 +0200
-
- Bump version and soname for 5.2.1.
-
- src/liblzma/Makefile.am | 2 +-
- src/liblzma/api/lzma/version.h | 2 +-
- 2 files changed, 2 insertions(+), 2 deletions(-)
-
-commit 29e39c79975ab89ee5dd671e97064534a9f3a649
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2015-02-26 13:01:09 +0200
-
- Update NEWS for 5.2.1.
-
- NEWS | 14 ++++++++++++++
- 1 file changed, 14 insertions(+)
-
-commit 7a11c4a8e5e15f13d5fa59233b3172e65428efdd
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2015-02-22 19:38:48 +0200
-
- xz: Use pipe2() if available.
-
- configure.ac | 4 ++--
- src/xz/file_io.c | 9 ++++++++-
- 2 files changed, 10 insertions(+), 3 deletions(-)
-
-commit 117d962685c72682c63edc9bb765367189800202
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2015-02-21 23:40:26 +0200
-
- liblzma: Fix a compression-ratio regression in LZMA1/2 in fast mode.
-
- The bug was added in the commit
- f48fce093b07aeda95c18850f5e086d9f2383380 and thus
- affected 5.1.4beta and 5.2.0. Luckily the bug cannot
- cause data corruption or other nasty things.
-
- src/liblzma/lzma/lzma_encoder_optimum_fast.c | 2 +-
- 1 file changed, 1 insertion(+), 1 deletion(-)
-
-commit ae984e31c167d3bc52972ec422dd1ebd5f5d5719
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2015-02-21 23:00:19 +0200
-
- xz: Fix the fcntl() usage when creating a pipe for the self-pipe trick.
-
- Now it reads the old flags instead of blindly setting O_NONBLOCK.
- The old code may have worked correctly, but this is better.
-
- src/xz/file_io.c | 16 +++++++++++-----
- 1 file changed, 11 insertions(+), 5 deletions(-)
-
-commit 2205bb5853098aea36a56df6f5747037175f66b4
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2015-02-10 15:29:34 +0200
-
- Update THANKS.
-
- THANKS | 1 +
- 1 file changed, 1 insertion(+)
-
-commit d935b0cdf3db440269b9d952b2b281b18f8c7b08
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2015-02-10 15:28:30 +0200
-
- tuklib_cpucores: Use cpuset_getaffinity() on FreeBSD if available.
-
- In FreeBSD, cpuset_getaffinity() is the preferred way to get
- the number of available cores.
-
- Thanks to Rui Paulo for the patch. I edited it slightly, but
- hopefully I didn't break anything.
-
- m4/tuklib_cpucores.m4 | 23 ++++++++++++++++++++++-
- src/common/tuklib_cpucores.c | 18 ++++++++++++++++++
- 2 files changed, 40 insertions(+), 1 deletion(-)
-
-commit eb61bc58c20769cac4d05f363b9c0e8c9c71a560
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2015-02-09 22:08:37 +0200
-
- xzdiff: Make the mktemp usage compatible with FreeBSD's mktemp.
-
- Thanks to Rui Paulo for the fix.
-
- src/scripts/xzdiff.in | 7 ++++++-
- 1 file changed, 6 insertions(+), 1 deletion(-)
-
-commit b9a5b6b7a29029680af733082b6a46e0fc01623a
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2015-02-03 21:45:53 +0200
-
- Add a few casts to tuklib_integer.h to silence possible warnings.
-
- I heard that Visual Studio 2013 gave warnings without the casts.
-
- Thanks to Gabi Davar.
-
- src/common/tuklib_integer.h | 24 ++++++++++++------------
- 1 file changed, 12 insertions(+), 12 deletions(-)
-
-commit c45757135f40e4a0de730ba5fff0100219493982
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2015-01-26 21:24:39 +0200
-
- liblzma: Set LZMA_MEMCMPLEN_EXTRA depending on the compare method.
-
- src/liblzma/common/memcmplen.h | 15 ++++++++++-----
- 1 file changed, 10 insertions(+), 5 deletions(-)
-
-commit 3c500174ed5485f550972a2a6109c361e875f069
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2015-01-26 20:40:16 +0200
-
- Update THANKS.
-
- THANKS | 1 +
- 1 file changed, 1 insertion(+)
-
-commit fec88d41e672d9e197c9442aecf02bd0dfa6d516
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2015-01-26 20:39:28 +0200
-
- liblzma: Silence harmless Valgrind errors.
-
- Thanks to Torsten Rupp for reporting this. I had
- forgotten to run Valgrind before the 5.2.0 release.
-
- src/liblzma/lz/lz_encoder.c | 6 ++++++
- 1 file changed, 6 insertions(+)
-
-commit a9b45badfec0928d20a27c7176c005fa637f7d1e
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2015-01-09 21:50:19 +0200
-
- xz: Fix comments.
-
- src/xz/file_io.c | 12 ++++++++----
- 1 file changed, 8 insertions(+), 4 deletions(-)
-
-commit 541aee6dd4aa97a809aba281475a21b641bb89e2
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2015-01-09 21:35:06 +0200
-
- Update THANKS.
-
- THANKS | 1 +
- 1 file changed, 1 insertion(+)
-
-commit 4170edc914655310d2363baccf5e615e09b04911
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2015-01-09 21:34:06 +0200
-
- xz: Don't fail if stdout doesn't support O_NONBLOCK.
-
- This is similar to the case with stdin.
-
- Thanks to Brad Smith for the bug report and testing
- on OpenBSD.
-
- src/xz/file_io.c | 36 +++++++++++++++---------------------
- 1 file changed, 15 insertions(+), 21 deletions(-)
-
-commit 04bbc0c2843c50c8ad1cba42b937118e38b0508d
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2015-01-07 19:18:20 +0200
-
- xz: Fix a memory leak in DOS-specific code.
-
- src/xz/file_io.c | 2 ++
- 1 file changed, 2 insertions(+)
-
-commit f0f1f6c7235ffa901cf76fe18e33749e200b3eea
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2015-01-07 19:08:06 +0200
-
- xz: Don't fail if stdin doesn't support O_NONBLOCK.
-
- It's a problem at least on OpenBSD which doesn't support
- O_NONBLOCK on e.g. /dev/null. I'm not surprised if it's
- a problem on other OSes too since this behavior is allowed
- in POSIX-1.2008.
-
- The code relying on this behavior was committed in June 2013
- and included in 5.1.3alpha released on 2013-10-26. Clearly
- the development releases only get limited testing.
-
- src/xz/file_io.c | 18 +++++++-----------
- 1 file changed, 7 insertions(+), 11 deletions(-)
-
-commit d2d484647d9d9d679f03c75abb0404f67069271c
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2015-01-06 20:30:15 +0200
-
- Tests: Don't hide unexpected error messages in test_files.sh.
-
- Hiding them makes no sense since normally there's no error
- when testing the "good" files. With "bad" files errors are
- expected and then it makes sense to keep the messages hidden.
-
- tests/test_files.sh | 4 ++--
- 1 file changed, 2 insertions(+), 2 deletions(-)
-
-commit aae6a6aeda51cf94a47e39ad624728f9bee75e30
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2014-12-30 11:17:16 +0200
-
- Update Solaris notes in INSTALL.
-
- Mention the possible "make check" failure on Solaris in the
- Solaris-specific section of INSTALL. It was already in
- section 4.5 but it is better mention it in the OS-specific
- section too.
-
- INSTALL | 4 ++++
- 1 file changed, 4 insertions(+)
-
-commit 7815112153178800a3521b9f31960e7cdc26cfba
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2014-12-26 12:00:05 +0200
-
- Build: POSIX shell isn't required if scripts are disabled.
-
- INSTALL | 3 ++-
- configure.ac | 2 +-
- 2 files changed, 3 insertions(+), 2 deletions(-)
-
-commit a0cd05ee71d330b79ead6eb9222e1b24e1559d3a
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2014-12-21 20:48:37 +0200
-
- DOS: Update Makefile.
-
- dos/Makefile | 1 +
- 1 file changed, 1 insertion(+)
-
-commit b85ee0905ec4ab7656d22e63519fdd3bedb21f2e
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2014-12-21 19:50:38 +0200
-
- Windows: Fix bin_i486 to bin_i686 in build.bash.
-
- windows/build.bash | 2 +-
- 1 file changed, 1 insertion(+), 1 deletion(-)
-
-commit cbafa710918195dbba3db02c3fab4f0538235206
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2014-12-21 18:58:44 +0200
-
- Docs: Use lzma_cputhreads() in 04_compress_easy_mt.c.
-
- doc/examples/04_compress_easy_mt.c | 30 ++++++++++++++++++++++++++----
- 1 file changed, 26 insertions(+), 4 deletions(-)
-
-commit 8dbb57238d372c7263cfeb3e7f7fd9a73173156a
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2014-12-21 18:56:44 +0200
-
- Docs: Update docs/examples/00_README.txt.
-
- doc/examples/00_README.txt | 4 ++++
- 1 file changed, 4 insertions(+)
-
-commit 6060f7dc76fd6c2a8a1f8e85d0e4d86bb78273e6
-Author: Lasse Collin <lasse.collin@tukaani.org>
-Date: 2014-12-21 18:11:17 +0200
-
- Bump version and soname for 5.2.0.
-
- I know that soname != app version, but I skip AGE=1
- in -version-info to make the soname match the liblzma
- version anyway. It doesn't hurt anything as long as
- it doesn't conflict with library versioning rules.
-
- src/liblzma/Makefile.am | 2 +-
- src/liblzma/api/lzma/version.h | 6 +++---
- src/liblzma/liblzma.map | 2 +-
- 3 files changed, 5 insertions(+), 5 deletions(-)
diff --git a/README b/README
index 9e76301b95cd..ac812ff150ca 100644
--- a/README
+++ b/README
@@ -67,24 +67,27 @@ XZ Utils
1.1. Overall documentation
- README This file
-
- INSTALL.generic Generic install instructions for those not familiar
- with packages using GNU Autotools
- INSTALL Installation instructions specific to XZ Utils
- PACKAGERS Information to packagers of XZ Utils
-
- COPYING XZ Utils copyright and license information
- COPYING.GPLv2 GNU General Public License version 2
- COPYING.GPLv3 GNU General Public License version 3
- COPYING.LGPLv2.1 GNU Lesser General Public License version 2.1
-
- AUTHORS The main authors of XZ Utils
- THANKS Incomplete list of people who have helped making
- this software
- NEWS User-visible changes between XZ Utils releases
- ChangeLog Detailed list of changes (commit log)
- TODO Known bugs and some sort of to-do list
+ README This file
+
+ INSTALL.generic Generic install instructions for those not
+ familiar with packages using GNU Autotools
+ INSTALL Installation instructions specific to XZ Utils
+ PACKAGERS Information to packagers of XZ Utils
+
+ COPYING XZ Utils copyright and license information
+ COPYING.0BSD BSD Zero Clause License
+ COPYING.GPLv2 GNU General Public License version 2
+ COPYING.GPLv3 GNU General Public License version 3
+ COPYING.LGPLv2.1 GNU Lesser General Public License version 2.1
+ COPYING.CC-BY-SA-4.0 Creative Commons Attribution-ShareAlike 4.0
+ International Public License
+
+ AUTHORS The main authors of XZ Utils
+ THANKS Incomplete list of people who have helped making
+ this software
+ NEWS User-visible changes between XZ Utils releases
+ ChangeLog Detailed list of changes (commit log)
+ TODO Known bugs and some sort of to-do list
Note that only some of the above files are included in binary
packages.
@@ -287,11 +290,11 @@ XZ Utils
XZ Embedded is a limited implementation written for use in the Linux
kernel, but it is also suitable for other embedded use.
- https://tukaani.org/xz/embedded.html
+ https://xz.tukaani.org/xz-embedded/
XZ for Java is a complete implementation written in pure Java.
- https://tukaani.org/xz/java.html
+ https://xz.tukaani.org/xz-for-java/
6. Contact information
diff --git a/THANKS b/THANKS
index 0206af938f1a..9bb90c77640c 100644
--- a/THANKS
+++ b/THANKS
@@ -5,6 +5,7 @@ Thanks
Some people have helped more, some less, but nevertheless everyone's help
has been important. :-) In alphabetical order:
- Mark Adler
+ - Kian-Meng Ang
- H. Peter Anvin
- Jeff Bastian
- Nelson H. F. Beebe
@@ -51,9 +52,11 @@ has been important. :-) In alphabetical order:
- Bjarni Ingi Gislason
- John Paul Adrian Glaubitz
- Bill Glessner
+ - Matthew Good
- Michał Górny
- Jason Gorski
- Juan Manuel Guerrero
+ - Gabriela Gutierrez
- Diederik de Haas
- Joachim Henke
- Christian Hesse
@@ -62,6 +65,7 @@ has been important. :-) In alphabetical order:
- Nicholas Jackson
- Sam James
- Hajin Jang
+ - Hans Jansen
- Jouk Jansen
- Jun I Jin
- Kiyoshi Kanazawa
@@ -79,6 +83,7 @@ has been important. :-) In alphabetical order:
- Ilya Kurdyukov
- Peter Lawler
- James M Leddy
+ - Kelvin Lee
- Vincent Lefevre
- Hin-Tak Leung
- Andraž 'ruskie' Levstik
@@ -89,6 +94,7 @@ has been important. :-) In alphabetical order:
- Lorenzo De Liso
- H.J. Lu
- Bela Lubkin
+ - Chenxi Mao
- Gregory Margo
- Julien Marrec
- Ed Maste
@@ -150,6 +156,7 @@ has been important. :-) In alphabetical order:
- Mohammed Adnène Trojette
- Alexey Tourbin
- Taiki Tsunekawa
+ - Maksym Vatsyk
- Loganaden Velvindron
- Patrick J. Volkerding
- Martin Väth
diff --git a/TODO b/TODO
index 7b9a3adfc716..ad37f3f559aa 100644
--- a/TODO
+++ b/TODO
@@ -24,10 +24,6 @@ Known bugs
tuklib_exit() doesn't block signals => EINTR is possible.
- SIGTSTP is not handled. If xz is stopped, the estimated remaining
- time and calculated (de)compression speed won't make sense in the
- progress indicator (xz --verbose).
-
If liblzma has created threads and fork() gets called, liblzma
code will break in the child process unless it calls exec() and
doesn't touch liblzma.
diff --git a/doxygen/Doxyfile b/doxygen/Doxyfile
index 14350cf44f64..b96ba5cab413 100644
--- a/doxygen/Doxyfile
+++ b/doxygen/Doxyfile
@@ -61,7 +61,7 @@ PROJECT_BRIEF =
# pixels and the maximum width should not exceed 200 pixels. Doxygen will copy
# the logo to the output directory.
-PROJECT_LOGO =
+PROJECT_LOGO = ../doc/xz-logo.png
# The OUTPUT_DIRECTORY tag is used to specify the (relative or absolute) path
# into which the generated documentation will be written. If a relative path is
@@ -1246,7 +1246,7 @@ HTML_HEADER =
# that doxygen normally uses.
# This tag requires that the tag GENERATE_HTML is set to YES.
-HTML_FOOTER =
+HTML_FOOTER = footer.html
# The HTML_STYLESHEET tag can be used to specify a user-defined cascading style
# sheet that is used by each HTML page. It can be used to fine-tune the look of
@@ -1286,7 +1286,7 @@ HTML_EXTRA_STYLESHEET =
# files will be copied as-is; there are no commands or markers available.
# This tag requires that the tag GENERATE_HTML is set to YES.
-HTML_EXTRA_FILES =
+HTML_EXTRA_FILES = ../COPYING.CC-BY-SA-4.0
# The HTML_COLORSTYLE tag can be used to specify if the generated HTML output
# should be rendered with a dark or light theme.
diff --git a/doxygen/footer.html b/doxygen/footer.html
new file mode 100644
index 000000000000..38d6ea0f4364
--- /dev/null
+++ b/doxygen/footer.html
@@ -0,0 +1,13 @@
+<hr class="footer"/>
+
+<p style="text-align: right;padding-right: 12px;">
+ XZ logo &copy; 2023 by Jia Tan is licensed under
+ <a href="COPYING.CC-BY-SA-4.0"
+ rel="license"
+ style="display:inline-block;">
+ CC BY-SA 4.0
+ </a>
+</p>
+
+</body>
+</html>
diff --git a/doxygen/update-doxygen b/doxygen/update-doxygen
index a5103199a8d1..87dfffb29e75 100755
--- a/doxygen/update-doxygen
+++ b/doxygen/update-doxygen
@@ -1,5 +1,6 @@
#!/bin/sh
-#
+# SPDX-License-Identifier: 0BSD
+
#############################################################################
#
# Updates the Doxygen generated documentation files in the source tree.
@@ -16,9 +17,6 @@
# Authors: Jia Tan
# Lasse Collin
#
-# This file has been put into the public domain.
-# You can do whatever you want with this file.
-#
#############################################################################
set -e
diff --git a/src/common/mythread.h b/src/common/mythread.h
index 4495e017b290..589901c7d3e1 100644
--- a/src/common/mythread.h
+++ b/src/common/mythread.h
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file mythread.h
@@ -5,9 +7,6 @@
//
// Author: Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
#ifndef MYTHREAD_H
@@ -112,6 +111,25 @@ mythread_sigmask(int how, const sigset_t *restrict set,
# include <sys/time.h>
#endif
+// MinGW-w64 with winpthreads:
+//
+// NOTE: Typical builds with MinGW-w64 don't use this code (MYTHREAD_POSIX).
+// Instead, native Windows threading APIs are used (MYTHREAD_VISTA or
+// MYTHREAD_WIN95).
+//
+// MinGW-w64 has _sigset_t (an integer type) in <sys/types.h>.
+// If _POSIX was #defined, the header would add the alias sigset_t too.
+// Let's keep this working even without _POSIX.
+//
+// There are no functions that actually do something with sigset_t
+// because signals barely exist on Windows. The sigfillset macro below
+// is just to silence warnings. There is no sigfillset() in MinGW-w64.
+#ifdef __MINGW32__
+# include <sys/types.h>
+# define sigset_t _sigset_t
+# define sigfillset(set_ptr) do { *(set_ptr) = 0; } while (0)
+#endif
+
#define MYTHREAD_RET_TYPE void *
#define MYTHREAD_RET_VALUE NULL
@@ -140,11 +158,13 @@ typedef struct timespec mythread_condtime;
// Use pthread_sigmask() to set the signal mask in multi-threaded programs.
// Do nothing on OpenVMS since it lacks pthread_sigmask().
+// Do nothing on MinGW-w64 too to silence warnings (its pthread_sigmask()
+// is #defined to 0 so it's a no-op).
static inline void
mythread_sigmask(int how, const sigset_t *restrict set,
sigset_t *restrict oset)
{
-#ifdef __VMS
+#if defined(__VMS) || defined(__MINGW32__)
(void)how;
(void)set;
(void)oset;
diff --git a/src/common/sysdefs.h b/src/common/sysdefs.h
index f04e45dd2147..5f3785b5137a 100644
--- a/src/common/sysdefs.h
+++ b/src/common/sysdefs.h
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file sysdefs.h
@@ -8,9 +10,6 @@
//
// Author: Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
#ifndef LZMA_SYSDEFS_H
@@ -159,13 +158,16 @@ typedef unsigned char _Bool;
#include <string.h>
-// As of MSVC 2013, inline and restrict are supported with
-// non-standard keywords.
-#if defined(_WIN32) && defined(_MSC_VER)
-# ifndef inline
+// Visual Studio 2013 update 2 supports only __inline, not inline.
+// MSVC v19.0 / VS 2015 and newer support both.
+//
+// MSVC v19.27 (VS 2019 version 16.7) added support for restrict.
+// Older ones support only __restrict.
+#ifdef _MSC_VER
+# if _MSC_VER < 1900 && !defined(inline)
# define inline __inline
# endif
-# ifndef restrict
+# if _MSC_VER < 1927 && !defined(restrict)
# define restrict __restrict
# endif
#endif
diff --git a/src/common/tuklib_common.h b/src/common/tuklib_common.h
index b1f531ea4a68..7554dfc86fb6 100644
--- a/src/common/tuklib_common.h
+++ b/src/common/tuklib_common.h
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file tuklib_common.h
@@ -5,9 +7,6 @@
//
// Author: Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
#ifndef TUKLIB_COMMON_H
@@ -57,8 +56,28 @@
# define TUKLIB_GNUC_REQ(major, minor) 0
#endif
-#if TUKLIB_GNUC_REQ(2, 5)
+// tuklib_attr_noreturn attribute is used to mark functions as non-returning.
+// We cannot use "noreturn" as the macro name because then C23 code that
+// uses [[noreturn]] would break as it would expand to [[ [[noreturn]] ]].
+//
+// tuklib_attr_noreturn must be used at the beginning of function declaration
+// to work in all cases. The [[noreturn]] syntax is the most limiting, it
+// must be even before any GNU C's __attribute__ keywords:
+//
+// tuklib_attr_noreturn
+// __attribute__((nonnull(1)))
+// extern void foo(const char *s);
+//
+// FIXME: Update __STDC_VERSION__ for the final C23 version. 202000 is used
+// by GCC 13 and Clang 15 with -std=c2x.
+#if defined(__STDC_VERSION__) && __STDC_VERSION__ >= 202000
+# define tuklib_attr_noreturn [[noreturn]]
+#elif defined(__STDC_VERSION__) && __STDC_VERSION__ >= 201112
+# define tuklib_attr_noreturn _Noreturn
+#elif TUKLIB_GNUC_REQ(2, 5)
# define tuklib_attr_noreturn __attribute__((__noreturn__))
+#elif defined(_MSC_VER)
+# define tuklib_attr_noreturn __declspec(noreturn)
#else
# define tuklib_attr_noreturn
#endif
diff --git a/src/common/tuklib_config.h b/src/common/tuklib_config.h
index 9d470ba732f1..b27251dc2765 100644
--- a/src/common/tuklib_config.h
+++ b/src/common/tuklib_config.h
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
// If config.h isn't available, assume that the headers required by
// tuklib_common.h are available. This is required by crc32_tablegen.c.
#ifdef HAVE_CONFIG_H
diff --git a/src/common/tuklib_cpucores.c b/src/common/tuklib_cpucores.c
index bb3f2f752b1b..c4a781ac387c 100644
--- a/src/common/tuklib_cpucores.c
+++ b/src/common/tuklib_cpucores.c
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file tuklib_cpucores.c
@@ -5,9 +7,6 @@
//
// Author: Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
#include "tuklib_cpucores.h"
diff --git a/src/common/tuklib_cpucores.h b/src/common/tuklib_cpucores.h
index be1ce1c175ae..edff9395e41c 100644
--- a/src/common/tuklib_cpucores.h
+++ b/src/common/tuklib_cpucores.h
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file tuklib_cpucores.h
@@ -5,9 +7,6 @@
//
// Author: Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
#ifndef TUKLIB_CPUCORES_H
diff --git a/src/common/tuklib_exit.c b/src/common/tuklib_exit.c
index aa55620ec563..c84e0f679a64 100644
--- a/src/common/tuklib_exit.c
+++ b/src/common/tuklib_exit.c
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file tuklib_exit.c
@@ -5,9 +7,6 @@
//
// Author: Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
#include "tuklib_common.h"
diff --git a/src/common/tuklib_exit.h b/src/common/tuklib_exit.h
index b11776f0e5bf..d4e6b4a7e832 100644
--- a/src/common/tuklib_exit.h
+++ b/src/common/tuklib_exit.h
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file tuklib_exit.h
@@ -6,9 +8,6 @@
//
// Author: Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
#ifndef TUKLIB_EXIT_H
@@ -18,8 +17,8 @@
TUKLIB_DECLS_BEGIN
#define tuklib_exit TUKLIB_SYMBOL(tuklib_exit)
-extern void tuklib_exit(int status, int err_status, int show_error)
- tuklib_attr_noreturn;
+tuklib_attr_noreturn
+extern void tuklib_exit(int status, int err_status, int show_error);
TUKLIB_DECLS_END
#endif
diff --git a/src/common/tuklib_gettext.h b/src/common/tuklib_gettext.h
index ff1890407125..3ef5cb7292b5 100644
--- a/src/common/tuklib_gettext.h
+++ b/src/common/tuklib_gettext.h
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file tuklib_gettext.h
@@ -5,9 +7,6 @@
//
// Author: Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
#ifndef TUKLIB_GETTEXT_H
diff --git a/src/common/tuklib_integer.h b/src/common/tuklib_integer.h
index e22aa8ad83b2..c0004531a710 100644
--- a/src/common/tuklib_integer.h
+++ b/src/common/tuklib_integer.h
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file tuklib_integer.h
@@ -37,9 +39,6 @@
// Authors: Lasse Collin
// Joachim Henke
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
#ifndef TUKLIB_INTEGER_H
@@ -251,7 +250,7 @@
// was one instruction longer.
//
// Conclusion: At least in case of GCC and Clang, byte-by-byte code is
-// the best choise for strict-align archs to do unaligned access.
+// the best choice for strict-align archs to do unaligned access.
//
// See also: https://gcc.gnu.org/bugzilla/show_bug.cgi?id=111502
//
diff --git a/src/common/tuklib_mbstr.h b/src/common/tuklib_mbstr.h
index dde9305f0a1c..4c8eeb7e3700 100644
--- a/src/common/tuklib_mbstr.h
+++ b/src/common/tuklib_mbstr.h
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file tuklib_mbstr.h
@@ -10,9 +12,6 @@
//
// Author: Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
#ifndef TUKLIB_MBSTR_H
diff --git a/src/common/tuklib_mbstr_fw.c b/src/common/tuklib_mbstr_fw.c
index 64c9ad5ae372..22d883b569fe 100644
--- a/src/common/tuklib_mbstr_fw.c
+++ b/src/common/tuklib_mbstr_fw.c
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file tuklib_mbstr_fw.c
@@ -5,9 +7,6 @@
//
// Author: Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
#include "tuklib_mbstr.h"
diff --git a/src/common/tuklib_mbstr_width.c b/src/common/tuklib_mbstr_width.c
index 69d159e0bbcc..7a8bf0707518 100644
--- a/src/common/tuklib_mbstr_width.c
+++ b/src/common/tuklib_mbstr_width.c
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file tuklib_mbstr_width.c
@@ -5,9 +7,6 @@
//
// Author: Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
#include "tuklib_mbstr.h"
diff --git a/src/common/tuklib_open_stdxxx.c b/src/common/tuklib_open_stdxxx.c
index 26702a6afab0..b93e61d3b688 100644
--- a/src/common/tuklib_open_stdxxx.c
+++ b/src/common/tuklib_open_stdxxx.c
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file tuklib_open_stdxxx.c
@@ -5,9 +7,6 @@
//
// Author: Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
#include "tuklib_open_stdxxx.h"
diff --git a/src/common/tuklib_open_stdxxx.h b/src/common/tuklib_open_stdxxx.h
index b91161609ee6..3ee3ade35527 100644
--- a/src/common/tuklib_open_stdxxx.h
+++ b/src/common/tuklib_open_stdxxx.h
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file tuklib_open_stdxxx.h
@@ -5,9 +7,6 @@
//
// Author: Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
#ifndef TUKLIB_OPEN_STDXXX_H
diff --git a/src/common/tuklib_physmem.c b/src/common/tuklib_physmem.c
index 69f6fd4c8663..1009df14d9d1 100644
--- a/src/common/tuklib_physmem.c
+++ b/src/common/tuklib_physmem.c
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file tuklib_physmem.c
@@ -5,9 +7,6 @@
//
// Author: Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
#include "tuklib_physmem.h"
@@ -73,23 +72,20 @@
#endif
-// With GCC >= 8.1 with -Wextra and Clang >= 13 with -Wcast-function-type
-// will warn about the Windows-specific code.
-#if defined(__has_warning)
-# if __has_warning("-Wcast-function-type")
-# define CAN_DISABLE_WCAST_FUNCTION_TYPE 1
-# endif
-#elif TUKLIB_GNUC_REQ(8,1)
-# define CAN_DISABLE_WCAST_FUNCTION_TYPE 1
-#endif
-
-
extern uint64_t
tuklib_physmem(void)
{
uint64_t ret = 0;
#if defined(_WIN32) || defined(__CYGWIN__)
+ // This requires Windows 2000 or later.
+ MEMORYSTATUSEX meminfo;
+ meminfo.dwLength = sizeof(meminfo);
+ if (GlobalMemoryStatusEx(&meminfo))
+ ret = meminfo.ullTotalPhys;
+
+/*
+ // Old version that is compatible with even Win95:
if ((GetVersion() & 0xFF) >= 5) {
// Windows 2000 and later have GlobalMemoryStatusEx() which
// supports reporting values greater than 4 GiB. To keep the
@@ -125,6 +121,7 @@ tuklib_physmem(void)
GlobalMemoryStatus(&meminfo);
ret = meminfo.dwTotalPhys;
}
+*/
#elif defined(__OS2__)
unsigned long mem;
diff --git a/src/common/tuklib_physmem.h b/src/common/tuklib_physmem.h
index 09e2a51338ae..f35bfbab9c16 100644
--- a/src/common/tuklib_physmem.h
+++ b/src/common/tuklib_physmem.h
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file tuklib_physmem.h
@@ -5,9 +7,6 @@
//
// Author: Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
#ifndef TUKLIB_PHYSMEM_H
diff --git a/src/common/tuklib_progname.c b/src/common/tuklib_progname.c
index e2ef4e555f35..959c1270ce32 100644
--- a/src/common/tuklib_progname.c
+++ b/src/common/tuklib_progname.c
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file tuklib_progname.c
@@ -5,9 +7,6 @@
//
// Author: Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
#include "tuklib_progname.h"
diff --git a/src/common/tuklib_progname.h b/src/common/tuklib_progname.h
index bb80f25e0381..a3d90cb1f21a 100644
--- a/src/common/tuklib_progname.h
+++ b/src/common/tuklib_progname.h
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file tuklib_progname.h
@@ -5,9 +7,6 @@
//
// Author: Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
#ifndef TUKLIB_PROGNAME_H
diff --git a/src/liblzma/api/lzma.h b/src/liblzma/api/lzma.h
index de12f225859f..d55349f47ec9 100644
--- a/src/liblzma/api/lzma.h
+++ b/src/liblzma/api/lzma.h
@@ -1,31 +1,30 @@
+/* SPDX-License-Identifier: 0BSD */
+
/**
* \file api/lzma.h
* \brief The public API of liblzma data compression library
* \mainpage
*
- * liblzma is a public domain general-purpose data compression library with
- * a zlib-like API. The native file format is .xz, but also the old .lzma
- * format and raw (no headers) streams are supported. Multiple compression
- * algorithms (filters) are supported. Currently LZMA2 is the primary filter.
+ * liblzma is a general-purpose data compression library with a zlib-like API.
+ * The native file format is .xz, but also the old .lzma format and raw (no
+ * headers) streams are supported. Multiple compression algorithms (filters)
+ * are supported. Currently LZMA2 is the primary filter.
+ *
+ * liblzma is part of XZ Utils <https://xz.tukaani.org/xz-utils/>. XZ Utils
+ * includes a gzip-like command line tool named xz and some other tools.
+ * XZ Utils is developed and maintained by Lasse Collin and Jia Tan.
*
- * liblzma is part of XZ Utils <https://tukaani.org/xz/>. XZ Utils includes
- * a gzip-like command line tool named xz and some other tools. XZ Utils
- * is developed and maintained by Lasse Collin and Jia Tan.
+ * Major parts of liblzma are based on code written by Igor Pavlov,
+ * specifically the LZMA SDK <https://7-zip.org/sdk.html>.
*
- * Major parts of liblzma are based on Igor Pavlov's public domain LZMA SDK
- * <https://7-zip.org/sdk.html>.
+ * The SHA-256 implementation in liblzma is based on code written by
+ * Wei Dai in Crypto++ Library <https://www.cryptopp.com/>.
*
- * The SHA-256 implementation is based on the public domain code found from
- * 7-Zip <https://7-zip.org/>, which has a modified version of the public
- * domain SHA-256 code found from Crypto++ <https://www.cryptopp.com/>.
- * The SHA-256 code in Crypto++ was written by Kevin Springle and Wei Dai.
+ * liblzma is distributed under the BSD Zero Clause License (0BSD).
*/
/*
* Author: Lasse Collin
- *
- * This file has been put into the public domain.
- * You can do whatever you want with this file.
*/
#ifndef LZMA_H
diff --git a/src/liblzma/api/lzma/base.h b/src/liblzma/api/lzma/base.h
index 75cdd72acf20..20d485b97bec 100644
--- a/src/liblzma/api/lzma/base.h
+++ b/src/liblzma/api/lzma/base.h
@@ -1,3 +1,5 @@
+/* SPDX-License-Identifier: 0BSD */
+
/**
* \file lzma/base.h
* \brief Data types and functions used in many places in liblzma API
@@ -6,9 +8,6 @@
/*
* Author: Lasse Collin
- *
- * This file has been put into the public domain.
- * You can do whatever you want with this file.
*/
#ifndef LZMA_H_INTERNAL
@@ -21,8 +20,8 @@
*
* This is here because C89 doesn't have stdbool.h. To set a value for
* variables having type lzma_bool, you can use
- * - C99's `true' and `false' from stdbool.h;
- * - C++'s internal `true' and `false'; or
+ * - C99's 'true' and 'false' from stdbool.h;
+ * - C++'s internal 'true' and 'false'; or
* - integers one (true) and zero (false).
*/
typedef unsigned char lzma_bool;
@@ -273,13 +272,13 @@ typedef enum {
/**
- * \brief The `action' argument for lzma_code()
+ * \brief The 'action' argument for lzma_code()
*
* After the first use of LZMA_SYNC_FLUSH, LZMA_FULL_FLUSH, LZMA_FULL_BARRIER,
- * or LZMA_FINISH, the same `action' must be used until lzma_code() returns
+ * or LZMA_FINISH, the same 'action' must be used until lzma_code() returns
* LZMA_STREAM_END. Also, the amount of input (that is, strm->avail_in) must
* not be modified by the application until lzma_code() returns
- * LZMA_STREAM_END. Changing the `action' or modifying the amount of input
+ * LZMA_STREAM_END. Changing the 'action' or modifying the amount of input
* will make lzma_code() return LZMA_PROG_ERROR.
*/
typedef enum {
@@ -393,8 +392,8 @@ typedef enum {
* Single-threaded mode only: liblzma doesn't make an internal copy of
* lzma_allocator. Thus, it is OK to change these function pointers in
* the middle of the coding process, but obviously it must be done
- * carefully to make sure that the replacement `free' can deallocate
- * memory allocated by the earlier `alloc' function(s).
+ * carefully to make sure that the replacement 'free' can deallocate
+ * memory allocated by the earlier 'alloc' function(s).
*
* Multithreaded mode: liblzma might internally store pointers to the
* lzma_allocator given via the lzma_stream structure. The application
@@ -422,7 +421,7 @@ typedef struct {
* liblzma never sets this to zero.
*
* \return Pointer to the beginning of a memory block of
- * `size' bytes, or NULL if allocation fails
+ * 'size' bytes, or NULL if allocation fails
* for some reason. When allocation fails, functions
* of liblzma return LZMA_MEM_ERROR.
*
@@ -622,7 +621,7 @@ typedef struct {
* to and get output from liblzma.
*
* See the description of the coder-specific initialization function to find
- * out what `action' values are supported by the coder.
+ * out what 'action' values are supported by the coder.
*
* \param strm Pointer to lzma_stream that is at least initialized
* with LZMA_STREAM_INIT.
diff --git a/src/liblzma/api/lzma/bcj.h b/src/liblzma/api/lzma/bcj.h
index 0c84e0cff901..7f6611feb325 100644
--- a/src/liblzma/api/lzma/bcj.h
+++ b/src/liblzma/api/lzma/bcj.h
@@ -1,3 +1,5 @@
+/* SPDX-License-Identifier: 0BSD */
+
/**
* \file lzma/bcj.h
* \brief Branch/Call/Jump conversion filters
@@ -6,9 +8,6 @@
/*
* Author: Lasse Collin
- *
- * This file has been put into the public domain.
- * You can do whatever you want with this file.
*/
#ifndef LZMA_H_INTERNAL
@@ -53,6 +52,11 @@
*/
#define LZMA_FILTER_ARM64 LZMA_VLI_C(0x0A)
+/**
+ * \brief Filter for RISC-V binaries
+ */
+#define LZMA_FILTER_RISCV LZMA_VLI_C(0x0B)
+
/**
* \brief Options for BCJ filters
diff --git a/src/liblzma/api/lzma/block.h b/src/liblzma/api/lzma/block.h
index ec5e77a69ae9..05b77e59aabb 100644
--- a/src/liblzma/api/lzma/block.h
+++ b/src/liblzma/api/lzma/block.h
@@ -1,3 +1,5 @@
+/* SPDX-License-Identifier: 0BSD */
+
/**
* \file lzma/block.h
* \brief .xz Block handling
@@ -6,9 +8,6 @@
/*
* Author: Lasse Collin
- *
- * This file has been put into the public domain.
- * You can do whatever you want with this file.
*/
#ifndef LZMA_H_INTERNAL
diff --git a/src/liblzma/api/lzma/check.h b/src/liblzma/api/lzma/check.h
index b37197d2c7f7..e7a50ed3a3c3 100644
--- a/src/liblzma/api/lzma/check.h
+++ b/src/liblzma/api/lzma/check.h
@@ -1,3 +1,5 @@
+/* SPDX-License-Identifier: 0BSD */
+
/**
* \file lzma/check.h
* \brief Integrity checks
@@ -6,9 +8,6 @@
/*
* Author: Lasse Collin
- *
- * This file has been put into the public domain.
- * You can do whatever you want with this file.
*/
#ifndef LZMA_H_INTERNAL
diff --git a/src/liblzma/api/lzma/container.h b/src/liblzma/api/lzma/container.h
index 2849fbfd3c51..ad3f99057a32 100644
--- a/src/liblzma/api/lzma/container.h
+++ b/src/liblzma/api/lzma/container.h
@@ -1,3 +1,5 @@
+/* SPDX-License-Identifier: 0BSD */
+
/**
* \file lzma/container.h
* \brief File formats
@@ -6,9 +8,6 @@
/*
* Author: Lasse Collin
- *
- * This file has been put into the public domain.
- * You can do whatever you want with this file.
*/
#ifndef LZMA_H_INTERNAL
@@ -297,7 +296,7 @@ extern LZMA_API(uint64_t) lzma_easy_decoder_memusage(uint32_t preset)
* to call lzma_end() after failed initialization.
*
* If initialization succeeds, use lzma_code() to do the actual encoding.
- * Valid values for `action' (the second argument of lzma_code()) are
+ * Valid values for 'action' (the second argument of lzma_code()) are
* LZMA_RUN, LZMA_SYNC_FLUSH, LZMA_FULL_FLUSH, and LZMA_FINISH. In future,
* there may be compression levels or flags that don't support LZMA_SYNC_FLUSH.
*
@@ -436,6 +435,34 @@ extern LZMA_API(lzma_ret) lzma_stream_encoder_mt(
/**
+ * \brief Calculate recommended Block size for multithreaded .xz encoder
+ *
+ * This calculates a recommended Block size for multithreaded encoding given
+ * a filter chain. This is used internally by lzma_stream_encoder_mt() to
+ * determine the Block size if the block_size member is not set to the
+ * special value of 0 in the lzma_mt options struct.
+ *
+ * If one wishes to change the filters between Blocks, this function is
+ * helpful to set the block_size member of the lzma_mt struct before calling
+ * lzma_stream_encoder_mt(). Since the block_size member represents the
+ * maximum possible Block size for the multithreaded .xz encoder, one can
+ * use this function to find the maximum recommended Block size based on
+ * all planned filter chains. Otherwise, the multithreaded encoder will
+ * base its maximum Block size on the first filter chain used (if the
+ * block_size member is not set), which may unnecessarily limit the Block
+ * size for a later filter chain.
+ *
+ * \param filters Array of filters terminated with
+ * .id == LZMA_VLI_UNKNOWN.
+ *
+ * \return Recommended Block size in bytes, or UINT64_MAX if
+ * an error occurred.
+ */
+extern LZMA_API(uint64_t) lzma_mt_block_size(const lzma_filter *filters)
+ lzma_nothrow;
+
+
+/**
* \brief Initialize .lzma encoder (legacy file format)
*
* The .lzma format is sometimes called the LZMA_Alone format, which is the
@@ -651,13 +678,13 @@ extern LZMA_API(lzma_ret) lzma_microlzma_encoder(
* supported by liblzma, only the .xz and .lz formats allow concatenated
* files. Concatenated files are not allowed with the legacy .lzma format.
*
- * This flag also affects the usage of the `action' argument for lzma_code().
+ * This flag also affects the usage of the 'action' argument for lzma_code().
* When LZMA_CONCATENATED is used, lzma_code() won't return LZMA_STREAM_END
- * unless LZMA_FINISH is used as `action'. Thus, the application has to set
+ * unless LZMA_FINISH is used as 'action'. Thus, the application has to set
* LZMA_FINISH in the same way as it does when encoding.
*
* If LZMA_CONCATENATED is not used, the decoders still accept LZMA_FINISH
- * as `action' for lzma_code(), but the usage of LZMA_FINISH isn't required.
+ * as 'action' for lzma_code(), but the usage of LZMA_FINISH isn't required.
*/
#define LZMA_CONCATENATED UINT32_C(0x08)
@@ -791,7 +818,7 @@ extern LZMA_API(lzma_ret) lzma_auto_decoder(
/**
* \brief Initialize .lzma decoder (legacy file format)
*
- * Valid `action' arguments to lzma_code() are LZMA_RUN and LZMA_FINISH.
+ * Valid 'action' arguments to lzma_code() are LZMA_RUN and LZMA_FINISH.
* There is no need to use LZMA_FINISH, but it's allowed because it may
* simplify certain types of applications.
*
diff --git a/src/liblzma/api/lzma/delta.h b/src/liblzma/api/lzma/delta.h
index 7a725bc40742..5ebacef81584 100644
--- a/src/liblzma/api/lzma/delta.h
+++ b/src/liblzma/api/lzma/delta.h
@@ -1,3 +1,5 @@
+/* SPDX-License-Identifier: 0BSD */
+
/**
* \file lzma/delta.h
* \brief Delta filter
@@ -6,9 +8,6 @@
/*
* Author: Lasse Collin
- *
- * This file has been put into the public domain.
- * You can do whatever you want with this file.
*/
#ifndef LZMA_H_INTERNAL
diff --git a/src/liblzma/api/lzma/filter.h b/src/liblzma/api/lzma/filter.h
index 1d887b4f2f43..e86809c4e395 100644
--- a/src/liblzma/api/lzma/filter.h
+++ b/src/liblzma/api/lzma/filter.h
@@ -1,3 +1,5 @@
+/* SPDX-License-Identifier: 0BSD */
+
/**
* \file lzma/filter.h
* \brief Common filter related types and functions
@@ -6,9 +8,6 @@
/*
* Author: Lasse Collin
- *
- * This file has been put into the public domain.
- * You can do whatever you want with this file.
*/
#ifndef LZMA_H_INTERNAL
@@ -43,7 +42,7 @@ typedef struct {
/**
* \brief Filter ID
*
- * Use constants whose name begin with `LZMA_FILTER_' to specify
+ * Use constants whose name begin with 'LZMA_FILTER_' to specify
* different filters. In an array of lzma_filter structures, use
* LZMA_VLI_UNKNOWN to indicate end of filters.
*
@@ -199,7 +198,7 @@ extern LZMA_API(uint64_t) lzma_raw_decoder_memusage(const lzma_filter *filters)
*
* This function may be useful when implementing custom file formats.
*
- * The `action' with lzma_code() can be LZMA_RUN, LZMA_SYNC_FLUSH (if the
+ * The 'action' with lzma_code() can be LZMA_RUN, LZMA_SYNC_FLUSH (if the
* filter chain supports it), or LZMA_FINISH.
*
* \param strm Pointer to lzma_stream that is at least
@@ -223,7 +222,7 @@ extern LZMA_API(lzma_ret) lzma_raw_encoder(
*
* The initialization of raw decoder goes similarly to raw encoder.
*
- * The `action' with lzma_code() can be LZMA_RUN or LZMA_FINISH. Using
+ * The 'action' with lzma_code() can be LZMA_RUN or LZMA_FINISH. Using
* LZMA_FINISH is not required, it is supported just for convenience.
*
* \param strm Pointer to lzma_stream that is at least
diff --git a/src/liblzma/api/lzma/hardware.h b/src/liblzma/api/lzma/hardware.h
index f34897d8740f..7a1a84fcccfc 100644
--- a/src/liblzma/api/lzma/hardware.h
+++ b/src/liblzma/api/lzma/hardware.h
@@ -1,3 +1,5 @@
+/* SPDX-License-Identifier: 0BSD */
+
/**
* \file lzma/hardware.h
* \brief Hardware information
@@ -23,9 +25,6 @@
/*
* Author: Lasse Collin
- *
- * This file has been put into the public domain.
- * You can do whatever you want with this file.
*/
#ifndef LZMA_H_INTERNAL
diff --git a/src/liblzma/api/lzma/index.h b/src/liblzma/api/lzma/index.h
index 6eee4d68137d..7d8a9950ceaf 100644
--- a/src/liblzma/api/lzma/index.h
+++ b/src/liblzma/api/lzma/index.h
@@ -1,3 +1,5 @@
+/* SPDX-License-Identifier: 0BSD */
+
/**
* \file lzma/index.h
* \brief Handling of .xz Index and related information
@@ -6,9 +8,6 @@
/*
* Author: Lasse Collin
- *
- * This file has been put into the public domain.
- * You can do whatever you want with this file.
*/
#ifndef LZMA_H_INTERNAL
@@ -302,6 +301,28 @@ typedef enum {
/**
+ * \brief Mask for return value from lzma_index_checks() for check none
+ *
+ * \note This and the other CHECK_MASK macros were added in 5.5.1alpha.
+ */
+#define LZMA_INDEX_CHECK_MASK_NONE (UINT32_C(1) << LZMA_CHECK_NONE)
+
+/**
+ * \brief Mask for return value from lzma_index_checks() for check CRC32
+ */
+#define LZMA_INDEX_CHECK_MASK_CRC32 (UINT32_C(1) << LZMA_CHECK_CRC32)
+
+/**
+ * \brief Mask for return value from lzma_index_checks() for check CRC64
+ */
+#define LZMA_INDEX_CHECK_MASK_CRC64 (UINT32_C(1) << LZMA_CHECK_CRC64)
+
+/**
+ * \brief Mask for return value from lzma_index_checks() for check SHA256
+ */
+#define LZMA_INDEX_CHECK_MASK_SHA256 (UINT32_C(1) << LZMA_CHECK_SHA256)
+
+/**
* \brief Calculate memory usage of lzma_index
*
* On disk, the size of the Index field depends on both the number of Records
@@ -431,6 +452,7 @@ extern LZMA_API(lzma_ret) lzma_index_stream_flags(
* showing the Check types to the user.
*
* The bitmask is 1 << check_id, e.g. CRC32 is 1 << 1 and SHA-256 is 1 << 10.
+ * These masks are defined for convenience as LZMA_INDEX_CHECK_MASK_XXX
*
* \param i Pointer to lzma_index structure
*
@@ -686,7 +708,7 @@ extern LZMA_API(lzma_index *) lzma_index_dup(
* \param strm Pointer to properly prepared lzma_stream
* \param i Pointer to lzma_index which should be encoded.
*
- * The valid `action' values for lzma_code() are LZMA_RUN and LZMA_FINISH.
+ * The valid 'action' values for lzma_code() are LZMA_RUN and LZMA_FINISH.
* It is enough to use only one of them (you can choose freely).
*
* \return Possible lzma_ret values:
@@ -715,7 +737,7 @@ extern LZMA_API(lzma_ret) lzma_index_encoder(
* don't allow 0 here and return LZMA_PROG_ERROR;
* later versions treat 0 as if 1 had been specified.
*
- * Valid `action' arguments to lzma_code() are LZMA_RUN and LZMA_FINISH.
+ * Valid 'action' arguments to lzma_code() are LZMA_RUN and LZMA_FINISH.
* There is no need to use LZMA_FINISH, but it's allowed because it may
* simplify certain types of applications.
*
@@ -819,10 +841,10 @@ extern LZMA_API(lzma_ret) lzma_index_buffer_decode(lzma_index **i,
* expect to see the same exact value for the same file if you change the
* input buffer size or switch to a different liblzma version.
*
- * Valid `action' arguments to lzma_code() are LZMA_RUN and LZMA_FINISH.
+ * Valid 'action' arguments to lzma_code() are LZMA_RUN and LZMA_FINISH.
* You only need to use LZMA_RUN; LZMA_FINISH is only supported because it
* might be convenient for some applications. If you use LZMA_FINISH and if
- * lzma_code() asks the application to seek, remember to reset `action' back
+ * lzma_code() asks the application to seek, remember to reset 'action' back
* to LZMA_RUN unless you hit the end of the file again.
*
* Possible return values from lzma_code():
diff --git a/src/liblzma/api/lzma/index_hash.h b/src/liblzma/api/lzma/index_hash.h
index a2d4c4845b7c..68f9024eb3bc 100644
--- a/src/liblzma/api/lzma/index_hash.h
+++ b/src/liblzma/api/lzma/index_hash.h
@@ -1,3 +1,5 @@
+/* SPDX-License-Identifier: 0BSD */
+
/**
* \file lzma/index_hash.h
* \brief Validate Index by using a hash function
@@ -9,9 +11,6 @@
/*
* Author: Lasse Collin
- *
- * This file has been put into the public domain.
- * You can do whatever you want with this file.
*/
#ifndef LZMA_H_INTERNAL
diff --git a/src/liblzma/api/lzma/lzma12.h b/src/liblzma/api/lzma/lzma12.h
index 8ef6ea5b5010..05f5b66eb56a 100644
--- a/src/liblzma/api/lzma/lzma12.h
+++ b/src/liblzma/api/lzma/lzma12.h
@@ -1,3 +1,5 @@
+/* SPDX-License-Identifier: 0BSD */
+
/**
* \file lzma/lzma12.h
* \brief LZMA1 and LZMA2 filters
@@ -6,9 +8,6 @@
/*
* Author: Lasse Collin
- *
- * This file has been put into the public domain.
- * You can do whatever you want with this file.
*/
#ifndef LZMA_H_INTERNAL
@@ -289,7 +288,7 @@ typedef struct {
* \brief Number of literal context bits
*
* How many of the highest bits of the previous uncompressed
- * eight-bit byte (also known as `literal') are taken into
+ * eight-bit byte (also known as 'literal') are taken into
* account when predicting the bits of the next literal.
*
* E.g. in typical English text, an upper-case letter is
diff --git a/src/liblzma/api/lzma/stream_flags.h b/src/liblzma/api/lzma/stream_flags.h
index 7622a62120e3..a33fe4683760 100644
--- a/src/liblzma/api/lzma/stream_flags.h
+++ b/src/liblzma/api/lzma/stream_flags.h
@@ -1,3 +1,5 @@
+/* SPDX-License-Identifier: 0BSD */
+
/**
* \file lzma/stream_flags.h
* \brief .xz Stream Header and Stream Footer encoder and decoder
@@ -6,9 +8,6 @@
/*
* Author: Lasse Collin
- *
- * This file has been put into the public domain.
- * You can do whatever you want with this file.
*/
#ifndef LZMA_H_INTERNAL
diff --git a/src/liblzma/api/lzma/version.h b/src/liblzma/api/lzma/version.h
index 8dac38297273..c13a82d5f3b5 100644
--- a/src/liblzma/api/lzma/version.h
+++ b/src/liblzma/api/lzma/version.h
@@ -1,3 +1,5 @@
+/* SPDX-License-Identifier: 0BSD */
+
/**
* \file lzma/version.h
* \brief Version number
@@ -6,9 +8,6 @@
/*
* Author: Lasse Collin
- *
- * This file has been put into the public domain.
- * You can do whatever you want with this file.
*/
#ifndef LZMA_H_INTERNAL
@@ -20,10 +19,10 @@
#define LZMA_VERSION_MAJOR 5
/** \brief Minor version number of the liblzma release. */
-#define LZMA_VERSION_MINOR 4
+#define LZMA_VERSION_MINOR 6
/** \brief Patch version number of the liblzma release. */
-#define LZMA_VERSION_PATCH 5
+#define LZMA_VERSION_PATCH 0
/**
* \brief Version stability marker
diff --git a/src/liblzma/api/lzma/vli.h b/src/liblzma/api/lzma/vli.h
index f9ad15500dfe..7f3e398aae5b 100644
--- a/src/liblzma/api/lzma/vli.h
+++ b/src/liblzma/api/lzma/vli.h
@@ -1,3 +1,5 @@
+/* SPDX-License-Identifier: 0BSD */
+
/**
* \file lzma/vli.h
* \brief Variable-length integer handling
@@ -17,9 +19,6 @@
/*
* Author: Lasse Collin
- *
- * This file has been put into the public domain.
- * You can do whatever you want with this file.
*/
#ifndef LZMA_H_INTERNAL
diff --git a/src/liblzma/check/check.c b/src/liblzma/check/check.c
index 428ddaeb7798..7734ace1856e 100644
--- a/src/liblzma/check/check.c
+++ b/src/liblzma/check/check.c
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file check.c
@@ -5,9 +7,6 @@
//
// Author: Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
#include "check.h"
diff --git a/src/liblzma/check/check.h b/src/liblzma/check/check.h
index 8ae95d59019f..f0eb1172d907 100644
--- a/src/liblzma/check/check.h
+++ b/src/liblzma/check/check.h
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file check.h
@@ -5,9 +7,6 @@
//
// Author: Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
#ifndef LZMA_CHECK_H
diff --git a/src/liblzma/check/crc32_arm64.h b/src/liblzma/check/crc32_arm64.h
new file mode 100644
index 000000000000..6cdb5dab32e6
--- /dev/null
+++ b/src/liblzma/check/crc32_arm64.h
@@ -0,0 +1,119 @@
+// SPDX-License-Identifier: 0BSD
+
+///////////////////////////////////////////////////////////////////////////////
+//
+/// \file crc32_arm64.h
+/// \brief CRC32 calculation with ARM64 optimization
+//
+// Authors: Chenxi Mao
+// Jia Tan
+// Hans Jansen
+//
+///////////////////////////////////////////////////////////////////////////////
+
+
+#ifndef LZMA_CRC32_ARM64_H
+#define LZMA_CRC32_ARM64_H
+
+// MSVC always has the CRC intrinsics available when building for ARM64
+// there is no need to include any header files.
+#ifndef _MSC_VER
+# include <arm_acle.h>
+#endif
+
+#if defined(CRC32_GENERIC) && defined(CRC32_ARCH_OPTIMIZED)
+# if defined(HAVE_GETAUXVAL) || defined(HAVE_ELF_AUX_INFO)
+# include <sys/auxv.h>
+# elif defined(_WIN32)
+# include <processthreadsapi.h>
+# elif defined(__APPLE__) && defined(HAVE_SYSCTLBYNAME)
+# include <sys/sysctl.h>
+# endif
+#endif
+
+// Some EDG-based compilers support ARM64 and define __GNUC__
+// (such as Nvidia's nvcc), but do not support function attributes.
+//
+// NOTE: Build systems check for this too, keep them in sync with this.
+#if (defined(__GNUC__) || defined(__clang__)) && !defined(__EDG__)
+# define crc_attr_target \
+ __attribute__((__target__("+crc")))
+#else
+# define crc_attr_target
+#endif
+
+
+crc_attr_target
+static uint32_t
+crc32_arch_optimized(const uint8_t *buf, size_t size, uint32_t crc)
+{
+ crc = ~crc;
+
+ // Align the input buffer because this was shown to be
+ // significantly faster than unaligned accesses.
+ const size_t align_amount = my_min(size, (8 - (uintptr_t)buf) & 7);
+
+ for (const uint8_t *limit = buf + align_amount; buf < limit; ++buf)
+ crc = __crc32b(crc, *buf);
+
+ size -= align_amount;
+
+ // Process 8 bytes at a time. The end point is determined by
+ // ignoring the least significant three bits of size to ensure
+ // we do not process past the bounds of the buffer. This guarantees
+ // that limit is a multiple of 8 and is strictly less than size.
+ for (const uint8_t *limit = buf + (size & ~((size_t)7));
+ buf < limit; buf += 8)
+ crc = __crc32d(crc, aligned_read64le(buf));
+
+ // Process the remaining bytes that are not 8 byte aligned.
+ for (const uint8_t *limit = buf + (size & 7); buf < limit; ++buf)
+ crc = __crc32b(crc, *buf);
+
+ return ~crc;
+}
+
+
+#if defined(CRC32_GENERIC) && defined(CRC32_ARCH_OPTIMIZED)
+static inline bool
+is_arch_extension_supported(void)
+{
+#if defined(HAVE_GETAUXVAL)
+ return (getauxval(AT_HWCAP) & HWCAP_CRC32) != 0;
+
+#elif defined(HAVE_ELF_AUX_INFO)
+ unsigned long feature_flags;
+
+ elf_aux_info(AT_HWCAP, &feature_flags, sizeof(feature_flags));
+ return feature_flags & HWCAP_CRC32 != 0;
+
+#elif defined(_WIN32)
+ return IsProcessorFeaturePresent(
+ PF_ARM_V8_CRC32_INSTRUCTIONS_AVAILABLE);
+
+#elif defined(__APPLE__) && defined(HAVE_SYSCTLBYNAME)
+ int has_crc32 = 0;
+ size_t size = sizeof(has_crc32);
+
+ // The sysctlbyname() function requires a string identifier for the
+ // CPU feature it tests. The Apple documentation lists the string
+ // "hw.optional.armv8_crc32", which can be found here:
+ // (https://developer.apple.com/documentation/kernel/1387446-sysctlbyname/determining_instruction_set_characteristics#3915619)
+ int err = sysctlbyname("hw.optional.armv8_crc32", &has_crc32,
+ &size, NULL, 0);
+
+ return !err && has_crc32;
+
+#else
+ // If a runtime detection method cannot be found, then this must
+ // be a compile time error. The checks in crc_common.h should ensure
+ // a runtime detection method is always found if this function is
+ // built. It would be possible to just return false here, but this
+ // is inefficient for binary size and runtime since only the generic
+ // method could ever be used.
+# error Runtime detection method unavailable.
+#endif
+}
+#endif
+
+#endif // LZMA_CRC32_ARM64_H
diff --git a/src/liblzma/check/crc32_fast.c b/src/liblzma/check/crc32_fast.c
index eed7350582e4..5e26914a4d1b 100644
--- a/src/liblzma/check/crc32_fast.c
+++ b/src/liblzma/check/crc32_fast.c
@@ -1,30 +1,35 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file crc32.c
/// \brief CRC32 calculation
-///
-/// Calculate the CRC32 using the slice-by-eight algorithm.
-/// It is explained in this document:
-/// http://www.intel.com/technology/comms/perfnet/download/CRC_generators.pdf
-/// The code in this file is not the same as in Intel's paper, but
-/// the basic principle is identical.
-//
-// Author: Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
+// Authors: Lasse Collin
+// Ilya Kurdyukov
+// Hans Jansen
//
///////////////////////////////////////////////////////////////////////////////
#include "check.h"
-#include "crc_macros.h"
+#include "crc_common.h"
+#if defined(CRC_X86_CLMUL)
+# define BUILDING_CRC32_CLMUL
+# include "crc_x86_clmul.h"
+#elif defined(CRC32_ARM64)
+# include "crc32_arm64.h"
+#endif
-// If you make any changes, do some benchmarking! Seemingly unrelated
-// changes can very easily ruin the performance (and very probably is
-// very compiler dependent).
-extern LZMA_API(uint32_t)
-lzma_crc32(const uint8_t *buf, size_t size, uint32_t crc)
+
+#ifdef CRC32_GENERIC
+
+///////////////////
+// Generic CRC32 //
+///////////////////
+
+static uint32_t
+crc32_generic(const uint8_t *buf, size_t size, uint32_t crc)
{
crc = ~crc;
@@ -80,3 +85,153 @@ lzma_crc32(const uint8_t *buf, size_t size, uint32_t crc)
return ~crc;
}
+#endif
+
+
+#if defined(CRC32_GENERIC) && defined(CRC32_ARCH_OPTIMIZED)
+
+//////////////////////////
+// Function dispatching //
+//////////////////////////
+
+// If both the generic and arch-optimized implementations are built, then
+// the function to use is selected at runtime because the system running
+// the binary might not have the arch-specific instruction set extension(s)
+// available. The three dispatch methods in order of priority:
+//
+// 1. Indirect function (ifunc). This method is slightly more efficient
+// than the constructor method because it will change the entry in the
+// Procedure Linkage Table (PLT) for the function either at load time or
+// at the first call. This avoids having to call the function through a
+// function pointer and will treat the function call like a regular call
+// through the PLT. ifuncs are created by using
+// __attribute__((__ifunc__("resolver"))) on a function which has no
+// body. The "resolver" is the name of the function that chooses at
+// runtime which implementation to use.
+//
+// 2. Constructor. This method uses __attribute__((__constructor__)) to
+// set crc32_func at load time. This avoids extra computation (and any
+// unlikely threading bugs) on the first call to lzma_crc32() to decide
+// which implementation should be used.
+//
+// 3. First Call Resolution. On the very first call to lzma_crc32(), the
+// call will be directed to crc32_dispatch() instead. This will set the
+// appropriate implementation function and will not be called again.
+// This method does not use any kind of locking but is safe because if
+// multiple threads run the dispatcher simultaneously then they will all
+// set crc32_func to the same value.
+
+typedef uint32_t (*crc32_func_type)(
+ const uint8_t *buf, size_t size, uint32_t crc);
+
+// Clang 16.0.0 and older has a bug where it marks the ifunc resolver
+// function as unused since it is static and never used outside of
+// __attribute__((__ifunc__())).
+#if defined(CRC_USE_IFUNC) && defined(__clang__)
+# pragma GCC diagnostic push
+# pragma GCC diagnostic ignored "-Wunused-function"
+#endif
+
+// This resolver is shared between all three dispatch methods. It serves as
+// the ifunc resolver if ifunc is supported, otherwise it is called as a
+// regular function by the constructor or first call resolution methods.
+static crc32_func_type
+crc32_resolve(void)
+{
+ return is_arch_extension_supported()
+ ? &crc32_arch_optimized : &crc32_generic;
+}
+
+#if defined(CRC_USE_IFUNC) && defined(__clang__)
+# pragma GCC diagnostic pop
+#endif
+
+#ifndef CRC_USE_IFUNC
+
+#ifdef HAVE_FUNC_ATTRIBUTE_CONSTRUCTOR
+// Constructor method.
+# define CRC32_SET_FUNC_ATTR __attribute__((__constructor__))
+static crc32_func_type crc32_func;
+#else
+// First Call Resolution method.
+# define CRC32_SET_FUNC_ATTR
+static uint32_t crc32_dispatch(const uint8_t *buf, size_t size, uint32_t crc);
+static crc32_func_type crc32_func = &crc32_dispatch;
+#endif
+
+CRC32_SET_FUNC_ATTR
+static void
+crc32_set_func(void)
+{
+ crc32_func = crc32_resolve();
+ return;
+}
+
+#ifndef HAVE_FUNC_ATTRIBUTE_CONSTRUCTOR
+static uint32_t
+crc32_dispatch(const uint8_t *buf, size_t size, uint32_t crc)
+{
+ // When __attribute__((__ifunc__(...))) and
+ // __attribute__((__constructor__)) isn't supported, set the
+ // function pointer without any locking. If multiple threads run
+ // the detection code in parallel, they will all end up setting
+ // the pointer to the same value. This avoids the use of
+ // mythread_once() on every call to lzma_crc32() but this likely
+ // isn't strictly standards compliant. Let's change it if it breaks.
+ crc32_set_func();
+ return crc32_func(buf, size, crc);
+}
+
+#endif
+#endif
+#endif
+
+
+#ifdef CRC_USE_IFUNC
+extern LZMA_API(uint32_t)
+lzma_crc32(const uint8_t *buf, size_t size, uint32_t crc)
+ __attribute__((__ifunc__("crc32_resolve")));
+#else
+extern LZMA_API(uint32_t)
+lzma_crc32(const uint8_t *buf, size_t size, uint32_t crc)
+{
+#if defined(CRC32_GENERIC) && defined(CRC32_ARCH_OPTIMIZED)
+ // On x86-64, if CLMUL is available, it is the best for non-tiny
+ // inputs, being over twice as fast as the generic slice-by-four
+ // version. However, for size <= 16 it's different. In the extreme
+ // case of size == 1 the generic version can be five times faster.
+ // At size >= 8 the CLMUL starts to become reasonable. It
+ // varies depending on the alignment of buf too.
+ //
+ // The above doesn't include the overhead of mythread_once().
+ // At least on x86-64 GNU/Linux, pthread_once() is very fast but
+ // it still makes lzma_crc32(buf, 1, crc) 50-100 % slower. When
+ // size reaches 12-16 bytes the overhead becomes negligible.
+ //
+ // So using the generic version for size <= 16 may give better
+ // performance with tiny inputs but if such inputs happen rarely
+ // it's not so obvious because then the lookup table of the
+ // generic version may not be in the processor cache.
+#ifdef CRC_USE_GENERIC_FOR_SMALL_INPUTS
+ if (size <= 16)
+ return crc32_generic(buf, size, crc);
+#endif
+
+/*
+#ifndef HAVE_FUNC_ATTRIBUTE_CONSTRUCTOR
+ // See crc32_dispatch(). This would be the alternative which uses
+ // locking and doesn't use crc32_dispatch(). Note that on Windows
+ // this method needs Vista threads.
+ mythread_once(crc64_set_func);
+#endif
+*/
+ return crc32_func(buf, size, crc);
+
+#elif defined(CRC32_ARCH_OPTIMIZED)
+ return crc32_arch_optimized(buf, size, crc);
+
+#else
+ return crc32_generic(buf, size, crc);
+#endif
+}
+#endif
diff --git a/src/liblzma/check/crc32_small.c b/src/liblzma/check/crc32_small.c
index 186966e99216..6a1bd66185ea 100644
--- a/src/liblzma/check/crc32_small.c
+++ b/src/liblzma/check/crc32_small.c
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file crc32_small.c
@@ -5,9 +7,6 @@
//
// Author: Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
#include "check.h"
diff --git a/src/liblzma/check/crc32_table.c b/src/liblzma/check/crc32_table.c
index b11762ae0ac7..fb1b6585422a 100644
--- a/src/liblzma/check/crc32_table.c
+++ b/src/liblzma/check/crc32_table.c
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file crc32_table.c
@@ -5,18 +7,38 @@
//
// Author: Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
#include "common.h"
+
+// FIXME: Compared to crc_common.h this has to check for __x86_64__ too
+// so that in 32-bit builds crc32_x86.S won't break due to a missing table.
+#if defined(HAVE_USABLE_CLMUL) && ((defined(__x86_64__) && defined(__SSSE3__) \
+ && defined(__SSE4_1__) && defined(__PCLMUL__)) \
+ || (defined(__e2k__) && __iset__ >= 6))
+# define X86_CLMUL_NO_TABLE 1
+#endif
+
+#if defined(HAVE_ARM64_CRC32) \
+ && !defined(WORDS_BIGENDIAN) \
+ && defined(__ARM_FEATURE_CRC32)
+# define ARM64_CRC32_NO_TABLE 1
+#endif
+
+
+#if !defined(HAVE_ENCODERS) && (defined(X86_CLMUL_NO_TABLE) \
+ || defined(ARM64_CRC32_NO_TABLE_))
+// No table needed. Use a typedef to avoid an empty translation unit.
+typedef void lzma_crc32_dummy;
+
+#else
// Having the declaration here silences clang -Wmissing-variable-declarations.
extern const uint32_t lzma_crc32_table[8][256];
-#ifdef WORDS_BIGENDIAN
-# include "crc32_table_be.h"
-#else
-# include "crc32_table_le.h"
+# ifdef WORDS_BIGENDIAN
+# include "crc32_table_be.h"
+# else
+# include "crc32_table_le.h"
+# endif
#endif
diff --git a/src/liblzma/check/crc32_table_be.h b/src/liblzma/check/crc32_table_be.h
index c483cb670dcb..505c23074c11 100644
--- a/src/liblzma/check/crc32_table_be.h
+++ b/src/liblzma/check/crc32_table_be.h
@@ -1,4 +1,6 @@
-/* This file has been automatically generated by crc32_tablegen.c. */
+// SPDX-License-Identifier: 0BSD
+
+// This file has been generated by crc32_tablegen.c.
const uint32_t lzma_crc32_table[8][256] = {
{
diff --git a/src/liblzma/check/crc32_table_le.h b/src/liblzma/check/crc32_table_le.h
index 25f4fc443537..e89c21a7b23d 100644
--- a/src/liblzma/check/crc32_table_le.h
+++ b/src/liblzma/check/crc32_table_le.h
@@ -1,4 +1,6 @@
-/* This file has been automatically generated by crc32_tablegen.c. */
+// SPDX-License-Identifier: 0BSD
+
+// This file has been generated by crc32_tablegen.c.
const uint32_t lzma_crc32_table[8][256] = {
{
diff --git a/src/liblzma/check/crc32_tablegen.c b/src/liblzma/check/crc32_tablegen.c
index 31a4d2751db2..01047d3eca47 100644
--- a/src/liblzma/check/crc32_tablegen.c
+++ b/src/liblzma/check/crc32_tablegen.c
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file crc32_tablegen.c
@@ -9,9 +11,6 @@
//
// Author: Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
#include <stdio.h>
@@ -54,9 +53,11 @@ init_crc32_table(void)
static void
print_crc32_table(void)
{
- printf("/* This file has been automatically generated by "
- "crc32_tablegen.c. */\n\n"
- "const uint32_t lzma_crc32_table[8][256] = {\n\t{");
+ // Split the SPDX string so that it won't accidentally match
+ // when tools search for the string.
+ printf("// SPDX" "-License-Identifier" ": 0BSD\n\n"
+ "// This file has been generated by crc32_tablegen.c.\n\n"
+ "const uint32_t lzma_crc32_table[8][256] = {\n\t{");
for (size_t s = 0; s < 8; ++s) {
for (size_t b = 0; b < 256; ++b) {
@@ -82,9 +83,11 @@ print_crc32_table(void)
static void
print_lz_table(void)
{
- printf("/* This file has been automatically generated by "
- "crc32_tablegen.c. */\n\n"
- "const uint32_t lzma_lz_hash_table[256] = {");
+ // Split the SPDX string so that it won't accidentally match
+ // when tools search for the string.
+ printf("// SPDX" "-License-Identifier" ": 0BSD\n\n"
+ "// This file has been generated by crc32_tablegen.c.\n\n"
+ "const uint32_t lzma_lz_hash_table[256] = {");
for (size_t b = 0; b < 256; ++b) {
if ((b % 4) == 0)
diff --git a/src/liblzma/check/crc32_x86.S b/src/liblzma/check/crc32_x86.S
index 4f395df8122a..ddc3cee6ea5b 100644
--- a/src/liblzma/check/crc32_x86.S
+++ b/src/liblzma/check/crc32_x86.S
@@ -1,3 +1,5 @@
+/* SPDX-License-Identifier: 0BSD */
+
/*
* Speed-optimized CRC32 using slicing-by-eight algorithm
*
@@ -11,9 +13,6 @@
* Authors: Igor Pavlov (original version)
* Lasse Collin (AT&T syntax, PIC support, better portability)
*
- * This file has been put into the public domain.
- * You can do whatever you want with this file.
- *
* This code needs lzma_crc32_table, which can be created using the
* following C code:
diff --git a/src/liblzma/check/crc64_fast.c b/src/liblzma/check/crc64_fast.c
index 0c8622a1f367..f29fe3d3c5e6 100644
--- a/src/liblzma/check/crc64_fast.c
+++ b/src/liblzma/check/crc64_fast.c
@@ -1,85 +1,30 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file crc64.c
/// \brief CRC64 calculation
-///
-/// There are two methods in this file. crc64_generic uses the
-/// the slice-by-four algorithm. This is the same idea that is
-/// used in crc32_fast.c, but for CRC64 we use only four tables
-/// instead of eight to avoid increasing CPU cache usage.
-///
-/// crc64_clmul uses 32/64-bit x86 SSSE3, SSE4.1, and CLMUL instructions.
-/// It was derived from
-/// https://www.intel.com/content/dam/www/public/us/en/documents/white-papers/fast-crc-computation-generic-polynomials-pclmulqdq-paper.pdf
-/// and the public domain code from https://github.com/rawrunprotected/crc
-/// (URLs were checked on 2022-11-07).
-///
-/// FIXME: Builds for 32-bit x86 use crc64_x86.S by default instead
-/// of this file and thus CLMUL version isn't available on 32-bit x86
-/// unless configured with --disable-assembler. Even then the lookup table
-/// isn't omitted in crc64_table.c since it doesn't know that assembly
-/// code has been disabled.
//
// Authors: Lasse Collin
// Ilya Kurdyukov
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
#include "check.h"
+#include "crc_common.h"
-#undef CRC_GENERIC
-#undef CRC_CLMUL
-#undef CRC_USE_GENERIC_FOR_SMALL_INPUTS
-
-// If CLMUL cannot be used then only the generic slice-by-four is built.
-#if !defined(HAVE_USABLE_CLMUL)
-# define CRC_GENERIC 1
-
-// If CLMUL is allowed unconditionally in the compiler options then the
-// generic version can be omitted. Note that this doesn't work with MSVC
-// as I don't know how to detect the features here.
-//
-// NOTE: Keep this this in sync with crc64_table.c.
-#elif (defined(__SSSE3__) && defined(__SSE4_1__) && defined(__PCLMUL__)) \
- || (defined(__e2k__) && __iset__ >= 6)
-# define CRC_CLMUL 1
-
-// Otherwise build both and detect at runtime which version to use.
-#else
-# define CRC_GENERIC 1
-# define CRC_CLMUL 1
-
-/*
- // The generic code is much faster with 1-8-byte inputs and has
- // similar performance up to 16 bytes at least in microbenchmarks
- // (it depends on input buffer alignment too). If both versions are
- // built, this #define will use the generic version for inputs up to
- // 16 bytes and CLMUL for bigger inputs. It saves a little in code
- // size since the special cases for 0-16-byte inputs will be omitted
- // from the CLMUL code.
-# define CRC_USE_GENERIC_FOR_SMALL_INPUTS 1
-*/
-
-# if defined(_MSC_VER)
-# include <intrin.h>
-# elif defined(HAVE_CPUID_H)
-# include <cpuid.h>
-# endif
+#if defined(CRC_X86_CLMUL)
+# define BUILDING_CRC64_CLMUL
+# include "crc_x86_clmul.h"
#endif
+#ifdef CRC64_GENERIC
+
/////////////////////////////////
// Generic slice-by-four CRC64 //
/////////////////////////////////
-#ifdef CRC_GENERIC
-
-#include "crc_macros.h"
-
-
#ifdef WORDS_BIGENDIAN
# define A1(x) ((x) >> 56)
#else
@@ -136,336 +81,51 @@ crc64_generic(const uint8_t *buf, size_t size, uint64_t crc)
#endif
-/////////////////////
-// x86 CLMUL CRC64 //
-/////////////////////
+#if defined(CRC64_GENERIC) && defined(CRC64_ARCH_OPTIMIZED)
-#ifdef CRC_CLMUL
+//////////////////////////
+// Function dispatching //
+//////////////////////////
-#include <immintrin.h>
+// If both the generic and arch-optimized implementations are usable, then
+// the function that is used is selected at runtime. See crc32_fast.c.
+typedef uint64_t (*crc64_func_type)(
+ const uint8_t *buf, size_t size, uint64_t crc);
-/*
-// These functions were used to generate the constants
-// at the top of crc64_clmul().
-static uint64_t
-calc_lo(uint64_t poly)
-{
- uint64_t a = poly;
- uint64_t b = 0;
-
- for (unsigned i = 0; i < 64; ++i) {
- b = (b >> 1) | (a << 63);
- a = (a >> 1) ^ (a & 1 ? poly : 0);
- }
-
- return b;
-}
-
-static uint64_t
-calc_hi(uint64_t poly, uint64_t a)
-{
- for (unsigned i = 0; i < 64; ++i)
- a = (a >> 1) ^ (a & 1 ? poly : 0);
-
- return a;
-}
-*/
-
-
-#define MASK_L(in, mask, r) \
- r = _mm_shuffle_epi8(in, mask)
-
-#define MASK_H(in, mask, r) \
- r = _mm_shuffle_epi8(in, _mm_xor_si128(mask, vsign))
-
-#define MASK_LH(in, mask, low, high) \
- MASK_L(in, mask, low); \
- MASK_H(in, mask, high)
-
-
-// MSVC (VS2015 - VS2022) produces bad 32-bit x86 code from the CLMUL CRC
-// code when optimizations are enabled (release build). According to the bug
-// report, the ebx register is corrupted and the calculated result is wrong.
-// Trying to workaround the problem with "__asm mov ebx, ebx" didn't help.
-// The following pragma works and performance is still good. x86-64 builds
-// aren't affected by this problem.
-//
-// NOTE: Another pragma after the function restores the optimizations.
-// If the #if condition here is updated, the other one must be updated too.
-#if defined(_MSC_VER) && !defined(__INTEL_COMPILER) && !defined(__clang__) \
- && defined(_M_IX86)
-# pragma optimize("g", off)
-#endif
-
-// EDG-based compilers (Intel's classic compiler and compiler for E2K) can
-// define __GNUC__ but the attribute must not be used with them.
-// The new Clang-based ICX needs the attribute.
-//
-// NOTE: Build systems check for this too, keep them in sync with this.
-#if (defined(__GNUC__) || defined(__clang__)) && !defined(__EDG__)
-__attribute__((__target__("ssse3,sse4.1,pclmul")))
-#endif
-// The intrinsics use 16-byte-aligned reads from buf, thus they may read
-// up to 15 bytes before or after the buffer (depending on the alignment
-// of the buf argument). The values of the extra bytes are ignored.
-// This unavoidably trips -fsanitize=address so address sanitizier has
-// to be disabled for this function.
-#if lzma_has_attribute(__no_sanitize_address__)
-__attribute__((__no_sanitize_address__))
-#endif
-static uint64_t
-crc64_clmul(const uint8_t *buf, size_t size, uint64_t crc)
-{
- // The prototypes of the intrinsics use signed types while most of
- // the values are treated as unsigned here. These warnings in this
- // function have been checked and found to be harmless so silence them.
-#if TUKLIB_GNUC_REQ(4, 6) || defined(__clang__)
+#if defined(CRC_USE_IFUNC) && defined(__clang__)
# pragma GCC diagnostic push
-# pragma GCC diagnostic ignored "-Wsign-conversion"
-# pragma GCC diagnostic ignored "-Wconversion"
-#endif
-
-#ifndef CRC_USE_GENERIC_FOR_SMALL_INPUTS
- // The code assumes that there is at least one byte of input.
- if (size == 0)
- return crc;
-#endif
-
- // const uint64_t poly = 0xc96c5795d7870f42; // CRC polynomial
- const uint64_t p = 0x92d8af2baf0e1e85; // (poly << 1) | 1
- const uint64_t mu = 0x9c3e466c172963d5; // (calc_lo(poly) << 1) | 1
- const uint64_t k2 = 0xdabe95afc7875f40; // calc_hi(poly, 1)
- const uint64_t k1 = 0xe05dd497ca393ae4; // calc_hi(poly, k2)
- const __m128i vfold0 = _mm_set_epi64x(p, mu);
- const __m128i vfold1 = _mm_set_epi64x(k2, k1);
-
- // Create a vector with 8-bit values 0 to 15. This is used to
- // construct control masks for _mm_blendv_epi8 and _mm_shuffle_epi8.
- const __m128i vramp = _mm_setr_epi32(
- 0x03020100, 0x07060504, 0x0b0a0908, 0x0f0e0d0c);
-
- // This is used to inverse the control mask of _mm_shuffle_epi8
- // so that bytes that wouldn't be picked with the original mask
- // will be picked and vice versa.
- const __m128i vsign = _mm_set1_epi8(0x80);
-
- // Memory addresses A to D and the distances between them:
- //
- // A B C D
- // [skip_start][size][skip_end]
- // [ size2 ]
- //
- // A and D are 16-byte aligned. B and C are 1-byte aligned.
- // skip_start and skip_end are 0-15 bytes. size is at least 1 byte.
- //
- // A = aligned_buf will initially point to this address.
- // B = The address pointed by the caller-supplied buf.
- // C = buf + size == aligned_buf + size2
- // D = buf + size + skip_end == aligned_buf + size2 + skip_end
- const size_t skip_start = (size_t)((uintptr_t)buf & 15);
- const size_t skip_end = (size_t)((0U - (uintptr_t)(buf + size)) & 15);
- const __m128i *aligned_buf = (const __m128i *)(
- (uintptr_t)buf & ~(uintptr_t)15);
-
- // If size2 <= 16 then the whole input fits into a single 16-byte
- // vector. If size2 > 16 then at least two 16-byte vectors must
- // be processed. If size2 > 16 && size <= 16 then there is only
- // one 16-byte vector's worth of input but it is unaligned in memory.
- //
- // NOTE: There is no integer overflow here if the arguments are valid.
- // If this overflowed, buf + size would too.
- size_t size2 = skip_start + size;
-
- // Masks to be used with _mm_blendv_epi8 and _mm_shuffle_epi8:
- // The first skip_start or skip_end bytes in the vectors will have
- // the high bit (0x80) set. _mm_blendv_epi8 and _mm_shuffle_epi8
- // will produce zeros for these positions. (Bitwise-xor of these
- // masks with vsign will produce the opposite behavior.)
- const __m128i mask_start
- = _mm_sub_epi8(vramp, _mm_set1_epi8(skip_start));
- const __m128i mask_end = _mm_sub_epi8(vramp, _mm_set1_epi8(skip_end));
-
- // Get the first 1-16 bytes into data0. If loading less than 16 bytes,
- // the bytes are loaded to the high bits of the vector and the least
- // significant positions are filled with zeros.
- const __m128i data0 = _mm_blendv_epi8(_mm_load_si128(aligned_buf),
- _mm_setzero_si128(), mask_start);
- ++aligned_buf;
-
-#if defined(__i386__) || defined(_M_IX86)
- const __m128i initial_crc = _mm_set_epi64x(0, ~crc);
-#else
- // GCC and Clang would produce good code with _mm_set_epi64x
- // but MSVC needs _mm_cvtsi64_si128 on x86-64.
- const __m128i initial_crc = _mm_cvtsi64_si128(~crc);
-#endif
-
- __m128i v0, v1, v2, v3;
-
-#ifndef CRC_USE_GENERIC_FOR_SMALL_INPUTS
- if (size <= 16) {
- // Right-shift initial_crc by 1-16 bytes based on "size"
- // and store the result in v1 (high bytes) and v0 (low bytes).
- //
- // NOTE: The highest 8 bytes of initial_crc are zeros so
- // v1 will be filled with zeros if size >= 8. The highest 8
- // bytes of v1 will always become zeros.
- //
- // [ v1 ][ v0 ]
- // [ initial_crc ] size == 1
- // [ initial_crc ] size == 2
- // [ initial_crc ] size == 15
- // [ initial_crc ] size == 16 (all in v0)
- const __m128i mask_low = _mm_add_epi8(
- vramp, _mm_set1_epi8(size - 16));
- MASK_LH(initial_crc, mask_low, v0, v1);
-
- if (size2 <= 16) {
- // There are 1-16 bytes of input and it is all
- // in data0. Copy the input bytes to v3. If there
- // are fewer than 16 bytes, the low bytes in v3
- // will be filled with zeros. That is, the input
- // bytes are stored to the same position as
- // (part of) initial_crc is in v0.
- MASK_L(data0, mask_end, v3);
- } else {
- // There are 2-16 bytes of input but not all bytes
- // are in data0.
- const __m128i data1 = _mm_load_si128(aligned_buf);
-
- // Collect the 2-16 input bytes from data0 and data1
- // to v2 and v3, and bitwise-xor them with the
- // low bits of initial_crc in v0. Note that the
- // the second xor is below this else-block as it
- // is shared with the other branch.
- MASK_H(data0, mask_end, v2);
- MASK_L(data1, mask_end, v3);
- v0 = _mm_xor_si128(v0, v2);
- }
-
- v0 = _mm_xor_si128(v0, v3);
- v1 = _mm_alignr_epi8(v1, v0, 8);
- } else
-#endif
- {
- const __m128i data1 = _mm_load_si128(aligned_buf);
- MASK_LH(initial_crc, mask_start, v0, v1);
- v0 = _mm_xor_si128(v0, data0);
- v1 = _mm_xor_si128(v1, data1);
-
-#define FOLD \
- v1 = _mm_xor_si128(v1, _mm_clmulepi64_si128(v0, vfold1, 0x00)); \
- v0 = _mm_xor_si128(v1, _mm_clmulepi64_si128(v0, vfold1, 0x11));
-
- while (size2 > 32) {
- ++aligned_buf;
- size2 -= 16;
- FOLD
- v1 = _mm_load_si128(aligned_buf);
- }
-
- if (size2 < 32) {
- MASK_H(v0, mask_end, v2);
- MASK_L(v0, mask_end, v0);
- MASK_L(v1, mask_end, v3);
- v1 = _mm_or_si128(v2, v3);
- }
-
- FOLD
- v1 = _mm_srli_si128(v0, 8);
-#undef FOLD
- }
-
- v1 = _mm_xor_si128(_mm_clmulepi64_si128(v0, vfold1, 0x10), v1);
- v0 = _mm_clmulepi64_si128(v1, vfold0, 0x00);
- v2 = _mm_clmulepi64_si128(v0, vfold0, 0x10);
- v0 = _mm_xor_si128(_mm_xor_si128(v2, _mm_slli_si128(v0, 8)), v1);
-
-#if defined(__i386__) || defined(_M_IX86)
- return ~(((uint64_t)(uint32_t)_mm_extract_epi32(v0, 3) << 32) |
- (uint64_t)(uint32_t)_mm_extract_epi32(v0, 2));
-#else
- return ~(uint64_t)_mm_extract_epi64(v0, 1);
+# pragma GCC diagnostic ignored "-Wunused-function"
#endif
-#if TUKLIB_GNUC_REQ(4, 6) || defined(__clang__)
-# pragma GCC diagnostic pop
-#endif
+static crc64_func_type
+crc64_resolve(void)
+{
+ return is_arch_extension_supported()
+ ? &crc64_arch_optimized : &crc64_generic;
}
-#if defined(_MSC_VER) && !defined(__INTEL_COMPILER) && !defined(__clang__) \
- && defined(_M_IX86)
-# pragma optimize("", on)
-#endif
-#endif
-
-
-////////////////////////
-// Detect CPU support //
-////////////////////////
-#if defined(CRC_GENERIC) && defined(CRC_CLMUL)
-static inline bool
-is_clmul_supported(void)
-{
- int success = 1;
- uint32_t r[4]; // eax, ebx, ecx, edx
-
-#if defined(_MSC_VER)
- // This needs <intrin.h> with MSVC. ICC has it as a built-in
- // on all platforms.
- __cpuid(r, 1);
-#elif defined(HAVE_CPUID_H)
- // Compared to just using __asm__ to run CPUID, this also checks
- // that CPUID is supported and saves and restores ebx as that is
- // needed with GCC < 5 with position-independent code (PIC).
- success = __get_cpuid(1, &r[0], &r[1], &r[2], &r[3]);
-#else
- // Just a fallback that shouldn't be needed.
- __asm__("cpuid\n\t"
- : "=a"(r[0]), "=b"(r[1]), "=c"(r[2]), "=d"(r[3])
- : "a"(1), "c"(0));
+#if defined(CRC_USE_IFUNC) && defined(__clang__)
+# pragma GCC diagnostic pop
#endif
- // Returns true if these are supported:
- // CLMUL (bit 1 in ecx)
- // SSSE3 (bit 9 in ecx)
- // SSE4.1 (bit 19 in ecx)
- const uint32_t ecx_mask = (1 << 1) | (1 << 9) | (1 << 19);
- return success && (r[2] & ecx_mask) == ecx_mask;
-
- // Alternative methods that weren't used:
- // - ICC's _may_i_use_cpu_feature: the other methods should work too.
- // - GCC >= 6 / Clang / ICX __builtin_cpu_supports("pclmul")
- //
- // CPUID decding is needed with MSVC anyway and older GCC. This keeps
- // the feature checks in the build system simpler too. The nice thing
- // about __builtin_cpu_supports would be that it generates very short
- // code as is it only reads a variable set at startup but a few bytes
- // doesn't matter here.
-}
-
+#ifndef CRC_USE_IFUNC
#ifdef HAVE_FUNC_ATTRIBUTE_CONSTRUCTOR
-# define CRC64_FUNC_INIT
# define CRC64_SET_FUNC_ATTR __attribute__((__constructor__))
+static crc64_func_type crc64_func;
#else
-# define CRC64_FUNC_INIT = &crc64_dispatch
# define CRC64_SET_FUNC_ATTR
static uint64_t crc64_dispatch(const uint8_t *buf, size_t size, uint64_t crc);
+static crc64_func_type crc64_func = &crc64_dispatch;
#endif
-// Pointer to the the selected CRC64 method.
-static uint64_t (*crc64_func)(const uint8_t *buf, size_t size, uint64_t crc)
- CRC64_FUNC_INIT;
-
-
CRC64_SET_FUNC_ATTR
static void
crc64_set_func(void)
{
- crc64_func = is_clmul_supported() ? &crc64_clmul : &crc64_generic;
+ crc64_func = crc64_resolve();
return;
}
@@ -474,65 +134,41 @@ crc64_set_func(void)
static uint64_t
crc64_dispatch(const uint8_t *buf, size_t size, uint64_t crc)
{
- // When __attribute__((__constructor__)) isn't supported, set the
- // function pointer without any locking. If multiple threads run
- // the detection code in parallel, they will all end up setting
- // the pointer to the same value. This avoids the use of
- // mythread_once() on every call to lzma_crc64() but this likely
- // isn't strictly standards compliant. Let's change it if it breaks.
crc64_set_func();
return crc64_func(buf, size, crc);
}
#endif
#endif
+#endif
+#ifdef CRC_USE_IFUNC
+extern LZMA_API(uint64_t)
+lzma_crc64(const uint8_t *buf, size_t size, uint64_t crc)
+ __attribute__((__ifunc__("crc64_resolve")));
+#else
extern LZMA_API(uint64_t)
lzma_crc64(const uint8_t *buf, size_t size, uint64_t crc)
{
-#if defined(CRC_GENERIC) && defined(CRC_CLMUL)
- // If CLMUL is available, it is the best for non-tiny inputs,
- // being over twice as fast as the generic slice-by-four version.
- // However, for size <= 16 it's different. In the extreme case
- // of size == 1 the generic version can be five times faster.
- // At size >= 8 the CLMUL starts to become reasonable. It
- // varies depending on the alignment of buf too.
- //
- // The above doesn't include the overhead of mythread_once().
- // At least on x86-64 GNU/Linux, pthread_once() is very fast but
- // it still makes lzma_crc64(buf, 1, crc) 50-100 % slower. When
- // size reaches 12-16 bytes the overhead becomes negligible.
- //
- // So using the generic version for size <= 16 may give better
- // performance with tiny inputs but if such inputs happen rarely
- // it's not so obvious because then the lookup table of the
- // generic version may not be in the processor cache.
+#if defined(CRC64_GENERIC) && defined(CRC64_ARCH_OPTIMIZED)
+
#ifdef CRC_USE_GENERIC_FOR_SMALL_INPUTS
if (size <= 16)
return crc64_generic(buf, size, crc);
#endif
-
-/*
-#ifndef HAVE_FUNC_ATTRIBUTE_CONSTRUCTOR
- // See crc64_dispatch(). This would be the alternative which uses
- // locking and doesn't use crc64_dispatch(). Note that on Windows
- // this method needs Vista threads.
- mythread_once(crc64_set_func);
-#endif
-*/
-
return crc64_func(buf, size, crc);
-#elif defined(CRC_CLMUL)
- // If CLMUL is used unconditionally without runtime CPU detection
- // then omitting the generic version and its 8 KiB lookup table
- // makes the library smaller.
+#elif defined(CRC64_ARCH_OPTIMIZED)
+ // If arch-optimized version is used unconditionally without runtime
+ // CPU detection then omitting the generic version and its 8 KiB
+ // lookup table makes the library smaller.
//
// FIXME: Lookup table isn't currently omitted on 32-bit x86,
// see crc64_table.c.
- return crc64_clmul(buf, size, crc);
+ return crc64_arch_optimized(buf, size, crc);
#else
return crc64_generic(buf, size, crc);
#endif
}
+#endif
diff --git a/src/liblzma/check/crc64_small.c b/src/liblzma/check/crc64_small.c
index 420f7cfbb475..ee4ea26f67d0 100644
--- a/src/liblzma/check/crc64_small.c
+++ b/src/liblzma/check/crc64_small.c
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file crc64_small.c
@@ -5,9 +7,6 @@
//
// Author: Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
#include "check.h"
diff --git a/src/liblzma/check/crc64_table.c b/src/liblzma/check/crc64_table.c
index 688e527b0fd1..6dee387a1fcf 100644
--- a/src/liblzma/check/crc64_table.c
+++ b/src/liblzma/check/crc64_table.c
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file crc64_table.c
@@ -5,19 +7,21 @@
//
// Author: Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
#include "common.h"
-// FIXME: Compared to crc64_fast.c this has to check for __x86_64__ too
+// FIXME: Compared to crc_common.h this has to check for __x86_64__ too
// so that in 32-bit builds crc64_x86.S won't break due to a missing table.
-#if (defined(__x86_64__) && defined(__SSSE3__) \
+#if defined(HAVE_USABLE_CLMUL) && ((defined(__x86_64__) && defined(__SSSE3__) \
&& defined(__SSE4_1__) && defined(__PCLMUL__)) \
- || (defined(__e2k__) && __iset__ >= 6)
+ || (defined(__e2k__) && __iset__ >= 6))
+# define X86_CLMUL_NO_TABLE 1
+#endif
+
+
+#ifdef X86_CLMUL_NO_TABLE
// No table needed. Use a typedef to avoid an empty translation unit.
typedef void lzma_crc64_dummy;
diff --git a/src/liblzma/check/crc64_table_be.h b/src/liblzma/check/crc64_table_be.h
index ea074f397a70..db76cc70e07c 100644
--- a/src/liblzma/check/crc64_table_be.h
+++ b/src/liblzma/check/crc64_table_be.h
@@ -1,4 +1,6 @@
-/* This file has been automatically generated by crc64_tablegen.c. */
+// SPDX-License-Identifier: 0BSD
+
+// This file has been generated by crc64_tablegen.c.
const uint64_t lzma_crc64_table[4][256] = {
{
diff --git a/src/liblzma/check/crc64_table_le.h b/src/liblzma/check/crc64_table_le.h
index 1196b31e1323..e40a8c82105e 100644
--- a/src/liblzma/check/crc64_table_le.h
+++ b/src/liblzma/check/crc64_table_le.h
@@ -1,4 +1,6 @@
-/* This file has been automatically generated by crc64_tablegen.c. */
+// SPDX-License-Identifier: 0BSD
+
+// This file has been generated by crc64_tablegen.c.
const uint64_t lzma_crc64_table[4][256] = {
{
diff --git a/src/liblzma/check/crc64_tablegen.c b/src/liblzma/check/crc64_tablegen.c
index fddaa7ed1400..af93e011ca21 100644
--- a/src/liblzma/check/crc64_tablegen.c
+++ b/src/liblzma/check/crc64_tablegen.c
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file crc64_tablegen.c
@@ -8,9 +10,6 @@
//
// Author: Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
#include <stdio.h>
@@ -53,9 +52,11 @@ init_crc64_table(void)
static void
print_crc64_table(void)
{
- printf("/* This file has been automatically generated by "
- "crc64_tablegen.c. */\n\n"
- "const uint64_t lzma_crc64_table[4][256] = {\n\t{");
+ // Split the SPDX string so that it won't accidentally match
+ // when tools search for the string.
+ printf("// SPDX" "-License-Identifier" ": 0BSD\n\n"
+ "// This file has been generated by crc64_tablegen.c.\n\n"
+ "const uint64_t lzma_crc64_table[4][256] = {\n\t{");
for (size_t s = 0; s < 4; ++s) {
for (size_t b = 0; b < 256; ++b) {
diff --git a/src/liblzma/check/crc64_x86.S b/src/liblzma/check/crc64_x86.S
index 9aecf5865455..47f608181ea8 100644
--- a/src/liblzma/check/crc64_x86.S
+++ b/src/liblzma/check/crc64_x86.S
@@ -1,3 +1,5 @@
+/* SPDX-License-Identifier: 0BSD */
+
/*
* Speed-optimized CRC64 using slicing-by-four algorithm
*
@@ -7,9 +9,6 @@
* Authors: Igor Pavlov (original CRC32 assembly code)
* Lasse Collin (CRC64 adaptation of the modified CRC32 code)
*
- * This file has been put into the public domain.
- * You can do whatever you want with this file.
- *
* This code needs lzma_crc64_table, which can be created using the
* following C code:
diff --git a/src/liblzma/check/crc_common.h b/src/liblzma/check/crc_common.h
new file mode 100644
index 000000000000..856665db79a8
--- /dev/null
+++ b/src/liblzma/check/crc_common.h
@@ -0,0 +1,143 @@
+// SPDX-License-Identifier: 0BSD
+
+///////////////////////////////////////////////////////////////////////////////
+//
+/// \file crc_common.h
+/// \brief Some functions and macros for CRC32 and CRC64
+//
+// Authors: Lasse Collin
+// Ilya Kurdyukov
+// Hans Jansen
+// Jia Tan
+//
+///////////////////////////////////////////////////////////////////////////////
+
+#ifndef LZMA_CRC_COMMON_H
+#define LZMA_CRC_COMMON_H
+
+#include "common.h"
+
+
+#ifdef WORDS_BIGENDIAN
+# define A(x) ((x) >> 24)
+# define B(x) (((x) >> 16) & 0xFF)
+# define C(x) (((x) >> 8) & 0xFF)
+# define D(x) ((x) & 0xFF)
+
+# define S8(x) ((x) << 8)
+# define S32(x) ((x) << 32)
+
+#else
+# define A(x) ((x) & 0xFF)
+# define B(x) (((x) >> 8) & 0xFF)
+# define C(x) (((x) >> 16) & 0xFF)
+# define D(x) ((x) >> 24)
+
+# define S8(x) ((x) >> 8)
+# define S32(x) ((x) >> 32)
+#endif
+
+
+// CRC CLMUL code needs this because accessing input buffers that aren't
+// aligned to the vector size will inherently trip the address sanitizer.
+#if lzma_has_attribute(__no_sanitize_address__)
+# define crc_attr_no_sanitize_address \
+ __attribute__((__no_sanitize_address__))
+#else
+# define crc_attr_no_sanitize_address
+#endif
+
+// Keep this in sync with changes to crc32_arm64.h
+#if defined(_WIN32) || defined(HAVE_GETAUXVAL) \
+ || defined(HAVE_ELF_AUX_INFO) \
+ || (defined(__APPLE__) && defined(HAVE_SYSCTLBYNAME))
+# define ARM64_RUNTIME_DETECTION 1
+#endif
+
+
+#undef CRC32_GENERIC
+#undef CRC64_GENERIC
+
+#undef CRC32_ARCH_OPTIMIZED
+#undef CRC64_ARCH_OPTIMIZED
+
+// The x86 CLMUL is used for both CRC32 and CRC64.
+#undef CRC_X86_CLMUL
+
+#undef CRC32_ARM64
+#undef CRC64_ARM64_CLMUL
+
+#undef CRC_USE_IFUNC
+
+#undef CRC_USE_GENERIC_FOR_SMALL_INPUTS
+
+// ARM64 CRC32 instruction is only useful for CRC32. Currently, only
+// little endian is supported since we were unable to test on a big
+// endian machine.
+//
+// NOTE: Keep this and the next check in sync with the macro
+// ARM64_CRC32_NO_TABLE in crc32_table.c
+#if defined(HAVE_ARM64_CRC32) && !defined(WORDS_BIGENDIAN)
+// Allow ARM64 CRC32 instruction without a runtime check if
+// __ARM_FEATURE_CRC32 is defined. GCC and Clang only define this if the
+// proper compiler options are used.
+# if defined(__ARM_FEATURE_CRC32)
+# define CRC32_ARCH_OPTIMIZED 1
+# define CRC32_ARM64 1
+# elif defined(ARM64_RUNTIME_DETECTION)
+# define CRC32_ARCH_OPTIMIZED 1
+# define CRC32_ARM64 1
+# define CRC32_GENERIC 1
+# endif
+#endif
+
+#if defined(HAVE_USABLE_CLMUL)
+// If CLMUL is allowed unconditionally in the compiler options then the
+// generic version can be omitted. Note that this doesn't work with MSVC
+// as I don't know how to detect the features here.
+//
+// NOTE: Keep this in sync with the CLMUL_NO_TABLE macro in crc32_table.c.
+# if (defined(__SSSE3__) && defined(__SSE4_1__) && defined(__PCLMUL__)) \
+ || (defined(__e2k__) && __iset__ >= 6)
+# define CRC32_ARCH_OPTIMIZED 1
+# define CRC64_ARCH_OPTIMIZED 1
+# define CRC_X86_CLMUL 1
+# else
+# define CRC32_GENERIC 1
+# define CRC64_GENERIC 1
+# define CRC32_ARCH_OPTIMIZED 1
+# define CRC64_ARCH_OPTIMIZED 1
+# define CRC_X86_CLMUL 1
+
+# ifdef HAVE_FUNC_ATTRIBUTE_IFUNC
+# define CRC_USE_IFUNC 1
+# endif
+/*
+ // The generic code is much faster with 1-8-byte inputs and
+ // has similar performance up to 16 bytes at least in
+ // microbenchmarks (it depends on input buffer alignment
+ // too). If both versions are built, this #define will use
+ // the generic version for inputs up to 16 bytes and CLMUL
+ // for bigger inputs. It saves a little in code size since
+ // the special cases for 0-16-byte inputs will be omitted
+ // from the CLMUL code.
+# ifndef CRC_USE_IFUNC
+# define CRC_USE_GENERIC_FOR_SMALL_INPUTS 1
+# endif
+*/
+# endif
+#endif
+
+// For CRC32 use the generic slice-by-eight implementation if no optimized
+// version is available.
+#if !defined(CRC32_ARCH_OPTIMIZED) && !defined(CRC32_GENERIC)
+# define CRC32_GENERIC 1
+#endif
+
+// For CRC64 use the generic slice-by-four implementation if no optimized
+// version is available.
+#if !defined(CRC64_ARCH_OPTIMIZED) && !defined(CRC64_GENERIC)
+# define CRC64_GENERIC 1
+#endif
+
+#endif
diff --git a/src/liblzma/check/crc_macros.h b/src/liblzma/check/crc_macros.h
deleted file mode 100644
index a7c21b765dca..000000000000
--- a/src/liblzma/check/crc_macros.h
+++ /dev/null
@@ -1,30 +0,0 @@
-///////////////////////////////////////////////////////////////////////////////
-//
-/// \file crc_macros.h
-/// \brief Some endian-dependent macros for CRC32 and CRC64
-//
-// Author: Lasse Collin
-//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
-///////////////////////////////////////////////////////////////////////////////
-
-#ifdef WORDS_BIGENDIAN
-# define A(x) ((x) >> 24)
-# define B(x) (((x) >> 16) & 0xFF)
-# define C(x) (((x) >> 8) & 0xFF)
-# define D(x) ((x) & 0xFF)
-
-# define S8(x) ((x) << 8)
-# define S32(x) ((x) << 32)
-
-#else
-# define A(x) ((x) & 0xFF)
-# define B(x) (((x) >> 8) & 0xFF)
-# define C(x) (((x) >> 16) & 0xFF)
-# define D(x) ((x) >> 24)
-
-# define S8(x) ((x) >> 8)
-# define S32(x) ((x) >> 32)
-#endif
diff --git a/src/liblzma/check/crc_x86_clmul.h b/src/liblzma/check/crc_x86_clmul.h
new file mode 100644
index 000000000000..ae66ca9f8c71
--- /dev/null
+++ b/src/liblzma/check/crc_x86_clmul.h
@@ -0,0 +1,435 @@
+// SPDX-License-Identifier: 0BSD
+
+///////////////////////////////////////////////////////////////////////////////
+//
+/// \file crc_x86_clmul.h
+/// \brief CRC32 and CRC64 implementations using CLMUL instructions.
+///
+/// The CRC32 and CRC64 implementations use 32/64-bit x86 SSSE3, SSE4.1, and
+/// CLMUL instructions. This is compatible with Elbrus 2000 (E2K) too.
+///
+/// They were derived from
+/// https://www.researchgate.net/publication/263424619_Fast_CRC_computation
+/// and the public domain code from https://github.com/rawrunprotected/crc
+/// (URLs were checked on 2023-10-14).
+///
+/// While this file has both CRC32 and CRC64 implementations, only one
+/// should be built at a time to ensure that crc_simd_body() is inlined
+/// even with compilers with which lzma_always_inline expands to plain inline.
+/// The version to build is selected by defining BUILDING_CRC32_CLMUL or
+/// BUILDING_CRC64_CLMUL before including this file.
+///
+/// FIXME: Builds for 32-bit x86 use the assembly .S files by default
+/// unless configured with --disable-assembler. Even then the lookup table
+/// isn't omitted in crc64_table.c since it doesn't know that assembly
+/// code has been disabled.
+//
+// Authors: Ilya Kurdyukov
+// Hans Jansen
+// Lasse Collin
+// Jia Tan
+//
+///////////////////////////////////////////////////////////////////////////////
+
+// This file must not be included more than once.
+#ifdef LZMA_CRC_X86_CLMUL_H
+# error crc_x86_clmul.h was included twice.
+#endif
+#define LZMA_CRC_X86_CLMUL_H
+
+#include <immintrin.h>
+
+#if defined(_MSC_VER)
+# include <intrin.h>
+#elif defined(HAVE_CPUID_H)
+# include <cpuid.h>
+#endif
+
+
+// EDG-based compilers (Intel's classic compiler and compiler for E2K) can
+// define __GNUC__ but the attribute must not be used with them.
+// The new Clang-based ICX needs the attribute.
+//
+// NOTE: Build systems check for this too, keep them in sync with this.
+#if (defined(__GNUC__) || defined(__clang__)) && !defined(__EDG__)
+# define crc_attr_target \
+ __attribute__((__target__("ssse3,sse4.1,pclmul")))
+#else
+# define crc_attr_target
+#endif
+
+
+#define MASK_L(in, mask, r) r = _mm_shuffle_epi8(in, mask)
+
+#define MASK_H(in, mask, r) \
+ r = _mm_shuffle_epi8(in, _mm_xor_si128(mask, vsign))
+
+#define MASK_LH(in, mask, low, high) \
+ MASK_L(in, mask, low); \
+ MASK_H(in, mask, high)
+
+
+crc_attr_target
+crc_attr_no_sanitize_address
+static lzma_always_inline void
+crc_simd_body(const uint8_t *buf, const size_t size, __m128i *v0, __m128i *v1,
+ const __m128i vfold16, const __m128i initial_crc)
+{
+ // Create a vector with 8-bit values 0 to 15. This is used to
+ // construct control masks for _mm_blendv_epi8 and _mm_shuffle_epi8.
+ const __m128i vramp = _mm_setr_epi32(
+ 0x03020100, 0x07060504, 0x0b0a0908, 0x0f0e0d0c);
+
+ // This is used to inverse the control mask of _mm_shuffle_epi8
+ // so that bytes that wouldn't be picked with the original mask
+ // will be picked and vice versa.
+ const __m128i vsign = _mm_set1_epi8(-0x80);
+
+ // Memory addresses A to D and the distances between them:
+ //
+ // A B C D
+ // [skip_start][size][skip_end]
+ // [ size2 ]
+ //
+ // A and D are 16-byte aligned. B and C are 1-byte aligned.
+ // skip_start and skip_end are 0-15 bytes. size is at least 1 byte.
+ //
+ // A = aligned_buf will initially point to this address.
+ // B = The address pointed by the caller-supplied buf.
+ // C = buf + size == aligned_buf + size2
+ // D = buf + size + skip_end == aligned_buf + size2 + skip_end
+ const size_t skip_start = (size_t)((uintptr_t)buf & 15);
+ const size_t skip_end = (size_t)((0U - (uintptr_t)(buf + size)) & 15);
+ const __m128i *aligned_buf = (const __m128i *)(
+ (uintptr_t)buf & ~(uintptr_t)15);
+
+ // If size2 <= 16 then the whole input fits into a single 16-byte
+ // vector. If size2 > 16 then at least two 16-byte vectors must
+ // be processed. If size2 > 16 && size <= 16 then there is only
+ // one 16-byte vector's worth of input but it is unaligned in memory.
+ //
+ // NOTE: There is no integer overflow here if the arguments
+ // are valid. If this overflowed, buf + size would too.
+ const size_t size2 = skip_start + size;
+
+ // Masks to be used with _mm_blendv_epi8 and _mm_shuffle_epi8:
+ // The first skip_start or skip_end bytes in the vectors will have
+ // the high bit (0x80) set. _mm_blendv_epi8 and _mm_shuffle_epi8
+ // will produce zeros for these positions. (Bitwise-xor of these
+ // masks with vsign will produce the opposite behavior.)
+ const __m128i mask_start
+ = _mm_sub_epi8(vramp, _mm_set1_epi8((char)skip_start));
+ const __m128i mask_end
+ = _mm_sub_epi8(vramp, _mm_set1_epi8((char)skip_end));
+
+ // Get the first 1-16 bytes into data0. If loading less than 16
+ // bytes, the bytes are loaded to the high bits of the vector and
+ // the least significant positions are filled with zeros.
+ const __m128i data0 = _mm_blendv_epi8(_mm_load_si128(aligned_buf),
+ _mm_setzero_si128(), mask_start);
+ aligned_buf++;
+
+ __m128i v2, v3;
+
+#ifndef CRC_USE_GENERIC_FOR_SMALL_INPUTS
+ if (size <= 16) {
+ // Right-shift initial_crc by 1-16 bytes based on "size"
+ // and store the result in v1 (high bytes) and v0 (low bytes).
+ //
+ // NOTE: The highest 8 bytes of initial_crc are zeros so
+ // v1 will be filled with zeros if size >= 8. The highest
+ // 8 bytes of v1 will always become zeros.
+ //
+ // [ v1 ][ v0 ]
+ // [ initial_crc ] size == 1
+ // [ initial_crc ] size == 2
+ // [ initial_crc ] size == 15
+ // [ initial_crc ] size == 16 (all in v0)
+ const __m128i mask_low = _mm_add_epi8(
+ vramp, _mm_set1_epi8((char)(size - 16)));
+ MASK_LH(initial_crc, mask_low, *v0, *v1);
+
+ if (size2 <= 16) {
+ // There are 1-16 bytes of input and it is all
+ // in data0. Copy the input bytes to v3. If there
+ // are fewer than 16 bytes, the low bytes in v3
+ // will be filled with zeros. That is, the input
+ // bytes are stored to the same position as
+ // (part of) initial_crc is in v0.
+ MASK_L(data0, mask_end, v3);
+ } else {
+ // There are 2-16 bytes of input but not all bytes
+ // are in data0.
+ const __m128i data1 = _mm_load_si128(aligned_buf);
+
+ // Collect the 2-16 input bytes from data0 and data1
+ // to v2 and v3, and bitwise-xor them with the
+ // low bits of initial_crc in v0. Note that the
+ // the second xor is below this else-block as it
+ // is shared with the other branch.
+ MASK_H(data0, mask_end, v2);
+ MASK_L(data1, mask_end, v3);
+ *v0 = _mm_xor_si128(*v0, v2);
+ }
+
+ *v0 = _mm_xor_si128(*v0, v3);
+ *v1 = _mm_alignr_epi8(*v1, *v0, 8);
+ } else
+#endif
+ {
+ // There is more than 16 bytes of input.
+ const __m128i data1 = _mm_load_si128(aligned_buf);
+ const __m128i *end = (const __m128i*)(
+ (const char *)aligned_buf - 16 + size2);
+ aligned_buf++;
+
+ MASK_LH(initial_crc, mask_start, *v0, *v1);
+ *v0 = _mm_xor_si128(*v0, data0);
+ *v1 = _mm_xor_si128(*v1, data1);
+
+ while (aligned_buf < end) {
+ *v1 = _mm_xor_si128(*v1, _mm_clmulepi64_si128(
+ *v0, vfold16, 0x00));
+ *v0 = _mm_xor_si128(*v1, _mm_clmulepi64_si128(
+ *v0, vfold16, 0x11));
+ *v1 = _mm_load_si128(aligned_buf++);
+ }
+
+ if (aligned_buf != end) {
+ MASK_H(*v0, mask_end, v2);
+ MASK_L(*v0, mask_end, *v0);
+ MASK_L(*v1, mask_end, v3);
+ *v1 = _mm_or_si128(v2, v3);
+ }
+
+ *v1 = _mm_xor_si128(*v1, _mm_clmulepi64_si128(
+ *v0, vfold16, 0x00));
+ *v0 = _mm_xor_si128(*v1, _mm_clmulepi64_si128(
+ *v0, vfold16, 0x11));
+ *v1 = _mm_srli_si128(*v0, 8);
+ }
+}
+
+
+/////////////////////
+// x86 CLMUL CRC32 //
+/////////////////////
+
+/*
+// These functions were used to generate the constants
+// at the top of crc32_arch_optimized().
+static uint64_t
+calc_lo(uint64_t p, uint64_t a, int n)
+{
+ uint64_t b = 0; int i;
+ for (i = 0; i < n; i++) {
+ b = b >> 1 | (a & 1) << (n - 1);
+ a = (a >> 1) ^ ((0 - (a & 1)) & p);
+ }
+ return b;
+}
+
+// same as ~crc(&a, sizeof(a), ~0)
+static uint64_t
+calc_hi(uint64_t p, uint64_t a, int n)
+{
+ int i;
+ for (i = 0; i < n; i++)
+ a = (a >> 1) ^ ((0 - (a & 1)) & p);
+ return a;
+}
+*/
+
+#ifdef BUILDING_CRC32_CLMUL
+
+crc_attr_target
+crc_attr_no_sanitize_address
+static uint32_t
+crc32_arch_optimized(const uint8_t *buf, size_t size, uint32_t crc)
+{
+#ifndef CRC_USE_GENERIC_FOR_SMALL_INPUTS
+ // The code assumes that there is at least one byte of input.
+ if (size == 0)
+ return crc;
+#endif
+
+ // uint32_t poly = 0xedb88320;
+ const int64_t p = 0x1db710640; // p << 1
+ const int64_t mu = 0x1f7011641; // calc_lo(p, p, 32) << 1 | 1
+ const int64_t k5 = 0x163cd6124; // calc_hi(p, p, 32) << 1
+ const int64_t k4 = 0x0ccaa009e; // calc_hi(p, p, 64) << 1
+ const int64_t k3 = 0x1751997d0; // calc_hi(p, p, 128) << 1
+
+ const __m128i vfold4 = _mm_set_epi64x(mu, p);
+ const __m128i vfold8 = _mm_set_epi64x(0, k5);
+ const __m128i vfold16 = _mm_set_epi64x(k4, k3);
+
+ __m128i v0, v1, v2;
+
+ crc_simd_body(buf, size, &v0, &v1, vfold16,
+ _mm_cvtsi32_si128((int32_t)~crc));
+
+ v1 = _mm_xor_si128(
+ _mm_clmulepi64_si128(v0, vfold16, 0x10), v1); // xxx0
+ v2 = _mm_shuffle_epi32(v1, 0xe7); // 0xx0
+ v0 = _mm_slli_epi64(v1, 32); // [0]
+ v0 = _mm_clmulepi64_si128(v0, vfold8, 0x00);
+ v0 = _mm_xor_si128(v0, v2); // [1] [2]
+ v2 = _mm_clmulepi64_si128(v0, vfold4, 0x10);
+ v2 = _mm_clmulepi64_si128(v2, vfold4, 0x00);
+ v0 = _mm_xor_si128(v0, v2); // [2]
+ return ~(uint32_t)_mm_extract_epi32(v0, 2);
+}
+#endif // BUILDING_CRC32_CLMUL
+
+
+/////////////////////
+// x86 CLMUL CRC64 //
+/////////////////////
+
+/*
+// These functions were used to generate the constants
+// at the top of crc64_arch_optimized().
+static uint64_t
+calc_lo(uint64_t poly)
+{
+ uint64_t a = poly;
+ uint64_t b = 0;
+
+ for (unsigned i = 0; i < 64; ++i) {
+ b = (b >> 1) | (a << 63);
+ a = (a >> 1) ^ (a & 1 ? poly : 0);
+ }
+
+ return b;
+}
+
+static uint64_t
+calc_hi(uint64_t poly, uint64_t a)
+{
+ for (unsigned i = 0; i < 64; ++i)
+ a = (a >> 1) ^ (a & 1 ? poly : 0);
+
+ return a;
+}
+*/
+
+#ifdef BUILDING_CRC64_CLMUL
+
+// MSVC (VS2015 - VS2022) produces bad 32-bit x86 code from the CLMUL CRC
+// code when optimizations are enabled (release build). According to the bug
+// report, the ebx register is corrupted and the calculated result is wrong.
+// Trying to workaround the problem with "__asm mov ebx, ebx" didn't help.
+// The following pragma works and performance is still good. x86-64 builds
+// and CRC32 CLMUL aren't affected by this problem. The problem does not
+// happen in crc_simd_body() either (which is shared with CRC32 CLMUL anyway).
+//
+// NOTE: Another pragma after crc64_arch_optimized() restores
+// the optimizations. If the #if condition here is updated,
+// the other one must be updated too.
+#if defined(_MSC_VER) && !defined(__INTEL_COMPILER) && !defined(__clang__) \
+ && defined(_M_IX86)
+# pragma optimize("g", off)
+#endif
+
+crc_attr_target
+crc_attr_no_sanitize_address
+static uint64_t
+crc64_arch_optimized(const uint8_t *buf, size_t size, uint64_t crc)
+{
+#ifndef CRC_USE_GENERIC_FOR_SMALL_INPUTS
+ // The code assumes that there is at least one byte of input.
+ if (size == 0)
+ return crc;
+#endif
+
+ // const uint64_t poly = 0xc96c5795d7870f42; // CRC polynomial
+ const uint64_t p = 0x92d8af2baf0e1e85; // (poly << 1) | 1
+ const uint64_t mu = 0x9c3e466c172963d5; // (calc_lo(poly) << 1) | 1
+ const uint64_t k2 = 0xdabe95afc7875f40; // calc_hi(poly, 1)
+ const uint64_t k1 = 0xe05dd497ca393ae4; // calc_hi(poly, k2)
+
+ const __m128i vfold8 = _mm_set_epi64x((int64_t)p, (int64_t)mu);
+ const __m128i vfold16 = _mm_set_epi64x((int64_t)k2, (int64_t)k1);
+
+ __m128i v0, v1, v2;
+
+#if defined(__i386__) || defined(_M_IX86)
+ crc_simd_body(buf, size, &v0, &v1, vfold16,
+ _mm_set_epi64x(0, (int64_t)~crc));
+#else
+ // GCC and Clang would produce good code with _mm_set_epi64x
+ // but MSVC needs _mm_cvtsi64_si128 on x86-64.
+ crc_simd_body(buf, size, &v0, &v1, vfold16,
+ _mm_cvtsi64_si128((int64_t)~crc));
+#endif
+
+ v1 = _mm_xor_si128(_mm_clmulepi64_si128(v0, vfold16, 0x10), v1);
+ v0 = _mm_clmulepi64_si128(v1, vfold8, 0x00);
+ v2 = _mm_clmulepi64_si128(v0, vfold8, 0x10);
+ v0 = _mm_xor_si128(_mm_xor_si128(v1, _mm_slli_si128(v0, 8)), v2);
+
+#if defined(__i386__) || defined(_M_IX86)
+ return ~(((uint64_t)(uint32_t)_mm_extract_epi32(v0, 3) << 32) |
+ (uint64_t)(uint32_t)_mm_extract_epi32(v0, 2));
+#else
+ return ~(uint64_t)_mm_extract_epi64(v0, 1);
+#endif
+}
+
+#if defined(_MSC_VER) && !defined(__INTEL_COMPILER) && !defined(__clang__) \
+ && defined(_M_IX86)
+# pragma optimize("", on)
+#endif
+
+#endif // BUILDING_CRC64_CLMUL
+
+
+// is_arch_extension_supported() must be inlined in this header file because
+// the ifunc resolver function may not support calling a function in another
+// translation unit. Depending on compiler-toolchain and flags, a call to
+// a function defined in another translation unit could result in a
+// reference to the PLT, which is unsafe to do in an ifunc resolver. The
+// ifunc resolver runs very early when loading a shared library, so the PLT
+// entries may not be setup at that time. Inlining this function duplicates
+// the function body in crc32_resolve() and crc64_resolve(), but this is
+// acceptable because the function results in very few instructions.
+static inline bool
+is_arch_extension_supported(void)
+{
+ int success = 1;
+ uint32_t r[4]; // eax, ebx, ecx, edx
+
+#if defined(_MSC_VER)
+ // This needs <intrin.h> with MSVC. ICC has it as a built-in
+ // on all platforms.
+ __cpuid(r, 1);
+#elif defined(HAVE_CPUID_H)
+ // Compared to just using __asm__ to run CPUID, this also checks
+ // that CPUID is supported and saves and restores ebx as that is
+ // needed with GCC < 5 with position-independent code (PIC).
+ success = __get_cpuid(1, &r[0], &r[1], &r[2], &r[3]);
+#else
+ // Just a fallback that shouldn't be needed.
+ __asm__("cpuid\n\t"
+ : "=a"(r[0]), "=b"(r[1]), "=c"(r[2]), "=d"(r[3])
+ : "a"(1), "c"(0));
+#endif
+
+ // Returns true if these are supported:
+ // CLMUL (bit 1 in ecx)
+ // SSSE3 (bit 9 in ecx)
+ // SSE4.1 (bit 19 in ecx)
+ const uint32_t ecx_mask = (1 << 1) | (1 << 9) | (1 << 19);
+ return success && (r[2] & ecx_mask) == ecx_mask;
+
+ // Alternative methods that weren't used:
+ // - ICC's _may_i_use_cpu_feature: the other methods should work too.
+ // - GCC >= 6 / Clang / ICX __builtin_cpu_supports("pclmul")
+ //
+ // CPUID decding is needed with MSVC anyway and older GCC. This keeps
+ // the feature checks in the build system simpler too. The nice thing
+ // about __builtin_cpu_supports would be that it generates very short
+ // code as is it only reads a variable set at startup but a few bytes
+ // doesn't matter here.
+}
diff --git a/src/liblzma/check/sha256.c b/src/liblzma/check/sha256.c
index 6feb342565fb..bd0d2806397c 100644
--- a/src/liblzma/check/sha256.c
+++ b/src/liblzma/check/sha256.c
@@ -1,24 +1,17 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file sha256.c
/// \brief SHA-256
-///
-/// \todo Crypto++ has x86 ASM optimizations. They use SSE so if they
-/// are imported to liblzma, SSE instructions need to be used
-/// conditionally to keep the code working on older boxes.
//
-// This code is based on the code found from 7-Zip, which has a modified
-// version of the SHA-256 found from Crypto++ <https://www.cryptopp.com/>.
-// The code was modified a little to fit into liblzma.
+// The C code is based on the public domain SHA-256 code found from
+// Crypto++ Library 5.5.1 released in 2007: https://www.cryptopp.com/
+// A few minor tweaks have been made in liblzma.
//
-// Authors: Kevin Springle
-// Wei Dai
-// Igor Pavlov
+// Authors: Wei Dai
// Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
#include "check.h"
diff --git a/src/liblzma/common/alone_decoder.c b/src/liblzma/common/alone_decoder.c
index 1dc85badf941..78af651578fc 100644
--- a/src/liblzma/common/alone_decoder.c
+++ b/src/liblzma/common/alone_decoder.c
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file alone_decoder.c
@@ -5,9 +7,6 @@
//
// Author: Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
#include "alone_decoder.h"
diff --git a/src/liblzma/common/alone_decoder.h b/src/liblzma/common/alone_decoder.h
index dfa031aa77dd..61ee24d97fe4 100644
--- a/src/liblzma/common/alone_decoder.h
+++ b/src/liblzma/common/alone_decoder.h
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file alone_decoder.h
@@ -5,9 +7,6 @@
//
// Author: Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
#ifndef LZMA_ALONE_DECODER_H
diff --git a/src/liblzma/common/alone_encoder.c b/src/liblzma/common/alone_encoder.c
index 7d3812fa6ea4..21b039509ae5 100644
--- a/src/liblzma/common/alone_encoder.c
+++ b/src/liblzma/common/alone_encoder.c
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file alone_encoder.c
@@ -5,9 +7,6 @@
//
// Author: Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
#include "common.h"
diff --git a/src/liblzma/common/auto_decoder.c b/src/liblzma/common/auto_decoder.c
index 2a5c0894d123..fdd520f905c5 100644
--- a/src/liblzma/common/auto_decoder.c
+++ b/src/liblzma/common/auto_decoder.c
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file auto_decoder.c
@@ -5,9 +7,6 @@
//
// Author: Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
#include "stream_decoder.h"
diff --git a/src/liblzma/common/block_buffer_decoder.c b/src/liblzma/common/block_buffer_decoder.c
index b0ded90ddc3e..55566cd2f2b0 100644
--- a/src/liblzma/common/block_buffer_decoder.c
+++ b/src/liblzma/common/block_buffer_decoder.c
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file block_buffer_decoder.c
@@ -5,9 +7,6 @@
//
// Author: Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
#include "block_decoder.h"
diff --git a/src/liblzma/common/block_buffer_encoder.c b/src/liblzma/common/block_buffer_encoder.c
index fdef02de8955..df3b90e8a186 100644
--- a/src/liblzma/common/block_buffer_encoder.c
+++ b/src/liblzma/common/block_buffer_encoder.c
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file block_buffer_encoder.c
@@ -5,9 +7,6 @@
//
// Author: Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
#include "block_buffer_encoder.h"
diff --git a/src/liblzma/common/block_buffer_encoder.h b/src/liblzma/common/block_buffer_encoder.h
index 653207f73498..5274ac40d3aa 100644
--- a/src/liblzma/common/block_buffer_encoder.h
+++ b/src/liblzma/common/block_buffer_encoder.h
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file block_buffer_encoder.h
@@ -5,9 +7,6 @@
//
// Author: Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
#ifndef LZMA_BLOCK_BUFFER_ENCODER_H
diff --git a/src/liblzma/common/block_decoder.c b/src/liblzma/common/block_decoder.c
index be647d4855d4..2e369d316bdf 100644
--- a/src/liblzma/common/block_decoder.c
+++ b/src/liblzma/common/block_decoder.c
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file block_decoder.c
@@ -5,9 +7,6 @@
//
// Author: Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
#include "block_decoder.h"
diff --git a/src/liblzma/common/block_decoder.h b/src/liblzma/common/block_decoder.h
index 718c5ced886c..2cbf9ba6db83 100644
--- a/src/liblzma/common/block_decoder.h
+++ b/src/liblzma/common/block_decoder.h
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file block_decoder.h
@@ -5,9 +7,6 @@
//
// Author: Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
#ifndef LZMA_BLOCK_DECODER_H
diff --git a/src/liblzma/common/block_encoder.c b/src/liblzma/common/block_encoder.c
index 4a136ef65e33..ce8c1de69442 100644
--- a/src/liblzma/common/block_encoder.c
+++ b/src/liblzma/common/block_encoder.c
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file block_encoder.c
@@ -5,9 +7,6 @@
//
// Author: Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
#include "block_encoder.h"
diff --git a/src/liblzma/common/block_encoder.h b/src/liblzma/common/block_encoder.h
index bd97c186e503..b7dfe9a08417 100644
--- a/src/liblzma/common/block_encoder.h
+++ b/src/liblzma/common/block_encoder.h
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file block_encoder.h
@@ -5,9 +7,6 @@
//
// Author: Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
#ifndef LZMA_BLOCK_ENCODER_H
diff --git a/src/liblzma/common/block_header_decoder.c b/src/liblzma/common/block_header_decoder.c
index c4935dcf46c1..f0b2fbe54d8d 100644
--- a/src/liblzma/common/block_header_decoder.c
+++ b/src/liblzma/common/block_header_decoder.c
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file block_header_decoder.c
@@ -5,9 +7,6 @@
//
// Author: Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
#include "common.h"
diff --git a/src/liblzma/common/block_header_encoder.c b/src/liblzma/common/block_header_encoder.c
index 160425d27a35..45e57a26aba8 100644
--- a/src/liblzma/common/block_header_encoder.c
+++ b/src/liblzma/common/block_header_encoder.c
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file block_header_encoder.c
@@ -5,9 +7,6 @@
//
// Author: Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
#include "common.h"
diff --git a/src/liblzma/common/block_util.c b/src/liblzma/common/block_util.c
index acb311142c21..191f6d444aa6 100644
--- a/src/liblzma/common/block_util.c
+++ b/src/liblzma/common/block_util.c
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file block_util.c
@@ -5,9 +7,6 @@
//
// Author: Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
#include "common.h"
diff --git a/src/liblzma/common/common.c b/src/liblzma/common/common.c
index adb50d785d52..cc0e06a51bee 100644
--- a/src/liblzma/common/common.c
+++ b/src/liblzma/common/common.c
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file common.c
@@ -5,9 +7,6 @@
//
// Author: Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
#include "common.h"
diff --git a/src/liblzma/common/common.h b/src/liblzma/common/common.h
index 378923e4012b..20af32f6d6cd 100644
--- a/src/liblzma/common/common.h
+++ b/src/liblzma/common/common.h
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file common.h
@@ -5,9 +7,6 @@
//
// Author: Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
#ifndef LZMA_COMMON_H
diff --git a/src/liblzma/common/easy_buffer_encoder.c b/src/liblzma/common/easy_buffer_encoder.c
index 48eb56f5cc91..da610cea6bfa 100644
--- a/src/liblzma/common/easy_buffer_encoder.c
+++ b/src/liblzma/common/easy_buffer_encoder.c
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file easy_buffer_encoder.c
@@ -5,9 +7,6 @@
//
// Author: Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
#include "easy_preset.h"
diff --git a/src/liblzma/common/easy_decoder_memusage.c b/src/liblzma/common/easy_decoder_memusage.c
index 20bcd5b71758..0c76f10033b6 100644
--- a/src/liblzma/common/easy_decoder_memusage.c
+++ b/src/liblzma/common/easy_decoder_memusage.c
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file easy_decoder_memusage.c
@@ -5,9 +7,6 @@
//
// Author: Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
#include "easy_preset.h"
diff --git a/src/liblzma/common/easy_encoder.c b/src/liblzma/common/easy_encoder.c
index 5cb492dd0681..8dfe29610f79 100644
--- a/src/liblzma/common/easy_encoder.c
+++ b/src/liblzma/common/easy_encoder.c
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file easy_encoder.c
@@ -5,9 +7,6 @@
//
// Author: Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
#include "easy_preset.h"
diff --git a/src/liblzma/common/easy_encoder_memusage.c b/src/liblzma/common/easy_encoder_memusage.c
index e91057584233..1184ac665425 100644
--- a/src/liblzma/common/easy_encoder_memusage.c
+++ b/src/liblzma/common/easy_encoder_memusage.c
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file easy_encoder_memusage.c
@@ -5,9 +7,6 @@
//
// Author: Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
#include "easy_preset.h"
diff --git a/src/liblzma/common/easy_preset.c b/src/liblzma/common/easy_preset.c
index 2f9859860ad7..7908a2bb73c8 100644
--- a/src/liblzma/common/easy_preset.c
+++ b/src/liblzma/common/easy_preset.c
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file easy_preset.c
@@ -5,9 +7,6 @@
//
// Author: Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
#include "easy_preset.h"
diff --git a/src/liblzma/common/easy_preset.h b/src/liblzma/common/easy_preset.h
index 382ade894066..d0ca1a6234a1 100644
--- a/src/liblzma/common/easy_preset.h
+++ b/src/liblzma/common/easy_preset.h
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file easy_preset.h
@@ -5,9 +7,6 @@
//
// Author: Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
#include "common.h"
diff --git a/src/liblzma/common/file_info.c b/src/liblzma/common/file_info.c
index 799bb024fe1f..7c85084a706e 100644
--- a/src/liblzma/common/file_info.c
+++ b/src/liblzma/common/file_info.c
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file file_info.c
@@ -5,9 +7,6 @@
//
// Author: Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
#include "index_decoder.h"
diff --git a/src/liblzma/common/filter_buffer_decoder.c b/src/liblzma/common/filter_buffer_decoder.c
index 6620986eea8a..e80c582c916f 100644
--- a/src/liblzma/common/filter_buffer_decoder.c
+++ b/src/liblzma/common/filter_buffer_decoder.c
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file filter_buffer_decoder.c
@@ -5,9 +7,6 @@
//
// Author: Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
#include "filter_decoder.h"
diff --git a/src/liblzma/common/filter_buffer_encoder.c b/src/liblzma/common/filter_buffer_encoder.c
index dda18e3d8e5e..7fb8922ae90e 100644
--- a/src/liblzma/common/filter_buffer_encoder.c
+++ b/src/liblzma/common/filter_buffer_encoder.c
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file filter_buffer_encoder.c
@@ -5,9 +7,6 @@
//
// Author: Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
#include "filter_encoder.h"
diff --git a/src/liblzma/common/filter_common.c b/src/liblzma/common/filter_common.c
index fa0927cf9b9f..2da6bd9c7781 100644
--- a/src/liblzma/common/filter_common.c
+++ b/src/liblzma/common/filter_common.c
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file filter_common.c
@@ -5,9 +7,6 @@
//
// Author: Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
#include "filter_common.h"
@@ -122,6 +121,15 @@ static const struct {
.changes_size = false,
},
#endif
+#if defined(HAVE_ENCODER_RISCV) || defined(HAVE_DECODER_RISCV)
+ {
+ .id = LZMA_FILTER_RISCV,
+ .options_size = sizeof(lzma_options_bcj),
+ .non_last_ok = true,
+ .last_ok = false,
+ .changes_size = false,
+ },
+#endif
#if defined(HAVE_ENCODER_DELTA) || defined(HAVE_DECODER_DELTA)
{
.id = LZMA_FILTER_DELTA,
diff --git a/src/liblzma/common/filter_common.h b/src/liblzma/common/filter_common.h
index 2e47bb69f7f6..95f9fe27017b 100644
--- a/src/liblzma/common/filter_common.h
+++ b/src/liblzma/common/filter_common.h
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file filter_common.h
@@ -5,9 +7,6 @@
//
// Author: Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
#ifndef LZMA_FILTER_COMMON_H
diff --git a/src/liblzma/common/filter_decoder.c b/src/liblzma/common/filter_decoder.c
index fa53f5bdbad0..77441e5449c3 100644
--- a/src/liblzma/common/filter_decoder.c
+++ b/src/liblzma/common/filter_decoder.c
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file filter_decoder.c
@@ -5,9 +7,6 @@
//
// Author: Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
#include "filter_decoder.h"
@@ -121,6 +120,14 @@ static const lzma_filter_decoder decoders[] = {
.props_decode = &lzma_simple_props_decode,
},
#endif
+#ifdef HAVE_DECODER_RISCV
+ {
+ .id = LZMA_FILTER_RISCV,
+ .init = &lzma_simple_riscv_decoder_init,
+ .memusage = NULL,
+ .props_decode = &lzma_simple_props_decode,
+ },
+#endif
#ifdef HAVE_DECODER_DELTA
{
.id = LZMA_FILTER_DELTA,
diff --git a/src/liblzma/common/filter_decoder.h b/src/liblzma/common/filter_decoder.h
index 2dac60282826..e610bc1f44ec 100644
--- a/src/liblzma/common/filter_decoder.h
+++ b/src/liblzma/common/filter_decoder.h
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file filter_decoder.h
@@ -5,9 +7,6 @@
//
// Author: Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
#ifndef LZMA_FILTER_DECODER_H
diff --git a/src/liblzma/common/filter_encoder.c b/src/liblzma/common/filter_encoder.c
index 46fe8af1c153..523d37310010 100644
--- a/src/liblzma/common/filter_encoder.c
+++ b/src/liblzma/common/filter_encoder.c
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file filter_decoder.c
@@ -5,9 +7,6 @@
//
// Author: Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
#include "filter_encoder.h"
@@ -33,7 +32,8 @@ typedef struct {
/// Calculates the recommended Uncompressed Size for .xz Blocks to
/// which the input data can be split to make multithreaded
/// encoding possible. If this is NULL, it is assumed that
- /// the encoder is fast enough with single thread.
+ /// the encoder is fast enough with single thread. If the options
+ /// are invalid, UINT64_MAX is returned.
uint64_t (*block_size)(const void *options);
/// Tells the size of the Filter Properties field. If options are
@@ -158,6 +158,16 @@ static const lzma_filter_encoder encoders[] = {
.props_encode = &lzma_simple_props_encode,
},
#endif
+#ifdef HAVE_ENCODER_RISCV
+ {
+ .id = LZMA_FILTER_RISCV,
+ .init = &lzma_simple_riscv_encoder_init,
+ .memusage = NULL,
+ .block_size = NULL,
+ .props_size_get = &lzma_simple_props_size,
+ .props_encode = &lzma_simple_props_encode,
+ },
+#endif
#ifdef HAVE_ENCODER_DELTA
{
.id = LZMA_FILTER_DELTA,
@@ -219,17 +229,17 @@ lzma_filters_update(lzma_stream *strm, const lzma_filter *filters)
extern lzma_ret
lzma_raw_encoder_init(lzma_next_coder *next, const lzma_allocator *allocator,
- const lzma_filter *options)
+ const lzma_filter *filters)
{
return lzma_raw_coder_init(next, allocator,
- options, (lzma_filter_find)(&encoder_find), true);
+ filters, (lzma_filter_find)(&encoder_find), true);
}
extern LZMA_API(lzma_ret)
-lzma_raw_encoder(lzma_stream *strm, const lzma_filter *options)
+lzma_raw_encoder(lzma_stream *strm, const lzma_filter *filters)
{
- lzma_next_strm_init(lzma_raw_coder_init, strm, options,
+ lzma_next_strm_init(lzma_raw_coder_init, strm, filters,
(lzma_filter_find)(&encoder_find), true);
strm->internal->supported_actions[LZMA_RUN] = true;
@@ -248,26 +258,29 @@ lzma_raw_encoder_memusage(const lzma_filter *filters)
}
-extern uint64_t
+extern LZMA_API(uint64_t)
lzma_mt_block_size(const lzma_filter *filters)
{
+ if (filters == NULL)
+ return UINT64_MAX;
+
uint64_t max = 0;
for (size_t i = 0; filters[i].id != LZMA_VLI_UNKNOWN; ++i) {
const lzma_filter_encoder *const fe
= encoder_find(filters[i].id);
+ if (fe == NULL)
+ return UINT64_MAX;
+
if (fe->block_size != NULL) {
const uint64_t size
= fe->block_size(filters[i].options);
- if (size == 0)
- return 0;
-
if (size > max)
max = size;
}
}
- return max;
+ return max == 0 ? UINT64_MAX : max;
}
diff --git a/src/liblzma/common/filter_encoder.h b/src/liblzma/common/filter_encoder.h
index f1d5683fe793..88f2dafa43b0 100644
--- a/src/liblzma/common/filter_encoder.h
+++ b/src/liblzma/common/filter_encoder.h
@@ -1,13 +1,12 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
-/// \file filter_encoder.c
+/// \file filter_encoder.h
/// \brief Filter ID mapping to filter-specific functions
//
// Author: Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
#ifndef LZMA_FILTER_ENCODER_H
@@ -16,10 +15,6 @@
#include "common.h"
-// FIXME: Might become a part of the public API.
-extern uint64_t lzma_mt_block_size(const lzma_filter *filters);
-
-
extern lzma_ret lzma_raw_encoder_init(
lzma_next_coder *next, const lzma_allocator *allocator,
const lzma_filter *filters);
diff --git a/src/liblzma/common/filter_flags_decoder.c b/src/liblzma/common/filter_flags_decoder.c
index ddfb085943d0..0f5d204d474e 100644
--- a/src/liblzma/common/filter_flags_decoder.c
+++ b/src/liblzma/common/filter_flags_decoder.c
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file filter_flags_decoder.c
@@ -5,9 +7,6 @@
//
// Author: Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
#include "filter_decoder.h"
diff --git a/src/liblzma/common/filter_flags_encoder.c b/src/liblzma/common/filter_flags_encoder.c
index b57b9fd80b06..e1d65884fb0b 100644
--- a/src/liblzma/common/filter_flags_encoder.c
+++ b/src/liblzma/common/filter_flags_encoder.c
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file filter_flags_encoder.c
@@ -5,9 +7,6 @@
//
// Author: Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
#include "filter_encoder.h"
diff --git a/src/liblzma/common/hardware_cputhreads.c b/src/liblzma/common/hardware_cputhreads.c
index 5d246d2cc083..4ce852b42c3d 100644
--- a/src/liblzma/common/hardware_cputhreads.c
+++ b/src/liblzma/common/hardware_cputhreads.c
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file hardware_cputhreads.c
@@ -5,9 +7,6 @@
//
// Author: Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
#include "common.h"
diff --git a/src/liblzma/common/hardware_physmem.c b/src/liblzma/common/hardware_physmem.c
index a2bbbe29d4b4..1bc34864e849 100644
--- a/src/liblzma/common/hardware_physmem.c
+++ b/src/liblzma/common/hardware_physmem.c
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file hardware_physmem.c
@@ -5,9 +7,6 @@
//
// Author: Jonathan Nieder
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
#include "common.h"
diff --git a/src/liblzma/common/index.c b/src/liblzma/common/index.c
index 8a35f4398dbe..6add6a683502 100644
--- a/src/liblzma/common/index.c
+++ b/src/liblzma/common/index.c
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file index.c
@@ -5,9 +7,6 @@
//
// Author: Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
#include "common.h"
diff --git a/src/liblzma/common/index.h b/src/liblzma/common/index.h
index 7b27d7004cfa..007e1188f259 100644
--- a/src/liblzma/common/index.h
+++ b/src/liblzma/common/index.h
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file index.h
@@ -12,9 +14,6 @@
//
// Author: Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
#ifndef LZMA_INDEX_H
diff --git a/src/liblzma/common/index_decoder.c b/src/liblzma/common/index_decoder.c
index 19a31b3e944c..f105ff04e8a1 100644
--- a/src/liblzma/common/index_decoder.c
+++ b/src/liblzma/common/index_decoder.c
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file index_decoder.c
@@ -5,9 +7,6 @@
//
// Author: Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
#include "index_decoder.h"
diff --git a/src/liblzma/common/index_decoder.h b/src/liblzma/common/index_decoder.h
index 3fec483331a6..5351d2f0dfa4 100644
--- a/src/liblzma/common/index_decoder.h
+++ b/src/liblzma/common/index_decoder.h
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file index_decoder.h
@@ -5,9 +7,6 @@
//
// Author: Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
#ifndef LZMA_INDEX_DECODER_H
diff --git a/src/liblzma/common/index_encoder.c b/src/liblzma/common/index_encoder.c
index 204490cc19d4..ecc299c0159f 100644
--- a/src/liblzma/common/index_encoder.c
+++ b/src/liblzma/common/index_encoder.c
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file index_encoder.c
@@ -5,9 +7,6 @@
//
// Author: Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
#include "index_encoder.h"
diff --git a/src/liblzma/common/index_encoder.h b/src/liblzma/common/index_encoder.h
index 4d55cd104785..29ba11066963 100644
--- a/src/liblzma/common/index_encoder.h
+++ b/src/liblzma/common/index_encoder.h
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file index_encoder.h
@@ -5,9 +7,6 @@
//
// Author: Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
#ifndef LZMA_INDEX_ENCODER_H
diff --git a/src/liblzma/common/index_hash.c b/src/liblzma/common/index_hash.c
index 52c3d6507771..caa5967ca496 100644
--- a/src/liblzma/common/index_hash.c
+++ b/src/liblzma/common/index_hash.c
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file index_hash.c
@@ -5,9 +7,6 @@
//
// Author: Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
#include "common.h"
diff --git a/src/liblzma/common/lzip_decoder.c b/src/liblzma/common/lzip_decoder.c
index 88cc7ffd236b..651a0ae712c8 100644
--- a/src/liblzma/common/lzip_decoder.c
+++ b/src/liblzma/common/lzip_decoder.c
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file lzip_decoder.c
@@ -6,9 +8,6 @@
// Author: Michał Górny
// Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
#include "lzip_decoder.h"
diff --git a/src/liblzma/common/lzip_decoder.h b/src/liblzma/common/lzip_decoder.h
index 33a01c352ce3..0e1f7bebd45b 100644
--- a/src/liblzma/common/lzip_decoder.h
+++ b/src/liblzma/common/lzip_decoder.h
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file lzip_decoder.h
@@ -5,9 +7,6 @@
//
// Author: Michał Górny
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
#ifndef LZMA_LZIP_DECODER_H
diff --git a/src/liblzma/common/memcmplen.h b/src/liblzma/common/memcmplen.h
index 99d9c519cc0d..d8c42040d368 100644
--- a/src/liblzma/common/memcmplen.h
+++ b/src/liblzma/common/memcmplen.h
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file memcmplen.h
@@ -5,9 +7,6 @@
//
// Author: Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
#ifndef LZMA_MEMCMPLEN_H
@@ -24,7 +23,8 @@
// can use the intrinsics without the header file.
#if defined(TUKLIB_FAST_UNALIGNED_ACCESS) \
&& defined(_MSC_VER) \
- && defined(_M_X64) \
+ && (defined(_M_X64) \
+ || defined(_M_ARM64) || defined(_M_ARM64EC)) \
&& !defined(__INTEL_COMPILER)
# include <intrin.h>
#endif
@@ -57,20 +57,22 @@ lzma_memcmplen(const uint8_t *buf1, const uint8_t *buf2,
assert(limit <= UINT32_MAX / 2);
#if defined(TUKLIB_FAST_UNALIGNED_ACCESS) \
- && ((TUKLIB_GNUC_REQ(3, 4) && defined(__x86_64__)) \
+ && (((TUKLIB_GNUC_REQ(3, 4) || defined(__clang__)) \
+ && (defined(__x86_64__) \
+ || defined(__aarch64__))) \
|| (defined(__INTEL_COMPILER) && defined(__x86_64__)) \
|| (defined(__INTEL_COMPILER) && defined(_M_X64)) \
- || (defined(_MSC_VER) && defined(_M_X64)))
- // I keep this x86-64 only for now since that's where I know this
- // to be a good method. This may be fine on other 64-bit CPUs too.
- // On big endian one should use xor instead of subtraction and switch
- // to __builtin_clzll().
+ || (defined(_MSC_VER) && (defined(_M_X64) \
+ || defined(_M_ARM64) || defined(_M_ARM64EC))))
+ // This is only for x86-64 and ARM64 for now. This might be fine on
+ // other 64-bit processors too. On big endian one should use xor
+ // instead of subtraction and switch to __builtin_clzll().
#define LZMA_MEMCMPLEN_EXTRA 8
while (len < limit) {
const uint64_t x = read64ne(buf1 + len) - read64ne(buf2 + len);
if (x != 0) {
// MSVC or Intel C compiler on Windows
-# if (defined(_MSC_VER) || defined(__INTEL_COMPILER)) && defined(_M_X64)
+# if defined(_MSC_VER) || defined(__INTEL_COMPILER)
unsigned long tmp;
_BitScanForward64(&tmp, x);
len += (uint32_t)tmp >> 3;
diff --git a/src/liblzma/common/microlzma_decoder.c b/src/liblzma/common/microlzma_decoder.c
index e473373daaae..882cb2c808d1 100644
--- a/src/liblzma/common/microlzma_decoder.c
+++ b/src/liblzma/common/microlzma_decoder.c
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file microlzma_decoder.c
@@ -5,9 +7,6 @@
//
// Author: Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
#include "lzma_decoder.h"
diff --git a/src/liblzma/common/microlzma_encoder.c b/src/liblzma/common/microlzma_encoder.c
index a787ca25b839..45ec0b12f45d 100644
--- a/src/liblzma/common/microlzma_encoder.c
+++ b/src/liblzma/common/microlzma_encoder.c
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file microlzma_encoder.c
@@ -5,9 +7,6 @@
//
// Author: Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
#include "lzma_encoder.h"
diff --git a/src/liblzma/common/outqueue.c b/src/liblzma/common/outqueue.c
index 71e8648a294d..eb018eb42b26 100644
--- a/src/liblzma/common/outqueue.c
+++ b/src/liblzma/common/outqueue.c
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file outqueue.c
@@ -5,9 +7,6 @@
//
// Author: Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
#include "outqueue.h"
diff --git a/src/liblzma/common/outqueue.h b/src/liblzma/common/outqueue.h
index 596911e95ee1..ae56f636e8b1 100644
--- a/src/liblzma/common/outqueue.h
+++ b/src/liblzma/common/outqueue.h
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file outqueue.h
@@ -5,9 +7,6 @@
//
// Author: Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
#include "common.h"
diff --git a/src/liblzma/common/stream_buffer_decoder.c b/src/liblzma/common/stream_buffer_decoder.c
index b9745b5dbe18..c4f91fb49839 100644
--- a/src/liblzma/common/stream_buffer_decoder.c
+++ b/src/liblzma/common/stream_buffer_decoder.c
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file stream_buffer_decoder.c
@@ -5,9 +7,6 @@
//
// Author: Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
#include "stream_decoder.h"
diff --git a/src/liblzma/common/stream_buffer_encoder.c b/src/liblzma/common/stream_buffer_encoder.c
index 73157590e6f4..04d586959469 100644
--- a/src/liblzma/common/stream_buffer_encoder.c
+++ b/src/liblzma/common/stream_buffer_encoder.c
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file stream_buffer_encoder.c
@@ -5,9 +7,6 @@
//
// Author: Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
#include "common.h"
diff --git a/src/liblzma/common/stream_decoder.c b/src/liblzma/common/stream_decoder.c
index 64283812f29a..7f426841366a 100644
--- a/src/liblzma/common/stream_decoder.c
+++ b/src/liblzma/common/stream_decoder.c
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file stream_decoder.c
@@ -5,9 +7,6 @@
//
// Author: Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
#include "stream_decoder.h"
diff --git a/src/liblzma/common/stream_decoder.h b/src/liblzma/common/stream_decoder.h
index c13c6ba12706..5803715374d6 100644
--- a/src/liblzma/common/stream_decoder.h
+++ b/src/liblzma/common/stream_decoder.h
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file stream_decoder.h
@@ -5,9 +7,6 @@
//
// Author: Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
#ifndef LZMA_STREAM_DECODER_H
diff --git a/src/liblzma/common/stream_decoder_mt.c b/src/liblzma/common/stream_decoder_mt.c
index 76212b46da32..244624a47900 100644
--- a/src/liblzma/common/stream_decoder_mt.c
+++ b/src/liblzma/common/stream_decoder_mt.c
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file stream_decoder_mt.c
@@ -6,9 +8,6 @@
// Authors: Sebastian Andrzej Siewior
// Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
#include "common.h"
diff --git a/src/liblzma/common/stream_encoder.c b/src/liblzma/common/stream_encoder.c
index ee9204601856..e7e5b3fce7e0 100644
--- a/src/liblzma/common/stream_encoder.c
+++ b/src/liblzma/common/stream_encoder.c
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file stream_encoder.c
@@ -5,9 +7,6 @@
//
// Author: Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
#include "block_encoder.h"
diff --git a/src/liblzma/common/stream_encoder_mt.c b/src/liblzma/common/stream_encoder_mt.c
index f64de9bdbc57..f0fef1523318 100644
--- a/src/liblzma/common/stream_encoder_mt.c
+++ b/src/liblzma/common/stream_encoder_mt.c
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file stream_encoder_mt.c
@@ -5,9 +7,6 @@
//
// Author: Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
#include "filter_encoder.h"
@@ -979,20 +978,18 @@ get_options(const lzma_mt *options, lzma_options_easy *opt_easy,
*filters = opt_easy->filters;
}
- // Block size
- if (options->block_size > 0) {
- if (options->block_size > BLOCK_SIZE_MAX)
- return LZMA_OPTIONS_ERROR;
-
+ // If the Block size is not set, determine it from the filter chain.
+ if (options->block_size > 0)
*block_size = options->block_size;
- } else {
- // Determine the Block size from the filter chain.
+ else
*block_size = lzma_mt_block_size(*filters);
- if (*block_size == 0)
- return LZMA_OPTIONS_ERROR;
- assert(*block_size <= BLOCK_SIZE_MAX);
- }
+ // UINT64_MAX > BLOCK_SIZE_MAX, so the second condition
+ // should be optimized out by any reasonable compiler.
+ // The second condition should be there in the unlikely event that
+ // the macros change and UINT64_MAX < BLOCK_SIZE_MAX.
+ if (*block_size > BLOCK_SIZE_MAX || *block_size == UINT64_MAX)
+ return LZMA_OPTIONS_ERROR;
// Calculate the maximum amount output that a single output buffer
// may need to hold. This is the same as the maximum total size of
diff --git a/src/liblzma/common/stream_flags_common.c b/src/liblzma/common/stream_flags_common.c
index fbe8eb8abda2..41b8dcb70d74 100644
--- a/src/liblzma/common/stream_flags_common.c
+++ b/src/liblzma/common/stream_flags_common.c
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file stream_flags_common.c
@@ -5,9 +7,6 @@
//
// Author: Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
#include "stream_flags_common.h"
diff --git a/src/liblzma/common/stream_flags_common.h b/src/liblzma/common/stream_flags_common.h
index 84e96ba1ff66..28729dbcb6f2 100644
--- a/src/liblzma/common/stream_flags_common.h
+++ b/src/liblzma/common/stream_flags_common.h
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file stream_flags_common.h
@@ -5,9 +7,6 @@
//
// Author: Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
#ifndef LZMA_STREAM_FLAGS_COMMON_H
diff --git a/src/liblzma/common/stream_flags_decoder.c b/src/liblzma/common/stream_flags_decoder.c
index b8d263ba4429..522c98b6fd5c 100644
--- a/src/liblzma/common/stream_flags_decoder.c
+++ b/src/liblzma/common/stream_flags_decoder.c
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file stream_flags_decoder.c
@@ -5,9 +7,6 @@
//
// Author: Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
#include "stream_flags_common.h"
diff --git a/src/liblzma/common/stream_flags_encoder.c b/src/liblzma/common/stream_flags_encoder.c
index b98ab17c456c..f94b5cd0a237 100644
--- a/src/liblzma/common/stream_flags_encoder.c
+++ b/src/liblzma/common/stream_flags_encoder.c
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file stream_flags_encoder.c
@@ -5,9 +7,6 @@
//
// Author: Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
#include "stream_flags_common.h"
diff --git a/src/liblzma/common/string_conversion.c b/src/liblzma/common/string_conversion.c
index d2c1e80936b2..92d9032bdd18 100644
--- a/src/liblzma/common/string_conversion.c
+++ b/src/liblzma/common/string_conversion.c
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file string_conversion.c
@@ -5,9 +7,6 @@
//
// Author: Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
#include "filter_common.h"
@@ -250,7 +249,9 @@ static const char *parse_options(const char **const str, const char *str_end,
|| defined(HAVE_ENCODER_IA64) \
|| defined(HAVE_DECODER_IA64) \
|| defined(HAVE_ENCODER_SPARC) \
- || defined(HAVE_DECODER_SPARC)
+ || defined(HAVE_DECODER_SPARC) \
+ || defined(HAVE_ENCODER_RISCV) \
+ || defined(HAVE_DECODER_RISCV)
static const option_map bcj_optmap[] = {
{
.name = "start",
@@ -509,6 +510,11 @@ static const struct {
&parse_bcj, bcj_optmap, 1, 1, true },
#endif
+#if defined(HAVE_ENCODER_RISCV) || defined(HAVE_DECODER_RISCV)
+ { "riscv", sizeof(lzma_options_bcj), LZMA_FILTER_RISCV,
+ &parse_bcj, bcj_optmap, 1, 1, true },
+#endif
+
#if defined(HAVE_ENCODER_POWERPC) || defined(HAVE_DECODER_POWERPC)
{ "powerpc", sizeof(lzma_options_bcj), LZMA_FILTER_POWERPC,
&parse_bcj, bcj_optmap, 1, 1, true },
diff --git a/src/liblzma/common/vli_decoder.c b/src/liblzma/common/vli_decoder.c
index af2799d1fb90..3254ccc35bde 100644
--- a/src/liblzma/common/vli_decoder.c
+++ b/src/liblzma/common/vli_decoder.c
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file vli_decoder.c
@@ -5,9 +7,6 @@
//
// Author: Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
#include "common.h"
diff --git a/src/liblzma/common/vli_encoder.c b/src/liblzma/common/vli_encoder.c
index f8642694e291..3859006a94f1 100644
--- a/src/liblzma/common/vli_encoder.c
+++ b/src/liblzma/common/vli_encoder.c
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file vli_encoder.c
@@ -5,9 +7,6 @@
//
// Author: Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
#include "common.h"
diff --git a/src/liblzma/common/vli_size.c b/src/liblzma/common/vli_size.c
index ec1b4fa488b6..c8cb2ec10ade 100644
--- a/src/liblzma/common/vli_size.c
+++ b/src/liblzma/common/vli_size.c
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file vli_size.c
@@ -5,9 +7,6 @@
//
// Author: Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
#include "common.h"
diff --git a/src/liblzma/delta/delta_common.c b/src/liblzma/delta/delta_common.c
index 4768201d1a9f..5dbe253b4b3a 100644
--- a/src/liblzma/delta/delta_common.c
+++ b/src/liblzma/delta/delta_common.c
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file delta_common.c
@@ -5,9 +7,6 @@
//
// Author: Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
#include "delta_common.h"
diff --git a/src/liblzma/delta/delta_common.h b/src/liblzma/delta/delta_common.h
index 7e7e1baaf680..bd0912769724 100644
--- a/src/liblzma/delta/delta_common.h
+++ b/src/liblzma/delta/delta_common.h
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file delta_common.h
@@ -5,9 +7,6 @@
//
// Author: Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
#ifndef LZMA_DELTA_COMMON_H
diff --git a/src/liblzma/delta/delta_decoder.c b/src/liblzma/delta/delta_decoder.c
index 77cf65cc76d8..10d53687894e 100644
--- a/src/liblzma/delta/delta_decoder.c
+++ b/src/liblzma/delta/delta_decoder.c
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file delta_decoder.c
@@ -5,9 +7,6 @@
//
// Author: Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
#include "delta_decoder.h"
diff --git a/src/liblzma/delta/delta_decoder.h b/src/liblzma/delta/delta_decoder.h
index ad89cc659764..e2268ed44e72 100644
--- a/src/liblzma/delta/delta_decoder.h
+++ b/src/liblzma/delta/delta_decoder.h
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file delta_decoder.h
@@ -5,9 +7,6 @@
//
// Author: Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
#ifndef LZMA_DELTA_DECODER_H
diff --git a/src/liblzma/delta/delta_encoder.c b/src/liblzma/delta/delta_encoder.c
index 056bf7468ea3..ba4a50b1f42d 100644
--- a/src/liblzma/delta/delta_encoder.c
+++ b/src/liblzma/delta/delta_encoder.c
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file delta_encoder.c
@@ -5,9 +7,6 @@
//
// Author: Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
#include "delta_encoder.h"
diff --git a/src/liblzma/delta/delta_encoder.h b/src/liblzma/delta/delta_encoder.h
index 4ab984785171..735f0ed0091b 100644
--- a/src/liblzma/delta/delta_encoder.h
+++ b/src/liblzma/delta/delta_encoder.h
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file delta_encoder.h
@@ -5,9 +7,6 @@
//
// Author: Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
#ifndef LZMA_DELTA_ENCODER_H
diff --git a/src/liblzma/delta/delta_private.h b/src/liblzma/delta/delta_private.h
index 0d6cb3866115..e54721a84665 100644
--- a/src/liblzma/delta/delta_private.h
+++ b/src/liblzma/delta/delta_private.h
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file delta_private.h
@@ -5,9 +7,6 @@
//
// Author: Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
#ifndef LZMA_DELTA_PRIVATE_H
diff --git a/src/liblzma/liblzma.pc.in b/src/liblzma/liblzma.pc.in
index d077cb77135a..a432992b7072 100644
--- a/src/liblzma/liblzma.pc.in
+++ b/src/liblzma/liblzma.pc.in
@@ -1,9 +1,5 @@
-#
+# SPDX-License-Identifier: 0BSD
# Author: Lasse Collin
-#
-# This file has been put into the public domain.
-# You can do whatever you want with this file.
-#
prefix=@prefix@
exec_prefix=@exec_prefix@
diff --git a/src/liblzma/liblzma_generic.map b/src/liblzma/liblzma_generic.map
index bb82167ed57a..f74c15484559 100644
--- a/src/liblzma/liblzma_generic.map
+++ b/src/liblzma/liblzma_generic.map
@@ -1,3 +1,5 @@
+/* SPDX-License-Identifier: 0BSD */
+
XZ_5.0 {
global:
lzma_alone_decoder;
@@ -119,3 +121,8 @@ global:
lzma_str_list_filters;
lzma_str_to_filters;
} XZ_5.2;
+
+XZ_5.6.0 {
+global:
+ lzma_mt_block_size;
+} XZ_5.4;
diff --git a/src/liblzma/liblzma_linux.map b/src/liblzma/liblzma_linux.map
index 449f5fd682db..7e4b25e17620 100644
--- a/src/liblzma/liblzma_linux.map
+++ b/src/liblzma/liblzma_linux.map
@@ -1,3 +1,5 @@
+/* SPDX-License-Identifier: 0BSD */
+
XZ_5.0 {
global:
lzma_alone_decoder;
@@ -134,3 +136,8 @@ global:
lzma_str_list_filters;
lzma_str_to_filters;
} XZ_5.2;
+
+XZ_5.6.0 {
+global:
+ lzma_mt_block_size;
+} XZ_5.4;
diff --git a/src/liblzma/lz/lz_decoder.c b/src/liblzma/lz/lz_decoder.c
index 06c95c1137df..92913f225a0d 100644
--- a/src/liblzma/lz/lz_decoder.c
+++ b/src/liblzma/lz/lz_decoder.c
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file lz_decoder.c
@@ -6,9 +8,6 @@
// Authors: Igor Pavlov
// Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
// liblzma supports multiple LZ77-based filters. The LZ part is shared
@@ -54,9 +53,10 @@ typedef struct {
static void
lz_decoder_reset(lzma_coder *coder)
{
- coder->dict.pos = 0;
+ coder->dict.pos = 2 * LZ_DICT_REPEAT_MAX;
coder->dict.full = 0;
- coder->dict.buf[coder->dict.size - 1] = '\0';
+ coder->dict.buf[2 * LZ_DICT_REPEAT_MAX - 1] = '\0';
+ coder->dict.has_wrapped = false;
coder->dict.need_reset = false;
return;
}
@@ -70,8 +70,15 @@ decode_buffer(lzma_coder *coder,
{
while (true) {
// Wrap the dictionary if needed.
- if (coder->dict.pos == coder->dict.size)
- coder->dict.pos = 0;
+ if (coder->dict.pos == coder->dict.size) {
+ // See the comment of #define LZ_DICT_REPEAT_MAX.
+ coder->dict.pos = LZ_DICT_REPEAT_MAX;
+ coder->dict.has_wrapped = true;
+ memcpy(coder->dict.buf, coder->dict.buf
+ + coder->dict.size
+ - LZ_DICT_REPEAT_MAX,
+ LZ_DICT_REPEAT_MAX);
+ }
// Store the current dictionary position. It is needed to know
// where to start copying to the out[] buffer.
@@ -253,21 +260,31 @@ lzma_lz_decoder_init(lzma_next_coder *next, const lzma_allocator *allocator,
// dictionary to the output buffer, since applications are
// recommended to give aligned buffers to liblzma.
//
+ // Reserve 2 * LZ_DICT_REPEAT_MAX bytes of extra space which is
+ // needed for alloc_size.
+ //
// Avoid integer overflow.
- if (lz_options.dict_size > SIZE_MAX - 15)
+ if (lz_options.dict_size > SIZE_MAX - 15 - 2 * LZ_DICT_REPEAT_MAX)
return LZMA_MEM_ERROR;
lz_options.dict_size = (lz_options.dict_size + 15) & ~((size_t)(15));
+ // Reserve extra space as explained in the comment
+ // of #define LZ_DICT_REPEAT_MAX.
+ const size_t alloc_size
+ = lz_options.dict_size + 2 * LZ_DICT_REPEAT_MAX;
+
// Allocate and initialize the dictionary.
- if (coder->dict.size != lz_options.dict_size) {
+ if (coder->dict.size != alloc_size) {
lzma_free(coder->dict.buf, allocator);
- coder->dict.buf
- = lzma_alloc(lz_options.dict_size, allocator);
+ coder->dict.buf = lzma_alloc(alloc_size, allocator);
if (coder->dict.buf == NULL)
return LZMA_MEM_ERROR;
- coder->dict.size = lz_options.dict_size;
+ // NOTE: Yes, alloc_size, not lz_options.dict_size. The way
+ // coder->dict.full is updated will take care that we will
+ // still reject distances larger than lz_options.dict_size.
+ coder->dict.size = alloc_size;
}
lz_decoder_reset(next->coder);
@@ -280,9 +297,12 @@ lzma_lz_decoder_init(lzma_next_coder *next, const lzma_allocator *allocator,
const size_t copy_size = my_min(lz_options.preset_dict_size,
lz_options.dict_size);
const size_t offset = lz_options.preset_dict_size - copy_size;
- memcpy(coder->dict.buf, lz_options.preset_dict + offset,
+ memcpy(coder->dict.buf + coder->dict.pos,
+ lz_options.preset_dict + offset,
copy_size);
- coder->dict.pos = copy_size;
+
+ // dict.pos isn't zero after lz_decoder_reset().
+ coder->dict.pos += copy_size;
coder->dict.full = copy_size;
}
diff --git a/src/liblzma/lz/lz_decoder.h b/src/liblzma/lz/lz_decoder.h
index ad80d4dd0d14..cb61b6e24c78 100644
--- a/src/liblzma/lz/lz_decoder.h
+++ b/src/liblzma/lz/lz_decoder.h
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file lz_decoder.h
@@ -6,9 +8,6 @@
// Authors: Igor Pavlov
// Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
#ifndef LZMA_LZ_DECODER_H
@@ -17,10 +16,28 @@
#include "common.h"
+/// Maximum length of a match rounded up to a nice power of 2 which is
+/// a good size for aligned memcpy(). The allocated dictionary buffer will
+/// be 2 * LZ_DICT_REPEAT_MAX bytes larger than the actual dictionary size:
+///
+/// (1) Every time the decoder reaches the end of the dictionary buffer,
+/// the last LZ_DICT_REPEAT_MAX bytes will be copied to the beginning.
+/// This way dict_repeat() will only need to copy from one place,
+/// never from both the end and beginning of the buffer.
+///
+/// (2) The other LZ_DICT_REPEAT_MAX bytes is kept as a buffer between
+/// the oldest byte still in the dictionary and the current write
+/// position. This way dict_repeat(dict, dict->size - 1, &len)
+/// won't need memmove() as the copying cannot overlap.
+///
+/// Note that memcpy() still cannot be used if distance < len.
+///
+/// LZMA's longest match length is 273 so pick a multiple of 16 above that.
+#define LZ_DICT_REPEAT_MAX 288
+
+
typedef struct {
- /// Pointer to the dictionary buffer. It can be an allocated buffer
- /// internal to liblzma, or it can a be a buffer given by the
- /// application when in single-call mode (not implemented yet).
+ /// Pointer to the dictionary buffer.
uint8_t *buf;
/// Write position in dictionary. The next byte will be written to
@@ -35,9 +52,16 @@ typedef struct {
/// Write limit
size_t limit;
- /// Size of the dictionary
+ /// Allocated size of buf. This is 2 * LZ_DICT_REPEAT_MAX bytes
+ /// larger than the actual dictionary size. This is enforced by
+ /// how the value for "full" is set; it can be at most
+ /// "size - 2 * LZ_DICT_REPEAT_MAX".
size_t size;
+ /// True once the dictionary has become full and the writing position
+ /// has been wrapped in decode_buffer() in lz_decoder.c.
+ bool has_wrapped;
+
/// True when dictionary should be reset before decoding more data.
bool need_reset;
@@ -103,7 +127,16 @@ static inline uint8_t
dict_get(const lzma_dict *const dict, const uint32_t distance)
{
return dict->buf[dict->pos - distance - 1
- + (distance < dict->pos ? 0 : dict->size)];
+ + (distance < dict->pos
+ ? 0 : dict->size - LZ_DICT_REPEAT_MAX)];
+}
+
+
+/// Optimized version of dict_get(dict, 0)
+static inline uint8_t
+dict_get0(const lzma_dict *const dict)
+{
+ return dict->buf[dict->pos - 1];
}
@@ -132,68 +165,51 @@ dict_repeat(lzma_dict *dict, uint32_t distance, uint32_t *len)
uint32_t left = my_min(dict_avail, *len);
*len -= left;
+ size_t back = dict->pos - distance - 1;
+ if (distance >= dict->pos)
+ back += dict->size - LZ_DICT_REPEAT_MAX;
+
// Repeat a block of data from the history. Because memcpy() is faster
// than copying byte by byte in a loop, the copying process gets split
- // into three cases.
+ // into two cases.
if (distance < left) {
// Source and target areas overlap, thus we can't use
// memcpy() nor even memmove() safely.
do {
- dict->buf[dict->pos] = dict_get(dict, distance);
- ++dict->pos;
+ dict->buf[dict->pos++] = dict->buf[back++];
} while (--left > 0);
-
- } else if (distance < dict->pos) {
- // The easiest and fastest case
- memcpy(dict->buf + dict->pos,
- dict->buf + dict->pos - distance - 1,
- left);
- dict->pos += left;
-
} else {
- // The bigger the dictionary, the more rare this
- // case occurs. We need to "wrap" the dict, thus
- // we might need two memcpy() to copy all the data.
- assert(dict->full == dict->size);
- const uint32_t copy_pos
- = dict->pos - distance - 1 + dict->size;
- uint32_t copy_size = dict->size - copy_pos;
-
- if (copy_size < left) {
- memmove(dict->buf + dict->pos, dict->buf + copy_pos,
- copy_size);
- dict->pos += copy_size;
- copy_size = left - copy_size;
- memcpy(dict->buf + dict->pos, dict->buf, copy_size);
- dict->pos += copy_size;
- } else {
- memmove(dict->buf + dict->pos, dict->buf + copy_pos,
- left);
- dict->pos += left;
- }
+ memcpy(dict->buf + dict->pos, dict->buf + back, left);
+ dict->pos += left;
}
// Update how full the dictionary is.
- if (dict->full < dict->pos)
- dict->full = dict->pos;
+ if (!dict->has_wrapped)
+ dict->full = dict->pos - 2 * LZ_DICT_REPEAT_MAX;
- return unlikely(*len != 0);
+ return *len != 0;
+}
+
+
+static inline void
+dict_put(lzma_dict *dict, uint8_t byte)
+{
+ dict->buf[dict->pos++] = byte;
+
+ if (!dict->has_wrapped)
+ dict->full = dict->pos - 2 * LZ_DICT_REPEAT_MAX;
}
/// Puts one byte into the dictionary. Returns true if the dictionary was
/// already full and the byte couldn't be added.
static inline bool
-dict_put(lzma_dict *dict, uint8_t byte)
+dict_put_safe(lzma_dict *dict, uint8_t byte)
{
if (unlikely(dict->pos == dict->limit))
return true;
- dict->buf[dict->pos++] = byte;
-
- if (dict->pos > dict->full)
- dict->full = dict->pos;
-
+ dict_put(dict, byte);
return false;
}
@@ -217,8 +233,8 @@ dict_write(lzma_dict *restrict dict, const uint8_t *restrict in,
*left -= lzma_bufcpy(in, in_pos, in_size,
dict->buf, &dict->pos, dict->limit);
- if (dict->pos > dict->full)
- dict->full = dict->pos;
+ if (!dict->has_wrapped)
+ dict->full = dict->pos - 2 * LZ_DICT_REPEAT_MAX;
return;
}
diff --git a/src/liblzma/lz/lz_encoder.c b/src/liblzma/lz/lz_encoder.c
index 5489085a0860..4af23e14c423 100644
--- a/src/liblzma/lz/lz_encoder.c
+++ b/src/liblzma/lz/lz_encoder.c
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file lz_encoder.c
@@ -6,9 +8,6 @@
// Authors: Igor Pavlov
// Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
#include "lz_encoder.h"
@@ -196,9 +195,7 @@ lz_encoder_prepare(lzma_mf *mf, const lzma_allocator *allocator,
// For now, the dictionary size is limited to 1.5 GiB. This may grow
// in the future if needed, but it needs a little more work than just
// changing this check.
- if (lz_options->dict_size < LZMA_DICT_SIZE_MIN
- || lz_options->dict_size
- > (UINT32_C(1) << 30) + (UINT32_C(1) << 29)
+ if (!IS_ENC_DICT_SIZE_VALID(lz_options->dict_size)
|| lz_options->nice_len > lz_options->match_len_max)
return true;
@@ -549,7 +546,7 @@ lzma_lz_encoder_init(lzma_next_coder *next, const lzma_allocator *allocator,
lzma_lz_options *lz_options))
{
#if defined(HAVE_SMALL) && !defined(HAVE_FUNC_ATTRIBUTE_CONSTRUCTOR)
- // We need that the CRC32 table has been initialized.
+ // The CRC32 table must be initialized.
lzma_crc32_init();
#endif
@@ -569,6 +566,8 @@ lzma_lz_encoder_init(lzma_next_coder *next, const lzma_allocator *allocator,
coder->lz.coder = NULL;
coder->lz.code = NULL;
coder->lz.end = NULL;
+ coder->lz.options_update = NULL;
+ coder->lz.set_out_limit = NULL;
// mf.size is initialized to silence Valgrind
// when used on optimized binaries (GCC may reorder
diff --git a/src/liblzma/lz/lz_encoder.h b/src/liblzma/lz/lz_encoder.h
index ffcba02ce931..429836c8bc4e 100644
--- a/src/liblzma/lz/lz_encoder.h
+++ b/src/liblzma/lz/lz_encoder.h
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file lz_encoder.h
@@ -6,9 +8,6 @@
// Authors: Igor Pavlov
// Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
#ifndef LZMA_LZ_ENCODER_H
@@ -17,6 +16,14 @@
#include "common.h"
+// For now, the dictionary size is limited to 1.5 GiB. This may grow
+// in the future if needed, but it needs a little more work than just
+// changing this check.
+#define IS_ENC_DICT_SIZE_VALID(size) \
+ ((size) >= LZMA_DICT_SIZE_MIN \
+ && (size) <= (UINT32_C(1) << 30) + (UINT32_C(1) << 29))
+
+
/// A table of these is used by the LZ-based encoder to hold
/// the length-distance pairs found by the match finder.
typedef struct {
@@ -153,9 +160,13 @@ typedef struct {
/// Maximum search depth
uint32_t depth;
- /// TODO: Comment
+ /// Initial dictionary for the match finder to search.
const uint8_t *preset_dict;
+ /// If the preset dictionary is NULL, this value is ignored.
+ /// Otherwise this member must indicate the preset dictionary's
+ /// buffer size. If this size is larger than dict_size, then only
+ /// the dict_size sized tail of the preset_dict will be used.
uint32_t preset_dict_size;
} lzma_lz_options;
@@ -217,7 +228,7 @@ typedef struct {
// 3. The literals and matches are encoded using e.g. LZMA.
//
// The bytes that have been ran through the match finder, but not encoded yet,
-// are called `read ahead'.
+// are called 'read ahead'.
/// Get how many bytes the match finder hashes in its initial step.
diff --git a/src/liblzma/lz/lz_encoder_hash.h b/src/liblzma/lz/lz_encoder_hash.h
index 4d9971ae6a5d..8ace82b04c51 100644
--- a/src/liblzma/lz/lz_encoder_hash.h
+++ b/src/liblzma/lz/lz_encoder_hash.h
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file lz_encoder_hash.h
@@ -5,9 +7,6 @@
//
// Author: Igor Pavlov
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
#ifndef LZMA_LZ_ENCODER_HASH_H
diff --git a/src/liblzma/lz/lz_encoder_hash_table.h b/src/liblzma/lz/lz_encoder_hash_table.h
index 8c51717d704f..2b3a60e43e80 100644
--- a/src/liblzma/lz/lz_encoder_hash_table.h
+++ b/src/liblzma/lz/lz_encoder_hash_table.h
@@ -1,4 +1,6 @@
-/* This file has been automatically generated by crc32_tablegen.c. */
+// SPDX-License-Identifier: 0BSD
+
+// This file has been generated by crc32_tablegen.c.
const uint32_t lzma_lz_hash_table[256] = {
0x00000000, 0x77073096, 0xEE0E612C, 0x990951BA,
diff --git a/src/liblzma/lz/lz_encoder_mf.c b/src/liblzma/lz/lz_encoder_mf.c
index 1fdc2d794909..557c2612f2a2 100644
--- a/src/liblzma/lz/lz_encoder_mf.c
+++ b/src/liblzma/lz/lz_encoder_mf.c
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file lz_encoder_mf.c
@@ -6,9 +8,6 @@
// Authors: Igor Pavlov
// Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
#include "lz_encoder.h"
diff --git a/src/liblzma/lzma/fastpos.h b/src/liblzma/lzma/fastpos.h
index dbeb16f7e31a..d3969a753fac 100644
--- a/src/liblzma/lzma/fastpos.h
+++ b/src/liblzma/lzma/fastpos.h
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file fastpos.h
@@ -6,9 +8,6 @@
// Authors: Igor Pavlov
// Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
#ifndef LZMA_FASTPOS_H
diff --git a/src/liblzma/lzma/fastpos_table.c b/src/liblzma/lzma/fastpos_table.c
index 6a3ceac0e90a..4e10e3795e29 100644
--- a/src/liblzma/lzma/fastpos_table.c
+++ b/src/liblzma/lzma/fastpos_table.c
@@ -1,4 +1,6 @@
-/* This file has been automatically generated by fastpos_tablegen.c. */
+// SPDX-License-Identifier: 0BSD
+
+// This file has been generated by fastpos_tablegen.c.
#include "common.h"
#include "fastpos.h"
diff --git a/src/liblzma/lzma/fastpos_tablegen.c b/src/liblzma/lzma/fastpos_tablegen.c
index 57ed15039b27..957ccb7a6436 100644
--- a/src/liblzma/lzma/fastpos_tablegen.c
+++ b/src/liblzma/lzma/fastpos_tablegen.c
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file fastpos_tablegen.c
@@ -6,9 +8,6 @@
// Authors: Igor Pavlov
// Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
#include <inttypes.h>
@@ -35,11 +34,13 @@ main(void)
fastpos[c] = slot_fast;
}
- printf("/* This file has been automatically generated "
- "by fastpos_tablegen.c. */\n\n"
- "#include \"common.h\"\n"
- "#include \"fastpos.h\"\n\n"
- "const uint8_t lzma_fastpos[1 << FASTPOS_BITS] = {");
+ // Split the SPDX string so that it won't accidentally match
+ // when tools search for the string.
+ printf("// SPDX" "-License-Identifier" ": 0BSD\n\n"
+ "// This file has been generated by fastpos_tablegen.c.\n\n"
+ "#include \"common.h\"\n"
+ "#include \"fastpos.h\"\n\n"
+ "const uint8_t lzma_fastpos[1 << FASTPOS_BITS] = {");
for (size_t i = 0; i < (1 << FASTPOS_BITS); ++i) {
if (i % 16 == 0)
diff --git a/src/liblzma/lzma/lzma2_decoder.c b/src/liblzma/lzma/lzma2_decoder.c
index 567df490ca5b..37ab253f5b0a 100644
--- a/src/liblzma/lzma/lzma2_decoder.c
+++ b/src/liblzma/lzma/lzma2_decoder.c
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file lzma2_decoder.c
@@ -6,9 +8,6 @@
// Authors: Igor Pavlov
// Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
#include "lzma2_decoder.h"
diff --git a/src/liblzma/lzma/lzma2_decoder.h b/src/liblzma/lzma/lzma2_decoder.h
index ef2dcbfa76f0..cdd8b463abfd 100644
--- a/src/liblzma/lzma/lzma2_decoder.h
+++ b/src/liblzma/lzma/lzma2_decoder.h
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file lzma2_decoder.h
@@ -6,9 +8,6 @@
// Authors: Igor Pavlov
// Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
#ifndef LZMA_LZMA2_DECODER_H
diff --git a/src/liblzma/lzma/lzma2_encoder.c b/src/liblzma/lzma/lzma2_encoder.c
index 4b6b23118d70..e20b75b30037 100644
--- a/src/liblzma/lzma/lzma2_encoder.c
+++ b/src/liblzma/lzma/lzma2_encoder.c
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file lzma2_encoder.c
@@ -6,9 +8,6 @@
// Authors: Igor Pavlov
// Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
#include "lz_encoder.h"
@@ -409,6 +408,9 @@ lzma_lzma2_block_size(const void *options)
{
const lzma_options_lzma *const opt = options;
+ if (!IS_ENC_DICT_SIZE_VALID(opt->dict_size))
+ return UINT64_MAX;
+
// Use at least 1 MiB to keep compression ratio better.
return my_max((uint64_t)(opt->dict_size) * 3, UINT64_C(1) << 20);
}
diff --git a/src/liblzma/lzma/lzma2_encoder.h b/src/liblzma/lzma/lzma2_encoder.h
index 515f1839347a..29966a66d237 100644
--- a/src/liblzma/lzma/lzma2_encoder.h
+++ b/src/liblzma/lzma/lzma2_encoder.h
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file lzma2_encoder.h
@@ -6,9 +8,6 @@
// Authors: Igor Pavlov
// Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
#ifndef LZMA_LZMA2_ENCODER_H
diff --git a/src/liblzma/lzma/lzma_common.h b/src/liblzma/lzma/lzma_common.h
index 9d040d95bb2f..c3c587f090ec 100644
--- a/src/liblzma/lzma/lzma_common.h
+++ b/src/liblzma/lzma/lzma_common.h
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file lzma_common.h
@@ -6,9 +8,6 @@
// Authors: Igor Pavlov
// Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
#ifndef LZMA_LZMA_COMMON_H
@@ -84,6 +83,20 @@ typedef enum {
? (state) - 3 \
: (state) - 6))
+/// Like update_literal(state) but when it is already known that
+/// is_literal_state(state) is true.
+#define update_literal_normal(state) \
+ state = ((state) <= STATE_SHORTREP_LIT_LIT \
+ ? STATE_LIT_LIT \
+ : (state) - 3);
+
+/// Like update_literal(state) but when it is already known that
+/// is_literal_state(state) is false.
+#define update_literal_matched(state) \
+ state = ((state) <= STATE_LIT_SHORTREP \
+ ? (state) - 3 \
+ : (state) - 6);
+
/// Indicate that the latest state was a match.
#define update_match(state) \
state = ((state) < LIT_STATES ? STATE_LIT_MATCH : STATE_NONLIT_MATCH)
@@ -112,31 +125,33 @@ typedef enum {
///
/// Match byte is used when the previous LZMA symbol was something else than
/// a literal (that is, it was some kind of match).
-#define LITERAL_CODER_SIZE 0x300
+#define LITERAL_CODER_SIZE UINT32_C(0x300)
/// Maximum number of literal coders
#define LITERAL_CODERS_MAX (1 << LZMA_LCLP_MAX)
+/// Calculates the literal_mask that literal_subcoder() needs.
+#define literal_mask_calc(lc, lp) \
+ ((UINT32_C(0x100) << (lp)) - (UINT32_C(0x100) >> (lc)))
+
/// Locate the literal coder for the next literal byte. The choice depends on
/// - the lowest literal_pos_bits bits of the position of the current
/// byte; and
/// - the highest literal_context_bits bits of the previous byte.
-#define literal_subcoder(probs, lc, lp_mask, pos, prev_byte) \
- ((probs)[(((pos) & (lp_mask)) << (lc)) \
- + ((uint32_t)(prev_byte) >> (8U - (lc)))])
+#define literal_subcoder(probs, lc, literal_mask, pos, prev_byte) \
+ ((probs) + UINT32_C(3) * \
+ (((((pos) << 8) + (prev_byte)) & (literal_mask)) << (lc)))
static inline void
-literal_init(probability (*probs)[LITERAL_CODER_SIZE],
- uint32_t lc, uint32_t lp)
+literal_init(probability *probs, uint32_t lc, uint32_t lp)
{
assert(lc + lp <= LZMA_LCLP_MAX);
- const uint32_t coders = 1U << (lc + lp);
+ const size_t coders = LITERAL_CODER_SIZE << (lc + lp);
- for (uint32_t i = 0; i < coders; ++i)
- for (uint32_t j = 0; j < LITERAL_CODER_SIZE; ++j)
- bit_reset(probs[i][j]);
+ for (size_t i = 0; i < coders; ++i)
+ bit_reset(probs[i]);
return;
}
diff --git a/src/liblzma/lzma/lzma_decoder.c b/src/liblzma/lzma/lzma_decoder.c
index 26c148a95e25..0abed02b8154 100644
--- a/src/liblzma/lzma/lzma_decoder.c
+++ b/src/liblzma/lzma/lzma_decoder.c
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file lzma_decoder.c
@@ -5,9 +7,7 @@
///
// Authors: Igor Pavlov
// Lasse Collin
-//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
+// Jia Tan
//
///////////////////////////////////////////////////////////////////////////////
@@ -22,25 +22,20 @@
# pragma GCC diagnostic ignored "-Wimplicit-fallthrough"
#endif
+// Minimum number of input bytes to safely decode one LZMA symbol.
+// The worst case is that we decode 22 bits using probabilities and 26
+// direct bits. This may decode at maximum 20 bytes of input.
+#define LZMA_IN_REQUIRED 20
-#ifdef HAVE_SMALL
// Macros for (somewhat) size-optimized code.
-#define seq_4(seq) seq
-
-#define seq_6(seq) seq
-
-#define seq_8(seq) seq
-
-#define seq_len(seq) \
- seq ## _CHOICE, \
- seq ## _CHOICE2, \
- seq ## _BITTREE
-
+// This is used to decode the match length (how many bytes must be repeated
+// from the dictionary). This version is used in the Resumable mode and
+// does not unroll any loops.
#define len_decode(target, ld, pos_state, seq) \
do { \
case seq ## _CHOICE: \
- rc_if_0(ld.choice, seq ## _CHOICE) { \
+ rc_if_0_safe(ld.choice, seq ## _CHOICE) { \
rc_update_0(ld.choice); \
probs = ld.low[pos_state];\
limit = LEN_LOW_SYMBOLS; \
@@ -48,7 +43,7 @@ case seq ## _CHOICE: \
} else { \
rc_update_1(ld.choice); \
case seq ## _CHOICE2: \
- rc_if_0(ld.choice2, seq ## _CHOICE2) { \
+ rc_if_0_safe(ld.choice2, seq ## _CHOICE2) { \
rc_update_0(ld.choice2); \
probs = ld.mid[pos_state]; \
limit = LEN_MID_SYMBOLS; \
@@ -64,98 +59,39 @@ case seq ## _CHOICE2: \
symbol = 1; \
case seq ## _BITTREE: \
do { \
- rc_bit(probs[symbol], , , seq ## _BITTREE); \
+ rc_bit_safe(probs[symbol], , , seq ## _BITTREE); \
} while (symbol < limit); \
target += symbol - limit; \
} while (0)
-#else // HAVE_SMALL
-
-// Unrolled versions
-#define seq_4(seq) \
- seq ## 0, \
- seq ## 1, \
- seq ## 2, \
- seq ## 3
-
-#define seq_6(seq) \
- seq ## 0, \
- seq ## 1, \
- seq ## 2, \
- seq ## 3, \
- seq ## 4, \
- seq ## 5
-
-#define seq_8(seq) \
- seq ## 0, \
- seq ## 1, \
- seq ## 2, \
- seq ## 3, \
- seq ## 4, \
- seq ## 5, \
- seq ## 6, \
- seq ## 7
-
-#define seq_len(seq) \
- seq ## _CHOICE, \
- seq ## _LOW0, \
- seq ## _LOW1, \
- seq ## _LOW2, \
- seq ## _CHOICE2, \
- seq ## _MID0, \
- seq ## _MID1, \
- seq ## _MID2, \
- seq ## _HIGH0, \
- seq ## _HIGH1, \
- seq ## _HIGH2, \
- seq ## _HIGH3, \
- seq ## _HIGH4, \
- seq ## _HIGH5, \
- seq ## _HIGH6, \
- seq ## _HIGH7
-#define len_decode(target, ld, pos_state, seq) \
+// This is the faster version of the match length decoder that does not
+// worry about being resumable. It unrolls the bittree decoding loop.
+#define len_decode_fast(target, ld, pos_state) \
do { \
symbol = 1; \
-case seq ## _CHOICE: \
- rc_if_0(ld.choice, seq ## _CHOICE) { \
+ rc_if_0(ld.choice) { \
rc_update_0(ld.choice); \
- rc_bit_case(ld.low[pos_state][symbol], , , seq ## _LOW0); \
- rc_bit_case(ld.low[pos_state][symbol], , , seq ## _LOW1); \
- rc_bit_case(ld.low[pos_state][symbol], , , seq ## _LOW2); \
- target = symbol - LEN_LOW_SYMBOLS + MATCH_LEN_MIN; \
+ rc_bittree3(ld.low[pos_state], \
+ -LEN_LOW_SYMBOLS + MATCH_LEN_MIN); \
+ target = symbol; \
} else { \
rc_update_1(ld.choice); \
-case seq ## _CHOICE2: \
- rc_if_0(ld.choice2, seq ## _CHOICE2) { \
+ rc_if_0(ld.choice2) { \
rc_update_0(ld.choice2); \
- rc_bit_case(ld.mid[pos_state][symbol], , , \
- seq ## _MID0); \
- rc_bit_case(ld.mid[pos_state][symbol], , , \
- seq ## _MID1); \
- rc_bit_case(ld.mid[pos_state][symbol], , , \
- seq ## _MID2); \
- target = symbol - LEN_MID_SYMBOLS \
- + MATCH_LEN_MIN + LEN_LOW_SYMBOLS; \
+ rc_bittree3(ld.mid[pos_state], -LEN_MID_SYMBOLS \
+ + MATCH_LEN_MIN + LEN_LOW_SYMBOLS); \
+ target = symbol; \
} else { \
rc_update_1(ld.choice2); \
- rc_bit_case(ld.high[symbol], , , seq ## _HIGH0); \
- rc_bit_case(ld.high[symbol], , , seq ## _HIGH1); \
- rc_bit_case(ld.high[symbol], , , seq ## _HIGH2); \
- rc_bit_case(ld.high[symbol], , , seq ## _HIGH3); \
- rc_bit_case(ld.high[symbol], , , seq ## _HIGH4); \
- rc_bit_case(ld.high[symbol], , , seq ## _HIGH5); \
- rc_bit_case(ld.high[symbol], , , seq ## _HIGH6); \
- rc_bit_case(ld.high[symbol], , , seq ## _HIGH7); \
- target = symbol - LEN_HIGH_SYMBOLS \
+ rc_bittree8(ld.high, -LEN_HIGH_SYMBOLS \
+ MATCH_LEN_MIN \
- + LEN_LOW_SYMBOLS + LEN_MID_SYMBOLS; \
+ + LEN_LOW_SYMBOLS + LEN_MID_SYMBOLS); \
+ target = symbol; \
} \
} \
} while (0)
-#endif // HAVE_SMALL
-
/// Length decoder probabilities; see comments in lzma_common.h.
typedef struct {
@@ -173,7 +109,7 @@ typedef struct {
///////////////////
/// Literals; see comments in lzma_common.h.
- probability literal[LITERAL_CODERS_MAX][LITERAL_CODER_SIZE];
+ probability literal[LITERAL_CODERS_MAX * LITERAL_CODER_SIZE];
/// If 1, it's a match. Otherwise it's a single 8-bit literal.
probability is_match[STATES][POS_STATES_MAX];
@@ -232,7 +168,7 @@ typedef struct {
uint32_t pos_mask; // (1U << pb) - 1
uint32_t literal_context_bits;
- uint32_t literal_pos_mask;
+ uint32_t literal_mask;
/// Uncompressed size as bytes, or LZMA_VLI_UNKNOWN if end of
/// payload marker is expected.
@@ -251,22 +187,26 @@ typedef struct {
enum {
SEQ_NORMALIZE,
SEQ_IS_MATCH,
- seq_8(SEQ_LITERAL),
- seq_8(SEQ_LITERAL_MATCHED),
+ SEQ_LITERAL,
+ SEQ_LITERAL_MATCHED,
SEQ_LITERAL_WRITE,
SEQ_IS_REP,
- seq_len(SEQ_MATCH_LEN),
- seq_6(SEQ_DIST_SLOT),
+ SEQ_MATCH_LEN_CHOICE,
+ SEQ_MATCH_LEN_CHOICE2,
+ SEQ_MATCH_LEN_BITTREE,
+ SEQ_DIST_SLOT,
SEQ_DIST_MODEL,
SEQ_DIRECT,
- seq_4(SEQ_ALIGN),
+ SEQ_ALIGN,
SEQ_EOPM,
SEQ_IS_REP0,
SEQ_SHORTREP,
SEQ_IS_REP0_LONG,
SEQ_IS_REP1,
SEQ_IS_REP2,
- seq_len(SEQ_REP_LEN),
+ SEQ_REP_LEN_CHOICE,
+ SEQ_REP_LEN_CHOICE2,
+ SEQ_REP_LEN_BITTREE,
SEQ_COPY,
} sequence;
@@ -321,7 +261,7 @@ lzma_decode(void *coder_ptr, lzma_dict *restrict dictptr,
const size_t dict_start = dict.pos;
// Range decoder
- rc_to_local(coder->rc, *in_pos);
+ rc_to_local(coder->rc, *in_pos, LZMA_IN_REQUIRED);
// State
uint32_t state = coder->state;
@@ -340,7 +280,7 @@ lzma_decode(void *coder_ptr, lzma_dict *restrict dictptr,
uint32_t offset = coder->offset;
uint32_t len = coder->len;
- const uint32_t literal_pos_mask = coder->literal_pos_mask;
+ const uint32_t literal_mask = coder->literal_mask;
const uint32_t literal_context_bits = coder->literal_context_bits;
// Temporary variables
@@ -367,8 +307,24 @@ lzma_decode(void *coder_ptr, lzma_dict *restrict dictptr,
might_finish_without_eopm = true;
}
- // The main decoder loop. The "switch" is used to restart the decoder at
- // correct location. Once restarted, the "switch" is no longer used.
+ // The main decoder loop. The "switch" is used to resume the decoder at
+ // correct location. Once resumed, the "switch" is no longer used.
+ // The decoder loops is split into two modes:
+ //
+ // 1 - Non-resumable mode (fast). This is used when it is guaranteed
+ // there is enough input to decode the next symbol. If the output
+ // limit is reached, then the decoder loop will save the place
+ // for the resumable mode to continue. This mode is not used if
+ // HAVE_SMALL is defined. This is faster than Resumable mode
+ // because it reduces the number of branches needed and allows
+ // for more compiler optimizations.
+ //
+ // 2 - Resumable mode (slow). This is used when a previous decoder
+ // loop did not have enough space in the input or output buffers
+ // to complete. It uses sequence enum values to set remind
+ // coder->sequence where to resume in the decoder loop. This
+ // is the only mode used when HAVE_SMALL is defined.
+
switch (coder->sequence)
while (true) {
// Calculate new pos_state. This is skipped on the first loop
@@ -376,13 +332,339 @@ lzma_decode(void *coder_ptr, lzma_dict *restrict dictptr,
// variables.
pos_state = dict.pos & pos_mask;
+#ifndef HAVE_SMALL
+
+ ///////////////////////////////
+ // Non-resumable Mode (fast) //
+ ///////////////////////////////
+
+ // Go to Resumable mode (1) if there is not enough input to
+ // safely decode any possible LZMA symbol or (2) if the
+ // dictionary is full, which may need special checks that
+ // are only done in the Resumable mode.
+ if (unlikely(!rc_is_fast_allowed()
+ || dict.pos == dict.limit))
+ goto slow;
+
+ // Decode the first bit from the next LZMA symbol.
+ // If the bit is a 0, then we handle it as a literal.
+ // If the bit is a 1, then it is a match of previously
+ // decoded data.
+ rc_if_0(coder->is_match[state][pos_state]) {
+ /////////////////////
+ // Decode literal. //
+ /////////////////////
+
+ // Update the RC that we have decoded a 0.
+ rc_update_0(coder->is_match[state][pos_state]);
+
+ // Get the correct probability array from lp and
+ // lc params.
+ probs = literal_subcoder(coder->literal,
+ literal_context_bits, literal_mask,
+ dict.pos, dict_get0(&dict));
+
+ if (is_literal_state(state)) {
+ update_literal_normal(state);
+
+ // Decode literal without match byte.
+ rc_bittree8(probs, 0);
+ } else {
+ update_literal_matched(state);
+
+ // Decode literal with match byte.
+ rc_matched_literal(probs,
+ dict_get(&dict, rep0));
+ }
+
+ // Write decoded literal to dictionary
+ dict_put(&dict, symbol);
+ continue;
+ }
+
+ ///////////////////
+ // Decode match. //
+ ///////////////////
+
+ // Instead of a new byte we are going to decode a
+ // distance-length pair. The distance represents how far
+ // back in the dictionary to begin copying. The length
+ // represents how many bytes to copy.
+
+ rc_update_1(coder->is_match[state][pos_state]);
+
+ rc_if_0(coder->is_rep[state]) {
+ ///////////////////
+ // Simple match. //
+ ///////////////////
+
+ // Not a repeated match. In this case,
+ // the length (how many bytes to copy) must be
+ // decoded first. Then, the distance (where to
+ // start copying) is decoded.
+ //
+ // This is also how we know when we are done
+ // decoding. If the distance decodes to UINT32_MAX,
+ // then we know to stop decoding (end of payload
+ // marker).
+
+ rc_update_0(coder->is_rep[state]);
+ update_match(state);
+
+ // The latest three match distances are kept in
+ // memory in case there are repeated matches.
+ rep3 = rep2;
+ rep2 = rep1;
+ rep1 = rep0;
+
+ // Decode the length of the match.
+ len_decode_fast(len, coder->match_len_decoder,
+ pos_state);
+
+ // Next, decode the distance into rep0.
+
+ // The next 6 bits determine how to decode the
+ // rest of the distance.
+ probs = coder->dist_slot[get_dist_state(len)];
+
+ rc_bittree6(probs, -DIST_SLOTS);
+ assert(symbol <= 63);
+
+ if (symbol < DIST_MODEL_START) {
+ // If the decoded symbol is < DIST_MODEL_START
+ // then we use its value directly as the
+ // match distance. No other bits are needed.
+ // The only possible distance values
+ // are [0, 3].
+ rep0 = symbol;
+ } else {
+ // Use the first two bits of symbol as the
+ // highest bits of the match distance.
+
+ // "limit" represents the number of low bits
+ // to decode.
+ limit = (symbol >> 1) - 1;
+ assert(limit >= 1 && limit <= 30);
+ rep0 = 2 + (symbol & 1);
+
+ if (symbol < DIST_MODEL_END) {
+ // When symbol is > DIST_MODEL_START,
+ // but symbol < DIST_MODEL_END, then
+ // it can decode distances between
+ // [4, 127].
+ assert(limit <= 5);
+ rep0 <<= limit;
+ assert(rep0 <= 96);
+
+ // -1 is fine, because we start
+ // decoding at probs[1], not probs[0].
+ // NOTE: This violates the C standard,
+ // since we are doing pointer
+ // arithmetic past the beginning of
+ // the array.
+ assert((int32_t)(rep0 - symbol - 1)
+ >= -1);
+ assert((int32_t)(rep0 - symbol - 1)
+ <= 82);
+ probs = coder->pos_special + rep0
+ - symbol - 1;
+ symbol = 1;
+ offset = 1;
+
+ // Variable number (1-5) of bits
+ // from a reverse bittree. This
+ // isn't worth manual unrolling.
+ //
+ // NOTE: Making one or many of the
+ // variables (probs, symbol, offset,
+ // or limit) local here (instead of
+ // using those declared outside the
+ // main loop) can affect code size
+ // and performance which isn't a
+ // surprise but it's not so clear
+ // what is the best.
+ do {
+ rc_bit_add_if_1(probs,
+ rep0, offset);
+ offset <<= 1;
+ } while (--limit > 0);
+ } else {
+ // The distance is >= 128. Decode the
+ // lower bits without probabilities
+ // except the lowest four bits.
+ assert(symbol >= 14);
+ assert(limit >= 6);
+
+ limit -= ALIGN_BITS;
+ assert(limit >= 2);
+
+ rc_direct(rep0, limit);
+
+ // Decode the lowest four bits using
+ // probabilities.
+ rep0 <<= ALIGN_BITS;
+ rc_bittree_rev4(coder->pos_align);
+ rep0 += symbol;
+
+ // If the end of payload marker (EOPM)
+ // is detected, jump to the safe code.
+ // The EOPM handling isn't speed
+ // critical at all.
+ //
+ // A final normalization is needed
+ // after the EOPM (there can be a
+ // dummy byte to read in some cases).
+ // If the normalization was done here
+ // in the fast code, it would need to
+ // be taken into account in the value
+ // of LZMA_IN_REQUIRED. Using the
+ // safe code allows keeping
+ // LZMA_IN_REQUIRED as 20 instead of
+ // 21.
+ if (rep0 == UINT32_MAX)
+ goto eopm;
+ }
+ }
+
+ // Validate the distance we just decoded.
+ if (unlikely(!dict_is_distance_valid(&dict, rep0))) {
+ ret = LZMA_DATA_ERROR;
+ goto out;
+ }
+
+ } else {
+ rc_update_1(coder->is_rep[state]);
+
+ /////////////////////
+ // Repeated match. //
+ /////////////////////
+
+ // The match distance is a value that we have decoded
+ // recently. The latest four match distances are
+ // available as rep0, rep1, rep2 and rep3. We will
+ // now decode which of them is the new distance.
+ //
+ // There cannot be a match if we haven't produced
+ // any output, so check that first.
+ if (unlikely(!dict_is_distance_valid(&dict, 0))) {
+ ret = LZMA_DATA_ERROR;
+ goto out;
+ }
+
+ rc_if_0(coder->is_rep0[state]) {
+ rc_update_0(coder->is_rep0[state]);
+ // The distance is rep0.
+
+ // Decode the next bit to determine if 1 byte
+ // should be copied from rep0 distance or
+ // if the number of bytes needs to be decoded.
+
+ // If the next bit is 0, then it is a
+ // "Short Rep Match" and only 1 bit is copied.
+ // Otherwise, the length of the match is
+ // decoded after the "else" statement.
+ rc_if_0(coder->is_rep0_long[state][pos_state]) {
+ rc_update_0(coder->is_rep0_long[
+ state][pos_state]);
+
+ update_short_rep(state);
+ dict_put(&dict, dict_get(&dict, rep0));
+ continue;
+ }
+
+ // Repeating more than one byte at
+ // distance of rep0.
+ rc_update_1(coder->is_rep0_long[
+ state][pos_state]);
+
+ } else {
+ rc_update_1(coder->is_rep0[state]);
+
+ // The distance is rep1, rep2 or rep3. Once
+ // we find out which one of these three, it
+ // is stored to rep0 and rep1, rep2 and rep3
+ // are updated accordingly. There is no
+ // "Short Rep Match" option, so the length
+ // of the match must always be decoded next.
+ rc_if_0(coder->is_rep1[state]) {
+ // The distance is rep1.
+ rc_update_0(coder->is_rep1[state]);
+
+ const uint32_t distance = rep1;
+ rep1 = rep0;
+ rep0 = distance;
+
+ } else {
+ rc_update_1(coder->is_rep1[state]);
+
+ rc_if_0(coder->is_rep2[state]) {
+ // The distance is rep2.
+ rc_update_0(coder->is_rep2[
+ state]);
+
+ const uint32_t distance = rep2;
+ rep2 = rep1;
+ rep1 = rep0;
+ rep0 = distance;
+
+ } else {
+ // The distance is rep3.
+ rc_update_1(coder->is_rep2[
+ state]);
+
+ const uint32_t distance = rep3;
+ rep3 = rep2;
+ rep2 = rep1;
+ rep1 = rep0;
+ rep0 = distance;
+ }
+ }
+ }
+
+ update_long_rep(state);
+
+ // Decode the length of the repeated match.
+ len_decode_fast(len, coder->rep_len_decoder,
+ pos_state);
+ }
+
+ /////////////////////////////////
+ // Repeat from history buffer. //
+ /////////////////////////////////
+
+ // The length is always between these limits. There is no way
+ // to trigger the algorithm to set len outside this range.
+ assert(len >= MATCH_LEN_MIN);
+ assert(len <= MATCH_LEN_MAX);
+
+ // Repeat len bytes from distance of rep0.
+ if (unlikely(dict_repeat(&dict, rep0, &len))) {
+ coder->sequence = SEQ_COPY;
+ goto out;
+ }
+
+ continue;
+
+slow:
+#endif
+ ///////////////////////////
+ // Resumable Mode (slow) //
+ ///////////////////////////
+
+ // This is very similar to Non-resumable Mode, so most of the
+ // comments are not repeated. The main differences are:
+ // - case labels are used to resume at the correct location.
+ // - Loops are not unrolled.
+ // - Range coder macros take an extra sequence argument
+ // so they can save to coder->sequence the location to
+ // resume in case there is not enough input.
case SEQ_NORMALIZE:
case SEQ_IS_MATCH:
if (unlikely(might_finish_without_eopm
&& dict.pos == dict.limit)) {
// In rare cases there is a useless byte that needs
// to be read anyway.
- rc_normalize(SEQ_NORMALIZE);
+ rc_normalize_safe(SEQ_NORMALIZE);
// If the range decoder state is such that we can
// be at the end of the LZMA stream, then the
@@ -405,49 +687,37 @@ lzma_decode(void *coder_ptr, lzma_dict *restrict dictptr,
eopm_is_valid = true;
}
- rc_if_0(coder->is_match[state][pos_state], SEQ_IS_MATCH) {
- rc_update_0(coder->is_match[state][pos_state]);
+ rc_if_0_safe(coder->is_match[state][pos_state], SEQ_IS_MATCH) {
+ /////////////////////
+ // Decode literal. //
+ /////////////////////
- // It's a literal i.e. a single 8-bit byte.
+ rc_update_0(coder->is_match[state][pos_state]);
probs = literal_subcoder(coder->literal,
- literal_context_bits, literal_pos_mask,
- dict.pos, dict_get(&dict, 0));
+ literal_context_bits, literal_mask,
+ dict.pos, dict_get0(&dict));
symbol = 1;
if (is_literal_state(state)) {
+ update_literal_normal(state);
+
// Decode literal without match byte.
-#ifdef HAVE_SMALL
+ // The "slow" version does not unroll
+ // the loop.
case SEQ_LITERAL:
do {
- rc_bit(probs[symbol], , , SEQ_LITERAL);
+ rc_bit_safe(probs[symbol], , ,
+ SEQ_LITERAL);
} while (symbol < (1 << 8));
-#else
- rc_bit_case(probs[symbol], , , SEQ_LITERAL0);
- rc_bit_case(probs[symbol], , , SEQ_LITERAL1);
- rc_bit_case(probs[symbol], , , SEQ_LITERAL2);
- rc_bit_case(probs[symbol], , , SEQ_LITERAL3);
- rc_bit_case(probs[symbol], , , SEQ_LITERAL4);
- rc_bit_case(probs[symbol], , , SEQ_LITERAL5);
- rc_bit_case(probs[symbol], , , SEQ_LITERAL6);
- rc_bit_case(probs[symbol], , , SEQ_LITERAL7);
-#endif
} else {
+ update_literal_matched(state);
+
// Decode literal with match byte.
- //
- // We store the byte we compare against
- // ("match byte") to "len" to minimize the
- // number of variables we need to store
- // between decoder calls.
len = (uint32_t)(dict_get(&dict, rep0)) << 1;
- // The usage of "offset" allows omitting some
- // branches, which should give tiny speed
- // improvement on some CPUs. "offset" gets
- // set to zero if match_bit didn't match.
offset = 0x100;
-#ifdef HAVE_SMALL
case SEQ_LITERAL_MATCHED:
do {
const uint32_t match_bit
@@ -456,7 +726,7 @@ lzma_decode(void *coder_ptr, lzma_dict *restrict dictptr,
= offset + match_bit
+ symbol;
- rc_bit(probs[subcoder_index],
+ rc_bit_safe(probs[subcoder_index],
offset &= ~match_bit,
offset &= match_bit,
SEQ_LITERAL_MATCHED);
@@ -469,61 +739,10 @@ lzma_decode(void *coder_ptr, lzma_dict *restrict dictptr,
len <<= 1;
} while (symbol < (1 << 8));
-#else
- // Unroll the loop.
- uint32_t match_bit;
- uint32_t subcoder_index;
-
-# define d(seq) \
- case seq: \
- match_bit = len & offset; \
- subcoder_index = offset + match_bit + symbol; \
- rc_bit(probs[subcoder_index], \
- offset &= ~match_bit, \
- offset &= match_bit, \
- seq)
-
- d(SEQ_LITERAL_MATCHED0);
- len <<= 1;
- d(SEQ_LITERAL_MATCHED1);
- len <<= 1;
- d(SEQ_LITERAL_MATCHED2);
- len <<= 1;
- d(SEQ_LITERAL_MATCHED3);
- len <<= 1;
- d(SEQ_LITERAL_MATCHED4);
- len <<= 1;
- d(SEQ_LITERAL_MATCHED5);
- len <<= 1;
- d(SEQ_LITERAL_MATCHED6);
- len <<= 1;
- d(SEQ_LITERAL_MATCHED7);
-# undef d
-#endif
}
- //update_literal(state);
- // Use a lookup table to update to literal state,
- // since compared to other state updates, this would
- // need two branches.
- static const lzma_lzma_state next_state[] = {
- STATE_LIT_LIT,
- STATE_LIT_LIT,
- STATE_LIT_LIT,
- STATE_LIT_LIT,
- STATE_MATCH_LIT_LIT,
- STATE_REP_LIT_LIT,
- STATE_SHORTREP_LIT_LIT,
- STATE_MATCH_LIT,
- STATE_REP_LIT,
- STATE_SHORTREP_LIT,
- STATE_MATCH_LIT,
- STATE_REP_LIT
- };
- state = next_state[state];
-
case SEQ_LITERAL_WRITE:
- if (unlikely(dict_put(&dict, symbol))) {
+ if (dict_put_safe(&dict, symbol)) {
coder->sequence = SEQ_LITERAL_WRITE;
goto out;
}
@@ -531,64 +750,47 @@ lzma_decode(void *coder_ptr, lzma_dict *restrict dictptr,
continue;
}
- // Instead of a new byte we are going to get a byte range
- // (distance and length) which will be repeated from our
- // output history.
+ ///////////////////
+ // Decode match. //
+ ///////////////////
rc_update_1(coder->is_match[state][pos_state]);
case SEQ_IS_REP:
- rc_if_0(coder->is_rep[state], SEQ_IS_REP) {
- // Not a repeated match
+ rc_if_0_safe(coder->is_rep[state], SEQ_IS_REP) {
+ ///////////////////
+ // Simple match. //
+ ///////////////////
+
rc_update_0(coder->is_rep[state]);
update_match(state);
- // The latest three match distances are kept in
- // memory in case there are repeated matches.
rep3 = rep2;
rep2 = rep1;
rep1 = rep0;
- // Decode the length of the match.
len_decode(len, coder->match_len_decoder,
pos_state, SEQ_MATCH_LEN);
- // Prepare to decode the highest two bits of the
- // match distance.
probs = coder->dist_slot[get_dist_state(len)];
symbol = 1;
-#ifdef HAVE_SMALL
case SEQ_DIST_SLOT:
do {
- rc_bit(probs[symbol], , , SEQ_DIST_SLOT);
+ rc_bit_safe(probs[symbol], , , SEQ_DIST_SLOT);
} while (symbol < DIST_SLOTS);
-#else
- rc_bit_case(probs[symbol], , , SEQ_DIST_SLOT0);
- rc_bit_case(probs[symbol], , , SEQ_DIST_SLOT1);
- rc_bit_case(probs[symbol], , , SEQ_DIST_SLOT2);
- rc_bit_case(probs[symbol], , , SEQ_DIST_SLOT3);
- rc_bit_case(probs[symbol], , , SEQ_DIST_SLOT4);
- rc_bit_case(probs[symbol], , , SEQ_DIST_SLOT5);
-#endif
- // Get rid of the highest bit that was needed for
- // indexing of the probability array.
+
symbol -= DIST_SLOTS;
assert(symbol <= 63);
if (symbol < DIST_MODEL_START) {
- // Match distances [0, 3] have only two bits.
rep0 = symbol;
} else {
- // Decode the lowest [1, 29] bits of
- // the match distance.
limit = (symbol >> 1) - 1;
assert(limit >= 1 && limit <= 30);
rep0 = 2 + (symbol & 1);
if (symbol < DIST_MODEL_END) {
- // Prepare to decode the low bits for
- // a distance of [4, 127].
assert(limit <= 5);
rep0 <<= limit;
assert(rep0 <= 96);
@@ -607,95 +809,36 @@ lzma_decode(void *coder_ptr, lzma_dict *restrict dictptr,
symbol = 1;
offset = 0;
case SEQ_DIST_MODEL:
-#ifdef HAVE_SMALL
do {
- rc_bit(probs[symbol], ,
+ rc_bit_safe(probs[symbol], ,
rep0 += 1U << offset,
SEQ_DIST_MODEL);
} while (++offset < limit);
-#else
- switch (limit) {
- case 5:
- assert(offset == 0);
- rc_bit(probs[symbol], ,
- rep0 += 1U,
- SEQ_DIST_MODEL);
- ++offset;
- --limit;
- case 4:
- rc_bit(probs[symbol], ,
- rep0 += 1U << offset,
- SEQ_DIST_MODEL);
- ++offset;
- --limit;
- case 3:
- rc_bit(probs[symbol], ,
- rep0 += 1U << offset,
- SEQ_DIST_MODEL);
- ++offset;
- --limit;
- case 2:
- rc_bit(probs[symbol], ,
- rep0 += 1U << offset,
- SEQ_DIST_MODEL);
- ++offset;
- --limit;
- case 1:
- // We need "symbol" only for
- // indexing the probability
- // array, thus we can use
- // rc_bit_last() here to omit
- // the unneeded updating of
- // "symbol".
- rc_bit_last(probs[symbol], ,
- rep0 += 1U << offset,
- SEQ_DIST_MODEL);
- }
-#endif
} else {
- // The distance is >= 128. Decode the
- // lower bits without probabilities
- // except the lowest four bits.
assert(symbol >= 14);
assert(limit >= 6);
limit -= ALIGN_BITS;
assert(limit >= 2);
case SEQ_DIRECT:
- // Not worth manual unrolling
- do {
- rc_direct(rep0, SEQ_DIRECT);
- } while (--limit > 0);
+ rc_direct_safe(rep0, limit,
+ SEQ_DIRECT);
- // Decode the lowest four bits using
- // probabilities.
rep0 <<= ALIGN_BITS;
- symbol = 1;
-#ifdef HAVE_SMALL
- offset = 0;
+ symbol = 0;
+ offset = 1;
case SEQ_ALIGN:
do {
- rc_bit(coder->pos_align[
- symbol], ,
- rep0 += 1U << offset,
+ rc_bit_last_safe(
+ coder->pos_align[
+ offset
+ + symbol],
+ ,
+ symbol += offset,
SEQ_ALIGN);
- } while (++offset < ALIGN_BITS);
-#else
- case SEQ_ALIGN0:
- rc_bit(coder->pos_align[symbol], ,
- rep0 += 1, SEQ_ALIGN0);
- case SEQ_ALIGN1:
- rc_bit(coder->pos_align[symbol], ,
- rep0 += 2, SEQ_ALIGN1);
- case SEQ_ALIGN2:
- rc_bit(coder->pos_align[symbol], ,
- rep0 += 4, SEQ_ALIGN2);
- case SEQ_ALIGN3:
- // Like in SEQ_DIST_MODEL, we don't
- // need "symbol" for anything else
- // than indexing the probability array.
- rc_bit_last(coder->pos_align[symbol], ,
- rep0 += 8, SEQ_ALIGN3);
-#endif
+ offset <<= 1;
+ } while (offset < ALIGN_SIZE);
+
+ rep0 += symbol;
if (rep0 == UINT32_MAX) {
// End of payload marker was
@@ -710,6 +853,9 @@ lzma_decode(void *coder_ptr, lzma_dict *restrict dictptr,
// that EOPM might be used
// (it's not allowed in
// LZMA2).
+#ifndef HAVE_SMALL
+eopm:
+#endif
if (!eopm_is_valid) {
ret = LZMA_DATA_ERROR;
goto out;
@@ -718,7 +864,7 @@ lzma_decode(void *coder_ptr, lzma_dict *restrict dictptr,
case SEQ_EOPM:
// LZMA1 stream with
// end-of-payload marker.
- rc_normalize(SEQ_EOPM);
+ rc_normalize_safe(SEQ_EOPM);
ret = rc_is_finished(rc)
? LZMA_STREAM_END
: LZMA_DATA_ERROR;
@@ -727,36 +873,30 @@ lzma_decode(void *coder_ptr, lzma_dict *restrict dictptr,
}
}
- // Validate the distance we just decoded.
if (unlikely(!dict_is_distance_valid(&dict, rep0))) {
ret = LZMA_DATA_ERROR;
goto out;
}
} else {
+ /////////////////////
+ // Repeated match. //
+ /////////////////////
+
rc_update_1(coder->is_rep[state]);
- // Repeated match
- //
- // The match distance is a value that we have had
- // earlier. The latest four match distances are
- // available as rep0, rep1, rep2 and rep3. We will
- // now decode which of them is the new distance.
- //
- // There cannot be a match if we haven't produced
- // any output, so check that first.
if (unlikely(!dict_is_distance_valid(&dict, 0))) {
ret = LZMA_DATA_ERROR;
goto out;
}
case SEQ_IS_REP0:
- rc_if_0(coder->is_rep0[state], SEQ_IS_REP0) {
+ rc_if_0_safe(coder->is_rep0[state], SEQ_IS_REP0) {
rc_update_0(coder->is_rep0[state]);
- // The distance is rep0.
case SEQ_IS_REP0_LONG:
- rc_if_0(coder->is_rep0_long[state][pos_state],
+ rc_if_0_safe(coder->is_rep0_long
+ [state][pos_state],
SEQ_IS_REP0_LONG) {
rc_update_0(coder->is_rep0_long[
state][pos_state]);
@@ -764,8 +904,9 @@ lzma_decode(void *coder_ptr, lzma_dict *restrict dictptr,
update_short_rep(state);
case SEQ_SHORTREP:
- if (unlikely(dict_put(&dict, dict_get(
- &dict, rep0)))) {
+ if (dict_put_safe(&dict,
+ dict_get(&dict,
+ rep0))) {
coder->sequence = SEQ_SHORTREP;
goto out;
}
@@ -773,8 +914,6 @@ lzma_decode(void *coder_ptr, lzma_dict *restrict dictptr,
continue;
}
- // Repeating more than one byte at
- // distance of rep0.
rc_update_1(coder->is_rep0_long[
state][pos_state]);
@@ -782,11 +921,7 @@ lzma_decode(void *coder_ptr, lzma_dict *restrict dictptr,
rc_update_1(coder->is_rep0[state]);
case SEQ_IS_REP1:
- // The distance is rep1, rep2 or rep3. Once
- // we find out which one of these three, it
- // is stored to rep0 and rep1, rep2 and rep3
- // are updated accordingly.
- rc_if_0(coder->is_rep1[state], SEQ_IS_REP1) {
+ rc_if_0_safe(coder->is_rep1[state], SEQ_IS_REP1) {
rc_update_0(coder->is_rep1[state]);
const uint32_t distance = rep1;
@@ -796,7 +931,7 @@ lzma_decode(void *coder_ptr, lzma_dict *restrict dictptr,
} else {
rc_update_1(coder->is_rep1[state]);
case SEQ_IS_REP2:
- rc_if_0(coder->is_rep2[state],
+ rc_if_0_safe(coder->is_rep2[state],
SEQ_IS_REP2) {
rc_update_0(coder->is_rep2[
state]);
@@ -821,7 +956,6 @@ lzma_decode(void *coder_ptr, lzma_dict *restrict dictptr,
update_long_rep(state);
- // Decode the length of the repeated match.
len_decode(len, coder->rep_len_decoder,
pos_state, SEQ_REP_LEN);
}
@@ -830,13 +964,10 @@ lzma_decode(void *coder_ptr, lzma_dict *restrict dictptr,
// Repeat from history buffer. //
/////////////////////////////////
- // The length is always between these limits. There is no way
- // to trigger the algorithm to set len outside this range.
assert(len >= MATCH_LEN_MIN);
assert(len <= MATCH_LEN_MAX);
case SEQ_COPY:
- // Repeat len bytes from distance of rep0.
if (unlikely(dict_repeat(&dict, rep0, &len))) {
coder->sequence = SEQ_COPY;
goto out;
@@ -890,7 +1021,6 @@ out:
}
-
static void
lzma_decoder_uncompressed(void *coder_ptr, lzma_vli uncompressed_size,
bool allow_eopm)
@@ -917,7 +1047,7 @@ lzma_decoder_reset(void *coder_ptr, const void *opt)
literal_init(coder->literal, options->lc, options->lp);
coder->literal_context_bits = options->lc;
- coder->literal_pos_mask = (1U << options->lp) - 1;
+ coder->literal_mask = literal_mask_calc(options->lc, options->lp);
// State
coder->state = STATE_LIT_LIT;
diff --git a/src/liblzma/lzma/lzma_decoder.h b/src/liblzma/lzma/lzma_decoder.h
index 1427bc2461f4..9730f56fc268 100644
--- a/src/liblzma/lzma/lzma_decoder.h
+++ b/src/liblzma/lzma/lzma_decoder.h
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file lzma_decoder.h
@@ -6,9 +8,6 @@
// Authors: Igor Pavlov
// Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
#ifndef LZMA_LZMA_DECODER_H
diff --git a/src/liblzma/lzma/lzma_encoder.c b/src/liblzma/lzma/lzma_encoder.c
index 559c63eda1d2..543ca321c3c2 100644
--- a/src/liblzma/lzma/lzma_encoder.c
+++ b/src/liblzma/lzma/lzma_encoder.c
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file lzma_encoder.c
@@ -6,9 +8,6 @@
// Authors: Igor Pavlov
// Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
#include "lzma2_encoder.h"
@@ -49,24 +48,24 @@ literal(lzma_lzma1_encoder *coder, lzma_mf *mf, uint32_t position)
const uint8_t cur_byte = mf->buffer[
mf->read_pos - mf->read_ahead];
probability *subcoder = literal_subcoder(coder->literal,
- coder->literal_context_bits, coder->literal_pos_mask,
+ coder->literal_context_bits, coder->literal_mask,
position, mf->buffer[mf->read_pos - mf->read_ahead - 1]);
if (is_literal_state(coder->state)) {
// Previous LZMA-symbol was a literal. Encode a normal
// literal without a match byte.
+ update_literal_normal(coder->state);
rc_bittree(&coder->rc, subcoder, 8, cur_byte);
} else {
// Previous LZMA-symbol was a match. Use the last byte of
// the match as a "match byte". That is, compare the bits
// of the current literal and the match byte.
+ update_literal_matched(coder->state);
const uint8_t match_byte = mf->buffer[
mf->read_pos - coder->reps[0] - 1
- mf->read_ahead];
literal_matched(&coder->rc, subcoder, match_byte, cur_byte);
}
-
- update_literal(coder->state);
}
@@ -283,7 +282,7 @@ encode_init(lzma_lzma1_encoder *coder, lzma_mf *mf)
mf_skip(mf, 1);
mf->read_ahead = 0;
rc_bit(&coder->rc, &coder->is_match[0][0], 0);
- rc_bittree(&coder->rc, coder->literal[0], 8, mf->buffer[0]);
+ rc_bittree(&coder->rc, coder->literal + 0, 8, mf->buffer[0]);
++coder->uncomp_size;
}
@@ -535,7 +534,7 @@ lzma_lzma_encoder_reset(lzma_lzma1_encoder *coder,
coder->pos_mask = (1U << options->pb) - 1;
coder->literal_context_bits = options->lc;
- coder->literal_pos_mask = (1U << options->lp) - 1;
+ coder->literal_mask = literal_mask_calc(options->lc, options->lp);
// Range coder
rc_reset(&coder->rc);
@@ -712,6 +711,9 @@ static lzma_ret
lzma_encoder_init(lzma_lz_encoder *lz, const lzma_allocator *allocator,
lzma_vli id, const void *options, lzma_lz_options *lz_options)
{
+ if (options == NULL)
+ return LZMA_PROG_ERROR;
+
lz->code = &lzma_encode;
lz->set_out_limit = &lzma_lzma_set_out_limit;
return lzma_lzma_encoder_create(
diff --git a/src/liblzma/lzma/lzma_encoder.h b/src/liblzma/lzma/lzma_encoder.h
index 84d8c9163f2d..e8ae8079306c 100644
--- a/src/liblzma/lzma/lzma_encoder.h
+++ b/src/liblzma/lzma/lzma_encoder.h
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file lzma_encoder.h
@@ -6,9 +8,6 @@
// Authors: Igor Pavlov
// Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
#ifndef LZMA_LZMA_ENCODER_H
diff --git a/src/liblzma/lzma/lzma_encoder_optimum_fast.c b/src/liblzma/lzma/lzma_encoder_optimum_fast.c
index 6c53d2bd0082..0f063d5be7a5 100644
--- a/src/liblzma/lzma/lzma_encoder_optimum_fast.c
+++ b/src/liblzma/lzma/lzma_encoder_optimum_fast.c
@@ -1,12 +1,11 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file lzma_encoder_optimum_fast.c
//
// Author: Igor Pavlov
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
#include "lzma_encoder_private.h"
diff --git a/src/liblzma/lzma/lzma_encoder_optimum_normal.c b/src/liblzma/lzma/lzma_encoder_optimum_normal.c
index 101c8d479008..a6c0398f3af3 100644
--- a/src/liblzma/lzma/lzma_encoder_optimum_normal.c
+++ b/src/liblzma/lzma/lzma_encoder_optimum_normal.c
@@ -1,12 +1,11 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file lzma_encoder_optimum_normal.c
//
// Author: Igor Pavlov
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
#include "lzma_encoder_private.h"
@@ -24,7 +23,7 @@ get_literal_price(const lzma_lzma1_encoder *const coder, const uint32_t pos,
uint32_t match_byte, uint32_t symbol)
{
const probability *const subcoder = literal_subcoder(coder->literal,
- coder->literal_context_bits, coder->literal_pos_mask,
+ coder->literal_context_bits, coder->literal_mask,
pos, prev_byte);
uint32_t price = 0;
diff --git a/src/liblzma/lzma/lzma_encoder_presets.c b/src/liblzma/lzma/lzma_encoder_presets.c
index 711df0255296..e53483f99582 100644
--- a/src/liblzma/lzma/lzma_encoder_presets.c
+++ b/src/liblzma/lzma/lzma_encoder_presets.c
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file lzma_encoder_presets.c
@@ -6,9 +8,6 @@
//
// Author: Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
#include "common.h"
diff --git a/src/liblzma/lzma/lzma_encoder_private.h b/src/liblzma/lzma/lzma_encoder_private.h
index b228c5776173..eeea5e9c1289 100644
--- a/src/liblzma/lzma/lzma_encoder_private.h
+++ b/src/liblzma/lzma/lzma_encoder_private.h
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file lzma_encoder_private.h
@@ -6,9 +8,6 @@
// Authors: Igor Pavlov
// Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
#ifndef LZMA_LZMA_ENCODER_PRIVATE_H
@@ -116,10 +115,10 @@ struct lzma_lzma1_encoder_s {
uint32_t pos_mask; ///< (1 << pos_bits) - 1
uint32_t literal_context_bits;
- uint32_t literal_pos_mask;
+ uint32_t literal_mask;
// These are the same as in lzma_decoder.c. See comments there.
- probability literal[LITERAL_CODERS_MAX][LITERAL_CODER_SIZE];
+ probability literal[LITERAL_CODERS_MAX * LITERAL_CODER_SIZE];
probability is_match[STATES][POS_STATES_MAX];
probability is_rep[STATES];
probability is_rep0[STATES];
diff --git a/src/liblzma/rangecoder/price.h b/src/liblzma/rangecoder/price.h
index 45dbbbb20cef..cce6bdae5f93 100644
--- a/src/liblzma/rangecoder/price.h
+++ b/src/liblzma/rangecoder/price.h
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file price.h
@@ -5,9 +7,6 @@
//
// Author: Igor Pavlov
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
#ifndef LZMA_PRICE_H
diff --git a/src/liblzma/rangecoder/price_table.c b/src/liblzma/rangecoder/price_table.c
index ac64bf62c767..c33433f718ca 100644
--- a/src/liblzma/rangecoder/price_table.c
+++ b/src/liblzma/rangecoder/price_table.c
@@ -1,4 +1,6 @@
-/* This file has been automatically generated by price_tablegen.c. */
+// SPDX-License-Identifier: 0BSD
+
+// This file has been generated by price_tablegen.c.
#include "range_encoder.h"
diff --git a/src/liblzma/rangecoder/price_tablegen.c b/src/liblzma/rangecoder/price_tablegen.c
index bf08ce39d7e5..4b6ca37efadf 100644
--- a/src/liblzma/rangecoder/price_tablegen.c
+++ b/src/liblzma/rangecoder/price_tablegen.c
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file price_tablegen.c
@@ -8,13 +10,15 @@
// Authors: Igor Pavlov
// Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
#include <inttypes.h>
#include <stdio.h>
+
+// Make it compile without common.h.
+#define BUILDING_PRICE_TABLEGEN
+#define lzma_attr_visibility_hidden
+
#include "range_common.h"
#include "price.h"
@@ -54,11 +58,13 @@ init_price_table(void)
static void
print_price_table(void)
{
- printf("/* This file has been automatically generated by "
- "price_tablegen.c. */\n\n"
- "#include \"range_encoder.h\"\n\n"
- "const uint8_t lzma_rc_prices["
- "RC_PRICE_TABLE_SIZE] = {");
+ // Split the SPDX string so that it won't accidentally match
+ // when tools search for the string.
+ printf("// SPDX" "-License-Identifier" ": 0BSD\n\n"
+ "// This file has been generated by price_tablegen.c.\n\n"
+ "#include \"range_encoder.h\"\n\n"
+ "const uint8_t lzma_rc_prices["
+ "RC_PRICE_TABLE_SIZE] = {");
const size_t array_size = sizeof(lzma_rc_prices)
/ sizeof(lzma_rc_prices[0]);
diff --git a/src/liblzma/rangecoder/range_common.h b/src/liblzma/rangecoder/range_common.h
index 2c74dc1537c8..ac4dbe196f50 100644
--- a/src/liblzma/rangecoder/range_common.h
+++ b/src/liblzma/rangecoder/range_common.h
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file range_common.h
@@ -6,15 +8,15 @@
// Authors: Igor Pavlov
// Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
#ifndef LZMA_RANGE_COMMON_H
#define LZMA_RANGE_COMMON_H
-#include "common.h"
+// Skip common.h if building price_tablegen.c.
+#ifndef BUILDING_PRICE_TABLEGEN
+# include "common.h"
+#endif
///////////////
@@ -66,6 +68,10 @@
///
/// I will be sticking to uint16_t unless some specific architectures
/// are *much* faster (20-50 %) with uint32_t.
+///
+/// Update in 2024: The branchless C and x86-64 assembly was written so that
+/// probability is assumed to be uint16_t. (In contrast, LZMA SDK 23.01
+/// assembly supports both types.)
typedef uint16_t probability;
#endif
diff --git a/src/liblzma/rangecoder/range_decoder.h b/src/liblzma/rangecoder/range_decoder.h
index e0b051fac2d2..b6422247f3c3 100644
--- a/src/liblzma/rangecoder/range_decoder.h
+++ b/src/liblzma/rangecoder/range_decoder.h
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file range_decoder.h
@@ -6,9 +8,6 @@
// Authors: Igor Pavlov
// Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
#ifndef LZMA_RANGE_DECODER_H
@@ -17,6 +16,54 @@
#include "range_common.h"
+// Choose the range decoder variants to use using a bitmask.
+// If no bits are set, only the basic version is used.
+// If more than one version is selected for the same feature,
+// the last one on the list below is used.
+//
+// Bitwise-or of the following enable branchless C versions:
+// 0x01 normal bittrees
+// 0x02 fixed-sized reverse bittrees
+// 0x04 variable-sized reverse bittrees (not faster)
+// 0x08 matched literal (not faster)
+//
+// GCC & Clang compatible x86-64 inline assembly:
+// 0x010 normal bittrees
+// 0x020 fixed-sized reverse bittrees
+// 0x040 variable-sized reverse bittrees
+// 0x080 matched literal
+// 0x100 direct bits
+//
+// The default can be overridden at build time by defining
+// LZMA_RANGE_DECODER_CONFIG to the desired mask.
+//
+// 2024-02-22: Feedback from benchmarks:
+// - Brancless C (0x003) can be better than basic on x86-64 but often it's
+// slightly worse on other archs. Since asm is much better on x86-64,
+// branchless C is not used at all.
+// - With x86-64 asm, there are slight differences between GCC and Clang
+// and different processors. Overall 0x1F0 seems to be the best choice.
+#ifndef LZMA_RANGE_DECODER_CONFIG
+# if defined(__x86_64__) && !defined(__ILP32__) \
+ && (defined(__GNUC__) || defined(__clang__))
+# define LZMA_RANGE_DECODER_CONFIG 0x1F0
+# else
+# define LZMA_RANGE_DECODER_CONFIG 0
+# endif
+#endif
+
+
+// Negative RC_BIT_MODEL_TOTAL but the lowest RC_MOVE_BITS are flipped.
+// This is useful for updating probability variables in branchless decoding:
+//
+// uint32_t decoded_bit = ...;
+// probability tmp = RC_BIT_MODEL_OFFSET;
+// tmp &= decoded_bit - 1;
+// prob -= (prob + tmp) >> RC_MOVE_BITS;
+#define RC_BIT_MODEL_OFFSET \
+ ((UINT32_C(1) << RC_MOVE_BITS) - 1 - RC_BIT_MODEL_TOTAL)
+
+
typedef struct {
uint32_t range;
uint32_t code;
@@ -50,18 +97,28 @@ rc_read_init(lzma_range_decoder *rc, const uint8_t *restrict in,
/// Makes local copies of range decoder and *in_pos variables. Doing this
/// improves speed significantly. The range decoder macros expect also
-/// variables `in' and `in_size' to be defined.
-#define rc_to_local(range_decoder, in_pos) \
+/// variables 'in' and 'in_size' to be defined.
+#define rc_to_local(range_decoder, in_pos, fast_mode_in_required) \
lzma_range_decoder rc = range_decoder; \
- size_t rc_in_pos = (in_pos); \
+ const uint8_t *rc_in_ptr = in + (in_pos); \
+ const uint8_t *rc_in_end = in + in_size; \
+ const uint8_t *rc_in_fast_end \
+ = (rc_in_end - rc_in_ptr) <= (fast_mode_in_required) \
+ ? rc_in_ptr \
+ : rc_in_end - (fast_mode_in_required); \
+ (void)rc_in_fast_end; /* Silence a warning with HAVE_SMALL. */ \
uint32_t rc_bound
+/// Evaluates to true if there is enough input remaining to use fast mode.
+#define rc_is_fast_allowed() (rc_in_ptr < rc_in_fast_end)
+
+
/// Stores the local copes back to the range decoder structure.
#define rc_from_local(range_decoder, in_pos) \
do { \
range_decoder = rc; \
- in_pos = rc_in_pos; \
+ in_pos = (size_t)(rc_in_ptr - in); \
} while (0)
@@ -81,18 +138,30 @@ do { \
((range_decoder).code == 0)
-/// Read the next input byte if needed. If more input is needed but there is
+// Read the next input byte if needed.
+#define rc_normalize() \
+do { \
+ if (rc.range < RC_TOP_VALUE) { \
+ rc.range <<= RC_SHIFT_BITS; \
+ rc.code = (rc.code << RC_SHIFT_BITS) | *rc_in_ptr++; \
+ } \
+} while (0)
+
+
+/// If more input is needed but there is
/// no more input available, "goto out" is used to jump out of the main
-/// decoder loop.
-#define rc_normalize(seq) \
+/// decoder loop. The "_safe" macros are used in the Resumable decoder
+/// mode in order to save the sequence to continue decoding from that
+/// point later.
+#define rc_normalize_safe(seq) \
do { \
if (rc.range < RC_TOP_VALUE) { \
- if (unlikely(rc_in_pos == in_size)) { \
+ if (rc_in_ptr == rc_in_end) { \
coder->sequence = seq; \
goto out; \
} \
rc.range <<= RC_SHIFT_BITS; \
- rc.code = (rc.code << RC_SHIFT_BITS) | in[rc_in_pos++]; \
+ rc.code = (rc.code << RC_SHIFT_BITS) | *rc_in_ptr++; \
} \
} while (0)
@@ -100,7 +169,7 @@ do { \
/// Start decoding a bit. This must be used together with rc_update_0()
/// and rc_update_1():
///
-/// rc_if_0(prob, seq) {
+/// rc_if_0(prob) {
/// rc_update_0(prob);
/// // Do something
/// } else {
@@ -108,18 +177,28 @@ do { \
/// // Do something else
/// }
///
-#define rc_if_0(prob, seq) \
- rc_normalize(seq); \
+#define rc_if_0(prob) \
+ rc_normalize(); \
+ rc_bound = (rc.range >> RC_BIT_MODEL_TOTAL_BITS) * (prob); \
+ if (rc.code < rc_bound)
+
+
+#define rc_if_0_safe(prob, seq) \
+ rc_normalize_safe(seq); \
rc_bound = (rc.range >> RC_BIT_MODEL_TOTAL_BITS) * (prob); \
if (rc.code < rc_bound)
/// Update the range decoder state and the used probability variable to
/// match a decoded bit of 0.
+///
+/// The x86-64 assembly uses the commented method but it seems that,
+/// at least on x86-64, the first version is slightly faster as C code.
#define rc_update_0(prob) \
do { \
rc.range = rc_bound; \
prob += (RC_BIT_MODEL_TOTAL - (prob)) >> RC_MOVE_BITS; \
+ /* prob -= ((prob) + RC_BIT_MODEL_OFFSET) >> RC_MOVE_BITS; */ \
} while (0)
@@ -137,9 +216,21 @@ do { \
/// This macro is used as the last step in bittree reverse decoders since
/// those don't use "symbol" for anything else than indexing the probability
/// arrays.
-#define rc_bit_last(prob, action0, action1, seq) \
+#define rc_bit_last(prob, action0, action1) \
+do { \
+ rc_if_0(prob) { \
+ rc_update_0(prob); \
+ action0; \
+ } else { \
+ rc_update_1(prob); \
+ action1; \
+ } \
+} while (0)
+
+
+#define rc_bit_last_safe(prob, action0, action1, seq) \
do { \
- rc_if_0(prob, seq) { \
+ rc_if_0_safe(prob, seq) { \
rc_update_0(prob); \
action0; \
} else { \
@@ -151,35 +242,724 @@ do { \
/// Decodes one bit, updates "symbol", and runs action0 or action1 depending
/// on the decoded bit.
-#define rc_bit(prob, action0, action1, seq) \
+#define rc_bit(prob, action0, action1) \
rc_bit_last(prob, \
symbol <<= 1; action0, \
+ symbol = (symbol << 1) + 1; action1);
+
+
+#define rc_bit_safe(prob, action0, action1, seq) \
+ rc_bit_last_safe(prob, \
+ symbol <<= 1; action0, \
symbol = (symbol << 1) + 1; action1, \
seq);
+// Unroll fixed-sized bittree decoding.
+//
+// A compile-time constant in final_add can be used to get rid of the high bit
+// from symbol that is used for the array indexing (1U << bittree_bits).
+// final_add may also be used to add offset to the result (LZMA length
+// decoder does that).
+//
+// The reason to have final_add here is that in the asm code the addition
+// can be done for free: in x86-64 there is SBB instruction with -1 as
+// the immediate value, and final_add is combined with that value.
+#define rc_bittree_bit(prob) \
+ rc_bit(prob, , )
+
+#define rc_bittree3(probs, final_add) \
+do { \
+ symbol = 1; \
+ rc_bittree_bit(probs[symbol]); \
+ rc_bittree_bit(probs[symbol]); \
+ rc_bittree_bit(probs[symbol]); \
+ symbol += (uint32_t)(final_add); \
+} while (0)
-/// Like rc_bit() but add "case seq:" as a prefix. This makes the unrolled
-/// loops more readable because the code isn't littered with "case"
-/// statements. On the other hand this also makes it less readable, since
-/// spotting the places where the decoder loop may be restarted is less
-/// obvious.
-#define rc_bit_case(prob, action0, action1, seq) \
- case seq: rc_bit(prob, action0, action1, seq)
+#define rc_bittree6(probs, final_add) \
+do { \
+ symbol = 1; \
+ rc_bittree_bit(probs[symbol]); \
+ rc_bittree_bit(probs[symbol]); \
+ rc_bittree_bit(probs[symbol]); \
+ rc_bittree_bit(probs[symbol]); \
+ rc_bittree_bit(probs[symbol]); \
+ rc_bittree_bit(probs[symbol]); \
+ symbol += (uint32_t)(final_add); \
+} while (0)
+
+#define rc_bittree8(probs, final_add) \
+do { \
+ symbol = 1; \
+ rc_bittree_bit(probs[symbol]); \
+ rc_bittree_bit(probs[symbol]); \
+ rc_bittree_bit(probs[symbol]); \
+ rc_bittree_bit(probs[symbol]); \
+ rc_bittree_bit(probs[symbol]); \
+ rc_bittree_bit(probs[symbol]); \
+ rc_bittree_bit(probs[symbol]); \
+ rc_bittree_bit(probs[symbol]); \
+ symbol += (uint32_t)(final_add); \
+} while (0)
+
+
+// Fixed-sized reverse bittree
+#define rc_bittree_rev4(probs) \
+do { \
+ symbol = 0; \
+ rc_bit_last(probs[symbol + 1], , symbol += 1); \
+ rc_bit_last(probs[symbol + 2], , symbol += 2); \
+ rc_bit_last(probs[symbol + 4], , symbol += 4); \
+ rc_bit_last(probs[symbol + 8], , symbol += 8); \
+} while (0)
+
+
+// Decode one bit from variable-sized reverse bittree. The loop is done
+// in the code that uses this macro. This could be changed if the assembly
+// version benefited from having the loop done in assembly but it didn't
+// seem so in early 2024.
+//
+// Also, if the loop was done here, the loop counter would likely be local
+// to the macro so that it wouldn't modify yet another input variable.
+// If a _safe version of a macro with a loop was done then a modifiable
+// input variable couldn't be avoided though.
+#define rc_bit_add_if_1(probs, dest, value_to_add_if_1) \
+ rc_bit(probs[symbol], \
+ , \
+ dest += value_to_add_if_1);
+
+
+// Matched literal
+#define decode_with_match_bit \
+ t_match_byte <<= 1; \
+ t_match_bit = t_match_byte & t_offset; \
+ t_subcoder_index = t_offset + t_match_bit + symbol; \
+ rc_bit(probs[t_subcoder_index], \
+ t_offset &= ~t_match_bit, \
+ t_offset &= t_match_bit)
+
+#define rc_matched_literal(probs_base_var, match_byte) \
+do { \
+ uint32_t t_match_byte = (match_byte); \
+ uint32_t t_match_bit; \
+ uint32_t t_subcoder_index; \
+ uint32_t t_offset = 0x100; \
+ symbol = 1; \
+ decode_with_match_bit; \
+ decode_with_match_bit; \
+ decode_with_match_bit; \
+ decode_with_match_bit; \
+ decode_with_match_bit; \
+ decode_with_match_bit; \
+ decode_with_match_bit; \
+ decode_with_match_bit; \
+} while (0)
/// Decode a bit without using a probability.
-#define rc_direct(dest, seq) \
+//
+// NOTE: GCC 13 and Clang/LLVM 16 can, at least on x86-64, optimize the bound
+// calculation to use an arithmetic right shift so there's no need to provide
+// the alternative code which, according to C99/C11/C23 6.3.1.3-p3 isn't
+// perfectly portable: rc_bound = (uint32_t)((int32_t)rc.code >> 31);
+#define rc_direct(dest, count_var) \
do { \
- rc_normalize(seq); \
+ dest = (dest << 1) + 1; \
+ rc_normalize(); \
+ rc.range >>= 1; \
+ rc.code -= rc.range; \
+ rc_bound = UINT32_C(0) - (rc.code >> 31); \
+ dest += rc_bound; \
+ rc.code += rc.range & rc_bound; \
+} while (--count_var > 0)
+
+
+
+#define rc_direct_safe(dest, count_var, seq) \
+do { \
+ rc_normalize_safe(seq); \
rc.range >>= 1; \
rc.code -= rc.range; \
rc_bound = UINT32_C(0) - (rc.code >> 31); \
rc.code += rc.range & rc_bound; \
dest = (dest << 1) + (rc_bound + 1); \
+} while (--count_var > 0)
+
+
+//////////////////
+// Branchless C //
+//////////////////
+
+/// Decode a bit using a branchless method. This reduces the number of
+/// mispredicted branches and thus can improve speed.
+#define rc_c_bit(prob, action_bit, action_neg) \
+do { \
+ probability *p = &(prob); \
+ rc_normalize(); \
+ rc_bound = (rc.range >> RC_BIT_MODEL_TOTAL_BITS) * *p; \
+ uint32_t rc_mask = rc.code >= rc_bound; /* rc_mask = decoded bit */ \
+ action_bit; /* action when rc_mask is 0 or 1 */ \
+ /* rc_mask becomes 0 if bit is 0 and 0xFFFFFFFF if bit is 1: */ \
+ rc_mask = 0U - rc_mask; \
+ rc.range &= rc_mask; /* If bit 0: set rc.range = 0 */ \
+ rc_bound ^= rc_mask; \
+ rc_bound -= rc_mask; /* If bit 1: rc_bound = 0U - rc_bound */ \
+ rc.range += rc_bound; \
+ rc_bound &= rc_mask; \
+ rc.code += rc_bound; \
+ action_neg; /* action when rc_mask is 0 or 0xFFFFFFFF */ \
+ rc_mask = ~rc_mask; /* If bit 0: all bits are set in rc_mask */ \
+ rc_mask &= RC_BIT_MODEL_OFFSET; \
+ *p -= (*p + rc_mask) >> RC_MOVE_BITS; \
} while (0)
-// NOTE: No macros are provided for bittree decoding. It seems to be simpler
-// to just write them open in the code.
+// Testing on x86-64 give an impression that only the normal bittrees and
+// the fixed-sized reverse bittrees are worth the branchless C code.
+// It should be tested on other archs for which there isn't assembly code
+// in this file.
+
+// Using addition in "(symbol << 1) + rc_mask" allows use of x86 LEA
+// or RISC-V SH1ADD instructions. Compilers might infer it from
+// "(symbol << 1) | rc_mask" too if they see that mask is 0 or 1 but
+// the use of addition doesn't require such analysis from compilers.
+#if LZMA_RANGE_DECODER_CONFIG & 0x01
+#undef rc_bittree_bit
+#define rc_bittree_bit(prob) \
+ rc_c_bit(prob, \
+ symbol = (symbol << 1) + rc_mask, \
+ )
+#endif // LZMA_RANGE_DECODER_CONFIG & 0x01
+
+#if LZMA_RANGE_DECODER_CONFIG & 0x02
+#undef rc_bittree_rev4
+#define rc_bittree_rev4(probs) \
+do { \
+ symbol = 0; \
+ rc_c_bit(probs[symbol + 1], symbol += rc_mask, ); \
+ rc_c_bit(probs[symbol + 2], symbol += rc_mask << 1, ); \
+ rc_c_bit(probs[symbol + 4], symbol += rc_mask << 2, ); \
+ rc_c_bit(probs[symbol + 8], symbol += rc_mask << 3, ); \
+} while (0)
+#endif // LZMA_RANGE_DECODER_CONFIG & 0x02
+
+#if LZMA_RANGE_DECODER_CONFIG & 0x04
+#undef rc_bit_add_if_1
+#define rc_bit_add_if_1(probs, dest, value_to_add_if_1) \
+ rc_c_bit(probs[symbol], \
+ symbol = (symbol << 1) + rc_mask, \
+ dest += (value_to_add_if_1) & rc_mask)
+#endif // LZMA_RANGE_DECODER_CONFIG & 0x04
+
+
+#if LZMA_RANGE_DECODER_CONFIG & 0x08
+#undef decode_with_match_bit
+#define decode_with_match_bit \
+ t_match_byte <<= 1; \
+ t_match_bit = t_match_byte & t_offset; \
+ t_subcoder_index = t_offset + t_match_bit + symbol; \
+ rc_c_bit(probs[t_subcoder_index], \
+ symbol = (symbol << 1) + rc_mask, \
+ t_offset &= ~t_match_bit ^ rc_mask)
+#endif // LZMA_RANGE_DECODER_CONFIG & 0x08
+
+
+////////////
+// x86-64 //
+////////////
+
+#if LZMA_RANGE_DECODER_CONFIG & 0x1F0
+
+// rc_asm_y and rc_asm_n are used as arguments to macros to control which
+// strings to include or omit.
+#define rc_asm_y(str) str
+#define rc_asm_n(str)
+
+// There are a few possible variations for normalization.
+// This is the smallest variant which is also used by LZMA SDK.
+//
+// - This has partial register write (the MOV from (%[in_ptr])).
+//
+// - INC saves one byte in code size over ADD. False dependency on
+// partial flags from INC shouldn't become a problem on any processor
+// because the instructions after normalization don't read the flags
+// until SUB which sets all flags.
+//
+#define rc_asm_normalize \
+ "cmp %[top_value], %[range]\n\t" \
+ "jae 1f\n\t" \
+ "shl %[shift_bits], %[code]\n\t" \
+ "mov (%[in_ptr]), %b[code]\n\t" \
+ "shl %[shift_bits], %[range]\n\t" \
+ "inc %[in_ptr]\n" \
+ "1:\n"
+
+// rc_asm_calc(prob) is roughly equivalent to the C version of rc_if_0(prob)...
+//
+// rc_bound = (rc.range >> RC_BIT_MODEL_TOTAL_BITS) * (prob);
+// if (rc.code < rc_bound)
+//
+// ...but the bound is stored in "range":
+//
+// t0 = range;
+// range = (range >> RC_BIT_MODEL_TOTAL_BITS) * (prob);
+// t0 -= range;
+// t1 = code;
+// code -= range;
+//
+// The carry flag (CF) from the last subtraction holds the negation of
+// the decoded bit (if CF==0 then the decoded bit is 1).
+// The values in t0 and t1 are needed for rc_update_0(prob) and
+// rc_update_1(prob). If the bit is 0, rc_update_0(prob)...
+//
+// rc.range = rc_bound;
+//
+// ...has already been done but the "code -= range" has to be reverted using
+// the old value stored in t1. (Also, prob needs to be updated.)
+//
+// If the bit is 1, rc_update_1(prob)...
+//
+// rc.range -= rc_bound;
+// rc.code -= rc_bound;
+//
+// ...is already done for "code" but the value for "range" needs to be taken
+// from t0. (Also, prob needs to be updated here as well.)
+//
+// The assignments from t0 and t1 can be done in a branchless manner with CMOV
+// after the instructions from this macro. The CF from SUB tells which moves
+// are needed.
+#define rc_asm_calc(prob) \
+ "mov %[range], %[t0]\n\t" \
+ "shr %[bit_model_total_bits], %[range]\n\t" \
+ "imul %[" prob "], %[range]\n\t" \
+ "sub %[range], %[t0]\n\t" \
+ "mov %[code], %[t1]\n\t" \
+ "sub %[range], %[code]\n\t"
+
+// Also, prob needs to be updated: The update math depends on the decoded bit.
+// It can be expressed in a few slightly different ways but this is fairly
+// convenient here:
+//
+// prob -= (prob + (bit ? 0 : RC_BIT_MODEL_OFFSET)) >> RC_MOVE_BITS;
+//
+// To do it in branchless way when the negation of the decoded bit is in CF,
+// both "prob" and "prob + RC_BIT_MODEL_OFFSET" are needed. Then the desired
+// value can be picked with CMOV. The addition can be done using LEA without
+// affecting CF.
+//
+// (This prob update method is a tiny bit different from LZMA SDK 23.01.
+// In the LZMA SDK a single register is reserved solely for a constant to
+// be used with CMOV when updating prob. That is fine since there are enough
+// free registers to do so. The method used here uses one fewer register,
+// which is valuable with inline assembly.)
+//
+// * * *
+//
+// In bittree decoding, each (unrolled) loop iteration decodes one bit
+// and needs one prob variable. To make it faster, the prob variable of
+// the iteration N+1 is loaded during iteration N. There are two possible
+// prob variables to choose from for N+1. Both are loaded from memory and
+// the correct one is chosen with CMOV using the same CF as is used for
+// other things described above.
+//
+// This preloading/prefetching requires an extra register. To avoid
+// useless moves from "preloaded prob register" to "current prob register",
+// the macros swap between the two registers for odd and even iterations.
+//
+// * * *
+//
+// Finally, the decoded bit has to be stored in "symbol". Since the negation
+// of the bit is in CF, this can be done with SBB: symbol -= CF - 1. That is,
+// if the decoded bit is 0 (CF==1) the operation is a no-op "symbol -= 0"
+// and when bit is 1 (CF==0) the operation is "symbol -= 0 - 1" which is
+// the same as "symbol += 1".
+//
+// The instructions for all things are intertwined for a few reasons:
+// - freeing temporary registers for new use
+// - not modifying CF too early
+// - instruction scheduling
+//
+// The first and last iterations can cheat a little. For example,
+// on the first iteration "symbol" is known to start from 1 so it
+// doesn't need to be read; it can even be immediately initialized
+// to 2 to prepare for the second iteration of the loop.
+//
+// * * *
+//
+// a = number of the current prob variable (0 or 1)
+// b = number of the next prob variable (1 or 0)
+// *_only = rc_asm_y or _n to include or exclude code marked with them
+#define rc_asm_bittree(a, b, first_only, middle_only, last_only) \
+ first_only( \
+ "movzw 2(%[probs_base]), %[prob" #a "]\n\t" \
+ "mov $2, %[symbol]\n\t" \
+ "movzw 4(%[probs_base]), %[prob" #b "]\n\t" \
+ ) \
+ middle_only( \
+ /* Note the scaling of 4 instead of 2: */ \
+ "movzw (%[probs_base], %q[symbol], 4), %[prob" #b "]\n\t" \
+ ) \
+ last_only( \
+ "add %[symbol], %[symbol]\n\t" \
+ ) \
+ \
+ rc_asm_normalize \
+ rc_asm_calc("prob" #a) \
+ \
+ "cmovae %[t0], %[range]\n\t" \
+ \
+ first_only( \
+ "movzw 6(%[probs_base]), %[t0]\n\t" \
+ "cmovae %[t0], %[prob" #b "]\n\t" \
+ ) \
+ middle_only( \
+ "movzw 2(%[probs_base], %q[symbol], 4), %[t0]\n\t" \
+ "lea (%q[symbol], %q[symbol]), %[symbol]\n\t" \
+ "cmovae %[t0], %[prob" #b "]\n\t" \
+ ) \
+ \
+ "lea %c[bit_model_offset](%q[prob" #a "]), %[t0]\n\t" \
+ "cmovb %[t1], %[code]\n\t" \
+ "mov %[symbol], %[t1]\n\t" \
+ "cmovae %[prob" #a "], %[t0]\n\t" \
+ \
+ first_only( \
+ "sbb $-1, %[symbol]\n\t" \
+ ) \
+ middle_only( \
+ "sbb $-1, %[symbol]\n\t" \
+ ) \
+ last_only( \
+ "sbb %[last_sbb], %[symbol]\n\t" \
+ ) \
+ \
+ "shr %[move_bits], %[t0]\n\t" \
+ "sub %[t0], %[prob" #a "]\n\t" \
+ /* Scaling of 1 instead of 2 because symbol <<= 1. */ \
+ "mov %w[prob" #a "], (%[probs_base], %q[t1], 1)\n\t"
+
+// NOTE: The order of variables in __asm__ can affect speed and code size.
+#define rc_asm_bittree_n(probs_base_var, final_add, asm_str) \
+do { \
+ uint32_t t0; \
+ uint32_t t1; \
+ uint32_t t_prob0; \
+ uint32_t t_prob1; \
+ \
+ __asm__( \
+ asm_str \
+ : \
+ [range] "+&r"(rc.range), \
+ [code] "+&r"(rc.code), \
+ [t0] "=&r"(t0), \
+ [t1] "=&r"(t1), \
+ [prob0] "=&r"(t_prob0), \
+ [prob1] "=&r"(t_prob1), \
+ [symbol] "=&r"(symbol), \
+ [in_ptr] "+&r"(rc_in_ptr) \
+ : \
+ [probs_base] "r"(probs_base_var), \
+ [last_sbb] "n"(-1 - (final_add)), \
+ [top_value] "n"(RC_TOP_VALUE), \
+ [shift_bits] "n"(RC_SHIFT_BITS), \
+ [bit_model_total_bits] "n"(RC_BIT_MODEL_TOTAL_BITS), \
+ [bit_model_offset] "n"(RC_BIT_MODEL_OFFSET), \
+ [move_bits] "n"(RC_MOVE_BITS) \
+ : \
+ "cc", "memory"); \
+} while (0)
+
+
+#if LZMA_RANGE_DECODER_CONFIG & 0x010
+#undef rc_bittree3
+#define rc_bittree3(probs_base_var, final_add) \
+ rc_asm_bittree_n(probs_base_var, final_add, \
+ rc_asm_bittree(0, 1, rc_asm_y, rc_asm_n, rc_asm_n) \
+ rc_asm_bittree(1, 0, rc_asm_n, rc_asm_y, rc_asm_n) \
+ rc_asm_bittree(0, 1, rc_asm_n, rc_asm_n, rc_asm_y) \
+ )
+
+#undef rc_bittree6
+#define rc_bittree6(probs_base_var, final_add) \
+ rc_asm_bittree_n(probs_base_var, final_add, \
+ rc_asm_bittree(0, 1, rc_asm_y, rc_asm_n, rc_asm_n) \
+ rc_asm_bittree(1, 0, rc_asm_n, rc_asm_y, rc_asm_n) \
+ rc_asm_bittree(0, 1, rc_asm_n, rc_asm_y, rc_asm_n) \
+ rc_asm_bittree(1, 0, rc_asm_n, rc_asm_y, rc_asm_n) \
+ rc_asm_bittree(0, 1, rc_asm_n, rc_asm_y, rc_asm_n) \
+ rc_asm_bittree(1, 0, rc_asm_n, rc_asm_n, rc_asm_y) \
+ )
+
+#undef rc_bittree8
+#define rc_bittree8(probs_base_var, final_add) \
+ rc_asm_bittree_n(probs_base_var, final_add, \
+ rc_asm_bittree(0, 1, rc_asm_y, rc_asm_n, rc_asm_n) \
+ rc_asm_bittree(1, 0, rc_asm_n, rc_asm_y, rc_asm_n) \
+ rc_asm_bittree(0, 1, rc_asm_n, rc_asm_y, rc_asm_n) \
+ rc_asm_bittree(1, 0, rc_asm_n, rc_asm_y, rc_asm_n) \
+ rc_asm_bittree(0, 1, rc_asm_n, rc_asm_y, rc_asm_n) \
+ rc_asm_bittree(1, 0, rc_asm_n, rc_asm_y, rc_asm_n) \
+ rc_asm_bittree(0, 1, rc_asm_n, rc_asm_y, rc_asm_n) \
+ rc_asm_bittree(1, 0, rc_asm_n, rc_asm_n, rc_asm_y) \
+ )
+#endif // LZMA_RANGE_DECODER_CONFIG & 0x010
+
+
+// Fixed-sized reverse bittree
+//
+// This uses the indexing that constructs the final value in symbol directly.
+// add = 1, 2, 4, 8
+// dcur = -, 4, 8, 16
+// dnext0 = 4, 8, 16, -
+// dnext0 = 6, 12, 24, -
+#define rc_asm_bittree_rev(a, b, add, dcur, dnext0, dnext1, \
+ first_only, middle_only, last_only) \
+ first_only( \
+ "movzw 2(%[probs_base]), %[prob" #a "]\n\t" \
+ "xor %[symbol], %[symbol]\n\t" \
+ "movzw 4(%[probs_base]), %[prob" #b "]\n\t" \
+ ) \
+ middle_only( \
+ "movzw " #dnext0 "(%[probs_base], %q[symbol], 2), " \
+ "%[prob" #b "]\n\t" \
+ ) \
+ \
+ rc_asm_normalize \
+ rc_asm_calc("prob" #a) \
+ \
+ "cmovae %[t0], %[range]\n\t" \
+ \
+ first_only( \
+ "movzw 6(%[probs_base]), %[t0]\n\t" \
+ "cmovae %[t0], %[prob" #b "]\n\t" \
+ ) \
+ middle_only( \
+ "movzw " #dnext1 "(%[probs_base], %q[symbol], 2), %[t0]\n\t" \
+ "cmovae %[t0], %[prob" #b "]\n\t" \
+ ) \
+ \
+ "lea " #add "(%q[symbol]), %[t0]\n\t" \
+ "cmovb %[t1], %[code]\n\t" \
+ middle_only( \
+ "mov %[symbol], %[t1]\n\t" \
+ ) \
+ last_only( \
+ "mov %[symbol], %[t1]\n\t" \
+ ) \
+ "cmovae %[t0], %[symbol]\n\t" \
+ "lea %c[bit_model_offset](%q[prob" #a "]), %[t0]\n\t" \
+ "cmovae %[prob" #a "], %[t0]\n\t" \
+ \
+ "shr %[move_bits], %[t0]\n\t" \
+ "sub %[t0], %[prob" #a "]\n\t" \
+ first_only( \
+ "mov %w[prob" #a "], 2(%[probs_base])\n\t" \
+ ) \
+ middle_only( \
+ "mov %w[prob" #a "], " \
+ #dcur "(%[probs_base], %q[t1], 2)\n\t" \
+ ) \
+ last_only( \
+ "mov %w[prob" #a "], " \
+ #dcur "(%[probs_base], %q[t1], 2)\n\t" \
+ )
+
+#if LZMA_RANGE_DECODER_CONFIG & 0x020
+#undef rc_bittree_rev4
+#define rc_bittree_rev4(probs_base_var) \
+rc_asm_bittree_n(probs_base_var, 4, \
+ rc_asm_bittree_rev(0, 1, 1, -, 4, 6, rc_asm_y, rc_asm_n, rc_asm_n) \
+ rc_asm_bittree_rev(1, 0, 2, 4, 8, 12, rc_asm_n, rc_asm_y, rc_asm_n) \
+ rc_asm_bittree_rev(0, 1, 4, 8, 16, 24, rc_asm_n, rc_asm_y, rc_asm_n) \
+ rc_asm_bittree_rev(1, 0, 8, 16, -, -, rc_asm_n, rc_asm_n, rc_asm_y) \
+)
+#endif // LZMA_RANGE_DECODER_CONFIG & 0x020
+
+
+#if LZMA_RANGE_DECODER_CONFIG & 0x040
+#undef rc_bit_add_if_1
+#define rc_bit_add_if_1(probs_base_var, dest_var, value_to_add_if_1) \
+do { \
+ uint32_t t0; \
+ uint32_t t1; \
+ uint32_t t2 = (value_to_add_if_1); \
+ uint32_t t_prob; \
+ uint32_t t_index; \
+ \
+ __asm__( \
+ "movzw (%[probs_base], %q[symbol], 2), %[prob]\n\t" \
+ "mov %[symbol], %[index]\n\t" \
+ \
+ "add %[dest], %[t2]\n\t" \
+ "add %[symbol], %[symbol]\n\t" \
+ \
+ rc_asm_normalize \
+ rc_asm_calc("prob") \
+ \
+ "cmovae %[t0], %[range]\n\t" \
+ "lea %c[bit_model_offset](%q[prob]), %[t0]\n\t" \
+ "cmovb %[t1], %[code]\n\t" \
+ "cmovae %[prob], %[t0]\n\t" \
+ \
+ "cmovae %[t2], %[dest]\n\t" \
+ "sbb $-1, %[symbol]\n\t" \
+ \
+ "sar %[move_bits], %[t0]\n\t" \
+ "sub %[t0], %[prob]\n\t" \
+ "mov %w[prob], (%[probs_base], %q[index], 2)" \
+ : \
+ [range] "+&r"(rc.range), \
+ [code] "+&r"(rc.code), \
+ [t0] "=&r"(t0), \
+ [t1] "=&r"(t1), \
+ [prob] "=&r"(t_prob), \
+ [index] "=&r"(t_index), \
+ [symbol] "+&r"(symbol), \
+ [t2] "+&r"(t2), \
+ [dest] "+&r"(dest_var), \
+ [in_ptr] "+&r"(rc_in_ptr) \
+ : \
+ [probs_base] "r"(probs_base_var), \
+ [top_value] "n"(RC_TOP_VALUE), \
+ [shift_bits] "n"(RC_SHIFT_BITS), \
+ [bit_model_total_bits] "n"(RC_BIT_MODEL_TOTAL_BITS), \
+ [bit_model_offset] "n"(RC_BIT_MODEL_OFFSET), \
+ [move_bits] "n"(RC_MOVE_BITS) \
+ : \
+ "cc", "memory"); \
+} while (0)
+#endif // LZMA_RANGE_DECODER_CONFIG & 0x040
+
+
+// Literal decoding uses a normal 8-bit bittree but literal with match byte
+// is more complex in picking the probability variable from the correct
+// subtree. This doesn't use preloading/prefetching of the next prob because
+// there are four choices instead of two.
+//
+// FIXME? The first iteration starts with symbol = 1 so it could be optimized
+// by a tiny amount.
+#define rc_asm_matched_literal(nonlast_only) \
+ "add %[offset], %[symbol]\n\t" \
+ "and %[offset], %[match_bit]\n\t" \
+ "add %[match_bit], %[symbol]\n\t" \
+ \
+ "movzw (%[probs_base], %q[symbol], 2), %[prob]\n\t" \
+ \
+ "add %[symbol], %[symbol]\n\t" \
+ \
+ nonlast_only( \
+ "xor %[match_bit], %[offset]\n\t" \
+ "add %[match_byte], %[match_byte]\n\t" \
+ ) \
+ \
+ rc_asm_normalize \
+ rc_asm_calc("prob") \
+ \
+ "cmovae %[t0], %[range]\n\t" \
+ "lea %c[bit_model_offset](%q[prob]), %[t0]\n\t" \
+ "cmovb %[t1], %[code]\n\t" \
+ "mov %[symbol], %[t1]\n\t" \
+ "cmovae %[prob], %[t0]\n\t" \
+ \
+ nonlast_only( \
+ "cmovae %[match_bit], %[offset]\n\t" \
+ "mov %[match_byte], %[match_bit]\n\t" \
+ ) \
+ \
+ "sbb $-1, %[symbol]\n\t" \
+ \
+ "shr %[move_bits], %[t0]\n\t" \
+ /* Undo symbol += match_bit + offset: */ \
+ "and $0x1FF, %[symbol]\n\t" \
+ "sub %[t0], %[prob]\n\t" \
+ \
+ /* Scaling of 1 instead of 2 because symbol <<= 1. */ \
+ "mov %w[prob], (%[probs_base], %q[t1], 1)\n\t"
+
+
+#if LZMA_RANGE_DECODER_CONFIG & 0x080
+#undef rc_matched_literal
+#define rc_matched_literal(probs_base_var, match_byte_value) \
+do { \
+ uint32_t t0; \
+ uint32_t t1; \
+ uint32_t t_prob; \
+ uint32_t t_match_byte = (uint32_t)(match_byte_value) << 1; \
+ uint32_t t_match_bit = t_match_byte; \
+ uint32_t t_offset = 0x100; \
+ symbol = 1; \
+ \
+ __asm__( \
+ rc_asm_matched_literal(rc_asm_y) \
+ rc_asm_matched_literal(rc_asm_y) \
+ rc_asm_matched_literal(rc_asm_y) \
+ rc_asm_matched_literal(rc_asm_y) \
+ rc_asm_matched_literal(rc_asm_y) \
+ rc_asm_matched_literal(rc_asm_y) \
+ rc_asm_matched_literal(rc_asm_y) \
+ rc_asm_matched_literal(rc_asm_n) \
+ : \
+ [range] "+&r"(rc.range), \
+ [code] "+&r"(rc.code), \
+ [t0] "=&r"(t0), \
+ [t1] "=&r"(t1), \
+ [prob] "=&r"(t_prob), \
+ [match_bit] "+&r"(t_match_bit), \
+ [symbol] "+&r"(symbol), \
+ [match_byte] "+&r"(t_match_byte), \
+ [offset] "+&r"(t_offset), \
+ [in_ptr] "+&r"(rc_in_ptr) \
+ : \
+ [probs_base] "r"(probs_base_var), \
+ [top_value] "n"(RC_TOP_VALUE), \
+ [shift_bits] "n"(RC_SHIFT_BITS), \
+ [bit_model_total_bits] "n"(RC_BIT_MODEL_TOTAL_BITS), \
+ [bit_model_offset] "n"(RC_BIT_MODEL_OFFSET), \
+ [move_bits] "n"(RC_MOVE_BITS) \
+ : \
+ "cc", "memory"); \
+} while (0)
+#endif // LZMA_RANGE_DECODER_CONFIG & 0x080
+
+
+// Doing the loop in asm instead of C seems to help a little.
+#if LZMA_RANGE_DECODER_CONFIG & 0x100
+#undef rc_direct
+#define rc_direct(dest_var, count_var) \
+do { \
+ uint32_t t0; \
+ uint32_t t1; \
+ \
+ __asm__( \
+ "2:\n\t" \
+ "add %[dest], %[dest]\n\t" \
+ "lea 1(%q[dest]), %[t1]\n\t" \
+ \
+ rc_asm_normalize \
+ \
+ "shr $1, %[range]\n\t" \
+ "mov %[code], %[t0]\n\t" \
+ "sub %[range], %[code]\n\t" \
+ "cmovns %[t1], %[dest]\n\t" \
+ "cmovs %[t0], %[code]\n\t" \
+ "dec %[count]\n\t" \
+ "jnz 2b\n\t" \
+ : \
+ [range] "+&r"(rc.range), \
+ [code] "+&r"(rc.code), \
+ [t0] "=&r"(t0), \
+ [t1] "=&r"(t1), \
+ [dest] "+&r"(dest_var), \
+ [count] "+&r"(count_var), \
+ [in_ptr] "+&r"(rc_in_ptr) \
+ : \
+ [top_value] "n"(RC_TOP_VALUE), \
+ [shift_bits] "n"(RC_SHIFT_BITS) \
+ : \
+ "cc", "memory"); \
+} while (0)
+#endif // LZMA_RANGE_DECODER_CONFIG & 0x100
+
+#endif // x86_64
#endif
diff --git a/src/liblzma/rangecoder/range_encoder.h b/src/liblzma/rangecoder/range_encoder.h
index d794eabbccea..8f62a47ac0a6 100644
--- a/src/liblzma/rangecoder/range_encoder.h
+++ b/src/liblzma/rangecoder/range_encoder.h
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file range_encoder.h
@@ -6,9 +8,6 @@
// Authors: Igor Pavlov
// Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
#ifndef LZMA_RANGE_ENCODER_H
diff --git a/src/liblzma/simple/arm.c b/src/liblzma/simple/arm.c
index 6e53970d2f27..58acb2d11adf 100644
--- a/src/liblzma/simple/arm.c
+++ b/src/liblzma/simple/arm.c
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file arm.c
@@ -6,9 +8,6 @@
// Authors: Igor Pavlov
// Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
#include "simple_private.h"
diff --git a/src/liblzma/simple/arm64.c b/src/liblzma/simple/arm64.c
index 0fe0824eb931..0a73f6c8bf2d 100644
--- a/src/liblzma/simple/arm64.c
+++ b/src/liblzma/simple/arm64.c
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file arm64.c
@@ -16,9 +18,6 @@
// Jia Tan
// Igor Pavlov
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
#include "simple_private.h"
diff --git a/src/liblzma/simple/armthumb.c b/src/liblzma/simple/armthumb.c
index 25d8dbd4f36e..f1eeca9b80f1 100644
--- a/src/liblzma/simple/armthumb.c
+++ b/src/liblzma/simple/armthumb.c
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file armthumb.c
@@ -6,9 +8,6 @@
// Authors: Igor Pavlov
// Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
#include "simple_private.h"
diff --git a/src/liblzma/simple/ia64.c b/src/liblzma/simple/ia64.c
index 692b0a295ef2..502501409977 100644
--- a/src/liblzma/simple/ia64.c
+++ b/src/liblzma/simple/ia64.c
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file ia64.c
@@ -6,9 +8,6 @@
// Authors: Igor Pavlov
// Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
#include "simple_private.h"
diff --git a/src/liblzma/simple/powerpc.c b/src/liblzma/simple/powerpc.c
index 3a340fd171a5..ba6cfbef3ab6 100644
--- a/src/liblzma/simple/powerpc.c
+++ b/src/liblzma/simple/powerpc.c
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file powerpc.c
@@ -6,9 +8,6 @@
// Authors: Igor Pavlov
// Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
#include "simple_private.h"
diff --git a/src/liblzma/simple/riscv.c b/src/liblzma/simple/riscv.c
new file mode 100644
index 000000000000..aabbb0520577
--- /dev/null
+++ b/src/liblzma/simple/riscv.c
@@ -0,0 +1,755 @@
+// SPDX-License-Identifier: 0BSD
+
+///////////////////////////////////////////////////////////////////////////////
+//
+/// \file riscv.c
+/// \brief Filter for 32-bit/64-bit little/big endian RISC-V binaries
+///
+/// This converts program counter relative addresses in function calls
+/// (JAL, AUIPC+JALR), address calculation of functions and global
+/// variables (AUIPC+ADDI), loads (AUIPC+load), and stores (AUIPC+store).
+///
+/// For AUIPC+inst2 pairs, the paired instruction checking is fairly relaxed.
+/// The paired instruction opcode must only have its lowest two bits set,
+/// meaning it will convert any paired instruction that is not a 16-bit
+/// compressed instruction. This was shown to be enough to keep the number
+/// of false matches low while improving code size and speed.
+//
+// Authors: Lasse Collin
+// Jia Tan
+//
+// Special thanks:
+//
+// - Chien Wong <m@xv97.com> provided a few early versions of RISC-V
+// filter variants along with test files and benchmark results.
+//
+// - Igor Pavlov helped a lot in the filter design, getting it both
+// faster and smaller. The implementation here is still independently
+// written, not based on LZMA SDK.
+//
+///////////////////////////////////////////////////////////////////////////////
+
+/*
+
+RISC-V filtering
+================
+
+ RV32I and RV64I, possibly combined with extensions C, Zfh, F, D,
+ and Q, are identical enough that the same filter works for both.
+
+ The instruction encoding is always little endian, even on systems
+ with big endian data access. Thus the same filter works for both
+ endiannesses.
+
+ The following instructions have program counter relative
+ (pc-relative) behavior:
+
+JAL
+---
+
+ JAL is used for function calls (including tail calls) and
+ unconditional jumps within functions. Jumps within functions
+ aren't useful to filter because the absolute addresses often
+ appear only once or at most a few times. Tail calls and jumps
+ within functions look the same to a simple filter so neither
+ are filtered, that is, JAL x0 is ignored (the ABI name of the
+ register x0 is "zero").
+
+ Almost all calls store the return address to register x1 (ra)
+ or x5 (t0). To reduce false matches when the filter is applied
+ to non-code data, only the JAL instructions that use x1 or x5
+ are converted. JAL has pc-relative range of +/-1 MiB so longer
+ calls and jumps need another method (AUIPC+JALR).
+
+C.J and C.JAL
+-------------
+
+ C.J and C.JAL have pc-relative range of +/-2 KiB.
+
+ C.J is for tail calls and jumps within functions and isn't
+ filtered for the reasons mentioned for JAL x0.
+
+ C.JAL is an RV32C-only instruction. Its encoding overlaps with
+ RV64C-only C.ADDIW which is a common instruction. So if filtering
+ C.JAL was useful (it wasn't tested) then a separate filter would
+ be needed for RV32 and RV64. Also, false positives would be a
+ significant problem when the filter is applied to non-code data
+ because C.JAL needs only five bits to match. Thus, this filter
+ doesn't modify C.JAL instructions.
+
+BEQ, BNE, BLT, BGE, BLTU, BGEU, C.BEQZ, and C.BNEZ
+--------------------------------------------------
+
+ These are conditional branches with pc-relative range
+ of +/-4 KiB (+/-256 B for C.*). The absolute addresses often
+ appear only once and very short distances are the most common,
+ so filtering these instructions would make compression worse.
+
+AUIPC with rd != x0
+-------------------
+
+ AUIPC is paired with a second instruction (inst2) to do
+ pc-relative jumps, calls, loads, stores, and for taking
+ an address of a symbol. AUIPC has a 20-bit immediate and
+ the possible inst2 choices have a 12-bit immediate.
+
+ AUIPC stores pc + 20-bit signed immediate to a register.
+ The immediate encodes a multiple of 4 KiB so AUIPC itself
+ has a pc-relative range of +/-2 GiB. AUIPC does *NOT* set
+ the lowest 12 bits of the result to zero! This means that
+ the 12-bit immediate in inst2 cannot just include the lowest
+ 12 bits of the absolute address as is; the immediate has to
+ compensate for the lowest 12 bits that AUIPC copies from the
+ program counter. This means that a good filter has to convert
+ not only AUIPC but also the paired inst2.
+
+ A strict filter would focus on filtering the following
+ AUIPC+inst2 pairs:
+
+ - AUIPC+JALR: Function calls, including tail calls.
+
+ - AUIPC+ADDI: Calculating the address of a function
+ or a global variable.
+
+ - AUIPC+load/store from the base instruction sets
+ (RV32I, RV64I) or from the floating point extensions
+ Zfh, F, D, and Q:
+ * RV32I: LB, LH, LW, LBU, LHU, SB, SH, SW
+ * RV64I has also: LD, LWU, SD
+ * Zhf: FLH, FSH
+ * F: FLW, FSW
+ * D: FLD, FSD
+ * Q: FLQ, FSQ
+
+ NOTE: AUIPC+inst2 can only be a pair if AUIPC's rd specifies
+ the same register as inst2's rs1.
+
+ Instead of strictly accepting only the above instructions as inst2,
+ this filter uses a much simpler condition: the lowest two bits of
+ inst2 must be set, that is, inst2 must not be a 16-bit compressed
+ instruction. So this will accept all 32-bit and possible future
+ extended instructions as a pair to AUIPC if the bits in AUIPC's
+ rd [11:7] match the bits [19:15] in inst2 (the bits that I-type and
+ S-type instructions use for rs1). Testing showed that this relaxed
+ condition for inst2 did not consistently or significantly affect
+ compression ratio but it reduced code size and improved speed.
+
+ Additionally, the paired instruction is always treated as an I-type
+ instruction. The S-type instructions used by stores (SB, SH, SW,
+ etc.) place the lowest 5 bits of the immediate in a different
+ location than I-type instructions. AUIPC+store pairs are less
+ common than other pairs, and testing showed that the extra
+ code required to handle S-type instructions was not worth the
+ compression ratio gained.
+
+ AUIPC+inst2 don't necessarily appear sequentially next to each
+ other although very often they do. Especially AUIPC+JALR are
+ sequential as that may allow instruction fusion in processors
+ (and perhaps help branch prediction as a fused AUIPC+JALR is
+ a direct branch while JALR alone is an indirect branch).
+
+ Clang 16 can generate code where AUIPC+inst2 is split:
+
+ - AUIPC is outside a loop and inst2 (load/store) is inside
+ the loop. This way the AUIPC instruction needs to be
+ executed only once.
+
+ - Load-modify-store may have AUIPC for the load and the same
+ AUIPC-result is used for the store too. This may get combined
+ with AUIPC being outside the loop.
+
+ - AUIPC is before a conditional branch and inst2 is hundreds
+ of bytes away at the branch target.
+
+ - Inner and outer pair:
+
+ auipc a1,0x2f
+ auipc a2,0x3d
+ ld a2,-500(a2)
+ addi a1,a1,-233
+
+ - Many split pairs with an untaken conditional branch between:
+
+ auipc s9,0x1613 # Pair 1
+ auipc s4,0x1613 # Pair 2
+ auipc s6,0x1613 # Pair 3
+ auipc s10,0x1613 # Pair 4
+ beqz a5,a3baae
+ ld a0,0(a6)
+ ld a6,246(s9) # Pair 1
+ ld a1,250(s4) # Pair 2
+ ld a3,254(s6) # Pair 3
+ ld a4,258(s10) # Pair 4
+
+ It's not possible to find all split pairs in a filter like this.
+ At least in 2024, simple sequential pairs are 99 % of AUIPC uses
+ so filtering only such pairs gives good results and makes the
+ filter simpler. However, it's possible that future compilers will
+ produce different code where sequential pairs aren't as common.
+
+ This filter doesn't convert AUIPC instructions alone because:
+
+ (1) The conversion would be off-by-one (or off-by-4096) half the
+ time because the lowest 12 bits from inst2 (inst2_imm12)
+ aren't known. We only know that the absolute address is
+ pc + AUIPC_imm20 + [-2048, +2047] but there is no way to
+ know the exact 4096-byte multiple (or 4096 * n + 2048):
+ there are always two possibilities because AUIPC copies
+ the 12 lowest bits from pc instead of zeroing them.
+
+ NOTE: The sign-extension of inst2_imm12 adds a tiny bit
+ of extra complexity to AUIPC math in general but it's not
+ the reason for this problem. The sign-extension only changes
+ the relative position of the pc-relative 4096-byte window.
+
+ (2) Matching AUIPC instruction alone requires only seven bits.
+ When the filter is applied to non-code data, that leads
+ to many false positives which make compression worse.
+ As long as most AUIPC+inst2 pairs appear as two consecutive
+ instructions, converting only such pairs gives better results.
+
+ In assembly, AUIPC+inst2 tend to look like this:
+
+ # Call:
+ auipc ra, 0x12345
+ jalr ra, -42(ra)
+
+ # Tail call:
+ auipc t1, 0x12345
+ jalr zero, -42(t1)
+
+ # Getting the absolute address:
+ auipc a0, 0x12345
+ addi a0, a0, -42
+
+ # rd of inst2 isn't necessarily the same as rs1 even
+ # in cases where there is no reason to preserve rs1.
+ auipc a0, 0x12345
+ addi a1, a0, -42
+
+ As of 2024, 16-bit instructions from the C extension don't
+ appear as inst2. The RISC-V psABI doesn't list AUIPC+C.* as
+ a linker relaxation type explicitly but it's not disallowed
+ either. Usefulness is limited as most of the time the lowest
+ 12 bits won't fit in a C instruction. This filter doesn't
+ support AUIPC+C.* combinations because this makes the filter
+ simpler, there are no test files, and it hopefully will never
+ be needed anyway.
+
+ (Compare AUIPC to ARM64 where ADRP does set the lowest 12 bits
+ to zero. The paired instruction has the lowest 12 bits of the
+ absolute address as is in a zero-extended immediate. Thus the
+ ARM64 filter doesn't need to care about the instructions that
+ are paired with ADRP. An off-by-4096 issue can still occur if
+ the code section isn't aligned with the filter's start offset.
+ It's not a problem with standalone ELF files but Windows PE
+ files need start_offset=3072 for best results. Also, a .tar
+ stores files with 512-byte alignment so most of the time it
+ won't be the best for ARM64.)
+
+AUIPC with rd == x0
+-------------------
+
+ AUIPC instructions with rd=x0 are reserved for HINTs in the base
+ instruction set. Such AUIPC instructions are never filtered.
+
+ As of January 2024, it seems likely that AUIPC with rd=x0 will
+ be used for landing pads (pseudoinstruction LPAD). LPAD is used
+ to mark valid targets for indirect jumps (for JALR), for example,
+ beginnings of functions. The 20-bit immediate in LPAD instruction
+ is a label, not a pc-relative address. Thus it would be
+ counterproductive to convert AUIPC instructions with rd=x0.
+
+ Often the next instruction after LPAD won't have rs1=x0 and thus
+ the filtering would be skipped for that reason alone. However,
+ it's not good to rely on this. For example, consider a function
+ that begins like this:
+
+ int foo(int i)
+ {
+ if (i <= 234) {
+ ...
+ }
+
+ A compiler may generate something like this:
+
+ lpad 0x54321
+ li a5, 234
+ bgt a0, a5, .L2
+
+ Converting the pseudoinstructions to raw instructions:
+
+ auipc x0, 0x54321
+ addi x15, x0, 234
+ blt x15, x10, .L2
+
+ In this case the filter would undesirably convert the AUIPC+ADDI
+ pair if the filter didn't explicitly skip AUIPC instructions
+ that have rd=x0.
+
+*/
+
+
+#include "simple_private.h"
+
+
+// This checks two conditions at once:
+// - AUIPC rd == inst2 rs1.
+// - inst2 opcode has the lowest two bits set.
+//
+// The 8 bit left shift aligns the rd of AUIPC with the rs1 of inst2.
+// By XORing the registers, any non-zero value in those bits indicates the
+// registers are not equal and thus not an AUIPC pair. Subtracting 3 from
+// inst2 will zero out the first two opcode bits only when they are set.
+// The mask tests if any of the register or opcode bits are set (and thus
+// not an AUIPC pair).
+//
+// Alternative expression: (((((auipc) << 8) ^ (inst2)) & 0xF8003) != 3)
+#define NOT_AUIPC_PAIR(auipc, inst2) \
+ ((((auipc) << 8) ^ ((inst2) - 3)) & 0xF8003)
+
+// This macro checks multiple conditions:
+// (1) AUIPC rd [11:7] == x2 (special rd value).
+// (2) AUIPC bits 12 and 13 set (the lowest two opcode bits of packed inst2).
+// (3) inst2_rs1 doesn't equal x0 or x2 because the opposite
+// conversion is only done when
+// auipc_rd != x0 &&
+// auipc_rd != x2 &&
+// auipc_rd == inst2_rs1.
+//
+// The left-hand side takes care of (1) and (2).
+// (a) The lowest 7 bits are already known to be AUIPC so subtracting 0x17
+// makes those bits zeros.
+// (b) If AUIPC rd equals x2, subtracting 0x10 makes bits [11:7] zeros.
+// If rd doesn't equal x2, then there will be at least one non-zero bit
+// and the next step (c) is irrelevant.
+// (c) If the lowest two opcode bits of the packed inst2 are set in [13:12],
+// then subtracting 0x300 will make those bits zeros. Otherwise there
+// will be at least one non-zero bit.
+//
+// The shift by 18 removes the high bits from the final '>=' comparison and
+// ensures that any non-zero result will be larger than any possible result
+// from the right-hand side of the comparison. The cast ensures that the
+// left-hand side didn't get promoted to a larger type than uint32_t.
+//
+// On the right-hand side, inst2_rs1 & 0x1D will be non-zero as long as
+// inst2_rs1 is not x0 or x2.
+//
+// The final '>=' comparison will make the expression true if:
+// - The subtraction caused any bits to be set (special AUIPC rd value not
+// used or inst2 opcode bits not set). (non-zero >= non-zero or 0)
+// - The subtraction did not cause any bits to be set but inst2_rs1 was
+// x0 or x2. (0 >= 0)
+#define NOT_SPECIAL_AUIPC(auipc, inst2_rs1) \
+ ((uint32_t)(((auipc) - 0x3117) << 18) >= ((inst2_rs1) & 0x1D))
+
+
+// The encode and decode functions are split for this filter because of the
+// AUIPC+inst2 filtering. This filter design allows a decoder-only
+// implementation to be smaller than alternative designs.
+
+#ifdef HAVE_ENCODER_RISCV
+static size_t
+riscv_encode(void *simple lzma_attribute((__unused__)),
+ uint32_t now_pos,
+ bool is_encoder lzma_attribute((__unused__)),
+ uint8_t *buffer, size_t size)
+{
+ // Avoid using i + 8 <= size in the loop condition.
+ //
+ // NOTE: If there is a JAL in the last six bytes of the stream, it
+ // won't be converted. This is intentional to keep the code simpler.
+ if (size < 8)
+ return 0;
+
+ size -= 8;
+
+ size_t i;
+
+ // The loop is advanced by 2 bytes every iteration since the
+ // instruction stream may include 16-bit instructions (C extension).
+ for (i = 0; i <= size; i += 2) {
+ uint32_t inst = buffer[i];
+
+ if (inst == 0xEF) {
+ // JAL
+ const uint32_t b1 = buffer[i + 1];
+
+ // Only filter rd=x1(ra) and rd=x5(t0).
+ if ((b1 & 0x0D) != 0)
+ continue;
+
+ // The 20-bit immediate is in four pieces.
+ // The encoder stores it in big endian form
+ // since it improves compression slightly.
+ const uint32_t b2 = buffer[i + 2];
+ const uint32_t b3 = buffer[i + 3];
+ const uint32_t pc = now_pos + (uint32_t)i;
+
+// The following chart shows the highest three bytes of JAL, focusing on
+// the 20-bit immediate field [31:12]. The first row of numbers is the
+// bit position in a 32-bit little endian instruction. The second row of
+// numbers shows the order of the immediate field in a J-type instruction.
+// The last row is the bit number in each byte.
+//
+// To determine the amount to shift each bit, subtract the value in
+// the last row from the value in the second last row. If the number
+// is positive, shift left. If negative, shift right.
+//
+// For example, at the rightmost side of the chart, the bit 4 in b1 is
+// the bit 12 of the address. Thus that bit needs to be shifted left
+// by 12 - 4 = 8 bits to put it in the right place in the addr variable.
+//
+// NOTE: The immediate of a J-type instruction holds bits [20:1] of
+// the address. The bit [0] is always 0 and not part of the immediate.
+//
+// | b3 | b2 | b1 |
+// | 31 30 29 28 27 26 25 24 | 23 22 21 20 19 18 17 16 | 15 14 13 12 x x x x |
+// | 20 10 9 8 7 6 5 4 | 3 2 1 11 19 18 17 16 | 15 14 13 12 x x x x |
+// | 7 6 5 4 3 2 1 0 | 7 6 5 4 3 2 1 0 | 7 6 5 4 x x x x |
+
+ uint32_t addr = ((b1 & 0xF0) << 8)
+ | ((b2 & 0x0F) << 16)
+ | ((b2 & 0x10) << 7)
+ | ((b2 & 0xE0) >> 4)
+ | ((b3 & 0x7F) << 4)
+ | ((b3 & 0x80) << 13);
+
+ addr += pc;
+
+ buffer[i + 1] = (uint8_t)((b1 & 0x0F)
+ | ((addr >> 13) & 0xF0));
+
+ buffer[i + 2] = (uint8_t)(addr >> 9);
+ buffer[i + 3] = (uint8_t)(addr >> 1);
+
+ // The "-2" is included because the for-loop will
+ // always increment by 2. In this case, we want to
+ // skip an extra 2 bytes since we used 4 bytes
+ // of input.
+ i += 4 - 2;
+
+ } else if ((inst & 0x7F) == 0x17) {
+ // AUIPC
+ inst |= (uint32_t)buffer[i + 1] << 8;
+ inst |= (uint32_t)buffer[i + 2] << 16;
+ inst |= (uint32_t)buffer[i + 3] << 24;
+
+ // Branch based on AUIPC's rd. The bitmask test does
+ // the same thing as this:
+ //
+ // const uint32_t auipc_rd = (inst >> 7) & 0x1F;
+ // if (auipc_rd != 0 && auipc_rd != 2) {
+ if (inst & 0xE80) {
+ // AUIPC's rd doesn't equal x0 or x2.
+
+ // Check if AUIPC+inst2 are a pair.
+ uint32_t inst2 = read32le(buffer + i + 4);
+
+ if (NOT_AUIPC_PAIR(inst, inst2)) {
+ // The NOT_AUIPC_PAIR macro allows
+ // a false AUIPC+AUIPC pair if the
+ // bits [19:15] (where rs1 would be)
+ // in the second AUIPC match the rd
+ // of the first AUIPC.
+ //
+ // We must skip enough forward so
+ // that the first two bytes of the
+ // second AUIPC cannot get converted.
+ // Such a conversion could make the
+ // current pair become a valid pair
+ // which would desync the decoder.
+ //
+ // Skipping six bytes is enough even
+ // though the above condition looks
+ // at the lowest four bits of the
+ // buffer[i + 6] too. This is safe
+ // because this filter never changes
+ // those bits if a conversion at
+ // that position is done.
+ i += 6 - 2;
+ continue;
+ }
+
+ // Convert AUIPC+inst2 to a special format:
+ //
+ // - The lowest 7 bits [6:0] retain the
+ // AUIPC opcode.
+ //
+ // - The rd [11:7] is set to x2(sp). x2 is
+ // used as the stack pointer so AUIPC with
+ // rd=x2 should be very rare in real-world
+ // executables.
+ //
+ // - The remaining 20 bits [31:12] (that
+ // normally hold the pc-relative immediate)
+ // are used to store the lowest 20 bits of
+ // inst2. That is, the 12-bit immediate of
+ // inst2 is not included.
+ //
+ // - The location of the original inst2 is
+ // used to store the 32-bit absolute
+ // address in big endian format. Compared
+ // to the 20+12-bit split encoding, this
+ // results in a longer uninterrupted
+ // sequence of identical common bytes
+ // when the same address is referred
+ // with different instruction pairs
+ // (like AUIPC+LD vs. AUIPC+ADDI) or
+ // when the occurrences of the same
+ // pair use different registers. When
+ // referring to adjacent memory locations
+ // (like function calls that go via the
+ // ELF PLT), in big endian order only the
+ // last 1-2 bytes differ; in little endian
+ // the differing 1-2 bytes would be in the
+ // middle of the 8-byte sequence.
+ //
+ // When reversing the transformation, the
+ // original rd of AUIPC can be restored
+ // from inst2's rs1 as they are required to
+ // be the same.
+
+ // Arithmetic right shift makes sign extension
+ // trivial but (1) it's implementation-defined
+ // behavior (C99/C11/C23 6.5.7-p5) and so is
+ // (2) casting unsigned to signed (6.3.1.3-p3).
+ //
+ // One can check for (1) with
+ //
+ // if ((-1 >> 1) == -1) ...
+ //
+ // but (2) has to be checked from the
+ // compiler docs. GCC promises that (1)
+ // and (2) behave in the common expected
+ // way and thus
+ //
+ // addr += (uint32_t)(
+ // (int32_t)inst2 >> 20);
+ //
+ // does the same as the code below. But since
+ // the 100 % portable way is only a few bytes
+ // bigger code and there is no real speed
+ // difference, let's just use that, especially
+ // since the decoder doesn't need this at all.
+ uint32_t addr = inst & 0xFFFFF000;
+ addr += (inst2 >> 20)
+ - ((inst2 >> 19) & 0x1000);
+
+ addr += now_pos + (uint32_t)i;
+
+ // Construct the first 32 bits:
+ // [6:0] AUIPC opcode
+ // [11:7] Special AUIPC rd = x2
+ // [31:12] The lowest 20 bits of inst2
+ inst = 0x17 | (2 << 7) | (inst2 << 12);
+
+ write32le(buffer + i, inst);
+
+ // The second 32 bits store the absolute
+ // address in big endian order.
+ write32be(buffer + i + 4, addr);
+ } else {
+ // AUIPC's rd equals x0 or x2.
+ //
+ // x0 indicates a landing pad (LPAD).
+ // It's always skipped.
+ //
+ // AUIPC with rd == x2 is used for the special
+ // format as explained above. When the input
+ // contains a byte sequence that matches the
+ // special format, "fake" decoding must be
+ // done to keep the filter bijective (that
+ // is, safe to apply on arbitrary data).
+ //
+ // See the "x0 or x2" section in riscv_decode()
+ // for how the "real" decoding is done. The
+ // "fake" decoding is a simplified version
+ // of "real" decoding with the following
+ // differences (these reduce code size of
+ // the decoder):
+ // (1) The lowest 12 bits aren't sign-extended.
+ // (2) No address conversion is done.
+ // (3) Big endian format isn't used (the fake
+ // address is in little endian order).
+
+ // Check if inst matches the special format.
+ const uint32_t fake_rs1 = inst >> 27;
+
+ if (NOT_SPECIAL_AUIPC(inst, fake_rs1)) {
+ i += 4 - 2;
+ continue;
+ }
+
+ const uint32_t fake_addr =
+ read32le(buffer + i + 4);
+
+ // Construct the second 32 bits:
+ // [19:0] Upper 20 bits from AUIPC
+ // [31:20] The lowest 12 bits of fake_addr
+ const uint32_t fake_inst2 = (inst >> 12)
+ | (fake_addr << 20);
+
+ // Construct new first 32 bits from:
+ // [6:0] AUIPC opcode
+ // [11:7] Fake AUIPC rd = fake_rs1
+ // [31:12] The highest 20 bits of fake_addr
+ inst = 0x17 | (fake_rs1 << 7)
+ | (fake_addr & 0xFFFFF000);
+
+ write32le(buffer + i, inst);
+ write32le(buffer + i + 4, fake_inst2);
+ }
+
+ i += 8 - 2;
+ }
+ }
+
+ return i;
+}
+
+
+extern lzma_ret
+lzma_simple_riscv_encoder_init(lzma_next_coder *next,
+ const lzma_allocator *allocator,
+ const lzma_filter_info *filters)
+{
+ return lzma_simple_coder_init(next, allocator, filters,
+ &riscv_encode, 0, 8, 2, true);
+}
+#endif
+
+
+#ifdef HAVE_DECODER_RISCV
+static size_t
+riscv_decode(void *simple lzma_attribute((__unused__)),
+ uint32_t now_pos,
+ bool is_encoder lzma_attribute((__unused__)),
+ uint8_t *buffer, size_t size)
+{
+ if (size < 8)
+ return 0;
+
+ size -= 8;
+
+ size_t i;
+ for (i = 0; i <= size; i += 2) {
+ uint32_t inst = buffer[i];
+
+ if (inst == 0xEF) {
+ // JAL
+ const uint32_t b1 = buffer[i + 1];
+
+ // Only filter rd=x1(ra) and rd=x5(t0).
+ if ((b1 & 0x0D) != 0)
+ continue;
+
+ const uint32_t b2 = buffer[i + 2];
+ const uint32_t b3 = buffer[i + 3];
+ const uint32_t pc = now_pos + (uint32_t)i;
+
+// | b3 | b2 | b1 |
+// | 31 30 29 28 27 26 25 24 | 23 22 21 20 19 18 17 16 | 15 14 13 12 x x x x |
+// | 20 10 9 8 7 6 5 4 | 3 2 1 11 19 18 17 16 | 15 14 13 12 x x x x |
+// | 7 6 5 4 3 2 1 0 | 7 6 5 4 3 2 1 0 | 7 6 5 4 x x x x |
+
+ uint32_t addr = ((b1 & 0xF0) << 13)
+ | (b2 << 9) | (b3 << 1);
+
+ addr -= pc;
+
+ buffer[i + 1] = (uint8_t)((b1 & 0x0F)
+ | ((addr >> 8) & 0xF0));
+
+ buffer[i + 2] = (uint8_t)(((addr >> 16) & 0x0F)
+ | ((addr >> 7) & 0x10)
+ | ((addr << 4) & 0xE0));
+
+ buffer[i + 3] = (uint8_t)(((addr >> 4) & 0x7F)
+ | ((addr >> 13) & 0x80));
+
+ i += 4 - 2;
+
+ } else if ((inst & 0x7F) == 0x17) {
+ // AUIPC
+ uint32_t inst2;
+
+ inst |= (uint32_t)buffer[i + 1] << 8;
+ inst |= (uint32_t)buffer[i + 2] << 16;
+ inst |= (uint32_t)buffer[i + 3] << 24;
+
+ if (inst & 0xE80) {
+ // AUIPC's rd doesn't equal x0 or x2.
+
+ // Check if it is a "fake" AUIPC+inst2 pair.
+ inst2 = read32le(buffer + i + 4);
+
+ if (NOT_AUIPC_PAIR(inst, inst2)) {
+ i += 6 - 2;
+ continue;
+ }
+
+ // Decode (or more like re-encode) the "fake"
+ // pair. The "fake" format doesn't do
+ // sign-extension, address conversion, or
+ // use big endian. (The use of little endian
+ // allows sharing the write32le() calls in
+ // the decoder to reduce code size when
+ // unaligned access isn't supported.)
+ uint32_t addr = inst & 0xFFFFF000;
+ addr += inst2 >> 20;
+
+ inst = 0x17 | (2 << 7) | (inst2 << 12);
+ inst2 = addr;
+ } else {
+ // AUIPC's rd equals x0 or x2.
+
+ // Check if inst matches the special format
+ // used by the encoder.
+ const uint32_t inst2_rs1 = inst >> 27;
+
+ if (NOT_SPECIAL_AUIPC(inst, inst2_rs1)) {
+ i += 4 - 2;
+ continue;
+ }
+
+ // Decode the "real" pair.
+ uint32_t addr = read32be(buffer + i + 4);
+
+ addr -= now_pos + (uint32_t)i;
+
+ // The second instruction:
+ // - Get the lowest 20 bits from inst.
+ // - Add the lowest 12 bits of the address
+ // as the immediate field.
+ inst2 = (inst >> 12) | (addr << 20);
+
+ // AUIPC:
+ // - rd is the same as inst2_rs1.
+ // - The sign extension of the lowest 12 bits
+ // must be taken into account.
+ inst = 0x17 | (inst2_rs1 << 7)
+ | ((addr + 0x800) & 0xFFFFF000);
+ }
+
+ // Both decoder branches write in little endian order.
+ write32le(buffer + i, inst);
+ write32le(buffer + i + 4, inst2);
+
+ i += 8 - 2;
+ }
+ }
+
+ return i;
+}
+
+
+extern lzma_ret
+lzma_simple_riscv_decoder_init(lzma_next_coder *next,
+ const lzma_allocator *allocator,
+ const lzma_filter_info *filters)
+{
+ return lzma_simple_coder_init(next, allocator, filters,
+ &riscv_decode, 0, 8, 2, false);
+}
+#endif
diff --git a/src/liblzma/simple/simple_coder.c b/src/liblzma/simple/simple_coder.c
index ed2d7fb02cca..5cbfa8227047 100644
--- a/src/liblzma/simple/simple_coder.c
+++ b/src/liblzma/simple/simple_coder.c
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file simple_coder.c
@@ -8,9 +10,6 @@
//
// Author: Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
#include "simple_private.h"
diff --git a/src/liblzma/simple/simple_coder.h b/src/liblzma/simple/simple_coder.h
index 668a5092ad5e..c9ccc3f1e634 100644
--- a/src/liblzma/simple/simple_coder.h
+++ b/src/liblzma/simple/simple_coder.h
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file simple_coder.h
@@ -5,9 +7,6 @@
//
// Author: Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
#ifndef LZMA_SIMPLE_CODER_H
@@ -78,4 +77,13 @@ extern lzma_ret lzma_simple_sparc_decoder_init(lzma_next_coder *next,
const lzma_allocator *allocator,
const lzma_filter_info *filters);
+
+extern lzma_ret lzma_simple_riscv_encoder_init(lzma_next_coder *next,
+ const lzma_allocator *allocator,
+ const lzma_filter_info *filters);
+
+extern lzma_ret lzma_simple_riscv_decoder_init(lzma_next_coder *next,
+ const lzma_allocator *allocator,
+ const lzma_filter_info *filters);
+
#endif
diff --git a/src/liblzma/simple/simple_decoder.c b/src/liblzma/simple/simple_decoder.c
index dc4d24151101..d9820ee8ed23 100644
--- a/src/liblzma/simple/simple_decoder.c
+++ b/src/liblzma/simple/simple_decoder.c
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file simple_decoder.c
@@ -5,9 +7,6 @@
//
// Author: Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
#include "simple_decoder.h"
diff --git a/src/liblzma/simple/simple_decoder.h b/src/liblzma/simple/simple_decoder.h
index bed8d37a9653..2ae87bb86328 100644
--- a/src/liblzma/simple/simple_decoder.h
+++ b/src/liblzma/simple/simple_decoder.h
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file simple_decoder.h
@@ -5,9 +7,6 @@
//
// Author: Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
#ifndef LZMA_SIMPLE_DECODER_H
diff --git a/src/liblzma/simple/simple_encoder.c b/src/liblzma/simple/simple_encoder.c
index d2cc03e58b81..d1f35096e2ae 100644
--- a/src/liblzma/simple/simple_encoder.c
+++ b/src/liblzma/simple/simple_encoder.c
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file simple_encoder.c
@@ -5,9 +7,6 @@
//
// Author: Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
#include "simple_encoder.h"
diff --git a/src/liblzma/simple/simple_encoder.h b/src/liblzma/simple/simple_encoder.h
index 1cee4823a4ed..bf5edbb1c3f4 100644
--- a/src/liblzma/simple/simple_encoder.h
+++ b/src/liblzma/simple/simple_encoder.h
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file simple_encoder.c
@@ -5,9 +7,6 @@
//
// Author: Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
#ifndef LZMA_SIMPLE_ENCODER_H
diff --git a/src/liblzma/simple/simple_private.h b/src/liblzma/simple/simple_private.h
index 9d2c0fdd7618..7aa360ff49e8 100644
--- a/src/liblzma/simple/simple_private.h
+++ b/src/liblzma/simple/simple_private.h
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file simple_private.h
@@ -5,9 +7,6 @@
//
// Author: Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
#ifndef LZMA_SIMPLE_PRIVATE_H
diff --git a/src/liblzma/simple/sparc.c b/src/liblzma/simple/sparc.c
index bad8492ebc06..e8ad285a1927 100644
--- a/src/liblzma/simple/sparc.c
+++ b/src/liblzma/simple/sparc.c
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file sparc.c
@@ -6,9 +8,6 @@
// Authors: Igor Pavlov
// Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
#include "simple_private.h"
diff --git a/src/liblzma/simple/x86.c b/src/liblzma/simple/x86.c
index 232b29542e66..10d70e91697b 100644
--- a/src/liblzma/simple/x86.c
+++ b/src/liblzma/simple/x86.c
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file x86.c
@@ -6,9 +8,6 @@
// Authors: Igor Pavlov
// Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
#include "simple_private.h"
diff --git a/src/liblzma/validate_map.sh b/src/liblzma/validate_map.sh
index 2bf6f8b98cbb..dd1589d236e7 100644
--- a/src/liblzma/validate_map.sh
+++ b/src/liblzma/validate_map.sh
@@ -1,4 +1,5 @@
#!/bin/sh
+# SPDX-License-Identifier: 0BSD
###############################################################################
#
@@ -78,9 +79,6 @@
#
# Author: Lasse Collin
#
-# This file has been put into the public domain.
-# You can do whatever you want with this file.
-#
###############################################################################
LC_ALL=C
@@ -124,7 +122,7 @@ DUPS=$(sort liblzma_generic.map | sed '/^$/d;/^global:$/d' | uniq -d)
# ignored (@XZ_5.1.2alpha or @XZ_5.2.2 won't be added at all when
# the #define HAVE_SYMBOL_VERSIONS_LINUX isn't used).
IN_SYNC=
-if ! sed '109,123d' liblzma_linux.map \
+if ! sed '111,125d' liblzma_linux.map \
| cmp -s - liblzma_generic.map; then
IN_SYNC=no
fi
diff --git a/src/lzmainfo/lzmainfo.1 b/src/lzmainfo/lzmainfo.1
index ce38eee50324..114e0f30ca6e 100644
--- a/src/lzmainfo/lzmainfo.1
+++ b/src/lzmainfo/lzmainfo.1
@@ -1,9 +1,7 @@
+.\" SPDX-License-Identifier: 0BSD
.\"
.\" Author: Lasse Collin
.\"
-.\" This file has been put into the public domain.
-.\" You can do whatever you want with this file.
-.\"
.TH LZMAINFO 1 "2013-06-30" "Tukaani" "XZ Utils"
.SH NAME
lzmainfo \- show information stored in the .lzma file header
diff --git a/src/lzmainfo/lzmainfo.c b/src/lzmainfo/lzmainfo.c
index 71e62958ad67..2550b1f1127b 100644
--- a/src/lzmainfo/lzmainfo.c
+++ b/src/lzmainfo/lzmainfo.c
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file lzmainfo.c
@@ -5,9 +7,6 @@
//
// Author: Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
#include "sysdefs.h"
diff --git a/src/xz/args.c b/src/xz/args.c
index 17e778c5db79..de84950a2987 100644
--- a/src/xz/args.c
+++ b/src/xz/args.c
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file args.c
@@ -5,10 +7,8 @@
///
/// \note Filter-specific options parsing is in options.c.
//
-// Author: Lasse Collin
-//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
+// Authors: Lasse Collin
+// Jia Tan
//
///////////////////////////////////////////////////////////////////////////////
@@ -83,14 +83,14 @@ parse_block_list(const char *str_const)
++count;
// Prevent an unlikely integer overflow.
- if (count > SIZE_MAX / sizeof(uint64_t) - 1)
+ if (count > SIZE_MAX / sizeof(block_list_entry) - 1)
message_fatal(_("%s: Too many arguments to --block-list"),
str);
// Allocate memory to hold all the sizes specified.
// If --block-list was specified already, its value is forgotten.
free(opt_block_list);
- opt_block_list = xmalloc((count + 1) * sizeof(uint64_t));
+ opt_block_list = xmalloc((count + 1) * sizeof(block_list_entry));
for (size_t i = 0; i < count; ++i) {
// Locate the next comma and replace it with \0.
@@ -98,6 +98,40 @@ parse_block_list(const char *str_const)
if (p != NULL)
*p = '\0';
+ // Use the default filter chain unless overridden.
+ opt_block_list[i].filters_index = 0;
+
+ // To specify a filter chain, the block list entry may be
+ // prepended with "[filter-chain-number]:". The size is
+ // still required for every block.
+ // For instance:
+ // --block-list=2:10MiB,1:5MiB,,8MiB,0:0
+ //
+ // Translates to:
+ // 1. Block of 10 MiB using filter chain 2
+ // 2. Block of 5 MiB using filter chain 1
+ // 3. Block of 5 MiB using filter chain 1
+ // 4. Block of 8 MiB using the default filter chain
+ // 5. The last block uses the default filter chain
+ //
+ // The block list:
+ // --block-list=2:MiB,1:,0
+ //
+ // Is not allowed because the second block does not specify
+ // the block size, only the filter chain.
+ if (str[0] >= '0' && str[0] <= '9' && str[1] == ':') {
+ if (str[2] == '\0')
+ message_fatal(_("In --block-list, block "
+ "size is missing after "
+ "filter chain number '%c:'"),
+ str[0]);
+
+ int filter_num = str[0] - '0';
+ opt_block_list[i].filters_index =
+ (uint32_t)filter_num;
+ str += 2;
+ }
+
if (str[0] == '\0') {
// There is no string, that is, a comma follows
// another comma. Use the previous value.
@@ -107,17 +141,17 @@ parse_block_list(const char *str_const)
assert(i > 0);
opt_block_list[i] = opt_block_list[i - 1];
} else {
- opt_block_list[i] = str_to_uint64("block-list", str,
- 0, UINT64_MAX);
+ opt_block_list[i].size = str_to_uint64("block-list",
+ str, 0, UINT64_MAX);
// Zero indicates no more new Blocks.
- if (opt_block_list[i] == 0) {
+ if (opt_block_list[i].size == 0) {
if (i + 1 != count)
message_fatal(_("0 can only be used "
"as the last element "
"in --block-list"));
- opt_block_list[i] = UINT64_MAX;
+ opt_block_list[i].size = UINT64_MAX;
}
}
@@ -125,7 +159,7 @@ parse_block_list(const char *str_const)
}
// Terminate the array.
- opt_block_list[count] = 0;
+ opt_block_list[count].size = 0;
free(str_start);
return;
@@ -136,13 +170,26 @@ static void
parse_real(args_info *args, int argc, char **argv)
{
enum {
- OPT_X86 = INT_MIN,
+ OPT_FILTERS = INT_MIN,
+ OPT_FILTERS1,
+ OPT_FILTERS2,
+ OPT_FILTERS3,
+ OPT_FILTERS4,
+ OPT_FILTERS5,
+ OPT_FILTERS6,
+ OPT_FILTERS7,
+ OPT_FILTERS8,
+ OPT_FILTERS9,
+ OPT_FILTERS_HELP,
+
+ OPT_X86,
OPT_POWERPC,
OPT_IA64,
OPT_ARM,
OPT_ARMTHUMB,
OPT_ARM64,
OPT_SPARC,
+ OPT_RISCV,
OPT_DELTA,
OPT_LZMA1,
OPT_LZMA2,
@@ -206,6 +253,18 @@ parse_real(args_info *args, int argc, char **argv)
{ "best", no_argument, NULL, '9' },
// Filters
+ { "filters", optional_argument, NULL, OPT_FILTERS},
+ { "filters1", optional_argument, NULL, OPT_FILTERS1},
+ { "filters2", optional_argument, NULL, OPT_FILTERS2},
+ { "filters3", optional_argument, NULL, OPT_FILTERS3},
+ { "filters4", optional_argument, NULL, OPT_FILTERS4},
+ { "filters5", optional_argument, NULL, OPT_FILTERS5},
+ { "filters6", optional_argument, NULL, OPT_FILTERS6},
+ { "filters7", optional_argument, NULL, OPT_FILTERS7},
+ { "filters8", optional_argument, NULL, OPT_FILTERS8},
+ { "filters9", optional_argument, NULL, OPT_FILTERS9},
+ { "filters-help", optional_argument, NULL, OPT_FILTERS_HELP},
+
{ "lzma1", optional_argument, NULL, OPT_LZMA1 },
{ "lzma2", optional_argument, NULL, OPT_LZMA2 },
{ "x86", optional_argument, NULL, OPT_X86 },
@@ -215,6 +274,7 @@ parse_real(args_info *args, int argc, char **argv)
{ "armthumb", optional_argument, NULL, OPT_ARMTHUMB },
{ "arm64", optional_argument, NULL, OPT_ARM64 },
{ "sparc", optional_argument, NULL, OPT_SPARC },
+ { "riscv", optional_argument, NULL, OPT_RISCV },
{ "delta", optional_argument, NULL, OPT_DELTA },
// Other options
@@ -372,7 +432,30 @@ parse_real(args_info *args, int argc, char **argv)
opt_mode = MODE_COMPRESS;
break;
- // Filter setup
+ // --filters
+ case OPT_FILTERS:
+ coder_add_filters_from_str(optarg);
+ break;
+
+ // --filters1...--filters9
+ case OPT_FILTERS1:
+ case OPT_FILTERS2:
+ case OPT_FILTERS3:
+ case OPT_FILTERS4:
+ case OPT_FILTERS5:
+ case OPT_FILTERS6:
+ case OPT_FILTERS7:
+ case OPT_FILTERS8:
+ case OPT_FILTERS9:
+ coder_add_block_filters(optarg,
+ (size_t)(c - OPT_FILTERS));
+ break;
+
+ // --filters-help
+ case OPT_FILTERS_HELP:
+ // This doesn't return.
+ message_filters_help();
+ break;
case OPT_X86:
coder_add_filter(LZMA_FILTER_X86,
@@ -409,6 +492,11 @@ parse_real(args_info *args, int argc, char **argv)
options_bcj(optarg));
break;
+ case OPT_RISCV:
+ coder_add_filter(LZMA_FILTER_RISCV,
+ options_bcj(optarg));
+ break;
+
case OPT_DELTA:
coder_add_filter(LZMA_FILTER_DELTA,
options_delta(optarg));
@@ -516,8 +604,8 @@ parse_real(args_info *args, int argc, char **argv)
case OPT_FILES0:
if (args->files_name != NULL)
message_fatal(_("Only one file can be "
- "specified with `--files' "
- "or `--files0'."));
+ "specified with '--files' "
+ "or '--files0'."));
if (optarg == NULL) {
args->files_name = stdin_filename;
@@ -718,6 +806,39 @@ args_parse(args_info *args, int argc, char **argv)
if (opt_mode == MODE_COMPRESS && opt_format == FORMAT_AUTO)
opt_format = FORMAT_XZ;
+ // Set opt_block_list to NULL if we are not compressing to the .xz
+ // format. This option cannot be used outside of this case, and
+ // simplifies the implementation later.
+ if ((opt_mode != MODE_COMPRESS || opt_format != FORMAT_XZ)
+ && opt_block_list != NULL) {
+ message(V_WARNING, _("--block-list is ignored unless "
+ "compressing to the .xz format"));
+ free(opt_block_list);
+ opt_block_list = NULL;
+ }
+
+ // If raw format is used and a custom suffix is not provided,
+ // then only stdout mode can be used when compressing or
+ // decompressing.
+ if (opt_format == FORMAT_RAW && !suffix_is_set() && !opt_stdout
+ && (opt_mode == MODE_COMPRESS
+ || opt_mode == MODE_DECOMPRESS)) {
+ if (args->files_name != NULL)
+ message_fatal(_("With --format=raw, "
+ "--suffix=.SUF is required "
+ "unless writing to stdout"));
+
+ // If all of the filenames provided are "-" (more than one
+ // "-" could be specified) or no filenames are provided,
+ // then we are only going to be writing to standard out.
+ for (int i = optind; i < argc; i++) {
+ if (strcmp(argv[i], "-") != 0)
+ message_fatal(_("With --format=raw, "
+ "--suffix=.SUF is required "
+ "unless writing to stdout"));
+ }
+ }
+
// Compression settings need to be validated (options themselves and
// their memory usage) when compressing to any file format. It has to
// be done also when uncompressing raw data, since for raw decoding
@@ -727,14 +848,6 @@ args_parse(args_info *args, int argc, char **argv)
&& opt_mode != MODE_LIST))
coder_set_compression_settings();
- // If raw format is used and a custom suffix is not provided,
- // then only stdout mode can be used when compressing or decompressing.
- if (opt_format == FORMAT_RAW && !suffix_is_set() && !opt_stdout
- && (opt_mode == MODE_COMPRESS
- || opt_mode == MODE_DECOMPRESS))
- message_fatal(_("With --format=raw, --suffix=.SUF is "
- "required unless writing to stdout"));
-
// If no filenames are given, use stdin.
if (argv[optind] == NULL && args->files_name == NULL) {
// We don't modify or free() the "-" constant. The caller
diff --git a/src/xz/args.h b/src/xz/args.h
index a1a5930ae5b1..e693ecd62280 100644
--- a/src/xz/args.h
+++ b/src/xz/args.h
@@ -1,12 +1,12 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file args.h
/// \brief Argument parsing
//
-// Author: Lasse Collin
-//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
+// Authors: Lasse Collin
+// Jia Tan
//
///////////////////////////////////////////////////////////////////////////////
diff --git a/src/xz/coder.c b/src/xz/coder.c
index 91d40ed2bb7b..4efaa802b9bb 100644
--- a/src/xz/coder.c
+++ b/src/xz/coder.c
@@ -1,12 +1,12 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file coder.c
/// \brief Compresses or uncompresses a file
//
-// Author: Lasse Collin
-//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
+// Authors: Lasse Collin
+// Jia Tan
//
///////////////////////////////////////////////////////////////////////////////
@@ -26,25 +26,51 @@ enum format_type opt_format = FORMAT_AUTO;
bool opt_auto_adjust = true;
bool opt_single_stream = false;
uint64_t opt_block_size = 0;
-uint64_t *opt_block_list = NULL;
-
+block_list_entry *opt_block_list = NULL;
/// Stream used to communicate with liblzma
static lzma_stream strm = LZMA_STREAM_INIT;
-/// Filters needed for all encoding all formats, and also decoding in raw data
-static lzma_filter filters[LZMA_FILTERS_MAX + 1];
+/// Maximum number of filter chains. The first filter chain is the default,
+/// and 9 other filter chains can be specified with --filtersX.
+#define NUM_FILTER_CHAIN_MAX 10
+
+/// The default filter chain is in filters[0]. It is used for encoding
+/// in all supported formats and also for decdoing raw streams. The other
+/// filter chains are set by --filtersX to support changing filters with
+/// the --block-list option.
+static lzma_filter filters[NUM_FILTER_CHAIN_MAX][LZMA_FILTERS_MAX + 1];
+
+/// Bit mask representing the filters that are actually used when encoding
+/// in the xz format. This is needed since a filter chain could be
+/// specified in --filtersX (or the default filter chain), but never used
+/// in --block-list. The default filter chain is always assumed to be used,
+/// unless --block-list is specified and does not have a block using the
+/// default filter chain.
+static uint32_t filters_used_mask = 1;
+
+#ifdef HAVE_ENCODERS
+/// Track the memory usage for all filter chains (default or --filtersX).
+/// The memory usage may need to be scaled down depending on the memory limit.
+static uint64_t filter_memusages[ARRAY_SIZE(filters)];
+#endif
/// Input and output buffers
static io_buf in_buf;
static io_buf out_buf;
-/// Number of filters. Zero indicates that we are using a preset.
+/// Number of filters in the default filter chain. Zero indicates that
+/// we are using a preset.
static uint32_t filters_count = 0;
/// Number of the preset (0-9)
static uint32_t preset_number = LZMA_PRESET_DEFAULT;
+/// True if the current default filter chain was set using the --filters
+/// option. The filter chain is reset if a preset option (like -9) or an
+/// old-style filter option (like --lzma2) is used after a --filters option.
+static bool string_to_filter_used = false;
+
/// Integrity check type
static lzma_check check;
@@ -60,7 +86,6 @@ static bool allow_trailing_input;
static lzma_mt mt_options = {
.flags = 0,
.timeout = 300,
- .filters = filters,
};
#endif
@@ -77,14 +102,14 @@ coder_set_check(lzma_check new_check)
static void
forget_filter_chain(void)
{
- // Setting a preset makes us forget a possibly defined custom
- // filter chain.
- while (filters_count > 0) {
- --filters_count;
- free(filters[filters_count].options);
- filters[filters_count].options = NULL;
+ // Setting a preset or using --filters makes us forget
+ // the earlier custom filter chain (if any).
+ if (filters_count > 0) {
+ lzma_filters_free(filters[0], NULL);
+ filters_count = 0;
}
+ string_to_filter_used = false;
return;
}
@@ -114,9 +139,14 @@ coder_add_filter(lzma_vli id, void *options)
if (filters_count == LZMA_FILTERS_MAX)
message_fatal(_("Maximum number of filters is four"));
- filters[filters_count].id = id;
- filters[filters_count].options = options;
- ++filters_count;
+ if (string_to_filter_used)
+ forget_filter_chain();
+
+ filters[0][filters_count].id = id;
+ filters[0][filters_count].options = options;
+ // Terminate the filter chain with LZMA_VLI_UNKNOWN to simplify
+ // implementation of forget_filter_chain().
+ filters[0][++filters_count].id = LZMA_VLI_UNKNOWN;
// Setting a custom filter chain makes us forget the preset options.
// This makes a difference if one specifies e.g. "xz -9 --lzma2 -e"
@@ -128,6 +158,69 @@ coder_add_filter(lzma_vli id, void *options)
}
+static void
+str_to_filters(const char *str, uint32_t index, uint32_t flags)
+{
+ int error_pos;
+ const char *err = lzma_str_to_filters(str, &error_pos,
+ filters[index], flags, NULL);
+
+ if (err != NULL) {
+ char filter_num[2] = "";
+ if (index > 0)
+ filter_num[0] = '0' + index;
+
+ // FIXME? The message in err isn't translated.
+ // Including the translations in the xz translations is
+ // slightly ugly but possible. Creating a new domain for
+ // liblzma might not be worth it especially since on some
+ // OSes it adds extra dependencies to translation libraries.
+ message(V_ERROR, _("Error in --filters%s=FILTERS option:"),
+ filter_num);
+ message(V_ERROR, "%s", str);
+ message(V_ERROR, "%*s^", error_pos, "");
+ message_fatal("%s", err);
+ }
+}
+
+
+extern void
+coder_add_filters_from_str(const char *filter_str)
+{
+ // Forget presets and previously defined filter chain. See
+ // coder_add_filter() above for why preset_number must be reset too.
+ forget_filter_chain();
+ preset_number = LZMA_PRESET_DEFAULT;
+
+ string_to_filter_used = true;
+
+ // Include LZMA_STR_ALL_FILTERS so this can be used with --format=raw.
+ str_to_filters(filter_str, 0, LZMA_STR_ALL_FILTERS);
+
+ // Set the filters_count to be the number of filters converted from
+ // the string.
+ for (filters_count = 0; filters[0][filters_count].id
+ != LZMA_VLI_UNKNOWN;
+ ++filters_count) ;
+
+ assert(filters_count > 0);
+ return;
+}
+
+
+extern void
+coder_add_block_filters(const char *str, size_t slot)
+{
+ // Free old filters first, if they were previously allocated.
+ if (filters_used_mask & (1U << slot))
+ lzma_filters_free(filters[slot], NULL);
+
+ str_to_filters(str, slot, 0);
+
+ filters_used_mask |= 1U << slot;
+}
+
+
tuklib_attr_noreturn
static void
memlimit_too_small(uint64_t memory_usage)
@@ -139,6 +232,71 @@ memlimit_too_small(uint64_t memory_usage)
}
+#ifdef HAVE_ENCODERS
+// For a given opt_block_list index, validate that the filter has been
+// set. If it has not been set, we must exit with error to avoid using
+// an uninitialized filter chain.
+static void
+validate_block_list_filter(const uint32_t filter_num)
+{
+ if (!(filters_used_mask & (1U << filter_num)))
+ message_fatal(_("filter chain %u used by --block-list but "
+ "not specified with --filters%u="),
+ (unsigned)filter_num, (unsigned)filter_num);
+}
+
+
+// Sets the memory usage for each filter chain. It will return the maximum
+// memory usage of all of the filter chains.
+static uint64_t
+filters_memusage_max(const lzma_mt *mt, bool encode)
+{
+ uint64_t max_memusage = 0;
+
+#ifdef MYTHREAD_ENABLED
+ // Copy multithreaded options to a temporary struct since the
+ // filters member needs to be changed
+ lzma_mt mt_local;
+ if (mt != NULL)
+ mt_local = *mt;
+#else
+ (void)mt;
+#endif
+
+ for (uint32_t i = 0; i < ARRAY_SIZE(filters); i++) {
+ if (!(filters_used_mask & (1U << i)))
+ continue;
+
+ uint64_t memusage = UINT64_MAX;
+#ifdef MYTHREAD_ENABLED
+ if (mt != NULL) {
+ mt_local.filters = filters[i];
+ memusage = lzma_stream_encoder_mt_memusage(&mt_local);
+ filter_memusages[i] = memusage;
+ }
+ else
+#endif
+
+ if (encode) {
+ memusage = lzma_raw_encoder_memusage(filters[i]);
+ filter_memusages[i] = memusage;
+ }
+
+#ifdef HAVE_DECODERS
+ else {
+ memusage = lzma_raw_decoder_memusage(filters[i]);
+ }
+#endif
+
+ if (memusage > max_memusage)
+ max_memusage = memusage;
+ }
+
+ return max_memusage;
+}
+
+#endif
+
extern void
coder_set_compression_settings(void)
{
@@ -147,6 +305,48 @@ coder_set_compression_settings(void)
assert(opt_format != FORMAT_LZIP);
#endif
+#ifdef HAVE_ENCODERS
+# ifdef MYTHREAD_ENABLED
+ // Represents the largest Block size specified with --block-list. This
+ // is needed to help reduce the Block size in the multithreaded encoder
+ // so memory is not wasted.
+ uint64_t max_block_list_size = 0;
+# endif
+
+ if (opt_block_list != NULL) {
+ // This mask tracks the filters actually referenced in
+ // --block-list. It is used to help remove bits from
+ // filters_used_mask when a filter chain was specified
+ // but never actually used.
+ uint32_t filters_ref_mask = 0;
+
+ for (uint32_t i = 0; opt_block_list[i].size != 0; i++) {
+ validate_block_list_filter(
+ opt_block_list[i].filters_index);
+
+ // Mark the current filter as referenced.
+ filters_ref_mask |= 1U <<
+ opt_block_list[i].filters_index;
+
+# ifdef MYTHREAD_ENABLED
+ if (opt_block_list[i].size > max_block_list_size)
+ max_block_list_size = opt_block_list[i].size;
+# endif
+ }
+
+ assert(filters_ref_mask != 0);
+ // Note: The filters that were initialized but not used do
+ // not free their options and do not have the filter
+ // IDs set to LZMA_VLI_UNKNOWN. Filter chains are not
+ // freed outside of debug mode and the default filter
+ // chain is never freed.
+ filters_used_mask = filters_ref_mask;
+ } else {
+ // Reset filters used mask in case --block-list is not
+ // used, but --filtersX is used.
+ filters_used_mask = 1;
+ }
+#endif
// The default check type is CRC64, but fallback to CRC32
// if CRC64 isn't supported by the copy of liblzma we are
// using. CRC32 is always supported.
@@ -159,7 +359,11 @@ coder_set_compression_settings(void)
// Options for LZMA1 or LZMA2 in case we are using a preset.
static lzma_options_lzma opt_lzma;
- if (filters_count == 0) {
+ // The first filter in the filters[] array is for the default
+ // filter chain.
+ lzma_filter *default_filters = filters[0];
+
+ if (filters_count == 0 && filters_used_mask & 1) {
// We are using a preset. This is not a good idea in raw mode
// except when playing around with things. Different versions
// of this software may use different options in presets, and
@@ -179,46 +383,59 @@ coder_set_compression_settings(void)
message_bug();
// Use LZMA2 except with --format=lzma we use LZMA1.
- filters[0].id = opt_format == FORMAT_LZMA
+ default_filters[0].id = opt_format == FORMAT_LZMA
? LZMA_FILTER_LZMA1 : LZMA_FILTER_LZMA2;
- filters[0].options = &opt_lzma;
+ default_filters[0].options = &opt_lzma;
+
filters_count = 1;
- }
- // Terminate the filter options array.
- filters[filters_count].id = LZMA_VLI_UNKNOWN;
+ // Terminate the filter options array.
+ default_filters[1].id = LZMA_VLI_UNKNOWN;
+ }
// If we are using the .lzma format, allow exactly one filter
- // which has to be LZMA1.
+ // which has to be LZMA1. There is no need to check if the default
+ // filter chain is being used since it can only be disabled if
+ // --block-list is used, which is incompatible with FORMAT_LZMA.
if (opt_format == FORMAT_LZMA && (filters_count != 1
- || filters[0].id != LZMA_FILTER_LZMA1))
+ || default_filters[0].id != LZMA_FILTER_LZMA1))
message_fatal(_("The .lzma format supports only "
"the LZMA1 filter"));
// If we are using the .xz format, make sure that there is no LZMA1
// filter to prevent LZMA_PROG_ERROR.
- if (opt_format == FORMAT_XZ)
+ if (opt_format == FORMAT_XZ && filters_used_mask & 1)
for (size_t i = 0; i < filters_count; ++i)
- if (filters[i].id == LZMA_FILTER_LZMA1)
+ if (default_filters[i].id == LZMA_FILTER_LZMA1)
message_fatal(_("LZMA1 cannot be used "
"with the .xz format"));
- // Print the selected filter chain.
- message_filters_show(V_DEBUG, filters);
+ if (filters_used_mask & 1) {
+ // Print the selected default filter chain.
+ message_filters_show(V_DEBUG, default_filters);
+ }
// The --flush-timeout option requires LZMA_SYNC_FLUSH support
- // from the filter chain. Currently threaded encoder doesn't support
- // LZMA_SYNC_FLUSH so single-threaded mode must be used.
+ // from the filter chain. Currently the threaded encoder doesn't
+ // support LZMA_SYNC_FLUSH so single-threaded mode must be used.
if (opt_mode == MODE_COMPRESS && opt_flush_timeout != 0) {
- for (size_t i = 0; i < filters_count; ++i) {
- switch (filters[i].id) {
- case LZMA_FILTER_LZMA2:
- case LZMA_FILTER_DELTA:
- break;
+ for (uint32_t i = 0; i < ARRAY_SIZE(filters); ++i) {
+ if (!(filters_used_mask & (1U << i)))
+ continue;
+
+ const lzma_filter *fc = filters[i];
+ for (size_t j = 0; fc[j].id != LZMA_VLI_UNKNOWN; j++) {
+ switch (fc[j].id) {
+ case LZMA_FILTER_LZMA2:
+ case LZMA_FILTER_DELTA:
+ break;
- default:
- message_fatal(_("The filter chain is "
- "incompatible with --flush-timeout"));
+ default:
+ message_fatal(_("Filter chain %u is "
+ "incompatible with "
+ "--flush-timeout"),
+ (unsigned)i);
+ }
}
}
@@ -229,11 +446,15 @@ coder_set_compression_settings(void)
}
}
- // Get the memory usage. Note that if --format=raw was used,
- // we can be decompressing.
+ // Get the memory usage and memory limit. The memory usage is the
+ // maximum of the default filters[] and any filters specified by
+ // --filtersX.
+ // Note that if --format=raw was used, we can be decompressing and
+ // do not need to account for any filter chains created
+ // with --filtersX.
//
- // If multithreaded .xz compression is done, this value will be
- // replaced.
+ // If multithreaded .xz compression is done, the memory limit
+ // will be replaced.
uint64_t memory_limit = hardware_memlimit_get(opt_mode);
uint64_t memory_usage = UINT64_MAX;
if (opt_mode == MODE_COMPRESS) {
@@ -242,10 +463,54 @@ coder_set_compression_settings(void)
if (opt_format == FORMAT_XZ && hardware_threads_is_mt()) {
memory_limit = hardware_memlimit_mtenc_get();
mt_options.threads = hardware_threads_get();
- mt_options.block_size = opt_block_size;
+
+ uint64_t block_size = opt_block_size;
+ // If opt_block_size is not set, find the maximum
+ // recommended Block size based on the filter chains
+ if (block_size == 0) {
+ for (uint32_t i = 0; i < ARRAY_SIZE(filters);
+ i++) {
+ if (!(filters_used_mask & (1U << i)))
+ continue;
+
+ uint64_t size = lzma_mt_block_size(
+ filters[i]);
+
+ // If this returns an error, then one
+ // of the filter chains in use is
+ // invalid, so there is no point in
+ // progressing further.
+ if (size == UINT64_MAX)
+ message_fatal(_("Unsupported "
+ "options in filter "
+ "chain %u"),
+ (unsigned)i);
+
+ if (size > block_size)
+ block_size = size;
+ }
+
+ // If the largest block size specified
+ // with --block-list is less than the
+ // recommended Block size, then it is a waste
+ // of RAM to use a larger Block size. It may
+ // even allow more threads to be used in some
+ // situations. If the special 0 Block size is
+ // used (encode all remaining data in 1 Block)
+ // then max_block_list_size will be set to
+ // UINT64_MAX, so the recommended Block size
+ // will always be used in this case.
+ if (max_block_list_size > 0
+ && max_block_list_size
+ < block_size)
+ block_size = max_block_list_size;
+ }
+
+ mt_options.block_size = block_size;
mt_options.check = check;
- memory_usage = lzma_stream_encoder_mt_memusage(
- &mt_options);
+
+ memory_usage = filters_memusage_max(
+ &mt_options, true);
if (memory_usage != UINT64_MAX)
message(V_DEBUG, _("Using up to %" PRIu32
" threads."),
@@ -253,12 +518,12 @@ coder_set_compression_settings(void)
} else
# endif
{
- memory_usage = lzma_raw_encoder_memusage(filters);
+ memory_usage = filters_memusage_max(NULL, true);
}
#endif
} else {
#ifdef HAVE_DECODERS
- memory_usage = lzma_raw_decoder_memusage(filters);
+ memory_usage = lzma_raw_decoder_memusage(default_filters);
#endif
}
@@ -273,7 +538,16 @@ coder_set_compression_settings(void)
message_mem_needed(V_DEBUG, memory_usage);
#ifdef HAVE_DECODERS
if (opt_mode == MODE_COMPRESS) {
- const uint64_t decmem = lzma_raw_decoder_memusage(filters);
+#ifdef HAVE_ENCODERS
+ const uint64_t decmem =
+ filters_memusage_max(NULL, false);
+#else
+ // If encoders are not enabled, then --block-list is never
+ // usable, so the other filter chains 1-9 can never be used.
+ // So there is no need to find the maximum decoder memory
+ // required in this case.
+ const uint64_t decmem = lzma_raw_decoder_memusage(filters[0]);
+#endif
if (decmem != UINT64_MAX)
message(V_DEBUG, _("Decompression will need "
"%s MiB of memory."), uint64_to_str(
@@ -300,8 +574,8 @@ coder_set_compression_settings(void)
// Reduce the number of threads by one and check
// the memory usage.
--mt_options.threads;
- memory_usage = lzma_stream_encoder_mt_memusage(
- &mt_options);
+ memory_usage = filters_memusage_max(
+ &mt_options, true);
if (memory_usage == UINT64_MAX)
message_bug();
@@ -353,7 +627,7 @@ coder_set_compression_settings(void)
// the multithreaded mode but the output
// is also different.
hardware_threads_set(1);
- memory_usage = lzma_raw_encoder_memusage(filters);
+ memory_usage = filters_memusage_max(NULL, true);
message(V_WARNING, _("Switching to single-threaded mode "
"to not exceed the memory usage limit of %s MiB"),
uint64_to_str(round_up_to_mib(memory_limit), 0));
@@ -368,55 +642,138 @@ coder_set_compression_settings(void)
if (!opt_auto_adjust)
memlimit_too_small(memory_usage);
- // Look for the last filter if it is LZMA2 or LZMA1, so we can make
- // it use less RAM. With other filters we don't know what to do.
- size_t i = 0;
- while (filters[i].id != LZMA_FILTER_LZMA2
- && filters[i].id != LZMA_FILTER_LZMA1) {
- if (filters[i].id == LZMA_VLI_UNKNOWN)
- memlimit_too_small(memory_usage);
-
- ++i;
+ // Decrease the dictionary size until we meet the memory usage limit.
+ // The struct is used to track data needed to correctly reduce the
+ // memory usage and report which filters were adjusted.
+ typedef struct {
+ // Pointer to the filter chain that needs to be reduced.
+ // NULL indicates that this filter chain was either never
+ // set or was never above the memory limit.
+ lzma_filter *filters;
+
+ // Original dictionary sizes are used to show how each
+ // filter's dictionary was reduced.
+ uint64_t orig_dict_size;
+
+ // Index of the LZMA filter in the filters member. We only
+ // adjust this filter's memusage because we don't know how
+ // to reduce the memory usage of the other filters.
+ uint32_t lzma_idx;
+
+ // Indicates if the filter's dictionary size needs to be
+ // reduced to fit under the memory limit (true) or if the
+ // filter chain is unused or is already under the memory
+ // limit (false).
+ bool reduce_dict_size;
+ } memusage_reduction_data;
+
+ memusage_reduction_data memusage_reduction[ARRAY_SIZE(filters)];
+
+ // Counter represents how many filter chains are above the memory
+ // limit.
+ size_t count = 0;
+
+ for (uint32_t i = 0; i < ARRAY_SIZE(filters); i++) {
+ // The short var name "r" will reduce the number of lines
+ // of code needed since less lines will stretch past 80
+ // characters.
+ memusage_reduction_data *r = &memusage_reduction[i];
+ r->filters = NULL;
+ r->reduce_dict_size = false;
+
+ if (!(filters_used_mask & (1U << i)))
+ continue;
+
+ for (uint32_t j = 0; filters[i][j].id != LZMA_VLI_UNKNOWN;
+ j++)
+ if ((filters[i][j].id == LZMA_FILTER_LZMA2
+ || filters[i][j].id
+ == LZMA_FILTER_LZMA1)
+ && filter_memusages[i]
+ > memory_limit) {
+ count++;
+ r->filters = filters[i];
+ r->lzma_idx = j;
+ r->reduce_dict_size = true;
+
+ lzma_options_lzma *opt = r->filters
+ [r->lzma_idx].options;
+ r->orig_dict_size = opt->dict_size;
+ opt->dict_size &= ~((UINT32_C(1) << 20) - 1);
+ }
}
- // Decrease the dictionary size until we meet the memory
- // usage limit. First round down to full mebibytes.
- lzma_options_lzma *opt = filters[i].options;
- const uint32_t orig_dict_size = opt->dict_size;
- opt->dict_size &= ~((UINT32_C(1) << 20) - 1);
- while (true) {
- // If it is below 1 MiB, auto-adjusting failed. We could be
- // more sophisticated and scale it down even more, but let's
- // see if many complain about this version.
- //
- // FIXME: Displays the scaled memory usage instead
- // of the original.
- if (opt->dict_size < (UINT32_C(1) << 20))
- memlimit_too_small(memory_usage);
+ // Loop until all filters use <= memory_limit, or exit.
+ while (count > 0) {
+ for (uint32_t i = 0; i < ARRAY_SIZE(memusage_reduction); i++) {
+ memusage_reduction_data *r = &memusage_reduction[i];
- memory_usage = lzma_raw_encoder_memusage(filters);
- if (memory_usage == UINT64_MAX)
- message_bug();
+ if (!r->reduce_dict_size)
+ continue;
- // Accept it if it is low enough.
- if (memory_usage <= memory_limit)
- break;
+ lzma_options_lzma *opt =
+ r->filters[r->lzma_idx].options;
+
+ // If it is below 1 MiB, auto-adjusting failed.
+ // We could be more sophisticated and scale it
+ // down even more, but nobody has complained so far.
+ if (opt->dict_size < (UINT32_C(1) << 20))
+ memlimit_too_small(memory_usage);
+
+ uint64_t filt_mem_usage =
+ lzma_raw_encoder_memusage(r->filters);
+
+ if (filt_mem_usage == UINT64_MAX)
+ message_bug();
- // Otherwise 1 MiB down and try again. I hope this
- // isn't too slow method for cases where the original
- // dict_size is very big.
- opt->dict_size -= UINT32_C(1) << 20;
+ if (filt_mem_usage < memory_limit) {
+ r->reduce_dict_size = false;
+ count--;
+ }
+ else {
+ opt->dict_size -= UINT32_C(1) << 20;
+ }
+ }
}
- // Tell the user that we decreased the dictionary size.
- message(V_WARNING, _("Adjusted LZMA%c dictionary size "
- "from %s MiB to %s MiB to not exceed "
- "the memory usage limit of %s MiB"),
- filters[i].id == LZMA_FILTER_LZMA2
- ? '2' : '1',
- uint64_to_str(orig_dict_size >> 20, 0),
- uint64_to_str(opt->dict_size >> 20, 1),
- uint64_to_str(round_up_to_mib(memory_limit), 2));
+ // Tell the user that we decreased the dictionary size for
+ // each filter that was adjusted.
+ for (uint32_t i = 0; i < ARRAY_SIZE(memusage_reduction); i++) {
+ memusage_reduction_data *r = &memusage_reduction[i];
+
+ // If the filters were never set, then the memory usage
+ // was never adjusted.
+ if (r->filters == NULL)
+ continue;
+
+ lzma_filter *filter_lzma = &(r->filters[r->lzma_idx]);
+ lzma_options_lzma *opt = filter_lzma->options;
+
+ // The first index is the default filter chain. The message
+ // should be slightly different if the default filter chain
+ // or if --filtersX was adjusted.
+ if (i == 0)
+ message(V_WARNING, _("Adjusted LZMA%c dictionary "
+ "size from %s MiB to %s MiB to not exceed the "
+ "memory usage limit of %s MiB"),
+ filter_lzma->id == LZMA_FILTER_LZMA2
+ ? '2' : '1',
+ uint64_to_str(r->orig_dict_size >> 20, 0),
+ uint64_to_str(opt->dict_size >> 20, 1),
+ uint64_to_str(round_up_to_mib(
+ memory_limit), 2));
+ else
+ message(V_WARNING, _("Adjusted LZMA%c dictionary size "
+ "for --filters%u from %s MiB to %s MiB to not "
+ "exceed the memory usage limit of %s MiB"),
+ filter_lzma->id == LZMA_FILTER_LZMA2
+ ? '2' : '1',
+ (unsigned)i,
+ uint64_to_str(r->orig_dict_size >> 20, 0),
+ uint64_to_str(opt->dict_size >> 20, 1),
+ uint64_to_str(round_up_to_mib(
+ memory_limit), 2));
+ }
#endif
return;
@@ -512,6 +869,13 @@ coder_init(file_pair *pair)
// These will be handled later in this function.
allow_trailing_input = false;
+ // Set the first filter chain. If the --block-list option is not
+ // used then use the default filter chain (filters[0]).
+ // Otherwise, use first filter chain from the block list.
+ lzma_filter *active_filters = opt_block_list == NULL
+ ? filters[0]
+ : filters[opt_block_list[0].filters_index];
+
if (opt_mode == MODE_COMPRESS) {
#ifdef HAVE_ENCODERS
switch (opt_format) {
@@ -522,17 +886,19 @@ coder_init(file_pair *pair)
case FORMAT_XZ:
# ifdef MYTHREAD_ENABLED
+ mt_options.filters = active_filters;
if (hardware_threads_is_mt())
ret = lzma_stream_encoder_mt(
&strm, &mt_options);
else
# endif
ret = lzma_stream_encoder(
- &strm, filters, check);
+ &strm, active_filters, check);
break;
case FORMAT_LZMA:
- ret = lzma_alone_encoder(&strm, filters[0].options);
+ ret = lzma_alone_encoder(&strm,
+ active_filters[0].options);
break;
# ifdef HAVE_LZIP_DECODER
@@ -544,7 +910,7 @@ coder_init(file_pair *pair)
# endif
case FORMAT_RAW:
- ret = lzma_raw_encoder(&strm, filters);
+ ret = lzma_raw_encoder(&strm, active_filters);
break;
}
#endif
@@ -668,7 +1034,7 @@ coder_init(file_pair *pair)
case FORMAT_RAW:
// Memory usage has already been checked in
// coder_set_compression_settings().
- ret = lzma_raw_decoder(&strm, filters);
+ ret = lzma_raw_decoder(&strm, active_filters);
break;
}
@@ -716,6 +1082,7 @@ coder_init(file_pair *pair)
}
+#ifdef HAVE_ENCODERS
/// Resolve conflicts between opt_block_size and opt_block_list in single
/// threaded mode. We want to default to opt_block_list, except when it is
/// larger than opt_block_size. If this is the case for the current Block
@@ -746,12 +1113,39 @@ split_block(uint64_t *block_remaining,
} else {
// The Block at *list_pos has been finished. Go to the next
- // entry in the list. If the end of the list has been reached,
- // reuse the size of the last Block.
- if (opt_block_list[*list_pos + 1] != 0)
+ // entry in the list. If the end of the list has been
+ // reached, reuse the size and filters of the last Block.
+ if (opt_block_list[*list_pos + 1].size != 0) {
++*list_pos;
- *block_remaining = opt_block_list[*list_pos];
+ // Update the filters if needed.
+ if (opt_block_list[*list_pos - 1].filters_index
+ != opt_block_list[*list_pos].filters_index) {
+ const uint32_t filter_idx = opt_block_list
+ [*list_pos].filters_index;
+ const lzma_filter *next = filters[filter_idx];
+ const lzma_ret ret = lzma_filters_update(
+ &strm, next);
+
+ if (ret != LZMA_OK) {
+ // This message is only possible if
+ // the filter chain has unsupported
+ // options since the filter chain is
+ // validated using
+ // lzma_raw_encoder_memusage() or
+ // lzma_stream_encoder_mt_memusage().
+ // Some options are not validated until
+ // the encoders are initialized.
+ message_fatal(
+ _("Error changing to "
+ "filter chain %u: %s"),
+ (unsigned)filter_idx,
+ message_strm(ret));
+ }
+ }
+ }
+
+ *block_remaining = opt_block_list[*list_pos].size;
// If in single-threaded mode, split up the Block if needed.
// This is not needed in multi-threaded mode because liblzma
@@ -764,6 +1158,7 @@ split_block(uint64_t *block_remaining,
}
}
}
+#endif
static bool
@@ -796,6 +1191,7 @@ coder_normal(file_pair *pair)
// Assume that something goes wrong.
bool success = false;
+#ifdef HAVE_ENCODERS
// block_remaining indicates how many input bytes to encode before
// finishing the current .xz Block. The Block size is set with
// --block-size=SIZE and --block-list. They have an effect only when
@@ -829,15 +1225,18 @@ coder_normal(file_pair *pair)
// output is still not identical because in single-threaded
// mode the size info isn't written into Block Headers.
if (opt_block_list != NULL) {
- if (block_remaining < opt_block_list[list_pos]) {
+ if (block_remaining < opt_block_list[list_pos].size) {
assert(!hardware_threads_is_mt());
- next_block_remaining = opt_block_list[list_pos]
+ next_block_remaining =
+ opt_block_list[list_pos].size
- block_remaining;
} else {
- block_remaining = opt_block_list[list_pos];
+ block_remaining =
+ opt_block_list[list_pos].size;
}
}
}
+#endif
strm.next_out = out_buf.u8;
strm.avail_out = IO_BUFFER_SIZE;
@@ -847,17 +1246,22 @@ coder_normal(file_pair *pair)
// flushing or finishing.
if (strm.avail_in == 0 && action == LZMA_RUN) {
strm.next_in = in_buf.u8;
- strm.avail_in = io_read(pair, &in_buf,
- my_min(block_remaining,
- IO_BUFFER_SIZE));
+#ifdef HAVE_ENCODERS
+ const size_t read_size = my_min(block_remaining,
+ IO_BUFFER_SIZE);
+#else
+ const size_t read_size = IO_BUFFER_SIZE;
+#endif
+ strm.avail_in = io_read(pair, &in_buf, read_size);
if (strm.avail_in == SIZE_MAX)
break;
if (pair->src_eof) {
action = LZMA_FINISH;
-
- } else if (block_remaining != UINT64_MAX) {
+ }
+#ifdef HAVE_ENCODERS
+ else if (block_remaining != UINT64_MAX) {
// Start a new Block after every
// opt_block_size bytes of input.
block_remaining -= strm.avail_in;
@@ -867,17 +1271,18 @@ coder_normal(file_pair *pair)
if (action == LZMA_RUN && pair->flush_needed)
action = LZMA_SYNC_FLUSH;
+#endif
}
// Let liblzma do the actual work.
ret = lzma_code(&strm, action);
// Write out if the output buffer became full.
- if (strm.avail_out == 0) {
+ if (strm.avail_out == 0)
if (coder_write_output(pair))
break;
- }
+#ifdef HAVE_ENCODERS
if (ret == LZMA_STREAM_END && (action == LZMA_SYNC_FLUSH
|| action == LZMA_FULL_BARRIER)) {
if (action == LZMA_SYNC_FLUSH) {
@@ -907,8 +1312,9 @@ coder_normal(file_pair *pair)
// Start a new Block after LZMA_FULL_FLUSH or continue
// the same block after LZMA_SYNC_FLUSH.
action = LZMA_RUN;
-
- } else if (ret != LZMA_OK) {
+ } else
+#endif
+ if (ret != LZMA_OK) {
// Determine if the return value indicates that we
// won't continue coding. LZMA_NO_CHECK would be
// here too if LZMA_TELL_ANY_CHECK was used.
@@ -1103,6 +1509,16 @@ coder_run(const char *filename)
extern void
coder_free(void)
{
+ // Free starting from the second filter chain since the default
+ // filter chain may have its options set from a static variable
+ // in coder_set_compression_settings(). Since this is only run in
+ // debug mode and will be freed when the process ends anyway, we
+ // don't worry about freeing it.
+ for (uint32_t i = 1; i < ARRAY_SIZE(filters); i++) {
+ if (filters_used_mask & (1U << i))
+ lzma_filters_free(filters[i], NULL);
+ }
+
lzma_end(&strm);
return;
}
diff --git a/src/xz/coder.h b/src/xz/coder.h
index b4f43a2bf21c..a7feeb9cadb1 100644
--- a/src/xz/coder.h
+++ b/src/xz/coder.h
@@ -1,12 +1,12 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file coder.h
/// \brief Compresses or uncompresses a file
//
-// Author: Lasse Collin
-//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
+// Authors: Lasse Collin
+// Jia Tan
//
///////////////////////////////////////////////////////////////////////////////
@@ -30,6 +30,18 @@ enum format_type {
};
+/// Simple struct to track Block metadata specified through the
+/// --block-list option.
+typedef struct {
+ /// Uncompressed size of the Block
+ uint64_t size;
+
+ /// Index into the filters[] representing the filter chain to use
+ /// for this Block.
+ uint32_t filters_index;
+} block_list_entry;
+
+
/// Operation mode of the command line tool. This is set in args.c and read
/// in several files.
extern enum operation_mode opt_mode;
@@ -50,9 +62,8 @@ extern bool opt_single_stream;
/// of input. This has an effect only when compressing to the .xz format.
extern uint64_t opt_block_size;
-/// This is non-NULL if --block-list was used. This contains the Block sizes
-/// as an array that is terminated with 0.
-extern uint64_t *opt_block_list;
+/// List of block size and filter chain pointer pairs.
+extern block_list_entry *opt_block_list;
/// Set the integrity check type used when compressing
extern void coder_set_check(lzma_check check);
@@ -77,3 +88,9 @@ extern void coder_run(const char *filename);
/// Free the memory allocated for the coder and kill the worker threads.
extern void coder_free(void);
#endif
+
+/// Create filter chain from string
+extern void coder_add_filters_from_str(const char *filter_str);
+
+/// Add or overwrite a filter that can be used by the block-list.
+extern void coder_add_block_filters(const char *str, size_t slot);
diff --git a/src/xz/file_io.c b/src/xz/file_io.c
index 28280293ef39..678a9a5ca860 100644
--- a/src/xz/file_io.c
+++ b/src/xz/file_io.c
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file file_io.c
@@ -5,9 +7,6 @@
//
// Author: Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
#include "private.h"
@@ -29,15 +28,33 @@ static bool warn_fchown;
# include <utime.h>
#endif
-#ifdef HAVE_CAPSICUM
-# ifdef HAVE_SYS_CAPSICUM_H
-# include <sys/capsicum.h>
+#include "tuklib_open_stdxxx.h"
+
+#ifdef _MSC_VER
+# ifdef _WIN64
+ typedef __int64 ssize_t;
# else
-# include <sys/capability.h>
+ typedef int ssize_t;
# endif
-#endif
-#include "tuklib_open_stdxxx.h"
+ typedef int mode_t;
+# define S_IRUSR _S_IREAD
+# define S_IWUSR _S_IWRITE
+
+# define setmode _setmode
+# define open _open
+# define close _close
+# define lseek _lseeki64
+# define unlink _unlink
+
+ // The casts are to silence warnings.
+ // The sizes are known to be small enough.
+# define read(fd, buf, size) _read(fd, buf, (unsigned int)(size))
+# define write(fd, buf, size) _write(fd, buf, (unsigned int)(size))
+
+# define S_ISDIR(m) (((m) & _S_IFMT) == _S_IFDIR)
+# define S_ISREG(m) (((m) & _S_IFMT) == _S_IFREG)
+#endif
#ifndef O_BINARY
# define O_BINARY 0
@@ -66,11 +83,6 @@ typedef enum {
/// If true, try to create sparse files when decompressing.
static bool try_sparse = true;
-#ifdef ENABLE_SANDBOX
-/// True if the conditions for sandboxing (described in main()) have been met.
-static bool sandbox_allowed = false;
-#endif
-
#ifndef TUKLIB_DOSLIKE
/// File status flags of standard input. This is used by io_open_src()
/// and io_close_src().
@@ -155,105 +167,6 @@ io_no_sparse(void)
}
-#ifdef ENABLE_SANDBOX
-extern void
-io_allow_sandbox(void)
-{
- sandbox_allowed = true;
- return;
-}
-
-
-/// Enables operating-system-specific sandbox if it is possible.
-/// src_fd is the file descriptor of the input file.
-static void
-io_sandbox_enter(int src_fd)
-{
- if (!sandbox_allowed) {
- // This message is more often annoying than useful so
- // it's commented out. It can be useful when developing
- // the sandboxing code.
- //message(V_DEBUG, _("Sandbox is disabled due "
- // "to incompatible command line arguments"));
- return;
- }
-
- const char dummy_str[] = "x";
-
- // Try to ensure that both libc and xz locale files have been
- // loaded when NLS is enabled.
- snprintf(NULL, 0, "%s%s", _(dummy_str), strerror(EINVAL));
-
- // Try to ensure that iconv data files needed for handling multibyte
- // characters have been loaded. This is needed at least with glibc.
- tuklib_mbstr_width(dummy_str, NULL);
-
-#ifdef HAVE_CAPSICUM
- // Capsicum needs FreeBSD 10.0 or later.
- cap_rights_t rights;
-
- if (cap_enter())
- goto error;
-
- if (cap_rights_limit(src_fd, cap_rights_init(&rights,
- CAP_EVENT, CAP_FCNTL, CAP_LOOKUP, CAP_READ, CAP_SEEK)))
- goto error;
-
- if (src_fd != STDIN_FILENO && cap_rights_limit(
- STDIN_FILENO, cap_rights_clear(&rights)))
- goto error;
-
- if (cap_rights_limit(STDOUT_FILENO, cap_rights_init(&rights,
- CAP_EVENT, CAP_FCNTL, CAP_FSTAT, CAP_LOOKUP,
- CAP_WRITE, CAP_SEEK)))
- goto error;
-
- if (cap_rights_limit(STDERR_FILENO, cap_rights_init(&rights,
- CAP_WRITE)))
- goto error;
-
- if (cap_rights_limit(user_abort_pipe[0], cap_rights_init(&rights,
- CAP_EVENT)))
- goto error;
-
- if (cap_rights_limit(user_abort_pipe[1], cap_rights_init(&rights,
- CAP_WRITE)))
- goto error;
-
-#elif defined(HAVE_PLEDGE)
- // pledge() was introduced in OpenBSD 5.9.
- //
- // main() unconditionally calls pledge() with fairly relaxed
- // promises which work in all situations. Here we make the
- // sandbox more strict.
- if (pledge("stdio", ""))
- goto error;
-
- (void)src_fd;
-
-#else
-# error ENABLE_SANDBOX is defined but no sandboxing method was found.
-#endif
-
- // This message is annoying in xz -lvv.
- //message(V_DEBUG, _("Sandbox was successfully enabled"));
- return;
-
-error:
-#ifdef HAVE_CAPSICUM
- // If a kernel is configured without capability mode support or
- // used in an emulator that does not implement the capability
- // system calls, then the Capsicum system calls will fail and set
- // errno to ENOSYS. In that case xz will silently run without
- // the sandbox.
- if (errno == ENOSYS)
- return;
-#endif
- message_fatal(_("Failed to enable the sandbox"));
-}
-#endif // ENABLE_SANDBOX
-
-
#ifndef TUKLIB_DOSLIKE
/// \brief Waits for input or output to become available or for a signal
///
@@ -407,7 +320,7 @@ io_copy_attrs(const file_pair *pair)
message_warning(_("%s: Cannot set the file group: %s"),
pair->dest_name, strerror(errno));
// We can still safely copy some additional permissions:
- // `group' must be at least as strict as `other' and
+ // 'group' must be at least as strict as 'other' and
// also vice versa.
//
// NOTE: After this, the owner of the source file may
@@ -809,7 +722,8 @@ io_open_src(const char *src_name)
#ifdef ENABLE_SANDBOX
if (!error)
- io_sandbox_enter(pair.src_fd);
+ sandbox_enable_strict_if_allowed(pair.src_fd,
+ user_abort_pipe[0], user_abort_pipe[1]);
#endif
return error ? NULL : &pair;
diff --git a/src/xz/file_io.h b/src/xz/file_io.h
index 6992efa4f86c..ae7e2f38f520 100644
--- a/src/xz/file_io.h
+++ b/src/xz/file_io.h
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file file_io.h
@@ -5,9 +7,6 @@
//
// Author: Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
// Some systems have suboptimal BUFSIZ. Use a bit bigger value on them.
@@ -18,6 +17,16 @@
# define IO_BUFFER_SIZE (BUFSIZ & ~7U)
#endif
+#ifdef _MSC_VER
+ // The first one renames both "struct stat" -> "struct _stat64"
+ // and stat() -> _stat64(). The documentation mentions only
+ // "struct __stat64", not "struct _stat64", but the latter
+ // works too.
+# define stat _stat64
+# define fstat _fstat64
+# define off_t __int64
+#endif
+
/// is_sparse() accesses the buffer as uint64_t for maximum speed.
/// The u32 and u64 members must only be access through this union
@@ -90,12 +99,6 @@ extern void io_write_to_user_abort_pipe(void);
extern void io_no_sparse(void);
-#ifdef ENABLE_SANDBOX
-/// \brief main() calls this if conditions for sandboxing have been met.
-extern void io_allow_sandbox(void);
-#endif
-
-
/// \brief Open the source file
extern file_pair *io_open_src(const char *src_name);
diff --git a/src/xz/hardware.c b/src/xz/hardware.c
index c6948821862a..952652fecb8d 100644
--- a/src/xz/hardware.c
+++ b/src/xz/hardware.c
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file hardware.c
@@ -5,9 +7,6 @@
//
// Author: Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
#include "private.h"
@@ -15,7 +14,7 @@
/// Maximum number of worker threads. This can be set with
/// the --threads=NUM command line option.
-static uint32_t threads_max = 1;
+static uint32_t threads_max;
/// True when the number of threads is automatically determined based
/// on the available hardware threads.
@@ -334,5 +333,9 @@ hardware_init(void)
memlimit_mt_default = mem_ceiling;
#endif
+ // Enable threaded mode by default. xz 5.4.x and older
+ // used single-threaded mode by default.
+ hardware_threads_set(0);
+
return;
}
diff --git a/src/xz/hardware.h b/src/xz/hardware.h
index a67b26efecb8..25b351e32b19 100644
--- a/src/xz/hardware.h
+++ b/src/xz/hardware.h
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file hardware.h
@@ -5,9 +7,6 @@
//
// Author: Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
/// Initialize some hardware-specific variables, which are needed by other
diff --git a/src/xz/list.c b/src/xz/list.c
index 86c3a762f560..ca9cf03e85b0 100644
--- a/src/xz/list.c
+++ b/src/xz/list.c
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file list.c
@@ -5,9 +7,6 @@
//
// Author: Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
#include "private.h"
@@ -544,11 +543,21 @@ parse_block_header(file_pair *pair, const lzma_index_iter *iter,
xfi->memusage_max = bhi->memusage;
// Determine the minimum XZ Utils version that supports this Block.
+ // - RISC-V filter needs 5.6.0.
//
// - ARM64 filter needs 5.4.0.
//
// - 5.0.0 doesn't support empty LZMA2 streams and thus empty
// Blocks that use LZMA2. This decoder bug was fixed in 5.0.2.
+ if (xfi->min_version < 50060002U) {
+ for (size_t i = 0; filters[i].id != LZMA_VLI_UNKNOWN; ++i) {
+ if (filters[i].id == LZMA_FILTER_RISCV) {
+ xfi->min_version = 50060002U;
+ break;
+ }
+ }
+ }
+
if (xfi->min_version < 50040002U) {
for (size_t i = 0; filters[i].id != LZMA_VLI_UNKNOWN; ++i) {
if (filters[i].id == LZMA_FILTER_ARM64) {
@@ -1266,10 +1275,22 @@ list_totals(void)
extern void
list_file(const char *filename)
{
- if (opt_format != FORMAT_XZ && opt_format != FORMAT_AUTO)
- message_fatal(_("--list works only on .xz files "
+ if (opt_format != FORMAT_XZ && opt_format != FORMAT_AUTO) {
+ // The 'lzmainfo' message is printed only when --format=lzma
+ // is used (it is implied if using "lzma" as the command
+ // name). Thus instead of using message_fatal(), print
+ // the messages separately and then call tuklib_exit()
+ // like message_fatal() does.
+ message(V_ERROR, _("--list works only on .xz files "
"(--format=xz or --format=auto)"));
+ if (opt_format == FORMAT_LZMA)
+ message(V_ERROR,
+ _("Try 'lzmainfo' with .lzma files."));
+
+ tuklib_exit(E_ERROR, E_ERROR, false);
+ }
+
message_filename(filename);
if (filename == stdin_filename) {
diff --git a/src/xz/list.h b/src/xz/list.h
index a4c6ec7dc429..805880de4095 100644
--- a/src/xz/list.h
+++ b/src/xz/list.h
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file list.h
@@ -5,9 +7,6 @@
//
// Author: Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
/// \brief List information about the given .xz file
diff --git a/src/xz/main.c b/src/xz/main.c
index c9c3deca2bf8..71b5ef7b7001 100644
--- a/src/xz/main.c
+++ b/src/xz/main.c
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file main.c
@@ -5,14 +7,12 @@
//
// Author: Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
#include "private.h"
#include <ctype.h>
+
/// Exit status to use. This can be changed with set_exit_status().
static enum exit_status_type exit_status = E_SUCCESS;
@@ -119,8 +119,8 @@ read_name(const args_info *args)
// newlines.
message_error(_("%s: Null character found when "
"reading filenames; maybe you meant "
- "to use `--files0' instead "
- "of `--files'?"), args->files_name);
+ "to use '--files0' instead "
+ "of '--files'?"), args->files_name);
return NULL;
}
@@ -142,35 +142,38 @@ read_name(const args_info *args)
int
main(int argc, char **argv)
{
-#ifdef HAVE_PLEDGE
- // OpenBSD's pledge(2) sandbox
- //
- // Unconditionally enable sandboxing with fairly relaxed promises.
- // This is still way better than having no sandbox at all. :-)
- // More strict promises will be made later in file_io.c if possible.
- if (pledge("stdio rpath wpath cpath fattr", "")) {
- // Don't translate the string or use message_fatal() as
- // those haven't been initialized yet.
- fprintf(stderr, "%s: Failed to enable the sandbox\n", argv[0]);
- return E_ERROR;
- }
-#endif
-
#if defined(_WIN32) && !defined(__CYGWIN__)
InitializeCriticalSection(&exit_status_cs);
#endif
- // Set up the progname variable.
+ // Set up the progname variable needed for messages.
tuklib_progname_init(argv);
// Initialize the file I/O. This makes sure that
// stdin, stdout, and stderr are something valid.
+ // This must be done before we might open any files
+ // even indirectly like locale and gettext initializations.
io_init();
+#ifdef ENABLE_SANDBOX
+ // Enable such sandboxing that can always be enabled.
+ // This requires that progname has been set up.
+ // It's also good that io_init() has been called because it
+ // might need to do things that the initial sandbox won't allow.
+ // Otherwise this should be called as early as possible.
+ //
+ // NOTE: Calling this before tuklib_gettext_init() means that
+ // translated error message won't be available if sandbox
+ // initialization fails. However, sandbox_init() shouldn't
+ // fail and this order simply feels better.
+ sandbox_init();
+#endif
+
// Set up the locale and message translations.
tuklib_gettext_init(PACKAGE, LOCALEDIR);
- // Initialize handling of error/warning/other messages.
+ // Initialize progress message handling. It's not always needed
+ // but it's simpler to do this unconditionally.
message_init();
// Set hardware-dependent default values. These can be overridden
@@ -220,21 +223,41 @@ main(int argc, char **argv)
signals_init();
#ifdef ENABLE_SANDBOX
- // Set a flag that sandboxing is allowed if all these are true:
- // - --files or --files0 wasn't used.
- // - There is exactly one input file or we are reading from stdin.
- // - We won't create any files: output goes to stdout or --test
- // or --list was used. Note that --test implies opt_stdout = true
- // but --list doesn't.
+ // Read-only sandbox can be enabled if we won't create or delete
+ // any files:
//
- // This is obviously not ideal but it was easy to implement and
- // it covers the most common use cases.
+ // - --stdout, --test, or --list was used. Note that --test
+ // implies opt_stdout = true but --list doesn't.
//
- // TODO: Make sandboxing work for other situations too.
- if (args.files_name == NULL && args.arg_count == 1
- && (opt_stdout || strcmp("-", args.arg_names[0]) == 0
- || opt_mode == MODE_LIST))
- io_allow_sandbox();
+ // - Output goes to stdout because --files or --files0 wasn't used
+ // and no arguments were given on the command line or the
+ // arguments are all "-" (indicating standard input).
+ bool to_stdout_only = opt_stdout || opt_mode == MODE_LIST;
+ if (!to_stdout_only && args.files_name == NULL) {
+ // If all of the filenames provided are "-" (more than one
+ // "-" could be specified), then we are only going to be
+ // writing to standard output. Note that if no filename args
+ // were provided, args.c puts a single "-" in arg_names[0].
+ to_stdout_only = true;
+
+ for (unsigned i = 0; i < args.arg_count; ++i) {
+ if (strcmp("-", args.arg_names[i]) != 0) {
+ to_stdout_only = false;
+ break;
+ }
+ }
+ }
+
+ if (to_stdout_only) {
+ sandbox_enable_read_only();
+
+ // Allow strict sandboxing if we are processing exactly one
+ // file to standard output. This requires that --files or
+ // --files0 wasn't specified (an unknown number of filenames
+ // could be provided that way).
+ if (args.files_name == NULL && args.arg_count == 1)
+ sandbox_allow_strict();
+ }
#endif
// coder_run() handles compression, decompression, and testing.
diff --git a/src/xz/main.h b/src/xz/main.h
index 323f2f7d09cd..a8a1b457760a 100644
--- a/src/xz/main.h
+++ b/src/xz/main.h
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file main.h
@@ -5,9 +7,6 @@
//
// Author: Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
/// Possible exit status values. These are the same as used by gzip and bzip2.
diff --git a/src/xz/message.c b/src/xz/message.c
index abf30adcc26c..deafdb438320 100644
--- a/src/xz/message.c
+++ b/src/xz/message.c
@@ -1,12 +1,12 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file message.c
/// \brief Printing messages
//
-// Author: Lasse Collin
-//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
+// Authors: Lasse Collin
+// Jia Tan
//
///////////////////////////////////////////////////////////////////////////////
@@ -42,7 +42,7 @@ static bool current_filename_printed = false;
/// True if we should print progress indicator and update it automatically
/// if also verbose >= V_VERBOSE.
-static bool progress_automatic;
+static bool progress_automatic = false;
/// True if message_progress_start() has been called but
/// message_progress_end() hasn't been called yet.
@@ -119,26 +119,7 @@ message_init(void)
// exception, even if --verbose was not used, user can send SIGALRM
// to make us print progress information once without automatic
// updating.
- progress_automatic = isatty(STDERR_FILENO);
-
- // Commented out because COLUMNS is rarely exported to environment.
- // Most users have at least 80 columns anyway, let's think something
- // fancy here if enough people complain.
-/*
- if (progress_automatic) {
- // stderr is a terminal. Check the COLUMNS environment
- // variable to see if the terminal is wide enough. If COLUMNS
- // doesn't exist or it has some unparsable value, we assume
- // that the terminal is wide enough.
- const char *columns_str = getenv("COLUMNS");
- if (columns_str != NULL) {
- char *endptr;
- const long columns = strtol(columns_str, &endptr, 10);
- if (*endptr != '\0' || columns < 80)
- progress_automatic = false;
- }
- }
-*/
+ progress_automatic = is_tty(STDERR_FILENO);
#ifdef SIGALRM
// Establish the signal handlers which set a flag to tell us that
@@ -932,7 +913,7 @@ message_try_help(void)
{
// Print this with V_WARNING instead of V_ERROR to prevent it from
// showing up when --quiet has been specified.
- message(V_WARNING, _("Try `%s --help' for more information."),
+ message(V_WARNING, _("Try '%s --help' for more information."),
progname);
return;
}
@@ -994,7 +975,7 @@ message_help(bool long_help)
" ignore possible remaining input data"));
puts(_(
" --no-sparse do not create sparse files when decompressing\n"
-" -S, --suffix=.SUF use the suffix `.SUF' on compressed files\n"
+" -S, --suffix=.SUF use the suffix '.SUF' on compressed files\n"
" --files[=FILE] read filenames to process from FILE; if FILE is\n"
" omitted, filenames are read from the standard input;\n"
" filenames must be terminated with the newline character\n"
@@ -1005,9 +986,9 @@ message_help(bool long_help)
puts(_("\n Basic file format and compression options:\n"));
puts(_(
" -F, --format=FMT file format to encode or decode; possible values are\n"
-" `auto' (default), `xz', `lzma', `lzip', and `raw'\n"
-" -C, --check=CHECK integrity check type: `none' (use with caution),\n"
-" `crc32', `crc64' (default), or `sha256'"));
+" 'auto' (default), 'xz', 'lzma', 'lzip', and 'raw'\n"
+" -C, --check=CHECK integrity check type: 'none' (use with caution),\n"
+" 'crc32', 'crc64' (default), or 'sha256'"));
puts(_(
" --ignore-check don't verify the integrity check when decompressing"));
}
@@ -1021,8 +1002,8 @@ message_help(bool long_help)
" does not affect decompressor memory requirements"));
puts(_(
-" -T, --threads=NUM use at most NUM threads; the default is 1; set to 0\n"
-" to use as many threads as there are processor cores"));
+" -T, --threads=NUM use at most NUM threads; the default is 0 which uses\n"
+" as many threads as there are processor cores"));
if (long_help) {
puts(_(
@@ -1030,9 +1011,11 @@ message_help(bool long_help)
" start a new .xz block after every SIZE bytes of input;\n"
" use this to set the block size for threaded compression"));
puts(_(
-" --block-list=SIZES\n"
+" --block-list=BLOCKS\n"
" start a new .xz block after the given comma-separated\n"
-" intervals of uncompressed data"));
+" intervals of uncompressed data; optionally, specify a\n"
+" filter chain number (0-9) followed by a ':' before the\n"
+" uncompressed data size"));
puts(_(
" --flush-timeout=TIMEOUT\n"
" when compressing, if more than TIMEOUT milliseconds has\n"
@@ -1057,6 +1040,23 @@ message_help(bool long_help)
puts(_(
"\n Custom filter chain for compression (alternative for using presets):"));
+ puts(_(
+"\n"
+" --filters=FILTERS set the filter chain using the liblzma filter string\n"
+" syntax; use --filters-help for more information"
+ ));
+
+ puts(_(
+" --filters1=FILTERS ... --filters9=FILTERS\n"
+" set additional filter chains using the liblzma filter\n"
+" string syntax to use with --block-list"
+ ));
+
+ puts(_(
+" --filters-help display more information about the liblzma filter string\n"
+" syntax and exit."
+ ));
+
#if defined(HAVE_ENCODER_LZMA1) || defined(HAVE_DECODER_LZMA1) \
|| defined(HAVE_ENCODER_LZMA2) || defined(HAVE_DECODER_LZMA2)
// TRANSLATORS: The word "literal" in "literal context bits"
@@ -1087,6 +1087,7 @@ message_help(bool long_help)
" --powerpc[=OPTS] PowerPC BCJ filter (big endian only)\n"
" --ia64[=OPTS] IA-64 (Itanium) BCJ filter\n"
" --sparc[=OPTS] SPARC BCJ filter\n"
+" --riscv[=OPTS] RISC-V BCJ filter\n"
" Valid OPTS for all BCJ filters:\n"
" start=NUM start offset for conversions (default=0)"));
@@ -1144,3 +1145,28 @@ message_help(bool long_help)
tuklib_exit(E_SUCCESS, E_ERROR, verbosity != V_SILENT);
}
+
+
+extern void
+message_filters_help(void)
+{
+ char *encoder_options;
+ if (lzma_str_list_filters(&encoder_options, LZMA_VLI_UNKNOWN,
+ LZMA_STR_ENCODER, NULL) != LZMA_OK)
+ message_bug();
+
+ if (!opt_robot) {
+ puts(_(
+"Filter chains are set using the --filters=FILTERS or\n"
+"--filters1=FILTERS ... --filters9=FILTERS options. Each filter in the chain\n"
+"can be separated by spaces or '--'. Alternatively a preset <0-9>[e] can be\n"
+"specified instead of a filter chain.\n"
+ ));
+
+ puts(_("The supported filters and their options are:"));
+ }
+
+ puts(encoder_options);
+
+ tuklib_exit(E_SUCCESS, E_ERROR, verbosity != V_SILENT);
+}
diff --git a/src/xz/message.h b/src/xz/message.h
index f608ec75dffa..1734f0eaab68 100644
--- a/src/xz/message.h
+++ b/src/xz/message.h
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file message.h
@@ -5,9 +7,6 @@
//
// Author: Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
/// Verbosity levels
@@ -24,7 +23,10 @@ enum message_verbosity {
extern const int message_progress_sigs[];
-/// \brief Initializes the message functions
+/// \brief Initializes the progress message functions
+///
+/// message_fatal() and such can be called even before message_init()
+/// has been called.
///
/// If an error occurs, this function doesn't return.
///
@@ -111,6 +113,11 @@ tuklib_attr_noreturn
extern void message_help(bool long_help);
+/// Prints a help message specifically for using the --filters and
+/// --filtersX command line options.
+extern void message_filters_help(void);
+
+
/// \brief Set the total number of files to be processed
///
/// Standard input is counted as a file here. This is used when printing
diff --git a/src/xz/mytime.c b/src/xz/mytime.c
index 7e8a074961f4..7d9a27d58b56 100644
--- a/src/xz/mytime.c
+++ b/src/xz/mytime.c
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file mytime.c
@@ -5,14 +7,14 @@
//
// Author: Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
#include "private.h"
-#if defined(HAVE_CLOCK_GETTIME) && defined(HAVE_CLOCK_MONOTONIC)
+#if defined(MYTHREAD_VISTA) || defined(_MSC_VER)
+ // Nothing
+#elif defined(HAVE_CLOCK_GETTIME) \
+ && (!defined(__MINGW32__) || defined(MYTHREAD_POSIX))
# include <time.h>
#else
# include <sys/time.h>
@@ -20,7 +22,22 @@
uint64_t opt_flush_timeout = 0;
+// start_time holds the time when the (de)compression was started.
+// It's from mytime_now() and thus only useful for calculating relative
+// time differences (elapsed time). start_time is initialized by calling
+// mytime_set_start_time() and modified by mytime_sigtstp_handler().
+//
+// When mytime_sigtstp_handler() is used, start_time is made volatile.
+// I'm not sure if that is really required since access to it is guarded
+// by signals_block()/signals_unblock() since accessing an uint64_t isn't
+// atomic on all systems. But since the variable isn't accessed very
+// frequently making it volatile doesn't hurt.
+#ifdef USE_SIGTSTP_HANDLER
+static volatile uint64_t start_time;
+#else
static uint64_t start_time;
+#endif
+
static uint64_t next_flush;
@@ -30,16 +47,41 @@ static uint64_t next_flush;
static uint64_t
mytime_now(void)
{
-#if defined(HAVE_CLOCK_GETTIME) && defined(HAVE_CLOCK_MONOTONIC)
+#if defined(MYTHREAD_VISTA) || defined(_MSC_VER)
+ // Since there is no SIGALRM on Windows, this function gets
+ // called frequently when the progress indicator is in use.
+ // Progress indicator doesn't need high-resolution time.
+ // GetTickCount64() has very low overhead but needs at least WinVista.
+ //
+ // MinGW-w64 provides the POSIX functions clock_gettime() and
+ // gettimeofday() in a manner that allow xz to run on older
+ // than WinVista. If the threading method needs WinVista anyway,
+ // there's no reason to avoid a WinVista API here either.
+ return GetTickCount64();
+
+#elif defined(HAVE_CLOCK_GETTIME) \
+ && (!defined(__MINGW32__) || defined(MYTHREAD_POSIX))
+ // MinGW-w64: clock_gettime() is defined in winpthreads but we need
+ // nothing else from winpthreads (unless, for some odd reason, POSIX
+ // threading has been selected). By avoiding clock_gettime(), we
+ // avoid the dependency on libwinpthread-1.dll or the need to link
+ // against the static version. The downside is that the fallback
+ // method, gettimeofday(), doesn't provide monotonic time.
+ struct timespec tv;
+
+# ifdef HAVE_CLOCK_MONOTONIC
// If CLOCK_MONOTONIC was available at compile time but for some
// reason isn't at runtime, fallback to CLOCK_REALTIME which
// according to POSIX is mandatory for all implementations.
static clockid_t clk_id = CLOCK_MONOTONIC;
- struct timespec tv;
while (clock_gettime(clk_id, &tv))
clk_id = CLOCK_REALTIME;
+# else
+ clock_gettime(CLOCK_REALTIME, &tv);
+# endif
return (uint64_t)tv.tv_sec * 1000 + (uint64_t)(tv.tv_nsec / 1000000);
+
#else
struct timeval tv;
gettimeofday(&tv, NULL);
@@ -48,10 +90,49 @@ mytime_now(void)
}
+#ifdef USE_SIGTSTP_HANDLER
+extern void
+mytime_sigtstp_handler(int sig lzma_attribute((__unused__)))
+{
+ // Measure how long the process stays in the stopped state and add
+ // that amount to start_time. This way the the progress indicator
+ // won't count the stopped time as elapsed time and the estimated
+ // remaining time won't be confused by the time spent in the
+ // stopped state.
+ //
+ // FIXME? Is raising SIGSTOP the correct thing to do? POSIX.1-2017
+ // says that orphan processes shouldn't stop on SIGTSTP. So perhaps
+ // the most correct thing to do could be to revert to the default
+ // handler for SIGTSTP, unblock SIGTSTP, and then raise(SIGTSTP).
+ // It's quite a bit more complicated than just raising SIGSTOP though.
+ //
+ // The difference between raising SIGTSTP vs. SIGSTOP can be seen on
+ // the shell command line too by running "echo $?" after stopping
+ // a process but perhaps that doesn't matter.
+ const uint64_t t = mytime_now();
+ raise(SIGSTOP);
+ start_time += mytime_now() - t;
+ return;
+}
+#endif
+
+
extern void
mytime_set_start_time(void)
{
+#ifdef USE_SIGTSTP_HANDLER
+ // Block the signals when accessing start_time so that we cannot
+ // end up with a garbage value. start_time is volatile but access
+ // to it isn't atomic at least on 32-bit systems.
+ signals_block();
+#endif
+
start_time = mytime_now();
+
+#ifdef USE_SIGTSTP_HANDLER
+ signals_unblock();
+#endif
+
return;
}
@@ -59,7 +140,17 @@ mytime_set_start_time(void)
extern uint64_t
mytime_get_elapsed(void)
{
- return mytime_now() - start_time;
+#ifdef USE_SIGTSTP_HANDLER
+ signals_block();
+#endif
+
+ const uint64_t t = mytime_now() - start_time;
+
+#ifdef USE_SIGTSTP_HANDLER
+ signals_unblock();
+#endif
+
+ return t;
}
diff --git a/src/xz/mytime.h b/src/xz/mytime.h
index a7be2aa7ca62..6dfaeae9b683 100644
--- a/src/xz/mytime.h
+++ b/src/xz/mytime.h
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file mytime.h
@@ -5,9 +7,6 @@
//
// Author: Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
@@ -21,6 +20,12 @@
extern uint64_t opt_flush_timeout;
+#ifdef USE_SIGTSTP_HANDLER
+/// \brief Signal handler for SIGTSTP
+extern void mytime_sigtstp_handler(int sig);
+#endif
+
+
/// \brief Store the time when (de)compression was started
///
/// The start time is also stored as the time of the first flush.
diff --git a/src/xz/options.c b/src/xz/options.c
index 4d5e899ccdc1..bc8bc1a6c36c 100644
--- a/src/xz/options.c
+++ b/src/xz/options.c
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file options.c
@@ -5,9 +7,6 @@
//
// Author: Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
#include "private.h"
@@ -83,7 +82,7 @@ parse_options(const char *str, const option_map *opts,
*value++ = '\0';
if (value == NULL || value[0] == '\0')
- message_fatal(_("%s: Options must be `name=value' "
+ message_fatal(_("%s: Options must be 'name=value' "
"pairs separated with commas"), str);
// Look for the option name from the option map.
diff --git a/src/xz/options.h b/src/xz/options.h
index 61ec8d58a145..4a1314db26f0 100644
--- a/src/xz/options.h
+++ b/src/xz/options.h
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file options.h
@@ -5,9 +7,6 @@
//
// Author: Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
/// \brief Parser for Delta options
diff --git a/src/xz/private.h b/src/xz/private.h
index 6414bdb5081c..b370472e32c8 100644
--- a/src/xz/private.h
+++ b/src/xz/private.h
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file private.h
@@ -5,9 +7,6 @@
//
// Author: Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
#include "sysdefs.h"
@@ -21,7 +20,10 @@
#include <signal.h>
#include <locale.h>
#include <stdio.h>
-#include <unistd.h>
+
+#ifndef _MSC_VER
+# include <unistd.h>
+#endif
#include "tuklib_gettext.h"
#include "tuklib_progname.h"
@@ -33,6 +35,10 @@
# include <windows.h>
#endif
+#ifdef _MSC_VER
+# define fileno _fileno
+#endif
+
#ifndef STDIN_FILENO
# define STDIN_FILENO (fileno(stdin))
#endif
@@ -45,8 +51,15 @@
# define STDERR_FILENO (fileno(stderr))
#endif
-#if defined(HAVE_CAPSICUM) || defined(HAVE_PLEDGE)
-# define ENABLE_SANDBOX 1
+// Handling SIGTSTP keeps time-keeping for progress indicator correct
+// if xz is stopped. It requires use of clock_gettime() as that is
+// async-signal safe in POSIX. Require also SIGALRM support since
+// on systems where SIGALRM isn't available, progress indicator code
+// polls the time and the SIGTSTP handling adds slight overhead to
+// that code. Most (all?) systems that have SIGTSTP also have SIGALRM
+// so this requirement won't exclude many systems.
+#if defined(HAVE_CLOCK_GETTIME) && defined(SIGTSTP) && defined(SIGALRM)
+# define USE_SIGTSTP_HANDLER 1
#endif
#include "main.h"
@@ -57,6 +70,7 @@
#include "hardware.h"
#include "file_io.h"
#include "options.h"
+#include "sandbox.h"
#include "signals.h"
#include "suffix.h"
#include "util.h"
diff --git a/src/xz/sandbox.c b/src/xz/sandbox.c
new file mode 100644
index 000000000000..3b3069c8b2c8
--- /dev/null
+++ b/src/xz/sandbox.c
@@ -0,0 +1,355 @@
+// SPDX-License-Identifier: 0BSD
+
+///////////////////////////////////////////////////////////////////////////////
+//
+/// \file sandbox.c
+/// \brief Sandbox support
+//
+// Author: Lasse Collin
+//
+///////////////////////////////////////////////////////////////////////////////
+
+#include "private.h"
+
+
+#ifndef ENABLE_SANDBOX
+
+// Prevent an empty translation unit when no sandboxing is supported.
+typedef int dummy;
+
+#else
+
+/// If the conditions for strict sandboxing (described in main())
+/// have been met, sandbox_allow_strict() can be called to set this
+/// variable to true.
+static bool strict_sandbox_allowed = false;
+
+
+extern void
+sandbox_allow_strict(void)
+{
+ strict_sandbox_allowed = true;
+ return;
+}
+
+
+// Strict sandboxing prevents opening any files. This *tries* to ensure
+// that any auxiliary files that might be required are already open.
+//
+// Returns true if strict sandboxing is allowed, false otherwise.
+static bool
+prepare_for_strict_sandbox(void)
+{
+ if (!strict_sandbox_allowed)
+ return false;
+
+ const char dummy_str[] = "x";
+
+ // Try to ensure that both libc and xz locale files have been
+ // loaded when NLS is enabled.
+ snprintf(NULL, 0, "%s%s", _(dummy_str), strerror(EINVAL));
+
+ // Try to ensure that iconv data files needed for handling multibyte
+ // characters have been loaded. This is needed at least with glibc.
+ tuklib_mbstr_width(dummy_str, NULL);
+
+ return true;
+}
+
+#endif
+
+
+#if defined(HAVE_PLEDGE)
+
+///////////////
+// pledge(2) //
+///////////////
+
+#include <unistd.h>
+
+
+extern void
+sandbox_init(void)
+{
+ if (pledge("stdio rpath wpath cpath fattr", "")) {
+ // gettext hasn't been initialized yet so
+ // there's no point to call it here.
+ message_fatal("Failed to enable the sandbox");
+ }
+
+ return;
+}
+
+
+extern void
+sandbox_enable_read_only(void)
+{
+ // We will be opening files for reading but
+ // won't create or remove any files.
+ if (pledge("stdio rpath", ""))
+ message_fatal(_("Failed to enable the sandbox"));
+
+ return;
+}
+
+
+extern void
+sandbox_enable_strict_if_allowed(int src_fd lzma_attribute((__unused__)),
+ int pipe_event_fd lzma_attribute((__unused__)),
+ int pipe_write_fd lzma_attribute((__unused__)))
+{
+ if (!prepare_for_strict_sandbox())
+ return;
+
+ // All files that need to be opened have already been opened.
+ if (pledge("stdio", ""))
+ message_fatal(_("Failed to enable the sandbox"));
+
+ return;
+}
+
+
+#elif defined(HAVE_LINUX_LANDLOCK_H)
+
+//////////////
+// Landlock //
+//////////////
+
+#include <linux/landlock.h>
+#include <sys/syscall.h>
+#include <sys/prctl.h>
+
+
+// Highest Landlock ABI version supported by this file:
+// - For ABI versions 1-3 we don't need anything from <linux/landlock.h>
+// that isn't part of version 1.
+// - For ABI version 4 we need the larger struct landlock_ruleset_attr
+// with the handled_access_net member. That is bundled with the macros
+// LANDLOCK_ACCESS_NET_BIND_TCP and LANDLOCK_ACCESS_NET_CONNECT_TCP.
+#ifdef LANDLOCK_ACCESS_NET_BIND_TCP
+# define LANDLOCK_ABI_MAX 4
+#else
+# define LANDLOCK_ABI_MAX 3
+#endif
+
+
+/// Landlock ABI version supported by the kernel
+static int landlock_abi;
+
+
+// The required_rights should have those bits set that must not be restricted.
+// This function will then bitwise-and ~required_rights with a mask matching
+// the Landlock ABI version, leaving only those bits set that are supported
+// by the ABI and allowed to be restricted by the function argument.
+static void
+enable_landlock(uint64_t required_rights)
+{
+ assert(landlock_abi <= LANDLOCK_ABI_MAX);
+
+ if (landlock_abi <= 0)
+ return;
+
+ // We want to set all supported flags in handled_access_fs.
+ // This way the ruleset will initially forbid access to all
+ // actions that the available Landlock ABI version supports.
+ // Exceptions can be added using landlock_add_rule(2) to
+ // allow certain actions on certain files or directories.
+ //
+ // The same flag values are used on all archs. ABI v2 and v3
+ // both add one new flag.
+ //
+ // First in ABI v1: LANDLOCK_ACCESS_FS_EXECUTE = 1ULL << 0
+ // Last in ABI v1: LANDLOCK_ACCESS_FS_MAKE_SYM = 1ULL << 12
+ // Last in ABI v2: LANDLOCK_ACCESS_FS_REFER = 1ULL << 13
+ // Last in ABI v3: LANDLOCK_ACCESS_FS_TRUNCATE = 1ULL << 14
+ //
+ // This makes it simple to set the mask based on the ABI
+ // version and we don't need to care which flags are #defined
+ // in the installed <linux/landlock.h> for ABI versions 1-3.
+ const struct landlock_ruleset_attr attr = {
+ .handled_access_fs = ~required_rights
+ & ((1ULL << (12 + my_min(3, landlock_abi))) - 1),
+#if LANDLOCK_ABI_MAX >= 4
+ .handled_access_net = landlock_abi < 4 ? 0 :
+ (LANDLOCK_ACCESS_NET_BIND_TCP
+ | LANDLOCK_ACCESS_NET_CONNECT_TCP),
+#endif
+ };
+
+ const int ruleset_fd = syscall(SYS_landlock_create_ruleset,
+ &attr, sizeof(attr), 0U);
+ if (ruleset_fd < 0)
+ message_fatal(_("Failed to enable the sandbox"));
+
+ // All files we need should have already been opened. Thus,
+ // we don't need to add any rules using landlock_add_rule(2)
+ // before activating the sandbox.
+ //
+ // NOTE: It's possible that the hack prepare_for_strict_sandbox()
+ // isn't be good enough. It tries to get translations and
+ // libc-specific files loaded but if it's not good enough
+ // then perhaps a Landlock rule to allow reading from /usr
+ // and/or the xz installation prefix would be needed.
+ //
+ // prctl(PR_SET_NO_NEW_PRIVS, ...) was already called in
+ // sandbox_init() so we don't do it here again.
+ if (syscall(SYS_landlock_restrict_self, ruleset_fd, 0U) != 0)
+ message_fatal(_("Failed to enable the sandbox"));
+
+ return;
+}
+
+
+extern void
+sandbox_init(void)
+{
+ // Prevent the process from gaining new privileges. This must be done
+ // before landlock_restrict_self(2) but since we will never need new
+ // privileges, this call can be done here already.
+ //
+ // This is supported since Linux 3.5. Ignore the return value to
+ // keep compatibility with old kernels. landlock_restrict_self(2)
+ // will fail if the no_new_privs attribute isn't set, thus if prctl()
+ // fails here the error will still be detected when it matters.
+ (void)prctl(PR_SET_NO_NEW_PRIVS, 1, 0, 0, 0);
+
+ // Get the highest Landlock ABI version supported by the kernel.
+ landlock_abi = syscall(SYS_landlock_create_ruleset,
+ (void *)NULL, 0, LANDLOCK_CREATE_RULESET_VERSION);
+
+ // The kernel might support a newer ABI than this file.
+ if (landlock_abi > LANDLOCK_ABI_MAX)
+ landlock_abi = LANDLOCK_ABI_MAX;
+
+ // These are all in ABI version 1 already. We don't need truncate
+ // rights because files are created with open() using O_EXCL and
+ // without O_TRUNC.
+ //
+ // LANDLOCK_ACCESS_FS_READ_DIR is included here to get a clear error
+ // message if xz is given a directory name. Without this permission
+ // the message would be "Permission denied" but with this permission
+ // it's "Is a directory, skipping". It could be worked around with
+ // stat()/lstat() but just giving this permission is simpler and
+ // shouldn't make the sandbox much weaker in practice.
+ const uint64_t required_rights
+ = LANDLOCK_ACCESS_FS_WRITE_FILE
+ | LANDLOCK_ACCESS_FS_READ_FILE
+ | LANDLOCK_ACCESS_FS_READ_DIR
+ | LANDLOCK_ACCESS_FS_REMOVE_FILE
+ | LANDLOCK_ACCESS_FS_MAKE_REG;
+
+ enable_landlock(required_rights);
+ return;
+}
+
+
+extern void
+sandbox_enable_read_only(void)
+{
+ // We will be opening files for reading but
+ // won't create or remove any files.
+ const uint64_t required_rights
+ = LANDLOCK_ACCESS_FS_READ_FILE
+ | LANDLOCK_ACCESS_FS_READ_DIR;
+ enable_landlock(required_rights);
+ return;
+}
+
+
+extern void
+sandbox_enable_strict_if_allowed(int src_fd lzma_attribute((__unused__)),
+ int pipe_event_fd lzma_attribute((__unused__)),
+ int pipe_write_fd lzma_attribute((__unused__)))
+{
+ if (!prepare_for_strict_sandbox())
+ return;
+
+ // Allow all restrictions that the kernel supports with the
+ // highest Landlock ABI version that the kernel or xz supports.
+ //
+ // NOTE: LANDLOCK_ACCESS_FS_READ_DIR isn't needed here because
+ // the only input file has already been opened.
+ enable_landlock(0);
+ return;
+}
+
+
+#elif defined(HAVE_CAP_RIGHTS_LIMIT)
+
+//////////////
+// Capsicum //
+//////////////
+
+#include <sys/capsicum.h>
+
+
+extern void
+sandbox_init(void)
+{
+ // Nothing to do.
+ return;
+}
+
+
+extern void
+sandbox_enable_read_only(void)
+{
+ // Nothing to do.
+ return;
+}
+
+
+extern void
+sandbox_enable_strict_if_allowed(
+ int src_fd, int pipe_event_fd, int pipe_write_fd)
+{
+ if (!prepare_for_strict_sandbox())
+ return;
+
+ // Capsicum needs FreeBSD 10.2 or later.
+ cap_rights_t rights;
+
+ if (cap_enter())
+ goto error;
+
+ if (cap_rights_limit(src_fd, cap_rights_init(&rights,
+ CAP_EVENT, CAP_FCNTL, CAP_LOOKUP, CAP_READ, CAP_SEEK)))
+ goto error;
+
+ // If not reading from stdin, remove all capabilities from it.
+ if (src_fd != STDIN_FILENO && cap_rights_limit(
+ STDIN_FILENO, cap_rights_clear(&rights)))
+ goto error;
+
+ if (cap_rights_limit(STDOUT_FILENO, cap_rights_init(&rights,
+ CAP_EVENT, CAP_FCNTL, CAP_FSTAT, CAP_LOOKUP,
+ CAP_WRITE, CAP_SEEK)))
+ goto error;
+
+ if (cap_rights_limit(STDERR_FILENO, cap_rights_init(&rights,
+ CAP_WRITE)))
+ goto error;
+
+ if (cap_rights_limit(pipe_event_fd, cap_rights_init(&rights,
+ CAP_EVENT)))
+ goto error;
+
+ if (cap_rights_limit(pipe_write_fd, cap_rights_init(&rights,
+ CAP_WRITE)))
+ goto error;
+
+ return;
+
+error:
+ // If a kernel is configured without capability mode support or
+ // used in an emulator that does not implement the capability
+ // system calls, then the Capsicum system calls will fail and set
+ // errno to ENOSYS. In that case xz will silently run without
+ // the sandbox.
+ if (errno == ENOSYS)
+ return;
+
+ message_fatal(_("Failed to enable the sandbox"));
+}
+
+#endif
diff --git a/src/xz/sandbox.h b/src/xz/sandbox.h
new file mode 100644
index 000000000000..f41b4725ce3f
--- /dev/null
+++ b/src/xz/sandbox.h
@@ -0,0 +1,43 @@
+// SPDX-License-Identifier: 0BSD
+
+///////////////////////////////////////////////////////////////////////////////
+//
+/// \file sandbox.h
+/// \brief Sandbox support
+//
+// Author: Lasse Collin
+//
+///////////////////////////////////////////////////////////////////////////////
+
+#if defined(HAVE_PLEDGE) || defined(HAVE_LINUX_LANDLOCK_H) \
+ || defined(HAVE_CAP_RIGHTS_LIMIT)
+# define ENABLE_SANDBOX 1
+#endif
+
+
+/// \brief Enables early sandboxing that can always be enabled
+///
+/// This requires that tuklib_progname() and io_init() have been called.
+extern void sandbox_init(void);
+
+
+/// \brief Enable sandboxing that only allows opening files for reading
+extern void sandbox_enable_read_only(void);
+
+
+/// \brief Tell sandboxing code that strict sandboxing can be used
+///
+/// This function only sets a flag which will be read by
+/// sandbox_enable_strict_if_allowed().
+extern void sandbox_allow_strict(void);
+
+
+/// \brief Enable sandboxing that allows reading from one file
+///
+/// This does nothing if sandbox_allow_strict() hasn't been called.
+///
+/// \param src_fd File descriptor open for reading
+/// \param pipe_event_fd user_abort_pipe[0] from file_io.c
+/// \param pipe_write_fd user_abort_pipe[1] from file_io.c
+extern void sandbox_enable_strict_if_allowed(
+ int src_fd, int pipe_event_fd, int pipe_write_fd);
diff --git a/src/xz/signals.c b/src/xz/signals.c
index 7aef463c7570..13cc4c2b0c2f 100644
--- a/src/xz/signals.c
+++ b/src/xz/signals.c
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file signals.c
@@ -5,9 +7,6 @@
//
// Author: Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
#include "private.h"
@@ -82,6 +81,11 @@ signals_init(void)
sigaddset(&hooked_signals, message_progress_sigs[i]);
#endif
+#ifdef USE_SIGTSTP_HANDLER
+ // Add the SIGTSTP handler from mytime.c to hooked_signals.
+ sigaddset(&hooked_signals, SIGTSTP);
+#endif
+
// Using "my_sa" because "sa" may conflict with a sockaddr variable
// from system headers on Solaris.
struct sigaction my_sa;
@@ -96,10 +100,11 @@ signals_init(void)
my_sa.sa_flags = 0;
my_sa.sa_handler = &signal_handler;
+ struct sigaction old;
+
for (size_t i = 0; i < ARRAY_SIZE(sigs); ++i) {
// If the parent process has left some signals ignored,
// we don't unignore them.
- struct sigaction old;
if (sigaction(sigs[i], NULL, &old) == 0
&& old.sa_handler == SIG_IGN)
continue;
@@ -109,6 +114,15 @@ signals_init(void)
message_signal_handler();
}
+#ifdef USE_SIGTSTP_HANDLER
+ if (!(sigaction(SIGTSTP, NULL, &old) == 0
+ && old.sa_handler == SIG_IGN)) {
+ my_sa.sa_handler = &mytime_sigtstp_handler;
+ if (sigaction(SIGTSTP, &my_sa, NULL))
+ message_signal_handler();
+ }
+#endif
+
signals_are_initialized = true;
return;
diff --git a/src/xz/signals.h b/src/xz/signals.h
index 5b125e0f0d7b..629335d4c96b 100644
--- a/src/xz/signals.h
+++ b/src/xz/signals.h
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file signals.h
@@ -5,9 +7,6 @@
//
// Author: Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
/// If this is true, we will clean up the possibly incomplete output file,
diff --git a/src/xz/suffix.c b/src/xz/suffix.c
index 6ce978783f78..1d548e485b8c 100644
--- a/src/xz/suffix.c
+++ b/src/xz/suffix.c
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file suffix.c
@@ -5,9 +7,6 @@
//
// Author: Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
#include "private.h"
@@ -21,7 +20,13 @@
# ifdef HAVE_STRINGS_H
# include <strings.h>
# endif
-# define strcmp strcasecmp
+# ifdef _MSC_VER
+# define suffix_strcmp _stricmp
+# else
+# define suffix_strcmp strcasecmp
+# endif
+#else
+# define suffix_strcmp strcmp
#endif
@@ -98,7 +103,7 @@ test_suffix(const char *suffix, const char *src_name, size_t src_len)
|| is_dir_sep(src_name[src_len - suffix_len - 1]))
return 0;
- if (strcmp(suffix, src_name + src_len - suffix_len) == 0)
+ if (suffix_strcmp(suffix, src_name + src_len - suffix_len) == 0)
return src_len - suffix_len;
return 0;
@@ -178,7 +183,7 @@ uncompressed_name(const char *src_name, const size_t src_len)
static void
msg_suffix(const char *src_name, const char *suffix)
{
- message_warning(_("%s: File already has `%s' suffix, skipping"),
+ message_warning(_("%s: File already has '%s' suffix, skipping"),
src_name, suffix);
return;
}
diff --git a/src/xz/suffix.h b/src/xz/suffix.h
index 135e905688b0..f59e3123ca8d 100644
--- a/src/xz/suffix.h
+++ b/src/xz/suffix.h
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file suffix.h
@@ -5,9 +7,6 @@
//
// Author: Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
/// \brief Get the name of the destination file
diff --git a/src/xz/util.c b/src/xz/util.c
index 6ab4c2d776ce..0d339aede675 100644
--- a/src/xz/util.c
+++ b/src/xz/util.c
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file util.c
@@ -5,9 +7,6 @@
//
// Author: Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
#include "private.h"
@@ -148,8 +147,8 @@ str_to_uint64(const char *name, const char *value, uint64_t min, uint64_t max)
if (multiplier == 0) {
message(V_ERROR, _("%s: Invalid multiplier suffix"),
value - 1);
- message_fatal(_("Valid suffixes are `KiB' (2^10), "
- "`MiB' (2^20), and `GiB' (2^30)."));
+ message_fatal(_("Valid suffixes are 'KiB' (2^10), "
+ "'MiB' (2^20), and 'GiB' (2^30)."));
}
// Don't overflow here either.
@@ -165,7 +164,7 @@ str_to_uint64(const char *name, const char *value, uint64_t min, uint64_t max)
return result;
error:
- message_fatal(_("Value of the option `%s' must be in the range "
+ message_fatal(_("Value of the option '%s' must be in the range "
"[%" PRIu64 ", %" PRIu64 "]"),
name, min, max);
}
@@ -262,9 +261,30 @@ my_snprintf(char **pos, size_t *left, const char *fmt, ...)
extern bool
+is_tty(int fd)
+{
+#if defined(_WIN32) && !defined(__CYGWIN__)
+ // There is no need to check if handle == INVALID_HANDLE_VALUE
+ // because it will return false anyway when used in GetConsoleMode().
+ // The resulting HANDLE is owned by the file descriptor.
+ // The HANDLE must not be closed here.
+ intptr_t handle = _get_osfhandle(fd);
+ DWORD mode;
+
+ // GetConsoleMode() is an easy way to tell if the HANDLE is a
+ // console or not. We do not care about the value of mode since we
+ // do not plan to use any further Windows console functions.
+ return GetConsoleMode((HANDLE)handle, &mode);
+#else
+ return isatty(fd);
+#endif
+}
+
+
+extern bool
is_tty_stdin(void)
{
- const bool ret = isatty(STDIN_FILENO);
+ const bool ret = is_tty(STDIN_FILENO);
if (ret)
message_error(_("Compressed data cannot be read from "
@@ -277,7 +297,7 @@ is_tty_stdin(void)
extern bool
is_tty_stdout(void)
{
- const bool ret = isatty(STDOUT_FILENO);
+ const bool ret = is_tty(STDOUT_FILENO);
if (ret)
message_error(_("Compressed data cannot be written to "
diff --git a/src/xz/util.h b/src/xz/util.h
index 6d7e1481863b..a2fdd0593372 100644
--- a/src/xz/util.h
+++ b/src/xz/util.h
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file util.h
@@ -5,9 +7,6 @@
//
// Author: Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
/// \brief Safe malloc() that never returns NULL
@@ -105,6 +104,20 @@ lzma_attribute((__format__(__printf__, 3, 4)))
extern void my_snprintf(char **pos, size_t *left, const char *fmt, ...);
+/// \brief Test if file descriptor is a terminal
+///
+/// For POSIX systems, this is a simple wrapper around isatty(). However on
+/// Windows, isatty() returns true for all character devices, not just
+/// terminals.
+///
+/// \param fd File descriptor to test
+///
+/// \return bool:
+/// - true if file descriptor is a terminal
+/// - false otherwise
+extern bool is_tty(int fd);
+
+
/// \brief Test if stdin is a terminal
///
/// If stdin is a terminal, an error message is printed and exit status set
diff --git a/src/xz/xz.1 b/src/xz/xz.1
index 73ca6efd6aff..6c8a52f5242e 100644
--- a/src/xz/xz.1
+++ b/src/xz/xz.1
@@ -1,12 +1,10 @@
'\" t
+.\" SPDX-License-Identifier: 0BSD
.\"
.\" Authors: Lasse Collin
.\" Jia Tan
.\"
-.\" This file has been put into the public domain.
-.\" You can do whatever you want with this file.
-.\"
-.TH XZ 1 "2023-07-17" "Tukaani" "XZ Utils"
+.TH XZ 1 "2024-02-13" "Tukaani" "XZ Utils"
.
.SH NAME
xz, unxz, xzcat, lzma, unlzma, lzcat \- Compress or decompress .xz and .lzma files
@@ -801,8 +799,6 @@ in the single-threaded mode.
It may vary slightly between
.B xz
versions.
-Memory requirements of some of the future multithreaded modes may
-be dramatically higher than that of the single-threaded mode.
.IP \(bu 3
DecMem contains the decompressor memory requirements.
That is, the compression settings determine
@@ -811,6 +807,15 @@ The exact decompressor memory usage is slightly more than
the LZMA2 dictionary size, but the values in the table
have been rounded up to the next full MiB.
.RE
+.IP ""
+Memory requirements of the multi-threaded mode are
+significantly higher than that of the single-threaded mode.
+With the default value of
+.BR \-\-block\-size ,
+each thread needs 3*3*DictSize plus CompMem or DecMem.
+For example, four threads with preset
+.B \-6
+needs 660\(en670\ MiB of memory.
.TP
.BR \-e ", " \-\-extreme
Use a slower variant of the selected compression preset level
@@ -902,50 +907,90 @@ Using
.I size
less than the LZMA2 dictionary size is waste of RAM
because then the LZMA2 dictionary buffer will never get fully used.
-The sizes of the blocks are stored in the block headers,
-which a future version of
-.B xz
-will use for multi-threaded decompression.
+In multi-threaded mode,
+the sizes of the blocks are stored in the block headers.
+This size information is required for multi-threaded decompression.
.IP ""
In single-threaded mode no block splitting is done by default.
Setting this option doesn't affect memory usage.
No size information is stored in block headers,
thus files created in single-threaded mode
won't be identical to files created in multi-threaded mode.
-The lack of size information also means that a future version of
+The lack of size information also means that
.B xz
won't be able decompress the files in multi-threaded mode.
.TP
-.BI \-\-block\-list= sizes
+.BI \-\-block\-list= items
When compressing to the
.B .xz
-format, start a new block after
+format, start a new block with an optional custom filter chain after
the given intervals of uncompressed data.
.IP ""
-The uncompressed
-.I sizes
-of the blocks are specified as a comma-separated list.
-Omitting a size (two or more consecutive commas) is a shorthand
-to use the size of the previous block.
+The
+.I items
+are a comma-separated list.
+Each item consists of an optional filter chain number
+between 0 and 9 followed by a colon
+.RB ( : )
+and a required size of uncompressed data.
+Omitting an item (two or more consecutive commas) is a
+shorthand to use the size and filters of the previous item.
.IP ""
If the input file is bigger than the sum of
-.IR sizes ,
-the last value in
-.I sizes
-is repeated until the end of the file.
+the sizes in
+.IR items ,
+the last item is repeated until the end of the file.
A special value of
.B 0
-may be used as the last value to indicate that
+may be used as the last size to indicate that
the rest of the file should be encoded as a single block.
.IP ""
-If one specifies
-.I sizes
-that exceed the encoder's block size
+An alternative filter chain for each block can be
+specified in combination with the
+.BI \-\-filters1= filters
+\&...\&
+.BI \-\-filters9= filters
+options.
+These options define filter chains with an identifier
+between 1\(en9.
+Filter chain 0 can be used to refer to the default filter chain,
+which is the same as not specifying a filter chain.
+The filter chain identifier can be used before the uncompressed
+size, followed by a colon
+.RB ( : ).
+For example, if one specifies
+.B \-\-block\-list=1:2MiB,3:2MiB,2:4MiB,,2MiB,0:4MiB
+then blocks will be created using:
+.RS
+.IP \(bu 3
+The filter chain specified by
+.B \-\-filters1
+and 2 MiB input
+.IP \(bu 3
+The filter chain specified by
+.B \-\-filters3
+and 2 MiB input
+.IP \(bu 3
+The filter chain specified by
+.B \-\-filters2
+and 4 MiB input
+.IP \(bu 3
+The filter chain specified by
+.B \-\-filters2
+and 4 MiB input
+.IP \(bu 3
+The default filter chain and 2 MiB input
+.IP \(bu 3
+The default filter chain and 4 MiB input for every block until
+end of input.
+.RE
+.IP ""
+If one specifies a size that exceeds the encoder's block size
(either the default value in threaded mode or
the value specified with \fB\-\-block\-size=\fIsize\fR),
the encoder will create additional blocks while
keeping the boundaries specified in
-.IR sizes .
+.IR items .
For example, if one specifies
.B \-\-block\-size=10MiB
.B \-\-block\-list=5MiB,10MiB,8MiB,12MiB,24MiB
@@ -1262,6 +1307,15 @@ meet this condition,
but files compressed in single-threaded mode don't even if
.BI \-\-block\-size= size
has been used.
+.IP ""
+The default value for
+.I threads
+is
+.BR 0 .
+In
+.B xz
+5.4.x and older the default is
+.BR 1 .
.
.SS "Custom compressor filter chains"
A custom filter chain allows specifying
@@ -1295,22 +1349,37 @@ in the chain.
Depending on the filter, this limitation is either inherent to
the filter design or exists to prevent security issues.
.PP
-A custom filter chain is specified by using one or more
-filter options in the order they are wanted in the filter chain.
-That is, the order of filter options is significant!
+A custom filter chain can be specified in two different ways.
+The options
+.BI \-\-filters= filters
+and
+.BI \-\-filters1= filters
+\&...\&
+.BI \-\-filters9= filters
+allow specifying an entire filter chain in one option using the
+liblzma filter string syntax.
+Alternatively, a filter chain can be specified by using one or more
+individual filter options in the order they are wanted in the filter chain.
+That is, the order of the individual filter options is significant!
When decoding raw streams
.RB ( \-\-format=raw ),
-the filter chain is specified in the same order as
+the filter chain must be specified in the same order as
it was specified when compressing.
-.PP
-Filters take filter-specific
+Any individual filter or preset options specified before the full
+chain option
+(\fB\-\-filters=\fIfilters\fR)
+will be forgotten.
+Individual filters specified after the full chain option will reset the
+filter chain.
+.PP
+Both the full and individual filter options take filter-specific
.I options
as a comma-separated list.
Extra commas in
.I options
are ignored.
-Every option has a default value, so you need to
-specify only those you want to change.
+Every option has a default value, so
+specify those you want to change.
.PP
To see the whole filter chain and
.IR options ,
@@ -1321,6 +1390,45 @@ use
twice).
This works also for viewing the filter chain options used by presets.
.TP
+.BI \-\-filters= filters
+Specify the full filter chain or a preset in a single option.
+Each filter can be separated by spaces or two dashes
+.RB ( \-\- ).
+.I filters
+may need to be quoted on the shell command line so it is
+parsed as a single option.
+To denote
+.IR options ,
+use
+.B :
+or
+.BR = .
+A preset can be prefixed with a
+.B \-
+and followed with zero or more flags.
+The only supported flag is
+.B e
+to apply the same options as
+.BR \-\-extreme .
+.TP
+\fB\-\-filters1\fR=\fIfilters\fR ... \fB\-\-filters9\fR=\fIfilters
+Specify up to nine additional filter chains that can be used with
+.BR \-\-block\-list .
+.IP ""
+For example, when compressing an archive with executable files
+followed by text files, the executable part could use a filter
+chain with a BCJ filter and the text part only the LZMA2 filter.
+.TP
+.B \-\-filters-help
+Display a help message describing how to specify presets and
+custom filter chains in the
+.B \-\-filters
+and
+.BI \-\-filters1= filters
+\&...\&
+.BI \-\-filters9= filters
+options, and exit successfully.
+.TP
\fB\-\-lzma1\fR[\fB=\fIoptions\fR]
.PD 0
.TP
@@ -1762,6 +1870,7 @@ ARM64;4;4096-byte alignment is best
PowerPC;4;Big endian only
IA-64;16;Itanium
SPARC;4;
+RISC-V;2;
.TE
.RE
.RE
@@ -1770,14 +1879,38 @@ Since the BCJ-filtered data is usually compressed with LZMA2,
the compression ratio may be improved slightly if
the LZMA2 options are set to match the
alignment of the selected BCJ filter.
-For example, with the IA-64 filter, it's good to set
-.B pb=4
-or even
+Examples:
+.RS
+.IP \(bu 3
+IA-64 filter has 16-byte alignment so
.B pb=4,lp=4,lc=0
+is good
with LZMA2 (2^4=16).
-The x86 filter is an exception;
-it's usually good to stick to LZMA2's default
-four-byte alignment when compressing x86 executables.
+.IP \(bu 3
+RISC-V code has 2-byte or 4-byte alignment
+depending on whether the file contains
+16-bit compressed instructions (the C extension).
+When 16-bit instructions are used,
+.B pb=2,lp=1,lc=3
+or
+.B pb=1,lp=1,lc=3
+is good.
+When 16-bit instructions aren't present,
+.B pb=2,lp=2,lc=2
+is the best.
+.B readelf \-h
+can be used to check if "RVC"
+appears on the "Flags" line.
+.IP \(bu 3
+ARM64 is always 4-byte aligned so
+.B pb=2,lp=2,lc=2
+is the best.
+.IP \(bu 3
+The x86 filter is an exception.
+It's usually good to stick to LZMA2's defaults
+.RB ( pb=2,lp=0,lc=3 )
+when compressing x86 executables.
+.RE
.IP ""
All BCJ filters support the same
.IR options :
@@ -1954,107 +2087,14 @@ easier to parse by other programs.
Currently
.B \-\-robot
is supported only together with
-.BR \-\-version ,
+.BR \-\-list ,
+.BR \-\-filters\-help ,
.BR \-\-info\-memory ,
and
-.BR \-\-list .
+.BR \-\-version .
It will be supported for compression and
decompression in the future.
.
-.SS Version
-.B "xz \-\-robot \-\-version"
-prints the version number of
-.B xz
-and liblzma in the following format:
-.PP
-.BI XZ_VERSION= XYYYZZZS
-.br
-.BI LIBLZMA_VERSION= XYYYZZZS
-.TP
-.I X
-Major version.
-.TP
-.I YYY
-Minor version.
-Even numbers are stable.
-Odd numbers are alpha or beta versions.
-.TP
-.I ZZZ
-Patch level for stable releases or
-just a counter for development releases.
-.TP
-.I S
-Stability.
-0 is alpha, 1 is beta, and 2 is stable.
-.I S
-should be always 2 when
-.I YYY
-is even.
-.PP
-.I XYYYZZZS
-are the same on both lines if
-.B xz
-and liblzma are from the same XZ Utils release.
-.PP
-Examples: 4.999.9beta is
-.B 49990091
-and
-5.0.0 is
-.BR 50000002 .
-.
-.SS "Memory limit information"
-.B "xz \-\-robot \-\-info\-memory"
-prints a single line with multiple tab-separated columns:
-.IP 1. 4
-Total amount of physical memory (RAM) in bytes.
-.IP 2. 4
-Memory usage limit for compression in bytes
-.RB ( \-\-memlimit\-compress ).
-A special value of
-.B 0
-indicates the default setting
-which for single-threaded mode is the same as no limit.
-.IP 3. 4
-Memory usage limit for decompression in bytes
-.RB ( \-\-memlimit\-decompress ).
-A special value of
-.B 0
-indicates the default setting
-which for single-threaded mode is the same as no limit.
-.IP 4. 4
-Since
-.B xz
-5.3.4alpha:
-Memory usage for multi-threaded decompression in bytes
-.RB ( \-\-memlimit\-mt\-decompress ).
-This is never zero because a system-specific default value
-shown in the column 5
-is used if no limit has been specified explicitly.
-This is also never greater than the value in the column 3
-even if a larger value has been specified with
-.BR \-\-memlimit\-mt\-decompress .
-.IP 5. 4
-Since
-.B xz
-5.3.4alpha:
-A system-specific default memory usage limit
-that is used to limit the number of threads
-when compressing with an automatic number of threads
-.RB ( \-\-threads=0 )
-and no memory usage limit has been specified
-.RB ( \-\-memlimit\-compress ).
-This is also used as the default value for
-.BR \-\-memlimit\-mt\-decompress .
-.IP 6. 4
-Since
-.B xz
-5.3.4alpha:
-Number of available processor threads.
-.PP
-In the future, the output of
-.B "xz \-\-robot \-\-info\-memory"
-may have more columns, but never more than a single line.
-.
.SS "List mode"
.B "xz \-\-robot \-\-list"
uses tab-separated output.
@@ -2339,6 +2379,127 @@ Future versions may add new line types and
new columns can be added to the existing line types,
but the existing columns won't be changed.
.
+.SS "Filters help"
+.B "xz \-\-robot \-\-filters-help"
+prints the supported filters in the following format:
+.PP
+\fIfilter\fB:\fIoption\fB=<\fIvalue\fB>,\fIoption\fB=<\fIvalue\fB>\fR...
+.TP
+.I filter
+Name of the filter
+.TP
+.I option
+Name of a filter specific option
+.TP
+.I value
+Numeric
+.I value
+ranges appear as
+\fB<\fImin\fB\-\fImax\fB>\fR.
+String
+.I value
+choices are shown within
+.B "< >"
+and separated by a
+.B |
+character.
+.PP
+Each filter is printed on its own line.
+.
+.SS "Memory limit information"
+.B "xz \-\-robot \-\-info\-memory"
+prints a single line with multiple tab-separated columns:
+.IP 1. 4
+Total amount of physical memory (RAM) in bytes.
+.IP 2. 4
+Memory usage limit for compression in bytes
+.RB ( \-\-memlimit\-compress ).
+A special value of
+.B 0
+indicates the default setting
+which for single-threaded mode is the same as no limit.
+.IP 3. 4
+Memory usage limit for decompression in bytes
+.RB ( \-\-memlimit\-decompress ).
+A special value of
+.B 0
+indicates the default setting
+which for single-threaded mode is the same as no limit.
+.IP 4. 4
+Since
+.B xz
+5.3.4alpha:
+Memory usage for multi-threaded decompression in bytes
+.RB ( \-\-memlimit\-mt\-decompress ).
+This is never zero because a system-specific default value
+shown in the column 5
+is used if no limit has been specified explicitly.
+This is also never greater than the value in the column 3
+even if a larger value has been specified with
+.BR \-\-memlimit\-mt\-decompress .
+.IP 5. 4
+Since
+.B xz
+5.3.4alpha:
+A system-specific default memory usage limit
+that is used to limit the number of threads
+when compressing with an automatic number of threads
+.RB ( \-\-threads=0 )
+and no memory usage limit has been specified
+.RB ( \-\-memlimit\-compress ).
+This is also used as the default value for
+.BR \-\-memlimit\-mt\-decompress .
+.IP 6. 4
+Since
+.B xz
+5.3.4alpha:
+Number of available processor threads.
+.PP
+In the future, the output of
+.B "xz \-\-robot \-\-info\-memory"
+may have more columns, but never more than a single line.
+.
+.SS Version
+.B "xz \-\-robot \-\-version"
+prints the version number of
+.B xz
+and liblzma in the following format:
+.PP
+.BI XZ_VERSION= XYYYZZZS
+.br
+.BI LIBLZMA_VERSION= XYYYZZZS
+.TP
+.I X
+Major version.
+.TP
+.I YYY
+Minor version.
+Even numbers are stable.
+Odd numbers are alpha or beta versions.
+.TP
+.I ZZZ
+Patch level for stable releases or
+just a counter for development releases.
+.TP
+.I S
+Stability.
+0 is alpha, 1 is beta, and 2 is stable.
+.I S
+should be always 2 when
+.I YYY
+is even.
+.PP
+.I XYYYZZZS
+are the same on both lines if
+.B xz
+and liblzma are from the same XZ Utils release.
+.PP
+Examples: 4.999.9beta is
+.B 49990091
+and
+5.0.0 is
+.BR 50000002 .
+.
.SH "EXIT STATUS"
.TP
.B 0
@@ -3013,8 +3174,8 @@ have the same number of bytes per pixel.
.BR bzip2 (1),
.BR 7z (1)
.PP
-XZ Utils: <https://tukaani.org/xz/>
+XZ Utils: <https://xz.tukaani.org/xz-utils/>
.br
-XZ Embedded: <https://tukaani.org/xz/embedded.html>
+XZ Embedded: <https://xz.tukaani.org/xz-embedded/>
.br
LZMA SDK: <https://7-zip.org/sdk.html>
diff --git a/src/xzdec/xzdec.1 b/src/xzdec/xzdec.1
index 78bc9b4a9813..0ae0fddda182 100644
--- a/src/xzdec/xzdec.1
+++ b/src/xzdec/xzdec.1
@@ -1,10 +1,8 @@
+.\" SPDX-License-Identifier: 0BSD
.\"
.\" Author: Lasse Collin
.\"
-.\" This file has been put into the public domain.
-.\" You can do whatever you want with this file.
-.\"
-.TH XZDEC 1 "2017-04-19" "Tukaani" "XZ Utils"
+.TH XZDEC 1 "2024-01-19" "Tukaani" "XZ Utils"
.SH NAME
xzdec, lzmadec \- Small .xz and .lzma decompressors
.SH SYNOPSIS
@@ -143,4 +141,4 @@ decompressor, consider using XZ Embedded.
.SH "SEE ALSO"
.BR xz (1)
.PP
-XZ Embedded: <https://tukaani.org/xz/embedded.html>
+XZ Embedded: <https://xz.tukaani.org/xz-embedded/>
diff --git a/src/xzdec/xzdec.c b/src/xzdec/xzdec.c
index 556c548d05ad..6fd0be39e67f 100644
--- a/src/xzdec/xzdec.c
+++ b/src/xzdec/xzdec.c
@@ -1,3 +1,5 @@
+// SPDX-License-Identifier: 0BSD
+
///////////////////////////////////////////////////////////////////////////////
//
/// \file xzdec.c
@@ -5,9 +7,6 @@
//
// Author: Lasse Collin
//
-// This file has been put into the public domain.
-// You can do whatever you want with this file.
-//
///////////////////////////////////////////////////////////////////////////////
#include "sysdefs.h"
@@ -16,7 +15,25 @@
#include <stdarg.h>
#include <errno.h>
#include <stdio.h>
-#include <unistd.h>
+
+#ifndef _MSC_VER
+# include <unistd.h>
+#endif
+
+#ifdef HAVE_CAP_RIGHTS_LIMIT
+# include <sys/capsicum.h>
+#endif
+
+#ifdef HAVE_LINUX_LANDLOCK_H
+# include <linux/landlock.h>
+# include <sys/prctl.h>
+# include <sys/syscall.h>
+#endif
+
+#if defined(HAVE_CAP_RIGHTS_LIMIT) || defined(HAVE_PLEDGE) \
+ || defined(HAVE_LINUX_LANDLOCK_H)
+# define ENABLE_SANDBOX 1
+#endif
#include "getopt.h"
#include "tuklib_progname.h"
@@ -25,6 +42,10 @@
#ifdef TUKLIB_DOSLIKE
# include <fcntl.h>
# include <io.h>
+# ifdef _MSC_VER
+# define fileno _fileno
+# define setmode _setmode
+# endif
#endif
@@ -273,9 +294,107 @@ uncompress(lzma_stream *strm, FILE *file, const char *filename)
}
+#ifdef ENABLE_SANDBOX
+static void
+sandbox_enter(int src_fd)
+{
+#if defined(HAVE_CAP_RIGHTS_LIMIT)
+ // Capsicum needs FreeBSD 10.2 or later.
+ cap_rights_t rights;
+
+ if (cap_enter())
+ goto error;
+
+ if (cap_rights_limit(src_fd, cap_rights_init(&rights, CAP_READ)))
+ goto error;
+
+ // If not reading from stdin, remove all capabilities from it.
+ if (src_fd != STDIN_FILENO && cap_rights_limit(
+ STDIN_FILENO, cap_rights_clear(&rights)))
+ goto error;
+
+ if (cap_rights_limit(STDOUT_FILENO, cap_rights_init(&rights, CAP_WRITE)))
+ goto error;
+
+ if (cap_rights_limit(STDERR_FILENO, cap_rights_init(&rights, CAP_WRITE)))
+ goto error;
+
+#elif defined(HAVE_PLEDGE)
+ // pledge() was introduced in OpenBSD 5.9.
+ if (pledge("stdio", ""))
+ goto error;
+
+ (void)src_fd;
+#elif defined(HAVE_LINUX_LANDLOCK_H)
+ int landlock_abi = syscall(SYS_landlock_create_ruleset,
+ (void *)NULL, 0, LANDLOCK_CREATE_RULESET_VERSION);
+
+ if (landlock_abi > 0) {
+ // We support ABI versions 1-3.
+ if (landlock_abi > 3)
+ landlock_abi = 3;
+
+ const struct landlock_ruleset_attr attr = {
+ .handled_access_fs = (1ULL << (12 + landlock_abi)) - 1
+ };
+
+ const int ruleset_fd = syscall(SYS_landlock_create_ruleset,
+ &attr, sizeof(attr), 0U);
+ if (ruleset_fd < 0)
+ goto error;
+
+ // All files we need should have already been opened. Thus,
+ // we don't need to add any rules using landlock_add_rule(2)
+ // before activating the sandbox.
+ if (syscall(SYS_landlock_restrict_self, ruleset_fd, 0U) != 0)
+ goto error;
+ }
+
+ (void)src_fd;
+#else
+# error ENABLE_SANDBOX is defined but no sandboxing method was found.
+#endif
+
+ return;
+
+error:
+#ifdef HAVE_CAP_RIGHTS_LIMIT
+ // If a kernel is configured without capability mode support or
+ // used in an emulator that does not implement the capability
+ // system calls, then the Capsicum system calls will fail and set
+ // errno to ENOSYS. In that case xzdec will silently run without
+ // the sandbox.
+ if (errno == ENOSYS)
+ return;
+#endif
+ my_errorf("Failed to enable the sandbox");
+ exit(EXIT_FAILURE);
+}
+#endif
+
+
int
main(int argc, char **argv)
{
+#ifdef HAVE_PLEDGE
+ // OpenBSD's pledge(2) sandbox.
+ // Initially enable the sandbox slightly more relaxed so that
+ // the process can still open files. This allows the sandbox to
+ // be enabled when parsing command line arguments and decompressing
+ // all files (the more strict sandbox only restricts the last file
+ // that is decompressed).
+ if (pledge("stdio rpath", "")) {
+ my_errorf("Failed to enable the sandbox");
+ exit(EXIT_FAILURE);
+ }
+#endif
+
+#ifdef HAVE_LINUX_LANDLOCK_H
+ // Prevent the process from gaining new privileges. The return
+ // is ignored to keep compatibility with old kernels.
+ (void)prctl(PR_SET_NO_NEW_PRIVS, 1, 0, 0, 0);
+#endif
+
// Initialize progname which we will be used in error messages.
tuklib_progname_init(argv);
@@ -295,24 +414,43 @@ main(int argc, char **argv)
if (optind == argc) {
// No filenames given, decode from stdin.
+#ifdef ENABLE_SANDBOX
+ sandbox_enter(STDIN_FILENO);
+#endif
uncompress(&strm, stdin, "(stdin)");
} else {
// Loop through the filenames given on the command line.
do {
+ FILE *src_file;
+ const char *src_name;
+
// "-" indicates stdin.
if (strcmp(argv[optind], "-") == 0) {
- uncompress(&strm, stdin, "(stdin)");
+ src_file = stdin;
+ src_name = "(stdin)";
} else {
- FILE *file = fopen(argv[optind], "rb");
- if (file == NULL) {
- my_errorf("%s: %s", argv[optind],
+ src_name = argv[optind];
+ src_file = fopen(src_name, "rb");
+ if (src_file == NULL) {
+ my_errorf("%s: %s", src_name,
strerror(errno));
exit(EXIT_FAILURE);
}
-
- uncompress(&strm, file, argv[optind]);
- fclose(file);
}
+#ifdef ENABLE_SANDBOX
+ // Enable the sandbox for the last file. When the
+ // strict sandbox is enabled the process can no
+ // longer open additional files. It is likely that
+ // the most common way to use xzdec is to
+ // decompress a single file, so this fully protects
+ // most use cases.
+ if (optind == argc - 1)
+ sandbox_enter(fileno(src_file));
+#endif
+ uncompress(&strm, src_file, src_name);
+
+ if (src_file != stdin)
+ fclose(src_file);
} while (++optind < argc);
}