drm/i915/display/vlv: fix pixel overlap register update
authorAndrzej Hajda <andrzej.hajda@intel.com>
Mon, 19 Dec 2022 09:24:27 +0000 (10:24 +0100)
committerJani Nikula <jani.nikula@intel.com>
Mon, 30 Jan 2023 12:57:07 +0000 (14:57 +0200)
To update properly bits in the register the mask should be used
to clear old value and then the result should be or-ed with new
value, for such updates there is separate helper intel_de_rmw.

Signed-off-by: Andrzej Hajda <andrzej.hajda@intel.com>
Reviewed-by: Jani Nikula <jani.nikula@intel.com>
Signed-off-by: Jani Nikula <jani.nikula@intel.com>
Link: https://patchwork.freedesktop.org/patch/msgid/20221219092428.2515430-1-andrzej.hajda@intel.com
drivers/gpu/drm/i915/display/vlv_dsi.c

index 2289f6b..d9fa325 100644 (file)
@@ -649,23 +649,17 @@ static void intel_dsi_port_enable(struct intel_encoder *encoder,
        enum port port;
 
        if (intel_dsi->dual_link == DSI_DUAL_LINK_FRONT_BACK) {
-               u32 temp;
+               u32 temp = intel_dsi->pixel_overlap;
+
                if (IS_GEMINILAKE(dev_priv) || IS_BROXTON(dev_priv)) {
-                       for_each_dsi_port(port, intel_dsi->ports) {
-                               temp = intel_de_read(dev_priv,
-                                                    MIPI_CTRL(port));
-                               temp &= ~BXT_PIXEL_OVERLAP_CNT_MASK |
-                                       intel_dsi->pixel_overlap <<
-                                       BXT_PIXEL_OVERLAP_CNT_SHIFT;
-                               intel_de_write(dev_priv, MIPI_CTRL(port),
-                                              temp);
-                       }
+                       for_each_dsi_port(port, intel_dsi->ports)
+                               intel_de_rmw(dev_priv, MIPI_CTRL(port),
+                                            BXT_PIXEL_OVERLAP_CNT_MASK,
+                                            temp << BXT_PIXEL_OVERLAP_CNT_SHIFT);
                } else {
-                       temp = intel_de_read(dev_priv, VLV_CHICKEN_3);
-                       temp &= ~PIXEL_OVERLAP_CNT_MASK |
-                                       intel_dsi->pixel_overlap <<
-                                       PIXEL_OVERLAP_CNT_SHIFT;
-                       intel_de_write(dev_priv, VLV_CHICKEN_3, temp);
+                       intel_de_rmw(dev_priv, VLV_CHICKEN_3,
+                                    PIXEL_OVERLAP_CNT_MASK,
+                                    temp << PIXEL_OVERLAP_CNT_SHIFT);
                }
        }