Re: [PATCH] "volatile considered harmful", take 3
- From: "H. Peter Anvin" <hpa@xxxxxxxxx>
- Date: Fri, 11 May 2007 22:34:13 -0700
Satyam Sharma wrote:
+ - Pointers to data structures in coherent memory which might be
modified
+ by I/O devices can, sometimes, legitimately be volatile. A ring
buffer
+ used by a network adapter, where that adapter changes pointers to
+ indicate which descriptors have been processed, is an example of
this
+ type of situation.
is a legitimate use case for volatile is still not clear to me (I
agree with Alan's
comment in a previous thread that this seems to be a case where a memory
barrier would be applicable^Wbetter, actually). I could be wrong here, so
would be nice if Peter explains why volatile is legitimate here.
Otherwise, it's fine with me.
I don't see why Alan's way is necessarily better; it should work but is
more heavy-handed as it's disabling *all* optimization such as loop
invariants across the barrier.
-hpa
-
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/
- Follow-Ups:
- Re: [PATCH] "volatile considered harmful", take 3
- From: Satyam Sharma
- Re: [PATCH] "volatile considered harmful", take 3
- From: H. Peter Anvin
- Re: [PATCH] "volatile considered harmful", take 3
- References:
- [PATCH] "volatile considered harmful", take 3
- From: Jonathan Corbet
- Re: [PATCH] "volatile considered harmful", take 3
- From: Satyam Sharma
- [PATCH] "volatile considered harmful", take 3
- Prev by Date: Re: [PATCH] "volatile considered harmful", take 2
- Next by Date: Re: [PATCH] "volatile considered harmful", take 3
- Previous by thread: Re: [PATCH] "volatile considered harmful", take 3
- Next by thread: Re: [PATCH] "volatile considered harmful", take 3
- Index(es):
Relevant Pages
|