aboutsummaryrefslogtreecommitdiff
path: root/rootston/output.c
diff options
context:
space:
mode:
authorDrew DeVault <sir@cmpwn.com>2018-07-07 08:58:17 -0700
committerGitHub <noreply@github.com>2018-07-07 08:58:17 -0700
commitbe54278207f5099b77a538e3043758aa59e5c998 (patch)
tree8e322b1c600afa6fd56a325d20e00d0ec054e85b /rootston/output.c
parent7c6588d7ae0b260aedc61da58eb6bf153b35ca94 (diff)
parent60a83e99f4dc930d7d4ed5999f49967a72b7df32 (diff)
Merge pull request #1095 from agx/output-add-mode
Allow to add additional modes to outputs
Diffstat (limited to 'rootston/output.c')
-rw-r--r--rootston/output.c14
1 files changed, 13 insertions, 1 deletions
diff --git a/rootston/output.c b/rootston/output.c
index fd7df99c..e3b03984 100644
--- a/rootston/output.c
+++ b/rootston/output.c
@@ -16,6 +16,7 @@
#include "rootston/layers.h"
#include "rootston/output.h"
#include "rootston/server.h"
+#include "backend/drm/drm.h"
/**
* Rotate a child's position relative to a parent. The parent size is (pw, ph),
@@ -821,7 +822,7 @@ void handle_new_output(struct wl_listener *listener, void *data) {
wlr_output->model, wlr_output->serial, wlr_output->phys_width,
wlr_output->phys_height);
- if (wl_list_length(&wlr_output->modes) > 0) {
+ if (!wl_list_empty(&wlr_output->modes)) {
struct wlr_output_mode *mode =
wl_container_of((&wlr_output->modes)->prev, mode, link);
wlr_output_set_mode(wlr_output, mode);
@@ -857,6 +858,17 @@ void handle_new_output(struct wl_listener *listener, void *data) {
roots_config_get_output(config, wlr_output);
if (output_config) {
if (output_config->enable) {
+ struct roots_output_mode_config *mode_config;
+
+ if (wlr_output_is_drm(wlr_output)) {
+ wl_list_for_each(mode_config, &output_config->modes, link) {
+ wlr_drm_connector_add_mode(wlr_output, &mode_config->info);
+ }
+ } else {
+ if (!wl_list_empty(&output_config->modes)) {
+ wlr_log(L_ERROR, "Can only add modes for DRM backend");
+ }
+ }
if (output_config->mode.width) {
set_mode(wlr_output, output_config);
}