On Fri, 05 May 2017, "Srivatsa, Anusha" <anusha.srivatsa@xxxxxxxxx> wrote: >>-----Original Message----- >>From: Nikula, Jani >>Sent: Thursday, May 4, 2017 2:25 AM >>To: Srivatsa, Anusha <anusha.srivatsa@xxxxxxxxx>; intel- >>gfx@xxxxxxxxxxxxxxxxxxxxx >>Cc: Vivi, Rodrigo <rodrigo.vivi@xxxxxxxxx>; Ville Syrjala >><ville.syrjala@xxxxxxxxxxxxxxx>; Srivatsa, Anusha <anusha.srivatsa@xxxxxxxxx> >>Subject: Re: [PATCH] drm/i915/cnp: Backlight support for CNP. >> >>On Wed, 03 May 2017, Anusha Srivatsa <anusha.srivatsa@xxxxxxxxx> wrote: >>> From: Rodrigo Vivi <rodrigo.vivi@xxxxxxxxx> >>> >>> Split out BXT and CNP's setup_backlight(),enable_backlight(), >>> disable_backlight() and hz_to_pwm() into two separate functions >>> instead of reusing BXT function. >>> >>> Reuse set_backlight() and get_backlight() since they have no reference >>> to the utility pin. >>> >>> v2: Reuse BXT functions with controller 0 instead of >>> redefining it. (Jani). >>> Use dev_priv->rawclk_freq instead of getting the value >>> from SFUSE_STRAP. >>> v3: Avoid setup backligh controller along with hooks and >>> fully reuse hooks setup as suggested by Jani. >>> v4: Clean up commit message. >>> v5: Implement per PCH instead per platform. >>> >>> v6: Introduce a new function for CNP.(Jani and Ville) >>> >>> v7: Squash the all CNP Backlight support patches into a single patch. >>> (Jani) >>> >>> v8: Correct indentation, remove unneeded blank lines and correct mail >>> address (Jani). >>> >>> Reviewed-by: Jani Nikula <jani.nikula@xxxxxxxxx> >> >>Yup. What's the plan for merging the series, incl. this patch? > > Yes. This will be merged as part of CNP series. Of course, but what's the plan for merging the series? BR, Jani. > > Anusha >>BR, >>Jani. >> >> >>> Suggested-by: Jani Nikula <jani.nikula@xxxxxxxxx> >>> Suggested-by: Ville Syrjala <ville.syrjala@xxxxxxxxx> >>> Cc: Ville Syrjala <ville.syrjala@xxxxxxxxxxxxxxx> >>> Cc: Jani Nikula <jani.nikula@xxxxxxxxx> >>> Signed-off-by: Anusha Srivatsa <anusha.srivatsa@xxxxxxxxx> >>> Signed-off-by: Rodrigo Vivi <rodrigo.vivi@xxxxxxxxx> >>> --- >>> drivers/gpu/drm/i915/intel_panel.c | 88 >>> +++++++++++++++++++++++++++++++++++--- >>> 1 file changed, 83 insertions(+), 5 deletions(-) >>> >>> diff --git a/drivers/gpu/drm/i915/intel_panel.c >>> b/drivers/gpu/drm/i915/intel_panel.c >>> index 1978bec..8ee61c1 100644 >>> --- a/drivers/gpu/drm/i915/intel_panel.c >>> +++ b/drivers/gpu/drm/i915/intel_panel.c >>> @@ -796,6 +796,19 @@ static void bxt_disable_backlight(struct >>intel_connector *connector) >>> } >>> } >>> >>> +static void cnp_disable_backlight(struct intel_connector *connector) >>> +{ >>> + struct drm_i915_private *dev_priv = to_i915(connector->base.dev); >>> + struct intel_panel *panel = &connector->panel; >>> + u32 tmp, val; >>> + >>> + intel_panel_actually_set_backlight(connector, 0); >>> + >>> + tmp = I915_READ(BXT_BLC_PWM_CTL(panel->backlight.controller)); >>> + I915_WRITE(BXT_BLC_PWM_CTL(panel->backlight.controller), >>> + tmp & ~BXT_BLC_PWM_ENABLE); >>> +} >>> + >>> static void pwm_disable_backlight(struct intel_connector *connector) >>> { >>> struct intel_panel *panel = &connector->panel; @@ -1076,6 +1089,36 >>> @@ static void bxt_enable_backlight(struct intel_connector *connector) >>> pwm_ctl | BXT_BLC_PWM_ENABLE); >>> } >>> >>> +static void cnp_enable_backlight(struct intel_connector *connector) { >>> + struct drm_i915_private *dev_priv = to_i915(connector->base.dev); >>> + struct intel_panel *panel = &connector->panel; >>> + enum pipe pipe = intel_get_pipe_from_connector(connector); >>> + u32 pwm_ctl, val; >>> + >>> + pwm_ctl = I915_READ(BXT_BLC_PWM_CTL(panel->backlight.controller)); >>> + if (pwm_ctl & BXT_BLC_PWM_ENABLE) { >>> + DRM_DEBUG_KMS("backlight already enabled\n"); >>> + pwm_ctl &= ~BXT_BLC_PWM_ENABLE; >>> + I915_WRITE(BXT_BLC_PWM_CTL(panel->backlight.controller), >>> + pwm_ctl); >>> + } >>> + >>> + I915_WRITE(BXT_BLC_PWM_FREQ(panel->backlight.controller), >>> + panel->backlight.max); >>> + >>> + intel_panel_actually_set_backlight(connector, >>> +panel->backlight.level); >>> + >>> + pwm_ctl = 0; >>> + if (panel->backlight.active_low_pwm) >>> + pwm_ctl |= BXT_BLC_PWM_POLARITY; >>> + >>> + I915_WRITE(BXT_BLC_PWM_CTL(panel->backlight.controller), pwm_ctl); >>> + POSTING_READ(BXT_BLC_PWM_CTL(panel->backlight.controller)); >>> + I915_WRITE(BXT_BLC_PWM_CTL(panel->backlight.controller), >>> + pwm_ctl | BXT_BLC_PWM_ENABLE); >>> +} >>> + >>> static void pwm_enable_backlight(struct intel_connector *connector) >>> { >>> struct intel_panel *panel = &connector->panel; @@ -1645,6 +1688,37 >>> @@ bxt_setup_backlight(struct intel_connector *connector, enum pipe >>unused) >>> return 0; >>> } >>> >>> +static int >>> +cnp_setup_backlight(struct intel_connector *connector, enum pipe >>> +unused) { >>> + struct drm_i915_private *dev_priv = to_i915(connector->base.dev); >>> + struct intel_panel *panel = &connector->panel; >>> + u32 pwm_ctl, val; >>> + >>> + panel->backlight.controller = dev_priv->vbt.backlight.controller; >>> + >>> + pwm_ctl = I915_READ(BXT_BLC_PWM_CTL(panel->backlight.controller)); >>> + >>> + panel->backlight.active_low_pwm = pwm_ctl & >>BXT_BLC_PWM_POLARITY; >>> + panel->backlight.max = >>> + I915_READ(BXT_BLC_PWM_FREQ(panel->backlight.controller)); >>> + >>> + if (!panel->backlight.max) >>> + panel->backlight.max = get_backlight_max_vbt(connector); >>> + >>> + if (!panel->backlight.max) >>> + return -ENODEV; >>> + >>> + val = bxt_get_backlight(connector); >>> + val = intel_panel_compute_brightness(connector, val); >>> + panel->backlight.level = clamp(val, panel->backlight.min, >>> + panel->backlight.max); >>> + >>> + panel->backlight.enabled = pwm_ctl & BXT_BLC_PWM_ENABLE; >>> + >>> + return 0; >>> +} >>> + >>> static int pwm_setup_backlight(struct intel_connector *connector, >>> enum pipe pipe) >>> { >>> @@ -1754,16 +1828,20 @@ intel_panel_init_backlight_funcs(struct intel_panel >>*panel) >>> intel_dsi_dcs_init_backlight_funcs(connector) == 0) >>> return; >>> >>> - if (IS_GEN9_LP(dev_priv) || HAS_PCH_CNP(dev_priv)) { >>> + if (IS_GEN9_LP(dev_priv)) { >>> panel->backlight.setup = bxt_setup_backlight; >>> panel->backlight.enable = bxt_enable_backlight; >>> panel->backlight.disable = bxt_disable_backlight; >>> panel->backlight.set = bxt_set_backlight; >>> panel->backlight.get = bxt_get_backlight; >>> - if (IS_GEN9_LP(dev_priv)) >>> - panel->backlight.hz_to_pwm = bxt_hz_to_pwm; >>> - else >>> - panel->backlight.hz_to_pwm = cnp_hz_to_pwm; >>> + panel->backlight.hz_to_pwm = bxt_hz_to_pwm; >>> + } else if (HAS_PCH_CNP(dev_priv)) { >>> + panel->backlight.setup = cnp_setup_backlight; >>> + panel->backlight.enable = cnp_enable_backlight; >>> + panel->backlight.disable = cnp_disable_backlight; >>> + panel->backlight.set = bxt_set_backlight; >>> + panel->backlight.get = bxt_get_backlight; >>> + panel->backlight.hz_to_pwm = cnp_hz_to_pwm; >>> } else if (HAS_PCH_LPT(dev_priv) || HAS_PCH_SPT(dev_priv) || >>> HAS_PCH_KBP(dev_priv)) { >>> panel->backlight.setup = lpt_setup_backlight; >> >>-- >>Jani Nikula, Intel Open Source Technology Center -- Jani Nikula, Intel Open Source Technology Center _______________________________________________ Intel-gfx mailing list Intel-gfx@xxxxxxxxxxxxxxxxxxxxx https://lists.freedesktop.org/mailman/listinfo/intel-gfx