Op 06-01-18 om 10:51 schreef Dhinakaran Pandiyan: > On Thursday, January 4, 2018 12:35:48 PM PST Maarten Lankhorst wrote: >> Op 03-01-18 om 21:39 schreef Dhinakaran Pandiyan: >>> Since we want to allow for a non-blocking power domain for vblanks, >>> the power domain use count and power well use count will not be updated >>> atomically inside the power domain mutex (see next patch). This affects >>> verifying if sum(power_domain_use_count) == power_well_use_count at >>> init time. So do not enable vblanks until this verification is done. >>> >>> Cc: Daniel Vetter <daniel.vetter@xxxxxxxx> >>> Cc: Ville Syrjälä <ville.syrjala@xxxxxxxxxxxxxxx> >>> Cc: Rodrigo Vivi <rodrigo.vivi@xxxxxxxxx> >>> Cc: Maarten Lankhorst <maarten.lankhorst@xxxxxxxxxxxxxxx> >>> Signed-off-by: Dhinakaran Pandiyan <dhinakaran.pandiyan@xxxxxxxxx> >>> --- >>> >>> drivers/gpu/drm/i915/intel_display.c | 24 ++++++++++++++++++++---- >>> 1 file changed, 20 insertions(+), 4 deletions(-) >>> >>> diff --git a/drivers/gpu/drm/i915/intel_display.c >>> b/drivers/gpu/drm/i915/intel_display.c index 0cd355978ab4..7bc874b8dac7 >>> 100644 >>> --- a/drivers/gpu/drm/i915/intel_display.c >>> +++ b/drivers/gpu/drm/i915/intel_display.c >>> @@ -14739,6 +14739,24 @@ static bool has_pch_trancoder(struct >>> drm_i915_private *dev_priv,> >>> (HAS_PCH_LPT_H(dev_priv) && pch_transcoder == PIPE_A); >>> >>> } >>> >>> +static void modeset_enable_vblanks(struct drm_i915_private *dev_priv) >>> +{ >>> + enum pipe pipe; >>> + >>> + for_each_pipe(dev_priv, pipe) { >>> + struct intel_crtc *crtc; >>> + >>> + crtc = intel_get_crtc_for_pipe(dev_priv, pipe); >>> + >>> + /* restore vblank interrupts to correct state */ >>> + drm_crtc_vblank_reset(&crtc->base); >>> + >>> + if (crtc->active) >>> + drm_crtc_vblank_on(&crtc->base); >>> + } >>> +} >>> + >>> + >>> >>> static void intel_sanitize_crtc(struct intel_crtc *crtc, >>> >>> struct drm_modeset_acquire_ctx *ctx) >>> >>> { >>> >>> @@ -14754,13 +14772,9 @@ static void intel_sanitize_crtc(struct intel_crtc >>> *crtc,> >>> I915_READ(reg) & ~PIPECONF_FRAME_START_DELAY_MASK); >>> >>> } >>> >>> - /* restore vblank interrupts to correct state */ >>> - drm_crtc_vblank_reset(&crtc->base); >>> >>> if (crtc->active) { >>> >>> struct intel_plane *plane; >>> >>> - drm_crtc_vblank_on(&crtc->base); >>> - >>> >>> /* Disable everything but the primary plane */ >>> for_each_intel_plane_on_crtc(dev, crtc, plane) { >>> >>> const struct intel_plane_state *plane_state = >>> >>> @@ -15147,6 +15161,8 @@ intel_modeset_setup_hw_state(struct drm_device >>> *dev,> >>> intel_power_domains_verify_state(dev_priv); >>> >>> + modeset_enable_vblanks(dev_priv); >>> + >>> >>> intel_fbc_init_pipe_state(dev_priv); >>> >>> } >> intel_pre_disable_primary_noatomic calls wait_for_vblank, which will fail >> with this patch. Wouldn't it be better to make >> intel_power_domains_verify_state work correctly with the vblank irq? > How about disabling vblanks just before power_domains_verify_state and > enabling it back again? > > Another option is to ignore the check in power_domains_verify_state for > DC_OFF. That would be better, or at least assume it's at most 1 more than calculated.. ~Maarten _______________________________________________ Intel-gfx mailing list Intel-gfx@xxxxxxxxxxxxxxxxxxxxx https://lists.freedesktop.org/mailman/listinfo/intel-gfx