< prev index next >
src/os_cpu/linux_sparc/vm/atomic_linux_sparc.hpp
Print this page
rev 13452 : imported patch Atomic_cmpxchg
rev 13453 : imported patch Atomic_add
rev 13454 : [mq]: Atomic_add_v2
*** 49,60 ****
inline void Atomic::dec_ptr(volatile intptr_t* dest) { (void)add_ptr(-1, dest); }
inline void Atomic::dec_ptr(volatile void* dest) { (void)add_ptr(-1, dest); }
inline jlong Atomic::load(const volatile jlong* src) { return *src; }
! inline jint Atomic::add (jint add_value, volatile jint* dest) {
! intptr_t rv;
__asm__ volatile(
"1: \n\t"
" ld [%2], %%o2\n\t"
" add %1, %%o2, %%o3\n\t"
" cas [%2], %%o2, %%o3\n\t"
--- 49,73 ----
inline void Atomic::dec_ptr(volatile intptr_t* dest) { (void)add_ptr(-1, dest); }
inline void Atomic::dec_ptr(volatile void* dest) { (void)add_ptr(-1, dest); }
inline jlong Atomic::load(const volatile jlong* src) { return *src; }
! template<size_t byte_size>
! struct Atomic::PlatformAdd
! : Atomic::AddAndFetch<Atomic::PlatformAdd<byte_size> >
! {
! template<typename I, typename D>
! D add_and_fetch(I add_value, D volatile* dest) const;
! };
!
! template<>
! template<typename I, typename D>
! inline D Atomic::PlatformAdd<4>::add_and_fetch(I add_value, D volatile* dest) const {
! STATIC_CAST(4 == sizeof(I));
! STATIC_CAST(4 == sizeof(D));
!
! D rv;
__asm__ volatile(
"1: \n\t"
" ld [%2], %%o2\n\t"
" add %1, %%o2, %%o3\n\t"
" cas [%2], %%o2, %%o3\n\t"
*** 66,77 ****
: "r" (add_value), "r" (dest)
: "memory", "o2", "o3");
return rv;
}
! inline intptr_t Atomic::add_ptr(intptr_t add_value, volatile intptr_t* dest) {
! intptr_t rv;
__asm__ volatile(
"1: \n\t"
" ldx [%2], %%o2\n\t"
" add %1, %%o2, %%o3\n\t"
" casx [%2], %%o2, %%o3\n\t"
--- 79,94 ----
: "r" (add_value), "r" (dest)
: "memory", "o2", "o3");
return rv;
}
! template<typename I, typename D>
! inline D Atomic::PlatformAdd<8>::add_and_fetch(I add_value, D volatile* dest) const {
! STATIC_CAST(8 == sizeof(I));
! STATIC_CAST(8 == sizeof(D));
!
! D rv;
__asm__ volatile(
"1: \n\t"
" ldx [%2], %%o2\n\t"
" add %1, %%o2, %%o3\n\t"
" casx [%2], %%o2, %%o3\n\t"
*** 83,96 ****
: "r" (add_value), "r" (dest)
: "memory", "o2", "o3");
return rv;
}
- inline void* Atomic::add_ptr(intptr_t add_value, volatile void* dest) {
- return (void*)add_ptr((intptr_t)add_value, (volatile intptr_t*)dest);
- }
inline jint Atomic::xchg (jint exchange_value, volatile jint* dest) {
intptr_t rv = exchange_value;
__asm__ volatile(
" swap [%2],%1\n\t"
--- 100,112 ----
: "r" (add_value), "r" (dest)
: "memory", "o2", "o3");
return rv;
}
+ template<>
+ struct Atomic::PlatformAdd<2>: Atomic::AddShortUsingInt {};
inline jint Atomic::xchg (jint exchange_value, volatile jint* dest) {
intptr_t rv = exchange_value;
__asm__ volatile(
" swap [%2],%1\n\t"
< prev index next >