summary refs log tree commit diff
path: root/devices/src/virtio/vhost/vsock.rs
diff options
context:
space:
mode:
authorDaniel Verkamp <dverkamp@chromium.org>2018-10-24 11:30:34 -0700
committerchrome-bot <chrome-bot@chromium.org>2018-11-21 01:25:28 -0800
commite81a3e66cc266821fa5faec258d33c2eb3d8e102 (patch)
treee968ec22d1db178aa08ffc3f4d067c47a9dc88b1 /devices/src/virtio/vhost/vsock.rs
parent5c4ad02dd4865949e7f4df1a04f4c1cc603e6c64 (diff)
downloadcrosvm-e81a3e66cc266821fa5faec258d33c2eb3d8e102.tar
crosvm-e81a3e66cc266821fa5faec258d33c2eb3d8e102.tar.gz
crosvm-e81a3e66cc266821fa5faec258d33c2eb3d8e102.tar.bz2
crosvm-e81a3e66cc266821fa5faec258d33c2eb3d8e102.tar.lz
crosvm-e81a3e66cc266821fa5faec258d33c2eb3d8e102.tar.xz
crosvm-e81a3e66cc266821fa5faec258d33c2eb3d8e102.tar.zst
crosvm-e81a3e66cc266821fa5faec258d33c2eb3d8e102.zip
devices: convert virtio features to a u64
The virtio specification only defines feature bits in the 0-63 range
currently, so we can represent the features as a u64.  The Linux kernel
makes the same simplifying assumption, and very few features have been
defined beyond the first 32 bits, so this is probably safe for a while.

This allows the device models to be simplified, since they no longer
need to deal with the features paging mechanism (it is handled by the
generic virtio transport code).

BUG=None
TEST=build_test; boot termina on kevin

Change-Id: I6fd86907b2bdf494466c205e85072ebfeb7f5b73
Signed-off-by: Daniel Verkamp <dverkamp@chromium.org>
Reviewed-on: https://chromium-review.googlesource.com/1313012
Commit-Ready: ChromeOS CL Exonerator Bot <chromiumos-cl-exonerator@appspot.gserviceaccount.com>
Reviewed-by: Dylan Reid <dgreid@chromium.org>
Reviewed-by: Zach Reizner <zachr@chromium.org>
Diffstat (limited to 'devices/src/virtio/vhost/vsock.rs')
-rw-r--r--devices/src/virtio/vhost/vsock.rs43
1 files changed, 9 insertions, 34 deletions
diff --git a/devices/src/virtio/vhost/vsock.rs b/devices/src/virtio/vhost/vsock.rs
index 31dd61e..4b8fe85 100644
--- a/devices/src/virtio/vhost/vsock.rs
+++ b/devices/src/virtio/vhost/vsock.rs
@@ -111,20 +111,8 @@ impl VirtioDevice for Vsock {
         QUEUE_SIZES
     }
 
-    fn features(&self, page: u32) -> u32 {
-        match page {
-            // Get the lower 32-bits of the features bitfield.
-            0 => self.avail_features as u32,
-            // Get the upper 32-bits of the features bitfield.
-            1 => (self.avail_features >> 32) as u32,
-            _ => {
-                warn!(
-                    "vsock: virtio-vsock got request for features page: {}",
-                    page
-                );
-                0u32
-            }
-        }
+    fn features(&self) -> u64 {
+        self.avail_features
     }
 
     fn read_config(&self, offset: u64, data: &mut [u8]) {
@@ -142,18 +130,8 @@ impl VirtioDevice for Vsock {
         }
     }
 
-    fn ack_features(&mut self, page: u32, value: u32) {
-        let mut v = match page {
-            0 => value as u64,
-            1 => (value as u64) << 32,
-            _ => {
-                warn!(
-                    "vsock: virtio-vsock device cannot ack unknown feature page: {}",
-                    page
-                );
-                0u64
-            }
-        };
+    fn ack_features(&mut self, value: u64) {
+        let mut v = value;
 
         // Check if the guest is ACK'ing a feature that we didn't claim to have.
         let unrequested_features = v & !self.avail_features;
@@ -238,16 +216,16 @@ mod tests {
         assert_eq!(acked_features, vsock.acked_features());
 
         acked_features |= 1 << 2;
-        vsock.ack_features(0, (acked_features & 0xffffffff) as u32);
+        vsock.ack_features(acked_features);
         assert_eq!(acked_features, vsock.acked_features());
 
         acked_features |= 1 << 49;
-        vsock.ack_features(1, (acked_features >> 32) as u32);
+        vsock.ack_features(acked_features);
         assert_eq!(acked_features, vsock.acked_features());
 
         acked_features |= 1 << 60;
         unavailable_features |= 1 << 60;
-        vsock.ack_features(1, (acked_features >> 32) as u32);
+        vsock.ack_features(acked_features);
         assert_eq!(
             acked_features & !unavailable_features,
             vsock.acked_features()
@@ -255,7 +233,7 @@ mod tests {
 
         acked_features |= 1 << 1;
         unavailable_features |= 1 << 1;
-        vsock.ack_features(0, (acked_features & 0xffffffff) as u32);
+        vsock.ack_features(acked_features);
         assert_eq!(
             acked_features & !unavailable_features,
             vsock.acked_features()
@@ -290,9 +268,6 @@ mod tests {
         let features: u64 = 0xfc195ae8db88cff9;
 
         let vsock = Vsock::new_for_testing(cid, features);
-        assert_eq!((features & 0xffffffff) as u32, vsock.features(0));
-        assert_eq!((features >> 32) as u32, vsock.features(1));
-        assert_eq!(0, vsock.features(559));
-        assert_eq!(0, vsock.features(3));
+        assert_eq!(features, vsock.features());
     }
 }