Re: [PATCH] x86 bitops.h commentary on instruction reordering

From: Maciej W. Rozycki
Date: Mon Aug 09 2004 - 07:00:27 EST


On Fri, 6 Aug 2004, Marcelo Tosatti wrote:

> Yes correct. *mb() usually imply barrier().
>
> About the flush, each architecture defines its own instruction for doing so,
> PowerPC has "sync" and "isync" instructions (to flush the whole cache and instruction
> cache respectively), MIPS has "sync" and so on..

JFTR, in the absence of an external write-back buffer (which some
processors have) the MIPS "sync" instruction has exactly the semantics of
mb(). There is no MIPS instruction to perform writeback, invalidation,
etc. operations on whole caches -- such operations can only be performed
in the kernel mode on a line-by-line basis and are model-specific, though
some standardisation exists.

Maciej
-
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/