diff mbox

[4/6] drm/i915/cnp: Backlight support for CNP.

Message ID 1494287104-13109-5-git-send-email-anusha.srivatsa@intel.com (mailing list archive)
State New, archived
Headers show

Commit Message

Srivatsa, Anusha May 8, 2017, 11:45 p.m. UTC
From: Rodrigo Vivi <rodrigo.vivi@intel.com>

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@intel.com>
Suggested-by: Jani Nikula <jani.nikula@intel.com>
Suggested-by: Ville Syrjala <ville.syrjala@intel.com>
Cc: Ville Syrjala <ville.syrjala@linux.intel.com>
Cc: Jani Nikula <jani.nikula@intel.com>
Signed-off-by: Anusha Srivatsa <anusha.srivatsa@intel.com>
Signed-off-by: Rodrigo Vivi <rodrigo.vivi@intel.com>
---
 drivers/gpu/drm/i915/intel_panel.c | 94 ++++++++++++++++++++++++++++++++++++++
 1 file changed, 94 insertions(+)

Comments

Dhinakaran Pandiyan May 9, 2017, 12:10 a.m. UTC | #1
On Mon, 2017-05-08 at 16:45 -0700, Anusha Srivatsa wrote:
> From: Rodrigo Vivi <rodrigo.vivi@intel.com>

> 

> 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@intel.com>

> Suggested-by: Jani Nikula <jani.nikula@intel.com>

> Suggested-by: Ville Syrjala <ville.syrjala@intel.com>

> Cc: Ville Syrjala <ville.syrjala@linux.intel.com>

> Cc: Jani Nikula <jani.nikula@intel.com>

> Signed-off-by: Anusha Srivatsa <anusha.srivatsa@intel.com>

> Signed-off-by: Rodrigo Vivi <rodrigo.vivi@intel.com>

> ---

>  drivers/gpu/drm/i915/intel_panel.c | 94 ++++++++++++++++++++++++++++++++++++++

>  1 file changed, 94 insertions(+)

> 

> diff --git a/drivers/gpu/drm/i915/intel_panel.c b/drivers/gpu/drm/i915/intel_panel.c

> index cb50c52..22da1e2 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;

> +

> +	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;

> +

> +	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;

> @@ -1239,6 +1282,18 @@ void intel_backlight_device_unregister(struct intel_connector *connector)

>  #endif /* CONFIG_BACKLIGHT_CLASS_DEVICE */

>  

>  /*

> + * CNP: PWM clock frequency is 19.2 MHz or 24 MHz.

> + *      Value is found in SFUSE_STRAP.

> + *      PWM increment = 1

> + */

> +static u32 cnp_hz_to_pwm(struct intel_connector *connector, u32 pwm_freq_hz)

> +{

> +	struct drm_i915_private *dev_priv = to_i915(connector->base.dev);

> +

> +	return DIV_ROUND_CLOSEST(KHz(dev_priv->rawclk_freq), pwm_freq_hz);

> +}

> +

> +/*

>   * BXT: PWM clock frequency = 19.2 MHz.

>   */

>  static u32 bxt_hz_to_pwm(struct intel_connector *connector, u32 pwm_freq_hz)

> @@ -1633,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)

>  {

> @@ -1749,6 +1835,14 @@ intel_panel_init_backlight_funcs(struct intel_panel *panel)

>  		panel->backlight.set = bxt_set_backlight;

>  		panel->backlight.get = bxt_get_backlight;

>  		panel->backlight.hz_to_pwm = bxt_hz_to_pwm;

> +		panel->backlight.hz_to_pwm = bxt_hz_to_pwm;


This diff should not be here.

-DK


> +	} 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;
Srivatsa, Anusha May 9, 2017, 12:11 a.m. UTC | #2
>-----Original Message-----

>From: Pandiyan, Dhinakaran

>Sent: Monday, May 8, 2017 5:10 PM

>To: Srivatsa, Anusha <anusha.srivatsa@intel.com>

>Cc: intel-gfx@lists.freedesktop.org; Vivi, Rodrigo <rodrigo.vivi@intel.com>;

>Nikula, Jani <jani.nikula@intel.com>

>Subject: Re: [Intel-gfx] [PATCH 4/6] drm/i915/cnp: Backlight support for CNP.

