[libcamera-devel] [PATCH 1/2] libcamera: MediaEntity: expose the entity flags

Niklas Söderlund niklas.soderlund at ragnatech.se
Fri Jan 25 15:35:50 CET 2019


Hi,

On 2019-01-25 13:04:18 +0200, Laurent Pinchart wrote:
> Hi Niklas,
> 
> Thank you for the patch.
> 
> On Wed, Jan 23, 2019 at 04:03:50PM +0100, Niklas Söderlund wrote:
> > The media entity flags can be useful for pipeline handlers to find the
> > default device in a media graph which is marked with the
> > MEDIA_ENT_FL_DEFAULT flag. This will be especially useful for the UVC
> > pipeline handler where the entity names differ per device.
> > 
> > Signed-off-by: Niklas Söderlund <niklas.soderlund at ragnatech.se>
> 
> We might want a helper to find the default entity, but this patch looks
> good to me regardless.
> 
> Reviewed-by: Laurent Pinchart <laurent.pinchart at ideasonboard.com>

Thanks I pushed this to master.

> 
> > ---
> >  src/libcamera/include/media_object.h |  2 ++
> >  src/libcamera/media_object.cpp       | 13 ++++++++++++-
> >  2 files changed, 14 insertions(+), 1 deletion(-)
> > 
> > diff --git a/src/libcamera/include/media_object.h b/src/libcamera/include/media_object.h
> > index 64095bec8606bd32..2a3ffc06c876d792 100644
> > --- a/src/libcamera/include/media_object.h
> > +++ b/src/libcamera/include/media_object.h
> > @@ -85,6 +85,7 @@ class MediaEntity : public MediaObject
> >  public:
> >  	const std::string &name() const { return name_; }
> >  	unsigned int function() const { return function_; }
> > +	unsigned int flags() const { return flags_; }
> >  	const std::string &deviceNode() const { return deviceNode_; }
> >  	unsigned int deviceMajor() const { return major_; }
> >  	unsigned int deviceMinor() const { return minor_; }
> > @@ -106,6 +107,7 @@ private:
> >  
> >  	std::string name_;
> >  	unsigned int function_;
> > +	unsigned int flags_;
> >  	std::string deviceNode_;
> >  	unsigned int major_;
> >  	unsigned int minor_;
> > diff --git a/src/libcamera/media_object.cpp b/src/libcamera/media_object.cpp
> > index baf9aeaa8fffe1a6..f6abcd8676a3866d 100644
> > --- a/src/libcamera/media_object.cpp
> > +++ b/src/libcamera/media_object.cpp
> > @@ -265,6 +265,16 @@ void MediaPad::addLink(MediaLink *link)
> >   * \return The entity's function
> >   */
> >  
> > +/**
> > + * \fn MediaEntity::flags()
> > + * \brief Retrieve the entity's flags
> > + *
> > + * Media entity flags are expressed using the MEDIA_ENT_FL_* macros
> > + * defined by the Media Controller API.
> > + *
> > + * \return The entity's flags
> > + */
> > +
> >  /**
> >   * \fn MediaEntity::deviceNode()
> >   * \brief Retrieve the entity's device node path, if any
> > @@ -358,7 +368,8 @@ MediaEntity::MediaEntity(MediaDevice *dev,
> >  			 const struct media_v2_entity *entity,
> >  			 unsigned int major, unsigned int minor)
> >  	: MediaObject(dev, entity->id), name_(entity->name),
> > -	  function_(entity->function), major_(major), minor_(minor)
> > +	  function_(entity->function), flags_(entity->flags),
> > +	  major_(major), minor_(minor)
> >  {
> >  }
> >  
> 
> -- 
> Regards,
> 
> Laurent Pinchart

-- 
Regards,
Niklas Söderlund


More information about the libcamera-devel mailing list