mirror of
https://git.libcamera.org/libcamera/libcamera.git
synced 2025-07-13 07:19:45 +03:00
camera_device: Remove private scope of Camera3RequestDescriptor
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 definition of the struct in CameraDevice class doesn't help. Hence, de-scope the structure so that it can be shared with other components (through references or pointers). Splitting the structure to a separate file will help avoiding circular dependencies when using it through the HAL implementation. Signed-off-by: Umang Jain <umang.jain@ideasonboard.com> Signed-off-by: Laurent Pinchart <laurent.pinchart@ideasonboard.com> Reviewed-by: Laurent Pinchart <laurent.pinchart@ideasonboard.com> Reviewed-by: Jacopo Mondi <jacopo@jmondi.org> Reviewed-by: Hirokazu Honda <hiroh@chromium.org>
This commit is contained in:
parent
db39cc7698
commit
109a98e8c0
5 changed files with 99 additions and 63 deletions
|
@ -6,9 +6,6 @@
|
|||
*/
|
||||
|
||||
#include "camera_device.h"
|
||||
#include "camera_hal_config.h"
|
||||
#include "camera_ops.h"
|
||||
#include "post_processor.h"
|
||||
|
||||
#include <algorithm>
|
||||
#include <fstream>
|
||||
|
@ -27,6 +24,11 @@
|
|||
|
||||
#include "system/graphics.h"
|
||||
|
||||
#include "camera_hal_config.h"
|
||||
#include "camera_ops.h"
|
||||
#include "camera_request.h"
|
||||
#include "post_processor.h"
|
||||
|
||||
using namespace libcamera;
|
||||
|
||||
LOG_DECLARE_CATEGORY(HAL)
|
||||
|
@ -213,41 +215,6 @@ bool validateCropRotate(const camera3_stream_configuration_t &streamList)
|
|||
|
||||
} /* namespace */
|
||||
|
||||
/*
|
||||
* \struct Camera3RequestDescriptor
|
||||
*
|
||||
* A utility structure that groups information about a capture request to be
|
||||
* later re-used at request complete time to notify the framework.
|
||||
*/
|
||||
|
||||
CameraDevice::Camera3RequestDescriptor::Camera3RequestDescriptor(
|
||||
Camera *camera, const camera3_capture_request_t *camera3Request)
|
||||
{
|
||||
frameNumber_ = camera3Request->frame_number;
|
||||
|
||||
/* Copy the camera3 request stream information for later access. */
|
||||
const uint32_t numBuffers = camera3Request->num_output_buffers;
|
||||
buffers_.resize(numBuffers);
|
||||
for (uint32_t i = 0; i < numBuffers; i++)
|
||||
buffers_[i] = camera3Request->output_buffers[i];
|
||||
|
||||
/*
|
||||
* FrameBuffer instances created by wrapping a camera3 provided dmabuf
|
||||
* are emplaced in this vector of unique_ptr<> for lifetime management.
|
||||
*/
|
||||
frameBuffers_.reserve(numBuffers);
|
||||
|
||||
/* Clone the controls associated with the camera3 request. */
|
||||
settings_ = CameraMetadata(camera3Request->settings);
|
||||
|
||||
/*
|
||||
* Create the CaptureRequest, stored as a unique_ptr<> to tie its
|
||||
* lifetime to the descriptor.
|
||||
*/
|
||||
request_ = std::make_unique<CaptureRequest>(camera,
|
||||
reinterpret_cast<uint64_t>(this));
|
||||
}
|
||||
|
||||
/*
|
||||
* \class CameraDevice
|
||||
*
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue