diff options
author | Lasse Collin <lasse.collin@tukaani.org> | 2019-12-31 00:18:24 +0200 |
---|---|---|
committer | Lasse Collin <lasse.collin@tukaani.org> | 2019-12-31 00:18:24 +0200 |
commit | 77bc5bc6dd67056cfd5888520ac930cfc57b4516 (patch) | |
tree | 8c9e30726f38ae255629dcf2dd52c0de6be85b24 /src/liblzma/common/stream_buffer_decoder.c | |
parent | Tests: Hopefully fix test_check.c to work on EBCDIC systems. (diff) | |
download | xz-77bc5bc6dd67056cfd5888520ac930cfc57b4516.tar.xz |
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
Diffstat (limited to 'src/liblzma/common/stream_buffer_decoder.c')
0 files changed, 0 insertions, 0 deletions