On Tue, Feb 06, 2018 at 01:38:47PM +0100, Christoffer Dall wrote: > On Mon, Nov 27, 2017 at 04:38:04PM +0000, Mark Rutland wrote: > > When pointer authentication is supported, a guest may wish to use it. > > This patch adds the necessary KVM infrastructure for this to work, with > > a semi-lazy context switch of the pointer auth state. > > > > When we schedule a vcpu, > > That's not quite what the code does, the code only does this when we > schedule back a preempted or blocked vcpu thread. Does that only leave the case of the vCPU being scheduled for the first time? Or am I missing something else? [...] > > we disable guest usage of pointer > > authentication instructions and accesses to the keys. While these are > > disabled, we avoid context-switching the keys. When we trap the guest > > trying to use pointer authentication functionality, we change to eagerly > > context-switching the keys, and enable the feature. The next time the > > vcpu is scheduled out/in, we start again. > > > > Pointer authentication consists of address authentication and generic > > authentication, and CPUs in a system might have varied support for > > either. Where support for either feature is not uniform, it is hidden > > from guests via ID register emulation, as a result of the cpufeature > > framework in the host. > > > > Unfortunately, address authentication and generic authentication cannot > > be trapped separately, as the architecture provides a single EL2 trap > > covering both. If we wish to expose one without the other, we cannot > > prevent a (badly-written) guest from intermittently using a feature > > which is not uniformly supported (when scheduled on a physical CPU which > > supports the relevant feature). > > We could choose to always trap and emulate in software in this case, > couldn't we? (not saying we should though). Practically speaking, we cannot. Emulating the feature would be so detrimental to performance as to render the feature useless -- every function prologue/epilogue in a guest would end up trapping to hyp. Additionally, if the algorithm is IMP DEF, we simply don't know how to emulate it. [...] > Also, this patch doesn't let userspace decide if we should hide or > expose the feature to guests, and will expose new system registers to > userspace. That means that on hardware supporting pointer > authentication, with this patch, it's not possible to migrate to a > machine which doesn't have the support. That's probably a good thing > (false sense of security etc.), but I wonder if we should have a > mechanism for userspace to ask for pointer authentication in the guest > and only if that's enabled, do we expose the feature to the guest and in > the system register list to user space as well? Making this an opt-in makes sense to me, given it affects migration. I'll take a look at what we do for SVE. [...] > > When the guest is scheduled on a > > physical CPU lacking the feature, these atetmps will result in an UNDEF > > attempts Whoops. Fixed. [...] > > +static inline void kvm_arch_sched_in(struct kvm_vcpu *vcpu, int cpu) > > +{ > > + kvm_arm_vcpu_ptrauth_disable(vcpu); > > +} > > + > > I still find this decision to begin trapping again quite arbitrary, and > would at least prefer this to be in vcpu_load (which would make the > behavior match the commit text as well). Sure, done. > My expectation would be that if a guest is running software with pointer > authentication enabled, then it's likely to either keep using the > feature, or not use it at all, so I would make this a one-time flag. I think it's likely that some applications will use ptrauth while others do not. Even if the gust OS supports ptrauth, KVM may repeatedly preempt an application that doesn't use it, and we'd win in that case. There are also some rarer cases, like kexec in a guest from a ptrauth-aware kernel to a ptrauth-oblivious one. I don't have strong feelings either way, and I have no data. Thanks, Mark.