Commit f316375a authored by Adam Cozzette's avatar Adam Cozzette

Added a workaround to allow building for NaCl

arm-nacl-clang seems to produce a mysterious compiler error when it
encounters __builtin_clzll, so when we are building for NaCl, let's
avoid that in favor of the portable implementation of
Log2FloorNonZero64.
parent b3f3e123
...@@ -44,6 +44,8 @@ ...@@ -44,6 +44,8 @@
#include <stdint.h> #include <stdint.h>
#endif #endif
#include <google/protobuf/stubs/platform_macros.h>
#undef PROTOBUF_LITTLE_ENDIAN #undef PROTOBUF_LITTLE_ENDIAN
#ifdef _WIN32 #ifdef _WIN32
// Assuming windows is always little-endian. // Assuming windows is always little-endian.
...@@ -359,7 +361,12 @@ class Bits { ...@@ -359,7 +361,12 @@ class Bits {
} }
static uint32 Log2FloorNonZero64(uint64 n) { static uint32 Log2FloorNonZero64(uint64 n) {
#if defined(__GNUC__) // arm-nacl-clang runs into an instruction-selection failure when it
// encounters __builtin_clzll:
// https://bugs.chromium.org/p/nativeclient/issues/detail?id=4395
// To work around this, when we build for NaCl we use the portable
// implementation instead.
#if defined(__GNUC__) && !defined(GOOGLE_PROTOBUF_OS_NACL)
return 63 ^ __builtin_clzll(n); return 63 ^ __builtin_clzll(n);
#else #else
return Log2FloorNonZero64_Portable(n); return Log2FloorNonZero64_Portable(n);
......
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