[PATCH 5/5] KVM: arm64: Exclude FP ownership from kvm_vcpu_arch
Marc Zyngier
maz at kernel.org
Wed Mar 6 01:43:13 PST 2024
On Mon, 04 Mar 2024 19:10:08 +0000,
Mark Brown <broonie at kernel.org> wrote:
>
> [1 <text/plain; us-ascii (quoted-printable)>]
> On Sat, Mar 02, 2024 at 11:19:35AM +0000, Marc Zyngier wrote:
> > In retrospect, it is fairly obvious that the FP state ownership
> > is only meaningful for a given CPU, and that locating this
> > information in the vcpu was just a mistake.
> >
> > Move the ownership tracking into the host data structure, and
> > rename it from fp_state to fp_owner, which is a better description
> > (name suggested by Mark Brown).
>
> The SME patch series proposes adding an additional state to this
> enumeration which would say if the registers are stored in a format
> suitable for exchange with userspace, that would make this state part of
> the vCPU state. With the addition of SME we can have two vector lengths
> in play so the series proposes picking the larger to be the format for
> userspace registers.
What does this addition have anything to do with the ownership of the
physical register file? Not a lot, it seems.
Specially as there better be no state resident on the CPU when
userspace messes up with it.
>
> We could store this separately to fp_state/owner but it'd still be a
> value stored in the vCPU.
I totally disagree.
> Storing in a format suitable for userspace
> usage all the time when we've got SME would most likely result in
> performance overhead
What performance overhead? Why should we care?
> if nothing else and feels more complicated than
> rewriting the data in the relatively unusual case where userspace looks
> at it. Trying to convert userspace writes into the current layout would
> have issues if the current layout uses the smaller vector length and
> create fragility with ordering issues when loading the guest state.
What ordering issues? If userspace manipulates the guest state, the
guest isn't running. If it is, all bets are off.
>
> The proposal is not the most lovely idea ever but given the architecture
> I think some degree of clunkiness would be unavoidable.
It is only unavoidable if we decide to make a bad job of it.
M.
--
Without deviation from the norm, progress is not possible.
More information about the linux-arm-kernel
mailing list