On Fri, May 01, 2015 at 09:03:32AM -0700, Linus Torvalds wrote: > On Fri, May 1, 2015 at 8:16 AM, Peter Zijlstra <pet...@infradead.org> wrote: > > PPS. Jakub, I see gcc5.1 still hasn't got output operands for asm goto; > > is this something we can get 'fixed' ? > > I suspect the problem is that now the particular register allocation > choices are basically not just around the asm, they'd affect the > target labels of the asm too. > > I think that for the kernel, it would *generally* be ok to just say > that the outputs are only valid in the case the asm does *not* branch > out, assuming that the *clobbers* obviously clobber things regardless. > Keeping the register allocation for the asm itself still purely > "local" to the asm. > > Something with a memory output we could just turn into a memory > clobber (so we could do the test-and-change bits today without using > any outputs - just mark memory clobbered).
The risk is of course that we'll cause too much stores and reloads around them and regress instead of win. A single variable clobber might be a solution here ? -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majord...@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/