On Mon, Apr 27, 2015 at 4:35 AM, Borislav Petkov <b...@alien8.de> wrote: > > /* > * Change top 16 bits to be the sign-extension of 47th bit, if this > * changed %rcx, it was not canonical. > */ > ALTERNATIVE "", \ > "shl $(64 - (47+1)), %rcx; \ > sar $(64 - (47+1)), %rcx; \ > cmpq %rcx, %r11; \ > jne opportunistic_sysret_failed", X86_BUG_SYSRET_CANON_RCX
Guys, if we're looking at cycles for this, then don't do the "exact canonical test". and go back to just doing shr $__VIRTUAL_MASK_SHIFT, %rcx jnz opportunistic_sysret_failed which is much smaller. In fact, aim to make the conditional jump be a two-byte one (jump forward to another jump if required - it's a slow-path that doesn't matter at *all* for the taken case), and the end result is just six bytes. That way you can use alternative to replace it with one single noop on AMD. Because dammit, if we're playing these kinds of games, let's do it *right*. No half measures. Linus -- 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/