[PATCH 1/2] ARM: hyp-stub: improve ABI
Russell King - ARM Linux
linux at armlinux.org.uk
Mon Jan 9 04:26:39 PST 2017
On Tue, Jan 03, 2017 at 10:51:49AM +0100, Christoffer Dall wrote:
> Hi Russell,
>
> On Thu, Dec 15, 2016 at 06:57:18PM +0000, Russell King - ARM Linux wrote:
> > What's also coming clear is that there's very few people who understand
> > all the interactions here, and the whole thing seems to be an undocumented
> > mess.
>
> I think the hyp stub has just served a very limited purpose so far, and
> therefore is a somewhat immature implementation. Now we've discovered a
> need to clean it up, and we're all for that. Again, I don't think the
> problem is any larger than that, we just need to fix it, and it seems to
> me everyone is willing to work on that.
What I want to see is some documentation of the hyp-stub, so that there
can be some element of confidence that changes there are properly
coordinated. As I said in a follow up email:
| Either we need more people to have an understanding (so if one of them
| gets run over by a bus, we're not left floundering around) or we need
| it to be documented - even if it's just a simple comment "the ABI in
| this file is shared with XYZ, if you change the ABI here, also update
| XYZ too."
> Marc even offered to work on your suggestion to support the general
> hyp ABI commands in KVM.
... which is pointless, because it's a duplication of the effort I've
already put in. My patches already do the:
#define HVC_GET_VECTORS 0
#define HVC_SET_VECTORS 1
#define HVC_SOFT_RESTART 2
thing which ARM64 does, passing the arguments in via the appropriate
registers. However, such a change is a major revision of hyp-stub's
ABI, which completely changes the way it works.
The issue here is that there seems to be only one person, Marc, who
understands that the KVM hypervisor also needs to be updated - everyone
else I've talked to was of the opinion that hyp-stub's ABI is limited
to hyp-stub.S. That's worse than "I don't know" because it leads to
exactly the situation that my patches created: the two ABIs going out
of step.
What I'm asking for is a patch to add some sort of documentation ASAP
which ensures that this important non-obvious information isn't limited
to just one person. As I mentioned in the quote above, it can be as
simple as merely pointing each file at its counterparts which have to
be updated at the same time.
Longer term, I'd like to see the existing hypervisor documentation in
Documentation/virtual/kvm/hypercalls.txt updated with the ARM details.
According to that document, KVM effectively only exists on PPC and x86
at the present time...
--
RMK's Patch system: http://www.armlinux.org.uk/developer/patches/
FTTC broadband for 0.8mile line: currently at 9.6Mbps down 400kbps up
according to speedtest.net.
More information about the linux-arm-kernel
mailing list