Commit 689c815b authored by Neil Conway's avatar Neil Conway

Add a comment describing the requirement that pointers into shared memory

that is protected by a spinlock must be volatile, per recent discussion.
parent 4a6dcf03
...@@ -7,21 +7,21 @@ ...@@ -7,21 +7,21 @@
* The hardware-independent interface to spinlocks is defined by the * The hardware-independent interface to spinlocks is defined by the
* typedef "slock_t" and these macros: * typedef "slock_t" and these macros:
* *
* void SpinLockInit(slock_t *lock) * void SpinLockInit(volatile slock_t *lock)
* Initialize a spinlock (to the unlocked state). * Initialize a spinlock (to the unlocked state).
* *
* void SpinLockAcquire(slock_t *lock) * void SpinLockAcquire(volatile slock_t *lock)
* Acquire a spinlock, waiting if necessary. * Acquire a spinlock, waiting if necessary.
* Time out and abort() if unable to acquire the lock in a * Time out and abort() if unable to acquire the lock in a
* "reasonable" amount of time --- typically ~ 1 minute. * "reasonable" amount of time --- typically ~ 1 minute.
* Cancel/die interrupts are held off until the lock is released. * Cancel/die interrupts are held off until the lock is released.
* *
* void SpinLockRelease(slock_t *lock) * void SpinLockRelease(volatile slock_t *lock)
* Unlock a previously acquired lock. * Unlock a previously acquired lock.
* Release the cancel/die interrupt holdoff. * Release the cancel/die interrupt holdoff.
* *
* void SpinLockAcquire_NoHoldoff(slock_t *lock) * void SpinLockAcquire_NoHoldoff(volatile slock_t *lock)
* void SpinLockRelease_NoHoldoff(slock_t *lock) * void SpinLockRelease_NoHoldoff(volatile slock_t *lock)
* Same as above, except no interrupt holdoff processing is done. * Same as above, except no interrupt holdoff processing is done.
* This pair of macros may be used when there is a surrounding * This pair of macros may be used when there is a surrounding
* interrupt holdoff. * interrupt holdoff.
...@@ -33,14 +33,24 @@ ...@@ -33,14 +33,24 @@
* Callers must beware that the macro argument may be evaluated multiple * Callers must beware that the macro argument may be evaluated multiple
* times! * times!
* *
* The macros are implemented in terms of hardware-dependent macros * CAUTION: Care must be taken to ensure that loads and stores of
* shared memory values are not rearranged around spinlock acquire
* and release. This is done using the "volatile" qualifier: the C
* standard states that loads and stores of volatile objects cannot
* be rearranged *with respect to other volatile objects*. The
* spinlock is always written through a volatile pointer by the
* spinlock macros, but this is not sufficient by itself: code that
* protects shared data with a spinlock MUST reference that shared
* data through a volatile pointer.
*
* These macros are implemented in terms of hardware-dependent macros
* supplied by s_lock.h. * supplied by s_lock.h.
* *
* *
* Portions Copyright (c) 1996-2005, PostgreSQL Global Development Group * Portions Copyright (c) 1996-2005, PostgreSQL Global Development Group
* Portions Copyright (c) 1994, Regents of the University of California * Portions Copyright (c) 1994, Regents of the University of California
* *
* $PostgreSQL: pgsql/src/include/storage/spin.h,v 1.25 2004/12/31 22:03:42 pgsql Exp $ * $PostgreSQL: pgsql/src/include/storage/spin.h,v 1.26 2005/10/13 06:17:34 neilc Exp $
* *
*------------------------------------------------------------------------- *-------------------------------------------------------------------------
*/ */
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment