[Intel-gfx] [PATCH] drm/i915: Support Async Flip on Linear buffers
kernel test robot
lkp at intel.com
Tue Apr 26 23:00:35 UTC 2022
Hi Arun,
Thank you for the patch! Yet something to improve:
[auto build test ERROR on drm-intel/for-linux-next]
[also build test ERROR on drm-tip/drm-tip v5.18-rc4 next-20220426]
[If your patch is applied to the wrong git tree, kindly drop us a note.
And when submitting patch, we suggest to use '--base' as documented in
https://git-scm.com/docs/git-format-patch]
url: https://github.com/intel-lab-lkp/linux/commits/Arun-R-Murthy/drm-i915-Support-Async-Flip-on-Linear-buffers/20220426-200801
base: git://anongit.freedesktop.org/drm-intel for-linux-next
config: i386-randconfig-a002-20220425 (https://download.01.org/0day-ci/archive/20220427/202204270658.1YtrpLya-lkp@intel.com/config)
compiler: clang version 15.0.0 (https://github.com/llvm/llvm-project 1cddcfdc3c683b393df1a5c9063252eb60e52818)
reproduce (this is a W=1 build):
wget https://raw.githubusercontent.com/intel/lkp-tests/master/sbin/make.cross -O ~/bin/make.cross
chmod +x ~/bin/make.cross
# https://github.com/intel-lab-lkp/linux/commit/a31035350521698f7d7656a54a3b7e163257bf70
git remote add linux-review https://github.com/intel-lab-lkp/linux
git fetch --no-tags linux-review Arun-R-Murthy/drm-i915-Support-Async-Flip-on-Linear-buffers/20220426-200801
git checkout a31035350521698f7d7656a54a3b7e163257bf70
# save the config file
mkdir build_dir && cp config build_dir/.config
COMPILER_INSTALL_PATH=$HOME/0day COMPILER=clang make.cross W=1 O=build_dir ARCH=i386 SHELL=/bin/bash
If you fix the issue, kindly add following tag as appropriate
Reported-by: kernel test robot <lkp at intel.com>
All errors (new ones prefixed by >>):
>> drivers/gpu/drm/i915/display/intel_display.c:7532:3: error: unannotated fall-through between switch labels [-Werror,-Wimplicit-fallthrough]
case I915_FORMAT_MOD_X_TILED:
^
drivers/gpu/drm/i915/display/intel_display.c:7532:3: note: insert 'break;' to avoid fall-through
case I915_FORMAT_MOD_X_TILED:
^
break;
1 error generated.
vim +7532 drivers/gpu/drm/i915/display/intel_display.c
b0b2bed2a1305c Ville Syrjälä 2022-02-14 7458
b0b2bed2a1305c Ville Syrjälä 2022-02-14 7459 static int intel_async_flip_check_hw(struct intel_atomic_state *state, struct intel_crtc *crtc)
30ff93af9e19db Karthik B S 2020-09-21 7460 {
30ff93af9e19db Karthik B S 2020-09-21 7461 struct drm_i915_private *i915 = to_i915(state->base.dev);
30ff93af9e19db Karthik B S 2020-09-21 7462 const struct intel_crtc_state *old_crtc_state, *new_crtc_state;
30ff93af9e19db Karthik B S 2020-09-21 7463 const struct intel_plane_state *new_plane_state, *old_plane_state;
30ff93af9e19db Karthik B S 2020-09-21 7464 struct intel_plane *plane;
30ff93af9e19db Karthik B S 2020-09-21 7465 int i;
30ff93af9e19db Karthik B S 2020-09-21 7466
0826edb6a5e5b3 José Roberto de Souza 2021-10-29 7467 old_crtc_state = intel_atomic_get_old_crtc_state(state, crtc);
0826edb6a5e5b3 José Roberto de Souza 2021-10-29 7468 new_crtc_state = intel_atomic_get_new_crtc_state(state, crtc);
0826edb6a5e5b3 José Roberto de Souza 2021-10-29 7469
b0b2bed2a1305c Ville Syrjälä 2022-02-14 7470 if (!new_crtc_state->uapi.async_flip)
b0b2bed2a1305c Ville Syrjälä 2022-02-14 7471 return 0;
b0b2bed2a1305c Ville Syrjälä 2022-02-14 7472
6b4e414ce8dab7 Ville Syrjälä 2022-02-14 7473 if (!new_crtc_state->hw.active) {
6b4e414ce8dab7 Ville Syrjälä 2022-02-14 7474 drm_dbg_kms(&i915->drm,
6b4e414ce8dab7 Ville Syrjälä 2022-02-14 7475 "[CRTC:%d:%s] not active\n",
6b4e414ce8dab7 Ville Syrjälä 2022-02-14 7476 crtc->base.base.id, crtc->base.name);
30ff93af9e19db Karthik B S 2020-09-21 7477 return -EINVAL;
30ff93af9e19db Karthik B S 2020-09-21 7478 }
30ff93af9e19db Karthik B S 2020-09-21 7479
6b4e414ce8dab7 Ville Syrjälä 2022-02-14 7480 if (intel_crtc_needs_modeset(new_crtc_state)) {
6b4e414ce8dab7 Ville Syrjälä 2022-02-14 7481 drm_dbg_kms(&i915->drm,
6b4e414ce8dab7 Ville Syrjälä 2022-02-14 7482 "[CRTC:%d:%s] modeset required\n",
6b4e414ce8dab7 Ville Syrjälä 2022-02-14 7483 crtc->base.base.id, crtc->base.name);
30ff93af9e19db Karthik B S 2020-09-21 7484 return -EINVAL;
30ff93af9e19db Karthik B S 2020-09-21 7485 }
6b4e414ce8dab7 Ville Syrjälä 2022-02-14 7486
30ff93af9e19db Karthik B S 2020-09-21 7487 if (old_crtc_state->active_planes != new_crtc_state->active_planes) {
30ff93af9e19db Karthik B S 2020-09-21 7488 drm_dbg_kms(&i915->drm,
6b4e414ce8dab7 Ville Syrjälä 2022-02-14 7489 "[CRTC:%d:%s] Active planes cannot be in async flip\n",
6b4e414ce8dab7 Ville Syrjälä 2022-02-14 7490 crtc->base.base.id, crtc->base.name);
30ff93af9e19db Karthik B S 2020-09-21 7491 return -EINVAL;
30ff93af9e19db Karthik B S 2020-09-21 7492 }
30ff93af9e19db Karthik B S 2020-09-21 7493
30ff93af9e19db Karthik B S 2020-09-21 7494 for_each_oldnew_intel_plane_in_state(state, plane, old_plane_state,
30ff93af9e19db Karthik B S 2020-09-21 7495 new_plane_state, i) {
0826edb6a5e5b3 José Roberto de Souza 2021-10-29 7496 if (plane->pipe != crtc->pipe)
0826edb6a5e5b3 José Roberto de Souza 2021-10-29 7497 continue;
0826edb6a5e5b3 José Roberto de Souza 2021-10-29 7498
30ff93af9e19db Karthik B S 2020-09-21 7499 /*
2e08437160d1e8 Ville Syrjälä 2022-02-14 7500 * Only async flip capable planes should be in the state
2e08437160d1e8 Ville Syrjälä 2022-02-14 7501 * if we're really about to ask the hardware to perform
2e08437160d1e8 Ville Syrjälä 2022-02-14 7502 * an async flip. We should never get this far otherwise.
30ff93af9e19db Karthik B S 2020-09-21 7503 */
2e08437160d1e8 Ville Syrjälä 2022-02-14 7504 if (drm_WARN_ON(&i915->drm,
2e08437160d1e8 Ville Syrjälä 2022-02-14 7505 new_crtc_state->do_async_flip && !plane->async_flip))
30ff93af9e19db Karthik B S 2020-09-21 7506 return -EINVAL;
30ff93af9e19db Karthik B S 2020-09-21 7507
2e08437160d1e8 Ville Syrjälä 2022-02-14 7508 /*
2e08437160d1e8 Ville Syrjälä 2022-02-14 7509 * Only check async flip capable planes other planes
2e08437160d1e8 Ville Syrjälä 2022-02-14 7510 * may be involved in the initial commit due to
2e08437160d1e8 Ville Syrjälä 2022-02-14 7511 * the wm0/ddb optimization.
2e08437160d1e8 Ville Syrjälä 2022-02-14 7512 *
2e08437160d1e8 Ville Syrjälä 2022-02-14 7513 * TODO maybe should track which planes actually
2e08437160d1e8 Ville Syrjälä 2022-02-14 7514 * were requested to do the async flip...
2e08437160d1e8 Ville Syrjälä 2022-02-14 7515 */
2e08437160d1e8 Ville Syrjälä 2022-02-14 7516 if (!plane->async_flip)
2e08437160d1e8 Ville Syrjälä 2022-02-14 7517 continue;
2e08437160d1e8 Ville Syrjälä 2022-02-14 7518
30ff93af9e19db Karthik B S 2020-09-21 7519 /*
30ff93af9e19db Karthik B S 2020-09-21 7520 * FIXME: This check is kept generic for all platforms.
244dba4cb59637 Lucas De Marchi 2021-07-28 7521 * Need to verify this for all gen9 platforms to enable
30ff93af9e19db Karthik B S 2020-09-21 7522 * this selectively if required.
30ff93af9e19db Karthik B S 2020-09-21 7523 */
30ff93af9e19db Karthik B S 2020-09-21 7524 switch (new_plane_state->hw.fb->modifier) {
a3103535052169 Arun R Murthy 2022-04-26 7525 case DRM_FORMAT_MOD_LINEAR:
a3103535052169 Arun R Murthy 2022-04-26 7526 if (DISPLAY_VER(i915) < 12) {
a3103535052169 Arun R Murthy 2022-04-26 7527 drm_dbg_kms(&i915->drm,
a3103535052169 Arun R Murthy 2022-04-26 7528 "[PLANE:%d:%s] Modifier does not support async flips\n",
a3103535052169 Arun R Murthy 2022-04-26 7529 plane->base.base.id, plane->base.name);
a3103535052169 Arun R Murthy 2022-04-26 7530 return -EINVAL;
a3103535052169 Arun R Murthy 2022-04-26 7531 }
30ff93af9e19db Karthik B S 2020-09-21 @7532 case I915_FORMAT_MOD_X_TILED:
30ff93af9e19db Karthik B S 2020-09-21 7533 case I915_FORMAT_MOD_Y_TILED:
30ff93af9e19db Karthik B S 2020-09-21 7534 case I915_FORMAT_MOD_Yf_TILED:
072ce4164f973b Stanislav Lisovskiy 2022-01-18 7535 case I915_FORMAT_MOD_4_TILED:
30ff93af9e19db Karthik B S 2020-09-21 7536 break;
30ff93af9e19db Karthik B S 2020-09-21 7537 default:
30ff93af9e19db Karthik B S 2020-09-21 7538 drm_dbg_kms(&i915->drm,
6b4e414ce8dab7 Ville Syrjälä 2022-02-14 7539 "[PLANE:%d:%s] Modifier does not support async flips\n",
6b4e414ce8dab7 Ville Syrjälä 2022-02-14 7540 plane->base.base.id, plane->base.name);
30ff93af9e19db Karthik B S 2020-09-21 7541 return -EINVAL;
30ff93af9e19db Karthik B S 2020-09-21 7542 }
30ff93af9e19db Karthik B S 2020-09-21 7543
aaec72ee90bccc Ville Syrjälä 2021-10-18 7544 if (new_plane_state->hw.fb->format->num_planes > 1) {
aaec72ee90bccc Ville Syrjälä 2021-10-18 7545 drm_dbg_kms(&i915->drm,
6b4e414ce8dab7 Ville Syrjälä 2022-02-14 7546 "[PLANE:%d:%s] Planar formats do not support async flips\n",
6b4e414ce8dab7 Ville Syrjälä 2022-02-14 7547 plane->base.base.id, plane->base.name);
aaec72ee90bccc Ville Syrjälä 2021-10-18 7548 return -EINVAL;
aaec72ee90bccc Ville Syrjälä 2021-10-18 7549 }
aaec72ee90bccc Ville Syrjälä 2021-10-18 7550
be6c1dd5ac074d Imre Deak 2021-10-27 7551 if (old_plane_state->view.color_plane[0].mapping_stride !=
be6c1dd5ac074d Imre Deak 2021-10-27 7552 new_plane_state->view.color_plane[0].mapping_stride) {
6b4e414ce8dab7 Ville Syrjälä 2022-02-14 7553 drm_dbg_kms(&i915->drm,
6b4e414ce8dab7 Ville Syrjälä 2022-02-14 7554 "[PLANE:%d:%s] Stride cannot be changed in async flip\n",
6b4e414ce8dab7 Ville Syrjälä 2022-02-14 7555 plane->base.base.id, plane->base.name);
30ff93af9e19db Karthik B S 2020-09-21 7556 return -EINVAL;
30ff93af9e19db Karthik B S 2020-09-21 7557 }
30ff93af9e19db Karthik B S 2020-09-21 7558
30ff93af9e19db Karthik B S 2020-09-21 7559 if (old_plane_state->hw.fb->modifier !=
30ff93af9e19db Karthik B S 2020-09-21 7560 new_plane_state->hw.fb->modifier) {
30ff93af9e19db Karthik B S 2020-09-21 7561 drm_dbg_kms(&i915->drm,
6b4e414ce8dab7 Ville Syrjälä 2022-02-14 7562 "[PLANE:%d:%s] Modifier cannot be changed in async flip\n",
6b4e414ce8dab7 Ville Syrjälä 2022-02-14 7563 plane->base.base.id, plane->base.name);
30ff93af9e19db Karthik B S 2020-09-21 7564 return -EINVAL;
30ff93af9e19db Karthik B S 2020-09-21 7565 }
30ff93af9e19db Karthik B S 2020-09-21 7566
30ff93af9e19db Karthik B S 2020-09-21 7567 if (old_plane_state->hw.fb->format !=
30ff93af9e19db Karthik B S 2020-09-21 7568 new_plane_state->hw.fb->format) {
30ff93af9e19db Karthik B S 2020-09-21 7569 drm_dbg_kms(&i915->drm,
6b4e414ce8dab7 Ville Syrjälä 2022-02-14 7570 "[PLANE:%d:%s] Pixel format cannot be changed in async flip\n",
6b4e414ce8dab7 Ville Syrjälä 2022-02-14 7571 plane->base.base.id, plane->base.name);
30ff93af9e19db Karthik B S 2020-09-21 7572 return -EINVAL;
30ff93af9e19db Karthik B S 2020-09-21 7573 }
30ff93af9e19db Karthik B S 2020-09-21 7574
30ff93af9e19db Karthik B S 2020-09-21 7575 if (old_plane_state->hw.rotation !=
30ff93af9e19db Karthik B S 2020-09-21 7576 new_plane_state->hw.rotation) {
6b4e414ce8dab7 Ville Syrjälä 2022-02-14 7577 drm_dbg_kms(&i915->drm,
6b4e414ce8dab7 Ville Syrjälä 2022-02-14 7578 "[PLANE:%d:%s] Rotation cannot be changed in async flip\n",
6b4e414ce8dab7 Ville Syrjälä 2022-02-14 7579 plane->base.base.id, plane->base.name);
30ff93af9e19db Karthik B S 2020-09-21 7580 return -EINVAL;
30ff93af9e19db Karthik B S 2020-09-21 7581 }
30ff93af9e19db Karthik B S 2020-09-21 7582
30ff93af9e19db Karthik B S 2020-09-21 7583 if (!drm_rect_equals(&old_plane_state->uapi.src, &new_plane_state->uapi.src) ||
30ff93af9e19db Karthik B S 2020-09-21 7584 !drm_rect_equals(&old_plane_state->uapi.dst, &new_plane_state->uapi.dst)) {
30ff93af9e19db Karthik B S 2020-09-21 7585 drm_dbg_kms(&i915->drm,
6b4e414ce8dab7 Ville Syrjälä 2022-02-14 7586 "[PLANE:%d:%s] Size/co-ordinates cannot be changed in async flip\n",
6b4e414ce8dab7 Ville Syrjälä 2022-02-14 7587 plane->base.base.id, plane->base.name);
30ff93af9e19db Karthik B S 2020-09-21 7588 return -EINVAL;
30ff93af9e19db Karthik B S 2020-09-21 7589 }
30ff93af9e19db Karthik B S 2020-09-21 7590
30ff93af9e19db Karthik B S 2020-09-21 7591 if (old_plane_state->hw.alpha != new_plane_state->hw.alpha) {
6b4e414ce8dab7 Ville Syrjälä 2022-02-14 7592 drm_dbg_kms(&i915->drm,
6b4e414ce8dab7 Ville Syrjälä 2022-02-14 7593 "[PLANES:%d:%s] Alpha value cannot be changed in async flip\n",
6b4e414ce8dab7 Ville Syrjälä 2022-02-14 7594 plane->base.base.id, plane->base.name);
30ff93af9e19db Karthik B S 2020-09-21 7595 return -EINVAL;
30ff93af9e19db Karthik B S 2020-09-21 7596 }
30ff93af9e19db Karthik B S 2020-09-21 7597
30ff93af9e19db Karthik B S 2020-09-21 7598 if (old_plane_state->hw.pixel_blend_mode !=
30ff93af9e19db Karthik B S 2020-09-21 7599 new_plane_state->hw.pixel_blend_mode) {
30ff93af9e19db Karthik B S 2020-09-21 7600 drm_dbg_kms(&i915->drm,
6b4e414ce8dab7 Ville Syrjälä 2022-02-14 7601 "[PLANE:%d:%s] Pixel blend mode cannot be changed in async flip\n",
6b4e414ce8dab7 Ville Syrjälä 2022-02-14 7602 plane->base.base.id, plane->base.name);
30ff93af9e19db Karthik B S 2020-09-21 7603 return -EINVAL;
30ff93af9e19db Karthik B S 2020-09-21 7604 }
30ff93af9e19db Karthik B S 2020-09-21 7605
30ff93af9e19db Karthik B S 2020-09-21 7606 if (old_plane_state->hw.color_encoding != new_plane_state->hw.color_encoding) {
30ff93af9e19db Karthik B S 2020-09-21 7607 drm_dbg_kms(&i915->drm,
6b4e414ce8dab7 Ville Syrjälä 2022-02-14 7608 "[PLANE:%d:%s] Color encoding cannot be changed in async flip\n",
6b4e414ce8dab7 Ville Syrjälä 2022-02-14 7609 plane->base.base.id, plane->base.name);
30ff93af9e19db Karthik B S 2020-09-21 7610 return -EINVAL;
30ff93af9e19db Karthik B S 2020-09-21 7611 }
30ff93af9e19db Karthik B S 2020-09-21 7612
30ff93af9e19db Karthik B S 2020-09-21 7613 if (old_plane_state->hw.color_range != new_plane_state->hw.color_range) {
6b4e414ce8dab7 Ville Syrjälä 2022-02-14 7614 drm_dbg_kms(&i915->drm,
6b4e414ce8dab7 Ville Syrjälä 2022-02-14 7615 "[PLANE:%d:%s] Color range cannot be changed in async flip\n",
6b4e414ce8dab7 Ville Syrjälä 2022-02-14 7616 plane->base.base.id, plane->base.name);
30ff93af9e19db Karthik B S 2020-09-21 7617 return -EINVAL;
30ff93af9e19db Karthik B S 2020-09-21 7618 }
ef6ba31dd38405 Anshuman Gupta 2021-09-24 7619
ef6ba31dd38405 Anshuman Gupta 2021-09-24 7620 /* plane decryption is allow to change only in synchronous flips */
6b4e414ce8dab7 Ville Syrjälä 2022-02-14 7621 if (old_plane_state->decrypt != new_plane_state->decrypt) {
6b4e414ce8dab7 Ville Syrjälä 2022-02-14 7622 drm_dbg_kms(&i915->drm,
6b4e414ce8dab7 Ville Syrjälä 2022-02-14 7623 "[PLANE:%d:%s] Decryption cannot be changed in async flip\n",
6b4e414ce8dab7 Ville Syrjälä 2022-02-14 7624 plane->base.base.id, plane->base.name);
ef6ba31dd38405 Anshuman Gupta 2021-09-24 7625 return -EINVAL;
30ff93af9e19db Karthik B S 2020-09-21 7626 }
6b4e414ce8dab7 Ville Syrjälä 2022-02-14 7627 }
30ff93af9e19db Karthik B S 2020-09-21 7628
30ff93af9e19db Karthik B S 2020-09-21 7629 return 0;
30ff93af9e19db Karthik B S 2020-09-21 7630 }
30ff93af9e19db Karthik B S 2020-09-21 7631
--
0-DAY CI Kernel Test Service
https://01.org/lkp
More information about the Intel-gfx
mailing list