what goes wrong with barrier free atomic_load/store?
John Baldwin
jhb at FreeBSD.org
Tue Apr 26 12:44:43 PDT 2005
On Wednesday 20 April 2005 04:39 pm, John Giacomoni wrote:
> in reading /src/sys/i386/include/atomic.h
>
> I found this comment and I'm having trouble understanding what the
> problem being
> referred to below is.
>
> /*
> * We assume that a = b will do atomic loads and stores. However, on a
> * PentiumPro or higher, reads may pass writes, so for that case we have
> * to use a serializing instruction (i.e. with LOCK) to do the load in
> * SMP kernels. For UP kernels, however, the cache of the single
> processor
> * is always consistent, so we don't need any memory barriers.
> */
>
> can someone give me an example of a situation where one needs to use
> memory barriers to ensure "correctness" when doing writes as above?
>
> the examples I can come up with seem to boil down to requiring locks
> or accepting stale values, given that without a synchronization
> mechanism
> one shouldn't expect two processes to act in any specific order.
>
> In my case I can accept reading a stale value so I'm not understanding
> the
> purpose of only having atomic_load/atomic_store wrappers with memory
> barriers.
>
> I saw a brief discussion where someone proposed barrier free load/store
> but
> don't think I saw any resolution.
>
> thanks,
>
> John G
We use atomic_store_rel() as part of implementing mutexes.
--
John Baldwin <jhb at FreeBSD.org> <>< http://www.FreeBSD.org/~jhb/
"Power Users Use the Power to Serve" = http://www.FreeBSD.org
More information about the freebsd-hackers
mailing list