Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

virtio.h: add some user-friendly apis #622

Open
wants to merge 2 commits into
base: main
Choose a base branch
from
Open
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
31 changes: 31 additions & 0 deletions lib/include/openamp/virtio.h
Original file line number Diff line number Diff line change
Expand Up @@ -118,6 +118,12 @@ struct virtio_device_id {
*/
#define VIRTIO_F_NOTIFY_ON_EMPTY (1 << 24)

/*
* This feature indicates that the device accepts arbitrary
* descriptor layouts.
*/
#define VIRTIO_F_ANY_LAYOUT (1 << 27)

/*
* The guest should never negotiate this feature; it
* is used to detect faulty drivers.
Expand Down Expand Up @@ -443,6 +449,9 @@ static inline int virtio_get_features(struct virtio_device *vdev,
return -ENXIO;

*features = vdev->func->get_features(vdev);
if (VIRTIO_ROLE_IS_DEVICE(vdev))
vdev->features = *features;

return 0;
}

Expand Down Expand Up @@ -559,6 +568,28 @@ static inline int virtio_free_buf(struct virtio_device *vdev, void *buf)
return 0;
}

/**
* @brief Check if the virtio device support a specific feature.
*
* @param vdev Pointer to device structure.
* @param feature_bit Feature bit to check.
*
* @return true if the feature is supported, otherwise false.
*/
static inline bool virtio_has_feature(struct virtio_device *vdev,
unsigned int feature_bit)
{
uint32_t features;

if (!vdev)
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

We should also check the feature_bit value. For time being we support only up to 32 features bit
so we should check that feature_bit < sizeof(features)

return false;

if (!vdev->features)
virtio_get_features(vdev, &features);

return (vdev->features & (1UL << feature_bit)) != 0;
}
arnopo marked this conversation as resolved.
Show resolved Hide resolved

#if defined __cplusplus
}
#endif
Expand Down