From: Marc Zyngier <marc.zyngier@arm.com>
To: Christoffer Dall <christoffer.dall@linaro.org>
Cc: Peter Maydell <peter.maydell@linaro.org>,
Suzuki Poulose <Suzuki.Poulose@arm.com>,
"timur@codeaurora.org" <timur@codeaurora.org>,
"vgandhi@codeaurora.org" <vgandhi@codeaurora.org>,
kvm-devel <kvm@vger.kernel.org>,
arm-mail-list <linux-arm-kernel@lists.infradead.org>,
"kvmarm@lists.cs.columbia.edu" <kvmarm@lists.cs.columbia.edu>
Subject: Re: [PATCH] arm64/kvm: Add generic v8 KVM target
Date: Thu, 25 Jun 2015 14:44:09 +0100 [thread overview]
Message-ID: <558C05A9.8080201@arm.com> (raw)
In-Reply-To: <558BF6C9.3000009@arm.com>
On 25/06/15 13:40, Marc Zyngier wrote:
> On 25/06/15 13:30, Christoffer Dall wrote:
>> On Wed, Jun 24, 2015 at 10:32:38AM +0100, Marc Zyngier wrote:
>>> Hi Christoffer,
>>>
>>> On 24/06/15 09:51, Christoffer Dall wrote:
>>>> On Wed, Jun 24, 2015 at 09:29:56AM +0100, Marc Zyngier wrote:
>>>>> On 22/06/15 09:44, Peter Maydell wrote:
>>>>>> On 17 June 2015 at 10:00, Suzuki K. Poulose <suzuki.poulose@arm.com> wrote:
>>>>>>> From: "Suzuki K. Poulose" <suzuki.poulose@arm.com>
>>>>>>>
>>>>>>> This patch adds a generic ARM v8 KVM target cpu type for use
>>>>>>> by the new CPUs which eventualy ends up using the common sys_reg
>>>>>>> table. For backward compatibility the existing targets have been
>>>>>>> preserved. Any new target CPU that can be covered by generic v8
>>>>>>> sys_reg tables should make use of the new generic target.
>>>>>>
>>>>>> How do you intend this to work for cross-host migration?
>>>>>
>>>>> It is not meant to work for cross migration at all.
>>>>>
>>>>>> Is the idea that the kernel guarantees that "generic" looks
>>>>>> 100% the same to the guest regardless of host hardware? I'm
>>>>>> not sure that can be made to work, given impdef differences
>>>>>> in ID register values, bp/wp registers, and so on.
>>>>>>
>>>>>> Given that, it seems to me that we still need to provide
>>>>>> KVM_ARM_TARGET_$THISCPU defines so userspace can request
>>>>>> a specific guest CPU flavour; so what does this patch
>>>>>> provide that isn't already provided by just having userspace
>>>>>> query for the "preferred" CPU type as it does already?
>>>>>
>>>>> The way I see this working is that a "generic" CPU cannot be migrated
>>>>> (because we don't know anything about it). If it can be identified as a
>>>>> known (non generic) implementation, then we can migrate it.
>>>>>
>>>> Concretely, how should this work? Be enforced by userspace or should we
>>>> deny certain SET_ONE_REG operations from working on this target?
>>>
>>> I can definitely see MIDR overriding failing on a generic CPU. Also, you
>>> shouldn't be able to select a generic CPU if we know about the physical CPU.
>>>
>>
>> If I am migrating from an A57 to an A53, but the VM was started as
>> "generic CPU" then we rely on the user discovering that this is not
>> supported when trying to set the MIDR from userspace in KVM?
>
> A57 to A53 is probably a bad example because we actively support both.
> So let's replace your A57 with an A72. With this patch, the A72 would be
> reported as "generic CPU", and MIDR access would fail on the A53.
Having thought about this a bit more...
It should always be possible to emulate a "known" CPU on a generic host,
and it should be able to migrate. The case we can't migrate is when we
let the guest be generic (which I guess should really be unknown, and
not generic).
So if the user specify "-cpu cortex-a57" on the command line, the guest
should be able to migrate from an A72 to an A53. if the user specified
"-cpu host", the resulting guest won't be able to migrate.
Does it make sense?
Thanks,
M.
--
Jazz is not dead. It just smells funny...
next prev parent reply other threads:[~2015-06-25 13:44 UTC|newest]
Thread overview: 31+ messages / expand[flat|nested] mbox.gz Atom feed top
2015-06-17 9:00 [PATCH] arm64/kvm: Add generic v8 KVM target Suzuki K. Poulose
2015-06-19 20:31 ` Timur Tabi
2015-06-22 6:47 ` Marc Zyngier
2015-06-22 8:44 ` Peter Maydell
2015-06-23 12:39 ` Christoffer Dall
2015-06-23 14:03 ` Suzuki K. Poulose
2015-06-23 14:16 ` Peter Maydell
2015-06-24 8:29 ` Marc Zyngier
2015-06-24 8:51 ` Christoffer Dall
2015-06-24 9:32 ` Marc Zyngier
2015-06-25 12:30 ` Christoffer Dall
2015-06-25 12:40 ` Marc Zyngier
2015-06-25 13:44 ` Marc Zyngier [this message]
2015-06-25 13:49 ` Peter Maydell
2015-06-26 9:53 ` Christoffer Dall
2015-06-29 17:13 ` Chalamarla, Tirumalesh
2015-06-29 17:30 ` Marc Zyngier
2015-06-29 17:38 ` Peter Maydell
2015-06-29 17:52 ` Marc Zyngier
2015-06-29 18:39 ` Chalamarla, Tirumalesh
2015-07-02 20:29 ` Chalamarla, Tirumalesh
2015-07-03 8:08 ` Marc Zyngier
2015-07-03 8:12 ` Peter Maydell
2015-07-03 8:28 ` Marc Zyngier
2015-07-03 9:34 ` Peter Maydell
2015-07-03 10:10 ` Marc Zyngier
2015-07-17 9:33 ` Christoffer Dall
2015-07-17 9:56 ` Marc Zyngier
2015-07-17 10:15 ` Christoffer Dall
2015-07-17 10:19 ` Marc Zyngier
2015-07-17 17:56 ` Chalamarla, Tirumalesh
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=558C05A9.8080201@arm.com \
--to=marc.zyngier@arm.com \
--cc=Suzuki.Poulose@arm.com \
--cc=christoffer.dall@linaro.org \
--cc=kvm@vger.kernel.org \
--cc=kvmarm@lists.cs.columbia.edu \
--cc=linux-arm-kernel@lists.infradead.org \
--cc=peter.maydell@linaro.org \
--cc=timur@codeaurora.org \
--cc=vgandhi@codeaurora.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).