Re: why are some atomic_t's not volatile, while most are?
From: Chris Snook
Date: Mon Aug 06 2007 - 13:54:14 EST
Jerry Jiang wrote:
Is there some feedback on this point ?
Thank you
./Jerry
On Sun, 1 Jul 2007 08:49:37 -0400 (EDT)
"Robert P. J. Day" <rpjday@xxxxxxxxxxxxxx> wrote:
prompted by the earlier post on "volatile"s, is there a reason that
most atomic_t typedefs use volatile int's, while the rest don't?
$ grep "typedef.*struct" $(find . -name atomic.h)
./include/asm-v850/atomic.h:typedef struct { int counter; } atomic_t;
./include/asm-mips/atomic.h:typedef struct { volatile int counter; } atomic_t;
./include/asm-mips/atomic.h:typedef struct { volatile long counter; } atomic64_t;
...
etc, etc. just curious.
If your architecture doesn't support SMP, the volatile keyword doesn't do
anything except add a useless memory fetch. Also, some SMP architectures (i386,
x86_64, s390) provide sufficiently strong guarantees about memory access
ordering that it's not necessary as long as you're using the appropriate
locked/atomic instructions in the atomic operations.
-- Chris
-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/