kwin/src/backends/drm/drm_gpu.h

139 lines
3.7 KiB
C
Raw Normal View History

/*
KWin - the KDE window manager
This file is part of the KDE project.
SPDX-FileCopyrightText: 2020 Xaver Hugl <xaver.hugl@gmail.com>
SPDX-License-Identifier: GPL-2.0-or-later
*/
#ifndef DRM_GPU_H
#define DRM_GPU_H
#include <qobject.h>
#include <QVector>
2021-02-19 11:59:43 +00:00
#include <QSocketNotifier>
#include <QPointer>
#include <QSize>
#include <epoxy/egl.h>
2021-11-22 13:00:59 +00:00
#include <sys/types.h>
struct gbm_device;
2021-02-05 18:45:34 +00:00
namespace KWaylandServer
{
class DrmLeaseDeviceV1Interface;
class DrmLeaseV1Interface;
}
namespace KWin
{
2020-11-27 19:57:24 +00:00
class DrmOutput;
class DrmObject;
class DrmCrtc;
class DrmConnector;
class DrmPlane;
class DrmBackend;
class EglGbmBackend;
class DrmPipeline;
class DrmAbstractOutput;
class DrmVirtualOutput;
2021-02-05 18:45:34 +00:00
class DrmLeaseOutput;
2020-11-27 19:57:24 +00:00
class DrmGpu : public QObject
{
Q_OBJECT
public:
DrmGpu(DrmBackend *backend, const QString &devNode, int fd, dev_t deviceId);
~DrmGpu();
2020-11-27 19:57:24 +00:00
int fd() const;
dev_t deviceId() const;
QString devNode() const;
2020-11-27 19:57:24 +00:00
bool atomicModeSetting() const;
bool addFB2ModifiersSupported() const;
bool isNVidia() const;
bool isFormatSupported(uint32_t drmFormat) const;
gbm_device *gbmDevice() const;
EGLDisplay eglDisplay() const;
EglGbmBackend *eglBackend() const;
DrmBackend *platform() const;
2020-11-19 08:52:29 +00:00
/**
* Returns the clock from which presentation timestamps are sourced. The returned value
* can be either CLOCK_MONOTONIC or CLOCK_REALTIME.
*/
clockid_t presentationClock() const;
QVector<DrmAbstractOutput*> outputs() const;
const QVector<DrmPipeline*> pipelines() const;
bool testPendingConfiguration();
2021-02-22 18:17:23 +00:00
void setEglDisplay(EGLDisplay display);
void setEglBackend(EglGbmBackend *eglBackend);
bool updateOutputs();
enum VirtualOutputMode { Placeholder, Full };
DrmVirtualOutput *createVirtualOutput(const QString &name, const QSize &size, double scale, VirtualOutputMode mode);
void removeVirtualOutput(DrmVirtualOutput *output);
bool needsModeset() const;
bool maybeModeset();
Q_SIGNALS:
void outputAdded(DrmAbstractOutput *output);
void outputRemoved(DrmAbstractOutput *output);
void outputEnabled(DrmAbstractOutput *output);
void outputDisabled(DrmAbstractOutput *output);
2020-11-27 19:57:24 +00:00
private:
void dispatchEvents();
DrmOutput *findOutput(quint32 connector);
2021-02-05 18:45:34 +00:00
DrmLeaseOutput *findLeaseOutput(quint32 connector);
2021-04-27 11:49:53 +00:00
void removeOutput(DrmOutput *output);
2021-02-05 18:45:34 +00:00
void removeLeaseOutput(DrmLeaseOutput *output);
void initDrmResources();
void waitIdle();
bool checkCrtcAssignment(QVector<DrmConnector*> connectors, QVector<DrmCrtc*> crtcs);
QVector<DrmObject*> unusedObjects() const;
2020-11-27 19:57:24 +00:00
2021-02-05 18:45:34 +00:00
void handleLeaseRequest(KWaylandServer::DrmLeaseV1Interface *leaseRequest);
void handleLeaseRevoked(KWaylandServer::DrmLeaseV1Interface *lease);
static void pageFlipHandler(int fd, unsigned int sequence, unsigned int sec, unsigned int usec, unsigned int crtc_id, void *user_data);
const int m_fd;
const dev_t m_deviceId;
const QString m_devNode;
bool m_atomicModeSetting;
bool m_addFB2ModifiersSupported = false;
bool m_isNVidia;
clockid_t m_presentationClock;
gbm_device* m_gbmDevice;
EGLDisplay m_eglDisplay = EGL_NO_DISPLAY;
QPointer<EglGbmBackend> m_eglBackend;
DrmBackend* const m_platform;
2020-11-27 19:57:24 +00:00
QVector<DrmPlane*> m_planes;
QVector<DrmCrtc*> m_crtcs;
QVector<DrmConnector*> m_connectors;
QVector<DrmObject*> m_allObjects;
QVector<DrmPipeline*> m_pipelines;
QVector<DrmOutput*> m_drmOutputs;
QVector<DrmAbstractOutput*> m_outputs;
2021-02-05 18:45:34 +00:00
QVector<DrmLeaseOutput*> m_leaseOutputs;
KWaylandServer::DrmLeaseDeviceV1Interface *m_leaseDevice = nullptr;
QSocketNotifier *m_socketNotifier = nullptr;
QSize m_cursorSize;
};
}
#endif // DRM_GPU_H