summaryrefslogtreecommitdiff
path: root/src/cam/kms_sink.h
diff options
context:
space:
mode:
authorLaurent Pinchart <laurent.pinchart@ideasonboard.com>2022-10-20 00:44:55 +0300
committerLaurent Pinchart <laurent.pinchart@ideasonboard.com>2022-10-20 13:36:25 +0300
commit84ad104499d9efc0253dae1a60ee070ed375ad95 (patch)
treed10fd53eb79cebb28fa3f72b18b46dddb6382b83 /src/cam/kms_sink.h
parentdaf3f4b59f4ea0ecb42c6a39fe909f071d3a2842 (diff)
Move test applications to src/apps/
The cam and qcam test application share code, currently through a crude hack that references the cam source files directly from the qcam meson.build file. To prepare for the introduction of hosting that code in a static library, move all applications to src/apps/. Signed-off-by: Laurent Pinchart <laurent.pinchart@ideasonboard.com> Reviewed-by: Paul Elder <paul.elder@ideasonboard.com> Reviewed-by: Kieran Bingham <kieran.bingham@ideasonboard.com>
Diffstat (limited to 'src/cam/kms_sink.h')
-rw-r--r--src/cam/kms_sink.h83
1 files changed, 0 insertions, 83 deletions
diff --git a/src/cam/kms_sink.h b/src/cam/kms_sink.h
deleted file mode 100644
index e2c618a1..00000000
--- a/src/cam/kms_sink.h
+++ /dev/null
@@ -1,83 +0,0 @@
-/* SPDX-License-Identifier: GPL-2.0-or-later */
-/*
- * Copyright (C) 2021, Ideas on Board Oy
- *
- * kms_sink.h - KMS Sink
- */
-
-#pragma once
-
-#include <list>
-#include <memory>
-#include <mutex>
-#include <optional>
-#include <string>
-#include <utility>
-
-#include <libcamera/base/signal.h>
-
-#include <libcamera/geometry.h>
-#include <libcamera/pixel_format.h>
-
-#include "drm.h"
-#include "frame_sink.h"
-
-class KMSSink : public FrameSink
-{
-public:
- KMSSink(const std::string &connectorName);
-
- void mapBuffer(libcamera::FrameBuffer *buffer) override;
-
- int configure(const libcamera::CameraConfiguration &config) override;
- int start() override;
- int stop() override;
-
- bool processRequest(libcamera::Request *request) override;
-
-private:
- class Request
- {
- public:
- Request(std::unique_ptr<DRM::AtomicRequest> drmRequest,
- libcamera::Request *camRequest)
- : drmRequest_(std::move(drmRequest)), camRequest_(camRequest)
- {
- }
-
- std::unique_ptr<DRM::AtomicRequest> drmRequest_;
- libcamera::Request *camRequest_;
- };
-
- int selectPipeline(const libcamera::PixelFormat &format);
- int configurePipeline(const libcamera::PixelFormat &format);
- bool testModeSet(DRM::FrameBuffer *drmBuffer,
- const libcamera::Rectangle &src,
- const libcamera::Rectangle &dst);
- bool setupComposition(DRM::FrameBuffer *drmBuffer);
-
- void requestComplete(DRM::AtomicRequest *request);
-
- DRM::Device dev_;
-
- const DRM::Connector *connector_;
- const DRM::Crtc *crtc_;
- const DRM::Plane *plane_;
- const DRM::Mode *mode_;
-
- libcamera::PixelFormat format_;
- libcamera::Size size_;
- unsigned int stride_;
- std::optional<unsigned int> colorEncoding_;
- std::optional<unsigned int> colorRange_;
-
- libcamera::Rectangle src_;
- libcamera::Rectangle dst_;
-
- std::map<libcamera::FrameBuffer *, std::unique_ptr<DRM::FrameBuffer>> buffers_;
-
- std::mutex lock_;
- std::unique_ptr<Request> pending_;
- std::unique_ptr<Request> queued_;
- std::unique_ptr<Request> active_;
-};