mirror of https://gitee.com/openkylin/linux.git
virtio: allow drivers to validate features
Some drivers can't support all features in all configurations. At the moment we blindly set FEATURES_OK and later FAILED. Support this better by adding a callback drivers can use to do some early checks. Signed-off-by: Michael S. Tsirkin <mst@redhat.com>
This commit is contained in:
parent
2e123b44a3
commit
404123c2db
|
@ -232,6 +232,12 @@ static int virtio_dev_probe(struct device *_d)
|
|||
if (device_features & (1ULL << i))
|
||||
__virtio_set_bit(dev, i);
|
||||
|
||||
if (drv->validate) {
|
||||
err = drv->validate(dev);
|
||||
if (err)
|
||||
goto err;
|
||||
}
|
||||
|
||||
err = virtio_finalize_features(dev);
|
||||
if (err)
|
||||
goto err;
|
||||
|
|
|
@ -167,6 +167,7 @@ struct virtio_driver {
|
|||
unsigned int feature_table_size;
|
||||
const unsigned int *feature_table_legacy;
|
||||
unsigned int feature_table_size_legacy;
|
||||
int (*validate)(struct virtio_device *dev);
|
||||
int (*probe)(struct virtio_device *dev);
|
||||
void (*scan)(struct virtio_device *dev);
|
||||
void (*remove)(struct virtio_device *dev);
|
||||
|
|
Loading…
Reference in New Issue