Commit 051aa980 by Copybara-Service

Merge pull request #1452 from niranjan-nilakantan:niranjan-nilakantan/issue1358

PiperOrigin-RevId: 534179290
Change-Id: I9ad24518cc6a336fbaf602269fb01319491c8b60
parents 02d1f5e1 bd748714
......@@ -34,9 +34,11 @@ namespace crc_internal {
#if defined(__x86_64__) || defined(_M_X64)
namespace {
#if !defined(_WIN32) && !defined(_WIN64)
#if ABSL_HAVE_BUILTIN(__cpuid)
// MSVC-equivalent __cpuid intrinsic declaration for clang-like compilers
// for non-Windows build environments.
extern void __cpuid(int[4], int);
#elif !defined(_WIN32) && !defined(_WIN64)
// MSVC defines this function for us.
// https://learn.microsoft.com/en-us/cpp/intrinsics/cpuid-cpuidex
static void __cpuid(int cpu_info[4], int info_type) {
......@@ -47,6 +49,8 @@ static void __cpuid(int cpu_info[4], int info_type) {
}
#endif // !defined(_WIN32) && !defined(_WIN64)
namespace {
enum class Vendor {
kUnknown,
kIntel,
......
......@@ -45,6 +45,10 @@
#if defined(ABSL_INTERNAL_USE_X86_CPUID)
#if defined(_WIN32) || defined(_WIN64)
#include <intrin.h> // NOLINT(build/include_order)
#elif ABSL_HAVE_BUILTIN(__cpuid)
// MSVC-equivalent __cpuid intrinsic declaration for clang-like compilers
// for non-Windows build environments.
extern void __cpuid(int[4], int);
#else
// MSVC-equivalent __cpuid intrinsic function.
static void __cpuid(int cpu_info[4], int info_type) {
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment