[libcamera-devel] [PATCH v2 2/9] camera_device: Remove private scope of Camera3RequestDescriptor

Laurent Pinchart laurent.pinchart at ideasonboard.com
Mon Sep 13 01:55:56 CEST 2021


Hi Umang,

Thank you for the patch.

On Fri, Sep 10, 2021 at 12:36:31PM +0530, Umang Jain wrote:
> Camera3RequestDescriptor is a utility structure that groups information
> about a capture request. It can be and will be extended to preserve the
> context of a capture overall. Since the context of a capture needs to
> be shared among other classes(for e.g. CameraStream) having a private

s/classes(/classes (/

Do I need to add a specific check to checkstyle.py ? :-)

> definition of the struct doesn't help. Hence, de-scope the structure
> so that it can be shared with other components (through references or
> pointers).
> 
> Signed-off-by: Umang Jain <umang.jain at ideasonboard.com>

Reviewed-by: Laurent Pinchart <laurent.pinchart at ideasonboard.com>

> ---
>  src/android/camera_device.cpp |  2 +-
>  src/android/camera_device.h   | 29 +++++++++++++++--------------
>  2 files changed, 16 insertions(+), 15 deletions(-)
> 
> diff --git a/src/android/camera_device.cpp b/src/android/camera_device.cpp
> index f2f36f32..0840c056 100644
> --- a/src/android/camera_device.cpp
> +++ b/src/android/camera_device.cpp
> @@ -220,7 +220,7 @@ bool validateCropRotate(const camera3_stream_configuration_t &streamList)
>   * later re-used at request complete time to notify the framework.
>   */
>  
> -CameraDevice::Camera3RequestDescriptor::Camera3RequestDescriptor(
> +Camera3RequestDescriptor::Camera3RequestDescriptor(
>  	Camera *camera, const camera3_capture_request_t *camera3Request)
>  {
>  	frameNumber_ = camera3Request->frame_number;
> diff --git a/src/android/camera_device.h b/src/android/camera_device.h
> index a5576927..b59ac3e7 100644
> --- a/src/android/camera_device.h
> +++ b/src/android/camera_device.h
> @@ -33,6 +33,21 @@
>  #include "jpeg/encoder.h"
>  
>  struct CameraConfigData;
> +
> +struct Camera3RequestDescriptor {
> +	Camera3RequestDescriptor() = default;
> +	~Camera3RequestDescriptor() = default;
> +	Camera3RequestDescriptor(libcamera::Camera *camera,
> +				 const camera3_capture_request_t *camera3Request);
> +	Camera3RequestDescriptor &operator=(Camera3RequestDescriptor &&) = default;
> +
> +	uint32_t frameNumber_ = 0;
> +	std::vector<camera3_stream_buffer_t> buffers_;
> +	std::vector<std::unique_ptr<libcamera::FrameBuffer>> frameBuffers_;
> +	CameraMetadata settings_;
> +	std::unique_ptr<CaptureRequest> request_;
> +};
> +
>  class CameraDevice : protected libcamera::Loggable
>  {
>  public:
> @@ -71,20 +86,6 @@ private:
>  
>  	CameraDevice(unsigned int id, std::shared_ptr<libcamera::Camera> camera);
>  
> -	struct Camera3RequestDescriptor {
> -		Camera3RequestDescriptor() = default;
> -		~Camera3RequestDescriptor() = default;
> -		Camera3RequestDescriptor(libcamera::Camera *camera,
> -					 const camera3_capture_request_t *camera3Request);
> -		Camera3RequestDescriptor &operator=(Camera3RequestDescriptor &&) = default;
> -
> -		uint32_t frameNumber_ = 0;
> -		std::vector<camera3_stream_buffer_t> buffers_;
> -		std::vector<std::unique_ptr<libcamera::FrameBuffer>> frameBuffers_;
> -		CameraMetadata settings_;
> -		std::unique_ptr<CaptureRequest> request_;
> -	};
> -
>  	enum class State {
>  		Stopped,
>  		Flushing,

-- 
Regards,

Laurent Pinchart


More information about the libcamera-devel mailing list