On 23/11/2017 18:48, Christoffer Dall wrote: >>> That doesn't solve my need as I want to *only* do the arch vcpu_load for >>> KVM_RUN, I should have been more clear in the commit message. >> >> That's what you want to do, but it might not be what you need to do. > > Well, why would we want to do a lot of work when there's absolutely no > need to? > > I see that this patch is invasive, and that's why I originally proposed > the other approach of recording the ioctl number. Because we need to balance performance and maintainability. The following observation is the important one: > While it may be possible to call kvm_arch_vcpu_load() for a number of > non-KVM_RUN ioctls, it makes the KVM/ARM code more difficult to reason > about, especially after my optimization series, because a lot of things > can now happen, where we have to consider if we're really in the process > of running a vcpu or not. ... because outside ARM I couldn't see any maintainability drawback. Now I understand (or at least, I understand enough to believe you!). The idea of this patch then is okay, but: * x86 can use __vcpu_load/__vcpu_put, because the calls outside the lock are all in the destruction path where no one can concurrently take the lock. So the lock+load and put+unlock variants are not necessary. * Just make a huge series that, one ioctl at a time, pushes down the load/put to the arch-specific functions. No need to figure out where it's actually needed, or at least you can leave it to the architecture maintainers. Thanks, Paolo _______________________________________________ kvmarm mailing list kvmarm@xxxxxxxxxxxxxxxxxxxxx https://lists.cs.columbia.edu/mailman/listinfo/kvmarm