On 3/15/24 16:07, Bibo Mao wrote:
Instruction cpucfg can be used to get processor features. And there
is trap exception when it is executed in VM mode, and also it is
to provide cpu features to VM. On real hardware cpucfg area 0 - 20
is used. Here one specified area 0x40000000 -- 0x400000ff is used
for KVM hypervisor to privide PV features, and the area can be extended
for other hypervisors in future. This area will never be used for
real HW, it is only used by software.
Signed-off-by: Bibo Mao <maobibo@xxxxxxxxxxx>
---
arch/loongarch/include/asm/inst.h | 1 +
arch/loongarch/include/asm/loongarch.h | 10 +++++
arch/loongarch/kvm/exit.c | 59 +++++++++++++++++++-------
3 files changed, 54 insertions(+), 16 deletions(-)
Sorry for the late reply, but I think it may be a bit non-constructive
to repeatedly submit the same code without due explanation in our
previous review threads. Let me try to recollect some of the details
though...
If I remember correctly, during the previous reviews, it was mentioned
that the only upsides of using CPUCFG were:
- it was exactly identical to the x86 approach,
- it would not require access to the LoongArch Reference Manual Volume 3
to use, and
- it was plain old data.
But, for the first point, we don't have to follow x86 convention after
all. The second reason might be compelling, but on the one hand that's
another problem orthogonal to the current one, and on the other hand
HVCL is:
- already effectively public because of the fact that this very patchset
is public,
- its semantics is trivial to implement even without access to the LVZ
manual, because of its striking similarity with SYSCALL, and
- by being a function call, we reserve the possibility for hypervisors
to invoke logic for self-identification purposes, even if this is likely
overkill from today's perspective.
And, even if we decide that using HVCL for self-identification is
overkill after all, we still have another choice that's IOCSR. We
already read LOONGARCH_IOCSR_FEATURES (0x8) for its bit 11 (IOCSRF_VM)
to populate the CPU_FEATURE_HYPERVISOR bit, and it's only natural that
we put the identification word in the IOCSR space. As far as I can see,
the IOCSR space is plenty and equally available for making reservations;
it can only be even easier when it's done by a Loongson team.
Finally, I've mentioned multiple times, that varying CPUCFG behavior
based on PLV is not something well documented on the manuals, hence not
friendly to low-level developers. Devs of third-party firmware and/or
kernels do exist, I've personally spoken to some of them on the
2023-11-18 3A6000 release event; in order for the varying CPUCFG
behavior approach to pass for me, at the very least, the LoongArch
reference manual must be amended to explicitly include an explanation of
it, and a reference to potential use cases.
--
WANG "xen0n" Xuerui
Linux/LoongArch mailing list: https://lore.kernel.org/loongarch/