Merge tag 'drm-intel-fixes-2022-03-10' of git://anongit.freedesktop.org/drm/drm-intel into drm-fixes

- Fix PSR2 when selective fetch is enabled and cursor at (-1, -1) (Jouni Högander)

Signed-off-by: Dave Airlie <airlied@redhat.com>
From: Tvrtko Ursulin <tvrtko.ursulin@linux.intel.com>
Link: https://patchwork.freedesktop.org/patch/msgid/YinTFSFg++HvuFpZ@tursulin-mobl2

Changed files
+15 -2
drivers
gpu
drm
i915
+14 -2
drivers/gpu/drm/i915/display/intel_psr.c
··· 1406 1406 PSR2_MAN_TRK_CTL_SF_SINGLE_FULL_FRAME; 1407 1407 } 1408 1408 1409 + static inline u32 man_trk_ctl_partial_frame_bit_get(struct drm_i915_private *dev_priv) 1410 + { 1411 + return IS_ALDERLAKE_P(dev_priv) ? 1412 + ADLP_PSR2_MAN_TRK_CTL_SF_PARTIAL_FRAME_UPDATE : 1413 + PSR2_MAN_TRK_CTL_SF_PARTIAL_FRAME_UPDATE; 1414 + } 1415 + 1409 1416 static void psr_force_hw_tracking_exit(struct intel_dp *intel_dp) 1410 1417 { 1411 1418 struct drm_i915_private *dev_priv = dp_to_i915(intel_dp); ··· 1517 1510 { 1518 1511 struct intel_crtc *crtc = to_intel_crtc(crtc_state->uapi.crtc); 1519 1512 struct drm_i915_private *dev_priv = to_i915(crtc->base.dev); 1520 - u32 val = PSR2_MAN_TRK_CTL_ENABLE; 1513 + u32 val = 0; 1514 + 1515 + if (!IS_ALDERLAKE_P(dev_priv)) 1516 + val = PSR2_MAN_TRK_CTL_ENABLE; 1517 + 1518 + /* SF partial frame enable has to be set even on full update */ 1519 + val |= man_trk_ctl_partial_frame_bit_get(dev_priv); 1521 1520 1522 1521 if (full_update) { 1523 1522 /* ··· 1543 1530 } else { 1544 1531 drm_WARN_ON(crtc_state->uapi.crtc->dev, clip->y1 % 4 || clip->y2 % 4); 1545 1532 1546 - val |= PSR2_MAN_TRK_CTL_SF_PARTIAL_FRAME_UPDATE; 1547 1533 val |= PSR2_MAN_TRK_CTL_SU_REGION_START_ADDR(clip->y1 / 4 + 1); 1548 1534 val |= PSR2_MAN_TRK_CTL_SU_REGION_END_ADDR(clip->y2 / 4 + 1); 1549 1535 }
+1
drivers/gpu/drm/i915/i915_reg.h
··· 4829 4829 #define ADLP_PSR2_MAN_TRK_CTL_SU_REGION_START_ADDR(val) REG_FIELD_PREP(ADLP_PSR2_MAN_TRK_CTL_SU_REGION_START_ADDR_MASK, val) 4830 4830 #define ADLP_PSR2_MAN_TRK_CTL_SU_REGION_END_ADDR_MASK REG_GENMASK(12, 0) 4831 4831 #define ADLP_PSR2_MAN_TRK_CTL_SU_REGION_END_ADDR(val) REG_FIELD_PREP(ADLP_PSR2_MAN_TRK_CTL_SU_REGION_END_ADDR_MASK, val) 4832 + #define ADLP_PSR2_MAN_TRK_CTL_SF_PARTIAL_FRAME_UPDATE REG_BIT(31) 4832 4833 #define ADLP_PSR2_MAN_TRK_CTL_SF_SINGLE_FULL_FRAME REG_BIT(14) 4833 4834 #define ADLP_PSR2_MAN_TRK_CTL_SF_CONTINUOS_FULL_FRAME REG_BIT(13) 4834 4835