1 /* 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> 32 #include <drm/drm_atomic_helper.h> 33 #include <drm/drm_writeback.h> 34 #include <linux/dma-fence.h> 35 36 #include "drm_crtc_helper_internal.h" 37 #include "drm_crtc_internal.h" 38 39 /** 40 * DOC: overview 41 * 42 * This helper library provides implementations of check and commit functions on 43 * top of the CRTC modeset helper callbacks and the plane helper callbacks. It 44 * also provides convenience implementations for the atomic state handling 45 * callbacks for drivers which don't need to subclass the drm core structures to 46 * add their own additional internal state. 47 * 48 * This library also provides default implementations for the check callback in 49 * drm_atomic_helper_check() and for the commit callback with 50 * drm_atomic_helper_commit(). But the individual stages and callbacks are 51 * exposed to allow drivers to mix and match and e.g. use the plane helpers only 52 * together with a driver private modeset implementation. 53 * 54 * This library also provides implementations for all the legacy driver 55 * interfaces on top of the atomic interface. See drm_atomic_helper_set_config(), 56 * drm_atomic_helper_disable_plane(), drm_atomic_helper_disable_plane() and the 57 * various functions to implement set_property callbacks. New drivers must not 58 * implement these functions themselves but must use the provided helpers. 59 * 60 * The atomic helper uses the same function table structures as all other 61 * modesetting helpers. See the documentation for &struct drm_crtc_helper_funcs, 62 * struct &drm_encoder_helper_funcs and &struct drm_connector_helper_funcs. It 63 * also shares the &struct drm_plane_helper_funcs function table with the plane 64 * helpers. 65 */ 66 static void 67 drm_atomic_helper_plane_changed(struct drm_atomic_state *state, 68 struct drm_plane_state *old_plane_state, 69 struct drm_plane_state *plane_state, 70 struct drm_plane *plane) 71 { 72 struct drm_crtc_state *crtc_state; 73 74 if (old_plane_state->crtc) { 75 crtc_state = drm_atomic_get_new_crtc_state(state, 76 old_plane_state->crtc); 77 78 if (WARN_ON(!crtc_state)) 79 return; 80 81 crtc_state->planes_changed = true; 82 } 83 84 if (plane_state->crtc) { 85 crtc_state = drm_atomic_get_new_crtc_state(state, plane_state->crtc); 86 87 if (WARN_ON(!crtc_state)) 88 return; 89 90 crtc_state->planes_changed = true; 91 } 92 } 93 94 static int handle_conflicting_encoders(struct drm_atomic_state *state, 95 bool disable_conflicting_encoders) 96 { 97 struct drm_connector_state *new_conn_state; 98 struct drm_connector *connector; 99 struct drm_connector_list_iter conn_iter; 100 struct drm_encoder *encoder; 101 unsigned encoder_mask = 0; 102 int i, ret = 0; 103 104 /* 105 * First loop, find all newly assigned encoders from the connectors 106 * part of the state. If the same encoder is assigned to multiple 107 * connectors bail out. 108 */ 109 for_each_new_connector_in_state(state, connector, new_conn_state, i) { 110 const struct drm_connector_helper_funcs *funcs = connector->helper_private; 111 struct drm_encoder *new_encoder; 112 113 if (!new_conn_state->crtc) 114 continue; 115 116 if (funcs->atomic_best_encoder) 117 new_encoder = funcs->atomic_best_encoder(connector, new_conn_state); 118 else if (funcs->best_encoder) 119 new_encoder = funcs->best_encoder(connector); 120 else 121 new_encoder = drm_atomic_helper_best_encoder(connector); 122 123 if (new_encoder) { 124 if (encoder_mask & drm_encoder_mask(new_encoder)) { 125 DRM_DEBUG_ATOMIC("[ENCODER:%d:%s] on [CONNECTOR:%d:%s] already assigned\n", 126 new_encoder->base.id, new_encoder->name, 127 connector->base.id, connector->name); 128 129 return -EINVAL; 130 } 131 132 encoder_mask |= drm_encoder_mask(new_encoder); 133 } 134 } 135 136 if (!encoder_mask) 137 return 0; 138 139 /* 140 * Second loop, iterate over all connectors not part of the state. 141 * 142 * If a conflicting encoder is found and disable_conflicting_encoders 143 * is not set, an error is returned. Userspace can provide a solution 144 * through the atomic ioctl. 145 * 146 * If the flag is set conflicting connectors are removed from the crtc 147 * and the crtc is disabled if no encoder is left. This preserves 148 * compatibility with the legacy set_config behavior. 149 */ 150 drm_connector_list_iter_begin(state->dev, &conn_iter); 151 drm_for_each_connector_iter(connector, &conn_iter) { 152 struct drm_crtc_state *crtc_state; 153 154 if (drm_atomic_get_new_connector_state(state, connector)) 155 continue; 156 157 encoder = connector->state->best_encoder; 158 if (!encoder || !(encoder_mask & drm_encoder_mask(encoder))) 159 continue; 160 161 if (!disable_conflicting_encoders) { 162 DRM_DEBUG_ATOMIC("[ENCODER:%d:%s] in use on [CRTC:%d:%s] by [CONNECTOR:%d:%s]\n", 163 encoder->base.id, encoder->name, 164 connector->state->crtc->base.id, 165 connector->state->crtc->name, 166 connector->base.id, connector->name); 167 ret = -EINVAL; 168 goto out; 169 } 170 171 new_conn_state = drm_atomic_get_connector_state(state, connector); 172 if (IS_ERR(new_conn_state)) { 173 ret = PTR_ERR(new_conn_state); 174 goto out; 175 } 176 177 DRM_DEBUG_ATOMIC("[ENCODER:%d:%s] in use on [CRTC:%d:%s], disabling [CONNECTOR:%d:%s]\n", 178 encoder->base.id, encoder->name, 179 new_conn_state->crtc->base.id, new_conn_state->crtc->name, 180 connector->base.id, connector->name); 181 182 crtc_state = drm_atomic_get_new_crtc_state(state, new_conn_state->crtc); 183 184 ret = drm_atomic_set_crtc_for_connector(new_conn_state, NULL); 185 if (ret) 186 goto out; 187 188 if (!crtc_state->connector_mask) { 189 ret = drm_atomic_set_mode_prop_for_crtc(crtc_state, 190 NULL); 191 if (ret < 0) 192 goto out; 193 194 crtc_state->active = false; 195 } 196 } 197 out: 198 drm_connector_list_iter_end(&conn_iter); 199 200 return ret; 201 } 202 203 static void 204 set_best_encoder(struct drm_atomic_state *state, 205 struct drm_connector_state *conn_state, 206 struct drm_encoder *encoder) 207 { 208 struct drm_crtc_state *crtc_state; 209 struct drm_crtc *crtc; 210 211 if (conn_state->best_encoder) { 212 /* Unset the encoder_mask in the old crtc state. */ 213 crtc = conn_state->connector->state->crtc; 214 215 /* A NULL crtc is an error here because we should have 216 * duplicated a NULL best_encoder when crtc was NULL. 217 * As an exception restoring duplicated atomic state 218 * during resume is allowed, so don't warn when 219 * best_encoder is equal to encoder we intend to set. 220 */ 221 WARN_ON(!crtc && encoder != conn_state->best_encoder); 222 if (crtc) { 223 crtc_state = drm_atomic_get_new_crtc_state(state, crtc); 224 225 crtc_state->encoder_mask &= 226 ~drm_encoder_mask(conn_state->best_encoder); 227 } 228 } 229 230 if (encoder) { 231 crtc = conn_state->crtc; 232 WARN_ON(!crtc); 233 if (crtc) { 234 crtc_state = drm_atomic_get_new_crtc_state(state, crtc); 235 236 crtc_state->encoder_mask |= 237 drm_encoder_mask(encoder); 238 } 239 } 240 241 conn_state->best_encoder = encoder; 242 } 243 244 static void 245 steal_encoder(struct drm_atomic_state *state, 246 struct drm_encoder *encoder) 247 { 248 struct drm_crtc_state *crtc_state; 249 struct drm_connector *connector; 250 struct drm_connector_state *old_connector_state, *new_connector_state; 251 int i; 252 253 for_each_oldnew_connector_in_state(state, connector, old_connector_state, new_connector_state, i) { 254 struct drm_crtc *encoder_crtc; 255 256 if (new_connector_state->best_encoder != encoder) 257 continue; 258 259 encoder_crtc = old_connector_state->crtc; 260 261 DRM_DEBUG_ATOMIC("[ENCODER:%d:%s] in use on [CRTC:%d:%s], stealing it\n", 262 encoder->base.id, encoder->name, 263 encoder_crtc->base.id, encoder_crtc->name); 264 265 set_best_encoder(state, new_connector_state, NULL); 266 267 crtc_state = drm_atomic_get_new_crtc_state(state, encoder_crtc); 268 crtc_state->connectors_changed = true; 269 270 return; 271 } 272 } 273 274 static int 275 update_connector_routing(struct drm_atomic_state *state, 276 struct drm_connector *connector, 277 struct drm_connector_state *old_connector_state, 278 struct drm_connector_state *new_connector_state) 279 { 280 const struct drm_connector_helper_funcs *funcs; 281 struct drm_encoder *new_encoder; 282 struct drm_crtc_state *crtc_state; 283 284 DRM_DEBUG_ATOMIC("Updating routing for [CONNECTOR:%d:%s]\n", 285 connector->base.id, 286 connector->name); 287 288 if (old_connector_state->crtc != new_connector_state->crtc) { 289 if (old_connector_state->crtc) { 290 crtc_state = drm_atomic_get_new_crtc_state(state, old_connector_state->crtc); 291 crtc_state->connectors_changed = true; 292 } 293 294 if (new_connector_state->crtc) { 295 crtc_state = drm_atomic_get_new_crtc_state(state, new_connector_state->crtc); 296 crtc_state->connectors_changed = true; 297 } 298 } 299 300 if (!new_connector_state->crtc) { 301 DRM_DEBUG_ATOMIC("Disabling [CONNECTOR:%d:%s]\n", 302 connector->base.id, 303 connector->name); 304 305 set_best_encoder(state, new_connector_state, NULL); 306 307 return 0; 308 } 309 310 funcs = connector->helper_private; 311 312 if (funcs->atomic_best_encoder) 313 new_encoder = funcs->atomic_best_encoder(connector, 314 new_connector_state); 315 else if (funcs->best_encoder) 316 new_encoder = funcs->best_encoder(connector); 317 else 318 new_encoder = drm_atomic_helper_best_encoder(connector); 319 320 if (!new_encoder) { 321 DRM_DEBUG_ATOMIC("No suitable encoder found for [CONNECTOR:%d:%s]\n", 322 connector->base.id, 323 connector->name); 324 return -EINVAL; 325 } 326 327 if (!drm_encoder_crtc_ok(new_encoder, new_connector_state->crtc)) { 328 DRM_DEBUG_ATOMIC("[ENCODER:%d:%s] incompatible with [CRTC:%d:%s]\n", 329 new_encoder->base.id, 330 new_encoder->name, 331 new_connector_state->crtc->base.id, 332 new_connector_state->crtc->name); 333 return -EINVAL; 334 } 335 336 if (new_encoder == new_connector_state->best_encoder) { 337 set_best_encoder(state, new_connector_state, new_encoder); 338 339 DRM_DEBUG_ATOMIC("[CONNECTOR:%d:%s] keeps [ENCODER:%d:%s], now on [CRTC:%d:%s]\n", 340 connector->base.id, 341 connector->name, 342 new_encoder->base.id, 343 new_encoder->name, 344 new_connector_state->crtc->base.id, 345 new_connector_state->crtc->name); 346 347 return 0; 348 } 349 350 steal_encoder(state, new_encoder); 351 352 set_best_encoder(state, new_connector_state, new_encoder); 353 354 crtc_state = drm_atomic_get_new_crtc_state(state, new_connector_state->crtc); 355 crtc_state->connectors_changed = true; 356 357 DRM_DEBUG_ATOMIC("[CONNECTOR:%d:%s] using [ENCODER:%d:%s] on [CRTC:%d:%s]\n", 358 connector->base.id, 359 connector->name, 360 new_encoder->base.id, 361 new_encoder->name, 362 new_connector_state->crtc->base.id, 363 new_connector_state->crtc->name); 364 365 return 0; 366 } 367 368 static int 369 mode_fixup(struct drm_atomic_state *state) 370 { 371 struct drm_crtc *crtc; 372 struct drm_crtc_state *new_crtc_state; 373 struct drm_connector *connector; 374 struct drm_connector_state *new_conn_state; 375 int i; 376 int ret; 377 378 for_each_new_crtc_in_state(state, crtc, new_crtc_state, i) { 379 if (!new_crtc_state->mode_changed && 380 !new_crtc_state->connectors_changed) 381 continue; 382 383 drm_mode_copy(&new_crtc_state->adjusted_mode, &new_crtc_state->mode); 384 } 385 386 for_each_new_connector_in_state(state, connector, new_conn_state, i) { 387 const struct drm_encoder_helper_funcs *funcs; 388 struct drm_encoder *encoder; 389 390 WARN_ON(!!new_conn_state->best_encoder != !!new_conn_state->crtc); 391 392 if (!new_conn_state->crtc || !new_conn_state->best_encoder) 393 continue; 394 395 new_crtc_state = 396 drm_atomic_get_new_crtc_state(state, new_conn_state->crtc); 397 398 /* 399 * Each encoder has at most one connector (since we always steal 400 * it away), so we won't call ->mode_fixup twice. 401 */ 402 encoder = new_conn_state->best_encoder; 403 funcs = encoder->helper_private; 404 405 ret = drm_bridge_mode_fixup(encoder->bridge, &new_crtc_state->mode, 406 &new_crtc_state->adjusted_mode); 407 if (!ret) { 408 DRM_DEBUG_ATOMIC("Bridge fixup failed\n"); 409 return -EINVAL; 410 } 411 412 if (funcs && funcs->atomic_check) { 413 ret = funcs->atomic_check(encoder, new_crtc_state, 414 new_conn_state); 415 if (ret) { 416 DRM_DEBUG_ATOMIC("[ENCODER:%d:%s] check failed\n", 417 encoder->base.id, encoder->name); 418 return ret; 419 } 420 } else if (funcs && funcs->mode_fixup) { 421 ret = funcs->mode_fixup(encoder, &new_crtc_state->mode, 422 &new_crtc_state->adjusted_mode); 423 if (!ret) { 424 DRM_DEBUG_ATOMIC("[ENCODER:%d:%s] fixup failed\n", 425 encoder->base.id, encoder->name); 426 return -EINVAL; 427 } 428 } 429 } 430 431 for_each_new_crtc_in_state(state, crtc, new_crtc_state, i) { 432 const struct drm_crtc_helper_funcs *funcs; 433 434 if (!new_crtc_state->enable) 435 continue; 436 437 if (!new_crtc_state->mode_changed && 438 !new_crtc_state->connectors_changed) 439 continue; 440 441 funcs = crtc->helper_private; 442 if (!funcs->mode_fixup) 443 continue; 444 445 ret = funcs->mode_fixup(crtc, &new_crtc_state->mode, 446 &new_crtc_state->adjusted_mode); 447 if (!ret) { 448 DRM_DEBUG_ATOMIC("[CRTC:%d:%s] fixup failed\n", 449 crtc->base.id, crtc->name); 450 return -EINVAL; 451 } 452 } 453 454 return 0; 455 } 456 457 static enum drm_mode_status mode_valid_path(struct drm_connector *connector, 458 struct drm_encoder *encoder, 459 struct drm_crtc *crtc, 460 struct drm_display_mode *mode) 461 { 462 enum drm_mode_status ret; 463 464 ret = drm_encoder_mode_valid(encoder, mode); 465 if (ret != MODE_OK) { 466 DRM_DEBUG_ATOMIC("[ENCODER:%d:%s] mode_valid() failed\n", 467 encoder->base.id, encoder->name); 468 return ret; 469 } 470 471 ret = drm_bridge_mode_valid(encoder->bridge, mode); 472 if (ret != MODE_OK) { 473 DRM_DEBUG_ATOMIC("[BRIDGE] mode_valid() failed\n"); 474 return ret; 475 } 476 477 ret = drm_crtc_mode_valid(crtc, mode); 478 if (ret != MODE_OK) { 479 DRM_DEBUG_ATOMIC("[CRTC:%d:%s] mode_valid() failed\n", 480 crtc->base.id, crtc->name); 481 return ret; 482 } 483 484 return ret; 485 } 486 487 static int 488 mode_valid(struct drm_atomic_state *state) 489 { 490 struct drm_connector_state *conn_state; 491 struct drm_connector *connector; 492 int i; 493 494 for_each_new_connector_in_state(state, connector, conn_state, i) { 495 struct drm_encoder *encoder = conn_state->best_encoder; 496 struct drm_crtc *crtc = conn_state->crtc; 497 struct drm_crtc_state *crtc_state; 498 enum drm_mode_status mode_status; 499 struct drm_display_mode *mode; 500 501 if (!crtc || !encoder) 502 continue; 503 504 crtc_state = drm_atomic_get_new_crtc_state(state, crtc); 505 if (!crtc_state) 506 continue; 507 if (!crtc_state->mode_changed && !crtc_state->connectors_changed) 508 continue; 509 510 mode = &crtc_state->mode; 511 512 mode_status = mode_valid_path(connector, encoder, crtc, mode); 513 if (mode_status != MODE_OK) 514 return -EINVAL; 515 } 516 517 return 0; 518 } 519 520 /** 521 * drm_atomic_helper_check_modeset - validate state object for modeset changes 522 * @dev: DRM device 523 * @state: the driver state object 524 * 525 * Check the state object to see if the requested state is physically possible. 526 * This does all the crtc and connector related computations for an atomic 527 * update and adds any additional connectors needed for full modesets. It calls 528 * the various per-object callbacks in the follow order: 529 * 530 * 1. &drm_connector_helper_funcs.atomic_best_encoder for determining the new encoder. 531 * 2. &drm_connector_helper_funcs.atomic_check to validate the connector state. 532 * 3. If it's determined a modeset is needed then all connectors on the affected crtc 533 * crtc are added and &drm_connector_helper_funcs.atomic_check is run on them. 534 * 4. &drm_encoder_helper_funcs.mode_valid, &drm_bridge_funcs.mode_valid and 535 * &drm_crtc_helper_funcs.mode_valid are called on the affected components. 536 * 5. &drm_bridge_funcs.mode_fixup is called on all encoder bridges. 537 * 6. &drm_encoder_helper_funcs.atomic_check is called to validate any encoder state. 538 * This function is only called when the encoder will be part of a configured crtc, 539 * it must not be used for implementing connector property validation. 540 * If this function is NULL, &drm_atomic_encoder_helper_funcs.mode_fixup is called 541 * instead. 542 * 7. &drm_crtc_helper_funcs.mode_fixup is called last, to fix up the mode with crtc constraints. 543 * 544 * &drm_crtc_state.mode_changed is set when the input mode is changed. 545 * &drm_crtc_state.connectors_changed is set when a connector is added or 546 * removed from the crtc. &drm_crtc_state.active_changed is set when 547 * &drm_crtc_state.active changes, which is used for DPMS. 548 * See also: drm_atomic_crtc_needs_modeset() 549 * 550 * IMPORTANT: 551 * 552 * Drivers which set &drm_crtc_state.mode_changed (e.g. in their 553 * &drm_plane_helper_funcs.atomic_check hooks if a plane update can't be done 554 * without a full modeset) _must_ call this function afterwards after that 555 * change. It is permitted to call this function multiple times for the same 556 * update, e.g. when the &drm_crtc_helper_funcs.atomic_check functions depend 557 * upon the adjusted dotclock for fifo space allocation and watermark 558 * computation. 559 * 560 * RETURNS: 561 * Zero for success or -errno 562 */ 563 int 564 drm_atomic_helper_check_modeset(struct drm_device *dev, 565 struct drm_atomic_state *state) 566 { 567 struct drm_crtc *crtc; 568 struct drm_crtc_state *old_crtc_state, *new_crtc_state; 569 struct drm_connector *connector; 570 struct drm_connector_state *old_connector_state, *new_connector_state; 571 int i, ret; 572 unsigned connectors_mask = 0; 573 574 for_each_oldnew_crtc_in_state(state, crtc, old_crtc_state, new_crtc_state, i) { 575 bool has_connectors = 576 !!new_crtc_state->connector_mask; 577 578 WARN_ON(!drm_modeset_is_locked(&crtc->mutex)); 579 580 if (!drm_mode_equal(&old_crtc_state->mode, &new_crtc_state->mode)) { 581 DRM_DEBUG_ATOMIC("[CRTC:%d:%s] mode changed\n", 582 crtc->base.id, crtc->name); 583 new_crtc_state->mode_changed = true; 584 } 585 586 if (old_crtc_state->enable != new_crtc_state->enable) { 587 DRM_DEBUG_ATOMIC("[CRTC:%d:%s] enable changed\n", 588 crtc->base.id, crtc->name); 589 590 /* 591 * For clarity this assignment is done here, but 592 * enable == 0 is only true when there are no 593 * connectors and a NULL mode. 594 * 595 * The other way around is true as well. enable != 0 596 * iff connectors are attached and a mode is set. 597 */ 598 new_crtc_state->mode_changed = true; 599 new_crtc_state->connectors_changed = true; 600 } 601 602 if (old_crtc_state->active != new_crtc_state->active) { 603 DRM_DEBUG_ATOMIC("[CRTC:%d:%s] active changed\n", 604 crtc->base.id, crtc->name); 605 new_crtc_state->active_changed = true; 606 } 607 608 if (new_crtc_state->enable != has_connectors) { 609 DRM_DEBUG_ATOMIC("[CRTC:%d:%s] enabled/connectors mismatch\n", 610 crtc->base.id, crtc->name); 611 612 return -EINVAL; 613 } 614 } 615 616 ret = handle_conflicting_encoders(state, false); 617 if (ret) 618 return ret; 619 620 for_each_oldnew_connector_in_state(state, connector, old_connector_state, new_connector_state, i) { 621 const struct drm_connector_helper_funcs *funcs = connector->helper_private; 622 623 WARN_ON(!drm_modeset_is_locked(&dev->mode_config.connection_mutex)); 624 625 /* 626 * This only sets crtc->connectors_changed for routing changes, 627 * drivers must set crtc->connectors_changed themselves when 628 * connector properties need to be updated. 629 */ 630 ret = update_connector_routing(state, connector, 631 old_connector_state, 632 new_connector_state); 633 if (ret) 634 return ret; 635 if (old_connector_state->crtc) { 636 new_crtc_state = drm_atomic_get_new_crtc_state(state, 637 old_connector_state->crtc); 638 if (old_connector_state->link_status != 639 new_connector_state->link_status) 640 new_crtc_state->connectors_changed = true; 641 } 642 643 if (funcs->atomic_check) 644 ret = funcs->atomic_check(connector, new_connector_state); 645 if (ret) 646 return ret; 647 648 connectors_mask |= BIT(i); 649 } 650 651 /* 652 * After all the routing has been prepared we need to add in any 653 * connector which is itself unchanged, but who's crtc changes it's 654 * configuration. This must be done before calling mode_fixup in case a 655 * crtc only changed its mode but has the same set of connectors. 656 */ 657 for_each_oldnew_crtc_in_state(state, crtc, old_crtc_state, new_crtc_state, i) { 658 if (!drm_atomic_crtc_needs_modeset(new_crtc_state)) 659 continue; 660 661 DRM_DEBUG_ATOMIC("[CRTC:%d:%s] needs all connectors, enable: %c, active: %c\n", 662 crtc->base.id, crtc->name, 663 new_crtc_state->enable ? 'y' : 'n', 664 new_crtc_state->active ? 'y' : 'n'); 665 666 ret = drm_atomic_add_affected_connectors(state, crtc); 667 if (ret != 0) 668 return ret; 669 670 ret = drm_atomic_add_affected_planes(state, crtc); 671 if (ret != 0) 672 return ret; 673 } 674 675 /* 676 * Iterate over all connectors again, to make sure atomic_check() 677 * has been called on them when a modeset is forced. 678 */ 679 for_each_oldnew_connector_in_state(state, connector, old_connector_state, new_connector_state, i) { 680 const struct drm_connector_helper_funcs *funcs = connector->helper_private; 681 682 if (connectors_mask & BIT(i)) 683 continue; 684 685 if (funcs->atomic_check) 686 ret = funcs->atomic_check(connector, new_connector_state); 687 if (ret) 688 return ret; 689 } 690 691 ret = mode_valid(state); 692 if (ret) 693 return ret; 694 695 return mode_fixup(state); 696 } 697 EXPORT_SYMBOL(drm_atomic_helper_check_modeset); 698 699 /** 700 * drm_atomic_helper_check_plane_state() - Check plane state for validity 701 * @plane_state: plane state to check 702 * @crtc_state: crtc state to check 703 * @min_scale: minimum @src:@dest scaling factor in 16.16 fixed point 704 * @max_scale: maximum @src:@dest scaling factor in 16.16 fixed point 705 * @can_position: is it legal to position the plane such that it 706 * doesn't cover the entire crtc? This will generally 707 * only be false for primary planes. 708 * @can_update_disabled: can the plane be updated while the crtc 709 * is disabled? 710 * 711 * Checks that a desired plane update is valid, and updates various 712 * bits of derived state (clipped coordinates etc.). Drivers that provide 713 * their own plane handling rather than helper-provided implementations may 714 * still wish to call this function to avoid duplication of error checking 715 * code. 716 * 717 * RETURNS: 718 * Zero if update appears valid, error code on failure 719 */ 720 int drm_atomic_helper_check_plane_state(struct drm_plane_state *plane_state, 721 const struct drm_crtc_state *crtc_state, 722 int min_scale, 723 int max_scale, 724 bool can_position, 725 bool can_update_disabled) 726 { 727 struct drm_framebuffer *fb = plane_state->fb; 728 struct drm_rect *src = &plane_state->src; 729 struct drm_rect *dst = &plane_state->dst; 730 unsigned int rotation = plane_state->rotation; 731 struct drm_rect clip = {}; 732 int hscale, vscale; 733 734 WARN_ON(plane_state->crtc && plane_state->crtc != crtc_state->crtc); 735 736 *src = drm_plane_state_src(plane_state); 737 *dst = drm_plane_state_dest(plane_state); 738 739 if (!fb) { 740 plane_state->visible = false; 741 return 0; 742 } 743 744 /* crtc should only be NULL when disabling (i.e., !fb) */ 745 if (WARN_ON(!plane_state->crtc)) { 746 plane_state->visible = false; 747 return 0; 748 } 749 750 if (!crtc_state->enable && !can_update_disabled) { 751 DRM_DEBUG_KMS("Cannot update plane of a disabled CRTC.\n"); 752 return -EINVAL; 753 } 754 755 drm_rect_rotate(src, fb->width << 16, fb->height << 16, rotation); 756 757 /* Check scaling */ 758 hscale = drm_rect_calc_hscale(src, dst, min_scale, max_scale); 759 vscale = drm_rect_calc_vscale(src, dst, min_scale, max_scale); 760 if (hscale < 0 || vscale < 0) { 761 DRM_DEBUG_KMS("Invalid scaling of plane\n"); 762 drm_rect_debug_print("src: ", &plane_state->src, true); 763 drm_rect_debug_print("dst: ", &plane_state->dst, false); 764 return -ERANGE; 765 } 766 767 if (crtc_state->enable) 768 drm_mode_get_hv_timing(&crtc_state->mode, &clip.x2, &clip.y2); 769 770 plane_state->visible = drm_rect_clip_scaled(src, dst, &clip); 771 772 drm_rect_rotate_inv(src, fb->width << 16, fb->height << 16, rotation); 773 774 if (!plane_state->visible) 775 /* 776 * Plane isn't visible; some drivers can handle this 777 * so we just return success here. Drivers that can't 778 * (including those that use the primary plane helper's 779 * update function) will return an error from their 780 * update_plane handler. 781 */ 782 return 0; 783 784 if (!can_position && !drm_rect_equals(dst, &clip)) { 785 DRM_DEBUG_KMS("Plane must cover entire CRTC\n"); 786 drm_rect_debug_print("dst: ", dst, false); 787 drm_rect_debug_print("clip: ", &clip, false); 788 return -EINVAL; 789 } 790 791 return 0; 792 } 793 EXPORT_SYMBOL(drm_atomic_helper_check_plane_state); 794 795 /** 796 * drm_atomic_helper_check_planes - validate state object for planes changes 797 * @dev: DRM device 798 * @state: the driver state object 799 * 800 * Check the state object to see if the requested state is physically possible. 801 * This does all the plane update related checks using by calling into the 802 * &drm_crtc_helper_funcs.atomic_check and &drm_plane_helper_funcs.atomic_check 803 * hooks provided by the driver. 804 * 805 * It also sets &drm_crtc_state.planes_changed to indicate that a crtc has 806 * updated planes. 807 * 808 * RETURNS: 809 * Zero for success or -errno 810 */ 811 int 812 drm_atomic_helper_check_planes(struct drm_device *dev, 813 struct drm_atomic_state *state) 814 { 815 struct drm_crtc *crtc; 816 struct drm_crtc_state *new_crtc_state; 817 struct drm_plane *plane; 818 struct drm_plane_state *new_plane_state, *old_plane_state; 819 int i, ret = 0; 820 821 for_each_oldnew_plane_in_state(state, plane, old_plane_state, new_plane_state, i) { 822 const struct drm_plane_helper_funcs *funcs; 823 824 WARN_ON(!drm_modeset_is_locked(&plane->mutex)); 825 826 funcs = plane->helper_private; 827 828 drm_atomic_helper_plane_changed(state, old_plane_state, new_plane_state, plane); 829 830 if (!funcs || !funcs->atomic_check) 831 continue; 832 833 ret = funcs->atomic_check(plane, new_plane_state); 834 if (ret) { 835 DRM_DEBUG_ATOMIC("[PLANE:%d:%s] atomic driver check failed\n", 836 plane->base.id, plane->name); 837 return ret; 838 } 839 } 840 841 for_each_new_crtc_in_state(state, crtc, new_crtc_state, i) { 842 const struct drm_crtc_helper_funcs *funcs; 843 844 funcs = crtc->helper_private; 845 846 if (!funcs || !funcs->atomic_check) 847 continue; 848 849 ret = funcs->atomic_check(crtc, new_crtc_state); 850 if (ret) { 851 DRM_DEBUG_ATOMIC("[CRTC:%d:%s] atomic driver check failed\n", 852 crtc->base.id, crtc->name); 853 return ret; 854 } 855 } 856 857 return ret; 858 } 859 EXPORT_SYMBOL(drm_atomic_helper_check_planes); 860 861 /** 862 * drm_atomic_helper_check - validate state object 863 * @dev: DRM device 864 * @state: the driver state object 865 * 866 * Check the state object to see if the requested state is physically possible. 867 * Only crtcs and planes have check callbacks, so for any additional (global) 868 * checking that a driver needs it can simply wrap that around this function. 869 * Drivers without such needs can directly use this as their 870 * &drm_mode_config_funcs.atomic_check callback. 871 * 872 * This just wraps the two parts of the state checking for planes and modeset 873 * state in the default order: First it calls drm_atomic_helper_check_modeset() 874 * and then drm_atomic_helper_check_planes(). The assumption is that the 875 * @drm_plane_helper_funcs.atomic_check and @drm_crtc_helper_funcs.atomic_check 876 * functions depend upon an updated adjusted_mode.clock to e.g. properly compute 877 * watermarks. 878 * 879 * Note that zpos normalization will add all enable planes to the state which 880 * might not desired for some drivers. 881 * For example enable/disable of a cursor plane which have fixed zpos value 882 * would trigger all other enabled planes to be forced to the state change. 883 * 884 * RETURNS: 885 * Zero for success or -errno 886 */ 887 int drm_atomic_helper_check(struct drm_device *dev, 888 struct drm_atomic_state *state) 889 { 890 int ret; 891 892 ret = drm_atomic_helper_check_modeset(dev, state); 893 if (ret) 894 return ret; 895 896 if (dev->mode_config.normalize_zpos) { 897 ret = drm_atomic_normalize_zpos(dev, state); 898 if (ret) 899 return ret; 900 } 901 902 ret = drm_atomic_helper_check_planes(dev, state); 903 if (ret) 904 return ret; 905 906 if (state->legacy_cursor_update) 907 state->async_update = !drm_atomic_helper_async_check(dev, state); 908 909 return ret; 910 } 911 EXPORT_SYMBOL(drm_atomic_helper_check); 912 913 static void 914 disable_outputs(struct drm_device *dev, struct drm_atomic_state *old_state) 915 { 916 struct drm_connector *connector; 917 struct drm_connector_state *old_conn_state, *new_conn_state; 918 struct drm_crtc *crtc; 919 struct drm_crtc_state *old_crtc_state, *new_crtc_state; 920 int i; 921 922 for_each_oldnew_connector_in_state(old_state, connector, old_conn_state, new_conn_state, i) { 923 const struct drm_encoder_helper_funcs *funcs; 924 struct drm_encoder *encoder; 925 926 /* Shut down everything that's in the changeset and currently 927 * still on. So need to check the old, saved state. */ 928 if (!old_conn_state->crtc) 929 continue; 930 931 old_crtc_state = drm_atomic_get_old_crtc_state(old_state, old_conn_state->crtc); 932 933 if (!old_crtc_state->active || 934 !drm_atomic_crtc_needs_modeset(old_conn_state->crtc->state)) 935 continue; 936 937 encoder = old_conn_state->best_encoder; 938 939 /* We shouldn't get this far if we didn't previously have 940 * an encoder.. but WARN_ON() rather than explode. 941 */ 942 if (WARN_ON(!encoder)) 943 continue; 944 945 funcs = encoder->helper_private; 946 947 DRM_DEBUG_ATOMIC("disabling [ENCODER:%d:%s]\n", 948 encoder->base.id, encoder->name); 949 950 /* 951 * Each encoder has at most one connector (since we always steal 952 * it away), so we won't call disable hooks twice. 953 */ 954 drm_bridge_disable(encoder->bridge); 955 956 /* Right function depends upon target state. */ 957 if (funcs) { 958 if (new_conn_state->crtc && funcs->prepare) 959 funcs->prepare(encoder); 960 else if (funcs->disable) 961 funcs->disable(encoder); 962 else if (funcs->dpms) 963 funcs->dpms(encoder, DRM_MODE_DPMS_OFF); 964 } 965 966 drm_bridge_post_disable(encoder->bridge); 967 } 968 969 for_each_oldnew_crtc_in_state(old_state, crtc, old_crtc_state, new_crtc_state, i) { 970 const struct drm_crtc_helper_funcs *funcs; 971 int ret; 972 973 /* Shut down everything that needs a full modeset. */ 974 if (!drm_atomic_crtc_needs_modeset(new_crtc_state)) 975 continue; 976 977 if (!old_crtc_state->active) 978 continue; 979 980 funcs = crtc->helper_private; 981 982 DRM_DEBUG_ATOMIC("disabling [CRTC:%d:%s]\n", 983 crtc->base.id, crtc->name); 984 985 986 /* Right function depends upon target state. */ 987 if (new_crtc_state->enable && funcs->prepare) 988 funcs->prepare(crtc); 989 else if (funcs->atomic_disable) 990 funcs->atomic_disable(crtc, old_crtc_state); 991 else if (funcs->disable) 992 funcs->disable(crtc); 993 else 994 funcs->dpms(crtc, DRM_MODE_DPMS_OFF); 995 996 if (!(dev->irq_enabled && dev->num_crtcs)) 997 continue; 998 999 ret = drm_crtc_vblank_get(crtc); 1000 WARN_ONCE(ret != -EINVAL, "driver forgot to call drm_crtc_vblank_off()\n"); 1001 if (ret == 0) 1002 drm_crtc_vblank_put(crtc); 1003 } 1004 } 1005 1006 /** 1007 * drm_atomic_helper_update_legacy_modeset_state - update legacy modeset state 1008 * @dev: DRM device 1009 * @old_state: atomic state object with old state structures 1010 * 1011 * This function updates all the various legacy modeset state pointers in 1012 * connectors, encoders and crtcs. It also updates the timestamping constants 1013 * used for precise vblank timestamps by calling 1014 * drm_calc_timestamping_constants(). 1015 * 1016 * Drivers can use this for building their own atomic commit if they don't have 1017 * a pure helper-based modeset implementation. 1018 * 1019 * Since these updates are not synchronized with lockings, only code paths 1020 * called from &drm_mode_config_helper_funcs.atomic_commit_tail can look at the 1021 * legacy state filled out by this helper. Defacto this means this helper and 1022 * the legacy state pointers are only really useful for transitioning an 1023 * existing driver to the atomic world. 1024 */ 1025 void 1026 drm_atomic_helper_update_legacy_modeset_state(struct drm_device *dev, 1027 struct drm_atomic_state *old_state) 1028 { 1029 struct drm_connector *connector; 1030 struct drm_connector_state *old_conn_state, *new_conn_state; 1031 struct drm_crtc *crtc; 1032 struct drm_crtc_state *new_crtc_state; 1033 int i; 1034 1035 /* clear out existing links and update dpms */ 1036 for_each_oldnew_connector_in_state(old_state, connector, old_conn_state, new_conn_state, i) { 1037 if (connector->encoder) { 1038 WARN_ON(!connector->encoder->crtc); 1039 1040 connector->encoder->crtc = NULL; 1041 connector->encoder = NULL; 1042 } 1043 1044 crtc = new_conn_state->crtc; 1045 if ((!crtc && old_conn_state->crtc) || 1046 (crtc && drm_atomic_crtc_needs_modeset(crtc->state))) { 1047 int mode = DRM_MODE_DPMS_OFF; 1048 1049 if (crtc && crtc->state->active) 1050 mode = DRM_MODE_DPMS_ON; 1051 1052 connector->dpms = mode; 1053 } 1054 } 1055 1056 /* set new links */ 1057 for_each_new_connector_in_state(old_state, connector, new_conn_state, i) { 1058 if (!new_conn_state->crtc) 1059 continue; 1060 1061 if (WARN_ON(!new_conn_state->best_encoder)) 1062 continue; 1063 1064 connector->encoder = new_conn_state->best_encoder; 1065 connector->encoder->crtc = new_conn_state->crtc; 1066 } 1067 1068 /* set legacy state in the crtc structure */ 1069 for_each_new_crtc_in_state(old_state, crtc, new_crtc_state, i) { 1070 struct drm_plane *primary = crtc->primary; 1071 struct drm_plane_state *new_plane_state; 1072 1073 crtc->mode = new_crtc_state->mode; 1074 crtc->enabled = new_crtc_state->enable; 1075 1076 new_plane_state = 1077 drm_atomic_get_new_plane_state(old_state, primary); 1078 1079 if (new_plane_state && new_plane_state->crtc == crtc) { 1080 crtc->x = new_plane_state->src_x >> 16; 1081 crtc->y = new_plane_state->src_y >> 16; 1082 } 1083 1084 if (new_crtc_state->enable) 1085 drm_calc_timestamping_constants(crtc, 1086 &new_crtc_state->adjusted_mode); 1087 } 1088 } 1089 EXPORT_SYMBOL(drm_atomic_helper_update_legacy_modeset_state); 1090 1091 static void 1092 crtc_set_mode(struct drm_device *dev, struct drm_atomic_state *old_state) 1093 { 1094 struct drm_crtc *crtc; 1095 struct drm_crtc_state *new_crtc_state; 1096 struct drm_connector *connector; 1097 struct drm_connector_state *new_conn_state; 1098 int i; 1099 1100 for_each_new_crtc_in_state(old_state, crtc, new_crtc_state, i) { 1101 const struct drm_crtc_helper_funcs *funcs; 1102 1103 if (!new_crtc_state->mode_changed) 1104 continue; 1105 1106 funcs = crtc->helper_private; 1107 1108 if (new_crtc_state->enable && funcs->mode_set_nofb) { 1109 DRM_DEBUG_ATOMIC("modeset on [CRTC:%d:%s]\n", 1110 crtc->base.id, crtc->name); 1111 1112 funcs->mode_set_nofb(crtc); 1113 } 1114 } 1115 1116 for_each_new_connector_in_state(old_state, connector, new_conn_state, i) { 1117 const struct drm_encoder_helper_funcs *funcs; 1118 struct drm_encoder *encoder; 1119 struct drm_display_mode *mode, *adjusted_mode; 1120 1121 if (!new_conn_state->best_encoder) 1122 continue; 1123 1124 encoder = new_conn_state->best_encoder; 1125 funcs = encoder->helper_private; 1126 new_crtc_state = new_conn_state->crtc->state; 1127 mode = &new_crtc_state->mode; 1128 adjusted_mode = &new_crtc_state->adjusted_mode; 1129 1130 if (!new_crtc_state->mode_changed) 1131 continue; 1132 1133 DRM_DEBUG_ATOMIC("modeset on [ENCODER:%d:%s]\n", 1134 encoder->base.id, encoder->name); 1135 1136 /* 1137 * Each encoder has at most one connector (since we always steal 1138 * it away), so we won't call mode_set hooks twice. 1139 */ 1140 if (funcs && funcs->atomic_mode_set) { 1141 funcs->atomic_mode_set(encoder, new_crtc_state, 1142 new_conn_state); 1143 } else if (funcs && funcs->mode_set) { 1144 funcs->mode_set(encoder, mode, adjusted_mode); 1145 } 1146 1147 drm_bridge_mode_set(encoder->bridge, mode, adjusted_mode); 1148 } 1149 } 1150 1151 /** 1152 * drm_atomic_helper_commit_modeset_disables - modeset commit to disable outputs 1153 * @dev: DRM device 1154 * @old_state: atomic state object with old state structures 1155 * 1156 * This function shuts down all the outputs that need to be shut down and 1157 * prepares them (if required) with the new mode. 1158 * 1159 * For compatibility with legacy crtc helpers this should be called before 1160 * drm_atomic_helper_commit_planes(), which is what the default commit function 1161 * does. But drivers with different needs can group the modeset commits together 1162 * and do the plane commits at the end. This is useful for drivers doing runtime 1163 * PM since planes updates then only happen when the CRTC is actually enabled. 1164 */ 1165 void drm_atomic_helper_commit_modeset_disables(struct drm_device *dev, 1166 struct drm_atomic_state *old_state) 1167 { 1168 disable_outputs(dev, old_state); 1169 1170 drm_atomic_helper_update_legacy_modeset_state(dev, old_state); 1171 1172 crtc_set_mode(dev, old_state); 1173 } 1174 EXPORT_SYMBOL(drm_atomic_helper_commit_modeset_disables); 1175 1176 static void drm_atomic_helper_commit_writebacks(struct drm_device *dev, 1177 struct drm_atomic_state *old_state) 1178 { 1179 struct drm_connector *connector; 1180 struct drm_connector_state *new_conn_state; 1181 int i; 1182 1183 for_each_new_connector_in_state(old_state, connector, new_conn_state, i) { 1184 const struct drm_connector_helper_funcs *funcs; 1185 1186 funcs = connector->helper_private; 1187 if (!funcs->atomic_commit) 1188 continue; 1189 1190 if (new_conn_state->writeback_job && new_conn_state->writeback_job->fb) { 1191 WARN_ON(connector->connector_type != DRM_MODE_CONNECTOR_WRITEBACK); 1192 funcs->atomic_commit(connector, new_conn_state); 1193 } 1194 } 1195 } 1196 1197 /** 1198 * drm_atomic_helper_commit_modeset_enables - modeset commit to enable outputs 1199 * @dev: DRM device 1200 * @old_state: atomic state object with old state structures 1201 * 1202 * This function enables all the outputs with the new configuration which had to 1203 * be turned off for the update. 1204 * 1205 * For compatibility with legacy crtc helpers this should be called after 1206 * drm_atomic_helper_commit_planes(), which is what the default commit function 1207 * does. But drivers with different needs can group the modeset commits together 1208 * and do the plane commits at the end. This is useful for drivers doing runtime 1209 * PM since planes updates then only happen when the CRTC is actually enabled. 1210 */ 1211 void drm_atomic_helper_commit_modeset_enables(struct drm_device *dev, 1212 struct drm_atomic_state *old_state) 1213 { 1214 struct drm_crtc *crtc; 1215 struct drm_crtc_state *old_crtc_state; 1216 struct drm_crtc_state *new_crtc_state; 1217 struct drm_connector *connector; 1218 struct drm_connector_state *new_conn_state; 1219 int i; 1220 1221 for_each_oldnew_crtc_in_state(old_state, crtc, old_crtc_state, new_crtc_state, i) { 1222 const struct drm_crtc_helper_funcs *funcs; 1223 1224 /* Need to filter out CRTCs where only planes change. */ 1225 if (!drm_atomic_crtc_needs_modeset(new_crtc_state)) 1226 continue; 1227 1228 if (!new_crtc_state->active) 1229 continue; 1230 1231 funcs = crtc->helper_private; 1232 1233 if (new_crtc_state->enable) { 1234 DRM_DEBUG_ATOMIC("enabling [CRTC:%d:%s]\n", 1235 crtc->base.id, crtc->name); 1236 1237 if (funcs->atomic_enable) 1238 funcs->atomic_enable(crtc, old_crtc_state); 1239 else 1240 funcs->commit(crtc); 1241 } 1242 } 1243 1244 for_each_new_connector_in_state(old_state, connector, new_conn_state, i) { 1245 const struct drm_encoder_helper_funcs *funcs; 1246 struct drm_encoder *encoder; 1247 1248 if (!new_conn_state->best_encoder) 1249 continue; 1250 1251 if (!new_conn_state->crtc->state->active || 1252 !drm_atomic_crtc_needs_modeset(new_conn_state->crtc->state)) 1253 continue; 1254 1255 encoder = new_conn_state->best_encoder; 1256 funcs = encoder->helper_private; 1257 1258 DRM_DEBUG_ATOMIC("enabling [ENCODER:%d:%s]\n", 1259 encoder->base.id, encoder->name); 1260 1261 /* 1262 * Each encoder has at most one connector (since we always steal 1263 * it away), so we won't call enable hooks twice. 1264 */ 1265 drm_bridge_pre_enable(encoder->bridge); 1266 1267 if (funcs) { 1268 if (funcs->enable) 1269 funcs->enable(encoder); 1270 else if (funcs->commit) 1271 funcs->commit(encoder); 1272 } 1273 1274 drm_bridge_enable(encoder->bridge); 1275 } 1276 1277 drm_atomic_helper_commit_writebacks(dev, old_state); 1278 } 1279 EXPORT_SYMBOL(drm_atomic_helper_commit_modeset_enables); 1280 1281 /** 1282 * drm_atomic_helper_wait_for_fences - wait for fences stashed in plane state 1283 * @dev: DRM device 1284 * @state: atomic state object with old state structures 1285 * @pre_swap: If true, do an interruptible wait, and @state is the new state. 1286 * Otherwise @state is the old state. 1287 * 1288 * For implicit sync, driver should fish the exclusive fence out from the 1289 * incoming fb's and stash it in the drm_plane_state. This is called after 1290 * drm_atomic_helper_swap_state() so it uses the current plane state (and 1291 * just uses the atomic state to find the changed planes) 1292 * 1293 * Note that @pre_swap is needed since the point where we block for fences moves 1294 * around depending upon whether an atomic commit is blocking or 1295 * non-blocking. For non-blocking commit all waiting needs to happen after 1296 * drm_atomic_helper_swap_state() is called, but for blocking commits we want 1297 * to wait **before** we do anything that can't be easily rolled back. That is 1298 * before we call drm_atomic_helper_swap_state(). 1299 * 1300 * Returns zero if success or < 0 if dma_fence_wait() fails. 1301 */ 1302 int drm_atomic_helper_wait_for_fences(struct drm_device *dev, 1303 struct drm_atomic_state *state, 1304 bool pre_swap) 1305 { 1306 struct drm_plane *plane; 1307 struct drm_plane_state *new_plane_state; 1308 int i, ret; 1309 1310 for_each_new_plane_in_state(state, plane, new_plane_state, i) { 1311 if (!new_plane_state->fence) 1312 continue; 1313 1314 WARN_ON(!new_plane_state->fb); 1315 1316 /* 1317 * If waiting for fences pre-swap (ie: nonblock), userspace can 1318 * still interrupt the operation. Instead of blocking until the 1319 * timer expires, make the wait interruptible. 1320 */ 1321 ret = dma_fence_wait(new_plane_state->fence, pre_swap); 1322 if (ret) 1323 return ret; 1324 1325 dma_fence_put(new_plane_state->fence); 1326 new_plane_state->fence = NULL; 1327 } 1328 1329 return 0; 1330 } 1331 EXPORT_SYMBOL(drm_atomic_helper_wait_for_fences); 1332 1333 /** 1334 * drm_atomic_helper_wait_for_vblanks - wait for vblank on crtcs 1335 * @dev: DRM device 1336 * @old_state: atomic state object with old state structures 1337 * 1338 * Helper to, after atomic commit, wait for vblanks on all effected 1339 * crtcs (ie. before cleaning up old framebuffers using 1340 * drm_atomic_helper_cleanup_planes()). It will only wait on CRTCs where the 1341 * framebuffers have actually changed to optimize for the legacy cursor and 1342 * plane update use-case. 1343 * 1344 * Drivers using the nonblocking commit tracking support initialized by calling 1345 * drm_atomic_helper_setup_commit() should look at 1346 * drm_atomic_helper_wait_for_flip_done() as an alternative. 1347 */ 1348 void 1349 drm_atomic_helper_wait_for_vblanks(struct drm_device *dev, 1350 struct drm_atomic_state *old_state) 1351 { 1352 struct drm_crtc *crtc; 1353 struct drm_crtc_state *old_crtc_state, *new_crtc_state; 1354 int i, ret; 1355 unsigned crtc_mask = 0; 1356 1357 if (cold) { 1358 delay(50000); 1359 return; 1360 } 1361 1362 /* 1363 * Legacy cursor ioctls are completely unsynced, and userspace 1364 * relies on that (by doing tons of cursor updates). 1365 */ 1366 if (old_state->legacy_cursor_update) 1367 return; 1368 1369 for_each_oldnew_crtc_in_state(old_state, crtc, old_crtc_state, new_crtc_state, i) { 1370 if (!new_crtc_state->active) 1371 continue; 1372 1373 ret = drm_crtc_vblank_get(crtc); 1374 if (ret != 0) 1375 continue; 1376 1377 crtc_mask |= drm_crtc_mask(crtc); 1378 old_state->crtcs[i].last_vblank_count = drm_crtc_vblank_count(crtc); 1379 } 1380 1381 for_each_old_crtc_in_state(old_state, crtc, old_crtc_state, i) { 1382 if (!(crtc_mask & drm_crtc_mask(crtc))) 1383 continue; 1384 1385 ret = wait_event_timeout(dev->vblank[i].queue, 1386 old_state->crtcs[i].last_vblank_count != 1387 drm_crtc_vblank_count(crtc), 1388 msecs_to_jiffies(50)); 1389 1390 WARN(!ret, "[CRTC:%d:%s] vblank wait timed out\n", 1391 crtc->base.id, crtc->name); 1392 1393 drm_crtc_vblank_put(crtc); 1394 } 1395 } 1396 EXPORT_SYMBOL(drm_atomic_helper_wait_for_vblanks); 1397 1398 /** 1399 * drm_atomic_helper_wait_for_flip_done - wait for all page flips to be done 1400 * @dev: DRM device 1401 * @old_state: atomic state object with old state structures 1402 * 1403 * Helper to, after atomic commit, wait for page flips on all effected 1404 * crtcs (ie. before cleaning up old framebuffers using 1405 * drm_atomic_helper_cleanup_planes()). Compared to 1406 * drm_atomic_helper_wait_for_vblanks() this waits for the completion of on all 1407 * CRTCs, assuming that cursors-only updates are signalling their completion 1408 * immediately (or using a different path). 1409 * 1410 * This requires that drivers use the nonblocking commit tracking support 1411 * initialized using drm_atomic_helper_setup_commit(). 1412 */ 1413 void drm_atomic_helper_wait_for_flip_done(struct drm_device *dev, 1414 struct drm_atomic_state *old_state) 1415 { 1416 struct drm_crtc *crtc; 1417 int i; 1418 1419 for (i = 0; i < dev->mode_config.num_crtc; i++) { 1420 struct drm_crtc_commit *commit = old_state->crtcs[i].commit; 1421 int ret; 1422 1423 crtc = old_state->crtcs[i].ptr; 1424 1425 if (!crtc || !commit) 1426 continue; 1427 1428 ret = wait_for_completion_timeout(&commit->flip_done, 10 * HZ); 1429 if (ret == 0) 1430 DRM_ERROR("[CRTC:%d:%s] flip_done timed out\n", 1431 crtc->base.id, crtc->name); 1432 } 1433 1434 if (old_state->fake_commit) 1435 complete_all(&old_state->fake_commit->flip_done); 1436 } 1437 EXPORT_SYMBOL(drm_atomic_helper_wait_for_flip_done); 1438 1439 /** 1440 * drm_atomic_helper_commit_tail - commit atomic update to hardware 1441 * @old_state: atomic state object with old state structures 1442 * 1443 * This is the default implementation for the 1444 * &drm_mode_config_helper_funcs.atomic_commit_tail hook, for drivers 1445 * that do not support runtime_pm or do not need the CRTC to be 1446 * enabled to perform a commit. Otherwise, see 1447 * drm_atomic_helper_commit_tail_rpm(). 1448 * 1449 * Note that the default ordering of how the various stages are called is to 1450 * match the legacy modeset helper library closest. 1451 */ 1452 void drm_atomic_helper_commit_tail(struct drm_atomic_state *old_state) 1453 { 1454 struct drm_device *dev = old_state->dev; 1455 1456 drm_atomic_helper_commit_modeset_disables(dev, old_state); 1457 1458 drm_atomic_helper_commit_planes(dev, old_state, 0); 1459 1460 drm_atomic_helper_commit_modeset_enables(dev, old_state); 1461 1462 drm_atomic_helper_fake_vblank(old_state); 1463 1464 drm_atomic_helper_commit_hw_done(old_state); 1465 1466 drm_atomic_helper_wait_for_vblanks(dev, old_state); 1467 1468 drm_atomic_helper_cleanup_planes(dev, old_state); 1469 } 1470 EXPORT_SYMBOL(drm_atomic_helper_commit_tail); 1471 1472 /** 1473 * drm_atomic_helper_commit_tail_rpm - commit atomic update to hardware 1474 * @old_state: new modeset state to be committed 1475 * 1476 * This is an alternative implementation for the 1477 * &drm_mode_config_helper_funcs.atomic_commit_tail hook, for drivers 1478 * that support runtime_pm or need the CRTC to be enabled to perform a 1479 * commit. Otherwise, one should use the default implementation 1480 * drm_atomic_helper_commit_tail(). 1481 */ 1482 void drm_atomic_helper_commit_tail_rpm(struct drm_atomic_state *old_state) 1483 { 1484 struct drm_device *dev = old_state->dev; 1485 1486 drm_atomic_helper_commit_modeset_disables(dev, old_state); 1487 1488 drm_atomic_helper_commit_modeset_enables(dev, old_state); 1489 1490 drm_atomic_helper_commit_planes(dev, old_state, 1491 DRM_PLANE_COMMIT_ACTIVE_ONLY); 1492 1493 drm_atomic_helper_fake_vblank(old_state); 1494 1495 drm_atomic_helper_commit_hw_done(old_state); 1496 1497 drm_atomic_helper_wait_for_vblanks(dev, old_state); 1498 1499 drm_atomic_helper_cleanup_planes(dev, old_state); 1500 } 1501 EXPORT_SYMBOL(drm_atomic_helper_commit_tail_rpm); 1502 1503 static void commit_tail(struct drm_atomic_state *old_state) 1504 { 1505 struct drm_device *dev = old_state->dev; 1506 const struct drm_mode_config_helper_funcs *funcs; 1507 1508 funcs = dev->mode_config.helper_private; 1509 1510 drm_atomic_helper_wait_for_fences(dev, old_state, false); 1511 1512 drm_atomic_helper_wait_for_dependencies(old_state); 1513 1514 if (funcs && funcs->atomic_commit_tail) 1515 funcs->atomic_commit_tail(old_state); 1516 else 1517 drm_atomic_helper_commit_tail(old_state); 1518 1519 drm_atomic_helper_commit_cleanup_done(old_state); 1520 1521 drm_atomic_state_put(old_state); 1522 } 1523 1524 static void commit_work(struct work_struct *work) 1525 { 1526 struct drm_atomic_state *state = container_of(work, 1527 struct drm_atomic_state, 1528 commit_work); 1529 commit_tail(state); 1530 } 1531 1532 /** 1533 * drm_atomic_helper_async_check - check if state can be commited asynchronously 1534 * @dev: DRM device 1535 * @state: the driver state object 1536 * 1537 * This helper will check if it is possible to commit the state asynchronously. 1538 * Async commits are not supposed to swap the states like normal sync commits 1539 * but just do in-place changes on the current state. 1540 * 1541 * It will return 0 if the commit can happen in an asynchronous fashion or error 1542 * if not. Note that error just mean it can't be commited asynchronously, if it 1543 * fails the commit should be treated like a normal synchronous commit. 1544 */ 1545 int drm_atomic_helper_async_check(struct drm_device *dev, 1546 struct drm_atomic_state *state) 1547 { 1548 struct drm_crtc *crtc; 1549 struct drm_crtc_state *crtc_state; 1550 struct drm_plane *plane = NULL; 1551 struct drm_plane_state *old_plane_state = NULL; 1552 struct drm_plane_state *new_plane_state = NULL; 1553 const struct drm_plane_helper_funcs *funcs; 1554 int i, n_planes = 0; 1555 1556 for_each_new_crtc_in_state(state, crtc, crtc_state, i) { 1557 if (drm_atomic_crtc_needs_modeset(crtc_state)) 1558 return -EINVAL; 1559 } 1560 1561 for_each_oldnew_plane_in_state(state, plane, old_plane_state, new_plane_state, i) 1562 n_planes++; 1563 1564 /* FIXME: we support only single plane updates for now */ 1565 if (n_planes != 1) 1566 return -EINVAL; 1567 1568 if (!new_plane_state->crtc || 1569 old_plane_state->crtc != new_plane_state->crtc) 1570 return -EINVAL; 1571 1572 /* 1573 * FIXME: Since prepare_fb and cleanup_fb are always called on 1574 * the new_plane_state for async updates we need to block framebuffer 1575 * changes. This prevents use of a fb that's been cleaned up and 1576 * double cleanups from occuring. 1577 */ 1578 if (old_plane_state->fb != new_plane_state->fb) 1579 return -EINVAL; 1580 1581 /* 1582 * FIXME: Since prepare_fb and cleanup_fb are always called on 1583 * the new_plane_state for async updates we need to block framebuffer 1584 * changes. This prevents use of a fb that's been cleaned up and 1585 * double cleanups from occuring. 1586 */ 1587 if (old_plane_state->fb != new_plane_state->fb) 1588 return -EINVAL; 1589 1590 funcs = plane->helper_private; 1591 if (!funcs->atomic_async_update) 1592 return -EINVAL; 1593 1594 if (new_plane_state->fence) 1595 return -EINVAL; 1596 1597 /* 1598 * Don't do an async update if there is an outstanding commit modifying 1599 * the plane. This prevents our async update's changes from getting 1600 * overridden by a previous synchronous update's state. 1601 */ 1602 if (old_plane_state->commit && 1603 !try_wait_for_completion(&old_plane_state->commit->hw_done)) 1604 return -EBUSY; 1605 1606 return funcs->atomic_async_check(plane, new_plane_state); 1607 } 1608 EXPORT_SYMBOL(drm_atomic_helper_async_check); 1609 1610 /** 1611 * drm_atomic_helper_async_commit - commit state asynchronously 1612 * @dev: DRM device 1613 * @state: the driver state object 1614 * 1615 * This function commits a state asynchronously, i.e., not vblank 1616 * synchronized. It should be used on a state only when 1617 * drm_atomic_async_check() succeeds. Async commits are not supposed to swap 1618 * the states like normal sync commits, but just do in-place changes on the 1619 * current state. 1620 */ 1621 void drm_atomic_helper_async_commit(struct drm_device *dev, 1622 struct drm_atomic_state *state) 1623 { 1624 struct drm_plane *plane; 1625 struct drm_plane_state *plane_state; 1626 const struct drm_plane_helper_funcs *funcs; 1627 int i; 1628 1629 for_each_new_plane_in_state(state, plane, plane_state, i) { 1630 funcs = plane->helper_private; 1631 funcs->atomic_async_update(plane, plane_state); 1632 1633 /* 1634 * ->atomic_async_update() is supposed to update the 1635 * plane->state in-place, make sure at least common 1636 * properties have been properly updated. 1637 */ 1638 WARN_ON_ONCE(plane->state->fb != plane_state->fb); 1639 WARN_ON_ONCE(plane->state->crtc_x != plane_state->crtc_x); 1640 WARN_ON_ONCE(plane->state->crtc_y != plane_state->crtc_y); 1641 WARN_ON_ONCE(plane->state->src_x != plane_state->src_x); 1642 WARN_ON_ONCE(plane->state->src_y != plane_state->src_y); 1643 } 1644 } 1645 EXPORT_SYMBOL(drm_atomic_helper_async_commit); 1646 1647 /** 1648 * drm_atomic_helper_commit - commit validated state object 1649 * @dev: DRM device 1650 * @state: the driver state object 1651 * @nonblock: whether nonblocking behavior is requested. 1652 * 1653 * This function commits a with drm_atomic_helper_check() pre-validated state 1654 * object. This can still fail when e.g. the framebuffer reservation fails. This 1655 * function implements nonblocking commits, using 1656 * drm_atomic_helper_setup_commit() and related functions. 1657 * 1658 * Committing the actual hardware state is done through the 1659 * &drm_mode_config_helper_funcs.atomic_commit_tail callback, or it's default 1660 * implementation drm_atomic_helper_commit_tail(). 1661 * 1662 * RETURNS: 1663 * Zero for success or -errno. 1664 */ 1665 int drm_atomic_helper_commit(struct drm_device *dev, 1666 struct drm_atomic_state *state, 1667 bool nonblock) 1668 { 1669 int ret; 1670 1671 if (state->async_update) { 1672 ret = drm_atomic_helper_prepare_planes(dev, state); 1673 if (ret) 1674 return ret; 1675 1676 drm_atomic_helper_async_commit(dev, state); 1677 drm_atomic_helper_cleanup_planes(dev, state); 1678 1679 return 0; 1680 } 1681 1682 ret = drm_atomic_helper_setup_commit(state, nonblock); 1683 if (ret) 1684 return ret; 1685 1686 INIT_WORK(&state->commit_work, commit_work); 1687 1688 ret = drm_atomic_helper_prepare_planes(dev, state); 1689 if (ret) 1690 return ret; 1691 1692 if (!nonblock) { 1693 ret = drm_atomic_helper_wait_for_fences(dev, state, true); 1694 if (ret) 1695 goto err; 1696 } 1697 1698 /* 1699 * This is the point of no return - everything below never fails except 1700 * when the hw goes bonghits. Which means we can commit the new state on 1701 * the software side now. 1702 */ 1703 1704 ret = drm_atomic_helper_swap_state(state, true); 1705 if (ret) 1706 goto err; 1707 1708 /* 1709 * Everything below can be run asynchronously without the need to grab 1710 * any modeset locks at all under one condition: It must be guaranteed 1711 * that the asynchronous work has either been cancelled (if the driver 1712 * supports it, which at least requires that the framebuffers get 1713 * cleaned up with drm_atomic_helper_cleanup_planes()) or completed 1714 * before the new state gets committed on the software side with 1715 * drm_atomic_helper_swap_state(). 1716 * 1717 * This scheme allows new atomic state updates to be prepared and 1718 * checked in parallel to the asynchronous completion of the previous 1719 * update. Which is important since compositors need to figure out the 1720 * composition of the next frame right after having submitted the 1721 * current layout. 1722 * 1723 * NOTE: Commit work has multiple phases, first hardware commit, then 1724 * cleanup. We want them to overlap, hence need system_unbound_wq to 1725 * make sure work items don't artifically stall on each another. 1726 */ 1727 1728 drm_atomic_state_get(state); 1729 if (nonblock) 1730 queue_work(system_unbound_wq, &state->commit_work); 1731 else 1732 commit_tail(state); 1733 1734 return 0; 1735 1736 err: 1737 drm_atomic_helper_cleanup_planes(dev, state); 1738 return ret; 1739 } 1740 EXPORT_SYMBOL(drm_atomic_helper_commit); 1741 1742 /** 1743 * DOC: implementing nonblocking commit 1744 * 1745 * Nonblocking atomic commits have to be implemented in the following sequence: 1746 * 1747 * 1. Run drm_atomic_helper_prepare_planes() first. This is the only function 1748 * which commit needs to call which can fail, so we want to run it first and 1749 * synchronously. 1750 * 1751 * 2. Synchronize with any outstanding nonblocking commit worker threads which 1752 * might be affected the new state update. This can be done by either cancelling 1753 * or flushing the work items, depending upon whether the driver can deal with 1754 * cancelled updates. Note that it is important to ensure that the framebuffer 1755 * cleanup is still done when cancelling. 1756 * 1757 * Asynchronous workers need to have sufficient parallelism to be able to run 1758 * different atomic commits on different CRTCs in parallel. The simplest way to 1759 * achive this is by running them on the &system_unbound_wq work queue. Note 1760 * that drivers are not required to split up atomic commits and run an 1761 * individual commit in parallel - userspace is supposed to do that if it cares. 1762 * But it might be beneficial to do that for modesets, since those necessarily 1763 * must be done as one global operation, and enabling or disabling a CRTC can 1764 * take a long time. But even that is not required. 1765 * 1766 * 3. The software state is updated synchronously with 1767 * drm_atomic_helper_swap_state(). Doing this under the protection of all modeset 1768 * locks means concurrent callers never see inconsistent state. And doing this 1769 * while it's guaranteed that no relevant nonblocking worker runs means that 1770 * nonblocking workers do not need grab any locks. Actually they must not grab 1771 * locks, for otherwise the work flushing will deadlock. 1772 * 1773 * 4. Schedule a work item to do all subsequent steps, using the split-out 1774 * commit helpers: a) pre-plane commit b) plane commit c) post-plane commit and 1775 * then cleaning up the framebuffers after the old framebuffer is no longer 1776 * being displayed. 1777 * 1778 * The above scheme is implemented in the atomic helper libraries in 1779 * drm_atomic_helper_commit() using a bunch of helper functions. See 1780 * drm_atomic_helper_setup_commit() for a starting point. 1781 */ 1782 1783 static int stall_checks(struct drm_crtc *crtc, bool nonblock) 1784 { 1785 struct drm_crtc_commit *commit, *stall_commit = NULL; 1786 bool completed = true; 1787 int i; 1788 long ret = 0; 1789 1790 spin_lock(&crtc->commit_lock); 1791 i = 0; 1792 list_for_each_entry(commit, &crtc->commit_list, commit_entry) { 1793 if (i == 0) { 1794 completed = try_wait_for_completion(&commit->flip_done); 1795 /* Userspace is not allowed to get ahead of the previous 1796 * commit with nonblocking ones. */ 1797 if (!completed && nonblock) { 1798 spin_unlock(&crtc->commit_lock); 1799 return -EBUSY; 1800 } 1801 } else if (i == 1) { 1802 stall_commit = drm_crtc_commit_get(commit); 1803 break; 1804 } 1805 1806 i++; 1807 } 1808 spin_unlock(&crtc->commit_lock); 1809 1810 if (!stall_commit) 1811 return 0; 1812 1813 /* We don't want to let commits get ahead of cleanup work too much, 1814 * stalling on 2nd previous commit means triple-buffer won't ever stall. 1815 */ 1816 ret = wait_for_completion_interruptible_timeout(&stall_commit->cleanup_done, 1817 10*HZ); 1818 if (ret == 0) 1819 DRM_ERROR("[CRTC:%d:%s] cleanup_done timed out\n", 1820 crtc->base.id, crtc->name); 1821 1822 drm_crtc_commit_put(stall_commit); 1823 1824 return ret < 0 ? ret : 0; 1825 } 1826 1827 static void release_crtc_commit(struct completion *completion) 1828 { 1829 struct drm_crtc_commit *commit = container_of(completion, 1830 typeof(*commit), 1831 flip_done); 1832 1833 drm_crtc_commit_put(commit); 1834 } 1835 1836 static void init_commit(struct drm_crtc_commit *commit, struct drm_crtc *crtc) 1837 { 1838 init_completion(&commit->flip_done); 1839 init_completion(&commit->hw_done); 1840 init_completion(&commit->cleanup_done); 1841 INIT_LIST_HEAD(&commit->commit_entry); 1842 kref_init(&commit->ref); 1843 commit->crtc = crtc; 1844 } 1845 1846 static struct drm_crtc_commit * 1847 crtc_or_fake_commit(struct drm_atomic_state *state, struct drm_crtc *crtc) 1848 { 1849 if (crtc) { 1850 struct drm_crtc_state *new_crtc_state; 1851 1852 new_crtc_state = drm_atomic_get_new_crtc_state(state, crtc); 1853 1854 return new_crtc_state->commit; 1855 } 1856 1857 if (!state->fake_commit) { 1858 state->fake_commit = kzalloc(sizeof(*state->fake_commit), GFP_KERNEL); 1859 if (!state->fake_commit) 1860 return NULL; 1861 1862 init_commit(state->fake_commit, NULL); 1863 } 1864 1865 return state->fake_commit; 1866 } 1867 1868 /** 1869 * drm_atomic_helper_setup_commit - setup possibly nonblocking commit 1870 * @state: new modeset state to be committed 1871 * @nonblock: whether nonblocking behavior is requested. 1872 * 1873 * This function prepares @state to be used by the atomic helper's support for 1874 * nonblocking commits. Drivers using the nonblocking commit infrastructure 1875 * should always call this function from their 1876 * &drm_mode_config_funcs.atomic_commit hook. 1877 * 1878 * To be able to use this support drivers need to use a few more helper 1879 * functions. drm_atomic_helper_wait_for_dependencies() must be called before 1880 * actually committing the hardware state, and for nonblocking commits this call 1881 * must be placed in the async worker. See also drm_atomic_helper_swap_state() 1882 * and it's stall parameter, for when a driver's commit hooks look at the 1883 * &drm_crtc.state, &drm_plane.state or &drm_connector.state pointer directly. 1884 * 1885 * Completion of the hardware commit step must be signalled using 1886 * drm_atomic_helper_commit_hw_done(). After this step the driver is not allowed 1887 * to read or change any permanent software or hardware modeset state. The only 1888 * exception is state protected by other means than &drm_modeset_lock locks. 1889 * Only the free standing @state with pointers to the old state structures can 1890 * be inspected, e.g. to clean up old buffers using 1891 * drm_atomic_helper_cleanup_planes(). 1892 * 1893 * At the very end, before cleaning up @state drivers must call 1894 * drm_atomic_helper_commit_cleanup_done(). 1895 * 1896 * This is all implemented by in drm_atomic_helper_commit(), giving drivers a 1897 * complete and easy-to-use default implementation of the atomic_commit() hook. 1898 * 1899 * The tracking of asynchronously executed and still pending commits is done 1900 * using the core structure &drm_crtc_commit. 1901 * 1902 * By default there's no need to clean up resources allocated by this function 1903 * explicitly: drm_atomic_state_default_clear() will take care of that 1904 * automatically. 1905 * 1906 * Returns: 1907 * 1908 * 0 on success. -EBUSY when userspace schedules nonblocking commits too fast, 1909 * -ENOMEM on allocation failures and -EINTR when a signal is pending. 1910 */ 1911 int drm_atomic_helper_setup_commit(struct drm_atomic_state *state, 1912 bool nonblock) 1913 { 1914 struct drm_crtc *crtc; 1915 struct drm_crtc_state *old_crtc_state, *new_crtc_state; 1916 struct drm_connector *conn; 1917 struct drm_connector_state *old_conn_state, *new_conn_state; 1918 struct drm_plane *plane; 1919 struct drm_plane_state *old_plane_state, *new_plane_state; 1920 struct drm_crtc_commit *commit; 1921 int i, ret; 1922 1923 for_each_oldnew_crtc_in_state(state, crtc, old_crtc_state, new_crtc_state, i) { 1924 commit = kzalloc(sizeof(*commit), GFP_KERNEL); 1925 if (!commit) 1926 return -ENOMEM; 1927 1928 init_commit(commit, crtc); 1929 1930 new_crtc_state->commit = commit; 1931 1932 ret = stall_checks(crtc, nonblock); 1933 if (ret) 1934 return ret; 1935 1936 /* Drivers only send out events when at least either current or 1937 * new CRTC state is active. Complete right away if everything 1938 * stays off. */ 1939 if (!old_crtc_state->active && !new_crtc_state->active) { 1940 complete_all(&commit->flip_done); 1941 continue; 1942 } 1943 1944 /* Legacy cursor updates are fully unsynced. */ 1945 if (state->legacy_cursor_update) { 1946 complete_all(&commit->flip_done); 1947 continue; 1948 } 1949 1950 if (!new_crtc_state->event) { 1951 commit->event = kzalloc(sizeof(*commit->event), 1952 GFP_KERNEL); 1953 if (!commit->event) 1954 return -ENOMEM; 1955 1956 new_crtc_state->event = commit->event; 1957 } 1958 1959 new_crtc_state->event->base.completion = &commit->flip_done; 1960 new_crtc_state->event->base.completion_release = release_crtc_commit; 1961 drm_crtc_commit_get(commit); 1962 1963 commit->abort_completion = true; 1964 1965 state->crtcs[i].commit = commit; 1966 drm_crtc_commit_get(commit); 1967 } 1968 1969 for_each_oldnew_connector_in_state(state, conn, old_conn_state, new_conn_state, i) { 1970 /* Userspace is not allowed to get ahead of the previous 1971 * commit with nonblocking ones. */ 1972 if (nonblock && old_conn_state->commit && 1973 !try_wait_for_completion(&old_conn_state->commit->flip_done)) 1974 return -EBUSY; 1975 1976 /* Always track connectors explicitly for e.g. link retraining. */ 1977 commit = crtc_or_fake_commit(state, new_conn_state->crtc ?: old_conn_state->crtc); 1978 if (!commit) 1979 return -ENOMEM; 1980 1981 new_conn_state->commit = drm_crtc_commit_get(commit); 1982 } 1983 1984 for_each_oldnew_plane_in_state(state, plane, old_plane_state, new_plane_state, i) { 1985 /* Userspace is not allowed to get ahead of the previous 1986 * commit with nonblocking ones. */ 1987 if (nonblock && old_plane_state->commit && 1988 !try_wait_for_completion(&old_plane_state->commit->flip_done)) 1989 return -EBUSY; 1990 1991 /* Always track planes explicitly for async pageflip support. */ 1992 commit = crtc_or_fake_commit(state, new_plane_state->crtc ?: old_plane_state->crtc); 1993 if (!commit) 1994 return -ENOMEM; 1995 1996 new_plane_state->commit = drm_crtc_commit_get(commit); 1997 } 1998 1999 return 0; 2000 } 2001 EXPORT_SYMBOL(drm_atomic_helper_setup_commit); 2002 2003 /** 2004 * drm_atomic_helper_wait_for_dependencies - wait for required preceeding commits 2005 * @old_state: atomic state object with old state structures 2006 * 2007 * This function waits for all preceeding commits that touch the same CRTC as 2008 * @old_state to both be committed to the hardware (as signalled by 2009 * drm_atomic_helper_commit_hw_done) and executed by the hardware (as signalled 2010 * by calling drm_crtc_send_vblank_event() on the &drm_crtc_state.event). 2011 * 2012 * This is part of the atomic helper support for nonblocking commits, see 2013 * drm_atomic_helper_setup_commit() for an overview. 2014 */ 2015 void drm_atomic_helper_wait_for_dependencies(struct drm_atomic_state *old_state) 2016 { 2017 struct drm_crtc *crtc; 2018 struct drm_crtc_state *old_crtc_state; 2019 struct drm_plane *plane; 2020 struct drm_plane_state *old_plane_state; 2021 struct drm_connector *conn; 2022 struct drm_connector_state *old_conn_state; 2023 struct drm_crtc_commit *commit; 2024 int i; 2025 long ret; 2026 2027 for_each_old_crtc_in_state(old_state, crtc, old_crtc_state, i) { 2028 commit = old_crtc_state->commit; 2029 2030 if (!commit) 2031 continue; 2032 2033 ret = wait_for_completion_timeout(&commit->hw_done, 2034 10*HZ); 2035 if (ret == 0) 2036 DRM_ERROR("[CRTC:%d:%s] hw_done timed out\n", 2037 crtc->base.id, crtc->name); 2038 2039 /* Currently no support for overwriting flips, hence 2040 * stall for previous one to execute completely. */ 2041 ret = wait_for_completion_timeout(&commit->flip_done, 2042 10*HZ); 2043 if (ret == 0) 2044 DRM_ERROR("[CRTC:%d:%s] flip_done timed out\n", 2045 crtc->base.id, crtc->name); 2046 } 2047 2048 for_each_old_connector_in_state(old_state, conn, old_conn_state, i) { 2049 commit = old_conn_state->commit; 2050 2051 if (!commit) 2052 continue; 2053 2054 ret = wait_for_completion_timeout(&commit->hw_done, 2055 10*HZ); 2056 if (ret == 0) 2057 DRM_ERROR("[CONNECTOR:%d:%s] hw_done timed out\n", 2058 conn->base.id, conn->name); 2059 2060 /* Currently no support for overwriting flips, hence 2061 * stall for previous one to execute completely. */ 2062 ret = wait_for_completion_timeout(&commit->flip_done, 2063 10*HZ); 2064 if (ret == 0) 2065 DRM_ERROR("[CONNECTOR:%d:%s] flip_done timed out\n", 2066 conn->base.id, conn->name); 2067 } 2068 2069 for_each_old_plane_in_state(old_state, plane, old_plane_state, i) { 2070 commit = old_plane_state->commit; 2071 2072 if (!commit) 2073 continue; 2074 2075 ret = wait_for_completion_timeout(&commit->hw_done, 2076 10*HZ); 2077 if (ret == 0) 2078 DRM_ERROR("[PLANE:%d:%s] hw_done timed out\n", 2079 plane->base.id, plane->name); 2080 2081 /* Currently no support for overwriting flips, hence 2082 * stall for previous one to execute completely. */ 2083 ret = wait_for_completion_timeout(&commit->flip_done, 2084 10*HZ); 2085 if (ret == 0) 2086 DRM_ERROR("[PLANE:%d:%s] flip_done timed out\n", 2087 plane->base.id, plane->name); 2088 } 2089 } 2090 EXPORT_SYMBOL(drm_atomic_helper_wait_for_dependencies); 2091 2092 /** 2093 * drm_atomic_helper_fake_vblank - fake VBLANK events if needed 2094 * @old_state: atomic state object with old state structures 2095 * 2096 * This function walks all CRTCs and fake VBLANK events on those with 2097 * &drm_crtc_state.no_vblank set to true and &drm_crtc_state.event != NULL. 2098 * The primary use of this function is writeback connectors working in oneshot 2099 * mode and faking VBLANK events. In this case they only fake the VBLANK event 2100 * when a job is queued, and any change to the pipeline that does not touch the 2101 * connector is leading to timeouts when calling 2102 * drm_atomic_helper_wait_for_vblanks() or 2103 * drm_atomic_helper_wait_for_flip_done(). 2104 * 2105 * This is part of the atomic helper support for nonblocking commits, see 2106 * drm_atomic_helper_setup_commit() for an overview. 2107 */ 2108 void drm_atomic_helper_fake_vblank(struct drm_atomic_state *old_state) 2109 { 2110 struct drm_crtc_state *new_crtc_state; 2111 struct drm_crtc *crtc; 2112 int i; 2113 2114 for_each_new_crtc_in_state(old_state, crtc, new_crtc_state, i) { 2115 unsigned long flags; 2116 2117 if (!new_crtc_state->no_vblank) 2118 continue; 2119 2120 spin_lock_irqsave(&old_state->dev->event_lock, flags); 2121 if (new_crtc_state->event) { 2122 drm_crtc_send_vblank_event(crtc, 2123 new_crtc_state->event); 2124 new_crtc_state->event = NULL; 2125 } 2126 spin_unlock_irqrestore(&old_state->dev->event_lock, flags); 2127 } 2128 } 2129 EXPORT_SYMBOL(drm_atomic_helper_fake_vblank); 2130 2131 /** 2132 * drm_atomic_helper_commit_hw_done - setup possible nonblocking commit 2133 * @old_state: atomic state object with old state structures 2134 * 2135 * This function is used to signal completion of the hardware commit step. After 2136 * this step the driver is not allowed to read or change any permanent software 2137 * or hardware modeset state. The only exception is state protected by other 2138 * means than &drm_modeset_lock locks. 2139 * 2140 * Drivers should try to postpone any expensive or delayed cleanup work after 2141 * this function is called. 2142 * 2143 * This is part of the atomic helper support for nonblocking commits, see 2144 * drm_atomic_helper_setup_commit() for an overview. 2145 */ 2146 void drm_atomic_helper_commit_hw_done(struct drm_atomic_state *old_state) 2147 { 2148 struct drm_crtc *crtc; 2149 struct drm_crtc_state *old_crtc_state, *new_crtc_state; 2150 struct drm_crtc_commit *commit; 2151 int i; 2152 2153 for_each_oldnew_crtc_in_state(old_state, crtc, old_crtc_state, new_crtc_state, i) { 2154 commit = new_crtc_state->commit; 2155 if (!commit) 2156 continue; 2157 2158 /* 2159 * copy new_crtc_state->commit to old_crtc_state->commit, 2160 * it's unsafe to touch new_crtc_state after hw_done, 2161 * but we still need to do so in cleanup_done(). 2162 */ 2163 if (old_crtc_state->commit) 2164 drm_crtc_commit_put(old_crtc_state->commit); 2165 2166 old_crtc_state->commit = drm_crtc_commit_get(commit); 2167 2168 /* backend must have consumed any event by now */ 2169 WARN_ON(new_crtc_state->event); 2170 complete_all(&commit->hw_done); 2171 } 2172 2173 if (old_state->fake_commit) { 2174 complete_all(&old_state->fake_commit->hw_done); 2175 complete_all(&old_state->fake_commit->flip_done); 2176 } 2177 } 2178 EXPORT_SYMBOL(drm_atomic_helper_commit_hw_done); 2179 2180 /** 2181 * drm_atomic_helper_commit_cleanup_done - signal completion of commit 2182 * @old_state: atomic state object with old state structures 2183 * 2184 * This signals completion of the atomic update @old_state, including any 2185 * cleanup work. If used, it must be called right before calling 2186 * drm_atomic_state_put(). 2187 * 2188 * This is part of the atomic helper support for nonblocking commits, see 2189 * drm_atomic_helper_setup_commit() for an overview. 2190 */ 2191 void drm_atomic_helper_commit_cleanup_done(struct drm_atomic_state *old_state) 2192 { 2193 struct drm_crtc *crtc; 2194 struct drm_crtc_state *old_crtc_state; 2195 struct drm_crtc_commit *commit; 2196 int i; 2197 2198 for_each_old_crtc_in_state(old_state, crtc, old_crtc_state, i) { 2199 commit = old_crtc_state->commit; 2200 if (WARN_ON(!commit)) 2201 continue; 2202 2203 complete_all(&commit->cleanup_done); 2204 WARN_ON(!try_wait_for_completion(&commit->hw_done)); 2205 2206 spin_lock(&crtc->commit_lock); 2207 list_del(&commit->commit_entry); 2208 spin_unlock(&crtc->commit_lock); 2209 } 2210 2211 if (old_state->fake_commit) 2212 complete_all(&old_state->fake_commit->cleanup_done); 2213 } 2214 EXPORT_SYMBOL(drm_atomic_helper_commit_cleanup_done); 2215 2216 /** 2217 * drm_atomic_helper_prepare_planes - prepare plane resources before commit 2218 * @dev: DRM device 2219 * @state: atomic state object with new state structures 2220 * 2221 * This function prepares plane state, specifically framebuffers, for the new 2222 * configuration, by calling &drm_plane_helper_funcs.prepare_fb. If any failure 2223 * is encountered this function will call &drm_plane_helper_funcs.cleanup_fb on 2224 * any already successfully prepared framebuffer. 2225 * 2226 * Returns: 2227 * 0 on success, negative error code on failure. 2228 */ 2229 int drm_atomic_helper_prepare_planes(struct drm_device *dev, 2230 struct drm_atomic_state *state) 2231 { 2232 struct drm_plane *plane; 2233 struct drm_plane_state *new_plane_state; 2234 int ret, i, j; 2235 2236 for_each_new_plane_in_state(state, plane, new_plane_state, i) { 2237 const struct drm_plane_helper_funcs *funcs; 2238 2239 funcs = plane->helper_private; 2240 2241 if (funcs->prepare_fb) { 2242 ret = funcs->prepare_fb(plane, new_plane_state); 2243 if (ret) 2244 goto fail; 2245 } 2246 } 2247 2248 return 0; 2249 2250 fail: 2251 for_each_new_plane_in_state(state, plane, new_plane_state, j) { 2252 const struct drm_plane_helper_funcs *funcs; 2253 2254 if (j >= i) 2255 continue; 2256 2257 funcs = plane->helper_private; 2258 2259 if (funcs->cleanup_fb) 2260 funcs->cleanup_fb(plane, new_plane_state); 2261 } 2262 2263 return ret; 2264 } 2265 EXPORT_SYMBOL(drm_atomic_helper_prepare_planes); 2266 2267 static bool plane_crtc_active(const struct drm_plane_state *state) 2268 { 2269 return state->crtc && state->crtc->state->active; 2270 } 2271 2272 /** 2273 * drm_atomic_helper_commit_planes - commit plane state 2274 * @dev: DRM device 2275 * @old_state: atomic state object with old state structures 2276 * @flags: flags for committing plane state 2277 * 2278 * This function commits the new plane state using the plane and atomic helper 2279 * functions for planes and crtcs. It assumes that the atomic state has already 2280 * been pushed into the relevant object state pointers, since this step can no 2281 * longer fail. 2282 * 2283 * It still requires the global state object @old_state to know which planes and 2284 * crtcs need to be updated though. 2285 * 2286 * Note that this function does all plane updates across all CRTCs in one step. 2287 * If the hardware can't support this approach look at 2288 * drm_atomic_helper_commit_planes_on_crtc() instead. 2289 * 2290 * Plane parameters can be updated by applications while the associated CRTC is 2291 * disabled. The DRM/KMS core will store the parameters in the plane state, 2292 * which will be available to the driver when the CRTC is turned on. As a result 2293 * most drivers don't need to be immediately notified of plane updates for a 2294 * disabled CRTC. 2295 * 2296 * Unless otherwise needed, drivers are advised to set the ACTIVE_ONLY flag in 2297 * @flags in order not to receive plane update notifications related to a 2298 * disabled CRTC. This avoids the need to manually ignore plane updates in 2299 * driver code when the driver and/or hardware can't or just don't need to deal 2300 * with updates on disabled CRTCs, for example when supporting runtime PM. 2301 * 2302 * Drivers may set the NO_DISABLE_AFTER_MODESET flag in @flags if the relevant 2303 * display controllers require to disable a CRTC's planes when the CRTC is 2304 * disabled. This function would skip the &drm_plane_helper_funcs.atomic_disable 2305 * call for a plane if the CRTC of the old plane state needs a modesetting 2306 * operation. Of course, the drivers need to disable the planes in their CRTC 2307 * disable callbacks since no one else would do that. 2308 * 2309 * The drm_atomic_helper_commit() default implementation doesn't set the 2310 * ACTIVE_ONLY flag to most closely match the behaviour of the legacy helpers. 2311 * This should not be copied blindly by drivers. 2312 */ 2313 void drm_atomic_helper_commit_planes(struct drm_device *dev, 2314 struct drm_atomic_state *old_state, 2315 uint32_t flags) 2316 { 2317 struct drm_crtc *crtc; 2318 struct drm_crtc_state *old_crtc_state, *new_crtc_state; 2319 struct drm_plane *plane; 2320 struct drm_plane_state *old_plane_state, *new_plane_state; 2321 int i; 2322 bool active_only = flags & DRM_PLANE_COMMIT_ACTIVE_ONLY; 2323 bool no_disable = flags & DRM_PLANE_COMMIT_NO_DISABLE_AFTER_MODESET; 2324 2325 for_each_oldnew_crtc_in_state(old_state, crtc, old_crtc_state, new_crtc_state, i) { 2326 const struct drm_crtc_helper_funcs *funcs; 2327 2328 funcs = crtc->helper_private; 2329 2330 if (!funcs || !funcs->atomic_begin) 2331 continue; 2332 2333 if (active_only && !new_crtc_state->active) 2334 continue; 2335 2336 funcs->atomic_begin(crtc, old_crtc_state); 2337 } 2338 2339 for_each_oldnew_plane_in_state(old_state, plane, old_plane_state, new_plane_state, i) { 2340 const struct drm_plane_helper_funcs *funcs; 2341 bool disabling; 2342 2343 funcs = plane->helper_private; 2344 2345 if (!funcs) 2346 continue; 2347 2348 disabling = drm_atomic_plane_disabling(old_plane_state, 2349 new_plane_state); 2350 2351 if (active_only) { 2352 /* 2353 * Skip planes related to inactive CRTCs. If the plane 2354 * is enabled use the state of the current CRTC. If the 2355 * plane is being disabled use the state of the old 2356 * CRTC to avoid skipping planes being disabled on an 2357 * active CRTC. 2358 */ 2359 if (!disabling && !plane_crtc_active(new_plane_state)) 2360 continue; 2361 if (disabling && !plane_crtc_active(old_plane_state)) 2362 continue; 2363 } 2364 2365 /* 2366 * Special-case disabling the plane if drivers support it. 2367 */ 2368 if (disabling && funcs->atomic_disable) { 2369 struct drm_crtc_state *crtc_state; 2370 2371 crtc_state = old_plane_state->crtc->state; 2372 2373 if (drm_atomic_crtc_needs_modeset(crtc_state) && 2374 no_disable) 2375 continue; 2376 2377 funcs->atomic_disable(plane, old_plane_state); 2378 } else if (new_plane_state->crtc || disabling) { 2379 funcs->atomic_update(plane, old_plane_state); 2380 } 2381 } 2382 2383 for_each_oldnew_crtc_in_state(old_state, crtc, old_crtc_state, new_crtc_state, i) { 2384 const struct drm_crtc_helper_funcs *funcs; 2385 2386 funcs = crtc->helper_private; 2387 2388 if (!funcs || !funcs->atomic_flush) 2389 continue; 2390 2391 if (active_only && !new_crtc_state->active) 2392 continue; 2393 2394 funcs->atomic_flush(crtc, old_crtc_state); 2395 } 2396 } 2397 EXPORT_SYMBOL(drm_atomic_helper_commit_planes); 2398 2399 /** 2400 * drm_atomic_helper_commit_planes_on_crtc - commit plane state for a crtc 2401 * @old_crtc_state: atomic state object with the old crtc state 2402 * 2403 * This function commits the new plane state using the plane and atomic helper 2404 * functions for planes on the specific crtc. It assumes that the atomic state 2405 * has already been pushed into the relevant object state pointers, since this 2406 * step can no longer fail. 2407 * 2408 * This function is useful when plane updates should be done crtc-by-crtc 2409 * instead of one global step like drm_atomic_helper_commit_planes() does. 2410 * 2411 * This function can only be savely used when planes are not allowed to move 2412 * between different CRTCs because this function doesn't handle inter-CRTC 2413 * depencies. Callers need to ensure that either no such depencies exist, 2414 * resolve them through ordering of commit calls or through some other means. 2415 */ 2416 void 2417 drm_atomic_helper_commit_planes_on_crtc(struct drm_crtc_state *old_crtc_state) 2418 { 2419 const struct drm_crtc_helper_funcs *crtc_funcs; 2420 struct drm_crtc *crtc = old_crtc_state->crtc; 2421 struct drm_atomic_state *old_state = old_crtc_state->state; 2422 struct drm_crtc_state *new_crtc_state = 2423 drm_atomic_get_new_crtc_state(old_state, crtc); 2424 struct drm_plane *plane; 2425 unsigned plane_mask; 2426 2427 plane_mask = old_crtc_state->plane_mask; 2428 plane_mask |= new_crtc_state->plane_mask; 2429 2430 crtc_funcs = crtc->helper_private; 2431 if (crtc_funcs && crtc_funcs->atomic_begin) 2432 crtc_funcs->atomic_begin(crtc, old_crtc_state); 2433 2434 drm_for_each_plane_mask(plane, crtc->dev, plane_mask) { 2435 struct drm_plane_state *old_plane_state = 2436 drm_atomic_get_old_plane_state(old_state, plane); 2437 struct drm_plane_state *new_plane_state = 2438 drm_atomic_get_new_plane_state(old_state, plane); 2439 const struct drm_plane_helper_funcs *plane_funcs; 2440 2441 plane_funcs = plane->helper_private; 2442 2443 if (!old_plane_state || !plane_funcs) 2444 continue; 2445 2446 WARN_ON(new_plane_state->crtc && 2447 new_plane_state->crtc != crtc); 2448 2449 if (drm_atomic_plane_disabling(old_plane_state, new_plane_state) && 2450 plane_funcs->atomic_disable) 2451 plane_funcs->atomic_disable(plane, old_plane_state); 2452 else if (new_plane_state->crtc || 2453 drm_atomic_plane_disabling(old_plane_state, new_plane_state)) 2454 plane_funcs->atomic_update(plane, old_plane_state); 2455 } 2456 2457 if (crtc_funcs && crtc_funcs->atomic_flush) 2458 crtc_funcs->atomic_flush(crtc, old_crtc_state); 2459 } 2460 EXPORT_SYMBOL(drm_atomic_helper_commit_planes_on_crtc); 2461 2462 /** 2463 * drm_atomic_helper_disable_planes_on_crtc - helper to disable CRTC's planes 2464 * @old_crtc_state: atomic state object with the old CRTC state 2465 * @atomic: if set, synchronize with CRTC's atomic_begin/flush hooks 2466 * 2467 * Disables all planes associated with the given CRTC. This can be 2468 * used for instance in the CRTC helper atomic_disable callback to disable 2469 * all planes. 2470 * 2471 * If the atomic-parameter is set the function calls the CRTC's 2472 * atomic_begin hook before and atomic_flush hook after disabling the 2473 * planes. 2474 * 2475 * It is a bug to call this function without having implemented the 2476 * &drm_plane_helper_funcs.atomic_disable plane hook. 2477 */ 2478 void 2479 drm_atomic_helper_disable_planes_on_crtc(struct drm_crtc_state *old_crtc_state, 2480 bool atomic) 2481 { 2482 struct drm_crtc *crtc = old_crtc_state->crtc; 2483 const struct drm_crtc_helper_funcs *crtc_funcs = 2484 crtc->helper_private; 2485 struct drm_plane *plane; 2486 2487 if (atomic && crtc_funcs && crtc_funcs->atomic_begin) 2488 crtc_funcs->atomic_begin(crtc, NULL); 2489 2490 drm_atomic_crtc_state_for_each_plane(plane, old_crtc_state) { 2491 const struct drm_plane_helper_funcs *plane_funcs = 2492 plane->helper_private; 2493 2494 if (!plane_funcs) 2495 continue; 2496 2497 WARN_ON(!plane_funcs->atomic_disable); 2498 if (plane_funcs->atomic_disable) 2499 plane_funcs->atomic_disable(plane, NULL); 2500 } 2501 2502 if (atomic && crtc_funcs && crtc_funcs->atomic_flush) 2503 crtc_funcs->atomic_flush(crtc, NULL); 2504 } 2505 EXPORT_SYMBOL(drm_atomic_helper_disable_planes_on_crtc); 2506 2507 /** 2508 * drm_atomic_helper_cleanup_planes - cleanup plane resources after commit 2509 * @dev: DRM device 2510 * @old_state: atomic state object with old state structures 2511 * 2512 * This function cleans up plane state, specifically framebuffers, from the old 2513 * configuration. Hence the old configuration must be perserved in @old_state to 2514 * be able to call this function. 2515 * 2516 * This function must also be called on the new state when the atomic update 2517 * fails at any point after calling drm_atomic_helper_prepare_planes(). 2518 */ 2519 void drm_atomic_helper_cleanup_planes(struct drm_device *dev, 2520 struct drm_atomic_state *old_state) 2521 { 2522 struct drm_plane *plane; 2523 struct drm_plane_state *old_plane_state, *new_plane_state; 2524 int i; 2525 2526 for_each_oldnew_plane_in_state(old_state, plane, old_plane_state, new_plane_state, i) { 2527 const struct drm_plane_helper_funcs *funcs; 2528 struct drm_plane_state *plane_state; 2529 2530 /* 2531 * This might be called before swapping when commit is aborted, 2532 * in which case we have to cleanup the new state. 2533 */ 2534 if (old_plane_state == plane->state) 2535 plane_state = new_plane_state; 2536 else 2537 plane_state = old_plane_state; 2538 2539 funcs = plane->helper_private; 2540 2541 if (funcs->cleanup_fb) 2542 funcs->cleanup_fb(plane, plane_state); 2543 } 2544 } 2545 EXPORT_SYMBOL(drm_atomic_helper_cleanup_planes); 2546 2547 /** 2548 * drm_atomic_helper_swap_state - store atomic state into current sw state 2549 * @state: atomic state 2550 * @stall: stall for preceeding commits 2551 * 2552 * This function stores the atomic state into the current state pointers in all 2553 * driver objects. It should be called after all failing steps have been done 2554 * and succeeded, but before the actual hardware state is committed. 2555 * 2556 * For cleanup and error recovery the current state for all changed objects will 2557 * be swapped into @state. 2558 * 2559 * With that sequence it fits perfectly into the plane prepare/cleanup sequence: 2560 * 2561 * 1. Call drm_atomic_helper_prepare_planes() with the staged atomic state. 2562 * 2563 * 2. Do any other steps that might fail. 2564 * 2565 * 3. Put the staged state into the current state pointers with this function. 2566 * 2567 * 4. Actually commit the hardware state. 2568 * 2569 * 5. Call drm_atomic_helper_cleanup_planes() with @state, which since step 3 2570 * contains the old state. Also do any other cleanup required with that state. 2571 * 2572 * @stall must be set when nonblocking commits for this driver directly access 2573 * the &drm_plane.state, &drm_crtc.state or &drm_connector.state pointer. With 2574 * the current atomic helpers this is almost always the case, since the helpers 2575 * don't pass the right state structures to the callbacks. 2576 * 2577 * Returns: 2578 * 2579 * Returns 0 on success. Can return -ERESTARTSYS when @stall is true and the 2580 * waiting for the previous commits has been interrupted. 2581 */ 2582 int drm_atomic_helper_swap_state(struct drm_atomic_state *state, 2583 bool stall) 2584 { 2585 int i, ret; 2586 struct drm_connector *connector; 2587 struct drm_connector_state *old_conn_state, *new_conn_state; 2588 struct drm_crtc *crtc; 2589 struct drm_crtc_state *old_crtc_state, *new_crtc_state; 2590 struct drm_plane *plane; 2591 struct drm_plane_state *old_plane_state, *new_plane_state; 2592 struct drm_crtc_commit *commit; 2593 struct drm_private_obj *obj; 2594 struct drm_private_state *old_obj_state, *new_obj_state; 2595 2596 if (stall) { 2597 /* 2598 * We have to stall for hw_done here before 2599 * drm_atomic_helper_wait_for_dependencies() because flip 2600 * depth > 1 is not yet supported by all drivers. As long as 2601 * obj->state is directly dereferenced anywhere in the drivers 2602 * atomic_commit_tail function, then it's unsafe to swap state 2603 * before drm_atomic_helper_commit_hw_done() is called. 2604 */ 2605 2606 for_each_old_crtc_in_state(state, crtc, old_crtc_state, i) { 2607 commit = old_crtc_state->commit; 2608 2609 if (!commit) 2610 continue; 2611 2612 ret = wait_for_completion_interruptible(&commit->hw_done); 2613 if (ret) 2614 return ret; 2615 } 2616 2617 for_each_old_connector_in_state(state, connector, old_conn_state, i) { 2618 commit = old_conn_state->commit; 2619 2620 if (!commit) 2621 continue; 2622 2623 ret = wait_for_completion_interruptible(&commit->hw_done); 2624 if (ret) 2625 return ret; 2626 } 2627 2628 for_each_old_plane_in_state(state, plane, old_plane_state, i) { 2629 commit = old_plane_state->commit; 2630 2631 if (!commit) 2632 continue; 2633 2634 ret = wait_for_completion_interruptible(&commit->hw_done); 2635 if (ret) 2636 return ret; 2637 } 2638 } 2639 2640 for_each_oldnew_connector_in_state(state, connector, old_conn_state, new_conn_state, i) { 2641 WARN_ON(connector->state != old_conn_state); 2642 2643 old_conn_state->state = state; 2644 new_conn_state->state = NULL; 2645 2646 state->connectors[i].state = old_conn_state; 2647 connector->state = new_conn_state; 2648 } 2649 2650 for_each_oldnew_crtc_in_state(state, crtc, old_crtc_state, new_crtc_state, i) { 2651 WARN_ON(crtc->state != old_crtc_state); 2652 2653 old_crtc_state->state = state; 2654 new_crtc_state->state = NULL; 2655 2656 state->crtcs[i].state = old_crtc_state; 2657 crtc->state = new_crtc_state; 2658 2659 if (new_crtc_state->commit) { 2660 spin_lock(&crtc->commit_lock); 2661 list_add(&new_crtc_state->commit->commit_entry, 2662 &crtc->commit_list); 2663 spin_unlock(&crtc->commit_lock); 2664 2665 new_crtc_state->commit->event = NULL; 2666 } 2667 } 2668 2669 for_each_oldnew_plane_in_state(state, plane, old_plane_state, new_plane_state, i) { 2670 WARN_ON(plane->state != old_plane_state); 2671 2672 old_plane_state->state = state; 2673 new_plane_state->state = NULL; 2674 2675 state->planes[i].state = old_plane_state; 2676 plane->state = new_plane_state; 2677 } 2678 2679 for_each_oldnew_private_obj_in_state(state, obj, old_obj_state, new_obj_state, i) { 2680 WARN_ON(obj->state != old_obj_state); 2681 2682 old_obj_state->state = state; 2683 new_obj_state->state = NULL; 2684 2685 state->private_objs[i].state = old_obj_state; 2686 obj->state = new_obj_state; 2687 } 2688 2689 return 0; 2690 } 2691 EXPORT_SYMBOL(drm_atomic_helper_swap_state); 2692 2693 /** 2694 * drm_atomic_helper_update_plane - Helper for primary plane update using atomic 2695 * @plane: plane object to update 2696 * @crtc: owning CRTC of owning plane 2697 * @fb: framebuffer to flip onto plane 2698 * @crtc_x: x offset of primary plane on crtc 2699 * @crtc_y: y offset of primary plane on crtc 2700 * @crtc_w: width of primary plane rectangle on crtc 2701 * @crtc_h: height of primary plane rectangle on crtc 2702 * @src_x: x offset of @fb for panning 2703 * @src_y: y offset of @fb for panning 2704 * @src_w: width of source rectangle in @fb 2705 * @src_h: height of source rectangle in @fb 2706 * @ctx: lock acquire context 2707 * 2708 * Provides a default plane update handler using the atomic driver interface. 2709 * 2710 * RETURNS: 2711 * Zero on success, error code on failure 2712 */ 2713 int drm_atomic_helper_update_plane(struct drm_plane *plane, 2714 struct drm_crtc *crtc, 2715 struct drm_framebuffer *fb, 2716 int crtc_x, int crtc_y, 2717 unsigned int crtc_w, unsigned int crtc_h, 2718 uint32_t src_x, uint32_t src_y, 2719 uint32_t src_w, uint32_t src_h, 2720 struct drm_modeset_acquire_ctx *ctx) 2721 { 2722 struct drm_atomic_state *state; 2723 struct drm_plane_state *plane_state; 2724 int ret = 0; 2725 2726 state = drm_atomic_state_alloc(plane->dev); 2727 if (!state) 2728 return -ENOMEM; 2729 2730 state->acquire_ctx = ctx; 2731 plane_state = drm_atomic_get_plane_state(state, plane); 2732 if (IS_ERR(plane_state)) { 2733 ret = PTR_ERR(plane_state); 2734 goto fail; 2735 } 2736 2737 ret = drm_atomic_set_crtc_for_plane(plane_state, crtc); 2738 if (ret != 0) 2739 goto fail; 2740 drm_atomic_set_fb_for_plane(plane_state, fb); 2741 plane_state->crtc_x = crtc_x; 2742 plane_state->crtc_y = crtc_y; 2743 plane_state->crtc_w = crtc_w; 2744 plane_state->crtc_h = crtc_h; 2745 plane_state->src_x = src_x; 2746 plane_state->src_y = src_y; 2747 plane_state->src_w = src_w; 2748 plane_state->src_h = src_h; 2749 2750 if (plane == crtc->cursor) 2751 state->legacy_cursor_update = true; 2752 2753 ret = drm_atomic_commit(state); 2754 fail: 2755 drm_atomic_state_put(state); 2756 return ret; 2757 } 2758 EXPORT_SYMBOL(drm_atomic_helper_update_plane); 2759 2760 /** 2761 * drm_atomic_helper_disable_plane - Helper for primary plane disable using * atomic 2762 * @plane: plane to disable 2763 * @ctx: lock acquire context 2764 * 2765 * Provides a default plane disable handler using the atomic driver interface. 2766 * 2767 * RETURNS: 2768 * Zero on success, error code on failure 2769 */ 2770 int drm_atomic_helper_disable_plane(struct drm_plane *plane, 2771 struct drm_modeset_acquire_ctx *ctx) 2772 { 2773 struct drm_atomic_state *state; 2774 struct drm_plane_state *plane_state; 2775 int ret = 0; 2776 2777 state = drm_atomic_state_alloc(plane->dev); 2778 if (!state) 2779 return -ENOMEM; 2780 2781 state->acquire_ctx = ctx; 2782 plane_state = drm_atomic_get_plane_state(state, plane); 2783 if (IS_ERR(plane_state)) { 2784 ret = PTR_ERR(plane_state); 2785 goto fail; 2786 } 2787 2788 if (plane_state->crtc && plane_state->crtc->cursor == plane) 2789 plane_state->state->legacy_cursor_update = true; 2790 2791 ret = __drm_atomic_helper_disable_plane(plane, plane_state); 2792 if (ret != 0) 2793 goto fail; 2794 2795 ret = drm_atomic_commit(state); 2796 fail: 2797 drm_atomic_state_put(state); 2798 return ret; 2799 } 2800 EXPORT_SYMBOL(drm_atomic_helper_disable_plane); 2801 2802 /* just used from fb-helper and atomic-helper: */ 2803 int __drm_atomic_helper_disable_plane(struct drm_plane *plane, 2804 struct drm_plane_state *plane_state) 2805 { 2806 int ret; 2807 2808 ret = drm_atomic_set_crtc_for_plane(plane_state, NULL); 2809 if (ret != 0) 2810 return ret; 2811 2812 drm_atomic_set_fb_for_plane(plane_state, NULL); 2813 plane_state->crtc_x = 0; 2814 plane_state->crtc_y = 0; 2815 plane_state->crtc_w = 0; 2816 plane_state->crtc_h = 0; 2817 plane_state->src_x = 0; 2818 plane_state->src_y = 0; 2819 plane_state->src_w = 0; 2820 plane_state->src_h = 0; 2821 2822 return 0; 2823 } 2824 2825 static int update_output_state(struct drm_atomic_state *state, 2826 struct drm_mode_set *set) 2827 { 2828 struct drm_device *dev = set->crtc->dev; 2829 struct drm_crtc *crtc; 2830 struct drm_crtc_state *new_crtc_state; 2831 struct drm_connector *connector; 2832 struct drm_connector_state *new_conn_state; 2833 int ret, i; 2834 2835 ret = drm_modeset_lock(&dev->mode_config.connection_mutex, 2836 state->acquire_ctx); 2837 if (ret) 2838 return ret; 2839 2840 /* First disable all connectors on the target crtc. */ 2841 ret = drm_atomic_add_affected_connectors(state, set->crtc); 2842 if (ret) 2843 return ret; 2844 2845 for_each_new_connector_in_state(state, connector, new_conn_state, i) { 2846 if (new_conn_state->crtc == set->crtc) { 2847 ret = drm_atomic_set_crtc_for_connector(new_conn_state, 2848 NULL); 2849 if (ret) 2850 return ret; 2851 2852 /* Make sure legacy setCrtc always re-trains */ 2853 new_conn_state->link_status = DRM_LINK_STATUS_GOOD; 2854 } 2855 } 2856 2857 /* Then set all connectors from set->connectors on the target crtc */ 2858 for (i = 0; i < set->num_connectors; i++) { 2859 new_conn_state = drm_atomic_get_connector_state(state, 2860 set->connectors[i]); 2861 if (IS_ERR(new_conn_state)) 2862 return PTR_ERR(new_conn_state); 2863 2864 ret = drm_atomic_set_crtc_for_connector(new_conn_state, 2865 set->crtc); 2866 if (ret) 2867 return ret; 2868 } 2869 2870 for_each_new_crtc_in_state(state, crtc, new_crtc_state, i) { 2871 /* Don't update ->enable for the CRTC in the set_config request, 2872 * since a mismatch would indicate a bug in the upper layers. 2873 * The actual modeset code later on will catch any 2874 * inconsistencies here. */ 2875 if (crtc == set->crtc) 2876 continue; 2877 2878 if (!new_crtc_state->connector_mask) { 2879 ret = drm_atomic_set_mode_prop_for_crtc(new_crtc_state, 2880 NULL); 2881 if (ret < 0) 2882 return ret; 2883 2884 new_crtc_state->active = false; 2885 } 2886 } 2887 2888 return 0; 2889 } 2890 2891 /** 2892 * drm_atomic_helper_set_config - set a new config from userspace 2893 * @set: mode set configuration 2894 * @ctx: lock acquisition context 2895 * 2896 * Provides a default crtc set_config handler using the atomic driver interface. 2897 * 2898 * NOTE: For backwards compatibility with old userspace this automatically 2899 * resets the "link-status" property to GOOD, to force any link 2900 * re-training. The SETCRTC ioctl does not define whether an update does 2901 * need a full modeset or just a plane update, hence we're allowed to do 2902 * that. See also drm_connector_set_link_status_property(). 2903 * 2904 * Returns: 2905 * Returns 0 on success, negative errno numbers on failure. 2906 */ 2907 int drm_atomic_helper_set_config(struct drm_mode_set *set, 2908 struct drm_modeset_acquire_ctx *ctx) 2909 { 2910 struct drm_atomic_state *state; 2911 struct drm_crtc *crtc = set->crtc; 2912 int ret = 0; 2913 2914 state = drm_atomic_state_alloc(crtc->dev); 2915 if (!state) 2916 return -ENOMEM; 2917 2918 state->acquire_ctx = ctx; 2919 ret = __drm_atomic_helper_set_config(set, state); 2920 if (ret != 0) 2921 goto fail; 2922 2923 ret = handle_conflicting_encoders(state, true); 2924 if (ret) 2925 return ret; 2926 2927 ret = drm_atomic_commit(state); 2928 2929 fail: 2930 drm_atomic_state_put(state); 2931 return ret; 2932 } 2933 EXPORT_SYMBOL(drm_atomic_helper_set_config); 2934 2935 /* just used from fb-helper and atomic-helper: */ 2936 int __drm_atomic_helper_set_config(struct drm_mode_set *set, 2937 struct drm_atomic_state *state) 2938 { 2939 struct drm_crtc_state *crtc_state; 2940 struct drm_plane_state *primary_state; 2941 struct drm_crtc *crtc = set->crtc; 2942 int hdisplay, vdisplay; 2943 int ret; 2944 2945 crtc_state = drm_atomic_get_crtc_state(state, crtc); 2946 if (IS_ERR(crtc_state)) 2947 return PTR_ERR(crtc_state); 2948 2949 primary_state = drm_atomic_get_plane_state(state, crtc->primary); 2950 if (IS_ERR(primary_state)) 2951 return PTR_ERR(primary_state); 2952 2953 if (!set->mode) { 2954 WARN_ON(set->fb); 2955 WARN_ON(set->num_connectors); 2956 2957 ret = drm_atomic_set_mode_for_crtc(crtc_state, NULL); 2958 if (ret != 0) 2959 return ret; 2960 2961 crtc_state->active = false; 2962 2963 ret = drm_atomic_set_crtc_for_plane(primary_state, NULL); 2964 if (ret != 0) 2965 return ret; 2966 2967 drm_atomic_set_fb_for_plane(primary_state, NULL); 2968 2969 goto commit; 2970 } 2971 2972 WARN_ON(!set->fb); 2973 WARN_ON(!set->num_connectors); 2974 2975 ret = drm_atomic_set_mode_for_crtc(crtc_state, set->mode); 2976 if (ret != 0) 2977 return ret; 2978 2979 crtc_state->active = true; 2980 2981 ret = drm_atomic_set_crtc_for_plane(primary_state, crtc); 2982 if (ret != 0) 2983 return ret; 2984 2985 drm_mode_get_hv_timing(set->mode, &hdisplay, &vdisplay); 2986 2987 drm_atomic_set_fb_for_plane(primary_state, set->fb); 2988 primary_state->crtc_x = 0; 2989 primary_state->crtc_y = 0; 2990 primary_state->crtc_w = hdisplay; 2991 primary_state->crtc_h = vdisplay; 2992 primary_state->src_x = set->x << 16; 2993 primary_state->src_y = set->y << 16; 2994 if (drm_rotation_90_or_270(primary_state->rotation)) { 2995 primary_state->src_w = vdisplay << 16; 2996 primary_state->src_h = hdisplay << 16; 2997 } else { 2998 primary_state->src_w = hdisplay << 16; 2999 primary_state->src_h = vdisplay << 16; 3000 } 3001 3002 commit: 3003 ret = update_output_state(state, set); 3004 if (ret) 3005 return ret; 3006 3007 return 0; 3008 } 3009 3010 static int __drm_atomic_helper_disable_all(struct drm_device *dev, 3011 struct drm_modeset_acquire_ctx *ctx, 3012 bool clean_old_fbs) 3013 { 3014 struct drm_atomic_state *state; 3015 struct drm_connector_state *conn_state; 3016 struct drm_connector *conn; 3017 struct drm_plane_state *plane_state; 3018 struct drm_plane *plane; 3019 struct drm_crtc_state *crtc_state; 3020 struct drm_crtc *crtc; 3021 int ret, i; 3022 3023 state = drm_atomic_state_alloc(dev); 3024 if (!state) 3025 return -ENOMEM; 3026 3027 state->acquire_ctx = ctx; 3028 3029 drm_for_each_crtc(crtc, dev) { 3030 crtc_state = drm_atomic_get_crtc_state(state, crtc); 3031 if (IS_ERR(crtc_state)) { 3032 ret = PTR_ERR(crtc_state); 3033 goto free; 3034 } 3035 3036 crtc_state->active = false; 3037 3038 ret = drm_atomic_set_mode_prop_for_crtc(crtc_state, NULL); 3039 if (ret < 0) 3040 goto free; 3041 3042 ret = drm_atomic_add_affected_planes(state, crtc); 3043 if (ret < 0) 3044 goto free; 3045 3046 ret = drm_atomic_add_affected_connectors(state, crtc); 3047 if (ret < 0) 3048 goto free; 3049 } 3050 3051 for_each_new_connector_in_state(state, conn, conn_state, i) { 3052 ret = drm_atomic_set_crtc_for_connector(conn_state, NULL); 3053 if (ret < 0) 3054 goto free; 3055 } 3056 3057 for_each_new_plane_in_state(state, plane, plane_state, i) { 3058 ret = drm_atomic_set_crtc_for_plane(plane_state, NULL); 3059 if (ret < 0) 3060 goto free; 3061 3062 drm_atomic_set_fb_for_plane(plane_state, NULL); 3063 } 3064 3065 ret = drm_atomic_commit(state); 3066 free: 3067 drm_atomic_state_put(state); 3068 return ret; 3069 } 3070 3071 /** 3072 * drm_atomic_helper_disable_all - disable all currently active outputs 3073 * @dev: DRM device 3074 * @ctx: lock acquisition context 3075 * 3076 * Loops through all connectors, finding those that aren't turned off and then 3077 * turns them off by setting their DPMS mode to OFF and deactivating the CRTC 3078 * that they are connected to. 3079 * 3080 * This is used for example in suspend/resume to disable all currently active 3081 * functions when suspending. If you just want to shut down everything at e.g. 3082 * driver unload, look at drm_atomic_helper_shutdown(). 3083 * 3084 * Note that if callers haven't already acquired all modeset locks this might 3085 * return -EDEADLK, which must be handled by calling drm_modeset_backoff(). 3086 * 3087 * Returns: 3088 * 0 on success or a negative error code on failure. 3089 * 3090 * See also: 3091 * drm_atomic_helper_suspend(), drm_atomic_helper_resume() and 3092 * drm_atomic_helper_shutdown(). 3093 */ 3094 int drm_atomic_helper_disable_all(struct drm_device *dev, 3095 struct drm_modeset_acquire_ctx *ctx) 3096 { 3097 return __drm_atomic_helper_disable_all(dev, ctx, false); 3098 } 3099 EXPORT_SYMBOL(drm_atomic_helper_disable_all); 3100 3101 /** 3102 * drm_atomic_helper_shutdown - shutdown all CRTC 3103 * @dev: DRM device 3104 * 3105 * This shuts down all CRTC, which is useful for driver unloading. Shutdown on 3106 * suspend should instead be handled with drm_atomic_helper_suspend(), since 3107 * that also takes a snapshot of the modeset state to be restored on resume. 3108 * 3109 * This is just a convenience wrapper around drm_atomic_helper_disable_all(), 3110 * and it is the atomic version of drm_crtc_force_disable_all(). 3111 */ 3112 void drm_atomic_helper_shutdown(struct drm_device *dev) 3113 { 3114 struct drm_modeset_acquire_ctx ctx; 3115 int ret; 3116 3117 drm_modeset_acquire_init(&ctx, 0); 3118 while (1) { 3119 ret = drm_modeset_lock_all_ctx(dev, &ctx); 3120 if (!ret) 3121 ret = __drm_atomic_helper_disable_all(dev, &ctx, true); 3122 3123 if (ret != -EDEADLK) 3124 break; 3125 3126 drm_modeset_backoff(&ctx); 3127 } 3128 3129 if (ret) 3130 DRM_ERROR("Disabling all crtc's during unload failed with %i\n", ret); 3131 3132 drm_modeset_drop_locks(&ctx); 3133 drm_modeset_acquire_fini(&ctx); 3134 } 3135 EXPORT_SYMBOL(drm_atomic_helper_shutdown); 3136 3137 /** 3138 * drm_atomic_helper_suspend - subsystem-level suspend helper 3139 * @dev: DRM device 3140 * 3141 * Duplicates the current atomic state, disables all active outputs and then 3142 * returns a pointer to the original atomic state to the caller. Drivers can 3143 * pass this pointer to the drm_atomic_helper_resume() helper upon resume to 3144 * restore the output configuration that was active at the time the system 3145 * entered suspend. 3146 * 3147 * Note that it is potentially unsafe to use this. The atomic state object 3148 * returned by this function is assumed to be persistent. Drivers must ensure 3149 * that this holds true. Before calling this function, drivers must make sure 3150 * to suspend fbdev emulation so that nothing can be using the device. 3151 * 3152 * Returns: 3153 * A pointer to a copy of the state before suspend on success or an ERR_PTR()- 3154 * encoded error code on failure. Drivers should store the returned atomic 3155 * state object and pass it to the drm_atomic_helper_resume() helper upon 3156 * resume. 3157 * 3158 * See also: 3159 * drm_atomic_helper_duplicate_state(), drm_atomic_helper_disable_all(), 3160 * drm_atomic_helper_resume(), drm_atomic_helper_commit_duplicated_state() 3161 */ 3162 struct drm_atomic_state *drm_atomic_helper_suspend(struct drm_device *dev) 3163 { 3164 struct drm_modeset_acquire_ctx ctx; 3165 struct drm_atomic_state *state; 3166 int err; 3167 3168 drm_modeset_acquire_init(&ctx, 0); 3169 3170 retry: 3171 err = drm_modeset_lock_all_ctx(dev, &ctx); 3172 if (err < 0) { 3173 state = ERR_PTR(err); 3174 goto unlock; 3175 } 3176 3177 state = drm_atomic_helper_duplicate_state(dev, &ctx); 3178 if (IS_ERR(state)) 3179 goto unlock; 3180 3181 err = drm_atomic_helper_disable_all(dev, &ctx); 3182 if (err < 0) { 3183 drm_atomic_state_put(state); 3184 state = ERR_PTR(err); 3185 goto unlock; 3186 } 3187 3188 unlock: 3189 if (PTR_ERR(state) == -EDEADLK) { 3190 drm_modeset_backoff(&ctx); 3191 goto retry; 3192 } 3193 3194 drm_modeset_drop_locks(&ctx); 3195 drm_modeset_acquire_fini(&ctx); 3196 return state; 3197 } 3198 EXPORT_SYMBOL(drm_atomic_helper_suspend); 3199 3200 /** 3201 * drm_atomic_helper_commit_duplicated_state - commit duplicated state 3202 * @state: duplicated atomic state to commit 3203 * @ctx: pointer to acquire_ctx to use for commit. 3204 * 3205 * The state returned by drm_atomic_helper_duplicate_state() and 3206 * drm_atomic_helper_suspend() is partially invalid, and needs to 3207 * be fixed up before commit. 3208 * 3209 * Returns: 3210 * 0 on success or a negative error code on failure. 3211 * 3212 * See also: 3213 * drm_atomic_helper_suspend() 3214 */ 3215 int drm_atomic_helper_commit_duplicated_state(struct drm_atomic_state *state, 3216 struct drm_modeset_acquire_ctx *ctx) 3217 { 3218 int i, ret; 3219 struct drm_plane *plane; 3220 struct drm_plane_state *new_plane_state; 3221 struct drm_connector *connector; 3222 struct drm_connector_state *new_conn_state; 3223 struct drm_crtc *crtc; 3224 struct drm_crtc_state *new_crtc_state; 3225 3226 state->acquire_ctx = ctx; 3227 3228 for_each_new_plane_in_state(state, plane, new_plane_state, i) 3229 state->planes[i].old_state = plane->state; 3230 3231 for_each_new_crtc_in_state(state, crtc, new_crtc_state, i) 3232 state->crtcs[i].old_state = crtc->state; 3233 3234 for_each_new_connector_in_state(state, connector, new_conn_state, i) 3235 state->connectors[i].old_state = connector->state; 3236 3237 ret = drm_atomic_commit(state); 3238 3239 state->acquire_ctx = NULL; 3240 3241 return ret; 3242 } 3243 EXPORT_SYMBOL(drm_atomic_helper_commit_duplicated_state); 3244 3245 /** 3246 * drm_atomic_helper_resume - subsystem-level resume helper 3247 * @dev: DRM device 3248 * @state: atomic state to resume to 3249 * 3250 * Calls drm_mode_config_reset() to synchronize hardware and software states, 3251 * grabs all modeset locks and commits the atomic state object. This can be 3252 * used in conjunction with the drm_atomic_helper_suspend() helper to 3253 * implement suspend/resume for drivers that support atomic mode-setting. 3254 * 3255 * Returns: 3256 * 0 on success or a negative error code on failure. 3257 * 3258 * See also: 3259 * drm_atomic_helper_suspend() 3260 */ 3261 int drm_atomic_helper_resume(struct drm_device *dev, 3262 struct drm_atomic_state *state) 3263 { 3264 struct drm_modeset_acquire_ctx ctx; 3265 int err; 3266 3267 drm_mode_config_reset(dev); 3268 3269 drm_modeset_acquire_init(&ctx, 0); 3270 while (1) { 3271 err = drm_modeset_lock_all_ctx(dev, &ctx); 3272 if (err) 3273 goto out; 3274 3275 err = drm_atomic_helper_commit_duplicated_state(state, &ctx); 3276 out: 3277 if (err != -EDEADLK) 3278 break; 3279 3280 drm_modeset_backoff(&ctx); 3281 } 3282 3283 drm_atomic_state_put(state); 3284 drm_modeset_drop_locks(&ctx); 3285 drm_modeset_acquire_fini(&ctx); 3286 3287 return err; 3288 } 3289 EXPORT_SYMBOL(drm_atomic_helper_resume); 3290 3291 static int page_flip_common(struct drm_atomic_state *state, 3292 struct drm_crtc *crtc, 3293 struct drm_framebuffer *fb, 3294 struct drm_pending_vblank_event *event, 3295 uint32_t flags) 3296 { 3297 struct drm_plane *plane = crtc->primary; 3298 struct drm_plane_state *plane_state; 3299 struct drm_crtc_state *crtc_state; 3300 int ret = 0; 3301 3302 crtc_state = drm_atomic_get_crtc_state(state, crtc); 3303 if (IS_ERR(crtc_state)) 3304 return PTR_ERR(crtc_state); 3305 3306 crtc_state->event = event; 3307 crtc_state->pageflip_flags = flags; 3308 3309 plane_state = drm_atomic_get_plane_state(state, plane); 3310 if (IS_ERR(plane_state)) 3311 return PTR_ERR(plane_state); 3312 3313 ret = drm_atomic_set_crtc_for_plane(plane_state, crtc); 3314 if (ret != 0) 3315 return ret; 3316 drm_atomic_set_fb_for_plane(plane_state, fb); 3317 3318 /* Make sure we don't accidentally do a full modeset. */ 3319 state->allow_modeset = false; 3320 if (!crtc_state->active) { 3321 DRM_DEBUG_ATOMIC("[CRTC:%d:%s] disabled, rejecting legacy flip\n", 3322 crtc->base.id, crtc->name); 3323 return -EINVAL; 3324 } 3325 3326 return ret; 3327 } 3328 3329 /** 3330 * drm_atomic_helper_page_flip - execute a legacy page flip 3331 * @crtc: DRM crtc 3332 * @fb: DRM framebuffer 3333 * @event: optional DRM event to signal upon completion 3334 * @flags: flip flags for non-vblank sync'ed updates 3335 * @ctx: lock acquisition context 3336 * 3337 * Provides a default &drm_crtc_funcs.page_flip implementation 3338 * using the atomic driver interface. 3339 * 3340 * Returns: 3341 * Returns 0 on success, negative errno numbers on failure. 3342 * 3343 * See also: 3344 * drm_atomic_helper_page_flip_target() 3345 */ 3346 int drm_atomic_helper_page_flip(struct drm_crtc *crtc, 3347 struct drm_framebuffer *fb, 3348 struct drm_pending_vblank_event *event, 3349 uint32_t flags, 3350 struct drm_modeset_acquire_ctx *ctx) 3351 { 3352 struct drm_plane *plane = crtc->primary; 3353 struct drm_atomic_state *state; 3354 int ret = 0; 3355 3356 state = drm_atomic_state_alloc(plane->dev); 3357 if (!state) 3358 return -ENOMEM; 3359 3360 state->acquire_ctx = ctx; 3361 3362 ret = page_flip_common(state, crtc, fb, event, flags); 3363 if (ret != 0) 3364 goto fail; 3365 3366 ret = drm_atomic_nonblocking_commit(state); 3367 fail: 3368 drm_atomic_state_put(state); 3369 return ret; 3370 } 3371 EXPORT_SYMBOL(drm_atomic_helper_page_flip); 3372 3373 /** 3374 * drm_atomic_helper_page_flip_target - do page flip on target vblank period. 3375 * @crtc: DRM crtc 3376 * @fb: DRM framebuffer 3377 * @event: optional DRM event to signal upon completion 3378 * @flags: flip flags for non-vblank sync'ed updates 3379 * @target: specifying the target vblank period when the flip to take effect 3380 * @ctx: lock acquisition context 3381 * 3382 * Provides a default &drm_crtc_funcs.page_flip_target implementation. 3383 * Similar to drm_atomic_helper_page_flip() with extra parameter to specify 3384 * target vblank period to flip. 3385 * 3386 * Returns: 3387 * Returns 0 on success, negative errno numbers on failure. 3388 */ 3389 int drm_atomic_helper_page_flip_target(struct drm_crtc *crtc, 3390 struct drm_framebuffer *fb, 3391 struct drm_pending_vblank_event *event, 3392 uint32_t flags, 3393 uint32_t target, 3394 struct drm_modeset_acquire_ctx *ctx) 3395 { 3396 struct drm_plane *plane = crtc->primary; 3397 struct drm_atomic_state *state; 3398 struct drm_crtc_state *crtc_state; 3399 int ret = 0; 3400 3401 state = drm_atomic_state_alloc(plane->dev); 3402 if (!state) 3403 return -ENOMEM; 3404 3405 state->acquire_ctx = ctx; 3406 3407 ret = page_flip_common(state, crtc, fb, event, flags); 3408 if (ret != 0) 3409 goto fail; 3410 3411 crtc_state = drm_atomic_get_new_crtc_state(state, crtc); 3412 if (WARN_ON(!crtc_state)) { 3413 ret = -EINVAL; 3414 goto fail; 3415 } 3416 crtc_state->target_vblank = target; 3417 3418 ret = drm_atomic_nonblocking_commit(state); 3419 fail: 3420 drm_atomic_state_put(state); 3421 return ret; 3422 } 3423 EXPORT_SYMBOL(drm_atomic_helper_page_flip_target); 3424 3425 /** 3426 * drm_atomic_helper_best_encoder - Helper for 3427 * &drm_connector_helper_funcs.best_encoder callback 3428 * @connector: Connector control structure 3429 * 3430 * This is a &drm_connector_helper_funcs.best_encoder callback helper for 3431 * connectors that support exactly 1 encoder, statically determined at driver 3432 * init time. 3433 */ 3434 struct drm_encoder * 3435 drm_atomic_helper_best_encoder(struct drm_connector *connector) 3436 { 3437 WARN_ON(connector->encoder_ids[1]); 3438 return drm_encoder_find(connector->dev, NULL, connector->encoder_ids[0]); 3439 } 3440 EXPORT_SYMBOL(drm_atomic_helper_best_encoder); 3441 3442 /** 3443 * DOC: atomic state reset and initialization 3444 * 3445 * Both the drm core and the atomic helpers assume that there is always the full 3446 * and correct atomic software state for all connectors, CRTCs and planes 3447 * available. Which is a bit a problem on driver load and also after system 3448 * suspend. One way to solve this is to have a hardware state read-out 3449 * infrastructure which reconstructs the full software state (e.g. the i915 3450 * driver). 3451 * 3452 * The simpler solution is to just reset the software state to everything off, 3453 * which is easiest to do by calling drm_mode_config_reset(). To facilitate this 3454 * the atomic helpers provide default reset implementations for all hooks. 3455 * 3456 * On the upside the precise state tracking of atomic simplifies system suspend 3457 * and resume a lot. For drivers using drm_mode_config_reset() a complete recipe 3458 * is implemented in drm_atomic_helper_suspend() and drm_atomic_helper_resume(). 3459 * For other drivers the building blocks are split out, see the documentation 3460 * for these functions. 3461 */ 3462 3463 /** 3464 * drm_atomic_helper_crtc_reset - default &drm_crtc_funcs.reset hook for CRTCs 3465 * @crtc: drm CRTC 3466 * 3467 * Resets the atomic state for @crtc by freeing the state pointer (which might 3468 * be NULL, e.g. at driver load time) and allocating a new empty state object. 3469 */ 3470 void drm_atomic_helper_crtc_reset(struct drm_crtc *crtc) 3471 { 3472 if (crtc->state) 3473 __drm_atomic_helper_crtc_destroy_state(crtc->state); 3474 3475 kfree(crtc->state); 3476 crtc->state = kzalloc(sizeof(*crtc->state), GFP_KERNEL); 3477 3478 if (crtc->state) 3479 crtc->state->crtc = crtc; 3480 } 3481 EXPORT_SYMBOL(drm_atomic_helper_crtc_reset); 3482 3483 /** 3484 * __drm_atomic_helper_crtc_duplicate_state - copy atomic CRTC state 3485 * @crtc: CRTC object 3486 * @state: atomic CRTC state 3487 * 3488 * Copies atomic state from a CRTC's current state and resets inferred values. 3489 * This is useful for drivers that subclass the CRTC state. 3490 */ 3491 void __drm_atomic_helper_crtc_duplicate_state(struct drm_crtc *crtc, 3492 struct drm_crtc_state *state) 3493 { 3494 memcpy(state, crtc->state, sizeof(*state)); 3495 3496 if (state->mode_blob) 3497 drm_property_blob_get(state->mode_blob); 3498 if (state->degamma_lut) 3499 drm_property_blob_get(state->degamma_lut); 3500 if (state->ctm) 3501 drm_property_blob_get(state->ctm); 3502 if (state->gamma_lut) 3503 drm_property_blob_get(state->gamma_lut); 3504 state->mode_changed = false; 3505 state->active_changed = false; 3506 state->planes_changed = false; 3507 state->connectors_changed = false; 3508 state->color_mgmt_changed = false; 3509 state->zpos_changed = false; 3510 state->commit = NULL; 3511 state->event = NULL; 3512 state->pageflip_flags = 0; 3513 } 3514 EXPORT_SYMBOL(__drm_atomic_helper_crtc_duplicate_state); 3515 3516 /** 3517 * drm_atomic_helper_crtc_duplicate_state - default state duplicate hook 3518 * @crtc: drm CRTC 3519 * 3520 * Default CRTC state duplicate hook for drivers which don't have their own 3521 * subclassed CRTC state structure. 3522 */ 3523 struct drm_crtc_state * 3524 drm_atomic_helper_crtc_duplicate_state(struct drm_crtc *crtc) 3525 { 3526 struct drm_crtc_state *state; 3527 3528 if (WARN_ON(!crtc->state)) 3529 return NULL; 3530 3531 state = kmalloc(sizeof(*state), GFP_KERNEL); 3532 if (state) 3533 __drm_atomic_helper_crtc_duplicate_state(crtc, state); 3534 3535 return state; 3536 } 3537 EXPORT_SYMBOL(drm_atomic_helper_crtc_duplicate_state); 3538 3539 /** 3540 * __drm_atomic_helper_crtc_destroy_state - release CRTC state 3541 * @state: CRTC state object to release 3542 * 3543 * Releases all resources stored in the CRTC state without actually freeing 3544 * the memory of the CRTC state. This is useful for drivers that subclass the 3545 * CRTC state. 3546 */ 3547 void __drm_atomic_helper_crtc_destroy_state(struct drm_crtc_state *state) 3548 { 3549 if (state->commit) { 3550 /* 3551 * In the event that a non-blocking commit returns 3552 * -ERESTARTSYS before the commit_tail work is queued, we will 3553 * have an extra reference to the commit object. Release it, if 3554 * the event has not been consumed by the worker. 3555 * 3556 * state->event may be freed, so we can't directly look at 3557 * state->event->base.completion. 3558 */ 3559 if (state->event && state->commit->abort_completion) 3560 drm_crtc_commit_put(state->commit); 3561 3562 kfree(state->commit->event); 3563 state->commit->event = NULL; 3564 3565 drm_crtc_commit_put(state->commit); 3566 } 3567 3568 drm_property_blob_put(state->mode_blob); 3569 drm_property_blob_put(state->degamma_lut); 3570 drm_property_blob_put(state->ctm); 3571 drm_property_blob_put(state->gamma_lut); 3572 } 3573 EXPORT_SYMBOL(__drm_atomic_helper_crtc_destroy_state); 3574 3575 /** 3576 * drm_atomic_helper_crtc_destroy_state - default state destroy hook 3577 * @crtc: drm CRTC 3578 * @state: CRTC state object to release 3579 * 3580 * Default CRTC state destroy hook for drivers which don't have their own 3581 * subclassed CRTC state structure. 3582 */ 3583 void drm_atomic_helper_crtc_destroy_state(struct drm_crtc *crtc, 3584 struct drm_crtc_state *state) 3585 { 3586 __drm_atomic_helper_crtc_destroy_state(state); 3587 kfree(state); 3588 } 3589 EXPORT_SYMBOL(drm_atomic_helper_crtc_destroy_state); 3590 3591 /** 3592 * drm_atomic_helper_plane_reset - default &drm_plane_funcs.reset hook for planes 3593 * @plane: drm plane 3594 * 3595 * Resets the atomic state for @plane by freeing the state pointer (which might 3596 * be NULL, e.g. at driver load time) and allocating a new empty state object. 3597 */ 3598 void drm_atomic_helper_plane_reset(struct drm_plane *plane) 3599 { 3600 if (plane->state) 3601 __drm_atomic_helper_plane_destroy_state(plane->state); 3602 3603 kfree(plane->state); 3604 plane->state = kzalloc(sizeof(*plane->state), GFP_KERNEL); 3605 3606 if (plane->state) { 3607 plane->state->plane = plane; 3608 plane->state->rotation = DRM_MODE_ROTATE_0; 3609 3610 /* Reset the alpha value to fully opaque if it matters */ 3611 if (plane->alpha_property) 3612 plane->state->alpha = plane->alpha_property->values[1]; 3613 } 3614 } 3615 EXPORT_SYMBOL(drm_atomic_helper_plane_reset); 3616 3617 /** 3618 * __drm_atomic_helper_plane_duplicate_state - copy atomic plane state 3619 * @plane: plane object 3620 * @state: atomic plane state 3621 * 3622 * Copies atomic state from a plane's current state. This is useful for 3623 * drivers that subclass the plane state. 3624 */ 3625 void __drm_atomic_helper_plane_duplicate_state(struct drm_plane *plane, 3626 struct drm_plane_state *state) 3627 { 3628 memcpy(state, plane->state, sizeof(*state)); 3629 3630 if (state->fb) 3631 drm_framebuffer_get(state->fb); 3632 3633 state->fence = NULL; 3634 state->commit = NULL; 3635 } 3636 EXPORT_SYMBOL(__drm_atomic_helper_plane_duplicate_state); 3637 3638 /** 3639 * drm_atomic_helper_plane_duplicate_state - default state duplicate hook 3640 * @plane: drm plane 3641 * 3642 * Default plane state duplicate hook for drivers which don't have their own 3643 * subclassed plane state structure. 3644 */ 3645 struct drm_plane_state * 3646 drm_atomic_helper_plane_duplicate_state(struct drm_plane *plane) 3647 { 3648 struct drm_plane_state *state; 3649 3650 if (WARN_ON(!plane->state)) 3651 return NULL; 3652 3653 state = kmalloc(sizeof(*state), GFP_KERNEL); 3654 if (state) 3655 __drm_atomic_helper_plane_duplicate_state(plane, state); 3656 3657 return state; 3658 } 3659 EXPORT_SYMBOL(drm_atomic_helper_plane_duplicate_state); 3660 3661 /** 3662 * __drm_atomic_helper_plane_destroy_state - release plane state 3663 * @state: plane state object to release 3664 * 3665 * Releases all resources stored in the plane state without actually freeing 3666 * the memory of the plane state. This is useful for drivers that subclass the 3667 * plane state. 3668 */ 3669 void __drm_atomic_helper_plane_destroy_state(struct drm_plane_state *state) 3670 { 3671 if (state->fb) 3672 drm_framebuffer_put(state->fb); 3673 3674 if (state->fence) 3675 dma_fence_put(state->fence); 3676 3677 if (state->commit) 3678 drm_crtc_commit_put(state->commit); 3679 } 3680 EXPORT_SYMBOL(__drm_atomic_helper_plane_destroy_state); 3681 3682 /** 3683 * drm_atomic_helper_plane_destroy_state - default state destroy hook 3684 * @plane: drm plane 3685 * @state: plane state object to release 3686 * 3687 * Default plane state destroy hook for drivers which don't have their own 3688 * subclassed plane state structure. 3689 */ 3690 void drm_atomic_helper_plane_destroy_state(struct drm_plane *plane, 3691 struct drm_plane_state *state) 3692 { 3693 __drm_atomic_helper_plane_destroy_state(state); 3694 kfree(state); 3695 } 3696 EXPORT_SYMBOL(drm_atomic_helper_plane_destroy_state); 3697 3698 /** 3699 * __drm_atomic_helper_connector_reset - reset state on connector 3700 * @connector: drm connector 3701 * @conn_state: connector state to assign 3702 * 3703 * Initializes the newly allocated @conn_state and assigns it to 3704 * the &drm_conector->state pointer of @connector, usually required when 3705 * initializing the drivers or when called from the &drm_connector_funcs.reset 3706 * hook. 3707 * 3708 * This is useful for drivers that subclass the connector state. 3709 */ 3710 void 3711 __drm_atomic_helper_connector_reset(struct drm_connector *connector, 3712 struct drm_connector_state *conn_state) 3713 { 3714 if (conn_state) 3715 conn_state->connector = connector; 3716 3717 connector->state = conn_state; 3718 } 3719 EXPORT_SYMBOL(__drm_atomic_helper_connector_reset); 3720 3721 /** 3722 * drm_atomic_helper_connector_reset - default &drm_connector_funcs.reset hook for connectors 3723 * @connector: drm connector 3724 * 3725 * Resets the atomic state for @connector by freeing the state pointer (which 3726 * might be NULL, e.g. at driver load time) and allocating a new empty state 3727 * object. 3728 */ 3729 void drm_atomic_helper_connector_reset(struct drm_connector *connector) 3730 { 3731 struct drm_connector_state *conn_state = 3732 kzalloc(sizeof(*conn_state), GFP_KERNEL); 3733 3734 if (connector->state) 3735 __drm_atomic_helper_connector_destroy_state(connector->state); 3736 3737 kfree(connector->state); 3738 __drm_atomic_helper_connector_reset(connector, conn_state); 3739 } 3740 EXPORT_SYMBOL(drm_atomic_helper_connector_reset); 3741 3742 /** 3743 * __drm_atomic_helper_connector_duplicate_state - copy atomic connector state 3744 * @connector: connector object 3745 * @state: atomic connector state 3746 * 3747 * Copies atomic state from a connector's current state. This is useful for 3748 * drivers that subclass the connector state. 3749 */ 3750 void 3751 __drm_atomic_helper_connector_duplicate_state(struct drm_connector *connector, 3752 struct drm_connector_state *state) 3753 { 3754 memcpy(state, connector->state, sizeof(*state)); 3755 if (state->crtc) 3756 drm_connector_get(connector); 3757 state->commit = NULL; 3758 3759 /* Don't copy over a writeback job, they are used only once */ 3760 state->writeback_job = NULL; 3761 } 3762 EXPORT_SYMBOL(__drm_atomic_helper_connector_duplicate_state); 3763 3764 /** 3765 * drm_atomic_helper_connector_duplicate_state - default state duplicate hook 3766 * @connector: drm connector 3767 * 3768 * Default connector state duplicate hook for drivers which don't have their own 3769 * subclassed connector state structure. 3770 */ 3771 struct drm_connector_state * 3772 drm_atomic_helper_connector_duplicate_state(struct drm_connector *connector) 3773 { 3774 struct drm_connector_state *state; 3775 3776 if (WARN_ON(!connector->state)) 3777 return NULL; 3778 3779 state = kmalloc(sizeof(*state), GFP_KERNEL); 3780 if (state) 3781 __drm_atomic_helper_connector_duplicate_state(connector, state); 3782 3783 return state; 3784 } 3785 EXPORT_SYMBOL(drm_atomic_helper_connector_duplicate_state); 3786 3787 /** 3788 * drm_atomic_helper_duplicate_state - duplicate an atomic state object 3789 * @dev: DRM device 3790 * @ctx: lock acquisition context 3791 * 3792 * Makes a copy of the current atomic state by looping over all objects and 3793 * duplicating their respective states. This is used for example by suspend/ 3794 * resume support code to save the state prior to suspend such that it can 3795 * be restored upon resume. 3796 * 3797 * Note that this treats atomic state as persistent between save and restore. 3798 * Drivers must make sure that this is possible and won't result in confusion 3799 * or erroneous behaviour. 3800 * 3801 * Note that if callers haven't already acquired all modeset locks this might 3802 * return -EDEADLK, which must be handled by calling drm_modeset_backoff(). 3803 * 3804 * Returns: 3805 * A pointer to the copy of the atomic state object on success or an 3806 * ERR_PTR()-encoded error code on failure. 3807 * 3808 * See also: 3809 * drm_atomic_helper_suspend(), drm_atomic_helper_resume() 3810 */ 3811 struct drm_atomic_state * 3812 drm_atomic_helper_duplicate_state(struct drm_device *dev, 3813 struct drm_modeset_acquire_ctx *ctx) 3814 { 3815 struct drm_atomic_state *state; 3816 struct drm_connector *conn; 3817 struct drm_connector_list_iter conn_iter; 3818 struct drm_plane *plane; 3819 struct drm_crtc *crtc; 3820 int err = 0; 3821 3822 state = drm_atomic_state_alloc(dev); 3823 if (!state) 3824 return ERR_PTR(-ENOMEM); 3825 3826 state->acquire_ctx = ctx; 3827 3828 drm_for_each_crtc(crtc, dev) { 3829 struct drm_crtc_state *crtc_state; 3830 3831 crtc_state = drm_atomic_get_crtc_state(state, crtc); 3832 if (IS_ERR(crtc_state)) { 3833 err = PTR_ERR(crtc_state); 3834 goto free; 3835 } 3836 } 3837 3838 drm_for_each_plane(plane, dev) { 3839 struct drm_plane_state *plane_state; 3840 3841 plane_state = drm_atomic_get_plane_state(state, plane); 3842 if (IS_ERR(plane_state)) { 3843 err = PTR_ERR(plane_state); 3844 goto free; 3845 } 3846 } 3847 3848 drm_connector_list_iter_begin(dev, &conn_iter); 3849 drm_for_each_connector_iter(conn, &conn_iter) { 3850 struct drm_connector_state *conn_state; 3851 3852 conn_state = drm_atomic_get_connector_state(state, conn); 3853 if (IS_ERR(conn_state)) { 3854 err = PTR_ERR(conn_state); 3855 drm_connector_list_iter_end(&conn_iter); 3856 goto free; 3857 } 3858 } 3859 drm_connector_list_iter_end(&conn_iter); 3860 3861 /* clear the acquire context so that it isn't accidentally reused */ 3862 state->acquire_ctx = NULL; 3863 3864 free: 3865 if (err < 0) { 3866 drm_atomic_state_put(state); 3867 state = ERR_PTR(err); 3868 } 3869 3870 return state; 3871 } 3872 EXPORT_SYMBOL(drm_atomic_helper_duplicate_state); 3873 3874 /** 3875 * __drm_atomic_helper_connector_destroy_state - release connector state 3876 * @state: connector state object to release 3877 * 3878 * Releases all resources stored in the connector state without actually 3879 * freeing the memory of the connector state. This is useful for drivers that 3880 * subclass the connector state. 3881 */ 3882 void 3883 __drm_atomic_helper_connector_destroy_state(struct drm_connector_state *state) 3884 { 3885 if (state->crtc) 3886 drm_connector_put(state->connector); 3887 3888 if (state->commit) 3889 drm_crtc_commit_put(state->commit); 3890 } 3891 EXPORT_SYMBOL(__drm_atomic_helper_connector_destroy_state); 3892 3893 /** 3894 * drm_atomic_helper_connector_destroy_state - default state destroy hook 3895 * @connector: drm connector 3896 * @state: connector state object to release 3897 * 3898 * Default connector state destroy hook for drivers which don't have their own 3899 * subclassed connector state structure. 3900 */ 3901 void drm_atomic_helper_connector_destroy_state(struct drm_connector *connector, 3902 struct drm_connector_state *state) 3903 { 3904 __drm_atomic_helper_connector_destroy_state(state); 3905 kfree(state); 3906 } 3907 EXPORT_SYMBOL(drm_atomic_helper_connector_destroy_state); 3908 3909 /** 3910 * drm_atomic_helper_legacy_gamma_set - set the legacy gamma correction table 3911 * @crtc: CRTC object 3912 * @red: red correction table 3913 * @green: green correction table 3914 * @blue: green correction table 3915 * @size: size of the tables 3916 * @ctx: lock acquire context 3917 * 3918 * Implements support for legacy gamma correction table for drivers 3919 * that support color management through the DEGAMMA_LUT/GAMMA_LUT 3920 * properties. See drm_crtc_enable_color_mgmt() and the containing chapter for 3921 * how the atomic color management and gamma tables work. 3922 */ 3923 int drm_atomic_helper_legacy_gamma_set(struct drm_crtc *crtc, 3924 u16 *red, u16 *green, u16 *blue, 3925 uint32_t size, 3926 struct drm_modeset_acquire_ctx *ctx) 3927 { 3928 struct drm_device *dev = crtc->dev; 3929 struct drm_atomic_state *state; 3930 struct drm_crtc_state *crtc_state; 3931 struct drm_property_blob *blob = NULL; 3932 struct drm_color_lut *blob_data; 3933 int i, ret = 0; 3934 bool replaced; 3935 3936 state = drm_atomic_state_alloc(crtc->dev); 3937 if (!state) 3938 return -ENOMEM; 3939 3940 blob = drm_property_create_blob(dev, 3941 sizeof(struct drm_color_lut) * size, 3942 NULL); 3943 if (IS_ERR(blob)) { 3944 ret = PTR_ERR(blob); 3945 blob = NULL; 3946 goto fail; 3947 } 3948 3949 /* Prepare GAMMA_LUT with the legacy values. */ 3950 blob_data = blob->data; 3951 for (i = 0; i < size; i++) { 3952 blob_data[i].red = red[i]; 3953 blob_data[i].green = green[i]; 3954 blob_data[i].blue = blue[i]; 3955 } 3956 3957 state->acquire_ctx = ctx; 3958 crtc_state = drm_atomic_get_crtc_state(state, crtc); 3959 if (IS_ERR(crtc_state)) { 3960 ret = PTR_ERR(crtc_state); 3961 goto fail; 3962 } 3963 3964 /* Reset DEGAMMA_LUT and CTM properties. */ 3965 replaced = drm_property_replace_blob(&crtc_state->degamma_lut, NULL); 3966 replaced |= drm_property_replace_blob(&crtc_state->ctm, NULL); 3967 replaced |= drm_property_replace_blob(&crtc_state->gamma_lut, blob); 3968 crtc_state->color_mgmt_changed |= replaced; 3969 3970 ret = drm_atomic_commit(state); 3971 3972 fail: 3973 drm_atomic_state_put(state); 3974 drm_property_blob_put(blob); 3975 return ret; 3976 } 3977 EXPORT_SYMBOL(drm_atomic_helper_legacy_gamma_set); 3978 3979 /** 3980 * __drm_atomic_helper_private_duplicate_state - copy atomic private state 3981 * @obj: CRTC object 3982 * @state: new private object state 3983 * 3984 * Copies atomic state from a private objects's current state and resets inferred values. 3985 * This is useful for drivers that subclass the private state. 3986 */ 3987 void __drm_atomic_helper_private_obj_duplicate_state(struct drm_private_obj *obj, 3988 struct drm_private_state *state) 3989 { 3990 memcpy(state, obj->state, sizeof(*state)); 3991 } 3992 EXPORT_SYMBOL(__drm_atomic_helper_private_obj_duplicate_state); 3993