>

>On Mon, 2017-05-08 at 16:45 -0700, Anusha Srivatsa wrote:

>> From: Rodrigo Vivi <rodrigo.vivi@intel.com>

>>

>> 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@intel.com>

>> Suggested-by: Jani Nikula <jani.nikula@intel.com>

>> Suggested-by: Ville Syrjala <ville.syrjala@intel.com>

>> Cc: Ville Syrjala <ville.syrjala@linux.intel.com>

>> Cc: Jani Nikula <jani.nikula@intel.com>

>> Signed-off-by: Anusha Srivatsa <anusha.srivatsa@intel.com>

>> Signed-off-by: Rodrigo Vivi <rodrigo.vivi@intel.com>

>> ---

>>  drivers/gpu/drm/i915/intel_panel.c | 94

>> ++++++++++++++++++++++++++++++++++++++

>>  1 file changed, 94 insertions(+)

>>

>> diff --git a/drivers/gpu/drm/i915/intel_panel.c

>> b/drivers/gpu/drm/i915/intel_panel.c

>> index cb50c52..22da1e2 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;

>> +

>> +	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;

>> +

>> +	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; @@ -1239,6 +1282,18

>> @@ void intel_backlight_device_unregister(struct intel_connector

>> *connector)  #endif /* CONFIG_BACKLIGHT_CLASS_DEVICE */

>>

>>  /*

>> + * CNP: PWM clock frequency is 19.2 MHz or 24 MHz.

>> + *      Value is found in SFUSE_STRAP.

>> + *      PWM increment = 1

>> + */

>> +static u32 cnp_hz_to_pwm(struct intel_connector *connector, u32

>> +pwm_freq_hz) {

>> +	struct drm_i915_private *dev_priv = to_i915(connector->base.dev);

>> +

>> +	return DIV_ROUND_CLOSEST(KHz(dev_priv->rawclk_freq),

>pwm_freq_hz); }

>> +

>> +/*

>>   * BXT: PWM clock frequency = 19.2 MHz.

>>   */

>>  static u32 bxt_hz_to_pwm(struct intel_connector *connector, u32

>> pwm_freq_hz) @@ -1633,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)

>>  {

>> @@ -1749,6 +1835,14 @@ intel_panel_init_backlight_funcs(struct intel_panel

>*panel)

>>  		panel->backlight.set = bxt_set_backlight;

>>  		panel->backlight.get = bxt_get_backlight;

>>  		panel->backlight.hz_to_pwm = bxt_hz_to_pwm;

>> +		panel->backlight.hz_to_pwm = bxt_hz_to_pwm;

>

>This diff should not be here.


Ah! Nice catch... Will rebase again and send. 
Thanks a lot.

Anusha

>-DK

>

>

>> +	} 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;
diff mbox

Patch

diff --git a/drivers/gpu/drm/i915/intel_panel.c b/drivers/gpu/drm/i915/intel_panel.c
index cb50c52..22da1e2 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;
+
+	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;
+
+	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;
@@ -1239,6 +1282,18 @@  void intel_backlight_device_unregister(struct intel_connector *connector)
 #endif /* CONFIG_BACKLIGHT_CLASS_DEVICE */
 
 /*
+ * CNP: PWM clock frequency is 19.2 MHz or 24 MHz.
+ *      Value is found in SFUSE_STRAP.
+ *      PWM increment = 1
+ */
+static u32 cnp_hz_to_pwm(struct intel_connector *connector, u32 pwm_freq_hz)
+{
+	struct drm_i915_private *dev_priv = to_i915(connector->base.dev);
+
+	return DIV_ROUND_CLOSEST(KHz(dev_priv->rawclk_freq), pwm_freq_hz);
+}
+
+/*
  * BXT: PWM clock frequency = 19.2 MHz.
  */
 static u32 bxt_hz_to_pwm(struct intel_connector *connector, u32 pwm_freq_hz)
@@ -1633,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)
 {
@@ -1749,6 +1835,14 @@  intel_panel_init_backlight_funcs(struct intel_panel *panel)
 		panel->backlight.set = bxt_set_backlight;
 		panel->backlight.get = bxt_get_backlight;
 		panel->backlight.hz_to_pwm = bxt_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;