44 lines
1.4 KiB
Go
44 lines
1.4 KiB
Go
|
// Package atomicx extends sync/atomic.
|
||
|
//
|
||
|
// Sync/atomic fails when using int64 atomic operations on 32 bit platforms
|
||
|
// when the access is not aligned. As specified in the documentation, in
|
||
|
// fact, "it is the caller's responsibility to arrange for 64-bit alignment
|
||
|
// of 64-bit words accessed atomically". For more information on this
|
||
|
// issue, see https://golang.org/pkg/sync/atomic/#pkg-note-BUG.
|
||
|
//
|
||
|
// As explained in CONTRIBUTING.md, probe-cli SHOULD use this package rather
|
||
|
// than sync/atomic to avoid these alignment issues on 32 bit.
|
||
|
//
|
||
|
// It is of course possible to write atomic code using 64 bit variables on a
|
||
|
// 32 bit platform, but that's difficult to do correctly. This package
|
||
|
// provides an easier-to-use interface. We use allocated
|
||
|
// structures protected by a mutex that encapsulate a int64 value.
|
||
|
//
|
||
|
// While there we also added support for atomic float64 operations, again
|
||
|
// by using structures protected by a mutex variable.
|
||
|
package atomicx
|
||
|
|
||
|
import "sync"
|
||
|
|
||
|
// Int64 is an int64 with atomic semantics.
|
||
|
type Int64 struct {
|
||
|
// mu provides mutual exclusion.
|
||
|
mu sync.Mutex
|
||
|
|
||
|
// v is the underlying value.
|
||
|
v int64
|
||
|
}
|
||
|
|
||
|
// Add behaves like atomic.AddInt64.
|
||
|
func (i64 *Int64) Add(delta int64) int64 {
|
||
|
i64.mu.Lock()
|
||
|
defer i64.mu.Unlock()
|
||
|
i64.v += delta
|
||
|
return i64.v
|
||
|
}
|
||
|
|
||
|
// Load behaves like atomic.LoadInt64.
|
||
|
func (i64 *Int64) Load() (v int64) {
|
||
|
return i64.Add(0)
|
||
|
}
|