diff options
| author | Michael S. Tsirkin <mst@redhat.com> | 2014-11-27 06:45:58 -0500 |
|---|---|---|
| committer | Michael S. Tsirkin <mst@redhat.com> | 2014-12-09 05:05:24 -0500 |
| commit | 93d389f82078cf7197152fb10d21977da0883420 (patch) | |
| tree | c168e5be2acd4e257212006a710af14df2185d80 /drivers/misc/mic/card | |
| parent | d025477368792b272802146a86e41f81a54d8a19 (diff) | |
virtio: assert 32 bit features in transports
At this point, no transports set any of the high 32 feature bits.
Since transports generally can't (yet) cope with such bits, add BUG_ON
checks to make sure they are not set by mistake.
Based on rproc patch by Rusty.
Signed-off-by: Rusty Russell <rusty@rustcorp.com.au>
Signed-off-by: Michael S. Tsirkin <mst@redhat.com>
Reviewed-by: David Hildenbrand <dahi@linux.vnet.ibm.com>
Reviewed-by: Cornelia Huck <cornelia.huck@de.ibm.com>
Diffstat (limited to 'drivers/misc/mic/card')
| -rw-r--r-- | drivers/misc/mic/card/mic_virtio.c | 3 |
1 files changed, 3 insertions, 0 deletions
diff --git a/drivers/misc/mic/card/mic_virtio.c b/drivers/misc/mic/card/mic_virtio.c index f5e756132bdb..d027d299602f 100644 --- a/drivers/misc/mic/card/mic_virtio.c +++ b/drivers/misc/mic/card/mic_virtio.c | |||
| @@ -96,6 +96,9 @@ static void mic_finalize_features(struct virtio_device *vdev) | |||
| 96 | /* Give virtio_ring a chance to accept features. */ | 96 | /* Give virtio_ring a chance to accept features. */ |
| 97 | vring_transport_features(vdev); | 97 | vring_transport_features(vdev); |
| 98 | 98 | ||
| 99 | /* Make sure we don't have any features > 32 bits! */ | ||
| 100 | BUG_ON((u32)vdev->features != vdev->features); | ||
| 101 | |||
| 99 | memset_io(out_features, 0, feature_len); | 102 | memset_io(out_features, 0, feature_len); |
| 100 | bits = min_t(unsigned, feature_len, | 103 | bits = min_t(unsigned, feature_len, |
| 101 | sizeof(vdev->features)) * 8; | 104 | sizeof(vdev->features)) * 8; |
