-
Notifications
You must be signed in to change notification settings - Fork 1.9k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Draft PR: Add Steal Time support in ARM #5139
base: main
Are you sure you want to change the base?
Conversation
- Added PVTime struct that allocates and stores per-vCPU stolen_time regions - Implemented register_vcpu() to register the IPA for each vCPU with KVM - Invoked setup_pv_time in build_microvm_for_boot - Added PVTime detection in setup_pv_time - Started using debug/info logs while booting microvm for testing Limitations/WIP: - While manually booting a microvm for testing, error during set_device_attr in register_vcpu - Snapshotting not yet supported Signed-off-by: Dakshin Devanand <[email protected]>
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Let's try making the proposed change to pass the right address and see if it works.
I haven't left any comment regarding style or design to focus on functionality first. Once we get something working we can see how to make it "look better".
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I got confused by the KVM API as well! Passing a user pointer to the IPA to kvm is ok, but it needs to be 64B aligned.
The hint was in the KVM documentation:
-EINVAL Base address not 64 byte aligned
https://www.kernel.org/doc/html/v5.8/virt/kvm/devices/vcpu.html#attribute-kvm-arm-vcpu-pvtime-ipa
- Each vCPU now gets 64 bytes for its steal_time struct region (16 bytes reguired for data) - This satisfies 64 byte alignment the IPA requires MicroVM can now successfully be booted with pvtime in the boot process. Signed-off-by: Dakshin Devanand <[email protected]>
Thank you so much for your fast response! Totally missed the docs for 64 byte alignment, but that ended up fixing the bugs and I can successfully boot a microVM manually. If you think its a good time now, we can look to flesh out the implementation and "make it better". Other than that, we believe the next step is adding unit/integration tests to make sure our device is working properly, as well as implementing persistence across snapshots. Any leads on how to do both of these things would be really helpful. The lead we have been looking at for snapshotting is the
|
Opening this PR as a draft as we continue working on this issue to add steal time support for ARM. Please see below for the changes we have implemented so far.
Changes
Added PVTime struct in
src/vmm/src/arch/aarch64/pvtime/mod.rs
that allocates and stores per-vCPU stolen_time regionsnew
constructor to create the device (allocating system memory and storing regions per vcpu), andregister_vcpu
which attempts to usekvm_set_device_attr
to register the corresponding IPA for a vcpuCreated a function
setup_pv_time
insrc/vmm/src/builder.rs
which is invoked inbuild_microvm_for_boot
kvm_has_device_attr
Started using debug/info logs while booting microvm for testing
Current problems:
Future Progress
setup_pv_time
Reason
Attempting to resolve issue #4866
License Acceptance
By submitting this pull request, I confirm that my contribution is made under
the terms of the Apache 2.0 license. For more information on following Developer
Certificate of Origin and signing off your commits, please check
CONTRIBUTING.md
.PR Checklist
tools/devtool checkstyle
to verify that the PR passes theautomated style checks.
how they are solving the problem in a clear and encompassing way.
in the PR.
CHANGELOG.md
.Runbook for Firecracker API changes.
integration tests.
TODO
.rust-vmm
.