blob: 3cfe2cbb1fe648b2a888910e5760ecf5835fd4a6 [file] [log] [blame]
Daniel Vetterc2fcd272014-11-05 00:14:14 +01001/*
2 * Copyright (C) 2014 Red Hat
3 * Copyright (C) 2014 Intel Corp.
4 *
5 * Permission is hereby granted, free of charge, to any person obtaining a
6 * copy of this software and associated documentation files (the "Software"),
7 * to deal in the Software without restriction, including without limitation
8 * the rights to use, copy, modify, merge, publish, distribute, sublicense,
9 * and/or sell copies of the Software, and to permit persons to whom the
10 * Software is furnished to do so, subject to the following conditions:
11 *
12 * The above copyright notice and this permission notice shall be included in
13 * all copies or substantial portions of the Software.
14 *
15 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
18 * THE COPYRIGHT HOLDER(S) OR AUTHOR(S) BE LIABLE FOR ANY CLAIM, DAMAGES OR
19 * OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
20 * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
21 * OTHER DEALINGS IN THE SOFTWARE.
22 *
23 * Authors:
24 * Rob Clark <robdclark@gmail.com>
25 * Daniel Vetter <daniel.vetter@ffwll.ch>
26 */
27
28#include <drm/drmP.h>
29#include <drm/drm_atomic.h>
30#include <drm/drm_plane_helper.h>
31#include <drm/drm_crtc_helper.h>
Daniel Vetter623369e2014-09-16 17:50:47 +020032#include <drm/drm_atomic_helper.h>
Chris Wilsonf54d1862016-10-25 13:00:45 +010033#include <linux/dma-fence.h>
Daniel Vetterc2fcd272014-11-05 00:14:14 +010034
Marek Szyprowski44d1240d2016-06-13 11:11:26 +020035#include "drm_crtc_internal.h"
36
Daniel Vetter3150c7d2014-11-06 20:53:29 +010037/**
38 * DOC: overview
39 *
40 * This helper library provides implementations of check and commit functions on
41 * top of the CRTC modeset helper callbacks and the plane helper callbacks. It
42 * also provides convenience implementations for the atomic state handling
43 * callbacks for drivers which don't need to subclass the drm core structures to
44 * add their own additional internal state.
45 *
46 * This library also provides default implementations for the check callback in
Daniel Vetter26196f72015-08-25 16:26:03 +020047 * drm_atomic_helper_check() and for the commit callback with
48 * drm_atomic_helper_commit(). But the individual stages and callbacks are
49 * exposed to allow drivers to mix and match and e.g. use the plane helpers only
Daniel Vetter3150c7d2014-11-06 20:53:29 +010050 * together with a driver private modeset implementation.
51 *
52 * This library also provides implementations for all the legacy driver
Daniel Vetter26196f72015-08-25 16:26:03 +020053 * interfaces on top of the atomic interface. See drm_atomic_helper_set_config(),
54 * drm_atomic_helper_disable_plane(), drm_atomic_helper_disable_plane() and the
Daniel Vetter3150c7d2014-11-06 20:53:29 +010055 * various functions to implement set_property callbacks. New drivers must not
56 * implement these functions themselves but must use the provided helpers.
Daniel Vetter092d01d2015-12-04 09:45:44 +010057 *
58 * The atomic helper uses the same function table structures as all other
Daniel Vetterea0dd852016-12-29 21:48:26 +010059 * modesetting helpers. See the documentation for &struct drm_crtc_helper_funcs,
60 * struct &drm_encoder_helper_funcs and &struct drm_connector_helper_funcs. It
61 * also shares the &struct drm_plane_helper_funcs function table with the plane
Daniel Vetter092d01d2015-12-04 09:45:44 +010062 * helpers.
Daniel Vetter3150c7d2014-11-06 20:53:29 +010063 */
Daniel Vetterc2fcd272014-11-05 00:14:14 +010064static void
65drm_atomic_helper_plane_changed(struct drm_atomic_state *state,
66 struct drm_plane_state *plane_state,
67 struct drm_plane *plane)
68{
69 struct drm_crtc_state *crtc_state;
70
71 if (plane->state->crtc) {
Andrzej Hajda2943ef32016-03-15 13:46:00 +010072 crtc_state = drm_atomic_get_existing_crtc_state(state,
73 plane->state->crtc);
Daniel Vetterc2fcd272014-11-05 00:14:14 +010074
75 if (WARN_ON(!crtc_state))
76 return;
77
78 crtc_state->planes_changed = true;
79 }
80
81 if (plane_state->crtc) {
Andrzej Hajda2943ef32016-03-15 13:46:00 +010082 crtc_state = drm_atomic_get_existing_crtc_state(state,
83 plane_state->crtc);
Daniel Vetterc2fcd272014-11-05 00:14:14 +010084
85 if (WARN_ON(!crtc_state))
86 return;
87
88 crtc_state->planes_changed = true;
89 }
90}
91
Maarten Lankhorst8248b652016-03-03 10:17:40 +010092static int handle_conflicting_encoders(struct drm_atomic_state *state,
93 bool disable_conflicting_encoders)
Daniel Vetter97ac3202015-12-03 10:49:14 +010094{
Daniel Vetter97ac3202015-12-03 10:49:14 +010095 struct drm_connector_state *conn_state;
Daniel Vetter623369e2014-09-16 17:50:47 +020096 struct drm_connector *connector;
Daniel Vetterc36a3252016-12-15 16:58:43 +010097 struct drm_connector_list_iter conn_iter;
Maarten Lankhorst40616a22016-03-03 10:17:39 +010098 struct drm_encoder *encoder;
99 unsigned encoder_mask = 0;
Daniel Vetterc36a3252016-12-15 16:58:43 +0100100 int i, ret = 0;
Daniel Vetter623369e2014-09-16 17:50:47 +0200101
Maarten Lankhorst8248b652016-03-03 10:17:40 +0100102 /*
103 * First loop, find all newly assigned encoders from the connectors
104 * part of the state. If the same encoder is assigned to multiple
105 * connectors bail out.
106 */
Maarten Lankhorst40616a22016-03-03 10:17:39 +0100107 for_each_connector_in_state(state, connector, conn_state, i) {
108 const struct drm_connector_helper_funcs *funcs = connector->helper_private;
109 struct drm_encoder *new_encoder;
Daniel Vetter623369e2014-09-16 17:50:47 +0200110
Maarten Lankhorst40616a22016-03-03 10:17:39 +0100111 if (!conn_state->crtc)
Daniel Vetter623369e2014-09-16 17:50:47 +0200112 continue;
113
Maarten Lankhorst40616a22016-03-03 10:17:39 +0100114 if (funcs->atomic_best_encoder)
115 new_encoder = funcs->atomic_best_encoder(connector, conn_state);
Boris Brezillona0909cc2016-06-01 18:03:37 +0200116 else if (funcs->best_encoder)
Maarten Lankhorst40616a22016-03-03 10:17:39 +0100117 new_encoder = funcs->best_encoder(connector);
Boris Brezillona0909cc2016-06-01 18:03:37 +0200118 else
119 new_encoder = drm_atomic_helper_best_encoder(connector);
Maarten Lankhorst40616a22016-03-03 10:17:39 +0100120
Maarten Lankhorst8248b652016-03-03 10:17:40 +0100121 if (new_encoder) {
122 if (encoder_mask & (1 << drm_encoder_index(new_encoder))) {
123 DRM_DEBUG_ATOMIC("[ENCODER:%d:%s] on [CONNECTOR:%d:%s] already assigned\n",
124 new_encoder->base.id, new_encoder->name,
125 connector->base.id, connector->name);
126
127 return -EINVAL;
128 }
129
Maarten Lankhorst40616a22016-03-03 10:17:39 +0100130 encoder_mask |= 1 << drm_encoder_index(new_encoder);
Maarten Lankhorst8248b652016-03-03 10:17:40 +0100131 }
Daniel Vetter623369e2014-09-16 17:50:47 +0200132 }
133
Maarten Lankhorst8248b652016-03-03 10:17:40 +0100134 if (!encoder_mask)
135 return 0;
136
137 /*
138 * Second loop, iterate over all connectors not part of the state.
139 *
140 * If a conflicting encoder is found and disable_conflicting_encoders
141 * is not set, an error is returned. Userspace can provide a solution
142 * through the atomic ioctl.
143 *
144 * If the flag is set conflicting connectors are removed from the crtc
145 * and the crtc is disabled if no encoder is left. This preserves
146 * compatibility with the legacy set_config behavior.
147 */
Daniel Vetterc36a3252016-12-15 16:58:43 +0100148 drm_connector_list_iter_get(state->dev, &conn_iter);
149 drm_for_each_connector_iter(connector, &conn_iter) {
Maarten Lankhorst40616a22016-03-03 10:17:39 +0100150 struct drm_crtc_state *crtc_state;
151
152 if (drm_atomic_get_existing_connector_state(state, connector))
153 continue;
154
155 encoder = connector->state->best_encoder;
156 if (!encoder || !(encoder_mask & (1 << drm_encoder_index(encoder))))
157 continue;
158
Maarten Lankhorst8248b652016-03-03 10:17:40 +0100159 if (!disable_conflicting_encoders) {
160 DRM_DEBUG_ATOMIC("[ENCODER:%d:%s] in use on [CRTC:%d:%s] by [CONNECTOR:%d:%s]\n",
161 encoder->base.id, encoder->name,
162 connector->state->crtc->base.id,
163 connector->state->crtc->name,
164 connector->base.id, connector->name);
Daniel Vetterc36a3252016-12-15 16:58:43 +0100165 ret = -EINVAL;
166 goto out;
Maarten Lankhorst8248b652016-03-03 10:17:40 +0100167 }
168
Maarten Lankhorst40616a22016-03-03 10:17:39 +0100169 conn_state = drm_atomic_get_connector_state(state, connector);
Daniel Vetterc36a3252016-12-15 16:58:43 +0100170 if (IS_ERR(conn_state)) {
171 ret = PTR_ERR(conn_state);
172 goto out;
173 }
Maarten Lankhorst40616a22016-03-03 10:17:39 +0100174
175 DRM_DEBUG_ATOMIC("[ENCODER:%d:%s] in use on [CRTC:%d:%s], disabling [CONNECTOR:%d:%s]\n",
176 encoder->base.id, encoder->name,
177 conn_state->crtc->base.id, conn_state->crtc->name,
178 connector->base.id, connector->name);
179
180 crtc_state = drm_atomic_get_existing_crtc_state(state, conn_state->crtc);
181
182 ret = drm_atomic_set_crtc_for_connector(conn_state, NULL);
183 if (ret)
Daniel Vetterc36a3252016-12-15 16:58:43 +0100184 goto out;
Maarten Lankhorst40616a22016-03-03 10:17:39 +0100185
186 if (!crtc_state->connector_mask) {
187 ret = drm_atomic_set_mode_prop_for_crtc(crtc_state,
188 NULL);
189 if (ret < 0)
Daniel Vetterc36a3252016-12-15 16:58:43 +0100190 goto out;
Maarten Lankhorst40616a22016-03-03 10:17:39 +0100191
192 crtc_state->active = false;
193 }
194 }
Daniel Vetterc36a3252016-12-15 16:58:43 +0100195out:
196 drm_connector_list_iter_put(&conn_iter);
Maarten Lankhorst40616a22016-03-03 10:17:39 +0100197
Daniel Vetterc36a3252016-12-15 16:58:43 +0100198 return ret;
Daniel Vetter623369e2014-09-16 17:50:47 +0200199}
200
Maarten Lankhorste87a52b2016-01-28 15:04:58 +0100201static void
202set_best_encoder(struct drm_atomic_state *state,
203 struct drm_connector_state *conn_state,
204 struct drm_encoder *encoder)
205{
206 struct drm_crtc_state *crtc_state;
207 struct drm_crtc *crtc;
208
209 if (conn_state->best_encoder) {
210 /* Unset the encoder_mask in the old crtc state. */
211 crtc = conn_state->connector->state->crtc;
212
213 /* A NULL crtc is an error here because we should have
214 * duplicated a NULL best_encoder when crtc was NULL.
215 * As an exception restoring duplicated atomic state
216 * during resume is allowed, so don't warn when
217 * best_encoder is equal to encoder we intend to set.
218 */
219 WARN_ON(!crtc && encoder != conn_state->best_encoder);
220 if (crtc) {
221 crtc_state = drm_atomic_get_existing_crtc_state(state, crtc);
222
223 crtc_state->encoder_mask &=
224 ~(1 << drm_encoder_index(conn_state->best_encoder));
225 }
226 }
227
228 if (encoder) {
229 crtc = conn_state->crtc;
230 WARN_ON(!crtc);
231 if (crtc) {
232 crtc_state = drm_atomic_get_existing_crtc_state(state, crtc);
233
234 crtc_state->encoder_mask |=
235 1 << drm_encoder_index(encoder);
236 }
237 }
238
239 conn_state->best_encoder = encoder;
240}
241
Maarten Lankhorstec5aaa52016-03-03 10:17:41 +0100242static void
Daniel Vetter623369e2014-09-16 17:50:47 +0200243steal_encoder(struct drm_atomic_state *state,
Maarten Lankhorstff19b782016-03-03 10:17:38 +0100244 struct drm_encoder *encoder)
Daniel Vetter623369e2014-09-16 17:50:47 +0200245{
Daniel Vetter623369e2014-09-16 17:50:47 +0200246 struct drm_crtc_state *crtc_state;
247 struct drm_connector *connector;
248 struct drm_connector_state *connector_state;
Maarten Lankhorstec5aaa52016-03-03 10:17:41 +0100249 int i;
Daniel Vetter623369e2014-09-16 17:50:47 +0200250
Maarten Lankhorstec5aaa52016-03-03 10:17:41 +0100251 for_each_connector_in_state(state, connector, connector_state, i) {
Maarten Lankhorstff19b782016-03-03 10:17:38 +0100252 struct drm_crtc *encoder_crtc;
Daniel Vetter623369e2014-09-16 17:50:47 +0200253
Maarten Lankhorste87a52b2016-01-28 15:04:58 +0100254 if (connector_state->best_encoder != encoder)
255 continue;
256
Maarten Lankhorstff19b782016-03-03 10:17:38 +0100257 encoder_crtc = connector->state->crtc;
Daniel Vetter623369e2014-09-16 17:50:47 +0200258
Maarten Lankhorstff19b782016-03-03 10:17:38 +0100259 DRM_DEBUG_ATOMIC("[ENCODER:%d:%s] in use on [CRTC:%d:%s], stealing it\n",
260 encoder->base.id, encoder->name,
261 encoder_crtc->base.id, encoder_crtc->name);
262
Daniel Vetter623369e2014-09-16 17:50:47 +0200263 set_best_encoder(state, connector_state, NULL);
Maarten Lankhorstff19b782016-03-03 10:17:38 +0100264
265 crtc_state = drm_atomic_get_existing_crtc_state(state, encoder_crtc);
266 crtc_state->connectors_changed = true;
267
Maarten Lankhorstec5aaa52016-03-03 10:17:41 +0100268 return;
Daniel Vetter623369e2014-09-16 17:50:47 +0200269 }
Daniel Vetter623369e2014-09-16 17:50:47 +0200270}
271
272static int
Maarten Lankhorst94595452016-02-24 09:37:29 +0100273update_connector_routing(struct drm_atomic_state *state,
274 struct drm_connector *connector,
275 struct drm_connector_state *connector_state)
Daniel Vetter623369e2014-09-16 17:50:47 +0200276{
Ville Syrjäläb5ceff202015-03-10 14:35:20 +0200277 const struct drm_connector_helper_funcs *funcs;
Daniel Vetter623369e2014-09-16 17:50:47 +0200278 struct drm_encoder *new_encoder;
Daniel Vetter623369e2014-09-16 17:50:47 +0200279 struct drm_crtc_state *crtc_state;
Daniel Vetter623369e2014-09-16 17:50:47 +0200280
Daniel Vetter17a38d92015-02-22 12:24:16 +0100281 DRM_DEBUG_ATOMIC("Updating routing for [CONNECTOR:%d:%s]\n",
282 connector->base.id,
283 connector->name);
Daniel Vetter623369e2014-09-16 17:50:47 +0200284
285 if (connector->state->crtc != connector_state->crtc) {
286 if (connector->state->crtc) {
Maarten Lankhorst9b8d1e52016-03-03 10:17:42 +0100287 crtc_state = drm_atomic_get_existing_crtc_state(state, connector->state->crtc);
Maarten Lankhorstfc596662015-07-21 13:28:57 +0200288 crtc_state->connectors_changed = true;
Daniel Vetter623369e2014-09-16 17:50:47 +0200289 }
290
291 if (connector_state->crtc) {
Maarten Lankhorst9b8d1e52016-03-03 10:17:42 +0100292 crtc_state = drm_atomic_get_existing_crtc_state(state, connector_state->crtc);
Maarten Lankhorstfc596662015-07-21 13:28:57 +0200293 crtc_state->connectors_changed = true;
Daniel Vetter623369e2014-09-16 17:50:47 +0200294 }
295 }
296
297 if (!connector_state->crtc) {
Daniel Vetter17a38d92015-02-22 12:24:16 +0100298 DRM_DEBUG_ATOMIC("Disabling [CONNECTOR:%d:%s]\n",
Daniel Vetter623369e2014-09-16 17:50:47 +0200299 connector->base.id,
300 connector->name);
301
Maarten Lankhorste87a52b2016-01-28 15:04:58 +0100302 set_best_encoder(state, connector_state, NULL);
Daniel Vetter623369e2014-09-16 17:50:47 +0200303
304 return 0;
305 }
306
307 funcs = connector->helper_private;
Daniel Vetter3b8a6842015-08-03 17:24:08 +0200308
309 if (funcs->atomic_best_encoder)
310 new_encoder = funcs->atomic_best_encoder(connector,
311 connector_state);
Boris Brezillonc61b93f2016-06-07 13:47:56 +0200312 else if (funcs->best_encoder)
Daniel Vetter3b8a6842015-08-03 17:24:08 +0200313 new_encoder = funcs->best_encoder(connector);
Boris Brezillonc61b93f2016-06-07 13:47:56 +0200314 else
315 new_encoder = drm_atomic_helper_best_encoder(connector);
Daniel Vetter623369e2014-09-16 17:50:47 +0200316
317 if (!new_encoder) {
Daniel Vetter17a38d92015-02-22 12:24:16 +0100318 DRM_DEBUG_ATOMIC("No suitable encoder found for [CONNECTOR:%d:%s]\n",
319 connector->base.id,
320 connector->name);
Daniel Vetter623369e2014-09-16 17:50:47 +0200321 return -EINVAL;
322 }
323
Daniel Vetter5481c8f2015-11-18 18:46:48 +0100324 if (!drm_encoder_crtc_ok(new_encoder, connector_state->crtc)) {
325 DRM_DEBUG_ATOMIC("[ENCODER:%d:%s] incompatible with [CRTC:%d]\n",
326 new_encoder->base.id,
327 new_encoder->name,
328 connector_state->crtc->base.id);
329 return -EINVAL;
330 }
331
Daniel Vetter623369e2014-09-16 17:50:47 +0200332 if (new_encoder == connector_state->best_encoder) {
Maarten Lankhorste87a52b2016-01-28 15:04:58 +0100333 set_best_encoder(state, connector_state, new_encoder);
334
Ville Syrjäläfa3ab4c2015-12-08 18:41:53 +0200335 DRM_DEBUG_ATOMIC("[CONNECTOR:%d:%s] keeps [ENCODER:%d:%s], now on [CRTC:%d:%s]\n",
Daniel Vetter17a38d92015-02-22 12:24:16 +0100336 connector->base.id,
337 connector->name,
338 new_encoder->base.id,
339 new_encoder->name,
Ville Syrjäläfa3ab4c2015-12-08 18:41:53 +0200340 connector_state->crtc->base.id,
341 connector_state->crtc->name);
Daniel Vetter623369e2014-09-16 17:50:47 +0200342
343 return 0;
344 }
345
Maarten Lankhorstec5aaa52016-03-03 10:17:41 +0100346 steal_encoder(state, new_encoder);
Daniel Vetter623369e2014-09-16 17:50:47 +0200347
Maarten Lankhorste87a52b2016-01-28 15:04:58 +0100348 set_best_encoder(state, connector_state, new_encoder);
349
Maarten Lankhorst9b8d1e52016-03-03 10:17:42 +0100350 crtc_state = drm_atomic_get_existing_crtc_state(state, connector_state->crtc);
Maarten Lankhorstfc596662015-07-21 13:28:57 +0200351 crtc_state->connectors_changed = true;
Daniel Vetter623369e2014-09-16 17:50:47 +0200352
Ville Syrjäläfa3ab4c2015-12-08 18:41:53 +0200353 DRM_DEBUG_ATOMIC("[CONNECTOR:%d:%s] using [ENCODER:%d:%s] on [CRTC:%d:%s]\n",
Daniel Vetter17a38d92015-02-22 12:24:16 +0100354 connector->base.id,
355 connector->name,
356 new_encoder->base.id,
357 new_encoder->name,
Ville Syrjäläfa3ab4c2015-12-08 18:41:53 +0200358 connector_state->crtc->base.id,
359 connector_state->crtc->name);
Daniel Vetter623369e2014-09-16 17:50:47 +0200360
361 return 0;
362}
363
364static int
365mode_fixup(struct drm_atomic_state *state)
366{
Ander Conselvan de Oliveiradf63b992015-04-10 14:58:39 +0300367 struct drm_crtc *crtc;
Daniel Vetter623369e2014-09-16 17:50:47 +0200368 struct drm_crtc_state *crtc_state;
Ander Conselvan de Oliveiradf63b992015-04-10 14:58:39 +0300369 struct drm_connector *connector;
Daniel Vetter623369e2014-09-16 17:50:47 +0200370 struct drm_connector_state *conn_state;
371 int i;
372 bool ret;
373
Ander Conselvan de Oliveiradf63b992015-04-10 14:58:39 +0300374 for_each_crtc_in_state(state, crtc, crtc_state, i) {
Maarten Lankhorstfc596662015-07-21 13:28:57 +0200375 if (!crtc_state->mode_changed &&
376 !crtc_state->connectors_changed)
Daniel Vetter623369e2014-09-16 17:50:47 +0200377 continue;
378
379 drm_mode_copy(&crtc_state->adjusted_mode, &crtc_state->mode);
380 }
381
Ander Conselvan de Oliveiradf63b992015-04-10 14:58:39 +0300382 for_each_connector_in_state(state, connector, conn_state, i) {
Ville Syrjäläb5ceff202015-03-10 14:35:20 +0200383 const struct drm_encoder_helper_funcs *funcs;
Daniel Vetter623369e2014-09-16 17:50:47 +0200384 struct drm_encoder *encoder;
385
Daniel Vetter623369e2014-09-16 17:50:47 +0200386 WARN_ON(!!conn_state->best_encoder != !!conn_state->crtc);
387
388 if (!conn_state->crtc || !conn_state->best_encoder)
389 continue;
390
Andrzej Hajda2943ef32016-03-15 13:46:00 +0100391 crtc_state = drm_atomic_get_existing_crtc_state(state,
392 conn_state->crtc);
Daniel Vetter623369e2014-09-16 17:50:47 +0200393
394 /*
395 * Each encoder has at most one connector (since we always steal
396 * it away), so we won't call ->mode_fixup twice.
397 */
398 encoder = conn_state->best_encoder;
399 funcs = encoder->helper_private;
400
Archit Taneja862e6862015-05-21 11:03:16 +0530401 ret = drm_bridge_mode_fixup(encoder->bridge, &crtc_state->mode,
402 &crtc_state->adjusted_mode);
403 if (!ret) {
404 DRM_DEBUG_ATOMIC("Bridge fixup failed\n");
405 return -EINVAL;
Daniel Vetter623369e2014-09-16 17:50:47 +0200406 }
407
Noralf Trønnes28276352016-05-11 18:09:20 +0200408 if (funcs && funcs->atomic_check) {
Thierry Reding4cd4df82014-12-03 16:44:34 +0100409 ret = funcs->atomic_check(encoder, crtc_state,
410 conn_state);
411 if (ret) {
Daniel Vetter17a38d92015-02-22 12:24:16 +0100412 DRM_DEBUG_ATOMIC("[ENCODER:%d:%s] check failed\n",
413 encoder->base.id, encoder->name);
Thierry Reding4cd4df82014-12-03 16:44:34 +0100414 return ret;
415 }
Noralf Trønnes28276352016-05-11 18:09:20 +0200416 } else if (funcs && funcs->mode_fixup) {
Thierry Reding4cd4df82014-12-03 16:44:34 +0100417 ret = funcs->mode_fixup(encoder, &crtc_state->mode,
418 &crtc_state->adjusted_mode);
419 if (!ret) {
Daniel Vetter17a38d92015-02-22 12:24:16 +0100420 DRM_DEBUG_ATOMIC("[ENCODER:%d:%s] fixup failed\n",
421 encoder->base.id, encoder->name);
Thierry Reding4cd4df82014-12-03 16:44:34 +0100422 return -EINVAL;
423 }
Daniel Vetter623369e2014-09-16 17:50:47 +0200424 }
425 }
426
Ander Conselvan de Oliveiradf63b992015-04-10 14:58:39 +0300427 for_each_crtc_in_state(state, crtc, crtc_state, i) {
Ville Syrjäläb5ceff202015-03-10 14:35:20 +0200428 const struct drm_crtc_helper_funcs *funcs;
Daniel Vetter623369e2014-09-16 17:50:47 +0200429
Liu Yingf55f1702016-05-27 17:35:54 +0800430 if (!crtc_state->enable)
431 continue;
432
Maarten Lankhorstfc596662015-07-21 13:28:57 +0200433 if (!crtc_state->mode_changed &&
434 !crtc_state->connectors_changed)
Daniel Vetter623369e2014-09-16 17:50:47 +0200435 continue;
436
437 funcs = crtc->helper_private;
Ander Conselvan de Oliveira840bfe92015-04-21 17:13:18 +0300438 if (!funcs->mode_fixup)
439 continue;
440
Daniel Vetter623369e2014-09-16 17:50:47 +0200441 ret = funcs->mode_fixup(crtc, &crtc_state->mode,
442 &crtc_state->adjusted_mode);
443 if (!ret) {
Ville Syrjäläfa3ab4c2015-12-08 18:41:53 +0200444 DRM_DEBUG_ATOMIC("[CRTC:%d:%s] fixup failed\n",
445 crtc->base.id, crtc->name);
Daniel Vetter623369e2014-09-16 17:50:47 +0200446 return -EINVAL;
447 }
448 }
449
450 return 0;
451}
452
Daniel Vetterd9b13622014-11-26 16:57:41 +0100453/**
John Hunterf98bd3e2015-03-17 15:30:26 +0800454 * drm_atomic_helper_check_modeset - validate state object for modeset changes
Daniel Vetterd9b13622014-11-26 16:57:41 +0100455 * @dev: DRM device
456 * @state: the driver state object
457 *
458 * Check the state object to see if the requested state is physically possible.
459 * This does all the crtc and connector related computations for an atomic
Maarten Lankhorstfc596662015-07-21 13:28:57 +0200460 * update and adds any additional connectors needed for full modesets and calls
461 * down into ->mode_fixup functions of the driver backend.
462 *
463 * crtc_state->mode_changed is set when the input mode is changed.
464 * crtc_state->connectors_changed is set when a connector is added or
465 * removed from the crtc.
466 * crtc_state->active_changed is set when crtc_state->active changes,
467 * which is used for dpms.
Brian Starkeyd807ed12016-10-13 10:47:08 +0100468 * See also: drm_atomic_crtc_needs_modeset()
Daniel Vetterd9b13622014-11-26 16:57:41 +0100469 *
470 * IMPORTANT:
471 *
Brian Starkeyd807ed12016-10-13 10:47:08 +0100472 * Drivers which set ->mode_changed (e.g. in their ->atomic_check hooks if a
Daniel Vetterd9b13622014-11-26 16:57:41 +0100473 * plane update can't be done without a full modeset) _must_ call this function
474 * afterwards after that change. It is permitted to call this function multiple
475 * times for the same update, e.g. when the ->atomic_check functions depend upon
476 * the adjusted dotclock for fifo space allocation and watermark computation.
477 *
Daniel Vetterc39032a2016-06-08 14:19:19 +0200478 * RETURNS:
Daniel Vetterd9b13622014-11-26 16:57:41 +0100479 * Zero for success or -errno
480 */
481int
Rob Clark934ce1c2014-11-19 16:41:33 -0500482drm_atomic_helper_check_modeset(struct drm_device *dev,
Daniel Vetter623369e2014-09-16 17:50:47 +0200483 struct drm_atomic_state *state)
484{
Daniel Vetter623369e2014-09-16 17:50:47 +0200485 struct drm_crtc *crtc;
486 struct drm_crtc_state *crtc_state;
Ander Conselvan de Oliveiradf63b992015-04-10 14:58:39 +0300487 struct drm_connector *connector;
488 struct drm_connector_state *connector_state;
Daniel Vetter623369e2014-09-16 17:50:47 +0200489 int i, ret;
490
Ander Conselvan de Oliveiradf63b992015-04-10 14:58:39 +0300491 for_each_crtc_in_state(state, crtc, crtc_state, i) {
Daniel Vetter623369e2014-09-16 17:50:47 +0200492 if (!drm_mode_equal(&crtc->state->mode, &crtc_state->mode)) {
Ville Syrjäläfa3ab4c2015-12-08 18:41:53 +0200493 DRM_DEBUG_ATOMIC("[CRTC:%d:%s] mode changed\n",
494 crtc->base.id, crtc->name);
Daniel Vetter623369e2014-09-16 17:50:47 +0200495 crtc_state->mode_changed = true;
496 }
497
498 if (crtc->state->enable != crtc_state->enable) {
Ville Syrjäläfa3ab4c2015-12-08 18:41:53 +0200499 DRM_DEBUG_ATOMIC("[CRTC:%d:%s] enable changed\n",
500 crtc->base.id, crtc->name);
Maarten Lankhorstfc596662015-07-21 13:28:57 +0200501
502 /*
503 * For clarity this assignment is done here, but
504 * enable == 0 is only true when there are no
505 * connectors and a NULL mode.
506 *
507 * The other way around is true as well. enable != 0
508 * iff connectors are attached and a mode is set.
509 */
Daniel Vetter623369e2014-09-16 17:50:47 +0200510 crtc_state->mode_changed = true;
Maarten Lankhorstfc596662015-07-21 13:28:57 +0200511 crtc_state->connectors_changed = true;
Daniel Vetter623369e2014-09-16 17:50:47 +0200512 }
513 }
514
Maarten Lankhorst8248b652016-03-03 10:17:40 +0100515 ret = handle_conflicting_encoders(state, state->legacy_set_config);
516 if (ret)
517 return ret;
Maarten Lankhorst40616a22016-03-03 10:17:39 +0100518
Ander Conselvan de Oliveiradf63b992015-04-10 14:58:39 +0300519 for_each_connector_in_state(state, connector, connector_state, i) {
Daniel Vetter623369e2014-09-16 17:50:47 +0200520 /*
Brian Starkeyd807ed12016-10-13 10:47:08 +0100521 * This only sets crtc->connectors_changed for routing changes,
522 * drivers must set crtc->connectors_changed themselves when
523 * connector properties need to be updated.
Daniel Vetter623369e2014-09-16 17:50:47 +0200524 */
Maarten Lankhorst94595452016-02-24 09:37:29 +0100525 ret = update_connector_routing(state, connector,
526 connector_state);
Daniel Vetter623369e2014-09-16 17:50:47 +0200527 if (ret)
528 return ret;
529 }
530
531 /*
532 * After all the routing has been prepared we need to add in any
533 * connector which is itself unchanged, but who's crtc changes it's
534 * configuration. This must be done before calling mode_fixup in case a
535 * crtc only changed its mode but has the same set of connectors.
536 */
Ander Conselvan de Oliveiradf63b992015-04-10 14:58:39 +0300537 for_each_crtc_in_state(state, crtc, crtc_state, i) {
Maarten Lankhorst14de6c42016-01-04 12:53:20 +0100538 bool has_connectors =
539 !!crtc_state->connector_mask;
Daniel Vetter623369e2014-09-16 17:50:47 +0200540
Daniel Vettereab3bbe2015-01-22 16:36:21 +0100541 /*
542 * We must set ->active_changed after walking connectors for
543 * otherwise an update that only changes active would result in
544 * a full modeset because update_connector_routing force that.
545 */
546 if (crtc->state->active != crtc_state->active) {
Ville Syrjäläfa3ab4c2015-12-08 18:41:53 +0200547 DRM_DEBUG_ATOMIC("[CRTC:%d:%s] active changed\n",
548 crtc->base.id, crtc->name);
Daniel Vettereab3bbe2015-01-22 16:36:21 +0100549 crtc_state->active_changed = true;
550 }
551
Daniel Vetter2465ff62015-06-18 09:58:55 +0200552 if (!drm_atomic_crtc_needs_modeset(crtc_state))
Daniel Vettereab3bbe2015-01-22 16:36:21 +0100553 continue;
554
Ville Syrjäläfa3ab4c2015-12-08 18:41:53 +0200555 DRM_DEBUG_ATOMIC("[CRTC:%d:%s] needs all connectors, enable: %c, active: %c\n",
556 crtc->base.id, crtc->name,
Daniel Vetter17a38d92015-02-22 12:24:16 +0100557 crtc_state->enable ? 'y' : 'n',
Ville Syrjäläfa3ab4c2015-12-08 18:41:53 +0200558 crtc_state->active ? 'y' : 'n');
Daniel Vetter623369e2014-09-16 17:50:47 +0200559
560 ret = drm_atomic_add_affected_connectors(state, crtc);
561 if (ret != 0)
562 return ret;
563
Maarten Lankhorst57744aa2015-05-19 16:41:03 +0200564 ret = drm_atomic_add_affected_planes(state, crtc);
565 if (ret != 0)
566 return ret;
567
Maarten Lankhorst14de6c42016-01-04 12:53:20 +0100568 if (crtc_state->enable != has_connectors) {
Ville Syrjäläfa3ab4c2015-12-08 18:41:53 +0200569 DRM_DEBUG_ATOMIC("[CRTC:%d:%s] enabled/connectors mismatch\n",
570 crtc->base.id, crtc->name);
Daniel Vetter623369e2014-09-16 17:50:47 +0200571
572 return -EINVAL;
573 }
574 }
575
576 return mode_fixup(state);
577}
Daniel Vetterd9b13622014-11-26 16:57:41 +0100578EXPORT_SYMBOL(drm_atomic_helper_check_modeset);
Daniel Vetter623369e2014-09-16 17:50:47 +0200579
Daniel Vetterc2fcd272014-11-05 00:14:14 +0100580/**
John Hunterf98bd3e2015-03-17 15:30:26 +0800581 * drm_atomic_helper_check_planes - validate state object for planes changes
Daniel Vetterc2fcd272014-11-05 00:14:14 +0100582 * @dev: DRM device
583 * @state: the driver state object
584 *
585 * Check the state object to see if the requested state is physically possible.
Daniel Vetterd9b13622014-11-26 16:57:41 +0100586 * This does all the plane update related checks using by calling into the
587 * ->atomic_check hooks provided by the driver.
Daniel Vetterc2fcd272014-11-05 00:14:14 +0100588 *
Maarten Lankhorstfc596662015-07-21 13:28:57 +0200589 * It also sets crtc_state->planes_changed to indicate that a crtc has
590 * updated planes.
591 *
Daniel Vetterc39032a2016-06-08 14:19:19 +0200592 * RETURNS:
Daniel Vetterc2fcd272014-11-05 00:14:14 +0100593 * Zero for success or -errno
594 */
Daniel Vetterd9b13622014-11-26 16:57:41 +0100595int
596drm_atomic_helper_check_planes(struct drm_device *dev,
597 struct drm_atomic_state *state)
Daniel Vetterc2fcd272014-11-05 00:14:14 +0100598{
Ander Conselvan de Oliveiradf63b992015-04-10 14:58:39 +0300599 struct drm_crtc *crtc;
600 struct drm_crtc_state *crtc_state;
601 struct drm_plane *plane;
602 struct drm_plane_state *plane_state;
Daniel Vetterc2fcd272014-11-05 00:14:14 +0100603 int i, ret = 0;
604
Ander Conselvan de Oliveiradf63b992015-04-10 14:58:39 +0300605 for_each_plane_in_state(state, plane, plane_state, i) {
Ville Syrjäläb5ceff202015-03-10 14:35:20 +0200606 const struct drm_plane_helper_funcs *funcs;
Daniel Vetterc2fcd272014-11-05 00:14:14 +0100607
608 funcs = plane->helper_private;
609
610 drm_atomic_helper_plane_changed(state, plane_state, plane);
611
612 if (!funcs || !funcs->atomic_check)
613 continue;
614
615 ret = funcs->atomic_check(plane, plane_state);
616 if (ret) {
Ville Syrjälä9f4c97a2015-12-08 18:41:54 +0200617 DRM_DEBUG_ATOMIC("[PLANE:%d:%s] atomic driver check failed\n",
618 plane->base.id, plane->name);
Daniel Vetterc2fcd272014-11-05 00:14:14 +0100619 return ret;
620 }
621 }
622
Ander Conselvan de Oliveiradf63b992015-04-10 14:58:39 +0300623 for_each_crtc_in_state(state, crtc, crtc_state, i) {
Ville Syrjäläb5ceff202015-03-10 14:35:20 +0200624 const struct drm_crtc_helper_funcs *funcs;
Daniel Vetterc2fcd272014-11-05 00:14:14 +0100625
626 funcs = crtc->helper_private;
627
628 if (!funcs || !funcs->atomic_check)
629 continue;
630
Daniel Vetterbe9174a2016-06-02 00:06:24 +0200631 ret = funcs->atomic_check(crtc, crtc_state);
Daniel Vetterc2fcd272014-11-05 00:14:14 +0100632 if (ret) {
Ville Syrjäläfa3ab4c2015-12-08 18:41:53 +0200633 DRM_DEBUG_ATOMIC("[CRTC:%d:%s] atomic driver check failed\n",
634 crtc->base.id, crtc->name);
Daniel Vetterc2fcd272014-11-05 00:14:14 +0100635 return ret;
636 }
637 }
638
Daniel Vetterd9b13622014-11-26 16:57:41 +0100639 return ret;
640}
641EXPORT_SYMBOL(drm_atomic_helper_check_planes);
642
643/**
644 * drm_atomic_helper_check - validate state object
645 * @dev: DRM device
646 * @state: the driver state object
647 *
648 * Check the state object to see if the requested state is physically possible.
649 * Only crtcs and planes have check callbacks, so for any additional (global)
650 * checking that a driver needs it can simply wrap that around this function.
651 * Drivers without such needs can directly use this as their ->atomic_check()
652 * callback.
653 *
Daniel Vetterb4274fb2014-11-26 17:02:18 +0100654 * This just wraps the two parts of the state checking for planes and modeset
655 * state in the default order: First it calls drm_atomic_helper_check_modeset()
656 * and then drm_atomic_helper_check_planes(). The assumption is that the
657 * ->atomic_check functions depend upon an updated adjusted_mode.clock to
658 * e.g. properly compute watermarks.
659 *
Daniel Vetterc39032a2016-06-08 14:19:19 +0200660 * RETURNS:
Daniel Vetterd9b13622014-11-26 16:57:41 +0100661 * Zero for success or -errno
662 */
663int drm_atomic_helper_check(struct drm_device *dev,
664 struct drm_atomic_state *state)
665{
666 int ret;
667
Daniel Vetterb4274fb2014-11-26 17:02:18 +0100668 ret = drm_atomic_helper_check_modeset(dev, state);
Daniel Vetterd9b13622014-11-26 16:57:41 +0100669 if (ret)
670 return ret;
671
Daniel Vetterb4274fb2014-11-26 17:02:18 +0100672 ret = drm_atomic_helper_check_planes(dev, state);
Rob Clark934ce1c2014-11-19 16:41:33 -0500673 if (ret)
674 return ret;
675
Daniel Vetterc2fcd272014-11-05 00:14:14 +0100676 return ret;
677}
678EXPORT_SYMBOL(drm_atomic_helper_check);
679
Daniel Vetter623369e2014-09-16 17:50:47 +0200680static void
681disable_outputs(struct drm_device *dev, struct drm_atomic_state *old_state)
682{
Ander Conselvan de Oliveiradf63b992015-04-10 14:58:39 +0300683 struct drm_connector *connector;
684 struct drm_connector_state *old_conn_state;
685 struct drm_crtc *crtc;
686 struct drm_crtc_state *old_crtc_state;
Daniel Vetter623369e2014-09-16 17:50:47 +0200687 int i;
688
Ander Conselvan de Oliveiradf63b992015-04-10 14:58:39 +0300689 for_each_connector_in_state(old_state, connector, old_conn_state, i) {
Ville Syrjäläb5ceff202015-03-10 14:35:20 +0200690 const struct drm_encoder_helper_funcs *funcs;
Daniel Vetter623369e2014-09-16 17:50:47 +0200691 struct drm_encoder *encoder;
692
Daniel Vetter623369e2014-09-16 17:50:47 +0200693 /* Shut down everything that's in the changeset and currently
694 * still on. So need to check the old, saved state. */
Ander Conselvan de Oliveiradf63b992015-04-10 14:58:39 +0300695 if (!old_conn_state->crtc)
Daniel Vetter623369e2014-09-16 17:50:47 +0200696 continue;
697
Andrzej Hajda2943ef32016-03-15 13:46:00 +0100698 old_crtc_state = drm_atomic_get_existing_crtc_state(old_state,
699 old_conn_state->crtc);
Daniel Vettereab3bbe2015-01-22 16:36:21 +0100700
Daniel Vetter4218a322015-03-26 22:18:40 +0100701 if (!old_crtc_state->active ||
Daniel Vetter2465ff62015-06-18 09:58:55 +0200702 !drm_atomic_crtc_needs_modeset(old_conn_state->crtc->state))
Daniel Vettereab3bbe2015-01-22 16:36:21 +0100703 continue;
704
Rob Clark46df9ad2014-11-20 15:40:36 -0500705 encoder = old_conn_state->best_encoder;
Daniel Vetter623369e2014-09-16 17:50:47 +0200706
Rob Clark46df9ad2014-11-20 15:40:36 -0500707 /* We shouldn't get this far if we didn't previously have
708 * an encoder.. but WARN_ON() rather than explode.
709 */
710 if (WARN_ON(!encoder))
Daniel Vetter623369e2014-09-16 17:50:47 +0200711 continue;
712
713 funcs = encoder->helper_private;
714
Daniel Vetter17a38d92015-02-22 12:24:16 +0100715 DRM_DEBUG_ATOMIC("disabling [ENCODER:%d:%s]\n",
716 encoder->base.id, encoder->name);
Daniel Vetter95d6eb32015-01-22 16:36:25 +0100717
Daniel Vetter623369e2014-09-16 17:50:47 +0200718 /*
719 * Each encoder has at most one connector (since we always steal
John Hunterf98bd3e2015-03-17 15:30:26 +0800720 * it away), so we won't call disable hooks twice.
Daniel Vetter623369e2014-09-16 17:50:47 +0200721 */
Archit Taneja862e6862015-05-21 11:03:16 +0530722 drm_bridge_disable(encoder->bridge);
Daniel Vetter623369e2014-09-16 17:50:47 +0200723
724 /* Right function depends upon target state. */
Noralf Trønnes28276352016-05-11 18:09:20 +0200725 if (funcs) {
726 if (connector->state->crtc && funcs->prepare)
727 funcs->prepare(encoder);
728 else if (funcs->disable)
729 funcs->disable(encoder);
730 else if (funcs->dpms)
731 funcs->dpms(encoder, DRM_MODE_DPMS_OFF);
732 }
Daniel Vetter623369e2014-09-16 17:50:47 +0200733
Archit Taneja862e6862015-05-21 11:03:16 +0530734 drm_bridge_post_disable(encoder->bridge);
Daniel Vetter623369e2014-09-16 17:50:47 +0200735 }
736
Ander Conselvan de Oliveiradf63b992015-04-10 14:58:39 +0300737 for_each_crtc_in_state(old_state, crtc, old_crtc_state, i) {
Ville Syrjäläb5ceff202015-03-10 14:35:20 +0200738 const struct drm_crtc_helper_funcs *funcs;
Daniel Vetter623369e2014-09-16 17:50:47 +0200739
740 /* Shut down everything that needs a full modeset. */
Daniel Vetter2465ff62015-06-18 09:58:55 +0200741 if (!drm_atomic_crtc_needs_modeset(crtc->state))
Daniel Vettereab3bbe2015-01-22 16:36:21 +0100742 continue;
743
744 if (!old_crtc_state->active)
Daniel Vetter623369e2014-09-16 17:50:47 +0200745 continue;
746
747 funcs = crtc->helper_private;
748
Ville Syrjäläfa3ab4c2015-12-08 18:41:53 +0200749 DRM_DEBUG_ATOMIC("disabling [CRTC:%d:%s]\n",
750 crtc->base.id, crtc->name);
Daniel Vetter95d6eb32015-01-22 16:36:25 +0100751
752
Daniel Vetter623369e2014-09-16 17:50:47 +0200753 /* Right function depends upon target state. */
Daniel Vetteree0a89c2015-01-22 16:36:24 +0100754 if (crtc->state->enable && funcs->prepare)
Daniel Vetter623369e2014-09-16 17:50:47 +0200755 funcs->prepare(crtc);
Liu Yingc9ac8b42016-08-26 15:30:38 +0800756 else if (funcs->atomic_disable)
757 funcs->atomic_disable(crtc, old_crtc_state);
Daniel Vetter623369e2014-09-16 17:50:47 +0200758 else if (funcs->disable)
759 funcs->disable(crtc);
760 else
761 funcs->dpms(crtc, DRM_MODE_DPMS_OFF);
762 }
763}
764
Daniel Vetter4c18d302015-05-12 15:27:37 +0200765/**
766 * drm_atomic_helper_update_legacy_modeset_state - update legacy modeset state
767 * @dev: DRM device
768 * @old_state: atomic state object with old state structures
769 *
770 * This function updates all the various legacy modeset state pointers in
771 * connectors, encoders and crtcs. It also updates the timestamping constants
772 * used for precise vblank timestamps by calling
773 * drm_calc_timestamping_constants().
774 *
775 * Drivers can use this for building their own atomic commit if they don't have
776 * a pure helper-based modeset implementation.
777 */
778void
779drm_atomic_helper_update_legacy_modeset_state(struct drm_device *dev,
780 struct drm_atomic_state *old_state)
Daniel Vetter623369e2014-09-16 17:50:47 +0200781{
Ander Conselvan de Oliveiradf63b992015-04-10 14:58:39 +0300782 struct drm_connector *connector;
783 struct drm_connector_state *old_conn_state;
784 struct drm_crtc *crtc;
785 struct drm_crtc_state *old_crtc_state;
Daniel Vetter623369e2014-09-16 17:50:47 +0200786 int i;
787
Maarten Lankhorst8c103422015-07-27 13:24:29 +0200788 /* clear out existing links and update dpms */
Ander Conselvan de Oliveiradf63b992015-04-10 14:58:39 +0300789 for_each_connector_in_state(old_state, connector, old_conn_state, i) {
Maarten Lankhorst8c103422015-07-27 13:24:29 +0200790 if (connector->encoder) {
791 WARN_ON(!connector->encoder->crtc);
Daniel Vetter623369e2014-09-16 17:50:47 +0200792
Maarten Lankhorst8c103422015-07-27 13:24:29 +0200793 connector->encoder->crtc = NULL;
794 connector->encoder = NULL;
795 }
Daniel Vetter623369e2014-09-16 17:50:47 +0200796
Maarten Lankhorst8c103422015-07-27 13:24:29 +0200797 crtc = connector->state->crtc;
798 if ((!crtc && old_conn_state->crtc) ||
799 (crtc && drm_atomic_crtc_needs_modeset(crtc->state))) {
800 struct drm_property *dpms_prop =
801 dev->mode_config.dpms_property;
802 int mode = DRM_MODE_DPMS_OFF;
803
804 if (crtc && crtc->state->active)
805 mode = DRM_MODE_DPMS_ON;
806
807 connector->dpms = mode;
808 drm_object_property_set_value(&connector->base,
809 dpms_prop, mode);
810 }
Daniel Vetter623369e2014-09-16 17:50:47 +0200811 }
812
813 /* set new links */
Ander Conselvan de Oliveiradf63b992015-04-10 14:58:39 +0300814 for_each_connector_in_state(old_state, connector, old_conn_state, i) {
815 if (!connector->state->crtc)
Daniel Vetter623369e2014-09-16 17:50:47 +0200816 continue;
817
818 if (WARN_ON(!connector->state->best_encoder))
819 continue;
820
821 connector->encoder = connector->state->best_encoder;
822 connector->encoder->crtc = connector->state->crtc;
823 }
824
825 /* set legacy state in the crtc structure */
Ander Conselvan de Oliveiradf63b992015-04-10 14:58:39 +0300826 for_each_crtc_in_state(old_state, crtc, old_crtc_state, i) {
Maarten Lankhorst26608012015-07-16 15:51:01 +0200827 struct drm_plane *primary = crtc->primary;
828
Daniel Vetter623369e2014-09-16 17:50:47 +0200829 crtc->mode = crtc->state->mode;
830 crtc->enabled = crtc->state->enable;
Maarten Lankhorst26608012015-07-16 15:51:01 +0200831
832 if (drm_atomic_get_existing_plane_state(old_state, primary) &&
833 primary->state->crtc == crtc) {
834 crtc->x = primary->state->src_x >> 16;
835 crtc->y = primary->state->src_y >> 16;
836 }
Daniel Vetter3d51d2d2015-05-12 15:21:06 +0200837
838 if (crtc->state->enable)
839 drm_calc_timestamping_constants(crtc,
840 &crtc->state->adjusted_mode);
Daniel Vetter623369e2014-09-16 17:50:47 +0200841 }
842}
Daniel Vetter4c18d302015-05-12 15:27:37 +0200843EXPORT_SYMBOL(drm_atomic_helper_update_legacy_modeset_state);
Daniel Vetter623369e2014-09-16 17:50:47 +0200844
845static void
846crtc_set_mode(struct drm_device *dev, struct drm_atomic_state *old_state)
847{
Ander Conselvan de Oliveiradf63b992015-04-10 14:58:39 +0300848 struct drm_crtc *crtc;
849 struct drm_crtc_state *old_crtc_state;
850 struct drm_connector *connector;
851 struct drm_connector_state *old_conn_state;
Daniel Vetter623369e2014-09-16 17:50:47 +0200852 int i;
853
Ander Conselvan de Oliveiradf63b992015-04-10 14:58:39 +0300854 for_each_crtc_in_state(old_state, crtc, old_crtc_state, i) {
Ville Syrjäläb5ceff202015-03-10 14:35:20 +0200855 const struct drm_crtc_helper_funcs *funcs;
Daniel Vetter623369e2014-09-16 17:50:47 +0200856
Ander Conselvan de Oliveiradf63b992015-04-10 14:58:39 +0300857 if (!crtc->state->mode_changed)
Daniel Vetter623369e2014-09-16 17:50:47 +0200858 continue;
859
860 funcs = crtc->helper_private;
861
Daniel Vetterc982bd92015-02-22 12:24:20 +0100862 if (crtc->state->enable && funcs->mode_set_nofb) {
Ville Syrjäläfa3ab4c2015-12-08 18:41:53 +0200863 DRM_DEBUG_ATOMIC("modeset on [CRTC:%d:%s]\n",
864 crtc->base.id, crtc->name);
Daniel Vetter95d6eb32015-01-22 16:36:25 +0100865
Daniel Vetter623369e2014-09-16 17:50:47 +0200866 funcs->mode_set_nofb(crtc);
Daniel Vetter95d6eb32015-01-22 16:36:25 +0100867 }
Daniel Vetter623369e2014-09-16 17:50:47 +0200868 }
869
Ander Conselvan de Oliveiradf63b992015-04-10 14:58:39 +0300870 for_each_connector_in_state(old_state, connector, old_conn_state, i) {
Ville Syrjäläb5ceff202015-03-10 14:35:20 +0200871 const struct drm_encoder_helper_funcs *funcs;
Daniel Vetter623369e2014-09-16 17:50:47 +0200872 struct drm_crtc_state *new_crtc_state;
Daniel Vetter623369e2014-09-16 17:50:47 +0200873 struct drm_encoder *encoder;
874 struct drm_display_mode *mode, *adjusted_mode;
875
Ander Conselvan de Oliveiradf63b992015-04-10 14:58:39 +0300876 if (!connector->state->best_encoder)
Daniel Vetter623369e2014-09-16 17:50:47 +0200877 continue;
878
879 encoder = connector->state->best_encoder;
880 funcs = encoder->helper_private;
881 new_crtc_state = connector->state->crtc->state;
882 mode = &new_crtc_state->mode;
883 adjusted_mode = &new_crtc_state->adjusted_mode;
884
Daniel Vettereab3bbe2015-01-22 16:36:21 +0100885 if (!new_crtc_state->mode_changed)
886 continue;
887
Daniel Vetter17a38d92015-02-22 12:24:16 +0100888 DRM_DEBUG_ATOMIC("modeset on [ENCODER:%d:%s]\n",
889 encoder->base.id, encoder->name);
Daniel Vetter95d6eb32015-01-22 16:36:25 +0100890
Daniel Vetter623369e2014-09-16 17:50:47 +0200891 /*
892 * Each encoder has at most one connector (since we always steal
John Hunterf98bd3e2015-03-17 15:30:26 +0800893 * it away), so we won't call mode_set hooks twice.
Daniel Vetter623369e2014-09-16 17:50:47 +0200894 */
Philipp Zabelfe4a11c2016-07-22 12:20:47 +0200895 if (funcs && funcs->atomic_mode_set) {
896 funcs->atomic_mode_set(encoder, new_crtc_state,
897 connector->state);
898 } else if (funcs && funcs->mode_set) {
Daniel Vetterc982bd92015-02-22 12:24:20 +0100899 funcs->mode_set(encoder, mode, adjusted_mode);
Philipp Zabelfe4a11c2016-07-22 12:20:47 +0200900 }
Daniel Vetter623369e2014-09-16 17:50:47 +0200901
Archit Taneja862e6862015-05-21 11:03:16 +0530902 drm_bridge_mode_set(encoder->bridge, mode, adjusted_mode);
Daniel Vetter623369e2014-09-16 17:50:47 +0200903 }
904}
905
906/**
Daniel Vetter1af434a2015-02-22 12:24:19 +0100907 * drm_atomic_helper_commit_modeset_disables - modeset commit to disable outputs
Daniel Vetter623369e2014-09-16 17:50:47 +0200908 * @dev: DRM device
Laurent Pincharta072f802015-02-22 12:24:18 +0100909 * @old_state: atomic state object with old state structures
Daniel Vetter623369e2014-09-16 17:50:47 +0200910 *
Daniel Vetter1af434a2015-02-22 12:24:19 +0100911 * This function shuts down all the outputs that need to be shut down and
Daniel Vetter623369e2014-09-16 17:50:47 +0200912 * prepares them (if required) with the new mode.
Daniel Vetter1af434a2015-02-22 12:24:19 +0100913 *
Laurent Pinchart60acc4e2015-05-27 15:05:42 +0300914 * For compatibility with legacy crtc helpers this should be called before
Daniel Vetter1af434a2015-02-22 12:24:19 +0100915 * drm_atomic_helper_commit_planes(), which is what the default commit function
916 * does. But drivers with different needs can group the modeset commits together
917 * and do the plane commits at the end. This is useful for drivers doing runtime
918 * PM since planes updates then only happen when the CRTC is actually enabled.
Daniel Vetter623369e2014-09-16 17:50:47 +0200919 */
Daniel Vetter1af434a2015-02-22 12:24:19 +0100920void drm_atomic_helper_commit_modeset_disables(struct drm_device *dev,
921 struct drm_atomic_state *old_state)
Daniel Vetter623369e2014-09-16 17:50:47 +0200922{
Laurent Pincharta072f802015-02-22 12:24:18 +0100923 disable_outputs(dev, old_state);
Daniel Vetter4c18d302015-05-12 15:27:37 +0200924
925 drm_atomic_helper_update_legacy_modeset_state(dev, old_state);
926
Laurent Pincharta072f802015-02-22 12:24:18 +0100927 crtc_set_mode(dev, old_state);
Daniel Vetter623369e2014-09-16 17:50:47 +0200928}
Daniel Vetter1af434a2015-02-22 12:24:19 +0100929EXPORT_SYMBOL(drm_atomic_helper_commit_modeset_disables);
Daniel Vetter623369e2014-09-16 17:50:47 +0200930
931/**
Daniel Vetter1af434a2015-02-22 12:24:19 +0100932 * drm_atomic_helper_commit_modeset_enables - modeset commit to enable outputs
Daniel Vetter623369e2014-09-16 17:50:47 +0200933 * @dev: DRM device
934 * @old_state: atomic state object with old state structures
935 *
Daniel Vetter1af434a2015-02-22 12:24:19 +0100936 * This function enables all the outputs with the new configuration which had to
937 * be turned off for the update.
938 *
Laurent Pinchart60acc4e2015-05-27 15:05:42 +0300939 * For compatibility with legacy crtc helpers this should be called after
Daniel Vetter1af434a2015-02-22 12:24:19 +0100940 * drm_atomic_helper_commit_planes(), which is what the default commit function
941 * does. But drivers with different needs can group the modeset commits together
942 * and do the plane commits at the end. This is useful for drivers doing runtime
943 * PM since planes updates then only happen when the CRTC is actually enabled.
Daniel Vetter623369e2014-09-16 17:50:47 +0200944 */
Daniel Vetter1af434a2015-02-22 12:24:19 +0100945void drm_atomic_helper_commit_modeset_enables(struct drm_device *dev,
946 struct drm_atomic_state *old_state)
Daniel Vetter623369e2014-09-16 17:50:47 +0200947{
Ander Conselvan de Oliveiradf63b992015-04-10 14:58:39 +0300948 struct drm_crtc *crtc;
949 struct drm_crtc_state *old_crtc_state;
950 struct drm_connector *connector;
951 struct drm_connector_state *old_conn_state;
Daniel Vetter623369e2014-09-16 17:50:47 +0200952 int i;
953
Ander Conselvan de Oliveiradf63b992015-04-10 14:58:39 +0300954 for_each_crtc_in_state(old_state, crtc, old_crtc_state, i) {
Ville Syrjäläb5ceff202015-03-10 14:35:20 +0200955 const struct drm_crtc_helper_funcs *funcs;
Daniel Vetter623369e2014-09-16 17:50:47 +0200956
957 /* Need to filter out CRTCs where only planes change. */
Daniel Vetter2465ff62015-06-18 09:58:55 +0200958 if (!drm_atomic_crtc_needs_modeset(crtc->state))
Daniel Vettereab3bbe2015-01-22 16:36:21 +0100959 continue;
960
961 if (!crtc->state->active)
Daniel Vetter623369e2014-09-16 17:50:47 +0200962 continue;
963
964 funcs = crtc->helper_private;
965
Daniel Vetteree0a89c2015-01-22 16:36:24 +0100966 if (crtc->state->enable) {
Ville Syrjäläfa3ab4c2015-12-08 18:41:53 +0200967 DRM_DEBUG_ATOMIC("enabling [CRTC:%d:%s]\n",
968 crtc->base.id, crtc->name);
Daniel Vetter95d6eb32015-01-22 16:36:25 +0100969
Daniel Vetteree0a89c2015-01-22 16:36:24 +0100970 if (funcs->enable)
971 funcs->enable(crtc);
972 else
973 funcs->commit(crtc);
974 }
Daniel Vetter623369e2014-09-16 17:50:47 +0200975 }
976
Ander Conselvan de Oliveiradf63b992015-04-10 14:58:39 +0300977 for_each_connector_in_state(old_state, connector, old_conn_state, i) {
Ville Syrjäläb5ceff202015-03-10 14:35:20 +0200978 const struct drm_encoder_helper_funcs *funcs;
Daniel Vetter623369e2014-09-16 17:50:47 +0200979 struct drm_encoder *encoder;
980
Ander Conselvan de Oliveiradf63b992015-04-10 14:58:39 +0300981 if (!connector->state->best_encoder)
Daniel Vetter623369e2014-09-16 17:50:47 +0200982 continue;
983
Daniel Vetter4218a322015-03-26 22:18:40 +0100984 if (!connector->state->crtc->state->active ||
Daniel Vetter2465ff62015-06-18 09:58:55 +0200985 !drm_atomic_crtc_needs_modeset(connector->state->crtc->state))
Daniel Vettereab3bbe2015-01-22 16:36:21 +0100986 continue;
987
Daniel Vetter623369e2014-09-16 17:50:47 +0200988 encoder = connector->state->best_encoder;
989 funcs = encoder->helper_private;
990
Daniel Vetter17a38d92015-02-22 12:24:16 +0100991 DRM_DEBUG_ATOMIC("enabling [ENCODER:%d:%s]\n",
992 encoder->base.id, encoder->name);
Daniel Vetter95d6eb32015-01-22 16:36:25 +0100993
Daniel Vetter623369e2014-09-16 17:50:47 +0200994 /*
995 * Each encoder has at most one connector (since we always steal
John Hunterf98bd3e2015-03-17 15:30:26 +0800996 * it away), so we won't call enable hooks twice.
Daniel Vetter623369e2014-09-16 17:50:47 +0200997 */
Archit Taneja862e6862015-05-21 11:03:16 +0530998 drm_bridge_pre_enable(encoder->bridge);
Daniel Vetter623369e2014-09-16 17:50:47 +0200999
Noralf Trønnes28276352016-05-11 18:09:20 +02001000 if (funcs) {
1001 if (funcs->enable)
1002 funcs->enable(encoder);
1003 else if (funcs->commit)
1004 funcs->commit(encoder);
1005 }
Daniel Vetter623369e2014-09-16 17:50:47 +02001006
Archit Taneja862e6862015-05-21 11:03:16 +05301007 drm_bridge_enable(encoder->bridge);
Daniel Vetter623369e2014-09-16 17:50:47 +02001008 }
1009}
Daniel Vetter1af434a2015-02-22 12:24:19 +01001010EXPORT_SYMBOL(drm_atomic_helper_commit_modeset_enables);
Daniel Vetter623369e2014-09-16 17:50:47 +02001011
Rob Clark4c5b7f32016-03-18 19:14:55 -04001012/**
1013 * drm_atomic_helper_wait_for_fences - wait for fences stashed in plane state
1014 * @dev: DRM device
1015 * @state: atomic state object with old state structures
Daniel Vetter1ea0c022016-11-21 18:18:02 +01001016 * @pre_swap: If true, do an interruptible wait, and @state is the new state.
1017 * Otherwise @state is the old state.
Rob Clark4c5b7f32016-03-18 19:14:55 -04001018 *
1019 * For implicit sync, driver should fish the exclusive fence out from the
1020 * incoming fb's and stash it in the drm_plane_state. This is called after
1021 * drm_atomic_helper_swap_state() so it uses the current plane state (and
1022 * just uses the atomic state to find the changed planes)
Gustavo Padovanf6ce4102016-09-12 16:08:11 -03001023 *
Daniel Vetter1ea0c022016-11-21 18:18:02 +01001024 * Note that @pre_swap is needed since the point where we block for fences moves
1025 * around depending upon whether an atomic commit is blocking or
1026 * non-blocking. For async commit all waiting needs to happen after
1027 * drm_atomic_helper_swap_state() is called, but for synchronous commits we want
1028 * to wait **before** we do anything that can't be easily rolled back. That is
1029 * before we call drm_atomic_helper_swap_state().
1030 *
Chris Wilsonf54d1862016-10-25 13:00:45 +01001031 * Returns zero if success or < 0 if dma_fence_wait() fails.
Rob Clark4c5b7f32016-03-18 19:14:55 -04001032 */
Gustavo Padovanf6ce4102016-09-12 16:08:11 -03001033int drm_atomic_helper_wait_for_fences(struct drm_device *dev,
1034 struct drm_atomic_state *state,
1035 bool pre_swap)
Daniel Vettere2330f02014-10-29 11:34:56 +01001036{
Ander Conselvan de Oliveiradf63b992015-04-10 14:58:39 +03001037 struct drm_plane *plane;
1038 struct drm_plane_state *plane_state;
Gustavo Padovanf6ce4102016-09-12 16:08:11 -03001039 int i, ret;
Daniel Vettere2330f02014-10-29 11:34:56 +01001040
Ander Conselvan de Oliveiradf63b992015-04-10 14:58:39 +03001041 for_each_plane_in_state(state, plane, plane_state, i) {
Gustavo Padovanf6ce4102016-09-12 16:08:11 -03001042 if (!pre_swap)
1043 plane_state = plane->state;
1044
1045 if (!plane_state->fence)
Daniel Vettere2330f02014-10-29 11:34:56 +01001046 continue;
1047
Gustavo Padovanf6ce4102016-09-12 16:08:11 -03001048 WARN_ON(!plane_state->fb);
Daniel Vettere2330f02014-10-29 11:34:56 +01001049
Gustavo Padovanf6ce4102016-09-12 16:08:11 -03001050 /*
1051 * If waiting for fences pre-swap (ie: nonblock), userspace can
1052 * still interrupt the operation. Instead of blocking until the
1053 * timer expires, make the wait interruptible.
1054 */
Chris Wilsonf54d1862016-10-25 13:00:45 +01001055 ret = dma_fence_wait(plane_state->fence, pre_swap);
Gustavo Padovanf6ce4102016-09-12 16:08:11 -03001056 if (ret)
1057 return ret;
1058
Chris Wilsonf54d1862016-10-25 13:00:45 +01001059 dma_fence_put(plane_state->fence);
Gustavo Padovanf6ce4102016-09-12 16:08:11 -03001060 plane_state->fence = NULL;
Daniel Vettere2330f02014-10-29 11:34:56 +01001061 }
Gustavo Padovanf6ce4102016-09-12 16:08:11 -03001062
1063 return 0;
Daniel Vettere2330f02014-10-29 11:34:56 +01001064}
Rob Clark4c5b7f32016-03-18 19:14:55 -04001065EXPORT_SYMBOL(drm_atomic_helper_wait_for_fences);
Daniel Vettere2330f02014-10-29 11:34:56 +01001066
John Keepingc2409062016-01-19 10:46:58 +00001067/**
Rob Clark5ee32292014-11-11 19:38:59 -05001068 * drm_atomic_helper_wait_for_vblanks - wait for vblank on crtcs
1069 * @dev: DRM device
1070 * @old_state: atomic state object with old state structures
1071 *
1072 * Helper to, after atomic commit, wait for vblanks on all effected
1073 * crtcs (ie. before cleaning up old framebuffers using
Daniel Vetterab58e332014-11-24 20:42:42 +01001074 * drm_atomic_helper_cleanup_planes()). It will only wait on crtcs where the
1075 * framebuffers have actually changed to optimize for the legacy cursor and
1076 * plane update use-case.
Rob Clark5ee32292014-11-11 19:38:59 -05001077 */
1078void
1079drm_atomic_helper_wait_for_vblanks(struct drm_device *dev,
1080 struct drm_atomic_state *old_state)
Daniel Vetter623369e2014-09-16 17:50:47 +02001081{
1082 struct drm_crtc *crtc;
1083 struct drm_crtc_state *old_crtc_state;
Daniel Vetter623369e2014-09-16 17:50:47 +02001084 int i, ret;
Maarten Lankhorstbdc57142016-12-15 12:51:42 +01001085 unsigned crtc_mask = 0;
1086
1087 /*
1088 * Legacy cursor ioctls are completely unsynced, and userspace
1089 * relies on that (by doing tons of cursor updates).
1090 */
1091 if (old_state->legacy_cursor_update)
1092 return;
Daniel Vetter623369e2014-09-16 17:50:47 +02001093
Ander Conselvan de Oliveiradf63b992015-04-10 14:58:39 +03001094 for_each_crtc_in_state(old_state, crtc, old_crtc_state, i) {
Maarten Lankhorstbdc57142016-12-15 12:51:42 +01001095 struct drm_crtc_state *new_crtc_state = crtc->state;
Daniel Vetter623369e2014-09-16 17:50:47 +02001096
Maarten Lankhorsta3fbb532016-12-08 14:45:27 +01001097 if (!new_crtc_state->active || !new_crtc_state->planes_changed)
Daniel Vetterab58e332014-11-24 20:42:42 +01001098 continue;
1099
Daniel Vetter623369e2014-09-16 17:50:47 +02001100 ret = drm_crtc_vblank_get(crtc);
1101 if (ret != 0)
1102 continue;
1103
Maarten Lankhorstbdc57142016-12-15 12:51:42 +01001104 crtc_mask |= drm_crtc_mask(crtc);
1105 old_state->crtcs[i].last_vblank_count = drm_crtc_vblank_count(crtc);
Daniel Vetter623369e2014-09-16 17:50:47 +02001106 }
1107
Ander Conselvan de Oliveiradf63b992015-04-10 14:58:39 +03001108 for_each_crtc_in_state(old_state, crtc, old_crtc_state, i) {
Maarten Lankhorstbdc57142016-12-15 12:51:42 +01001109 if (!(crtc_mask & drm_crtc_mask(crtc)))
Daniel Vetter623369e2014-09-16 17:50:47 +02001110 continue;
1111
1112 ret = wait_event_timeout(dev->vblank[i].queue,
Maarten Lankhorstbdc57142016-12-15 12:51:42 +01001113 old_state->crtcs[i].last_vblank_count !=
Thierry Redingd4853632015-08-12 17:00:35 +02001114 drm_crtc_vblank_count(crtc),
Daniel Vetter623369e2014-09-16 17:50:47 +02001115 msecs_to_jiffies(50));
1116
Ville Syrjälä8d4d0d72016-04-18 14:29:33 +03001117 WARN(!ret, "[CRTC:%d] vblank wait timed out\n", crtc->base.id);
1118
Daniel Vetter623369e2014-09-16 17:50:47 +02001119 drm_crtc_vblank_put(crtc);
1120 }
1121}
Rob Clark5ee32292014-11-11 19:38:59 -05001122EXPORT_SYMBOL(drm_atomic_helper_wait_for_vblanks);
Daniel Vetter623369e2014-09-16 17:50:47 +02001123
1124/**
Daniel Vetter9f2a7952016-06-08 14:19:02 +02001125 * drm_atomic_helper_commit_tail - commit atomic update to hardware
Daniel Vetter1ea0c022016-11-21 18:18:02 +01001126 * @old_state: atomic state object with old state structures
Daniel Vetter623369e2014-09-16 17:50:47 +02001127 *
Daniel Vetter9f2a7952016-06-08 14:19:02 +02001128 * This is the default implemenation for the ->atomic_commit_tail() hook of the
1129 * &drm_mode_config_helper_funcs vtable.
Daniel Vetter623369e2014-09-16 17:50:47 +02001130 *
Daniel Vetter9f2a7952016-06-08 14:19:02 +02001131 * Note that the default ordering of how the various stages are called is to
1132 * match the legacy modeset helper library closest. One peculiarity of that is
1133 * that it doesn't mesh well with runtime PM at all.
Daniel Vetter6e48ae32015-09-08 13:52:45 +02001134 *
Daniel Vetter9f2a7952016-06-08 14:19:02 +02001135 * For drivers supporting runtime PM the recommended sequence is instead ::
Daniel Vetter6e48ae32015-09-08 13:52:45 +02001136 *
Daniel Vetter1ea0c022016-11-21 18:18:02 +01001137 * drm_atomic_helper_commit_modeset_disables(dev, old_state);
Daniel Vetter6e48ae32015-09-08 13:52:45 +02001138 *
Daniel Vetter1ea0c022016-11-21 18:18:02 +01001139 * drm_atomic_helper_commit_modeset_enables(dev, old_state);
Daniel Vetter6e48ae32015-09-08 13:52:45 +02001140 *
Daniel Vetter1ea0c022016-11-21 18:18:02 +01001141 * drm_atomic_helper_commit_planes(dev, old_state,
Liu Ying2b58e982016-08-29 17:12:03 +08001142 * DRM_PLANE_COMMIT_ACTIVE_ONLY);
Daniel Vetter6e48ae32015-09-08 13:52:45 +02001143 *
Daniel Vetter9f2a7952016-06-08 14:19:02 +02001144 * for committing the atomic update to hardware. See the kerneldoc entries for
1145 * these three functions for more details.
1146 */
Daniel Vetter1ea0c022016-11-21 18:18:02 +01001147void drm_atomic_helper_commit_tail(struct drm_atomic_state *old_state)
Daniel Vetter9f2a7952016-06-08 14:19:02 +02001148{
Daniel Vetter1ea0c022016-11-21 18:18:02 +01001149 struct drm_device *dev = old_state->dev;
Daniel Vetter9f2a7952016-06-08 14:19:02 +02001150
Daniel Vetter1ea0c022016-11-21 18:18:02 +01001151 drm_atomic_helper_commit_modeset_disables(dev, old_state);
Daniel Vetter9f2a7952016-06-08 14:19:02 +02001152
Daniel Vetter1ea0c022016-11-21 18:18:02 +01001153 drm_atomic_helper_commit_planes(dev, old_state, 0);
Daniel Vetter9f2a7952016-06-08 14:19:02 +02001154
Daniel Vetter1ea0c022016-11-21 18:18:02 +01001155 drm_atomic_helper_commit_modeset_enables(dev, old_state);
Daniel Vetter9f2a7952016-06-08 14:19:02 +02001156
Daniel Vetter1ea0c022016-11-21 18:18:02 +01001157 drm_atomic_helper_commit_hw_done(old_state);
Daniel Vetter9f2a7952016-06-08 14:19:02 +02001158
Daniel Vetter1ea0c022016-11-21 18:18:02 +01001159 drm_atomic_helper_wait_for_vblanks(dev, old_state);
Daniel Vetter9f2a7952016-06-08 14:19:02 +02001160
Daniel Vetter1ea0c022016-11-21 18:18:02 +01001161 drm_atomic_helper_cleanup_planes(dev, old_state);
Daniel Vetter9f2a7952016-06-08 14:19:02 +02001162}
1163EXPORT_SYMBOL(drm_atomic_helper_commit_tail);
1164
Daniel Vetter1ea0c022016-11-21 18:18:02 +01001165static void commit_tail(struct drm_atomic_state *old_state)
Daniel Vetter9f2a7952016-06-08 14:19:02 +02001166{
Daniel Vetter1ea0c022016-11-21 18:18:02 +01001167 struct drm_device *dev = old_state->dev;
Daniel Vetter9f2a7952016-06-08 14:19:02 +02001168 struct drm_mode_config_helper_funcs *funcs;
1169
1170 funcs = dev->mode_config.helper_private;
1171
Daniel Vetter1ea0c022016-11-21 18:18:02 +01001172 drm_atomic_helper_wait_for_fences(dev, old_state, false);
Daniel Vetter9f2a7952016-06-08 14:19:02 +02001173
Daniel Vetter1ea0c022016-11-21 18:18:02 +01001174 drm_atomic_helper_wait_for_dependencies(old_state);
Daniel Vetter9f2a7952016-06-08 14:19:02 +02001175
1176 if (funcs && funcs->atomic_commit_tail)
Daniel Vetter1ea0c022016-11-21 18:18:02 +01001177 funcs->atomic_commit_tail(old_state);
Daniel Vetter9f2a7952016-06-08 14:19:02 +02001178 else
Daniel Vetter1ea0c022016-11-21 18:18:02 +01001179 drm_atomic_helper_commit_tail(old_state);
Daniel Vetter9f2a7952016-06-08 14:19:02 +02001180
Daniel Vetter1ea0c022016-11-21 18:18:02 +01001181 drm_atomic_helper_commit_cleanup_done(old_state);
Daniel Vetter9f2a7952016-06-08 14:19:02 +02001182
Daniel Vetter1ea0c022016-11-21 18:18:02 +01001183 drm_atomic_state_put(old_state);
Daniel Vetter9f2a7952016-06-08 14:19:02 +02001184}
1185
1186static void commit_work(struct work_struct *work)
1187{
1188 struct drm_atomic_state *state = container_of(work,
1189 struct drm_atomic_state,
1190 commit_work);
1191 commit_tail(state);
1192}
1193
1194/**
1195 * drm_atomic_helper_commit - commit validated state object
1196 * @dev: DRM device
1197 * @state: the driver state object
1198 * @nonblock: whether nonblocking behavior is requested.
1199 *
1200 * This function commits a with drm_atomic_helper_check() pre-validated state
1201 * object. This can still fail when e.g. the framebuffer reservation fails. This
1202 * function implements nonblocking commits, using
1203 * drm_atomic_helper_setup_commit() and related functions.
1204 *
Daniel Vetter9f2a7952016-06-08 14:19:02 +02001205 * Committing the actual hardware state is done through the
1206 * ->atomic_commit_tail() callback of the &drm_mode_config_helper_funcs vtable,
1207 * or it's default implementation drm_atomic_helper_commit_tail().
Daniel Vetter6e48ae32015-09-08 13:52:45 +02001208 *
Daniel Vetterc39032a2016-06-08 14:19:19 +02001209 * RETURNS:
Daniel Vetter623369e2014-09-16 17:50:47 +02001210 * Zero for success or -errno.
1211 */
1212int drm_atomic_helper_commit(struct drm_device *dev,
1213 struct drm_atomic_state *state,
Maarten Lankhorst286dbb82016-04-26 16:11:34 +02001214 bool nonblock)
Daniel Vetter623369e2014-09-16 17:50:47 +02001215{
1216 int ret;
1217
Daniel Vettera095caa2016-06-08 17:15:36 +02001218 ret = drm_atomic_helper_setup_commit(state, nonblock);
1219 if (ret)
1220 return ret;
1221
Daniel Vetter9f2a7952016-06-08 14:19:02 +02001222 INIT_WORK(&state->commit_work, commit_work);
1223
Daniel Vetter623369e2014-09-16 17:50:47 +02001224 ret = drm_atomic_helper_prepare_planes(dev, state);
1225 if (ret)
1226 return ret;
1227
Gustavo Padovanf6ce4102016-09-12 16:08:11 -03001228 if (!nonblock) {
1229 ret = drm_atomic_helper_wait_for_fences(dev, state, true);
1230 if (ret)
1231 return ret;
1232 }
1233
Daniel Vetter623369e2014-09-16 17:50:47 +02001234 /*
1235 * This is the point of no return - everything below never fails except
1236 * when the hw goes bonghits. Which means we can commit the new state on
1237 * the software side now.
1238 */
1239
Daniel Vetter5e84c262016-06-10 00:06:32 +02001240 drm_atomic_helper_swap_state(state, true);
Daniel Vetter623369e2014-09-16 17:50:47 +02001241
1242 /*
1243 * Everything below can be run asynchronously without the need to grab
John Hunterf98bd3e2015-03-17 15:30:26 +08001244 * any modeset locks at all under one condition: It must be guaranteed
Daniel Vetter623369e2014-09-16 17:50:47 +02001245 * that the asynchronous work has either been cancelled (if the driver
1246 * supports it, which at least requires that the framebuffers get
1247 * cleaned up with drm_atomic_helper_cleanup_planes()) or completed
1248 * before the new state gets committed on the software side with
1249 * drm_atomic_helper_swap_state().
1250 *
1251 * This scheme allows new atomic state updates to be prepared and
1252 * checked in parallel to the asynchronous completion of the previous
1253 * update. Which is important since compositors need to figure out the
1254 * composition of the next frame right after having submitted the
1255 * current layout.
Daniel Vetter9f2a7952016-06-08 14:19:02 +02001256 *
1257 * NOTE: Commit work has multiple phases, first hardware commit, then
1258 * cleanup. We want them to overlap, hence need system_unbound_wq to
1259 * make sure work items don't artifically stall on each another.
Daniel Vetter623369e2014-09-16 17:50:47 +02001260 */
1261
Chris Wilson08536952016-10-14 13:18:18 +01001262 drm_atomic_state_get(state);
Daniel Vetter9f2a7952016-06-08 14:19:02 +02001263 if (nonblock)
1264 queue_work(system_unbound_wq, &state->commit_work);
1265 else
1266 commit_tail(state);
Daniel Vetter623369e2014-09-16 17:50:47 +02001267
1268 return 0;
1269}
1270EXPORT_SYMBOL(drm_atomic_helper_commit);
1271
Daniel Vetterc2fcd272014-11-05 00:14:14 +01001272/**
Maarten Lankhorst286dbb82016-04-26 16:11:34 +02001273 * DOC: implementing nonblocking commit
Daniel Vettere8c833a2014-07-27 18:30:19 +02001274 *
Daniel Vetter9f2a7952016-06-08 14:19:02 +02001275 * Nonblocking atomic commits have to be implemented in the following sequence:
Daniel Vettere8c833a2014-07-27 18:30:19 +02001276 *
1277 * 1. Run drm_atomic_helper_prepare_planes() first. This is the only function
1278 * which commit needs to call which can fail, so we want to run it first and
1279 * synchronously.
1280 *
Maarten Lankhorst286dbb82016-04-26 16:11:34 +02001281 * 2. Synchronize with any outstanding nonblocking commit worker threads which
Daniel Vettere8c833a2014-07-27 18:30:19 +02001282 * might be affected the new state update. This can be done by either cancelling
1283 * or flushing the work items, depending upon whether the driver can deal with
1284 * cancelled updates. Note that it is important to ensure that the framebuffer
1285 * cleanup is still done when cancelling.
1286 *
Daniel Vetter9f2a7952016-06-08 14:19:02 +02001287 * Asynchronous workers need to have sufficient parallelism to be able to run
1288 * different atomic commits on different CRTCs in parallel. The simplest way to
1289 * achive this is by running them on the &system_unbound_wq work queue. Note
1290 * that drivers are not required to split up atomic commits and run an
1291 * individual commit in parallel - userspace is supposed to do that if it cares.
1292 * But it might be beneficial to do that for modesets, since those necessarily
1293 * must be done as one global operation, and enabling or disabling a CRTC can
1294 * take a long time. But even that is not required.
Daniel Vettere8c833a2014-07-27 18:30:19 +02001295 *
1296 * 3. The software state is updated synchronously with
Daniel Vetter26196f72015-08-25 16:26:03 +02001297 * drm_atomic_helper_swap_state(). Doing this under the protection of all modeset
Daniel Vettere8c833a2014-07-27 18:30:19 +02001298 * locks means concurrent callers never see inconsistent state. And doing this
Maarten Lankhorst286dbb82016-04-26 16:11:34 +02001299 * while it's guaranteed that no relevant nonblocking worker runs means that
1300 * nonblocking workers do not need grab any locks. Actually they must not grab
1301 * locks, for otherwise the work flushing will deadlock.
Daniel Vettere8c833a2014-07-27 18:30:19 +02001302 *
1303 * 4. Schedule a work item to do all subsequent steps, using the split-out
1304 * commit helpers: a) pre-plane commit b) plane commit c) post-plane commit and
1305 * then cleaning up the framebuffers after the old framebuffer is no longer
1306 * being displayed.
Daniel Vetter9f2a7952016-06-08 14:19:02 +02001307 *
1308 * The above scheme is implemented in the atomic helper libraries in
1309 * drm_atomic_helper_commit() using a bunch of helper functions. See
1310 * drm_atomic_helper_setup_commit() for a starting point.
Daniel Vettere8c833a2014-07-27 18:30:19 +02001311 */
1312
Daniel Vettera095caa2016-06-08 17:15:36 +02001313static int stall_checks(struct drm_crtc *crtc, bool nonblock)
1314{
1315 struct drm_crtc_commit *commit, *stall_commit = NULL;
1316 bool completed = true;
1317 int i;
1318 long ret = 0;
1319
1320 spin_lock(&crtc->commit_lock);
1321 i = 0;
1322 list_for_each_entry(commit, &crtc->commit_list, commit_entry) {
1323 if (i == 0) {
1324 completed = try_wait_for_completion(&commit->flip_done);
1325 /* Userspace is not allowed to get ahead of the previous
1326 * commit with nonblocking ones. */
1327 if (!completed && nonblock) {
1328 spin_unlock(&crtc->commit_lock);
1329 return -EBUSY;
1330 }
1331 } else if (i == 1) {
1332 stall_commit = commit;
1333 drm_crtc_commit_get(stall_commit);
Daniel Vettera095caa2016-06-08 17:15:36 +02001334 break;
Daniel Vetter723c3e52016-06-14 19:50:58 +02001335 }
Daniel Vettera095caa2016-06-08 17:15:36 +02001336
1337 i++;
1338 }
1339 spin_unlock(&crtc->commit_lock);
1340
1341 if (!stall_commit)
1342 return 0;
1343
1344 /* We don't want to let commits get ahead of cleanup work too much,
1345 * stalling on 2nd previous commit means triple-buffer won't ever stall.
1346 */
Daniel Vetter723c3e52016-06-14 19:50:58 +02001347 ret = wait_for_completion_interruptible_timeout(&stall_commit->cleanup_done,
Daniel Vettera095caa2016-06-08 17:15:36 +02001348 10*HZ);
1349 if (ret == 0)
1350 DRM_ERROR("[CRTC:%d:%s] cleanup_done timed out\n",
1351 crtc->base.id, crtc->name);
1352
1353 drm_crtc_commit_put(stall_commit);
1354
1355 return ret < 0 ? ret : 0;
1356}
1357
Daniel Vetter24835e42016-12-21 11:23:30 +01001358void release_crtc_commit(struct completion *completion)
1359{
1360 struct drm_crtc_commit *commit = container_of(completion,
1361 typeof(*commit),
1362 flip_done);
1363
1364 drm_crtc_commit_put(commit);
1365}
1366
Daniel Vettera095caa2016-06-08 17:15:36 +02001367/**
1368 * drm_atomic_helper_setup_commit - setup possibly nonblocking commit
1369 * @state: new modeset state to be committed
1370 * @nonblock: whether nonblocking behavior is requested.
1371 *
1372 * This function prepares @state to be used by the atomic helper's support for
1373 * nonblocking commits. Drivers using the nonblocking commit infrastructure
1374 * should always call this function from their ->atomic_commit hook.
1375 *
1376 * To be able to use this support drivers need to use a few more helper
1377 * functions. drm_atomic_helper_wait_for_dependencies() must be called before
1378 * actually committing the hardware state, and for nonblocking commits this call
1379 * must be placed in the async worker. See also drm_atomic_helper_swap_state()
1380 * and it's stall parameter, for when a driver's commit hooks look at the
Daniel Vetterea0dd852016-12-29 21:48:26 +01001381 * ->state pointers of &struct drm_crtc, &drm_plane or &drm_connector directly.
Daniel Vettera095caa2016-06-08 17:15:36 +02001382 *
1383 * Completion of the hardware commit step must be signalled using
1384 * drm_atomic_helper_commit_hw_done(). After this step the driver is not allowed
1385 * to read or change any permanent software or hardware modeset state. The only
1386 * exception is state protected by other means than &drm_modeset_lock locks.
1387 * Only the free standing @state with pointers to the old state structures can
1388 * be inspected, e.g. to clean up old buffers using
1389 * drm_atomic_helper_cleanup_planes().
1390 *
1391 * At the very end, before cleaning up @state drivers must call
1392 * drm_atomic_helper_commit_cleanup_done().
1393 *
1394 * This is all implemented by in drm_atomic_helper_commit(), giving drivers a
1395 * complete and esay-to-use default implementation of the atomic_commit() hook.
1396 *
1397 * The tracking of asynchronously executed and still pending commits is done
1398 * using the core structure &drm_crtc_commit.
1399 *
1400 * By default there's no need to clean up resources allocated by this function
1401 * explicitly: drm_atomic_state_default_clear() will take care of that
1402 * automatically.
1403 *
1404 * Returns:
1405 *
1406 * 0 on success. -EBUSY when userspace schedules nonblocking commits too fast,
1407 * -ENOMEM on allocation failures and -EINTR when a signal is pending.
1408 */
1409int drm_atomic_helper_setup_commit(struct drm_atomic_state *state,
1410 bool nonblock)
1411{
1412 struct drm_crtc *crtc;
1413 struct drm_crtc_state *crtc_state;
1414 struct drm_crtc_commit *commit;
1415 int i, ret;
1416
1417 for_each_crtc_in_state(state, crtc, crtc_state, i) {
1418 commit = kzalloc(sizeof(*commit), GFP_KERNEL);
1419 if (!commit)
1420 return -ENOMEM;
1421
1422 init_completion(&commit->flip_done);
1423 init_completion(&commit->hw_done);
1424 init_completion(&commit->cleanup_done);
1425 INIT_LIST_HEAD(&commit->commit_entry);
1426 kref_init(&commit->ref);
1427 commit->crtc = crtc;
1428
1429 state->crtcs[i].commit = commit;
1430
1431 ret = stall_checks(crtc, nonblock);
1432 if (ret)
1433 return ret;
1434
1435 /* Drivers only send out events when at least either current or
1436 * new CRTC state is active. Complete right away if everything
1437 * stays off. */
1438 if (!crtc->state->active && !crtc_state->active) {
1439 complete_all(&commit->flip_done);
1440 continue;
1441 }
1442
1443 /* Legacy cursor updates are fully unsynced. */
1444 if (state->legacy_cursor_update) {
1445 complete_all(&commit->flip_done);
1446 continue;
1447 }
1448
1449 if (!crtc_state->event) {
1450 commit->event = kzalloc(sizeof(*commit->event),
1451 GFP_KERNEL);
1452 if (!commit->event)
1453 return -ENOMEM;
1454
1455 crtc_state->event = commit->event;
1456 }
1457
1458 crtc_state->event->base.completion = &commit->flip_done;
Daniel Vetter24835e42016-12-21 11:23:30 +01001459 crtc_state->event->base.completion_release = release_crtc_commit;
1460 drm_crtc_commit_get(commit);
Daniel Vettera095caa2016-06-08 17:15:36 +02001461 }
1462
1463 return 0;
1464}
1465EXPORT_SYMBOL(drm_atomic_helper_setup_commit);
1466
1467
1468static struct drm_crtc_commit *preceeding_commit(struct drm_crtc *crtc)
1469{
1470 struct drm_crtc_commit *commit;
1471 int i = 0;
1472
1473 list_for_each_entry(commit, &crtc->commit_list, commit_entry) {
1474 /* skip the first entry, that's the current commit */
1475 if (i == 1)
1476 return commit;
1477 i++;
1478 }
1479
1480 return NULL;
1481}
1482
1483/**
1484 * drm_atomic_helper_wait_for_dependencies - wait for required preceeding commits
Daniel Vetter1ea0c022016-11-21 18:18:02 +01001485 * @old_state: atomic state object with old state structures
Daniel Vettera095caa2016-06-08 17:15:36 +02001486 *
1487 * This function waits for all preceeding commits that touch the same CRTC as
Daniel Vetter1ea0c022016-11-21 18:18:02 +01001488 * @old_state to both be committed to the hardware (as signalled by
Daniel Vettera095caa2016-06-08 17:15:36 +02001489 * drm_atomic_helper_commit_hw_done) and executed by the hardware (as signalled
1490 * by calling drm_crtc_vblank_send_event on the event member of
1491 * &drm_crtc_state).
1492 *
1493 * This is part of the atomic helper support for nonblocking commits, see
1494 * drm_atomic_helper_setup_commit() for an overview.
1495 */
Daniel Vetter1ea0c022016-11-21 18:18:02 +01001496void drm_atomic_helper_wait_for_dependencies(struct drm_atomic_state *old_state)
Daniel Vettera095caa2016-06-08 17:15:36 +02001497{
1498 struct drm_crtc *crtc;
1499 struct drm_crtc_state *crtc_state;
1500 struct drm_crtc_commit *commit;
1501 int i;
1502 long ret;
1503
Daniel Vetter1ea0c022016-11-21 18:18:02 +01001504 for_each_crtc_in_state(old_state, crtc, crtc_state, i) {
Daniel Vettera095caa2016-06-08 17:15:36 +02001505 spin_lock(&crtc->commit_lock);
1506 commit = preceeding_commit(crtc);
1507 if (commit)
1508 drm_crtc_commit_get(commit);
1509 spin_unlock(&crtc->commit_lock);
1510
1511 if (!commit)
1512 continue;
1513
1514 ret = wait_for_completion_timeout(&commit->hw_done,
1515 10*HZ);
1516 if (ret == 0)
1517 DRM_ERROR("[CRTC:%d:%s] hw_done timed out\n",
1518 crtc->base.id, crtc->name);
1519
1520 /* Currently no support for overwriting flips, hence
1521 * stall for previous one to execute completely. */
1522 ret = wait_for_completion_timeout(&commit->flip_done,
1523 10*HZ);
1524 if (ret == 0)
1525 DRM_ERROR("[CRTC:%d:%s] flip_done timed out\n",
1526 crtc->base.id, crtc->name);
1527
1528 drm_crtc_commit_put(commit);
1529 }
1530}
1531EXPORT_SYMBOL(drm_atomic_helper_wait_for_dependencies);
1532
1533/**
1534 * drm_atomic_helper_commit_hw_done - setup possible nonblocking commit
Daniel Vetter1ea0c022016-11-21 18:18:02 +01001535 * @old_state: atomic state object with old state structures
Daniel Vettera095caa2016-06-08 17:15:36 +02001536 *
1537 * This function is used to signal completion of the hardware commit step. After
1538 * this step the driver is not allowed to read or change any permanent software
1539 * or hardware modeset state. The only exception is state protected by other
1540 * means than &drm_modeset_lock locks.
1541 *
1542 * Drivers should try to postpone any expensive or delayed cleanup work after
1543 * this function is called.
1544 *
1545 * This is part of the atomic helper support for nonblocking commits, see
1546 * drm_atomic_helper_setup_commit() for an overview.
1547 */
Daniel Vetter1ea0c022016-11-21 18:18:02 +01001548void drm_atomic_helper_commit_hw_done(struct drm_atomic_state *old_state)
Daniel Vettera095caa2016-06-08 17:15:36 +02001549{
1550 struct drm_crtc *crtc;
1551 struct drm_crtc_state *crtc_state;
1552 struct drm_crtc_commit *commit;
1553 int i;
1554
Daniel Vetter1ea0c022016-11-21 18:18:02 +01001555 for_each_crtc_in_state(old_state, crtc, crtc_state, i) {
1556 commit = old_state->crtcs[i].commit;
Daniel Vettera095caa2016-06-08 17:15:36 +02001557 if (!commit)
1558 continue;
1559
1560 /* backend must have consumed any event by now */
1561 WARN_ON(crtc->state->event);
1562 spin_lock(&crtc->commit_lock);
1563 complete_all(&commit->hw_done);
1564 spin_unlock(&crtc->commit_lock);
1565 }
1566}
1567EXPORT_SYMBOL(drm_atomic_helper_commit_hw_done);
1568
1569/**
1570 * drm_atomic_helper_commit_cleanup_done - signal completion of commit
Daniel Vetter1ea0c022016-11-21 18:18:02 +01001571 * @old_state: atomic state object with old state structures
Daniel Vettera095caa2016-06-08 17:15:36 +02001572 *
Daniel Vetter1ea0c022016-11-21 18:18:02 +01001573 * This signals completion of the atomic update @old_state, including any
1574 * cleanup work. If used, it must be called right before calling
Chris Wilson08536952016-10-14 13:18:18 +01001575 * drm_atomic_state_put().
Daniel Vettera095caa2016-06-08 17:15:36 +02001576 *
1577 * This is part of the atomic helper support for nonblocking commits, see
1578 * drm_atomic_helper_setup_commit() for an overview.
1579 */
Daniel Vetter1ea0c022016-11-21 18:18:02 +01001580void drm_atomic_helper_commit_cleanup_done(struct drm_atomic_state *old_state)
Daniel Vettera095caa2016-06-08 17:15:36 +02001581{
1582 struct drm_crtc *crtc;
1583 struct drm_crtc_state *crtc_state;
1584 struct drm_crtc_commit *commit;
1585 int i;
1586 long ret;
1587
Daniel Vetter1ea0c022016-11-21 18:18:02 +01001588 for_each_crtc_in_state(old_state, crtc, crtc_state, i) {
1589 commit = old_state->crtcs[i].commit;
Daniel Vettera095caa2016-06-08 17:15:36 +02001590 if (WARN_ON(!commit))
1591 continue;
1592
1593 spin_lock(&crtc->commit_lock);
1594 complete_all(&commit->cleanup_done);
1595 WARN_ON(!try_wait_for_completion(&commit->hw_done));
1596
1597 /* commit_list borrows our reference, need to remove before we
1598 * clean up our drm_atomic_state. But only after it actually
1599 * completed, otherwise subsequent commits won't stall properly. */
Daniel Vetter7deef7f12016-06-15 12:24:26 +02001600 if (try_wait_for_completion(&commit->flip_done))
1601 goto del_commit;
Daniel Vettera095caa2016-06-08 17:15:36 +02001602
1603 spin_unlock(&crtc->commit_lock);
1604
1605 /* We must wait for the vblank event to signal our completion
1606 * before releasing our reference, since the vblank work does
1607 * not hold a reference of its own. */
1608 ret = wait_for_completion_timeout(&commit->flip_done,
1609 10*HZ);
1610 if (ret == 0)
1611 DRM_ERROR("[CRTC:%d:%s] flip_done timed out\n",
1612 crtc->base.id, crtc->name);
1613
1614 spin_lock(&crtc->commit_lock);
Daniel Vetter7deef7f12016-06-15 12:24:26 +02001615del_commit:
Daniel Vettera095caa2016-06-08 17:15:36 +02001616 list_del(&commit->commit_entry);
1617 spin_unlock(&crtc->commit_lock);
1618 }
1619}
1620EXPORT_SYMBOL(drm_atomic_helper_commit_cleanup_done);
1621
Daniel Vettere8c833a2014-07-27 18:30:19 +02001622/**
Daniel Vetter2e3afd42015-02-26 14:17:38 +01001623 * drm_atomic_helper_prepare_planes - prepare plane resources before commit
Daniel Vetterc2fcd272014-11-05 00:14:14 +01001624 * @dev: DRM device
Daniel Vetter2e3afd42015-02-26 14:17:38 +01001625 * @state: atomic state object with new state structures
Daniel Vetterc2fcd272014-11-05 00:14:14 +01001626 *
1627 * This function prepares plane state, specifically framebuffers, for the new
1628 * configuration. If any failure is encountered this function will call
1629 * ->cleanup_fb on any already successfully prepared framebuffer.
1630 *
1631 * Returns:
1632 * 0 on success, negative error code on failure.
1633 */
1634int drm_atomic_helper_prepare_planes(struct drm_device *dev,
1635 struct drm_atomic_state *state)
1636{
Daniel Vetterbe9174a2016-06-02 00:06:24 +02001637 struct drm_plane *plane;
1638 struct drm_plane_state *plane_state;
1639 int ret, i, j;
Daniel Vetterc2fcd272014-11-05 00:14:14 +01001640
Daniel Vetterbe9174a2016-06-02 00:06:24 +02001641 for_each_plane_in_state(state, plane, plane_state, i) {
Ville Syrjäläb5ceff202015-03-10 14:35:20 +02001642 const struct drm_plane_helper_funcs *funcs;
Daniel Vetterc2fcd272014-11-05 00:14:14 +01001643
1644 funcs = plane->helper_private;
1645
Maarten Lankhorst844f9112015-09-02 10:42:40 +02001646 if (funcs->prepare_fb) {
1647 ret = funcs->prepare_fb(plane, plane_state);
Daniel Vetterc2fcd272014-11-05 00:14:14 +01001648 if (ret)
1649 goto fail;
1650 }
1651 }
1652
1653 return 0;
1654
1655fail:
Daniel Vetterbe9174a2016-06-02 00:06:24 +02001656 for_each_plane_in_state(state, plane, plane_state, j) {
Ville Syrjäläb5ceff202015-03-10 14:35:20 +02001657 const struct drm_plane_helper_funcs *funcs;
Daniel Vetterc2fcd272014-11-05 00:14:14 +01001658
Daniel Vetterbe9174a2016-06-02 00:06:24 +02001659 if (j >= i)
Daniel Vetterc2fcd272014-11-05 00:14:14 +01001660 continue;
1661
1662 funcs = plane->helper_private;
1663
Maarten Lankhorst844f9112015-09-02 10:42:40 +02001664 if (funcs->cleanup_fb)
1665 funcs->cleanup_fb(plane, plane_state);
Daniel Vetterc2fcd272014-11-05 00:14:14 +01001666 }
1667
1668 return ret;
1669}
1670EXPORT_SYMBOL(drm_atomic_helper_prepare_planes);
1671
Ville Syrjälä7135ac52016-09-19 16:33:42 +03001672static bool plane_crtc_active(const struct drm_plane_state *state)
Daniel Vetteraef9dbb2015-09-08 12:02:07 +02001673{
1674 return state->crtc && state->crtc->state->active;
1675}
1676
Daniel Vetterc2fcd272014-11-05 00:14:14 +01001677/**
1678 * drm_atomic_helper_commit_planes - commit plane state
1679 * @dev: DRM device
Daniel Vetterb0fcfc82014-11-19 18:38:11 +01001680 * @old_state: atomic state object with old state structures
Liu Ying2b58e982016-08-29 17:12:03 +08001681 * @flags: flags for committing plane state
Daniel Vetterc2fcd272014-11-05 00:14:14 +01001682 *
1683 * This function commits the new plane state using the plane and atomic helper
1684 * functions for planes and crtcs. It assumes that the atomic state has already
1685 * been pushed into the relevant object state pointers, since this step can no
1686 * longer fail.
1687 *
Daniel Vetterb0fcfc82014-11-19 18:38:11 +01001688 * It still requires the global state object @old_state to know which planes and
Daniel Vetterc2fcd272014-11-05 00:14:14 +01001689 * crtcs need to be updated though.
Maarten Lankhorstde28d022015-05-19 16:41:01 +02001690 *
1691 * Note that this function does all plane updates across all CRTCs in one step.
1692 * If the hardware can't support this approach look at
1693 * drm_atomic_helper_commit_planes_on_crtc() instead.
Daniel Vetter6e48ae32015-09-08 13:52:45 +02001694 *
1695 * Plane parameters can be updated by applications while the associated CRTC is
1696 * disabled. The DRM/KMS core will store the parameters in the plane state,
1697 * which will be available to the driver when the CRTC is turned on. As a result
1698 * most drivers don't need to be immediately notified of plane updates for a
1699 * disabled CRTC.
1700 *
Liu Ying2b58e982016-08-29 17:12:03 +08001701 * Unless otherwise needed, drivers are advised to set the ACTIVE_ONLY flag in
1702 * @flags in order not to receive plane update notifications related to a
1703 * disabled CRTC. This avoids the need to manually ignore plane updates in
Daniel Vetter6e48ae32015-09-08 13:52:45 +02001704 * driver code when the driver and/or hardware can't or just don't need to deal
1705 * with updates on disabled CRTCs, for example when supporting runtime PM.
1706 *
Liu Ying2b58e982016-08-29 17:12:03 +08001707 * Drivers may set the NO_DISABLE_AFTER_MODESET flag in @flags if the relevant
1708 * display controllers require to disable a CRTC's planes when the CRTC is
1709 * disabled. This function would skip the ->atomic_disable call for a plane if
1710 * the CRTC of the old plane state needs a modesetting operation. Of course,
1711 * the drivers need to disable the planes in their CRTC disable callbacks
1712 * since no one else would do that.
1713 *
1714 * The drm_atomic_helper_commit() default implementation doesn't set the
1715 * ACTIVE_ONLY flag to most closely match the behaviour of the legacy helpers.
1716 * This should not be copied blindly by drivers.
Daniel Vetterc2fcd272014-11-05 00:14:14 +01001717 */
1718void drm_atomic_helper_commit_planes(struct drm_device *dev,
Daniel Vetteraef9dbb2015-09-08 12:02:07 +02001719 struct drm_atomic_state *old_state,
Liu Ying2b58e982016-08-29 17:12:03 +08001720 uint32_t flags)
Daniel Vetterc2fcd272014-11-05 00:14:14 +01001721{
Ander Conselvan de Oliveiradf63b992015-04-10 14:58:39 +03001722 struct drm_crtc *crtc;
1723 struct drm_crtc_state *old_crtc_state;
1724 struct drm_plane *plane;
1725 struct drm_plane_state *old_plane_state;
Daniel Vetterc2fcd272014-11-05 00:14:14 +01001726 int i;
Liu Ying2b58e982016-08-29 17:12:03 +08001727 bool active_only = flags & DRM_PLANE_COMMIT_ACTIVE_ONLY;
1728 bool no_disable = flags & DRM_PLANE_COMMIT_NO_DISABLE_AFTER_MODESET;
Daniel Vetterc2fcd272014-11-05 00:14:14 +01001729
Ander Conselvan de Oliveiradf63b992015-04-10 14:58:39 +03001730 for_each_crtc_in_state(old_state, crtc, old_crtc_state, i) {
Ville Syrjäläb5ceff202015-03-10 14:35:20 +02001731 const struct drm_crtc_helper_funcs *funcs;
Daniel Vetterc2fcd272014-11-05 00:14:14 +01001732
1733 funcs = crtc->helper_private;
1734
1735 if (!funcs || !funcs->atomic_begin)
1736 continue;
1737
Daniel Vetteraef9dbb2015-09-08 12:02:07 +02001738 if (active_only && !crtc->state->active)
1739 continue;
1740
Maarten Lankhorst613d2b22015-07-21 13:28:58 +02001741 funcs->atomic_begin(crtc, old_crtc_state);
Daniel Vetterc2fcd272014-11-05 00:14:14 +01001742 }
1743
Ander Conselvan de Oliveiradf63b992015-04-10 14:58:39 +03001744 for_each_plane_in_state(old_state, plane, old_plane_state, i) {
Ville Syrjäläb5ceff202015-03-10 14:35:20 +02001745 const struct drm_plane_helper_funcs *funcs;
Laurent Pinchart216c59d2015-09-11 00:07:19 +03001746 bool disabling;
Daniel Vetterc2fcd272014-11-05 00:14:14 +01001747
1748 funcs = plane->helper_private;
1749
Thierry Reding3cad4b62014-11-25 13:05:12 +01001750 if (!funcs)
Daniel Vetterc2fcd272014-11-05 00:14:14 +01001751 continue;
1752
Laurent Pinchart216c59d2015-09-11 00:07:19 +03001753 disabling = drm_atomic_plane_disabling(plane, old_plane_state);
1754
1755 if (active_only) {
1756 /*
1757 * Skip planes related to inactive CRTCs. If the plane
1758 * is enabled use the state of the current CRTC. If the
1759 * plane is being disabled use the state of the old
1760 * CRTC to avoid skipping planes being disabled on an
1761 * active CRTC.
1762 */
1763 if (!disabling && !plane_crtc_active(plane->state))
1764 continue;
1765 if (disabling && !plane_crtc_active(old_plane_state))
1766 continue;
1767 }
Daniel Vetteraef9dbb2015-09-08 12:02:07 +02001768
Thierry Reding407b8bd2014-11-20 12:05:50 +01001769 /*
1770 * Special-case disabling the plane if drivers support it.
1771 */
Liu Ying2b58e982016-08-29 17:12:03 +08001772 if (disabling && funcs->atomic_disable) {
1773 struct drm_crtc_state *crtc_state;
1774
1775 crtc_state = old_plane_state->crtc->state;
1776
1777 if (drm_atomic_crtc_needs_modeset(crtc_state) &&
1778 no_disable)
1779 continue;
1780
Thierry Reding407b8bd2014-11-20 12:05:50 +01001781 funcs->atomic_disable(plane, old_plane_state);
Liu Ying2b58e982016-08-29 17:12:03 +08001782 } else if (plane->state->crtc || disabling) {
Thierry Reding407b8bd2014-11-20 12:05:50 +01001783 funcs->atomic_update(plane, old_plane_state);
Liu Ying2b58e982016-08-29 17:12:03 +08001784 }
Daniel Vetterc2fcd272014-11-05 00:14:14 +01001785 }
1786
Ander Conselvan de Oliveiradf63b992015-04-10 14:58:39 +03001787 for_each_crtc_in_state(old_state, crtc, old_crtc_state, i) {
Ville Syrjäläb5ceff202015-03-10 14:35:20 +02001788 const struct drm_crtc_helper_funcs *funcs;
Daniel Vetterc2fcd272014-11-05 00:14:14 +01001789
1790 funcs = crtc->helper_private;
1791
1792 if (!funcs || !funcs->atomic_flush)
1793 continue;
1794
Daniel Vetteraef9dbb2015-09-08 12:02:07 +02001795 if (active_only && !crtc->state->active)
1796 continue;
1797
Maarten Lankhorst613d2b22015-07-21 13:28:58 +02001798 funcs->atomic_flush(crtc, old_crtc_state);
Daniel Vetterc2fcd272014-11-05 00:14:14 +01001799 }
1800}
1801EXPORT_SYMBOL(drm_atomic_helper_commit_planes);
1802
1803/**
Maarten Lankhorstde28d022015-05-19 16:41:01 +02001804 * drm_atomic_helper_commit_planes_on_crtc - commit plane state for a crtc
1805 * @old_crtc_state: atomic state object with the old crtc state
1806 *
1807 * This function commits the new plane state using the plane and atomic helper
1808 * functions for planes on the specific crtc. It assumes that the atomic state
1809 * has already been pushed into the relevant object state pointers, since this
1810 * step can no longer fail.
1811 *
1812 * This function is useful when plane updates should be done crtc-by-crtc
1813 * instead of one global step like drm_atomic_helper_commit_planes() does.
1814 *
1815 * This function can only be savely used when planes are not allowed to move
1816 * between different CRTCs because this function doesn't handle inter-CRTC
1817 * depencies. Callers need to ensure that either no such depencies exist,
1818 * resolve them through ordering of commit calls or through some other means.
1819 */
1820void
1821drm_atomic_helper_commit_planes_on_crtc(struct drm_crtc_state *old_crtc_state)
1822{
1823 const struct drm_crtc_helper_funcs *crtc_funcs;
1824 struct drm_crtc *crtc = old_crtc_state->crtc;
1825 struct drm_atomic_state *old_state = old_crtc_state->state;
1826 struct drm_plane *plane;
1827 unsigned plane_mask;
1828
1829 plane_mask = old_crtc_state->plane_mask;
1830 plane_mask |= crtc->state->plane_mask;
1831
1832 crtc_funcs = crtc->helper_private;
1833 if (crtc_funcs && crtc_funcs->atomic_begin)
Maarten Lankhorst613d2b22015-07-21 13:28:58 +02001834 crtc_funcs->atomic_begin(crtc, old_crtc_state);
Maarten Lankhorstde28d022015-05-19 16:41:01 +02001835
1836 drm_for_each_plane_mask(plane, crtc->dev, plane_mask) {
1837 struct drm_plane_state *old_plane_state =
1838 drm_atomic_get_existing_plane_state(old_state, plane);
1839 const struct drm_plane_helper_funcs *plane_funcs;
1840
1841 plane_funcs = plane->helper_private;
1842
1843 if (!old_plane_state || !plane_funcs)
1844 continue;
1845
1846 WARN_ON(plane->state->crtc && plane->state->crtc != crtc);
1847
1848 if (drm_atomic_plane_disabling(plane, old_plane_state) &&
1849 plane_funcs->atomic_disable)
1850 plane_funcs->atomic_disable(plane, old_plane_state);
1851 else if (plane->state->crtc ||
1852 drm_atomic_plane_disabling(plane, old_plane_state))
1853 plane_funcs->atomic_update(plane, old_plane_state);
1854 }
1855
1856 if (crtc_funcs && crtc_funcs->atomic_flush)
Maarten Lankhorst613d2b22015-07-21 13:28:58 +02001857 crtc_funcs->atomic_flush(crtc, old_crtc_state);
Maarten Lankhorstde28d022015-05-19 16:41:01 +02001858}
1859EXPORT_SYMBOL(drm_atomic_helper_commit_planes_on_crtc);
1860
1861/**
Jyri Sarha6753ba92015-11-27 16:14:01 +02001862 * drm_atomic_helper_disable_planes_on_crtc - helper to disable CRTC's planes
Liu Ying28500292016-08-26 15:30:39 +08001863 * @old_crtc_state: atomic state object with the old CRTC state
Jyri Sarha6753ba92015-11-27 16:14:01 +02001864 * @atomic: if set, synchronize with CRTC's atomic_begin/flush hooks
1865 *
1866 * Disables all planes associated with the given CRTC. This can be
Liu Ying28500292016-08-26 15:30:39 +08001867 * used for instance in the CRTC helper atomic_disable callback to disable
1868 * all planes.
Jyri Sarha6753ba92015-11-27 16:14:01 +02001869 *
1870 * If the atomic-parameter is set the function calls the CRTC's
1871 * atomic_begin hook before and atomic_flush hook after disabling the
1872 * planes.
1873 *
1874 * It is a bug to call this function without having implemented the
1875 * ->atomic_disable() plane hook.
1876 */
Liu Ying28500292016-08-26 15:30:39 +08001877void
1878drm_atomic_helper_disable_planes_on_crtc(struct drm_crtc_state *old_crtc_state,
1879 bool atomic)
Jyri Sarha6753ba92015-11-27 16:14:01 +02001880{
Liu Ying28500292016-08-26 15:30:39 +08001881 struct drm_crtc *crtc = old_crtc_state->crtc;
Jyri Sarha6753ba92015-11-27 16:14:01 +02001882 const struct drm_crtc_helper_funcs *crtc_funcs =
1883 crtc->helper_private;
1884 struct drm_plane *plane;
1885
1886 if (atomic && crtc_funcs && crtc_funcs->atomic_begin)
1887 crtc_funcs->atomic_begin(crtc, NULL);
1888
Liu Ying28500292016-08-26 15:30:39 +08001889 drm_atomic_crtc_state_for_each_plane(plane, old_crtc_state) {
Jyri Sarha6753ba92015-11-27 16:14:01 +02001890 const struct drm_plane_helper_funcs *plane_funcs =
1891 plane->helper_private;
1892
Liu Ying28500292016-08-26 15:30:39 +08001893 if (!plane_funcs)
Jyri Sarha6753ba92015-11-27 16:14:01 +02001894 continue;
1895
1896 WARN_ON(!plane_funcs->atomic_disable);
1897 if (plane_funcs->atomic_disable)
1898 plane_funcs->atomic_disable(plane, NULL);
1899 }
1900
1901 if (atomic && crtc_funcs && crtc_funcs->atomic_flush)
1902 crtc_funcs->atomic_flush(crtc, NULL);
1903}
1904EXPORT_SYMBOL(drm_atomic_helper_disable_planes_on_crtc);
1905
1906/**
Daniel Vetterc2fcd272014-11-05 00:14:14 +01001907 * drm_atomic_helper_cleanup_planes - cleanup plane resources after commit
1908 * @dev: DRM device
1909 * @old_state: atomic state object with old state structures
1910 *
1911 * This function cleans up plane state, specifically framebuffers, from the old
1912 * configuration. Hence the old configuration must be perserved in @old_state to
1913 * be able to call this function.
1914 *
1915 * This function must also be called on the new state when the atomic update
1916 * fails at any point after calling drm_atomic_helper_prepare_planes().
1917 */
1918void drm_atomic_helper_cleanup_planes(struct drm_device *dev,
1919 struct drm_atomic_state *old_state)
1920{
Ander Conselvan de Oliveiradf63b992015-04-10 14:58:39 +03001921 struct drm_plane *plane;
1922 struct drm_plane_state *plane_state;
Daniel Vetterc2fcd272014-11-05 00:14:14 +01001923 int i;
1924
Ander Conselvan de Oliveiradf63b992015-04-10 14:58:39 +03001925 for_each_plane_in_state(old_state, plane, plane_state, i) {
Ville Syrjäläb5ceff202015-03-10 14:35:20 +02001926 const struct drm_plane_helper_funcs *funcs;
Daniel Vetterc2fcd272014-11-05 00:14:14 +01001927
Daniel Vetterc2fcd272014-11-05 00:14:14 +01001928 funcs = plane->helper_private;
1929
Maarten Lankhorst844f9112015-09-02 10:42:40 +02001930 if (funcs->cleanup_fb)
1931 funcs->cleanup_fb(plane, plane_state);
Daniel Vetterc2fcd272014-11-05 00:14:14 +01001932 }
1933}
1934EXPORT_SYMBOL(drm_atomic_helper_cleanup_planes);
1935
1936/**
1937 * drm_atomic_helper_swap_state - store atomic state into current sw state
Daniel Vetterc2fcd272014-11-05 00:14:14 +01001938 * @state: atomic state
Daniel Vetter5e84c262016-06-10 00:06:32 +02001939 * @stall: stall for proceeding commits
Daniel Vetterc2fcd272014-11-05 00:14:14 +01001940 *
1941 * This function stores the atomic state into the current state pointers in all
1942 * driver objects. It should be called after all failing steps have been done
1943 * and succeeded, but before the actual hardware state is committed.
1944 *
1945 * For cleanup and error recovery the current state for all changed objects will
1946 * be swaped into @state.
1947 *
1948 * With that sequence it fits perfectly into the plane prepare/cleanup sequence:
1949 *
1950 * 1. Call drm_atomic_helper_prepare_planes() with the staged atomic state.
1951 *
1952 * 2. Do any other steps that might fail.
1953 *
1954 * 3. Put the staged state into the current state pointers with this function.
1955 *
1956 * 4. Actually commit the hardware state.
1957 *
Daniel Vetter26196f72015-08-25 16:26:03 +02001958 * 5. Call drm_atomic_helper_cleanup_planes() with @state, which since step 3
Daniel Vetterc2fcd272014-11-05 00:14:14 +01001959 * contains the old state. Also do any other cleanup required with that state.
Daniel Vettera095caa2016-06-08 17:15:36 +02001960 *
1961 * @stall must be set when nonblocking commits for this driver directly access
1962 * the ->state pointer of &drm_plane, &drm_crtc or &drm_connector. With the
1963 * current atomic helpers this is almost always the case, since the helpers
1964 * don't pass the right state structures to the callbacks.
Daniel Vetterc2fcd272014-11-05 00:14:14 +01001965 */
Daniel Vetter5e84c262016-06-10 00:06:32 +02001966void drm_atomic_helper_swap_state(struct drm_atomic_state *state,
1967 bool stall)
Daniel Vetterc2fcd272014-11-05 00:14:14 +01001968{
1969 int i;
Daniel Vettera095caa2016-06-08 17:15:36 +02001970 long ret;
Daniel Vetterbe9174a2016-06-02 00:06:24 +02001971 struct drm_connector *connector;
1972 struct drm_connector_state *conn_state;
1973 struct drm_crtc *crtc;
1974 struct drm_crtc_state *crtc_state;
1975 struct drm_plane *plane;
1976 struct drm_plane_state *plane_state;
Daniel Vettera095caa2016-06-08 17:15:36 +02001977 struct drm_crtc_commit *commit;
1978
1979 if (stall) {
1980 for_each_crtc_in_state(state, crtc, crtc_state, i) {
1981 spin_lock(&crtc->commit_lock);
1982 commit = list_first_entry_or_null(&crtc->commit_list,
1983 struct drm_crtc_commit, commit_entry);
1984 if (commit)
1985 drm_crtc_commit_get(commit);
1986 spin_unlock(&crtc->commit_lock);
1987
1988 if (!commit)
1989 continue;
1990
1991 ret = wait_for_completion_timeout(&commit->hw_done,
1992 10*HZ);
1993 if (ret == 0)
1994 DRM_ERROR("[CRTC:%d:%s] hw_done timed out\n",
1995 crtc->base.id, crtc->name);
1996 drm_crtc_commit_put(commit);
1997 }
1998 }
Daniel Vetterc2fcd272014-11-05 00:14:14 +01001999
Daniel Vetterbe9174a2016-06-02 00:06:24 +02002000 for_each_connector_in_state(state, connector, conn_state, i) {
Daniel Vetterc2fcd272014-11-05 00:14:14 +01002001 connector->state->state = state;
Daniel Vetter63e83c12016-06-02 00:06:32 +02002002 swap(state->connectors[i].state, connector->state);
Daniel Vetterc2fcd272014-11-05 00:14:14 +01002003 connector->state->state = NULL;
2004 }
2005
Daniel Vetterbe9174a2016-06-02 00:06:24 +02002006 for_each_crtc_in_state(state, crtc, crtc_state, i) {
Daniel Vetterc2fcd272014-11-05 00:14:14 +01002007 crtc->state->state = state;
Daniel Vetter5d943aa62016-06-02 00:06:34 +02002008 swap(state->crtcs[i].state, crtc->state);
Daniel Vetterc2fcd272014-11-05 00:14:14 +01002009 crtc->state->state = NULL;
Daniel Vettera095caa2016-06-08 17:15:36 +02002010
2011 if (state->crtcs[i].commit) {
2012 spin_lock(&crtc->commit_lock);
2013 list_add(&state->crtcs[i].commit->commit_entry,
2014 &crtc->commit_list);
2015 spin_unlock(&crtc->commit_lock);
2016
2017 state->crtcs[i].commit->event = NULL;
2018 }
Daniel Vetterc2fcd272014-11-05 00:14:14 +01002019 }
2020
Daniel Vetterbe9174a2016-06-02 00:06:24 +02002021 for_each_plane_in_state(state, plane, plane_state, i) {
Daniel Vetterc2fcd272014-11-05 00:14:14 +01002022 plane->state->state = state;
Daniel Vetterb8b53422016-06-02 00:06:33 +02002023 swap(state->planes[i].state, plane->state);
Daniel Vetterc2fcd272014-11-05 00:14:14 +01002024 plane->state->state = NULL;
2025 }
2026}
2027EXPORT_SYMBOL(drm_atomic_helper_swap_state);
Daniel Vetter042652e2014-07-27 13:46:52 +02002028
2029/**
2030 * drm_atomic_helper_update_plane - Helper for primary plane update using atomic
2031 * @plane: plane object to update
2032 * @crtc: owning CRTC of owning plane
2033 * @fb: framebuffer to flip onto plane
2034 * @crtc_x: x offset of primary plane on crtc
2035 * @crtc_y: y offset of primary plane on crtc
2036 * @crtc_w: width of primary plane rectangle on crtc
2037 * @crtc_h: height of primary plane rectangle on crtc
2038 * @src_x: x offset of @fb for panning
2039 * @src_y: y offset of @fb for panning
2040 * @src_w: width of source rectangle in @fb
2041 * @src_h: height of source rectangle in @fb
2042 *
2043 * Provides a default plane update handler using the atomic driver interface.
2044 *
2045 * RETURNS:
2046 * Zero on success, error code on failure
2047 */
2048int drm_atomic_helper_update_plane(struct drm_plane *plane,
2049 struct drm_crtc *crtc,
2050 struct drm_framebuffer *fb,
2051 int crtc_x, int crtc_y,
2052 unsigned int crtc_w, unsigned int crtc_h,
2053 uint32_t src_x, uint32_t src_y,
2054 uint32_t src_w, uint32_t src_h)
2055{
2056 struct drm_atomic_state *state;
2057 struct drm_plane_state *plane_state;
2058 int ret = 0;
2059
2060 state = drm_atomic_state_alloc(plane->dev);
2061 if (!state)
2062 return -ENOMEM;
2063
2064 state->acquire_ctx = drm_modeset_legacy_acquire_ctx(crtc);
2065retry:
2066 plane_state = drm_atomic_get_plane_state(state, plane);
2067 if (IS_ERR(plane_state)) {
2068 ret = PTR_ERR(plane_state);
2069 goto fail;
2070 }
2071
Daniel Vetter07cc0ef2014-11-27 15:49:39 +01002072 ret = drm_atomic_set_crtc_for_plane(plane_state, crtc);
Daniel Vetter042652e2014-07-27 13:46:52 +02002073 if (ret != 0)
2074 goto fail;
Daniel Vetter321ebf02014-11-04 22:57:27 +01002075 drm_atomic_set_fb_for_plane(plane_state, fb);
Daniel Vetter042652e2014-07-27 13:46:52 +02002076 plane_state->crtc_x = crtc_x;
2077 plane_state->crtc_y = crtc_y;
Daniel Vetter042652e2014-07-27 13:46:52 +02002078 plane_state->crtc_w = crtc_w;
Ville Syrjälä02e6f372015-11-16 17:02:35 +02002079 plane_state->crtc_h = crtc_h;
Daniel Vetter042652e2014-07-27 13:46:52 +02002080 plane_state->src_x = src_x;
2081 plane_state->src_y = src_y;
Daniel Vetter042652e2014-07-27 13:46:52 +02002082 plane_state->src_w = src_w;
Ville Syrjälä02e6f372015-11-16 17:02:35 +02002083 plane_state->src_h = src_h;
Daniel Vetter042652e2014-07-27 13:46:52 +02002084
Daniel Vetter3671c582015-05-04 15:40:52 +02002085 if (plane == crtc->cursor)
2086 state->legacy_cursor_update = true;
2087
Daniel Vetter042652e2014-07-27 13:46:52 +02002088 ret = drm_atomic_commit(state);
Daniel Vetter042652e2014-07-27 13:46:52 +02002089fail:
2090 if (ret == -EDEADLK)
2091 goto backoff;
2092
Chris Wilson08536952016-10-14 13:18:18 +01002093 drm_atomic_state_put(state);
Daniel Vetter042652e2014-07-27 13:46:52 +02002094 return ret;
Chris Wilson08536952016-10-14 13:18:18 +01002095
Daniel Vetter042652e2014-07-27 13:46:52 +02002096backoff:
Daniel Vetter042652e2014-07-27 13:46:52 +02002097 drm_atomic_state_clear(state);
Daniel Vetter6f75cea2014-11-19 18:38:07 +01002098 drm_atomic_legacy_backoff(state);
Daniel Vetter042652e2014-07-27 13:46:52 +02002099
2100 /*
2101 * Someone might have exchanged the framebuffer while we dropped locks
2102 * in the backoff code. We need to fix up the fb refcount tracking the
2103 * core does for us.
2104 */
2105 plane->old_fb = plane->fb;
2106
2107 goto retry;
2108}
2109EXPORT_SYMBOL(drm_atomic_helper_update_plane);
2110
2111/**
2112 * drm_atomic_helper_disable_plane - Helper for primary plane disable using * atomic
2113 * @plane: plane to disable
2114 *
2115 * Provides a default plane disable handler using the atomic driver interface.
2116 *
2117 * RETURNS:
2118 * Zero on success, error code on failure
2119 */
2120int drm_atomic_helper_disable_plane(struct drm_plane *plane)
2121{
2122 struct drm_atomic_state *state;
2123 struct drm_plane_state *plane_state;
2124 int ret = 0;
2125
Jasper St. Pierreaa54e2e2014-11-20 19:59:15 -08002126 /*
2127 * FIXME: Without plane->crtc set we can't get at the implicit legacy
2128 * acquire context. The real fix will be to wire the acquire ctx through
2129 * everywhere we need it, but meanwhile prevent chaos by just skipping
2130 * this noop. The critical case is the cursor ioctls which a) only grab
2131 * crtc/cursor-plane locks (so we need the crtc to get at the right
2132 * acquire context) and b) can try to disable the plane multiple times.
2133 */
2134 if (!plane->crtc)
2135 return 0;
2136
Daniel Vetter042652e2014-07-27 13:46:52 +02002137 state = drm_atomic_state_alloc(plane->dev);
2138 if (!state)
2139 return -ENOMEM;
2140
2141 state->acquire_ctx = drm_modeset_legacy_acquire_ctx(plane->crtc);
2142retry:
2143 plane_state = drm_atomic_get_plane_state(state, plane);
2144 if (IS_ERR(plane_state)) {
2145 ret = PTR_ERR(plane_state);
2146 goto fail;
2147 }
2148
Maarten Lankhorst24e79d02015-11-11 11:29:07 +01002149 if (plane_state->crtc && (plane == plane->crtc->cursor))
2150 plane_state->state->legacy_cursor_update = true;
2151
Rob Clarkbbb1e522015-08-25 15:35:58 -04002152 ret = __drm_atomic_helper_disable_plane(plane, plane_state);
Daniel Vetter042652e2014-07-27 13:46:52 +02002153 if (ret != 0)
2154 goto fail;
Daniel Vetterf02ad902015-01-22 16:36:23 +01002155
Daniel Vetter042652e2014-07-27 13:46:52 +02002156 ret = drm_atomic_commit(state);
Daniel Vetter042652e2014-07-27 13:46:52 +02002157fail:
2158 if (ret == -EDEADLK)
2159 goto backoff;
2160
Chris Wilson08536952016-10-14 13:18:18 +01002161 drm_atomic_state_put(state);
Daniel Vetter042652e2014-07-27 13:46:52 +02002162 return ret;
Chris Wilson08536952016-10-14 13:18:18 +01002163
Daniel Vetter042652e2014-07-27 13:46:52 +02002164backoff:
Daniel Vetter042652e2014-07-27 13:46:52 +02002165 drm_atomic_state_clear(state);
Daniel Vetter6f75cea2014-11-19 18:38:07 +01002166 drm_atomic_legacy_backoff(state);
Daniel Vetter042652e2014-07-27 13:46:52 +02002167
2168 /*
2169 * Someone might have exchanged the framebuffer while we dropped locks
2170 * in the backoff code. We need to fix up the fb refcount tracking the
2171 * core does for us.
2172 */
2173 plane->old_fb = plane->fb;
2174
2175 goto retry;
2176}
2177EXPORT_SYMBOL(drm_atomic_helper_disable_plane);
2178
Rob Clarkbbb1e522015-08-25 15:35:58 -04002179/* just used from fb-helper and atomic-helper: */
2180int __drm_atomic_helper_disable_plane(struct drm_plane *plane,
2181 struct drm_plane_state *plane_state)
2182{
2183 int ret;
2184
2185 ret = drm_atomic_set_crtc_for_plane(plane_state, NULL);
2186 if (ret != 0)
2187 return ret;
2188
2189 drm_atomic_set_fb_for_plane(plane_state, NULL);
2190 plane_state->crtc_x = 0;
2191 plane_state->crtc_y = 0;
Rob Clarkbbb1e522015-08-25 15:35:58 -04002192 plane_state->crtc_w = 0;
Ville Syrjälä02e6f372015-11-16 17:02:35 +02002193 plane_state->crtc_h = 0;
Rob Clarkbbb1e522015-08-25 15:35:58 -04002194 plane_state->src_x = 0;
2195 plane_state->src_y = 0;
Rob Clarkbbb1e522015-08-25 15:35:58 -04002196 plane_state->src_w = 0;
Ville Syrjälä02e6f372015-11-16 17:02:35 +02002197 plane_state->src_h = 0;
Rob Clarkbbb1e522015-08-25 15:35:58 -04002198
Rob Clarkbbb1e522015-08-25 15:35:58 -04002199 return 0;
2200}
2201
Daniel Vetter042652e2014-07-27 13:46:52 +02002202static int update_output_state(struct drm_atomic_state *state,
2203 struct drm_mode_set *set)
2204{
2205 struct drm_device *dev = set->crtc->dev;
Ander Conselvan de Oliveiradf63b992015-04-10 14:58:39 +03002206 struct drm_crtc *crtc;
2207 struct drm_crtc_state *crtc_state;
2208 struct drm_connector *connector;
Daniel Vetter042652e2014-07-27 13:46:52 +02002209 struct drm_connector_state *conn_state;
Maarten Lankhorst6ab520a2016-02-24 09:37:28 +01002210 int ret, i;
Daniel Vetter042652e2014-07-27 13:46:52 +02002211
2212 ret = drm_modeset_lock(&dev->mode_config.connection_mutex,
2213 state->acquire_ctx);
2214 if (ret)
2215 return ret;
2216
Maarten Lankhorst6ab520a2016-02-24 09:37:28 +01002217 /* First disable all connectors on the target crtc. */
2218 ret = drm_atomic_add_affected_connectors(state, set->crtc);
2219 if (ret)
2220 return ret;
Daniel Vetter042652e2014-07-27 13:46:52 +02002221
Ander Conselvan de Oliveiradf63b992015-04-10 14:58:39 +03002222 for_each_connector_in_state(state, connector, conn_state, i) {
Daniel Vetter042652e2014-07-27 13:46:52 +02002223 if (conn_state->crtc == set->crtc) {
2224 ret = drm_atomic_set_crtc_for_connector(conn_state,
2225 NULL);
2226 if (ret)
2227 return ret;
2228 }
Maarten Lankhorst6ab520a2016-02-24 09:37:28 +01002229 }
Daniel Vetter042652e2014-07-27 13:46:52 +02002230
Maarten Lankhorst6ab520a2016-02-24 09:37:28 +01002231 /* Then set all connectors from set->connectors on the target crtc */
2232 for (i = 0; i < set->num_connectors; i++) {
2233 conn_state = drm_atomic_get_connector_state(state,
2234 set->connectors[i]);
2235 if (IS_ERR(conn_state))
2236 return PTR_ERR(conn_state);
2237
2238 ret = drm_atomic_set_crtc_for_connector(conn_state,
2239 set->crtc);
2240 if (ret)
2241 return ret;
Daniel Vetter042652e2014-07-27 13:46:52 +02002242 }
2243
Ander Conselvan de Oliveiradf63b992015-04-10 14:58:39 +03002244 for_each_crtc_in_state(state, crtc, crtc_state, i) {
Daniel Vetter042652e2014-07-27 13:46:52 +02002245 /* Don't update ->enable for the CRTC in the set_config request,
2246 * since a mismatch would indicate a bug in the upper layers.
2247 * The actual modeset code later on will catch any
2248 * inconsistencies here. */
2249 if (crtc == set->crtc)
2250 continue;
2251
Maarten Lankhorst14de6c42016-01-04 12:53:20 +01002252 if (!crtc_state->connector_mask) {
Laurent Pinchartc30f55a2015-06-22 13:37:46 +03002253 ret = drm_atomic_set_mode_prop_for_crtc(crtc_state,
2254 NULL);
2255 if (ret < 0)
2256 return ret;
2257
Maarten Lankhorst9b5edbf2015-06-01 08:59:53 +02002258 crtc_state->active = false;
Laurent Pinchartc30f55a2015-06-22 13:37:46 +03002259 }
Daniel Vetter042652e2014-07-27 13:46:52 +02002260 }
2261
2262 return 0;
2263}
2264
2265/**
2266 * drm_atomic_helper_set_config - set a new config from userspace
2267 * @set: mode set configuration
2268 *
2269 * Provides a default crtc set_config handler using the atomic driver interface.
2270 *
2271 * Returns:
2272 * Returns 0 on success, negative errno numbers on failure.
2273 */
2274int drm_atomic_helper_set_config(struct drm_mode_set *set)
2275{
2276 struct drm_atomic_state *state;
2277 struct drm_crtc *crtc = set->crtc;
Daniel Vetter042652e2014-07-27 13:46:52 +02002278 int ret = 0;
2279
2280 state = drm_atomic_state_alloc(crtc->dev);
2281 if (!state)
2282 return -ENOMEM;
2283
Maarten Lankhorst40616a22016-03-03 10:17:39 +01002284 state->legacy_set_config = true;
Daniel Vetter042652e2014-07-27 13:46:52 +02002285 state->acquire_ctx = drm_modeset_legacy_acquire_ctx(crtc);
2286retry:
Rob Clarkbbb1e522015-08-25 15:35:58 -04002287 ret = __drm_atomic_helper_set_config(set, state);
Daniel Stone819364d2015-05-26 14:36:48 +01002288 if (ret != 0)
2289 goto fail;
2290
Daniel Vetter042652e2014-07-27 13:46:52 +02002291 ret = drm_atomic_commit(state);
Daniel Vetter042652e2014-07-27 13:46:52 +02002292fail:
2293 if (ret == -EDEADLK)
2294 goto backoff;
2295
Chris Wilson08536952016-10-14 13:18:18 +01002296 drm_atomic_state_put(state);
Daniel Vetter042652e2014-07-27 13:46:52 +02002297 return ret;
Chris Wilson08536952016-10-14 13:18:18 +01002298
Daniel Vetter042652e2014-07-27 13:46:52 +02002299backoff:
Daniel Vetter042652e2014-07-27 13:46:52 +02002300 drm_atomic_state_clear(state);
Daniel Vetter6f75cea2014-11-19 18:38:07 +01002301 drm_atomic_legacy_backoff(state);
Daniel Vetter042652e2014-07-27 13:46:52 +02002302
2303 /*
2304 * Someone might have exchanged the framebuffer while we dropped locks
2305 * in the backoff code. We need to fix up the fb refcount tracking the
2306 * core does for us.
2307 */
2308 crtc->primary->old_fb = crtc->primary->fb;
2309
2310 goto retry;
2311}
2312EXPORT_SYMBOL(drm_atomic_helper_set_config);
2313
Rob Clarkbbb1e522015-08-25 15:35:58 -04002314/* just used from fb-helper and atomic-helper: */
2315int __drm_atomic_helper_set_config(struct drm_mode_set *set,
2316 struct drm_atomic_state *state)
2317{
2318 struct drm_crtc_state *crtc_state;
2319 struct drm_plane_state *primary_state;
2320 struct drm_crtc *crtc = set->crtc;
Ville Syrjälä83926112015-11-16 17:02:34 +02002321 int hdisplay, vdisplay;
Rob Clarkbbb1e522015-08-25 15:35:58 -04002322 int ret;
2323
2324 crtc_state = drm_atomic_get_crtc_state(state, crtc);
2325 if (IS_ERR(crtc_state))
2326 return PTR_ERR(crtc_state);
2327
2328 primary_state = drm_atomic_get_plane_state(state, crtc->primary);
2329 if (IS_ERR(primary_state))
2330 return PTR_ERR(primary_state);
2331
2332 if (!set->mode) {
2333 WARN_ON(set->fb);
2334 WARN_ON(set->num_connectors);
2335
2336 ret = drm_atomic_set_mode_for_crtc(crtc_state, NULL);
2337 if (ret != 0)
2338 return ret;
2339
2340 crtc_state->active = false;
2341
2342 ret = drm_atomic_set_crtc_for_plane(primary_state, NULL);
2343 if (ret != 0)
2344 return ret;
2345
2346 drm_atomic_set_fb_for_plane(primary_state, NULL);
2347
2348 goto commit;
2349 }
2350
2351 WARN_ON(!set->fb);
2352 WARN_ON(!set->num_connectors);
2353
2354 ret = drm_atomic_set_mode_for_crtc(crtc_state, set->mode);
2355 if (ret != 0)
2356 return ret;
2357
2358 crtc_state->active = true;
2359
2360 ret = drm_atomic_set_crtc_for_plane(primary_state, crtc);
2361 if (ret != 0)
2362 return ret;
2363
Ville Syrjälä83926112015-11-16 17:02:34 +02002364 drm_crtc_get_hv_timing(set->mode, &hdisplay, &vdisplay);
2365
Rob Clarkbbb1e522015-08-25 15:35:58 -04002366 drm_atomic_set_fb_for_plane(primary_state, set->fb);
2367 primary_state->crtc_x = 0;
2368 primary_state->crtc_y = 0;
Ville Syrjälä83926112015-11-16 17:02:34 +02002369 primary_state->crtc_w = hdisplay;
Ville Syrjälä02e6f372015-11-16 17:02:35 +02002370 primary_state->crtc_h = vdisplay;
Rob Clarkbbb1e522015-08-25 15:35:58 -04002371 primary_state->src_x = set->x << 16;
2372 primary_state->src_y = set->y << 16;
Ville Syrjäläbd2ef252016-09-26 19:30:46 +03002373 if (drm_rotation_90_or_270(primary_state->rotation)) {
Ville Syrjälä83926112015-11-16 17:02:34 +02002374 primary_state->src_w = vdisplay << 16;
Ville Syrjälä02e6f372015-11-16 17:02:35 +02002375 primary_state->src_h = hdisplay << 16;
Ville Syrjälä41121242015-10-15 20:39:59 +03002376 } else {
Ville Syrjälä83926112015-11-16 17:02:34 +02002377 primary_state->src_w = hdisplay << 16;
Ville Syrjälä02e6f372015-11-16 17:02:35 +02002378 primary_state->src_h = vdisplay << 16;
Ville Syrjälä41121242015-10-15 20:39:59 +03002379 }
Rob Clarkbbb1e522015-08-25 15:35:58 -04002380
2381commit:
2382 ret = update_output_state(state, set);
2383 if (ret)
2384 return ret;
2385
2386 return 0;
2387}
2388
Daniel Vetter042652e2014-07-27 13:46:52 +02002389/**
Thierry Reding14942762015-12-02 17:50:04 +01002390 * drm_atomic_helper_disable_all - disable all currently active outputs
2391 * @dev: DRM device
2392 * @ctx: lock acquisition context
2393 *
2394 * Loops through all connectors, finding those that aren't turned off and then
2395 * turns them off by setting their DPMS mode to OFF and deactivating the CRTC
2396 * that they are connected to.
2397 *
2398 * This is used for example in suspend/resume to disable all currently active
2399 * functions when suspending.
2400 *
2401 * Note that if callers haven't already acquired all modeset locks this might
2402 * return -EDEADLK, which must be handled by calling drm_modeset_backoff().
2403 *
2404 * Returns:
2405 * 0 on success or a negative error code on failure.
2406 *
2407 * See also:
2408 * drm_atomic_helper_suspend(), drm_atomic_helper_resume()
2409 */
2410int drm_atomic_helper_disable_all(struct drm_device *dev,
2411 struct drm_modeset_acquire_ctx *ctx)
2412{
2413 struct drm_atomic_state *state;
2414 struct drm_connector *conn;
Daniel Vetterc36a3252016-12-15 16:58:43 +01002415 struct drm_connector_list_iter conn_iter;
Thierry Reding14942762015-12-02 17:50:04 +01002416 int err;
2417
2418 state = drm_atomic_state_alloc(dev);
2419 if (!state)
2420 return -ENOMEM;
2421
2422 state->acquire_ctx = ctx;
2423
Daniel Vetterc36a3252016-12-15 16:58:43 +01002424 drm_connector_list_iter_get(dev, &conn_iter);
2425 drm_for_each_connector_iter(conn, &conn_iter) {
Thierry Reding14942762015-12-02 17:50:04 +01002426 struct drm_crtc *crtc = conn->state->crtc;
2427 struct drm_crtc_state *crtc_state;
2428
2429 if (!crtc || conn->dpms != DRM_MODE_DPMS_ON)
2430 continue;
2431
2432 crtc_state = drm_atomic_get_crtc_state(state, crtc);
2433 if (IS_ERR(crtc_state)) {
2434 err = PTR_ERR(crtc_state);
2435 goto free;
2436 }
2437
2438 crtc_state->active = false;
2439 }
2440
2441 err = drm_atomic_commit(state);
Thierry Reding14942762015-12-02 17:50:04 +01002442free:
Daniel Vetterc36a3252016-12-15 16:58:43 +01002443 drm_connector_list_iter_put(&conn_iter);
Chris Wilson08536952016-10-14 13:18:18 +01002444 drm_atomic_state_put(state);
Thierry Reding14942762015-12-02 17:50:04 +01002445 return err;
2446}
2447EXPORT_SYMBOL(drm_atomic_helper_disable_all);
2448
2449/**
2450 * drm_atomic_helper_suspend - subsystem-level suspend helper
2451 * @dev: DRM device
2452 *
2453 * Duplicates the current atomic state, disables all active outputs and then
2454 * returns a pointer to the original atomic state to the caller. Drivers can
2455 * pass this pointer to the drm_atomic_helper_resume() helper upon resume to
2456 * restore the output configuration that was active at the time the system
2457 * entered suspend.
2458 *
2459 * Note that it is potentially unsafe to use this. The atomic state object
2460 * returned by this function is assumed to be persistent. Drivers must ensure
2461 * that this holds true. Before calling this function, drivers must make sure
2462 * to suspend fbdev emulation so that nothing can be using the device.
2463 *
2464 * Returns:
2465 * A pointer to a copy of the state before suspend on success or an ERR_PTR()-
2466 * encoded error code on failure. Drivers should store the returned atomic
2467 * state object and pass it to the drm_atomic_helper_resume() helper upon
2468 * resume.
2469 *
2470 * See also:
2471 * drm_atomic_helper_duplicate_state(), drm_atomic_helper_disable_all(),
2472 * drm_atomic_helper_resume()
2473 */
2474struct drm_atomic_state *drm_atomic_helper_suspend(struct drm_device *dev)
2475{
2476 struct drm_modeset_acquire_ctx ctx;
2477 struct drm_atomic_state *state;
2478 int err;
2479
2480 drm_modeset_acquire_init(&ctx, 0);
2481
2482retry:
2483 err = drm_modeset_lock_all_ctx(dev, &ctx);
2484 if (err < 0) {
2485 state = ERR_PTR(err);
2486 goto unlock;
2487 }
2488
2489 state = drm_atomic_helper_duplicate_state(dev, &ctx);
2490 if (IS_ERR(state))
2491 goto unlock;
2492
2493 err = drm_atomic_helper_disable_all(dev, &ctx);
2494 if (err < 0) {
Chris Wilson08536952016-10-14 13:18:18 +01002495 drm_atomic_state_put(state);
Thierry Reding14942762015-12-02 17:50:04 +01002496 state = ERR_PTR(err);
2497 goto unlock;
2498 }
2499
2500unlock:
2501 if (PTR_ERR(state) == -EDEADLK) {
2502 drm_modeset_backoff(&ctx);
2503 goto retry;
2504 }
2505
2506 drm_modeset_drop_locks(&ctx);
2507 drm_modeset_acquire_fini(&ctx);
2508 return state;
2509}
2510EXPORT_SYMBOL(drm_atomic_helper_suspend);
2511
2512/**
2513 * drm_atomic_helper_resume - subsystem-level resume helper
2514 * @dev: DRM device
2515 * @state: atomic state to resume to
2516 *
2517 * Calls drm_mode_config_reset() to synchronize hardware and software states,
2518 * grabs all modeset locks and commits the atomic state object. This can be
2519 * used in conjunction with the drm_atomic_helper_suspend() helper to
2520 * implement suspend/resume for drivers that support atomic mode-setting.
2521 *
2522 * Returns:
2523 * 0 on success or a negative error code on failure.
2524 *
2525 * See also:
2526 * drm_atomic_helper_suspend()
2527 */
2528int drm_atomic_helper_resume(struct drm_device *dev,
2529 struct drm_atomic_state *state)
2530{
2531 struct drm_mode_config *config = &dev->mode_config;
2532 int err;
2533
2534 drm_mode_config_reset(dev);
2535 drm_modeset_lock_all(dev);
2536 state->acquire_ctx = config->acquire_ctx;
2537 err = drm_atomic_commit(state);
2538 drm_modeset_unlock_all(dev);
2539
2540 return err;
2541}
2542EXPORT_SYMBOL(drm_atomic_helper_resume);
2543
2544/**
Laurent Pinchart7f500022015-02-23 02:50:23 +02002545 * drm_atomic_helper_crtc_set_property - helper for crtc properties
Daniel Vetter042652e2014-07-27 13:46:52 +02002546 * @crtc: DRM crtc
2547 * @property: DRM property
2548 * @val: value of property
2549 *
Laurent Pinchart7f500022015-02-23 02:50:23 +02002550 * Provides a default crtc set_property handler using the atomic driver
2551 * interface.
Daniel Vetter042652e2014-07-27 13:46:52 +02002552 *
2553 * RETURNS:
2554 * Zero on success, error code on failure
2555 */
2556int
2557drm_atomic_helper_crtc_set_property(struct drm_crtc *crtc,
2558 struct drm_property *property,
2559 uint64_t val)
2560{
2561 struct drm_atomic_state *state;
2562 struct drm_crtc_state *crtc_state;
2563 int ret = 0;
2564
2565 state = drm_atomic_state_alloc(crtc->dev);
2566 if (!state)
2567 return -ENOMEM;
2568
2569 /* ->set_property is always called with all locks held. */
2570 state->acquire_ctx = crtc->dev->mode_config.acquire_ctx;
2571retry:
2572 crtc_state = drm_atomic_get_crtc_state(state, crtc);
2573 if (IS_ERR(crtc_state)) {
2574 ret = PTR_ERR(crtc_state);
2575 goto fail;
2576 }
2577
Rob Clark40ecc692014-12-18 16:01:46 -05002578 ret = drm_atomic_crtc_set_property(crtc, crtc_state,
2579 property, val);
Daniel Vetter042652e2014-07-27 13:46:52 +02002580 if (ret)
2581 goto fail;
2582
2583 ret = drm_atomic_commit(state);
Daniel Vetter042652e2014-07-27 13:46:52 +02002584fail:
2585 if (ret == -EDEADLK)
2586 goto backoff;
2587
Chris Wilson08536952016-10-14 13:18:18 +01002588 drm_atomic_state_put(state);
Daniel Vetter042652e2014-07-27 13:46:52 +02002589 return ret;
Chris Wilson08536952016-10-14 13:18:18 +01002590
Daniel Vetter042652e2014-07-27 13:46:52 +02002591backoff:
Daniel Vetter042652e2014-07-27 13:46:52 +02002592 drm_atomic_state_clear(state);
Daniel Vetter6f75cea2014-11-19 18:38:07 +01002593 drm_atomic_legacy_backoff(state);
Daniel Vetter042652e2014-07-27 13:46:52 +02002594
2595 goto retry;
2596}
2597EXPORT_SYMBOL(drm_atomic_helper_crtc_set_property);
2598
2599/**
Laurent Pinchart7f500022015-02-23 02:50:23 +02002600 * drm_atomic_helper_plane_set_property - helper for plane properties
Daniel Vetter042652e2014-07-27 13:46:52 +02002601 * @plane: DRM plane
2602 * @property: DRM property
2603 * @val: value of property
2604 *
Laurent Pinchart7f500022015-02-23 02:50:23 +02002605 * Provides a default plane set_property handler using the atomic driver
2606 * interface.
Daniel Vetter042652e2014-07-27 13:46:52 +02002607 *
2608 * RETURNS:
2609 * Zero on success, error code on failure
2610 */
2611int
2612drm_atomic_helper_plane_set_property(struct drm_plane *plane,
2613 struct drm_property *property,
2614 uint64_t val)
2615{
2616 struct drm_atomic_state *state;
2617 struct drm_plane_state *plane_state;
2618 int ret = 0;
2619
2620 state = drm_atomic_state_alloc(plane->dev);
2621 if (!state)
2622 return -ENOMEM;
2623
2624 /* ->set_property is always called with all locks held. */
2625 state->acquire_ctx = plane->dev->mode_config.acquire_ctx;
2626retry:
2627 plane_state = drm_atomic_get_plane_state(state, plane);
2628 if (IS_ERR(plane_state)) {
2629 ret = PTR_ERR(plane_state);
2630 goto fail;
2631 }
2632
Rob Clark40ecc692014-12-18 16:01:46 -05002633 ret = drm_atomic_plane_set_property(plane, plane_state,
2634 property, val);
Daniel Vetter042652e2014-07-27 13:46:52 +02002635 if (ret)
2636 goto fail;
2637
2638 ret = drm_atomic_commit(state);
Daniel Vetter042652e2014-07-27 13:46:52 +02002639fail:
2640 if (ret == -EDEADLK)
2641 goto backoff;
2642
Chris Wilson08536952016-10-14 13:18:18 +01002643 drm_atomic_state_put(state);
Daniel Vetter042652e2014-07-27 13:46:52 +02002644 return ret;
Chris Wilson08536952016-10-14 13:18:18 +01002645
Daniel Vetter042652e2014-07-27 13:46:52 +02002646backoff:
Daniel Vetter042652e2014-07-27 13:46:52 +02002647 drm_atomic_state_clear(state);
Daniel Vetter6f75cea2014-11-19 18:38:07 +01002648 drm_atomic_legacy_backoff(state);
Daniel Vetter042652e2014-07-27 13:46:52 +02002649
2650 goto retry;
2651}
2652EXPORT_SYMBOL(drm_atomic_helper_plane_set_property);
2653
2654/**
Laurent Pinchart7f500022015-02-23 02:50:23 +02002655 * drm_atomic_helper_connector_set_property - helper for connector properties
Daniel Vetter042652e2014-07-27 13:46:52 +02002656 * @connector: DRM connector
2657 * @property: DRM property
2658 * @val: value of property
2659 *
Laurent Pinchart7f500022015-02-23 02:50:23 +02002660 * Provides a default connector set_property handler using the atomic driver
2661 * interface.
Daniel Vetter042652e2014-07-27 13:46:52 +02002662 *
2663 * RETURNS:
2664 * Zero on success, error code on failure
2665 */
2666int
2667drm_atomic_helper_connector_set_property(struct drm_connector *connector,
2668 struct drm_property *property,
2669 uint64_t val)
2670{
2671 struct drm_atomic_state *state;
2672 struct drm_connector_state *connector_state;
2673 int ret = 0;
2674
2675 state = drm_atomic_state_alloc(connector->dev);
2676 if (!state)
2677 return -ENOMEM;
2678
2679 /* ->set_property is always called with all locks held. */
2680 state->acquire_ctx = connector->dev->mode_config.acquire_ctx;
2681retry:
2682 connector_state = drm_atomic_get_connector_state(state, connector);
2683 if (IS_ERR(connector_state)) {
2684 ret = PTR_ERR(connector_state);
2685 goto fail;
2686 }
2687
Rob Clark40ecc692014-12-18 16:01:46 -05002688 ret = drm_atomic_connector_set_property(connector, connector_state,
2689 property, val);
Daniel Vetter042652e2014-07-27 13:46:52 +02002690 if (ret)
2691 goto fail;
2692
2693 ret = drm_atomic_commit(state);
Daniel Vetter042652e2014-07-27 13:46:52 +02002694fail:
2695 if (ret == -EDEADLK)
2696 goto backoff;
2697
Chris Wilson08536952016-10-14 13:18:18 +01002698 drm_atomic_state_put(state);
Daniel Vetter042652e2014-07-27 13:46:52 +02002699 return ret;
Chris Wilson08536952016-10-14 13:18:18 +01002700
Daniel Vetter042652e2014-07-27 13:46:52 +02002701backoff:
Daniel Vetter042652e2014-07-27 13:46:52 +02002702 drm_atomic_state_clear(state);
Daniel Vetter6f75cea2014-11-19 18:38:07 +01002703 drm_atomic_legacy_backoff(state);
Daniel Vetter042652e2014-07-27 13:46:52 +02002704
2705 goto retry;
2706}
2707EXPORT_SYMBOL(drm_atomic_helper_connector_set_property);
Daniel Vetter8bc0f312014-07-27 18:42:37 +02002708
Andrey Grodzovskyf869a6e2017-01-06 15:39:40 -05002709static int page_flip_common(
2710 struct drm_atomic_state *state,
2711 struct drm_crtc *crtc,
2712 struct drm_framebuffer *fb,
2713 struct drm_pending_vblank_event *event)
2714{
2715 struct drm_plane *plane = crtc->primary;
2716 struct drm_plane_state *plane_state;
2717 struct drm_crtc_state *crtc_state;
2718 int ret = 0;
2719
2720 crtc_state = drm_atomic_get_crtc_state(state, crtc);
2721 if (IS_ERR(crtc_state))
2722 return PTR_ERR(crtc_state);
2723
2724 crtc_state->event = event;
2725
2726 plane_state = drm_atomic_get_plane_state(state, plane);
2727 if (IS_ERR(plane_state))
2728 return PTR_ERR(plane_state);
2729
2730
2731 ret = drm_atomic_set_crtc_for_plane(plane_state, crtc);
2732 if (ret != 0)
2733 return ret;
2734 drm_atomic_set_fb_for_plane(plane_state, fb);
2735
2736 /* Make sure we don't accidentally do a full modeset. */
2737 state->allow_modeset = false;
2738 if (!crtc_state->active) {
2739 DRM_DEBUG_ATOMIC("[CRTC:%d] disabled, rejecting legacy flip\n",
2740 crtc->base.id);
2741 return -EINVAL;
2742 }
2743
2744 return ret;
2745}
2746
Daniel Vetter8bc0f312014-07-27 18:42:37 +02002747/**
2748 * drm_atomic_helper_page_flip - execute a legacy page flip
2749 * @crtc: DRM crtc
2750 * @fb: DRM framebuffer
2751 * @event: optional DRM event to signal upon completion
2752 * @flags: flip flags for non-vblank sync'ed updates
2753 *
Andrey Grodzovskyf869a6e2017-01-06 15:39:40 -05002754 * Provides a default &drm_crtc_funcs.page_flip implementation
2755 * using the atomic driver interface.
Daniel Vetter8bc0f312014-07-27 18:42:37 +02002756 *
2757 * Note that for now so called async page flips (i.e. updates which are not
2758 * synchronized to vblank) are not supported, since the atomic interfaces have
2759 * no provisions for this yet.
2760 *
2761 * Returns:
2762 * Returns 0 on success, negative errno numbers on failure.
Andrey Grodzovskyf869a6e2017-01-06 15:39:40 -05002763 *
2764 * See also:
2765 * drm_atomic_helper_page_flip_target()
Daniel Vetter8bc0f312014-07-27 18:42:37 +02002766 */
2767int drm_atomic_helper_page_flip(struct drm_crtc *crtc,
2768 struct drm_framebuffer *fb,
2769 struct drm_pending_vblank_event *event,
2770 uint32_t flags)
2771{
2772 struct drm_plane *plane = crtc->primary;
2773 struct drm_atomic_state *state;
Daniel Vetter8bc0f312014-07-27 18:42:37 +02002774 int ret = 0;
2775
2776 if (flags & DRM_MODE_PAGE_FLIP_ASYNC)
2777 return -EINVAL;
2778
2779 state = drm_atomic_state_alloc(plane->dev);
2780 if (!state)
2781 return -ENOMEM;
2782
2783 state->acquire_ctx = drm_modeset_legacy_acquire_ctx(crtc);
Andrey Grodzovskyf869a6e2017-01-06 15:39:40 -05002784
Daniel Vetter8bc0f312014-07-27 18:42:37 +02002785retry:
Andrey Grodzovskyf869a6e2017-01-06 15:39:40 -05002786 ret = page_flip_common(state, crtc, fb, event);
Daniel Vetter8bc0f312014-07-27 18:42:37 +02002787 if (ret != 0)
2788 goto fail;
Daniel Vetter4cba6852015-12-08 09:49:20 +01002789
Maarten Lankhorstb837ba02016-04-26 16:11:35 +02002790 ret = drm_atomic_nonblocking_commit(state);
Andrey Grodzovskyf869a6e2017-01-06 15:39:40 -05002791
Daniel Vetter8bc0f312014-07-27 18:42:37 +02002792fail:
2793 if (ret == -EDEADLK)
2794 goto backoff;
2795
Chris Wilson08536952016-10-14 13:18:18 +01002796 drm_atomic_state_put(state);
Daniel Vetter8bc0f312014-07-27 18:42:37 +02002797 return ret;
Chris Wilson08536952016-10-14 13:18:18 +01002798
Daniel Vetter8bc0f312014-07-27 18:42:37 +02002799backoff:
Daniel Vetter8bc0f312014-07-27 18:42:37 +02002800 drm_atomic_state_clear(state);
Daniel Vetter6f75cea2014-11-19 18:38:07 +01002801 drm_atomic_legacy_backoff(state);
Daniel Vetter8bc0f312014-07-27 18:42:37 +02002802
2803 /*
2804 * Someone might have exchanged the framebuffer while we dropped locks
2805 * in the backoff code. We need to fix up the fb refcount tracking the
2806 * core does for us.
2807 */
2808 plane->old_fb = plane->fb;
2809
2810 goto retry;
2811}
2812EXPORT_SYMBOL(drm_atomic_helper_page_flip);
Daniel Vetterd4617012014-11-03 15:56:43 +01002813
2814/**
Andrey Grodzovskyf869a6e2017-01-06 15:39:40 -05002815 * drm_atomic_helper_page_flip_target - do page flip on target vblank period.
2816 * @crtc: DRM crtc
2817 * @fb: DRM framebuffer
2818 * @event: optional DRM event to signal upon completion
2819 * @flags: flip flags for non-vblank sync'ed updates
2820 * @target: specifying the target vblank period when the flip to take effect
2821 *
2822 * Provides a default &drm_crtc_funcs.page_flip_target implementation.
2823 * Similar to drm_atomic_helper_page_flip() with extra parameter to specify
2824 * target vblank period to flip.
2825 *
2826 * Returns:
2827 * Returns 0 on success, negative errno numbers on failure.
2828 */
2829int drm_atomic_helper_page_flip_target(
2830 struct drm_crtc *crtc,
2831 struct drm_framebuffer *fb,
2832 struct drm_pending_vblank_event *event,
2833 uint32_t flags,
2834 uint32_t target)
2835{
2836 struct drm_plane *plane = crtc->primary;
2837 struct drm_atomic_state *state;
2838 struct drm_crtc_state *crtc_state;
2839 int ret = 0;
2840
2841 if (flags & DRM_MODE_PAGE_FLIP_ASYNC)
2842 return -EINVAL;
2843
2844 state = drm_atomic_state_alloc(plane->dev);
2845 if (!state)
2846 return -ENOMEM;
2847
2848 state->acquire_ctx = drm_modeset_legacy_acquire_ctx(crtc);
2849
2850retry:
2851 ret = page_flip_common(state, crtc, fb, event);
2852 if (ret != 0)
2853 goto fail;
2854
2855 crtc_state = drm_atomic_get_existing_crtc_state(state, crtc);
2856 if (WARN_ON(!crtc_state)) {
2857 ret = -EINVAL;
2858 goto fail;
2859 }
2860 crtc_state->target_vblank = target;
2861
2862 ret = drm_atomic_nonblocking_commit(state);
2863
2864fail:
2865 if (ret == -EDEADLK)
2866 goto backoff;
2867
2868 drm_atomic_state_put(state);
2869 return ret;
2870
2871backoff:
2872 drm_atomic_state_clear(state);
2873 drm_atomic_legacy_backoff(state);
2874
2875 /*
2876 * Someone might have exchanged the framebuffer while we dropped locks
2877 * in the backoff code. We need to fix up the fb refcount tracking the
2878 * core does for us.
2879 */
2880 plane->old_fb = plane->fb;
2881
2882 goto retry;
2883}
2884EXPORT_SYMBOL(drm_atomic_helper_page_flip_target);
2885
2886/**
Daniel Vetterb486e0e2015-01-22 18:53:05 +01002887 * drm_atomic_helper_connector_dpms() - connector dpms helper implementation
2888 * @connector: affected connector
2889 * @mode: DPMS mode
2890 *
2891 * This is the main helper function provided by the atomic helper framework for
2892 * implementing the legacy DPMS connector interface. It computes the new desired
2893 * ->active state for the corresponding CRTC (if the connector is enabled) and
Daniel Vetter2e7a5702016-06-01 23:40:36 +02002894 * updates it.
Maarten Lankhorst9a69a9a2015-07-21 11:34:55 +02002895 *
2896 * Returns:
2897 * Returns 0 on success, negative errno numbers on failure.
Daniel Vetterb486e0e2015-01-22 18:53:05 +01002898 */
Maarten Lankhorst9a69a9a2015-07-21 11:34:55 +02002899int drm_atomic_helper_connector_dpms(struct drm_connector *connector,
2900 int mode)
Daniel Vetterb486e0e2015-01-22 18:53:05 +01002901{
2902 struct drm_mode_config *config = &connector->dev->mode_config;
2903 struct drm_atomic_state *state;
2904 struct drm_crtc_state *crtc_state;
2905 struct drm_crtc *crtc;
2906 struct drm_connector *tmp_connector;
Daniel Vetterc36a3252016-12-15 16:58:43 +01002907 struct drm_connector_list_iter conn_iter;
Daniel Vetterb486e0e2015-01-22 18:53:05 +01002908 int ret;
2909 bool active = false;
Maarten Lankhorst9a69a9a2015-07-21 11:34:55 +02002910 int old_mode = connector->dpms;
Daniel Vetterb486e0e2015-01-22 18:53:05 +01002911
2912 if (mode != DRM_MODE_DPMS_ON)
2913 mode = DRM_MODE_DPMS_OFF;
2914
2915 connector->dpms = mode;
2916 crtc = connector->state->crtc;
2917
2918 if (!crtc)
Maarten Lankhorst9a69a9a2015-07-21 11:34:55 +02002919 return 0;
Daniel Vetterb486e0e2015-01-22 18:53:05 +01002920
Daniel Vetterb486e0e2015-01-22 18:53:05 +01002921 state = drm_atomic_state_alloc(connector->dev);
2922 if (!state)
Maarten Lankhorst9a69a9a2015-07-21 11:34:55 +02002923 return -ENOMEM;
Daniel Vetterb486e0e2015-01-22 18:53:05 +01002924
2925 state->acquire_ctx = drm_modeset_legacy_acquire_ctx(crtc);
2926retry:
2927 crtc_state = drm_atomic_get_crtc_state(state, crtc);
Maarten Lankhorst9a69a9a2015-07-21 11:34:55 +02002928 if (IS_ERR(crtc_state)) {
2929 ret = PTR_ERR(crtc_state);
2930 goto fail;
2931 }
Daniel Vetterb486e0e2015-01-22 18:53:05 +01002932
2933 WARN_ON(!drm_modeset_is_locked(&config->connection_mutex));
2934
Daniel Vetterc36a3252016-12-15 16:58:43 +01002935 drm_connector_list_iter_get(connector->dev, &conn_iter);
2936 drm_for_each_connector_iter(tmp_connector, &conn_iter) {
John Hunter0388df02015-03-17 15:30:28 +08002937 if (tmp_connector->state->crtc != crtc)
Daniel Vetterb486e0e2015-01-22 18:53:05 +01002938 continue;
2939
John Hunter0388df02015-03-17 15:30:28 +08002940 if (tmp_connector->dpms == DRM_MODE_DPMS_ON) {
Daniel Vetterb486e0e2015-01-22 18:53:05 +01002941 active = true;
2942 break;
2943 }
2944 }
Daniel Vetterc36a3252016-12-15 16:58:43 +01002945 drm_connector_list_iter_put(&conn_iter);
Daniel Vetterb486e0e2015-01-22 18:53:05 +01002946 crtc_state->active = active;
2947
2948 ret = drm_atomic_commit(state);
Daniel Vetterb486e0e2015-01-22 18:53:05 +01002949fail:
2950 if (ret == -EDEADLK)
2951 goto backoff;
Marta Lofstedt8f5040e2016-12-05 14:04:08 +02002952 if (ret != 0)
2953 connector->dpms = old_mode;
Chris Wilson08536952016-10-14 13:18:18 +01002954 drm_atomic_state_put(state);
Maarten Lankhorst9a69a9a2015-07-21 11:34:55 +02002955 return ret;
Chris Wilson08536952016-10-14 13:18:18 +01002956
Daniel Vetterb486e0e2015-01-22 18:53:05 +01002957backoff:
2958 drm_atomic_state_clear(state);
2959 drm_atomic_legacy_backoff(state);
2960
2961 goto retry;
2962}
2963EXPORT_SYMBOL(drm_atomic_helper_connector_dpms);
2964
2965/**
Noralf Trønnes9ecb5492016-05-11 18:09:21 +02002966 * drm_atomic_helper_best_encoder - Helper for &drm_connector_helper_funcs
2967 * ->best_encoder callback
2968 * @connector: Connector control structure
2969 *
2970 * This is a &drm_connector_helper_funcs ->best_encoder callback helper for
2971 * connectors that support exactly 1 encoder, statically determined at driver
2972 * init time.
2973 */
2974struct drm_encoder *
2975drm_atomic_helper_best_encoder(struct drm_connector *connector)
2976{
2977 WARN_ON(connector->encoder_ids[1]);
2978 return drm_encoder_find(connector->dev, connector->encoder_ids[0]);
2979}
2980EXPORT_SYMBOL(drm_atomic_helper_best_encoder);
2981
2982/**
Daniel Vetter3150c7d2014-11-06 20:53:29 +01002983 * DOC: atomic state reset and initialization
2984 *
2985 * Both the drm core and the atomic helpers assume that there is always the full
2986 * and correct atomic software state for all connectors, CRTCs and planes
2987 * available. Which is a bit a problem on driver load and also after system
2988 * suspend. One way to solve this is to have a hardware state read-out
2989 * infrastructure which reconstructs the full software state (e.g. the i915
2990 * driver).
2991 *
2992 * The simpler solution is to just reset the software state to everything off,
2993 * which is easiest to do by calling drm_mode_config_reset(). To facilitate this
2994 * the atomic helpers provide default reset implementations for all hooks.
Daniel Vetter7f8ee3e2015-12-04 09:46:06 +01002995 *
2996 * On the upside the precise state tracking of atomic simplifies system suspend
2997 * and resume a lot. For drivers using drm_mode_config_reset() a complete recipe
2998 * is implemented in drm_atomic_helper_suspend() and drm_atomic_helper_resume().
2999 * For other drivers the building blocks are split out, see the documentation
3000 * for these functions.
Daniel Vetter3150c7d2014-11-06 20:53:29 +01003001 */
3002
3003/**
Daniel Vetterd4617012014-11-03 15:56:43 +01003004 * drm_atomic_helper_crtc_reset - default ->reset hook for CRTCs
3005 * @crtc: drm CRTC
3006 *
3007 * Resets the atomic state for @crtc by freeing the state pointer (which might
3008 * be NULL, e.g. at driver load time) and allocating a new empty state object.
3009 */
3010void drm_atomic_helper_crtc_reset(struct drm_crtc *crtc)
3011{
Daniel Vetterb0b55112016-04-22 22:10:29 +02003012 if (crtc->state)
Daniel Vetterec2dc6a2016-05-09 16:34:09 +02003013 __drm_atomic_helper_crtc_destroy_state(crtc->state);
Daniel Vetterb0b55112016-04-22 22:10:29 +02003014
Daniel Vetterd4617012014-11-03 15:56:43 +01003015 kfree(crtc->state);
3016 crtc->state = kzalloc(sizeof(*crtc->state), GFP_KERNEL);
Daniel Vetter07cc0ef2014-11-27 15:49:39 +01003017
3018 if (crtc->state)
3019 crtc->state->crtc = crtc;
Daniel Vetterd4617012014-11-03 15:56:43 +01003020}
3021EXPORT_SYMBOL(drm_atomic_helper_crtc_reset);
3022
3023/**
Thierry Redingf5e78402015-01-28 14:54:32 +01003024 * __drm_atomic_helper_crtc_duplicate_state - copy atomic CRTC state
3025 * @crtc: CRTC object
3026 * @state: atomic CRTC state
3027 *
3028 * Copies atomic state from a CRTC's current state and resets inferred values.
3029 * This is useful for drivers that subclass the CRTC state.
3030 */
3031void __drm_atomic_helper_crtc_duplicate_state(struct drm_crtc *crtc,
3032 struct drm_crtc_state *state)
3033{
3034 memcpy(state, crtc->state, sizeof(*state));
3035
Daniel Stone99cf4a22015-05-25 19:11:51 +01003036 if (state->mode_blob)
3037 drm_property_reference_blob(state->mode_blob);
Lionel Landwerlin5488dc12016-02-26 17:05:00 +00003038 if (state->degamma_lut)
3039 drm_property_reference_blob(state->degamma_lut);
3040 if (state->ctm)
3041 drm_property_reference_blob(state->ctm);
3042 if (state->gamma_lut)
3043 drm_property_reference_blob(state->gamma_lut);
Thierry Redingf5e78402015-01-28 14:54:32 +01003044 state->mode_changed = false;
3045 state->active_changed = false;
3046 state->planes_changed = false;
Maarten Lankhorstfc596662015-07-21 13:28:57 +02003047 state->connectors_changed = false;
Lionel Landwerlin5488dc12016-02-26 17:05:00 +00003048 state->color_mgmt_changed = false;
Marek Szyprowski44d1240d2016-06-13 11:11:26 +02003049 state->zpos_changed = false;
Thierry Redingf5e78402015-01-28 14:54:32 +01003050 state->event = NULL;
3051}
3052EXPORT_SYMBOL(__drm_atomic_helper_crtc_duplicate_state);
3053
3054/**
Daniel Vetterd4617012014-11-03 15:56:43 +01003055 * drm_atomic_helper_crtc_duplicate_state - default state duplicate hook
3056 * @crtc: drm CRTC
3057 *
3058 * Default CRTC state duplicate hook for drivers which don't have their own
3059 * subclassed CRTC state structure.
3060 */
3061struct drm_crtc_state *
3062drm_atomic_helper_crtc_duplicate_state(struct drm_crtc *crtc)
3063{
3064 struct drm_crtc_state *state;
3065
3066 if (WARN_ON(!crtc->state))
3067 return NULL;
3068
Thierry Redingf5e78402015-01-28 14:54:32 +01003069 state = kmalloc(sizeof(*state), GFP_KERNEL);
3070 if (state)
3071 __drm_atomic_helper_crtc_duplicate_state(crtc, state);
Daniel Vetterd4617012014-11-03 15:56:43 +01003072
3073 return state;
3074}
3075EXPORT_SYMBOL(drm_atomic_helper_crtc_duplicate_state);
3076
3077/**
Thierry Redingf5e78402015-01-28 14:54:32 +01003078 * __drm_atomic_helper_crtc_destroy_state - release CRTC state
Thierry Redingf5e78402015-01-28 14:54:32 +01003079 * @state: CRTC state object to release
3080 *
3081 * Releases all resources stored in the CRTC state without actually freeing
3082 * the memory of the CRTC state. This is useful for drivers that subclass the
3083 * CRTC state.
3084 */
Daniel Vetterec2dc6a2016-05-09 16:34:09 +02003085void __drm_atomic_helper_crtc_destroy_state(struct drm_crtc_state *state)
Thierry Redingf5e78402015-01-28 14:54:32 +01003086{
Markus Elfring5f911902015-11-06 12:03:46 +01003087 drm_property_unreference_blob(state->mode_blob);
Lionel Landwerlin5488dc12016-02-26 17:05:00 +00003088 drm_property_unreference_blob(state->degamma_lut);
3089 drm_property_unreference_blob(state->ctm);
3090 drm_property_unreference_blob(state->gamma_lut);
Thierry Redingf5e78402015-01-28 14:54:32 +01003091}
3092EXPORT_SYMBOL(__drm_atomic_helper_crtc_destroy_state);
3093
3094/**
Daniel Vetterd4617012014-11-03 15:56:43 +01003095 * drm_atomic_helper_crtc_destroy_state - default state destroy hook
3096 * @crtc: drm CRTC
3097 * @state: CRTC state object to release
3098 *
3099 * Default CRTC state destroy hook for drivers which don't have their own
3100 * subclassed CRTC state structure.
3101 */
3102void drm_atomic_helper_crtc_destroy_state(struct drm_crtc *crtc,
3103 struct drm_crtc_state *state)
3104{
Daniel Vetterec2dc6a2016-05-09 16:34:09 +02003105 __drm_atomic_helper_crtc_destroy_state(state);
Daniel Vetterd4617012014-11-03 15:56:43 +01003106 kfree(state);
3107}
3108EXPORT_SYMBOL(drm_atomic_helper_crtc_destroy_state);
3109
3110/**
3111 * drm_atomic_helper_plane_reset - default ->reset hook for planes
3112 * @plane: drm plane
3113 *
3114 * Resets the atomic state for @plane by freeing the state pointer (which might
3115 * be NULL, e.g. at driver load time) and allocating a new empty state object.
3116 */
3117void drm_atomic_helper_plane_reset(struct drm_plane *plane)
3118{
Daniel Vetterb0b55112016-04-22 22:10:29 +02003119 if (plane->state)
Daniel Vetter2f701692016-05-09 16:34:10 +02003120 __drm_atomic_helper_plane_destroy_state(plane->state);
Daniel Vetter321ebf02014-11-04 22:57:27 +01003121
Daniel Vetterd4617012014-11-03 15:56:43 +01003122 kfree(plane->state);
3123 plane->state = kzalloc(sizeof(*plane->state), GFP_KERNEL);
Daniel Vetter07cc0ef2014-11-27 15:49:39 +01003124
Marek Szyprowski25aaa3a2016-01-19 09:26:48 +01003125 if (plane->state) {
Daniel Vetter07cc0ef2014-11-27 15:49:39 +01003126 plane->state->plane = plane;
Joonas Lahtinen31ad61e2016-07-29 08:50:05 +03003127 plane->state->rotation = DRM_ROTATE_0;
Marek Szyprowski25aaa3a2016-01-19 09:26:48 +01003128 }
Daniel Vetterd4617012014-11-03 15:56:43 +01003129}
3130EXPORT_SYMBOL(drm_atomic_helper_plane_reset);
3131
3132/**
Thierry Redingf5e78402015-01-28 14:54:32 +01003133 * __drm_atomic_helper_plane_duplicate_state - copy atomic plane state
3134 * @plane: plane object
3135 * @state: atomic plane state
3136 *
3137 * Copies atomic state from a plane's current state. This is useful for
3138 * drivers that subclass the plane state.
3139 */
3140void __drm_atomic_helper_plane_duplicate_state(struct drm_plane *plane,
3141 struct drm_plane_state *state)
3142{
3143 memcpy(state, plane->state, sizeof(*state));
3144
3145 if (state->fb)
3146 drm_framebuffer_reference(state->fb);
Gustavo Padovan96260142016-11-15 22:06:39 +09003147
3148 state->fence = NULL;
Thierry Redingf5e78402015-01-28 14:54:32 +01003149}
3150EXPORT_SYMBOL(__drm_atomic_helper_plane_duplicate_state);
3151
3152/**
Daniel Vetterd4617012014-11-03 15:56:43 +01003153 * drm_atomic_helper_plane_duplicate_state - default state duplicate hook
3154 * @plane: drm plane
3155 *
3156 * Default plane state duplicate hook for drivers which don't have their own
3157 * subclassed plane state structure.
3158 */
3159struct drm_plane_state *
3160drm_atomic_helper_plane_duplicate_state(struct drm_plane *plane)
3161{
Daniel Vetter321ebf02014-11-04 22:57:27 +01003162 struct drm_plane_state *state;
3163
Daniel Vetterd4617012014-11-03 15:56:43 +01003164 if (WARN_ON(!plane->state))
3165 return NULL;
3166
Thierry Redingf5e78402015-01-28 14:54:32 +01003167 state = kmalloc(sizeof(*state), GFP_KERNEL);
3168 if (state)
3169 __drm_atomic_helper_plane_duplicate_state(plane, state);
Daniel Vetter321ebf02014-11-04 22:57:27 +01003170
3171 return state;
Daniel Vetterd4617012014-11-03 15:56:43 +01003172}
3173EXPORT_SYMBOL(drm_atomic_helper_plane_duplicate_state);
3174
3175/**
Thierry Redingf5e78402015-01-28 14:54:32 +01003176 * __drm_atomic_helper_plane_destroy_state - release plane state
Thierry Redingf5e78402015-01-28 14:54:32 +01003177 * @state: plane state object to release
3178 *
3179 * Releases all resources stored in the plane state without actually freeing
3180 * the memory of the plane state. This is useful for drivers that subclass the
3181 * plane state.
3182 */
Daniel Vetter2f701692016-05-09 16:34:10 +02003183void __drm_atomic_helper_plane_destroy_state(struct drm_plane_state *state)
Thierry Redingf5e78402015-01-28 14:54:32 +01003184{
3185 if (state->fb)
3186 drm_framebuffer_unreference(state->fb);
Gustavo Padovan96260142016-11-15 22:06:39 +09003187
3188 if (state->fence)
3189 dma_fence_put(state->fence);
Thierry Redingf5e78402015-01-28 14:54:32 +01003190}
3191EXPORT_SYMBOL(__drm_atomic_helper_plane_destroy_state);
3192
3193/**
Daniel Vetterd4617012014-11-03 15:56:43 +01003194 * drm_atomic_helper_plane_destroy_state - default state destroy hook
3195 * @plane: drm plane
3196 * @state: plane state object to release
3197 *
3198 * Default plane state destroy hook for drivers which don't have their own
3199 * subclassed plane state structure.
3200 */
3201void drm_atomic_helper_plane_destroy_state(struct drm_plane *plane,
Daniel Vetter321ebf02014-11-04 22:57:27 +01003202 struct drm_plane_state *state)
Daniel Vetterd4617012014-11-03 15:56:43 +01003203{
Daniel Vetter2f701692016-05-09 16:34:10 +02003204 __drm_atomic_helper_plane_destroy_state(state);
Daniel Vetterd4617012014-11-03 15:56:43 +01003205 kfree(state);
3206}
3207EXPORT_SYMBOL(drm_atomic_helper_plane_destroy_state);
3208
3209/**
Maarten Lankhorst4cd39912016-01-04 12:53:16 +01003210 * __drm_atomic_helper_connector_reset - reset state on connector
3211 * @connector: drm connector
3212 * @conn_state: connector state to assign
3213 *
3214 * Initializes the newly allocated @conn_state and assigns it to
3215 * #connector ->state, usually required when initializing the drivers
3216 * or when called from the ->reset hook.
3217 *
3218 * This is useful for drivers that subclass the connector state.
3219 */
3220void
3221__drm_atomic_helper_connector_reset(struct drm_connector *connector,
3222 struct drm_connector_state *conn_state)
3223{
3224 if (conn_state)
3225 conn_state->connector = connector;
3226
3227 connector->state = conn_state;
3228}
3229EXPORT_SYMBOL(__drm_atomic_helper_connector_reset);
3230
3231/**
Daniel Vetterd4617012014-11-03 15:56:43 +01003232 * drm_atomic_helper_connector_reset - default ->reset hook for connectors
3233 * @connector: drm connector
3234 *
3235 * Resets the atomic state for @connector by freeing the state pointer (which
3236 * might be NULL, e.g. at driver load time) and allocating a new empty state
3237 * object.
3238 */
3239void drm_atomic_helper_connector_reset(struct drm_connector *connector)
3240{
Maarten Lankhorst4cd39912016-01-04 12:53:16 +01003241 struct drm_connector_state *conn_state =
3242 kzalloc(sizeof(*conn_state), GFP_KERNEL);
Daniel Vetter07cc0ef2014-11-27 15:49:39 +01003243
Daniel Vetterb0b55112016-04-22 22:10:29 +02003244 if (connector->state)
Daniel Vetterfabd9102016-05-09 16:34:11 +02003245 __drm_atomic_helper_connector_destroy_state(connector->state);
Daniel Vetterb0b55112016-04-22 22:10:29 +02003246
Maarten Lankhorst4cd39912016-01-04 12:53:16 +01003247 kfree(connector->state);
3248 __drm_atomic_helper_connector_reset(connector, conn_state);
Daniel Vetterd4617012014-11-03 15:56:43 +01003249}
3250EXPORT_SYMBOL(drm_atomic_helper_connector_reset);
3251
3252/**
Thierry Redingf5e78402015-01-28 14:54:32 +01003253 * __drm_atomic_helper_connector_duplicate_state - copy atomic connector state
3254 * @connector: connector object
3255 * @state: atomic connector state
3256 *
3257 * Copies atomic state from a connector's current state. This is useful for
3258 * drivers that subclass the connector state.
3259 */
3260void
3261__drm_atomic_helper_connector_duplicate_state(struct drm_connector *connector,
3262 struct drm_connector_state *state)
3263{
3264 memcpy(state, connector->state, sizeof(*state));
Dave Airlied2307de2016-04-27 11:27:39 +10003265 if (state->crtc)
3266 drm_connector_reference(connector);
Thierry Redingf5e78402015-01-28 14:54:32 +01003267}
3268EXPORT_SYMBOL(__drm_atomic_helper_connector_duplicate_state);
3269
3270/**
Daniel Vetterd4617012014-11-03 15:56:43 +01003271 * drm_atomic_helper_connector_duplicate_state - default state duplicate hook
3272 * @connector: drm connector
3273 *
3274 * Default connector state duplicate hook for drivers which don't have their own
3275 * subclassed connector state structure.
3276 */
3277struct drm_connector_state *
3278drm_atomic_helper_connector_duplicate_state(struct drm_connector *connector)
3279{
Thierry Redingf5e78402015-01-28 14:54:32 +01003280 struct drm_connector_state *state;
3281
Daniel Vetterd4617012014-11-03 15:56:43 +01003282 if (WARN_ON(!connector->state))
3283 return NULL;
3284
Thierry Redingf5e78402015-01-28 14:54:32 +01003285 state = kmalloc(sizeof(*state), GFP_KERNEL);
3286 if (state)
3287 __drm_atomic_helper_connector_duplicate_state(connector, state);
3288
3289 return state;
Daniel Vetterd4617012014-11-03 15:56:43 +01003290}
3291EXPORT_SYMBOL(drm_atomic_helper_connector_duplicate_state);
3292
3293/**
Thierry Reding397fd772015-09-08 15:00:45 +02003294 * drm_atomic_helper_duplicate_state - duplicate an atomic state object
3295 * @dev: DRM device
3296 * @ctx: lock acquisition context
3297 *
3298 * Makes a copy of the current atomic state by looping over all objects and
Thierry Reding14942762015-12-02 17:50:04 +01003299 * duplicating their respective states. This is used for example by suspend/
3300 * resume support code to save the state prior to suspend such that it can
3301 * be restored upon resume.
Thierry Reding397fd772015-09-08 15:00:45 +02003302 *
3303 * Note that this treats atomic state as persistent between save and restore.
3304 * Drivers must make sure that this is possible and won't result in confusion
3305 * or erroneous behaviour.
3306 *
3307 * Note that if callers haven't already acquired all modeset locks this might
3308 * return -EDEADLK, which must be handled by calling drm_modeset_backoff().
3309 *
3310 * Returns:
3311 * A pointer to the copy of the atomic state object on success or an
3312 * ERR_PTR()-encoded error code on failure.
Thierry Reding14942762015-12-02 17:50:04 +01003313 *
3314 * See also:
3315 * drm_atomic_helper_suspend(), drm_atomic_helper_resume()
Thierry Reding397fd772015-09-08 15:00:45 +02003316 */
3317struct drm_atomic_state *
3318drm_atomic_helper_duplicate_state(struct drm_device *dev,
3319 struct drm_modeset_acquire_ctx *ctx)
3320{
3321 struct drm_atomic_state *state;
3322 struct drm_connector *conn;
Daniel Vetterc36a3252016-12-15 16:58:43 +01003323 struct drm_connector_list_iter conn_iter;
Thierry Reding397fd772015-09-08 15:00:45 +02003324 struct drm_plane *plane;
3325 struct drm_crtc *crtc;
3326 int err = 0;
3327
3328 state = drm_atomic_state_alloc(dev);
3329 if (!state)
3330 return ERR_PTR(-ENOMEM);
3331
3332 state->acquire_ctx = ctx;
3333
3334 drm_for_each_crtc(crtc, dev) {
3335 struct drm_crtc_state *crtc_state;
3336
3337 crtc_state = drm_atomic_get_crtc_state(state, crtc);
3338 if (IS_ERR(crtc_state)) {
3339 err = PTR_ERR(crtc_state);
3340 goto free;
3341 }
3342 }
3343
3344 drm_for_each_plane(plane, dev) {
3345 struct drm_plane_state *plane_state;
3346
3347 plane_state = drm_atomic_get_plane_state(state, plane);
3348 if (IS_ERR(plane_state)) {
3349 err = PTR_ERR(plane_state);
3350 goto free;
3351 }
3352 }
3353
Daniel Vetterc36a3252016-12-15 16:58:43 +01003354 drm_connector_list_iter_get(dev, &conn_iter);
3355 drm_for_each_connector_iter(conn, &conn_iter) {
Thierry Reding397fd772015-09-08 15:00:45 +02003356 struct drm_connector_state *conn_state;
3357
3358 conn_state = drm_atomic_get_connector_state(state, conn);
3359 if (IS_ERR(conn_state)) {
3360 err = PTR_ERR(conn_state);
Daniel Vetterc36a3252016-12-15 16:58:43 +01003361 drm_connector_list_iter_put(&conn_iter);
Thierry Reding397fd772015-09-08 15:00:45 +02003362 goto free;
3363 }
3364 }
Daniel Vetterc36a3252016-12-15 16:58:43 +01003365 drm_connector_list_iter_put(&conn_iter);
Thierry Reding397fd772015-09-08 15:00:45 +02003366
3367 /* clear the acquire context so that it isn't accidentally reused */
3368 state->acquire_ctx = NULL;
3369
3370free:
3371 if (err < 0) {
Chris Wilson08536952016-10-14 13:18:18 +01003372 drm_atomic_state_put(state);
Thierry Reding397fd772015-09-08 15:00:45 +02003373 state = ERR_PTR(err);
3374 }
3375
3376 return state;
3377}
3378EXPORT_SYMBOL(drm_atomic_helper_duplicate_state);
3379
3380/**
Thierry Redingf5e78402015-01-28 14:54:32 +01003381 * __drm_atomic_helper_connector_destroy_state - release connector state
Thierry Redingf5e78402015-01-28 14:54:32 +01003382 * @state: connector state object to release
3383 *
3384 * Releases all resources stored in the connector state without actually
3385 * freeing the memory of the connector state. This is useful for drivers that
3386 * subclass the connector state.
3387 */
3388void
Daniel Vetterfabd9102016-05-09 16:34:11 +02003389__drm_atomic_helper_connector_destroy_state(struct drm_connector_state *state)
Thierry Redingf5e78402015-01-28 14:54:32 +01003390{
Dave Airlied2307de2016-04-27 11:27:39 +10003391 if (state->crtc)
3392 drm_connector_unreference(state->connector);
Thierry Redingf5e78402015-01-28 14:54:32 +01003393}
3394EXPORT_SYMBOL(__drm_atomic_helper_connector_destroy_state);
3395
3396/**
Daniel Vetterd4617012014-11-03 15:56:43 +01003397 * drm_atomic_helper_connector_destroy_state - default state destroy hook
3398 * @connector: drm connector
3399 * @state: connector state object to release
3400 *
3401 * Default connector state destroy hook for drivers which don't have their own
3402 * subclassed connector state structure.
3403 */
3404void drm_atomic_helper_connector_destroy_state(struct drm_connector *connector,
3405 struct drm_connector_state *state)
3406{
Daniel Vetterfabd9102016-05-09 16:34:11 +02003407 __drm_atomic_helper_connector_destroy_state(state);
Daniel Vetterd4617012014-11-03 15:56:43 +01003408 kfree(state);
3409}
3410EXPORT_SYMBOL(drm_atomic_helper_connector_destroy_state);
Lionel Landwerlin5488dc12016-02-26 17:05:00 +00003411
3412/**
3413 * drm_atomic_helper_legacy_gamma_set - set the legacy gamma correction table
3414 * @crtc: CRTC object
3415 * @red: red correction table
3416 * @green: green correction table
3417 * @blue: green correction table
Lionel Landwerlin5488dc12016-02-26 17:05:00 +00003418 * @size: size of the tables
3419 *
3420 * Implements support for legacy gamma correction table for drivers
3421 * that support color management through the DEGAMMA_LUT/GAMMA_LUT
3422 * properties.
3423 */
Maarten Lankhorst7ea77282016-06-07 12:49:30 +02003424int drm_atomic_helper_legacy_gamma_set(struct drm_crtc *crtc,
3425 u16 *red, u16 *green, u16 *blue,
3426 uint32_t size)
Lionel Landwerlin5488dc12016-02-26 17:05:00 +00003427{
3428 struct drm_device *dev = crtc->dev;
3429 struct drm_mode_config *config = &dev->mode_config;
3430 struct drm_atomic_state *state;
3431 struct drm_crtc_state *crtc_state;
3432 struct drm_property_blob *blob = NULL;
3433 struct drm_color_lut *blob_data;
3434 int i, ret = 0;
3435
3436 state = drm_atomic_state_alloc(crtc->dev);
3437 if (!state)
Maarten Lankhorst7ea77282016-06-07 12:49:30 +02003438 return -ENOMEM;
Lionel Landwerlin5488dc12016-02-26 17:05:00 +00003439
3440 blob = drm_property_create_blob(dev,
3441 sizeof(struct drm_color_lut) * size,
3442 NULL);
Lionel Landwerlin562c5b42016-03-10 12:04:21 +00003443 if (IS_ERR(blob)) {
3444 ret = PTR_ERR(blob);
Lionel Landwerlinc1f415c2016-03-11 12:17:26 +00003445 blob = NULL;
Lionel Landwerlin5488dc12016-02-26 17:05:00 +00003446 goto fail;
3447 }
3448
3449 /* Prepare GAMMA_LUT with the legacy values. */
3450 blob_data = (struct drm_color_lut *) blob->data;
3451 for (i = 0; i < size; i++) {
3452 blob_data[i].red = red[i];
3453 blob_data[i].green = green[i];
3454 blob_data[i].blue = blue[i];
3455 }
3456
3457 state->acquire_ctx = crtc->dev->mode_config.acquire_ctx;
3458retry:
3459 crtc_state = drm_atomic_get_crtc_state(state, crtc);
3460 if (IS_ERR(crtc_state)) {
3461 ret = PTR_ERR(crtc_state);
3462 goto fail;
3463 }
3464
3465 /* Reset DEGAMMA_LUT and CTM properties. */
3466 ret = drm_atomic_crtc_set_property(crtc, crtc_state,
3467 config->degamma_lut_property, 0);
3468 if (ret)
3469 goto fail;
3470
3471 ret = drm_atomic_crtc_set_property(crtc, crtc_state,
3472 config->ctm_property, 0);
3473 if (ret)
3474 goto fail;
3475
3476 ret = drm_atomic_crtc_set_property(crtc, crtc_state,
3477 config->gamma_lut_property, blob->base.id);
3478 if (ret)
3479 goto fail;
3480
3481 ret = drm_atomic_commit(state);
Lionel Landwerlin5488dc12016-02-26 17:05:00 +00003482fail:
3483 if (ret == -EDEADLK)
3484 goto backoff;
3485
Chris Wilson08536952016-10-14 13:18:18 +01003486 drm_atomic_state_put(state);
Lionel Landwerlin5488dc12016-02-26 17:05:00 +00003487 drm_property_unreference_blob(blob);
Maarten Lankhorst7ea77282016-06-07 12:49:30 +02003488 return ret;
Chris Wilson08536952016-10-14 13:18:18 +01003489
Lionel Landwerlin5488dc12016-02-26 17:05:00 +00003490backoff:
3491 drm_atomic_state_clear(state);
3492 drm_atomic_legacy_backoff(state);
3493
3494 goto retry;
3495}
3496EXPORT_SYMBOL(drm_atomic_helper_legacy_gamma_set);