On Tue, 2018-01-23 at 21:28 +0100, Borislav Petkov wrote:
>
> > flags = (flags & EFLAGS_MASK) | X86_EFLAGS_IF;
> > - asm("push %[flags]; popf; call *%[fastop]"
> > - : "=a"(rc) : [fastop]"r"(fop), [flags]"r"(flags));
> > + asm("push %[flags]; popf; " CALL_NOSPEC
> > + : "=a"(rc) : [thunk_target]"r"(fop), [flags]"r"(flags));
>
> Oh, "thunk_target" is magical.You can use THUNK_TARGET(fop), which will be "rm" on 32-bit and avoids register starvation in some cases (I don't think the hyperv calls worked until I did that).
smime.p7s
Description: S/MIME cryptographic signature

