drm/i915/dvo: Use intel_de_rmw() for DVO enable/disable
Replace the hand rolled RMW with intel_de_rmw() in the DVO port enable/disable functions. Also switch to intel_de_posting_read() for the posting read (though maybe it should be just be nuked...). Signed-off-by: Ville Syrjälä <ville.syrjala@linux.intel.com> Link: https://patchwork.freedesktop.org/patch/msgid/20221122120825.26338-9-ville.syrjala@linux.intel.com Reviewed-by: Jani Nikula <jani.nikula@intel.com>
This commit is contained in:
parent
7ce5b3a704
commit
079c4c0c6c
@ -185,11 +185,11 @@ static void intel_disable_dvo(struct intel_atomic_state *state,
|
||||
struct drm_i915_private *i915 = to_i915(encoder->base.dev);
|
||||
struct intel_dvo *intel_dvo = enc_to_dvo(encoder);
|
||||
enum port port = encoder->port;
|
||||
u32 temp = intel_de_read(i915, DVO(port));
|
||||
|
||||
intel_dvo->dev.dev_ops->dpms(&intel_dvo->dev, false);
|
||||
intel_de_write(i915, DVO(port), temp & ~DVO_ENABLE);
|
||||
intel_de_read(i915, DVO(port));
|
||||
|
||||
intel_de_rmw(i915, DVO(port), DVO_ENABLE, 0);
|
||||
intel_de_posting_read(i915, DVO(port));
|
||||
}
|
||||
|
||||
static void intel_enable_dvo(struct intel_atomic_state *state,
|
||||
@ -200,14 +200,13 @@ static void intel_enable_dvo(struct intel_atomic_state *state,
|
||||
struct drm_i915_private *i915 = to_i915(encoder->base.dev);
|
||||
struct intel_dvo *intel_dvo = enc_to_dvo(encoder);
|
||||
enum port port = encoder->port;
|
||||
u32 temp = intel_de_read(i915, DVO(port));
|
||||
|
||||
intel_dvo->dev.dev_ops->mode_set(&intel_dvo->dev,
|
||||
&pipe_config->hw.mode,
|
||||
&pipe_config->hw.adjusted_mode);
|
||||
|
||||
intel_de_write(i915, DVO(port), temp | DVO_ENABLE);
|
||||
intel_de_read(i915, DVO(port));
|
||||
intel_de_rmw(i915, DVO(port), 0, DVO_ENABLE);
|
||||
intel_de_posting_read(i915, DVO(port));
|
||||
|
||||
intel_dvo->dev.dev_ops->dpms(&intel_dvo->dev, true);
|
||||
}
|
||||
|
Loading…
x
Reference in New Issue
Block a user