[libcamera-devel] [PATCH 1/2] libcamera: request: Declare a using directive for map of buffers
Niklas Söderlund
niklas.soderlund at ragnatech.se
Tue Aug 11 01:45:27 CEST 2020
Declare a using directive for the map of Stream to FrameBuffer. Update
all users of Request::buffers() to use the new usage directive.
Signed-off-by: Niklas Söderlund <niklas.soderlund at ragnatech.se>
---
include/libcamera/request.h | 6 ++++--
src/android/camera_device.cpp | 2 +-
src/cam/capture.cpp | 2 +-
src/libcamera/request.cpp | 5 +++++
src/qcam/main_window.h | 4 ++--
test/camera/buffer_import.cpp | 2 +-
test/camera/capture.cpp | 2 +-
7 files changed, 15 insertions(+), 8 deletions(-)
diff --git a/include/libcamera/request.h b/include/libcamera/request.h
index eded68318b7dbb3c..e74f56a7d6415315 100644
--- a/include/libcamera/request.h
+++ b/include/libcamera/request.h
@@ -31,6 +31,8 @@ public:
RequestCancelled,
};
+ using BufferMap = std::map<Stream *, FrameBuffer *>;
+
Request(Camera *camera, uint64_t cookie = 0);
Request(const Request &) = delete;
Request &operator=(const Request &) = delete;
@@ -38,7 +40,7 @@ public:
ControlList &controls() { return *controls_; }
ControlList &metadata() { return *metadata_; }
- const std::map<Stream *, FrameBuffer *> &buffers() const { return bufferMap_; }
+ const BufferMap &buffers() const { return bufferMap_; }
int addBuffer(Stream *stream, FrameBuffer *buffer);
FrameBuffer *findBuffer(Stream *stream) const;
@@ -58,7 +60,7 @@ private:
CameraControlValidator *validator_;
ControlList *controls_;
ControlList *metadata_;
- std::map<Stream *, FrameBuffer *> bufferMap_;
+ BufferMap bufferMap_;
std::unordered_set<FrameBuffer *> pending_;
const uint64_t cookie_;
diff --git a/src/android/camera_device.cpp b/src/android/camera_device.cpp
index d9183501228f4642..3419236a061cba57 100644
--- a/src/android/camera_device.cpp
+++ b/src/android/camera_device.cpp
@@ -1371,7 +1371,7 @@ int CameraDevice::processCaptureRequest(camera3_capture_request_t *camera3Reques
void CameraDevice::requestComplete(Request *request)
{
- const std::map<Stream *, FrameBuffer *> &buffers = request->buffers();
+ const Request::BufferMap &buffers = request->buffers();
camera3_buffer_status status = CAMERA3_BUFFER_STATUS_OK;
std::unique_ptr<CameraMetadata> resultMetadata;
Camera3RequestDescriptor *descriptor =
diff --git a/src/cam/capture.cpp b/src/cam/capture.cpp
index 3d8e89d52c7ab68d..0720376983470f2f 100644
--- a/src/cam/capture.cpp
+++ b/src/cam/capture.cpp
@@ -157,7 +157,7 @@ void Capture::requestComplete(Request *request)
if (request->status() == Request::RequestCancelled)
return;
- const std::map<Stream *, FrameBuffer *> &buffers = request->buffers();
+ const Request::BufferMap &buffers = request->buffers();
std::chrono::steady_clock::time_point now = std::chrono::steady_clock::now();
double fps = std::chrono::duration_cast<std::chrono::milliseconds>(now - last_).count();
diff --git a/src/libcamera/request.cpp b/src/libcamera/request.cpp
index f3753514131ae394..d5f11e8c43c32766 100644
--- a/src/libcamera/request.cpp
+++ b/src/libcamera/request.cpp
@@ -37,6 +37,11 @@ LOG_DEFINE_CATEGORY(Request)
* The request has been cancelled due to capture stop
*/
+/**
+ * \typedef Request::BufferMap
+ * \brief A map of Stream to FrameBuffer pointers
+ */
+
/**
* \class Request
* \brief A frame capture request
diff --git a/src/qcam/main_window.h b/src/qcam/main_window.h
index 4606fe487ad49777..6e1bcd76a2438b4c 100644
--- a/src/qcam/main_window.h
+++ b/src/qcam/main_window.h
@@ -47,13 +47,13 @@ public:
{
}
- CaptureRequest(const std::map<Stream *, FrameBuffer *> &buffers,
+ CaptureRequest(const Request::BufferMap &buffers,
const ControlList &metadata)
: buffers_(buffers), metadata_(metadata)
{
}
- std::map<Stream *, FrameBuffer *> buffers_;
+ Request::BufferMap buffers_;
ControlList metadata_;
};
diff --git a/test/camera/buffer_import.cpp b/test/camera/buffer_import.cpp
index 46e03746213912aa..726d2cb2fe757066 100644
--- a/test/camera/buffer_import.cpp
+++ b/test/camera/buffer_import.cpp
@@ -46,7 +46,7 @@ protected:
if (request->status() != Request::RequestComplete)
return;
- const std::map<Stream *, FrameBuffer *> &buffers = request->buffers();
+ const Request::BufferMap &buffers = request->buffers();
completeRequestsCount_++;
diff --git a/test/camera/capture.cpp b/test/camera/capture.cpp
index ea84daeef196e349..ae572eb955753151 100644
--- a/test/camera/capture.cpp
+++ b/test/camera/capture.cpp
@@ -39,7 +39,7 @@ protected:
if (request->status() != Request::RequestComplete)
return;
- const std::map<Stream *, FrameBuffer *> &buffers = request->buffers();
+ const Request::BufferMap &buffers = request->buffers();
completeRequestsCount_++;
--
2.28.0
More information about the libcamera-devel
mailing list