Internships/ProjectIdeas/KaniProofsInRustVMM: Difference between revisions

From QEMU
Line 21: Line 21:
virtqueue implementation is correct and conformant.
virtqueue implementation is correct and conformant.


During the internship, we propose the following tasks:
Tasks:
* Finish [https://github.com/rust-vmm/vm-virtio/pull/324 current PR] that adds a proof for the notification suppression mechanism
* Finish [https://github.com/rust-vmm/vm-virtio/pull/324 current PR] that adds a proof for the notification suppression mechanism
* Port [https://github.com/firecracker-microvm/firecracker/blob/4bbbec06ee0d529add07807f75d923cc3d3cd210/src/vmm/src/devices/virtio/queue.rs#L1006 add_used() proof]
* Port [https://github.com/firecracker-microvm/firecracker/blob/4bbbec06ee0d529add07807f75d923cc3d3cd210/src/vmm/src/devices/virtio/queue.rs#L1006 add_used() proof]

Revision as of 14:22, 10 February 2025

Adding Kani proofs for Virtqueues in Rust-vmm

Expected outcome: Verify conformance of the virtqueue implementation in rust-vmm to the VirtIO specification.

In the rust-vmm project, devices rely on the virtqueue implementation provided by the `vm-virtio` crate. This implementation is based on the VirtIO specification, which defines the behavior and requirements for virtqueues. To ensure that the implementation meets these specifications, we have been relying on unit tests that check the output of the code given specific inputs.

However, writing unit tests can be incomplete, as it's challenging to cover all possible scenarios and edge cases. During this internship, we propose a more comprehensive approach: using Kani proofs to verify that the virtqueue implementation conforms to the VirtIO specification.

Kani allows us to write exhaustive checks for all possible values, going beyond what unit tests can achieve. By writing Kani proofs, we can confirm that our implementation meets the requirements of the VirtIO specification. If a proof passes, it provides strong evidence that the virtqueue implementation is correct and conformant.

Tasks:

Links:

Details:

  • Project size: 175 or 350 hours, depending on how many proofs you wish to tackle
  • Skill level: intermediate
  • Language: Rust
  • Mentor: Matias Ezequiel Vara Larsen (mvaralar@redhat.com)