Re: [PATCH v2] x86/retpoline: Add LFENCE to the retpoline/RSB filling RSB macros

From: Woodhouse, David
Date: Sun Jan 14 2018 - 12:09:31 EST


On Sun, 2018-01-14 at 16:41 +0100, Borislav Petkov wrote:
> On Sat, Jan 13, 2018 at 05:27:30PM -0600, Tom Lendacky wrote:
> >
> > The PAUSE instruction is currently used in the retpoline and RSB filling
> > macros as a speculation trap.ÂÂThe use of PAUSE was originally suggested
> > because it showed a very, very small difference in the amount of
> > cycles/time used to execute the retpoline as compared to LFENCE.ÂÂOn AMD,
> > the PAUSE instruction is not a serializing instruction, so the pause/jmp
> > loop will use excess power as it is speculated over waiting for return
> > to mispredict to the correct target.
> >
> > The RSB filling macro is applicable to AMD, and, if software is unable to
> > verify that LFENCE is serializing on AMD (possible when running under a
> > hypervisor), the generic retpoline support will be used and, so, is also
> > applicable to AMD.ÂÂKeep the current usage of PAUSE for Intel, but add an
> > LFENCE instruction to the speculation trap for AMD.
> >
> > Signed-off-by: Tom Lendacky <thomas.lendacky@xxxxxxx>
> > ---
> > Âarch/x86/include/asm/nospec-branch.h |ÂÂÂÂ6 +++++-
> > Â1 file changed, 5 insertions(+), 1 deletion(-)
>
> Reviewed-by: Borislav Petkov <bp@xxxxxxx>

Acked-by: Arjan van de Ven <arjan@xxxxxxxxxxxxxxx>
Acked-by: David Woodhouse <dwmw@xxxxxxxxxxxx>

Attachment: smime.p7s
Description: S/MIME cryptographic signature