From: Nick Piggin <nickpiggin@yahoo.com.au>
To: David Howells <dhowells@redhat.com>
Cc: torvalds@osdl.org, akpm@osdl.org, linux-kernel@vger.kernel.org,
linux-arch@vger.kernel.org, davem@davemloft.net
Subject: Re: [PATCH] Fix memory barrier docs wrt atomic ops
Date: Wed, 05 Apr 2006 19:32:25 +1000 [thread overview]
Message-ID: <44338EA9.3020102@yahoo.com.au> (raw)
In-Reply-To: <29800.1144228639@warthog.cambridge.redhat.com>
David Howells wrote:
> ATOMIC OPERATIONS
> -----------------
>
> -Though they are technically interprocessor interaction considerations, atomic
> -operations are noted specially as they do _not_ generally imply memory
> -barriers. The possible offenders include:
> +Whilst they are technically interprocessor interaction considerations, atomic
> +operations are noted specially as some of them imply full memory barriers and
> +some don't, but they're very heavily relied on as a group throughout the
> +kernel.
> +
> +Any atomic_t operation, for instance, that returns a value implies an
> +SMP-conditional general memory barrier (smp_mb()) on each side of the actual
> +operation. These include:
Actually: this only applies to operations which _both_ modify their atomic_t
operand and return a value. Eg. atomic_read() does not have barrier semantics.
>
> - xchg();
> - cmpxchg();
> - test_and_set_bit();
> - test_and_clear_bit();
> - test_and_change_bit();
> atomic_cmpxchg();
> atomic_inc_return();
> atomic_dec_return();
> @@ -1283,20 +1283,30 @@ barriers. The possible offenders includ
> atomic_add_negative();
> atomic_add_unless();
>
> -These may be used for such things as implementing LOCK operations or controlling
> -the lifetime of objects by decreasing their reference counts. In such cases
> -they need preceding memory barriers.
>
> -The following may also be possible offenders as they may be used as UNLOCK
> -operations.
> +The following, however, do _not_ imply memory barrier effects:
> +
> + xchg();
> + cmpxchg();
> + test_and_set_bit();
> + test_and_clear_bit();
> + test_and_change_bit();
> +
> +These may be used for such things as implementing LOCK-class operations. In
> +such cases they need explicit memory barriers.
> +
I believe all the bitops are essentially the same as the atomic semantics.
That is, if they change their operand and return something, they are full
barriers both ways.
atomic_ops.txt says of them:
"These routines, like the atomic_t counter operations returning values,
require explicit memory barrier semantics around their execution."
I think we'd have problems at least with TestSetPageLocked if this were
not the case.
I'm not sure if I like the words imply, explicit, implicit, etc. They're
a bit confusing. provide, semantics may be better?
> +The following are also potential offenders as they may be used as UNLOCK-class
> +operations, amongst other things, but do _not_ imply memory barriers either:
>
> set_bit();
> clear_bit();
> change_bit();
> atomic_set();
>
> +With these the appropriate explicit memory barrier should be used if necessary.
> +
>
In particular, when clearing a bit to signal the end of a critical section,
clear_bit must be preceeded by smp_mb__before_clear_bit();
--
SUSE Labs, Novell Inc.
Send instant messages to your online friends http://au.messenger.yahoo.com
next prev parent reply other threads:[~2006-04-06 6:31 UTC|newest]
Thread overview: 3+ messages / expand[flat|nested] mbox.gz Atom feed top
2006-04-05 9:17 [PATCH] Fix memory barrier docs wrt atomic ops David Howells
2006-04-05 9:32 ` Nick Piggin [this message]
2006-04-06 9:53 ` [PATCH] Futher fix " David Howells
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=44338EA9.3020102@yahoo.com.au \
--to=nickpiggin@yahoo.com.au \
--cc=akpm@osdl.org \
--cc=davem@davemloft.net \
--cc=dhowells@redhat.com \
--cc=linux-arch@vger.kernel.org \
--cc=linux-kernel@vger.kernel.org \
--cc=torvalds@osdl.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox