Copyright 2014 The Go Authors. All rights reserved. Use of this source code is governed by a BSD-style license that can be found in the LICENSE file.

package atomic

import (
	
)
A Value provides an atomic load and store of a consistently typed value. The zero value for a Value returns nil from Load. Once Store has been called, a Value must not be copied. A Value must not be copied after first use.
type Value struct {
	v interface{}
}
ifaceWords is interface{} internal representation.
Load returns the value set by the most recent Store. It returns nil if there has been no call to Store for this Value.
func ( *Value) () ( interface{}) {
	 := (*ifaceWords)(unsafe.Pointer())
	 := LoadPointer(&.typ)
First store not yet completed.
		return nil
	}
	 := LoadPointer(&.data)
	 := (*ifaceWords)(unsafe.Pointer(&))
	.typ = 
	.data = 
	return
}
Store sets the value of the Value to x. All calls to Store for a given Value must use values of the same concrete type. Store of an inconsistent type panics, as does Store(nil).
func ( *Value) ( interface{}) {
	if  == nil {
		panic("sync/atomic: store of nil value into Value")
	}
	 := (*ifaceWords)(unsafe.Pointer())
	 := (*ifaceWords)(unsafe.Pointer(&))
	for {
		 := LoadPointer(&.typ)
Attempt to start first store. Disable preemption so that other goroutines can use active spin wait to wait for completion; and so that GC does not see the fake type accidentally.
Complete first store.
			StorePointer(&.data, .data)
			StorePointer(&.typ, .typ)
			runtime_procUnpin()
			return
		}
First store in progress. Wait. Since we disable preemption around the first store, we can wait with active spinning.
			continue
First store completed. Check type and overwrite data.
		if  != .typ {
			panic("sync/atomic: store of inconsistently typed value into Value")
		}
		StorePointer(&.data, .data)
		return
	}
}
Disable/enable preemption, implemented in runtime.