/* SPDX-FileCopyrightText: 2018 Fredrik Höglund SPDX-FileCopyrightText: 2019 Roman Gilg SPDX-FileCopyrightText: 2021 Vlad Zahorodnii SPDX-FileCopyrightText: 2021 Xaver Hugl SPDX-License-Identifier: LGPL-2.1-only OR LGPL-3.0-only OR LicenseRef-KDE-Accepted-LGPL */ #pragma once #include "clientbuffer.h" #include "clientbufferintegration.h" #include "dmabufattributes.h" #include #include #include namespace KWaylandServer { class LinuxDmaBufV1ClientBufferPrivate; class LinuxDmaBufV1ClientBufferIntegrationPrivate; class LinuxDmaBufV1FeedbackPrivate; /** * The LinuxDmaBufV1ClientBuffer class represents a linux dma-buf client buffer. * * The LinuxDmaBufV1ClientBuffer can be used even after the underlying wl_buffer object * is destroyed by the client. */ class KWIN_EXPORT LinuxDmaBufV1ClientBuffer : public ClientBuffer { Q_OBJECT Q_DECLARE_PRIVATE(LinuxDmaBufV1ClientBuffer) public: LinuxDmaBufV1ClientBuffer(const KWin::DmaBufAttributes &attrs, quint32 flags); ~LinuxDmaBufV1ClientBuffer() override; quint32 format() const; quint32 flags() const; KWin::DmaBufAttributes attributes() const; QSize size() const override; bool hasAlphaChannel() const override; Origin origin() const override; private: void initialize(wl_resource *resource); friend class LinuxDmaBufParamsV1; }; class KWIN_EXPORT LinuxDmaBufV1Feedback : public QObject { Q_OBJECT public: ~LinuxDmaBufV1Feedback() override; enum class TrancheFlag : uint32_t { Scanout = 1, }; Q_DECLARE_FLAGS(TrancheFlags, TrancheFlag) struct Tranche { dev_t device; TrancheFlags flags; QHash> formatTable; }; /** * Sets the list of tranches for this feedback object, with lower indices * indicating a higher priority / a more optimal configuration. * The main device does not need to be included */ void setTranches(const QVector &tranches); private: LinuxDmaBufV1Feedback(LinuxDmaBufV1ClientBufferIntegrationPrivate *integration); friend class LinuxDmaBufV1ClientBufferIntegrationPrivate; friend class LinuxDmaBufV1FeedbackPrivate; std::unique_ptr d; }; /** * The LinuxDmaBufV1ClientBufferIntegration class provides support for linux dma-buf buffers. */ class KWIN_EXPORT LinuxDmaBufV1ClientBufferIntegration : public ClientBufferIntegration { Q_OBJECT public: explicit LinuxDmaBufV1ClientBufferIntegration(Display *display); ~LinuxDmaBufV1ClientBufferIntegration() override; /** * The Iface class provides an interface from the LinuxDmabufInterface into the compositor */ class RendererInterface { public: virtual ~RendererInterface() = default; /** * Imports a linux-dmabuf buffer into the compositor. * * The parent LinuxDmabufUnstableV1Interface class takes ownership of returned * buffer objects. * * In return the returned buffer takes ownership of the file descriptor for each * plane. * * Note that it is the responsibility of the caller to close the file descriptors * when the import fails. * * @return The imported buffer on success, and nullptr otherwise. */ virtual LinuxDmaBufV1ClientBuffer *importBuffer(const KWin::DmaBufAttributes &attrs, quint32 flags) = 0; }; RendererInterface *rendererInterface() const; /** * Sets the compositor implementation for the dmabuf interface. * * The ownership is not transferred by this call. */ void setRendererInterface(RendererInterface *rendererInterface); void setSupportedFormatsWithModifiers(const QVector &tranches); private: friend class LinuxDmaBufV1ClientBufferIntegrationPrivate; std::unique_ptr d; }; } // namespace KWaylandServer