[libcamera-devel] [PATCH 1/3] android: post_processor: Introduce a PostProcessor interface

Umang Jain email at uajain.com
Thu Oct 15 19:14:55 CEST 2020


Introduce a PostProcessor interface for the streams that require any
kind of processing (refer to CameraStream::Type) for their consumption
by the HAL layer. The PostProcessor interface can be configured via
configure() and the actual processing can be initiated using process().

The post-processing layer can be extended to have multiple post
processors for various stream configurations. As of now, we only have
one post processor (JPEG), hence the subsequent commit will port its
function to this interface.

Signed-off-by: Umang Jain <email at uajain.com>
---
 src/android/post_processor.h | 28 ++++++++++++++++++++++++++++
 1 file changed, 28 insertions(+)
 create mode 100644 src/android/post_processor.h

diff --git a/src/android/post_processor.h b/src/android/post_processor.h
new file mode 100644
index 0000000..a891c43
--- /dev/null
+++ b/src/android/post_processor.h
@@ -0,0 +1,28 @@
+/* SPDX-License-Identifier: LGPL-2.1-or-later */
+/*
+ * Copyright (C) 2020, Google Inc.
+ *
+ * post_processor.h - CameraStream Post Processing Interface
+ */
+#ifndef __ANDROID_POST_PROCESSOR_H__
+#define __ANDROID_POST_PROCESSOR_H__
+
+#include <libcamera/buffer.h>
+#include <libcamera/span.h>
+#include <libcamera/stream.h>
+
+class CameraMetadata;
+
+class PostProcessor
+{
+public:
+	virtual ~PostProcessor() {}
+
+	virtual int configure(const libcamera::StreamConfiguration &inCfg,
+			      const libcamera::StreamConfiguration &outCfg) = 0;
+	virtual int process(const libcamera::FrameBuffer *source,
+			    const libcamera::Span<uint8_t> &destination,
+			    CameraMetadata *metadata) = 0;
+};
+
+#endif /* __ANDROID_POST_PROCESSOR_H__ */
-- 
2.26.2



More information about the libcamera-devel mailing list