2103fd9acd
-- d447fdcb801036cf08197eece193a5a706661120 by Gennadiy Rozental <rogeeff@google.com>: Eliminate the need for static function holding help message. This decreases the cost of ABSL_FLAG abstraction by 120 bytes under clang. PiperOrigin-RevId: 281107806 -- 0aa6b91189f0e8b2381438c33465673a7ae02487 by Derek Mauro <dmauro@google.com>: Disable the weak symbol CCTZ extension in the time test_util on MinGW, which does not support it. PiperOrigin-RevId: 280719769 -- 67322c41c3e776eb541de90fa4526bdb49422eb6 by Abseil Team <absl-team@google.com>: Tune PeriodicSampler implementation (for internal-use only) PiperOrigin-RevId: 280708943 -- 3a48c346340c7ed03816645cd327e1ff07729aa4 by Abseil Team <absl-team@google.com>: Clean up public headers not to have warnings for "-Wcomma" PiperOrigin-RevId: 280695373 -- 981acd1ef3b13a83a84f04f11c8931f4ed4451c9 by Matthew Brown <matthewbr@google.com>: Release absl::int128. PiperOrigin-RevId: 280690817 -- d30fae9d2ec30b81322d2eb5afe7e13e45b4b422 by Derek Mauro <dmauro@google.com>: Fix -Wundef warnings in random platform detection PiperOrigin-RevId: 280669598 GitOrigin-RevId: d447fdcb801036cf08197eece193a5a706661120 Change-Id: Ie5e10e567c54b7de211833607689f233d4ddf734
171 lines
6.4 KiB
C
171 lines
6.4 KiB
C
// Copyright 2017 The Abseil Authors.
|
|
//
|
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
|
// you may not use this file except in compliance with the License.
|
|
// You may obtain a copy of the License at
|
|
//
|
|
// https://www.apache.org/licenses/LICENSE-2.0
|
|
//
|
|
// Unless required by applicable law or agreed to in writing, software
|
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
// See the License for the specific language governing permissions and
|
|
// limitations under the License.
|
|
|
|
#ifndef ABSL_RANDOM_INTERNAL_PLATFORM_H_
|
|
#define ABSL_RANDOM_INTERNAL_PLATFORM_H_
|
|
|
|
// HERMETIC NOTE: The randen_hwaes target must not introduce duplicate
|
|
// symbols from arbitrary system and other headers, since it may be built
|
|
// with different flags from other targets, using different levels of
|
|
// optimization, potentially introducing ODR violations.
|
|
|
|
// -----------------------------------------------------------------------------
|
|
// Platform Feature Checks
|
|
// -----------------------------------------------------------------------------
|
|
|
|
// Currently supported operating systems and associated preprocessor
|
|
// symbols:
|
|
//
|
|
// Linux and Linux-derived __linux__
|
|
// Android __ANDROID__ (implies __linux__)
|
|
// Linux (non-Android) __linux__ && !__ANDROID__
|
|
// Darwin (macOS and iOS) __APPLE__
|
|
// Akaros (http://akaros.org) __ros__
|
|
// Windows _WIN32
|
|
// NaCL __native_client__
|
|
// AsmJS __asmjs__
|
|
// WebAssembly __wasm__
|
|
// Fuchsia __Fuchsia__
|
|
//
|
|
// Note that since Android defines both __ANDROID__ and __linux__, one
|
|
// may probe for either Linux or Android by simply testing for __linux__.
|
|
//
|
|
// NOTE: For __APPLE__ platforms, we use #include <TargetConditionals.h>
|
|
// to distinguish os variants.
|
|
//
|
|
// http://nadeausoftware.com/articles/2012/01/c_c_tip_how_use_compiler_predefined_macros_detect_operating_system
|
|
|
|
#if defined(__APPLE__)
|
|
#include <TargetConditionals.h>
|
|
#endif
|
|
|
|
// -----------------------------------------------------------------------------
|
|
// Architecture Checks
|
|
// -----------------------------------------------------------------------------
|
|
|
|
// These preprocessor directives are trying to determine CPU architecture,
|
|
// including necessary headers to support hardware AES.
|
|
//
|
|
// ABSL_ARCH_{X86/PPC/ARM} macros determine the platform.
|
|
#if defined(__x86_64__) || defined(__x86_64) || defined(_M_AMD64) || \
|
|
defined(_M_X64)
|
|
#define ABSL_ARCH_X86_64
|
|
#elif defined(__i386) || defined(_M_IX86)
|
|
#define ABSL_ARCH_X86_32
|
|
#elif defined(__aarch64__) || defined(__arm64__) || defined(_M_ARM64)
|
|
#define ABSL_ARCH_AARCH64
|
|
#elif defined(__arm__) || defined(__ARMEL__) || defined(_M_ARM)
|
|
#define ABSL_ARCH_ARM
|
|
#elif defined(__powerpc64__) || defined(__PPC64__) || defined(__powerpc__) || \
|
|
defined(__ppc__) || defined(__PPC__)
|
|
#define ABSL_ARCH_PPC
|
|
#else
|
|
// Unsupported architecture.
|
|
// * https://sourceforge.net/p/predef/wiki/Architectures/
|
|
// * https://msdn.microsoft.com/en-us/library/b0084kay.aspx
|
|
// * for gcc, clang: "echo | gcc -E -dM -"
|
|
#endif
|
|
|
|
// -----------------------------------------------------------------------------
|
|
// Attribute Checks
|
|
// -----------------------------------------------------------------------------
|
|
|
|
// ABSL_RANDOM_INTERNAL_RESTRICT annotates whether pointers may be considered
|
|
// to be unaliased.
|
|
#if defined(__clang__) || defined(__GNUC__)
|
|
#define ABSL_RANDOM_INTERNAL_RESTRICT __restrict__
|
|
#elif defined(_MSC_VER)
|
|
#define ABSL_RANDOM_INTERNAL_RESTRICT __restrict
|
|
#else
|
|
#define ABSL_RANDOM_INTERNAL_RESTRICT
|
|
#endif
|
|
|
|
// ABSL_HAVE_ACCELERATED_AES indicates whether the currently active compiler
|
|
// flags (e.g. -maes) allow using hardware accelerated AES instructions, which
|
|
// implies us assuming that the target platform supports them.
|
|
#define ABSL_HAVE_ACCELERATED_AES 0
|
|
|
|
#if defined(ABSL_ARCH_X86_64)
|
|
|
|
#if defined(__AES__) || defined(__AVX__)
|
|
#undef ABSL_HAVE_ACCELERATED_AES
|
|
#define ABSL_HAVE_ACCELERATED_AES 1
|
|
#endif
|
|
|
|
#elif defined(ABSL_ARCH_PPC)
|
|
|
|
// Rely on VSX and CRYPTO extensions for vcipher on PowerPC.
|
|
#if (defined(__VEC__) || defined(__ALTIVEC__)) && defined(__VSX__) && \
|
|
defined(__CRYPTO__)
|
|
#undef ABSL_HAVE_ACCELERATED_AES
|
|
#define ABSL_HAVE_ACCELERATED_AES 1
|
|
#endif
|
|
|
|
#elif defined(ABSL_ARCH_ARM) || defined(ABSL_ARCH_AARCH64)
|
|
|
|
// http://infocenter.arm.com/help/topic/com.arm.doc.ihi0053c/IHI0053C_acle_2_0.pdf
|
|
// Rely on NEON+CRYPTO extensions for ARM.
|
|
#if defined(__ARM_NEON) && defined(__ARM_FEATURE_CRYPTO)
|
|
#undef ABSL_HAVE_ACCELERATED_AES
|
|
#define ABSL_HAVE_ACCELERATED_AES 1
|
|
#endif
|
|
|
|
#endif
|
|
|
|
// NaCl does not allow AES.
|
|
#if defined(__native_client__)
|
|
#undef ABSL_HAVE_ACCELERATED_AES
|
|
#define ABSL_HAVE_ACCELERATED_AES 0
|
|
#endif
|
|
|
|
// ABSL_RANDOM_INTERNAL_AES_DISPATCH indicates whether the currently active
|
|
// platform has, or should use run-time dispatch for selecting the
|
|
// acclerated Randen implementation.
|
|
#define ABSL_RANDOM_INTERNAL_AES_DISPATCH 0
|
|
|
|
#if defined(ABSL_ARCH_X86_64)
|
|
// Dispatch is available on x86_64
|
|
#undef ABSL_RANDOM_INTERNAL_AES_DISPATCH
|
|
#define ABSL_RANDOM_INTERNAL_AES_DISPATCH 1
|
|
#elif defined(__linux__) && defined(ABSL_ARCH_PPC)
|
|
// Or when running linux PPC
|
|
#undef ABSL_RANDOM_INTERNAL_AES_DISPATCH
|
|
#define ABSL_RANDOM_INTERNAL_AES_DISPATCH 1
|
|
#elif defined(__linux__) && defined(ABSL_ARCH_AARCH64)
|
|
// Or when running linux AArch64
|
|
#undef ABSL_RANDOM_INTERNAL_AES_DISPATCH
|
|
#define ABSL_RANDOM_INTERNAL_AES_DISPATCH 1
|
|
#elif defined(__linux__) && defined(ABSL_ARCH_ARM) && (__ARM_ARCH >= 8)
|
|
// Or when running linux ARM v8 or higher.
|
|
// (This captures a lot of Android configurations.)
|
|
#undef ABSL_RANDOM_INTERNAL_AES_DISPATCH
|
|
#define ABSL_RANDOM_INTERNAL_AES_DISPATCH 1
|
|
#endif
|
|
|
|
// NaCl does not allow dispatch.
|
|
#if defined(__native_client__)
|
|
#undef ABSL_RANDOM_INTERNAL_AES_DISPATCH
|
|
#define ABSL_RANDOM_INTERNAL_AES_DISPATCH 0
|
|
#endif
|
|
|
|
// iOS does not support dispatch, even on x86, since applications
|
|
// should be bundled as fat binaries, with a different build tailored for
|
|
// each specific supported platform/architecture.
|
|
#if (defined(TARGET_OS_IPHONE) && TARGET_OS_IPHONE) || \
|
|
(defined(TARGET_OS_IPHONE_SIMULATOR) && TARGET_OS_IPHONE_SIMULATOR)
|
|
#undef ABSL_RANDOM_INTERNAL_AES_DISPATCH
|
|
#define ABSL_RANDOM_INTERNAL_AES_DISPATCH 0
|
|
#endif
|
|
|
|
#endif // ABSL_RANDOM_INTERNAL_PLATFORM_H_
|