new file mode 100644
@@ -0,0 +1,32 @@
+/* SPDX-License-Identifier: LGPL-2.1-or-later */
+/*
+ * Copyright (C) 2022, Google Inc.
+ *
+ * android_framebuffer.cpp - Android Frame buffer handling
+ */
+
+#include "android_framebuffer.h"
+
+#include <hardware/camera3.h>
+
+AndroidFrameBuffer::AndroidFrameBuffer(
+ buffer_handle_t handle,
+ std::unique_ptr<Private> d,
+ const std::vector<Plane> &planes,
+ unsigned int cookie)
+ : FrameBuffer(std::move(d), planes, cookie), handle_(handle)
+{
+}
+
+AndroidFrameBuffer::AndroidFrameBuffer(
+ buffer_handle_t handle,
+ const std::vector<Plane> &planes,
+ unsigned int cookie)
+ : FrameBuffer(planes, cookie), handle_(handle)
+{
+}
+
+buffer_handle_t AndroidFrameBuffer::getHandle() const
+{
+ return handle_;
+}
new file mode 100644
@@ -0,0 +1,28 @@
+/* SPDX-License-Identifier: LGPL-2.1-or-later */
+/*
+ * Copyright (C) 2022, Google Inc.
+ *
+ * android_framebuffer.h - Android Frame buffer handling
+ */
+
+#pragma once
+
+#include "libcamera/internal/framebuffer.h"
+
+#include <hardware/camera3.h>
+
+class AndroidFrameBuffer final : public libcamera::FrameBuffer
+{
+public:
+ AndroidFrameBuffer(
+ buffer_handle_t handle, std::unique_ptr<Private> d,
+ const std::vector<Plane> &planes,
+ unsigned int cookie = 0);
+ AndroidFrameBuffer(buffer_handle_t handle,
+ const std::vector<Plane> &planes,
+ unsigned int cookie = 0);
+ buffer_handle_t getHandle() const;
+
+private:
+ buffer_handle_t handle_ = nullptr;
+};
@@ -25,6 +25,7 @@
#include "system/graphics.h"
+#include "android_framebuffer.h"
#include "camera_buffer.h"
#include "camera_hal_config.h"
#include "camera_ops.h"
@@ -754,7 +755,7 @@ CameraDevice::createFrameBuffer(const buffer_handle_t camera3buffer,
planes[i].length = buf.size(i);
}
- return std::make_unique<FrameBuffer>(planes);
+ return std::make_unique<AndroidFrameBuffer>(camera3buffer, planes);
}
int CameraDevice::processControls(Camera3RequestDescriptor *descriptor)
@@ -13,9 +13,10 @@
#include <libcamera/base/class.h>
#include <libcamera/camera.h>
-#include <libcamera/framebuffer.h>
#include <libcamera/geometry.h>
+#include "android_framebuffer.h"
+
class CameraDevice;
class PlatformFrameBufferAllocator : libcamera::Extensible
@@ -31,7 +32,7 @@ public:
* Note: The returned FrameBuffer needs to be destroyed before
* PlatformFrameBufferAllocator is destroyed.
*/
- std::unique_ptr<libcamera::FrameBuffer> allocate(
+ std::unique_ptr<AndroidFrameBuffer> allocate(
int halPixelFormat, const libcamera::Size &size, uint32_t usage);
};
@@ -44,7 +45,7 @@ PlatformFrameBufferAllocator::PlatformFrameBufferAllocator( \
PlatformFrameBufferAllocator::~PlatformFrameBufferAllocator() \
{ \
} \
-std::unique_ptr<libcamera::FrameBuffer> \
+std::unique_ptr<AndroidFrameBuffer> \
PlatformFrameBufferAllocator::allocate(int halPixelFormat, \
const libcamera::Size &size, \
uint32_t usage) \
@@ -38,6 +38,7 @@ endif
android_deps += [libyuv_dep]
android_hal_sources = files([
+ 'android_framebuffer.cpp',
'camera3_hal.cpp',
'camera_capabilities.cpp',
'camera_device.cpp',
@@ -14,6 +14,7 @@
#include "libcamera/internal/framebuffer.h"
+#include "../android_framebuffer.h"
#include "../camera_device.h"
#include "../frame_buffer_allocator.h"
#include "cros-camera/camera_buffer_manager.h"
@@ -47,11 +48,11 @@ public:
{
}
- std::unique_ptr<libcamera::FrameBuffer>
+ std::unique_ptr<AndroidFrameBuffer>
allocate(int halPixelFormat, const libcamera::Size &size, uint32_t usage);
};
-std::unique_ptr<libcamera::FrameBuffer>
+std::unique_ptr<AndroidFrameBuffer>
PlatformFrameBufferAllocator::Private::allocate(int halPixelFormat,
const libcamera::Size &size,
uint32_t usage)
@@ -80,9 +81,11 @@ PlatformFrameBufferAllocator::Private::allocate(int halPixelFormat,
plane.length = cros::CameraBufferManager::GetPlaneSize(handle, i);
}
- return std::make_unique<FrameBuffer>(
- std::make_unique<CrosFrameBufferData>(std::move(scopedHandle)),
- planes);
+ auto fb = std::make_unique<AndroidFrameBuffer>(handle,
+ std::make_unique<CrosFrameBufferData>(std::move(scopedHandle)),
+ planes);
+
+ return fb;
}
PUBLIC_FRAME_BUFFER_ALLOCATOR_IMPLEMENTATION
@@ -18,6 +18,7 @@
#include <hardware/gralloc.h>
#include <hardware/hardware.h>
+#include "../android_framebuffer.h"
#include "../camera_device.h"
#include "../frame_buffer_allocator.h"
@@ -77,7 +78,7 @@ public:
~Private() override;
- std::unique_ptr<libcamera::FrameBuffer>
+ std::unique_ptr<AndroidFrameBuffer>
allocate(int halPixelFormat, const libcamera::Size &size, uint32_t usage);
private:
@@ -92,7 +93,7 @@ PlatformFrameBufferAllocator::Private::~Private()
gralloc_close(allocDevice_);
}
-std::unique_ptr<libcamera::FrameBuffer>
+std::unique_ptr<AndroidFrameBuffer>
PlatformFrameBufferAllocator::Private::allocate(int halPixelFormat,
const libcamera::Size &size,
uint32_t usage)
@@ -135,9 +136,9 @@ PlatformFrameBufferAllocator::Private::allocate(int halPixelFormat,
offset += planeSize;
}
- return std::make_unique<FrameBuffer>(
- std::make_unique<GenericFrameBufferData>(allocDevice_, handle),
- planes);
+ return std::make_unique<AndroidFrameBuffer>(handle,
+ std::make_unique<GenericFrameBufferData>(allocDevice_, handle),
+ planes);
}
PUBLIC_FRAME_BUFFER_ALLOCATOR_IMPLEMENTATION