libcamera: v4l2_videodevice: Identify non-zero stream starts
V4L2 Video devices should always start streaming from index zero. Identify and report a warning if they don't, and correct for any offset. Reviewed-by: Jacopo Mondi <jacopo@jmondi.org> Reviewed-by: Laurent Pinchart <laurent.pinchart@ideasonboard.com> Signed-off-by: Kieran Bingham <kieran.bingham@ideasonboard.com>
This commit is contained in:
parent
27cc0a6b58
commit
1c9dc0fd89
2 changed files with 16 additions and 0 deletions
|
@ -276,6 +276,7 @@ private:
|
||||||
EventNotifier *fdBufferNotifier_;
|
EventNotifier *fdBufferNotifier_;
|
||||||
|
|
||||||
State state_;
|
State state_;
|
||||||
|
std::optional<unsigned int> firstFrame_;
|
||||||
|
|
||||||
Timer watchdog_;
|
Timer watchdog_;
|
||||||
utils::Duration watchdogDuration_;
|
utils::Duration watchdogDuration_;
|
||||||
|
|
|
@ -1771,6 +1771,19 @@ FrameBuffer *V4L2VideoDevice::dequeueBuffer()
|
||||||
if (V4L2_TYPE_IS_OUTPUT(buf.type))
|
if (V4L2_TYPE_IS_OUTPUT(buf.type))
|
||||||
return buffer;
|
return buffer;
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Detect kernel drivers which do not reset the sequence number to zero
|
||||||
|
* on stream start.
|
||||||
|
*/
|
||||||
|
if (!firstFrame_) {
|
||||||
|
if (buf.sequence)
|
||||||
|
LOG(V4L2, Warning)
|
||||||
|
<< "Zero sequence expected for first frame (got "
|
||||||
|
<< buf.sequence << ")";
|
||||||
|
firstFrame_ = buf.sequence;
|
||||||
|
}
|
||||||
|
buffer->metadata_.sequence -= firstFrame_.value();
|
||||||
|
|
||||||
unsigned int numV4l2Planes = multiPlanar ? buf.length : 1;
|
unsigned int numV4l2Planes = multiPlanar ? buf.length : 1;
|
||||||
FrameMetadata &metadata = buffer->metadata_;
|
FrameMetadata &metadata = buffer->metadata_;
|
||||||
|
|
||||||
|
@ -1847,6 +1860,8 @@ int V4L2VideoDevice::streamOn()
|
||||||
{
|
{
|
||||||
int ret;
|
int ret;
|
||||||
|
|
||||||
|
firstFrame_.reset();
|
||||||
|
|
||||||
ret = ioctl(VIDIOC_STREAMON, &bufferType_);
|
ret = ioctl(VIDIOC_STREAMON, &bufferType_);
|
||||||
if (ret < 0) {
|
if (ret < 0) {
|
||||||
LOG(V4L2, Error)
|
LOG(V4L2, Error)
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue