Upcoming

v0.11.0

Changed

  • Updated vm-memory from 0.13.1 to 0.14.0
  • Updated vmm-sys-util from 0.11.0 to 0.12.1

v0.10.0

Identical to v0.9.1, which was incorrectly published as minor release.

v0.9.1 - yanked

This version got yanked. It should have been a major release. The vm-memory dependency - which received a major bump - is part of the public interface.

Changed

  • Updated vm-memory from 0.12.0 to 0.13.1.
  • Updated dev-dependencies:
    • criterion (0.3.0 -> 0.5.1)
    • memoffset (0.7.1 -> 0.9.0)

v0.9.0

Changed

  • Updated vm-memory from 0.11.0 to 0.12.0.

v0.8.0

Changed

  • Terminate iterating descriptor chains that are longer than 2^32 bytes.
  • Updated vm-memory from 0.10.0 to 0.11.0.
  • Updated virtio-bindings from 0.1.0 to 0.2.0.

v0.7.1

Fixed

  • Skip indirect descriptor address alignment check, the virtio spec has no alignment requirement on this, see 2.6.5.3 Indirect Descriptors and 2.7.7 Indirect Flag: Scatter-Gather Support in virtio 1.0.
  • Update the add_desc_chains mock function such that it works on big endian hosts as well.
  • Check that the queue is ready for processing requests when calling the iterator functions. For now the checks are limited to the avail address and the ready fields, but should be extended in the future to account for other fields that could signal an invalid queue. This behavior can be triggered by doing a reset followed by a pop_descriptor_chain.

v0.7.0

Changed

  • Updated vmm-sys-util from 0.10.0 to 0.11.0.
  • Updated vm-memory from 0.9.0 to 0.10.0.

v0.6.1

Fixed

  • Return an error if the number of available descriptor chains exposed by the driver exceeds the queue size. This way we avoid potential hanging and Denial-of-Service in the VMM, that was possible before by iterating multiple times over the same chains.

v0.6.0

Added

  • Derive Eq for structures that derive PartialEq.

Changed

  • Use add_desc_chains in tests
  • Update dependencies: vm-memory from 0.8.0 to 0.9.0 and log from 0.4.6 to 0.4.17.
  • Upgrade to Rust 2021 edition.

v0.5.0

Added

  • Added getters and setters for the Virtio Queue fields.
  • Added the state method for retrieving the QueueState of a Queue.

Fixed

  • Validate the state of the Virtio Queue when restoring from state and return errors on invalid input.

Removed

  • Removed the wrapper over the Virtio Queue that was wrapping the Guest Memory. VMMs can define this wrapper if needed, but this is no longer provided as part of virtio-queue crate so that the naming scheme can be simplified. As a consequence, a couple of functions now receive the memory as a parameter (more details in the Changed section).
  • Removed num_added field from the QueueState because this is an implementation detail of the notification suppression feature and thus should not be part of the state.
  • Removed QueueGuard and lock_with_memory.

Changed

  • QueueState is now renamed to Queue.
  • QueueStateSync is now renamed to QueueSync.
  • The QueueState structure now represents the state of the Queue without any implementation details. This can be used for implementing save/restore.
  • Initializing a Queue now returns an error in case the max_size is invalid.
  • The Queue fields are now private and can be updated only through the dedicated setters.
  • The following Queue methods now receive the memory as a parameter: iter, is_valid, add_used, needs_notification, enable_notification, disable_notification, avail_idx, used_idx.
  • Use the constant definition from the virtio-queue crate.

v0.4.0

Fixed

  • [#173] Fix potential division by zero in iterator when the queue size is 0.

Changed

  • [#162] Added error handling in the mock interface and the ability to create multiple descriptor chains for testing in order to support running fuzzing.
  • [#174] Updated the avail_idx and used_idx documentation to specify when these functions panic.

v0.3.0

Added

  • [#148]: QueueStateOwnedT trait that stands for queue objects which are exclusively owned and accessed by a single thread of execution.
  • [#148]: Added the pop_descriptor_chain method, which can be used to consume descriptor chains from the available ring without using an iterator, to QueueStateT and QueueGuard. Also added go_to_previous_position() to QueueGuard, which enables decrementing the next available index by one position, which effectively undoes the consumption of a descriptor chain in some use cases.
  • [#151]: Added MockSplitQueue::add_desc_chain(), which places a descriptor chain at the specified offset in the descriptor table.
  • [#153]: Added QueueStateT::size() to return the size of the queue.

Changed

  • The minimum version of the vm-memory dependency is now v0.8.0
  • [#161]: Improve the efficiency of needs_notification

Removed

  • [#153]: #[derive(Clone)] for QueueState

v0.2.0

Added

  • Testing Interface: Added the possibility to initialize a mock descriptor chain from a list of descriptors.
  • Added setters and getters for the queue fields required for extending the Queue in VMMs.

Fixed

  • Apply the appropriate endianness conversion on used_idx.

v0.1.0

This is the first release of the crate.