Skip to content

Conversation

@bchalios
Copy link
Contributor

@bchalios bchalios commented Apr 29, 2025

Changes

Group all device managers in a single top-level device manager, which now becomes the owner of the MMIO and Port IO buses along with the resource allocator. Also, it gets rid of the our Bus implementation in favour of the vm-device one from Cloud Hypervisor.

Reason

PCIe devices also need to be registered to the MMIO and Port IO buses. So, it makes more sense to keep the buses outside of MMIO and PortIO device managers.

Regarding switching to using vm_devices::Bus, PCIe implementation is using it and it was quite simpler to switch our own implementation to the upstream type rather than the other way around.

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

  • I have read and understand CONTRIBUTING.md.
  • I have run tools/devtool checkstyle to verify that the PR passes the
    automated style checks.
  • I have described what is done in these changes, why they are needed, and
    how they are solving the problem in a clear and encompassing way.
  • I have updated any relevant documentation (both in code and in the docs)
    in the PR.
  • I have mentioned all user-facing changes in CHANGELOG.md.
  • If a specific issue led to this PR, this PR closes the issue.
  • When making API changes, I have followed the
    Runbook for Firecracker API changes.
  • I have tested all new and changed functionalities in unit tests and/or
    integration tests.
  • I have linked an issue to every new TODO.

  • This functionality cannot be added in rust-vmm.

@bchalios bchalios force-pushed the device_manager branch 4 times, most recently from 503fa5d to a7ec377 Compare April 30, 2025 15:41
@bchalios bchalios force-pushed the device_manager branch 3 times, most recently from 903e15a to 564c7c0 Compare May 2, 2025 13:05
@codecov
Copy link

codecov bot commented May 2, 2025

Codecov Report

Attention: Patch coverage is 84.37103% with 123 lines in your changes missing coverage. Please review.

Project coverage is 83.23%. Comparing base (c4e3bf8) to head (e9840ac).
Report is 8 commits behind head on feature/pcie.

Files with missing lines Patch % Lines
src/vmm/src/device_manager/mmio.rs 73.23% 38 Missing ⚠️
src/vmm/src/lib.rs 13.33% 26 Missing ⚠️
src/vmm/src/devices/legacy/rtc_pl031.rs 33.33% 12 Missing ⚠️
src/vm-device/src/bus.rs 91.66% 11 Missing ⚠️
src/vm-device/src/interrupt/mod.rs 0.00% 10 Missing ⚠️
src/vmm/src/device_manager/mod.rs 96.66% 7 Missing ⚠️
src/vmm/src/builder.rs 92.72% 4 Missing ⚠️
src/vmm/src/devices/pseudo/boot_timer.rs 0.00% 4 Missing ⚠️
src/vmm/src/devices/virtio/transport/mmio.rs 55.55% 4 Missing ⚠️
src/vmm/src/persist.rs 50.00% 3 Missing ⚠️
... and 2 more
Additional details and impacted files
@@               Coverage Diff                @@
##           feature/pcie    #5174      +/-   ##
================================================
+ Coverage         82.93%   83.23%   +0.30%     
================================================
  Files               251      253       +2     
  Lines             27073    27171      +98     
================================================
+ Hits              22454    22617     +163     
+ Misses             4619     4554      -65     
Flag Coverage Δ
5.10-c5n.metal 83.55% <83.10%> (+0.17%) ⬆️
5.10-m5n.metal 83.54% <83.10%> (+0.16%) ⬆️
5.10-m6a.metal 82.77% <83.10%> (+0.17%) ⬆️
5.10-m6g.metal 79.76% <78.13%> (+0.53%) ⬆️
5.10-m6i.metal 83.53% <83.10%> (+0.16%) ⬆️
5.10-m7a.metal-48xl 82.76% <83.10%> (+0.17%) ⬆️
5.10-m7g.metal 79.76% <78.13%> (+0.53%) ⬆️
5.10-m7i.metal-24xl 83.50% <83.10%> (+0.16%) ⬆️
5.10-m7i.metal-48xl 83.50% <83.10%> (+0.17%) ⬆️
5.10-m8g.metal-24xl 79.75% <78.13%> (+0.53%) ⬆️
5.10-m8g.metal-48xl 79.75% <78.13%> (+0.53%) ⬆️
6.1-c5n.metal 83.59% <83.10%> (+0.17%) ⬆️
6.1-m5n.metal 83.59% <83.10%> (+0.17%) ⬆️
6.1-m6a.metal 82.82% <83.10%> (+0.17%) ⬆️
6.1-m6g.metal 79.75% <78.13%> (+0.52%) ⬆️
6.1-m6i.metal 83.58% <83.10%> (+0.16%) ⬆️
6.1-m7a.metal-48xl 82.81% <83.10%> (+0.18%) ⬆️
6.1-m7g.metal 79.75% <78.13%> (+0.52%) ⬆️
6.1-m7i.metal-24xl 83.60% <83.10%> (+0.16%) ⬆️
6.1-m7i.metal-48xl 83.61% <83.10%> (+0.17%) ⬆️
6.1-m8g.metal-24xl 79.75% <78.13%> (+0.53%) ⬆️
6.1-m8g.metal-48xl 79.75% <78.13%> (+0.53%) ⬆️

