linuxppc_2_4_devel patch: 8xx FEC extensions
Dan Malek
dan at embeddededge.com
Fri Jan 3 04:40:13 EST 2003
Tom Rini wrote:
> Erm. That sounds bad. So the values can change under the functions
> feet? Even if the values tested for are only tested by this function,
> that still sounds like a bad idea.
If you look at the code, you will notice that the object that is declared
volatile is part of a shared driver data structure. It isn't a hardware
register. The reason it was originally declared volatile (and is a valid
programming method) was the MII interrupt would set this value, and later
a normal thread of execution would read this value in another function.
These functions can, which is also a valid compiler optimization technique,
cache these global values in a processor register. In order for the normal
thread of execution to see the update from the interrupt handler, you have
to do something to force it to use the shared data structure, not the
optimization. It's no big deal, and quite a common multithreaded programming
practice.
I don't understand Wolfgang's original "multiple access" comment since it's
only accessing a data structure in memory, unless there was some weird software
timing that occurred here due to the additional memory accesses. There shouldn't
be any race conditions even though the status is updated in multiple C program
statements.
Thanks.
-- Dan
** Sent via the linuxppc-embedded mail list. See http://lists.linuxppc.org/
More information about the Linuxppc-embedded
mailing list