aboutsummaryrefslogtreecommitdiff
path: root/src/runtime/internal/atomic/atomic_mipsx.go
diff options
context:
space:
mode:
Diffstat (limited to 'src/runtime/internal/atomic/atomic_mipsx.go')
-rw-r--r--src/runtime/internal/atomic/atomic_mipsx.go14
1 files changed, 13 insertions, 1 deletions
diff --git a/src/runtime/internal/atomic/atomic_mipsx.go b/src/runtime/internal/atomic/atomic_mipsx.go
index 0e2d77ade1..1336b50121 100644
--- a/src/runtime/internal/atomic/atomic_mipsx.go
+++ b/src/runtime/internal/atomic/atomic_mipsx.go
@@ -34,7 +34,7 @@ func spinUnlock(state *uint32)
func lockAndCheck(addr *uint64) {
// ensure 8-byte alignment
if uintptr(unsafe.Pointer(addr))&7 != 0 {
- addr = nil
+ panicUnaligned()
}
// force dereference before taking lock
_ = *addr
@@ -133,12 +133,21 @@ func Loadp(ptr unsafe.Pointer) unsafe.Pointer
func LoadAcq(ptr *uint32) uint32
//go:noescape
+func LoadAcquintptr(ptr *uintptr) uintptr
+
+//go:noescape
func And8(ptr *uint8, val uint8)
//go:noescape
func Or8(ptr *uint8, val uint8)
//go:noescape
+func And(ptr *uint32, val uint32)
+
+//go:noescape
+func Or(ptr *uint32, val uint32)
+
+//go:noescape
func Store(ptr *uint32, val uint32)
//go:noescape
@@ -151,4 +160,7 @@ func StorepNoWB(ptr unsafe.Pointer, val unsafe.Pointer)
func StoreRel(ptr *uint32, val uint32)
//go:noescape
+func StoreReluintptr(ptr *uintptr, val uintptr)
+
+//go:noescape
func CasRel(addr *uint32, old, new uint32) bool