aboutsummaryrefslogtreecommitdiff
path: root/backend
diff options
context:
space:
mode:
authorDrew DeVault <sir@cmpwn.com>2017-09-07 10:18:28 +0900
committerGitHub <noreply@github.com>2017-09-07 10:18:28 +0900
commitc59ccbde518ac173fffe8aba16ad9c5b703f7e2a (patch)
tree56634ac125808cc53f3de76950a7a480b96095d9 /backend
parent586ae674ae65c64bf57653afae5378ca76ba40a7 (diff)
parent7d43d662f5cb54c13cbc4c791d97bfee30c10124 (diff)
Merge pull request #137 from emersion/gamma_control
Add gamma_control interface
Diffstat (limited to 'backend')
-rw-r--r--backend/drm/drm.c19
1 files changed, 19 insertions, 0 deletions
diff --git a/backend/drm/drm.c b/backend/drm/drm.c
index 5b24e05f..163321a3 100644
--- a/backend/drm/drm.c
+++ b/backend/drm/drm.c
@@ -301,6 +301,23 @@ static void wlr_drm_output_swap_buffers(struct wlr_output *_output) {
output->pageflip_pending = true;
}
+static void wlr_drm_output_set_gamma(struct wlr_output *_output,
+ uint16_t size, uint16_t *r, uint16_t *g, uint16_t *b) {
+ struct wlr_drm_output *output = (struct wlr_drm_output *)_output;
+ struct wlr_drm_backend *backend =
+ wl_container_of(output->renderer, backend, renderer);
+ drmModeCrtcSetGamma(backend->fd, output->crtc->id, size, r, g, b);
+}
+
+static uint16_t wlr_drm_output_get_gamma_size(struct wlr_output *_output) {
+ struct wlr_drm_output *output = (struct wlr_drm_output *)_output;
+ drmModeCrtc *crtc = output->old_crtc;
+ if (!crtc) {
+ return 0;
+ }
+ return crtc->gamma_size;
+}
+
void wlr_drm_output_start_renderer(struct wlr_drm_output *output) {
if (output->state != WLR_DRM_OUTPUT_CONNECTED) {
return;
@@ -696,6 +713,8 @@ static struct wlr_output_impl output_impl = {
.destroy = wlr_drm_output_destroy,
.make_current = wlr_drm_output_make_current,
.swap_buffers = wlr_drm_output_swap_buffers,
+ .set_gamma = wlr_drm_output_set_gamma,
+ .get_gamma_size = wlr_drm_output_get_gamma_size,
};
static int find_id(const void *item, const void *cmp_to) {