> Hi all,
> One of my coworkers directed my attention to the implementation of
> spinlocks on IA-32. In spin_lock_string, we can read:
> "cmpb $0,%0\n\t" \
> "rep;nop\n\t" \
> "jle 2b\n\t" \
> The "rep;nop" line looks dubious, since the IA-32 programmer's manual from
> Intel (year 2001) mentions that the behaviour of REP is undefined when it
> is not used with string opcodes. BTW, according to the same manual, REP is
> supposed to modify ecx, but it looks like is is not the case here... which
> is fortunate, since ecx is never saved. :-)
> What is the intent behind this "rep;nop" ? Does it really rely on an
> undocumented behaviour ?
Well it's now documented although you have to search a web-site to
find it. Basically, it runs the CPU at low clock-speed when it's
busy-waiting. Since most all spin-locks lock for mere microseconds
it's unlikely that it does anything useful, but it can't hurt.
Penguin : Linux version 2.4.1 on an i686 machine (799.53 BogoMips).
I was going to compile a list of innovations that could be
attributed to Microsoft. Once I realized that Ctrl-Alt-Del
was handled in the BIOS, I found that there aren't any.
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to firstname.lastname@example.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/