libcamera: v4l2_videodevice: Extract exportDmabufFd()

The part in createPlane() that exports a dma buffer from a video device
will be used directly by the FrameBuffer interface. Break it out to a
separate function.

Signed-off-by: Niklas Söderlund <niklas.soderlund@ragnatech.se>
Reviewed-by: Jacopo Mondi <jacopo@jmondi.org>
Reviewed-by: Laurent Pinchart <laurent.pinchart@ideasonboard.com>
This commit is contained in:
Niklas Söderlund
2019-11-21 16:06:27 +01:00
parent 3f9d34f55e
commit 13724144f9
2 changed files with 28 additions and 16 deletions
+2
View File
@@ -26,6 +26,7 @@ class Buffer;
class BufferMemory;
class BufferPool;
class EventNotifier;
class FileDescriptor;
class MediaDevice;
class MediaEntity;
@@ -179,6 +180,7 @@ private:
int requestBuffers(unsigned int count);
int createPlane(BufferMemory *buffer, unsigned int index,
unsigned int plane, unsigned int length);
FileDescriptor exportDmabufFd(unsigned int index, unsigned int plane);
Buffer *dequeueBuffer();
void bufferAvailable(EventNotifier *notifier);
+26 -16
View File
@@ -22,6 +22,7 @@
#include <libcamera/buffer.h>
#include <libcamera/event_notifier.h>
#include <libcamera/file_descriptor.h>
#include "log.h"
#include "media_device.h"
@@ -902,31 +903,19 @@ int V4L2VideoDevice::exportBuffers(BufferPool *pool)
int V4L2VideoDevice::createPlane(BufferMemory *buffer, unsigned int index,
unsigned int planeIndex, unsigned int length)
{
struct v4l2_exportbuffer expbuf = {};
int ret;
LOG(V4L2, Debug)
<< "Buffer " << index
<< " plane " << planeIndex
<< ": length=" << length;
expbuf.type = bufferType_;
expbuf.index = index;
expbuf.plane = planeIndex;
expbuf.flags = O_RDWR;
ret = ioctl(VIDIOC_EXPBUF, &expbuf);
if (ret < 0) {
LOG(V4L2, Error)
<< "Failed to export buffer: " << strerror(-ret);
return ret;
}
FileDescriptor fd = exportDmabufFd(index, planeIndex);
if (!fd.isValid())
return -EINVAL;
FrameBuffer::Plane plane;
plane.fd = FileDescriptor(expbuf.fd);
plane.fd = fd;
plane.length = length;
buffer->planes().push_back(plane);
::close(expbuf.fd);
return 0;
}
@@ -952,6 +941,27 @@ int V4L2VideoDevice::importBuffers(BufferPool *pool)
return 0;
}
FileDescriptor V4L2VideoDevice::exportDmabufFd(unsigned int index,
unsigned int plane)
{
struct v4l2_exportbuffer expbuf = {};
int ret;
expbuf.type = bufferType_;
expbuf.index = index;
expbuf.plane = plane;
expbuf.flags = O_RDWR;
ret = ioctl(VIDIOC_EXPBUF, &expbuf);
if (ret < 0) {
LOG(V4L2, Error)
<< "Failed to export buffer: " << strerror(-ret);
return FileDescriptor();
}
return FileDescriptor(expbuf.fd);
}
/**
* \brief Release all internally allocated buffers
*/