mirror of
https://github.com/bitcoin/bitcoin.git
synced 2026-06-04 02:02:42 +02:00
Squashed 'src/crc32c/' changes from b5ef9be675..0d624261ef
0d624261ef Merge bitcoin-core/crc32c#2: Merge upstream cac7ca830b Merge commit 'fa5ade41ee480003d9c5af6f43567ba22e4e17e6' into bitcoin-fork fa5ade41ee Fix compilation warnings on ARM64 with old GCC versions. (#52) db08d22129 Updated Travis-CI configuration. (#51) e31619a5b7 Fix GitHub links. (#50) 7fa4c263e8 Update Travis CI config. (#49) a3d9e6d1a4 Updated third_party/ and Travis CI config. (#48) git-subtree-dir: src/crc32c git-subtree-split: 0d624261ef83ab08c953c196540ed18f355add4c
This commit is contained in:
@@ -40,7 +40,15 @@ inline bool CanUseArm64Crc32() {
|
||||
// From 'arch/arm64/include/uapi/asm/hwcap.h' in Linux kernel source code.
|
||||
constexpr unsigned long kHWCAP_PMULL = 1 << 4;
|
||||
constexpr unsigned long kHWCAP_CRC32 = 1 << 7;
|
||||
unsigned long hwcap = (&getauxval != nullptr) ? getauxval(AT_HWCAP) : 0;
|
||||
unsigned long hwcap =
|
||||
#if HAVE_STRONG_GETAUXVAL
|
||||
// Some compilers warn on (&getauxval != nullptr) in the block below.
|
||||
getauxval(AT_HWCAP);
|
||||
#elif HAVE_WEAK_GETAUXVAL
|
||||
(&getauxval != nullptr) ? getauxval(AT_HWCAP) : 0;
|
||||
#else
|
||||
#error This is supposed to be nested inside a check for HAVE_*_GETAUXVAL.
|
||||
#endif // HAVE_STRONG_GETAUXVAL
|
||||
return (hwcap & (kHWCAP_PMULL | kHWCAP_CRC32)) ==
|
||||
(kHWCAP_PMULL | kHWCAP_CRC32);
|
||||
#elif defined(__APPLE__)
|
||||
|
||||
Reference in New Issue
Block a user