]> granicus.if.org Git - python/commitdiff
Issue #18028: Fix aliasing issue in READ_TIMESTAMP() of ceval.c on x86_64,
authorVictor Stinner <victor.stinner@gmail.com>
Fri, 12 Dec 2014 12:19:00 +0000 (13:19 +0100)
committerVictor Stinner <victor.stinner@gmail.com>
Fri, 12 Dec 2014 12:19:00 +0000 (13:19 +0100)
when Python is configure with --with-tsc. Patch written by Christian Heimes.

Python/ceval.c

index 682a1e7e48a8b076469ae4945563018ec04f14a8..fa6bb60517ba112cc554ed9a2bbf24e72988402a 100644 (file)
@@ -66,9 +66,11 @@ ppc_getcounter(uint64 *v)
    even in 64-bit mode, we need to use "a" and "d" for the lower and upper
    32-bit pieces of the result. */
 
-#define READ_TIMESTAMP(val) \
-    __asm__ __volatile__("rdtsc" : \
-                         "=a" (((int*)&(val))[0]), "=d" (((int*)&(val))[1]));
+#define READ_TIMESTAMP(val) do {                        \
+    unsigned int h, l;                                  \
+    __asm__ __volatile__("rdtsc" : "=a" (l), "=d" (h)); \
+    (val) = ((uint64)l) | (((uint64)h) << 32);          \
+    } while(0)
 
 
 #else