From 009828beac9bfe9c36d336a4de0d297f90aece52 Mon Sep 17 00:00:00 2001 From: Tomi Valkeinen Date: Mon, 28 Sep 2015 01:13:34 +0300 Subject: Initial version --- libkms++/encoder.cpp | 63 ++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 63 insertions(+) create mode 100644 libkms++/encoder.cpp (limited to 'libkms++/encoder.cpp') diff --git a/libkms++/encoder.cpp b/libkms++/encoder.cpp new file mode 100644 index 0000000..081177b --- /dev/null +++ b/libkms++/encoder.cpp @@ -0,0 +1,63 @@ +#include +#include +#include +#include +#include +#include +#include + +#include "kms++.h" + +using namespace std; + +namespace kms +{ + +struct EncoderPriv +{ + drmModeEncoderPtr drm_encoder; +}; + +Encoder::Encoder(Card &card, uint32_t id) + :DrmObject(card, id, DRM_MODE_OBJECT_ENCODER) +{ + m_priv = new EncoderPriv(); + m_priv->drm_encoder = drmModeGetEncoder(this->card().fd(), this->id()); + assert(m_priv->drm_encoder); +} + +Encoder::~Encoder() +{ + drmModeFreeEncoder(m_priv->drm_encoder); + delete m_priv; +} + +void Encoder::print_short() const +{ + auto e = m_priv->drm_encoder; + + printf("Encoder %d, %d\n", id(), + e->encoder_type); +} + +Crtc* Encoder::get_crtc() const +{ + return card().get_crtc(m_priv->drm_encoder->crtc_id); +} + +vector Encoder::get_possible_crtcs() const +{ + unsigned bits = m_priv->drm_encoder->possible_crtcs; + vector crtcs; + + for (int idx = 0; bits; idx++, bits >>= 1) { + if ((bits & 1) == 0) + continue; + + auto crtc = card().get_crtc_by_index(idx); + crtcs.push_back(crtc); + } + + return crtcs; +} +} -- cgit v1.2.3