[x265] [RESEND] source/test/testharness.h: don't redefine `__rdtsc()` builtin

Sergei Trofimovich slyich at gmail.com
Tue Aug 13 08:00:20 UTC 2024


On darwin clang-16 provides `__rdtsc()` builtin. As a result the build
fails in `nixpkgs` as:

    source/test/testharness.h:78:24: error: static declaration of '__rdtsc' follows non-static declaration
    static inline uint32_t __rdtsc(void)
                           ^
    x265_3.6/source/test/testharness.h:78:24: note: '__rdtsc' is a builtin with type 2

The change avoid redefinition on targets that define `__rdtsc()` builtin.
---
 source/test/testharness.h | 2 ++
 1 file changed, 2 insertions(+)

diff --git a/source/test/testharness.h b/source/test/testharness.h
index 5b8e274b1..357f4154a 100644
--- a/source/test/testharness.h
+++ b/source/test/testharness.h
@@ -69,6 +69,8 @@ protected:
 #include <intrin.h>
 #elif HAVE_RDTSC
 #include <intrin.h>
+#elif defined(__has_builtin) && __has_builtin(__rdtsc)
+/* compiler-provided builtin */
 #elif (!defined(__APPLE__) && (defined (__GNUC__) && (defined(__x86_64__) || defined(__i386__))))
 #include <x86intrin.h>
 #elif ( !defined(__APPLE__) && defined (__GNUC__) && defined(__ARM_NEON__))
-- 
2.45.2



More information about the x265-devel mailing list