On Mon, 3 Mar 2008, Pavel Machek wrote:Here's an updated version of the patch, including the issue Alan Cox brought up. Alan Stern ----------------------------------------------------------------- Atomicity of reads of write for pointers and integral types (other than long long) should be documented, along with the limitations imposed by the compiler. Signed-off-by: Alan Stern <stern@rowland.harvard.edu> --- Index: usb-2.6/Documentation/atomic_ops.txt =================================================================== --- usb-2.6.orig/Documentation/atomic_ops.txt +++ usb-2.6/Documentation/atomic_ops.txt @@ -21,6 +21,24 @@ local_t is very similar to atomic_t. If updated by one CPU, local_t is probably more appropriate. Please see Documentation/local_ops.txt for the semantics of local_t. +For all properly-aligned pointer and integral types other than long +long, the kernel requires simple reads and writes to be atomic with +respect to each other. That is, if one CPU reads a pointer value at +the same time as another CPU overwrites the pointer, it is guaranteed +that the reader will obtain either the old or the new value of the +pointer, never some mish-mash combination of the two. Likewise, if +one CPU writes a long value at the same time as another CPU does, it +is guaranteed that one or the other of the values will end up stored +in memory, not some mish-mash combination of bits. + +Thus, if all you need is atomicity of reading and writing then you can +use plain old ints, longs, or pointers; you don't need to use +atomic_t. But note: This guarantee emphatically does not apply to +long long values or unaligned values! Note also that gcc does not +guarantee to compile all C assignment expressions into simple writes. +For example, a statement like "x = a + b" might cause gcc to emit code +equivalent to "x = a; x += b", which is decidedly non-atomic. + The first operations to implement for atomic_t's are the initializers and plain reads. --
| Rafael J. Wysocki | Re: 2.6.27-rc1 mtrr fixes do not work |
| Denis Cheng | [PATCH] trivial: the memset operation on a automatic array variable should be opti... |
| Andrea Arcangeli | Re: [PATCH 02 of 11] get_task_mm |
| Andrew Morton | Re: [GIT *] Allow request_firmware() to be satisfied from in-kernel, use it in mor... |
git: | |
| Johannes Schindelin | Re: git-clean buglet |
| Sam Vilain | [RFC] Authenticate push via PGP signature, not SSH |
| Jon Smirl | ! [rejected] master -> master (non-fast forward) |
| Luben Tuikov | Which module contains SVN/Core.pm in CPAN |
| Julien TOUCHE | setting up ssh tunnel/vpn |
| Darrin Chandler | Re: SMTP flood + spamdb |
| Markus Wernig | host to host ipsec link |
| Frank Bax | QEMU crashes |
| Jussi Kivilinna | [PATCH net-next-2.6 v4 1/2] net_sched: add size table functions |
| Patrick McHardy | Re: pkt_sched: add DRR scheduler |
| Eric Dumazet | [PATCH] fs: pipe/sockets/anon dentries should not have a parent |
| Matheos Worku | 2.6.24 BUG: soft lockup - CPU#X |
