linux-coco.lists.linux.dev archive mirror
 help / color / mirror / Atom feed
* [Question - ARM CCA] vCPU Hotplug Support in ARM Realm world might require ARM spec change?
@ 2023-07-19  2:35 Salil Mehta
  2023-07-19  9:28 ` Suzuki K Poulose
  2023-07-25  0:28 ` bibo mao
  0 siblings, 2 replies; 13+ messages in thread
From: Salil Mehta @ 2023-07-19  2:35 UTC (permalink / raw)
  To: steven.price@arm.com, Suzuki K Poulose, Jean-Philippe Brucker,
	james.morse@arm.com, linux-coco@lists.linux.dev,
	kvmarm@lists.linux.dev
  Cc: Catalin Marinas, Jonathan Cameron, Marc Zyngier, Will Deacon,
	christoffer.dall@arm.com, oliver.upton@linux.dev,
	mark.rutland@arm.com, pbonzini@redhat.com, Salil Mehta,
	andrew.jones@linux.dev, yuzenghui, kvmarm@lists.cs.columbia.edu,
	linux-arm-kernel@lists.infradead.org,
	linux-kernel@vger.kernel.org, kvm@vger.kernel.org

[Reposting it here from Linaro Open Discussion List for more eyes to look at]

Hello,
I have recently started to dabble with ARM CCA stuff and check if our
recent changes to support vCPU Hotplug in ARM64 can work in the realm
world. I have realized that in the RMM specification[1] PSCI_CPU_ON
command(B5.3.3) does not handles the PSCI_DENIED return code(B5.4.2),
from the host. This might be required to support vCPU Hotplug feature
in the realm world in future. vCPU Hotplug is an important feature to
support kata-containers in realm world as it reduces the VM boot time
and facilitates dynamic adjustment of vCPUs (which I think should be
true even with Realm world as current implementation only makes use
of the PSCI_ON/OFF to realize the Hotplug look-like effect?)


As per our recent changes [2], [3] related to support vCPU Hotplug on
ARM64, we handle the guest exits due to SMC/HVC Hypercall in the
user-space i.e. VMM/Qemu. In realm world, REC Exits to host due to
PSCI_CPU_ON should undergo similar policy checks and I think,

1. Host should *deny* to online the target vCPUs which are NOT plugged
2. This means target REC should be denied by host. Can host call
   RMI_PSCI_COMPETE in such s case? 
3. The *return* value (B5.3.3.1.3 Output values) should be PSCI_DENIED
4. Failure condition (B5.3.3.2) should be amended with
   runnable pre: target_rec.flags.runnable == NOT_RUNNABLE (?)
            post: result == PSCI_DENIED (?)
5. Change would also be required in the flow (D1.4 PSCI flows) depicting 
   PSCI_CPU_ON flow (D1.4.1)
  

I do understand that ARM CCA support is in its infancy stage and
discussing about vCPU Hotplug in realm world seem to be a far-fetched
idea right now. But specification changes require lot of time and if
this change is really required then it should be further discussed
within ARM. 

Many thanks!


Bes regards
Salil


References:

[1] https://developer.arm.com/documentation/den0137/latest/
[2] https://github.com/salil-mehta/qemu.git virt-cpuhp-armv8/rfc-v1-port11052023.dev-1
[3] https://git.gitlab.arm.com/linux-arm/linux-jm.git virtual_cpu_hotplug/rfc/v2


^ permalink raw reply	[flat|nested] 13+ messages in thread

end of thread, other threads:[~2023-07-27 16:40 UTC | newest]

Thread overview: 13+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2023-07-19  2:35 [Question - ARM CCA] vCPU Hotplug Support in ARM Realm world might require ARM spec change? Salil Mehta
2023-07-19  9:28 ` Suzuki K Poulose
2023-07-24 16:27   ` Suzuki K Poulose
2023-07-25  0:05     ` Salil Mehta
2023-07-25 11:19       ` Suzuki K Poulose
2023-07-27 14:24         ` Salil Mehta
2023-07-27 16:40           ` Suzuki K Poulose
2023-07-25  0:28 ` bibo mao
2023-07-25  0:56   ` Salil Mehta
2023-07-25  1:13     ` bibo mao
2023-07-25  5:45       ` Salil Mehta
2023-07-25  6:24         ` bibo mao
2023-07-27 14:15           ` Salil Mehta

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).