[libcamera-devel] [PATCH v3 18/30] android: camera_device: Don't assume all planes use the same fd

Kieran Bingham kieran.bingham at ideasonboard.com
Tue Sep 7 01:57:49 CEST 2021


On 06/09/2021 23:56, Laurent Pinchart wrote:
> Now that libcamera correctly supports frame buffers with different
> dmabuf for each plane, remove the assumption that a single dmabuf is
> used.
> 
> Signed-off-by: Laurent Pinchart <laurent.pinchart at ideasonboard.com>
> Reviewed-by: Jean-Michel Hautbois <jeanmichel.hautbois at ideasonboard.com>

Reviewed-by: Kieran Bingham <kieran.bingham at ideasonboard.com>

> ---
>  src/android/camera_device.cpp | 25 ++++++-------------------
>  1 file changed, 6 insertions(+), 19 deletions(-)
> 
> diff --git a/src/android/camera_device.cpp b/src/android/camera_device.cpp
> index 8ca76719a50f..c64064106ccc 100644
> --- a/src/android/camera_device.cpp
> +++ b/src/android/camera_device.cpp
> @@ -749,25 +749,6 @@ FrameBuffer *CameraDevice::createFrameBuffer(const buffer_handle_t camera3buffer
>  					     libcamera::PixelFormat pixelFormat,
>  					     const libcamera::Size &size)
>  {
> -	FileDescriptor fd;
> -	/*
> -	 * This assumes all the planes are in the same dmabuf.
> -	 *
> -	 * \todo Verify that this assumption holds, fstat() can be used to check
> -	 * if two fds refer to the same dmabuf.
> -	 */
> -	for (int i = 0; i < camera3buffer->numFds; i++) {
> -		if (camera3buffer->data[i] != -1) {
> -			fd = FileDescriptor(camera3buffer->data[i]);
> -			break;
> -		}
> -	}
> -
> -	if (!fd.isValid()) {
> -		LOG(HAL, Fatal) << "No valid fd";
> -		return nullptr;
> -	}
> -
>  	CameraBuffer buf(camera3buffer, pixelFormat, size, PROT_READ);
>  	if (!buf.isValid()) {
>  		LOG(HAL, Fatal) << "Failed to create CameraBuffer";
> @@ -776,6 +757,12 @@ FrameBuffer *CameraDevice::createFrameBuffer(const buffer_handle_t camera3buffer
>  
>  	std::vector<FrameBuffer::Plane> planes(buf.numPlanes());
>  	for (size_t i = 0; i < buf.numPlanes(); ++i) {
> +		FileDescriptor fd{ camera3buffer->data[i] };
> +		if (!fd.isValid()) {
> +			LOG(HAL, Fatal) << "No valid fd";
> +			return nullptr;
> +		}
> +
>  		planes[i].fd = fd;
>  		planes[i].offset = buf.offset(i);
>  		planes[i].length = buf.size(i);
> 


More information about the libcamera-devel mailing list