0b5ec94
# HG changeset patch
0b5ec94
# User aph
0b5ec94
# Date 1501690960 -3600
0b5ec94
#      Wed Aug 02 17:22:40 2017 +0100
0b5ec94
# Node ID 91ab2eac9856ec86c16c0bedd32e0b87974ead6f
0b5ec94
# Parent  4e2adbc3d2b512f6b2bf318d2db60f4d1903f8c7
0b5ec94
8185723, PR3553: Zero: segfaults on Power PC 32-bit
0b5ec94
Reviewed-by: roland
0b5ec94
0b5ec94
diff --git openjdk.orig/hotspot/src/os_cpu/linux_zero/vm/os_linux_zero.hpp openjdk/hotspot/src/os_cpu/linux_zero/vm/os_linux_zero.hpp
0b5ec94
--- openjdk.orig/hotspot/src/os_cpu/linux_zero/vm/os_linux_zero.hpp
0b5ec94
+++ openjdk/hotspot/src/os_cpu/linux_zero/vm/os_linux_zero.hpp
0b5ec94
@@ -38,10 +38,10 @@
0b5ec94
   static void atomic_copy64(volatile void *src, volatile void *dst) {
0b5ec94
 #if defined(PPC32)
0b5ec94
     double tmp;
0b5ec94
-    asm volatile ("lfd  %0, 0(%1)\n"
0b5ec94
-                  "stfd %0, 0(%2)\n"
0b5ec94
-                  : "=f"(tmp)
0b5ec94
-                  : "b"(src), "b"(dst));
0b5ec94
+    asm volatile ("lfd  %0, %2\n"
0b5ec94
+                  "stfd %0, %1\n"
0b5ec94
+                  : "=&f"(tmp), "=Q"(*(volatile double*)dst)
0b5ec94
+                  : "Q"(*(volatile double*)src));
0b5ec94
 #elif defined(S390) && !defined(_LP64)
0b5ec94
     double tmp;
0b5ec94
     asm volatile ("ld  %0, 0(%1)\n"