Blame SOURCES/8185723-pr3553.patch

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