libcamera: media_object: Expose entity type

Add a new field to the MediaEntity class to identify the type of
interface it exposes to userspace. The MediaEntity constructor is
changed to take a media_v2_interface pointer instead of just the device
node major and minor to have access to the interface type.

Signed-off-by: Laurent Pinchart <laurent.pinchart@ideasonboard.com>
Reviewed-by: Kieran Bingham <kieran.bingham@ideasonboard.com>
Tested-by: Martin Kepplinger <martin.kepplinger@puri.sm>
This commit is contained in:
Laurent Pinchart 2021-07-03 21:37:44 +03:00
parent 2e4fc65f77
commit a376aa331a
3 changed files with 57 additions and 13 deletions

View file

@ -652,14 +652,7 @@ bool MediaDevice::populateEntities(const struct media_v2_topology &topology)
*/
struct media_v2_interface *iface =
findInterface(topology, ent->id);
MediaEntity *entity;
if (iface)
entity = new MediaEntity(this, ent,
iface->devnode.major,
iface->devnode.minor);
else
entity = new MediaEntity(this, ent);
MediaEntity *entity = new MediaEntity(this, ent, iface);
if (!addObject(entity)) {
delete entity;

View file

@ -247,6 +247,23 @@ void MediaPad::addLink(MediaLink *link)
* may expose a deviceNode().
*/
/**
* \enum MediaEntity::Type
* \brief The type of the interface exposed by the entity to userspace
*
* \var MediaEntity::Type::Invalid
* \brief Invalid or unsupported entity type
*
* \var MediaEntity::Type::MediaEntity
* \brief Plain media entity with no userspace interface
*
* \var MediaEntity::Type::V4L2VideoDevice
* \brief V4L2 video device with a V4L2 video device node
*
* \var MediaEntity::Type::V4L2Subdevice
* \brief V4L2 subdevice with a V4L2 subdev device node
*/
/**
* \fn MediaEntity::name()
* \brief Retrieve the entity name
@ -273,6 +290,15 @@ void MediaPad::addLink(MediaLink *link)
* \return The entity's flags
*/
/**
* \fn MediaEntity::type()
* \brief Retrieve the entity's type
*
* The entity type identifies the type of interface exposed to userspace.
*
* \return The entity's type
*/
/**
* \fn MediaEntity::deviceNode()
* \brief Retrieve the entity's device node path, if any
@ -356,16 +382,32 @@ int MediaEntity::setDeviceNode(const std::string &deviceNode)
* \brief Construct a MediaEntity
* \param[in] dev The media device this entity belongs to
* \param[in] entity The media entity kernel data
* \param[in] major The major number of the entity associated interface
* \param[in] minor The minor number of the entity associated interface
* \param[in] iface The entity interface data (may be null)
*/
MediaEntity::MediaEntity(MediaDevice *dev,
const struct media_v2_entity *entity,
unsigned int major, unsigned int minor)
const struct media_v2_interface *iface)
: MediaObject(dev, entity->id), name_(entity->name),
function_(entity->function), flags_(entity->flags),
major_(major), minor_(minor)
type_(Type::MediaEntity), major_(0), minor_(0)
{
if (!iface)
return;
switch (iface->intf_type) {
case MEDIA_INTF_T_V4L_VIDEO:
type_ = Type::V4L2VideoDevice;
break;
case MEDIA_INTF_T_V4L_SUBDEV:
type_ = Type::V4L2Subdevice;
break;
default:
type_ = Type::Invalid;
return;
}
major_ = iface->devnode.major;
minor_ = iface->devnode.minor;
}
/**