comparison src/os_cpu/linux_sparc/vm/atomic_linux_sparc.inline.hpp @ 17940:7f77d17d0f13

8042059: Various fixes to linux/sparc Reviewed-by: twisti, kvn
author mikael
date Tue, 29 Apr 2014 22:05:10 -0700
parents 46c544b8fbfc
children
comparison
equal deleted inserted replaced
17939:0fb5b60ab4a2 17940:7f77d17d0f13
76 intptr_t rv; 76 intptr_t rv;
77 #ifdef _LP64 77 #ifdef _LP64
78 __asm__ volatile( 78 __asm__ volatile(
79 "1: \n\t" 79 "1: \n\t"
80 " ldx [%2], %%o2\n\t" 80 " ldx [%2], %%o2\n\t"
81 " add %0, %%o2, %%o3\n\t" 81 " add %1, %%o2, %%o3\n\t"
82 " casx [%2], %%o2, %%o3\n\t" 82 " casx [%2], %%o2, %%o3\n\t"
83 " cmp %%o2, %%o3\n\t" 83 " cmp %%o2, %%o3\n\t"
84 " bne %%xcc, 1b\n\t" 84 " bne %%xcc, 1b\n\t"
85 " nop\n\t" 85 " nop\n\t"
86 " add %0, %%o2, %0\n\t" 86 " add %1, %%o2, %0\n\t"
87 : "=r" (rv) 87 : "=r" (rv)
88 : "r" (add_value), "r" (dest) 88 : "r" (add_value), "r" (dest)
89 : "memory", "o2", "o3"); 89 : "memory", "o2", "o3");
90 #else 90 #else
91 __asm__ volatile( 91 __asm__ volatile(