2005-02-15 01:07:08 +03:00
|
|
|
START_FILE
|
|
|
|
TEXT
|
|
|
|
|
|
|
|
ALIGN(4)
|
|
|
|
|
|
|
|
|
|
|
|
START_FUNC(ompi_atomic_mb)
|
|
|
|
!#PROLOGUE# 0
|
|
|
|
!#PROLOGUE# 1
|
|
|
|
membar #LoadLoad | #LoadStore | #StoreStore | #StoreLoad
|
|
|
|
retl
|
|
|
|
nop
|
|
|
|
END_FUNC(ompi_atomic_mb)
|
|
|
|
|
|
|
|
|
|
|
|
START_FUNC(ompi_atomic_rmb)
|
|
|
|
!#PROLOGUE# 0
|
|
|
|
!#PROLOGUE# 1
|
|
|
|
membar #LoadLoad
|
|
|
|
retl
|
|
|
|
nop
|
|
|
|
END_FUNC(ompi_atomic_rmb)
|
|
|
|
|
|
|
|
|
|
|
|
START_FUNC(ompi_atomic_wmb)
|
|
|
|
!#PROLOGUE# 0
|
|
|
|
!#PROLOGUE# 1
|
|
|
|
membar #StoreStore
|
|
|
|
retl
|
|
|
|
nop
|
|
|
|
END_FUNC(ompi_atomic_wmb)
|
|
|
|
|
|
|
|
|
|
|
|
START_FUNC(ompi_atomic_cmpset_32)
|
|
|
|
!#PROLOGUE# 0
|
|
|
|
!#PROLOGUE# 1
|
2005-02-15 21:50:19 +03:00
|
|
|
casa [%o0] 0x80, %o1, %o2
|
|
|
|
xor %o2, %o1, %o2
|
|
|
|
subcc %g0, %o2, %g0
|
2005-02-15 01:07:08 +03:00
|
|
|
retl
|
|
|
|
subx %g0, -1, %o0
|
|
|
|
END_FUNC(ompi_atomic_cmpset_32)
|
|
|
|
|
|
|
|
|
|
|
|
START_FUNC(ompi_atomic_cmpset_acq_32)
|
|
|
|
!#PROLOGUE# 0
|
|
|
|
!#PROLOGUE# 1
|
2005-02-15 21:50:19 +03:00
|
|
|
casa [%o0] 0x80, %o1, %o2
|
|
|
|
xor %o2, %o1, %o2
|
|
|
|
subcc %g0, %o2, %g0
|
|
|
|
subx %g0, -1, %o0
|
|
|
|
membar #LoadLoad
|
|
|
|
retl
|
|
|
|
sra %o0, 0, %o0
|
2005-02-15 01:07:08 +03:00
|
|
|
END_FUNC(ompi_atomic_cmpset_acq_32)
|
|
|
|
|
|
|
|
|
|
|
|
START_FUNC(ompi_atomic_cmpset_rel_32)
|
|
|
|
!#PROLOGUE# 0
|
|
|
|
!#PROLOGUE# 1
|
2005-02-15 21:50:19 +03:00
|
|
|
membar #StoreStore
|
|
|
|
casa [%o0] 0x80, %o1, %o2
|
|
|
|
xor %o2, %o1, %o2
|
|
|
|
subcc %g0, %o2, %g0
|
|
|
|
retl
|
|
|
|
subx %g0, -1, %o0
|
2005-02-15 01:07:08 +03:00
|
|
|
END_FUNC(ompi_atomic_cmpset_rel_32)
|
|
|
|
|
|
|
|
|
|
|
|
START_FUNC(ompi_atomic_cmpset_64)
|
|
|
|
!#PROLOGUE# 0
|
|
|
|
!#PROLOGUE# 1
|
2005-02-15 21:50:19 +03:00
|
|
|
casxa [%o0] 0x80, %o1, %o2
|
|
|
|
mov 0, %o0
|
|
|
|
xor %o2, %o1, %o2
|
2005-02-15 01:07:08 +03:00
|
|
|
retl
|
2005-02-15 21:50:19 +03:00
|
|
|
movre %o2, 1, %o0
|
2005-02-15 01:07:08 +03:00
|
|
|
END_FUNC(ompi_atomic_cmpset_64)
|
|
|
|
|
|
|
|
|
|
|
|
START_FUNC(ompi_atomic_cmpset_acq_64)
|
|
|
|
!#PROLOGUE# 0
|
|
|
|
!#PROLOGUE# 1
|
2005-02-15 21:50:19 +03:00
|
|
|
casxa [%o0] 0x80, %o1, %o2
|
|
|
|
mov 0, %o0
|
|
|
|
xor %o2, %o1, %o2
|
|
|
|
movre %o2, 1, %o0
|
|
|
|
membar #LoadLoad
|
|
|
|
retl
|
|
|
|
sra %o0, 0, %o0
|
2005-02-15 01:07:08 +03:00
|
|
|
END_FUNC(ompi_atomic_cmpset_acq_64)
|
|
|
|
|
|
|
|
|
|
|
|
START_FUNC(ompi_atomic_cmpset_rel_64)
|
|
|
|
!#PROLOGUE# 0
|
|
|
|
!#PROLOGUE# 1
|
2005-02-15 21:50:19 +03:00
|
|
|
membar #StoreStore
|
|
|
|
casxa [%o0] 0x80, %o1, %o2
|
|
|
|
mov 0, %o0
|
|
|
|
xor %o2, %o1, %o2
|
|
|
|
retl
|
|
|
|
movre %o2, 1, %o0
|
2005-02-15 01:07:08 +03:00
|
|
|
END_FUNC(ompi_atomic_cmpset_rel_64)
|