From: christoffer.dall@linaro.org (Christoffer Dall)
To: linux-arm-kernel@lists.infradead.org
Subject: [PATCH v3 1/4] ARM: KVM: Implement kvm_vcpu_preferred_target() function
Date: Mon, 23 Sep 2013 17:16:40 +0100 [thread overview]
Message-ID: <20130923161640.GE19043@lvm> (raw)
In-Reply-To: <CAAhSdy36jMkZF1oQZry9EKO5s8fJHM1NZtnRhA2ijR1ShY-eAA@mail.gmail.com>
On Mon, Sep 23, 2013 at 09:24:06PM +0530, Anup Patel wrote:
> On Mon, Sep 23, 2013 at 9:14 PM, Marc Zyngier <marc.zyngier@arm.com> wrote:
> > On 23/09/13 16:31, Christoffer Dall wrote:
> >> On Mon, Sep 23, 2013 at 01:35:20PM +0530, Anup Patel wrote:
> >>> Hi Christoffer/Marc,
> >>>
> >>> On Fri, Sep 20, 2013 at 12:50 AM, Christoffer Dall
> >>> <christoffer.dall@linaro.org> wrote:
> >>>> On Thu, Sep 19, 2013 at 03:27:54PM +0100, Marc Zyngier wrote:
> >>>>> On 19/09/13 14:11, Anup Patel wrote:
> >>>>>> This patch implements kvm_vcpu_preferred_target() function for
> >>>>>> KVM ARM which will help us implement KVM_ARM_PREFERRED_TARGET ioctl
> >>>>>> for user space.
> >>>>>>
> >>>>>> Signed-off-by: Anup Patel <anup.patel@linaro.org>
> >>>>>> Signed-off-by: Pranavkumar Sawargaonkar <pranavkumar@linaro.org>
> >>>>>> ---
> >>>>>> arch/arm/kvm/guest.c | 20 ++++++++++++++++++++
> >>>>>> arch/arm64/include/asm/kvm_host.h | 1 +
> >>>>>> 2 files changed, 21 insertions(+)
> >>>>>>
> >>>>>> diff --git a/arch/arm/kvm/guest.c b/arch/arm/kvm/guest.c
> >>>>>> index 152d036..b407e6c 100644
> >>>>>> --- a/arch/arm/kvm/guest.c
> >>>>>> +++ b/arch/arm/kvm/guest.c
> >>>>>> @@ -222,6 +222,26 @@ int kvm_vcpu_set_target(struct kvm_vcpu *vcpu,
> >>>>>> return kvm_reset_vcpu(vcpu);
> >>>>>> }
> >>>>>>
> >>>>>> +int kvm_vcpu_preferred_target(struct kvm_vcpu_init *init)
> >>>>>> +{
> >>>>>> + int target = kvm_target_cpu();
> >>>>>> +
> >>>>>> + if (target < 0)
> >>>>>> + return -ENODEV;
> >>>>>> +
> >>>>>> + memset(init, 0, sizeof(*init));
> >>>>>> +
> >>>>>> + /*
> >>>>>> + * For now, we return all optional features are available
> >>>>>> + * for preferred target. In future, we might have features
> >>>>>> + * available based on underlying host.
> >>>>>> + */
> >>>>>> + init->target = (__u32)target;
> >>>>>> + init->features[0] |= (1 << KVM_ARM_VCPU_POWER_OFF);
> >>>>>
> >>>>> I'm in two minds about this feature reporting. I see they serve a
> >>>>> purpose, but they also duplicate capabilities, which is the standard way
> >>>>> to advertise what KVM can do.
> >>>>>
> >>>>> It means we end up having to sync two reporting mechanism, and I feel
> >>>>> this is in general a bad idea.
> >>>>>
> >>>>> Furthermore, KVM_ARM_VCPU_POWER_OFF is hardly a feature of the HW, but
> >>>>> rather a firmware emulation thing.
> >>>>>
> >>>>> Peter, Christoffer: Thoughts?
> >>>>>
> >>>> I wanted to return the full kvm_vcpu_init instead of just a target int,
> >>>> so we did not have to come up with yet another ioctl if we need to
> >>>> return more information about the capabilities of the host CPU in the
> >>>> future.
> >>>>
> >>>> But perhaps we can formulate the API, to say only the (currently empty)
> >>>> following list of features can only be enabled if the corresponding bit
> >>>> is enabled, or something along those lines.
> >>>>
> >>>> -Christoffer
> >>>> _______________________________________________
> >>>> kvmarm mailing list
> >>>> kvmarm at lists.cs.columbia.edu
> >>>> https://lists.cs.columbia.edu/cucslists/listinfo/kvmarm
> >>>
> >>> Do we stick with current implementation of returning struct kvm_vcpu_init ?
> >>> OR
> >>> Do we return struct kvm_vcpu_init with all features set to zero ?
> >>>
> >> Let's give Marc a day or two to respond to this one ;)
> >
> > Are you implying I'm getting slow? ;-)
Wouldn't dream of it.
> >
> > To answer Anup's question, I would tend to be cautious, and not expose
> > things for which we already have another API in place. So far, we've
> > stuck with the KVM approach of having a capability bit for each feature
> > we enable, and I'm quite happy with that.
> >
> > So I'm in favour of Christoffer's proposal to return an empty feature
> > set, and start adding stuff if/when the need arises.
>
> Agreed, I will send revised patch where we return zeroed-out features
> in struct kvm_vcpu_init (for now).
>
Sounds good, also remember to address this specific item in the API
documentation.
-Christoffer
next prev parent reply other threads:[~2013-09-23 16:16 UTC|newest]
Thread overview: 14+ messages / expand[flat|nested] mbox.gz Atom feed top
2013-09-19 13:11 [PATCH v3 0/4] Target CPU=Host implementation for KVM ARM/ARM64 Anup Patel
2013-09-19 13:11 ` [PATCH v3 1/4] ARM: KVM: Implement kvm_vcpu_preferred_target() function Anup Patel
2013-09-19 14:27 ` Marc Zyngier
2013-09-19 19:20 ` Christoffer Dall
2013-09-23 8:05 ` Anup Patel
2013-09-23 15:31 ` Christoffer Dall
2013-09-23 15:44 ` Marc Zyngier
2013-09-23 15:54 ` Anup Patel
2013-09-23 16:16 ` Christoffer Dall [this message]
2013-09-19 13:11 ` [PATCH v3 2/4] ARM64: " Anup Patel
2013-09-19 14:15 ` Marc Zyngier
2013-09-19 15:51 ` Anup Patel
2013-09-19 13:11 ` [PATCH v3 3/4] ARM/ARM64: KVM: Implement KVM_ARM_PREFERRED_TARGET ioctl Anup Patel
2013-09-19 13:11 ` [PATCH v3 4/4] KVM: Add documentation for " Anup Patel
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20130923161640.GE19043@lvm \
--to=christoffer.dall@linaro.org \
--cc=linux-arm-kernel@lists.infradead.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).