[libcamera-devel] [PATCH v6 1/9] libcamera: device_enumerator: Add method to lookup sysfs path

Laurent Pinchart laurent.pinchart at ideasonboard.com
Tue Aug 4 13:24:41 CEST 2020


Hi Niklas,

Thank you for the patch.

On Tue, Aug 04, 2020 at 09:31:54AM +0200, Jacopo Mondi wrote:
> On Mon, Aug 03, 2020 at 11:17:25PM +0200, Niklas Söderlund wrote:
> > Add an implementation to lookup a device nodes sysfs interface path

s/nodes/node's/

> > based on the assumption that device name under /dev matches the one
> > under /sysfs. Subclasses of the DeviceEnumerator may override this to
> > create more clever methods to lookup the path.
> 
> s/method/implementation

Isn't "method" an appropriate term too ?

> > Signed-off-by: Niklas Söderlund <niklas.soderlund at ragnatech.se>
> > ---
> >  include/libcamera/internal/device_enumerator.h |  2 ++
> >  src/libcamera/device_enumerator.cpp            | 14 ++++++++++++++
> >  2 files changed, 16 insertions(+)
> >
> > diff --git a/include/libcamera/internal/device_enumerator.h b/include/libcamera/internal/device_enumerator.h
> > index a9850400229d2b53..11961f4f9304f6d7 100644
> > --- a/include/libcamera/internal/device_enumerator.h
> > +++ b/include/libcamera/internal/device_enumerator.h
> > @@ -45,6 +45,8 @@ public:
> >
> >  	std::shared_ptr<MediaDevice> search(const DeviceMatch &dm);
> >
> > +	virtual std::string lookupSysfsPath(const std::string &deviceNode);
> 
> That's a quite peculiar name I would say. Any reason I have missed why
> you retained the 'lookup' part ? As we don't have 'get' in getters,
> I'm not sure if 'lookup' should be there.
> 
> Why not just 'sysfsPath()' ?

I also think it would be better.

Niklas, conceptual question, would it make sense to move this
implementation to the sysfs enumerator, keeping the function purely
virtual in the base class ?

> > +
> >  	Signal<> devicesAdded;
> >
> >  protected:
> > diff --git a/src/libcamera/device_enumerator.cpp b/src/libcamera/device_enumerator.cpp
> > index 647974b17341f44b..ef2451ac29159bf0 100644
> > --- a/src/libcamera/device_enumerator.cpp
> > +++ b/src/libcamera/device_enumerator.cpp
> > @@ -318,4 +318,18 @@ std::shared_ptr<MediaDevice> DeviceEnumerator::search(const DeviceMatch &dm)
> >  	return nullptr;
> >  }
> >
> > +/**
> > + * \brief Lookup a nodes sysfs path
> 
> Lookup a video device node path in sysfs

I'd talk about character device instead of video device, as this is
generic.

Except it's not now that I read the implementation below :-) I should
have thought about it, but how about

std::string DeviceEnumerator::lookupSysfsPath(const std::string &deviceNode)
{
	struct stat st;
	int ret = stat(deviceNode.c_str(), &st);
	if (ret < 0) {
		LOG(DeviceEnumerator, Error)
			<< "Unable to stat '" << deviceNode << "'";
		return {};
	}

	std::ostringstream dev("/sys/dev/char/", std::ios_base::ate);
	dev << major(st.st_rdev) << ":" << minor(st.st_rdev);
	return dev.str();
}

This should work in all cases and wouldn't require udev at all. The code
could even be moved to V4L2Device::devicePath(), as it's the only user.
I think this would have my preference for now.

Another option is to add a sysfs.cpp file for this function and
tryLookupFirmwareID(). No need to add classes there, a simple
libcamera::sysfs namespace would do (maybe we'll refactor that in a
CharDev class later, if the need arises).

> > + * \param[in] deviceNode device node to lookup
> 
> The video device node path in /dev/
> 
> > + *
> > + * Lookup \a deviceNode sysfs interface.
> 
> I know nothing about sysfs, but to me a device node has several
> representation in sysfs, by device hierarchy, by class, by device node
> devnums etc.
> 
> This one returns a very precise one, I would mention that
> 
> > + *
> > + * \return Path in sysfs
> > + */
> > +std::string DeviceEnumerator::lookupSysfsPath(const std::string &deviceNode)
> > +{
> > +	std::string dev = basename(deviceNode.c_str());
> > +	return "/sys/class/video4linux/" + dev;
> > +}
> > +
> >  } /* namespace libcamera */

-- 
Regards,

Laurent Pinchart


More information about the libcamera-devel mailing list