Flags with carried forward coverage won't be shown. Click here to find out more.

☔ View full report in Codecov by Sentry.
📢 Have feedback on the report? Share it here.

🚀 New features to boost your workflow:
  • ❄️ Test Analytics: Detect flaky tests, report on failures, and find test suite problems.

@bchalios bchalios force-pushed the device_manager branch 3 times, most recently from f84229f to e6560c9 Compare May 2, 2025 23:08
@bchalios bchalios force-pushed the device_manager branch 10 times, most recently from 60a6a74 to 6e35ab0 Compare May 12, 2025 22:14
@bchalios bchalios changed the title WIP: Refactor device managers, preparing for PCIe devices Refactor device managers, preparing for PCIe devices May 12, 2025
@bchalios bchalios marked this pull request as ready for review May 12, 2025 22:29
@bchalios bchalios self-assigned this May 13, 2025
@bchalios bchalios added the Status: Awaiting review Indicates that a pull request is ready to be reviewed label May 13, 2025
Manciukic
Manciukic previously approved these changes May 14, 2025
Copy link
Contributor

@Manciukic Manciukic left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

lgtm

bchalios and others added 8 commits May 14, 2025 13:14
Bring in the vm-device crate from CloudHypervisor. We will be using it
for adding PCIe support.

Signed-off-by: Babis Chalios <[email protected]>
We use `SerialDevice` with Stdin as the input source. Encode this in the
type so that we don't spill the generic all over the place.

Signed-off-by: Babis Chalios <[email protected]>
Co-authored-by: Egor Lazarchuk <[email protected]>
Signed-off-by: Egor Lazarchuk <[email protected]>
Signed-off-by: Babis Chalios <[email protected]>
Use the vm_device::Bus bus for all MMIO devices. This is mainly to
prepare for using it for PCIe devices. Also, sepate VirtIO devices from
other MMIO devices inside the MMIODeviceManager struct. This makes
iterating over VirtIO devices easier since we don't need to access two
data structures to get a reference to a VirtIO device any more.

Signed-off-by: Babis Chalios <[email protected]>
We were always constructing RTCDevice using a set of metrics that were
defined in the RTC module itself. Don't leak the metrics to other
modules. Instead, create a new() function that always constructs it the
correct way.

Signed-off-by: Babis Chalios <[email protected]>
Use the vm_device::Bus bus for PortIO devices on x86. PCIe devices will
use this as well.

Signed-off-by: Babis Chalios <[email protected]>
PCIe spec mandates that software can access the configuration space of
PCIe devices both via MMIO and Port IO accesses. As a result, PCIe
devices will need to register to both buses (on x86).

Change the organization of devices, so that MMIO and PIO device managers
do not own the buses. Instead, introduce a DeviceManager object which
holds the buses, the resource allocator and includes also all types of
device managers (at the moment MMIO, PIO and ACPI).

Signed-off-by: Babis Chalios <[email protected]>
We always create anew the keyboard interrupt event. Just create it
inside `I8042Device::new()` and return an error if that fails.

Signed-off-by: Babis Chalios <[email protected]>
test_serial_dos test checks that when we send a lot of bytes in the
serial device the emulation logic does not increase indefinitely the
underlying buffer that we use for when the device is set in loopback
mode.

However, the test does not wait for the microVM to start and sometimes
the virtual memory allocation may increase between readings. Add a
network device to the microVM so that we implicitly wait until it has
booted before taking the first measurement.

Signed-off-by: Babis Chalios <[email protected]>
@bchalios bchalios merged commit 361361f into firecracker-microvm:feature/pcie May 14, 2025
5 of 7 checks passed
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

Status: Awaiting review Indicates that a pull request is ready to be reviewed

Projects

None yet

Development

Successfully merging this pull request may close these issues.

3 participants