Re: Q: smp.c && barriers (Was: [PATCH 1/4] generic-smp: remove singleipi fallback for smp_call_function_many())

From: Linus Torvalds
Date: Wed Feb 18 2009 - 12:16:01 EST




On Wed, 18 Feb 2009, Ingo Molnar wrote:
>
> an off-list comment pointed out this piece of information as
> well:
>
> http://www.sandpile.org/ia32/coherent.htm
>
> A WRMSR to one of the x2APIC MSRs (0000_0800h...0000_0BFFh) is
> not guaranteed to be serializing.
>
> So i suspect we should just enclose it in smp_mb() pairs to make
> sure it's a full barrier in both directions?

Why would we care about "both directions"?

I think putting an sfence _before_ the wrmsr (and not even all of them -
just put it in front of the "send IPI" sequence) should be fine. Any other
ordering sounds like just unnecessary overhead to me.

We do want this to be low-overhead, even if we probably don't care _that_
much.

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