On 24/03/21 22:21, Borislav Petkov wrote:
        if (kaiser_enabled)
                invpcid_flush_one(X86_CR3_PCID_ASID_USER, addr);
+       else
+               asm volatile("invlpg (%0)" ::"r" (addr) : "memory");
+
        invpcid_flush_one(X86_CR3_PCID_ASID_KERN, addr);
  }

I think the kernel ASID flush can also be moved under the "if"?

and the reason why it does, IMHO, is because on AMD, kaiser_enabled is
false because AMD is not affected by Meltdown, which means, there's no
user/kernel pagetables split.

And that also means, you have global TLB entries which means that if you
look at that __native_flush_tlb_single() function, it needs to flush
global TLB entries on CPUs with X86_FEATURE_INVPCID_SINGLE by doing an
INVLPG in the kaiser_enabled=0 case. Errgo, the above hunk.

Makes sense.

Paolo

Reply via email to