[libcamera-devel] [PATCH v3 08/10] android: camera_buffer: Add method to get the JPEG blob size
Jacopo Mondi
jacopo at jmondi.org
Tue Mar 2 12:51:06 CET 2021
To maintain compatibility with platforms that do not provide a memory
backend implementation add a method to be return the size of the buffer
used for JPEG encoding capped to a maximum size.
Platforms that implement a memory backend will always calculate the
correct buffer size.
Signed-off-by: Jacopo Mondi <jacopo at jmondi.org>
---
src/android/camera_buffer.h | 2 ++
src/android/jpeg/post_processor_jpeg.cpp | 12 ++++++++++--
src/android/mm/generic_camera_buffer.cpp | 14 ++++++++++++++
3 files changed, 26 insertions(+), 2 deletions(-)
diff --git a/src/android/camera_buffer.h b/src/android/camera_buffer.h
index 2311cdaf96b2..342aac6d3f14 100644
--- a/src/android/camera_buffer.h
+++ b/src/android/camera_buffer.h
@@ -26,6 +26,8 @@ public:
libcamera::Span<const uint8_t> plane(unsigned int plane) const;
libcamera::Span<uint8_t> plane(unsigned int plane);
+
+ size_t jpegBlobSize(size_t maxJpegBlobSize);
};
#endif /* __ANDROID_CAMERA_BUFFER_H__ */
diff --git a/src/android/jpeg/post_processor_jpeg.cpp b/src/android/jpeg/post_processor_jpeg.cpp
index 83244ce6769e..65ab6b196ad1 100644
--- a/src/android/jpeg/post_processor_jpeg.cpp
+++ b/src/android/jpeg/post_processor_jpeg.cpp
@@ -182,8 +182,16 @@ int PostProcessorJpeg::process(const FrameBuffer &source,
}
/* Fill in the JPEG blob header. */
- uint8_t *resultPtr = destination->plane(0).data()
- + destination->plane(0).size()
+ /*
+ * \todo For backward compatibility reasons with the android_generic
+ * memory backend, continue using the maxJpegBufferSize in case the
+ * computed buffer size is larger. This can be dropped once all
+ * supported platforms will have a working memory backend that
+ * returns the correct buffer size.
+ */
+ size_t blobSize = std::min<unsigned int>(cameraDevice_->maxJpegBufferSize(),
+ destination->plane(0).size());
+ uint8_t *resultPtr = destination->plane(0).data() + blobSize
- sizeof(struct camera3_jpeg_blob);
auto *blob = reinterpret_cast<struct camera3_jpeg_blob *>(resultPtr);
blob->jpeg_blob_id = CAMERA3_JPEG_BLOB_ID;
diff --git a/src/android/mm/generic_camera_buffer.cpp b/src/android/mm/generic_camera_buffer.cpp
index 45a83c351266..5637b3f415eb 100644
--- a/src/android/mm/generic_camera_buffer.cpp
+++ b/src/android/mm/generic_camera_buffer.cpp
@@ -27,6 +27,8 @@ public:
unsigned int numPlanes() const;
Span<uint8_t> plane(unsigned int plane);
+
+ size_t jpegBlobSize(size_t maxJpegBlobSize);
};
CameraBuffer::Private::Private(CameraBuffer *cameraBuffer,
@@ -77,6 +79,12 @@ Span<uint8_t> CameraBuffer::Private::plane(unsigned int plane)
return maps_[plane];
}
+size_t CameraBuffer::Private::jpegBlobSize(size_t maxJpegBlobSize)
+{
+ return std::min<unsigned int>(plane(0).size(),
+ maxJpegBlobSize);
+}
+
CameraBuffer::CameraBuffer(buffer_handle_t camera3Buffer, int flags)
: Extensible(new Private(this, camera3Buffer, flags))
{
@@ -109,3 +117,9 @@ Span<uint8_t> CameraBuffer::plane(unsigned int plane)
Private *const d = LIBCAMERA_D_PTR();
return d->plane(plane);
}
+
+size_t CameraBuffer::jpegBlobSize(size_t maxJpegBlobSize)
+{
+ Private *const d = LIBCAMERA_D_PTR();
+ return d->jpegBlobSize(maxJpegBlobSize);
+}
--
2.30.0
More information about the libcamera-devel
mailing list