From 9aeb6a85b561d74d3f42ef67e830133f2a9d4d70 Mon Sep 17 00:00:00 2001 From: Andrew Haley Date: Wed, 2 Aug 2017 17:22:40 +0100 Subject: [PATCH] 8185723: Zero: segfaults on Power PC 32-bit Reviewed-by: roland --- hotspot/src/os_cpu/linux_zero/vm/os_linux_zero.hpp | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/hotspot/src/os_cpu/linux_zero/vm/os_linux_zero.hpp b/hotspot/src/os_cpu/linux_zero/vm/os_linux_zero.hpp index 8814879b367..8e6dc325c4c 100644 --- a/hotspot/src/os_cpu/linux_zero/vm/os_linux_zero.hpp +++ b/hotspot/src/os_cpu/linux_zero/vm/os_linux_zero.hpp @@ -38,10 +38,10 @@ static void atomic_copy64(const volatile void *src, volatile void *dst) { #if defined(PPC32) double tmp; - asm volatile ("lfd %0, 0(%1)\n" - "stfd %0, 0(%2)\n" - : "=f"(tmp) - : "b"(src), "b"(dst)); + asm volatile ("lfd %0, %2\n" + "stfd %0, %1\n" + : "=&f"(tmp), "=Q"(*(volatile double*)dst) + : "Q"(*(volatile double*)src)); #elif defined(S390) && !defined(_LP64) double tmp; asm volatile ("ld %0, 0(%1)\n"