On Tue, Feb 18, 2014 at 10:23 AM, Peter Sewell <Peter.Sewell@xxxxxxxxxxxx> wrote: > > interesting list. So are you saying that value-range-analysis and > such-like (I say glibly, without really knowing what "such-like" > refers to here) are fundamentally incompatible with > the kernel code No, it's fine to do things like value-range-analysis, it's just that you have to do it on a local scope, and not think that you can see every single write to some variable. And as Paul points out, this is actually generally true even outside of kernels. We may be pretty unique in having some things that are literally done by hardware (eg the page table updates), but we're certainly not unique in having loadable modules or code that the compiler doesn't know about by virtue of being compiled separately (assembly files, JITted, whatever). And we are actually perfectly fine with compiler barriers. One of our most common barriers is simply this: #define barrier() __asm__ __volatile__("": : :"memory") which basically tells the compiler "something changes memory in ways you don't understand, so you cannot assume anything about memory contents". Obviously, a compiler is still perfectly fine optimizing things like local variables etc that haven't had their address taken across such a barrier (regardless of whether those local variables might be spilled to the stack frame etc), but equally obviously we'd require that this kind of thing makes sure that any atomic writes have been finalized by the time the barrier happens (it does *not* imply a memory ordering, just a compiler memory access barrier - we have separate things for ordering requirements, and those obviously often generate actual barrier instructions) And we're likely always going to have things like this, but if C11 atomics end up working well for us, we might have *fewer* of them. Linus -- To unsubscribe from this list: send the line "unsubscribe linux-arch" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html