Sfoglia il codice sorgente

pwm: atmel: correct CDTY calculation

From the datasheet, the actual duty cycle is:

	(period - (1 / clk) * CDTY) / period

This actually correct the polarity of the PWM and solves the issue that
pwm-leds exhibits: when setting a duty cycle of 0 and then disabling a
channel, the level was wrong (1 when the polarity was normal and 0 when
the polarity was inversed).

Signed-off-by: Alexandre Belloni <alexandre.belloni@free-electrons.com>
Acked-by: Nicolas Ferre <nicolas.ferre@atmel.com>
Signed-off-by: Thierry Reding <thierry.reding@gmail.com>
Alexandre Belloni 11 anni fa
parent
commit
916030db43
1 ha cambiato i file con 1 aggiunte e 1 eliminazioni
  1. 1 1
      drivers/pwm/pwm-atmel.c

+ 1 - 1
drivers/pwm/pwm-atmel.c

@@ -133,7 +133,7 @@ static int atmel_pwm_config(struct pwm_chip *chip, struct pwm_device *pwm,
 	prd = div;
 	prd = div;
 	div *= duty_ns;
 	div *= duty_ns;
 	do_div(div, period_ns);
 	do_div(div, period_ns);
-	dty = div;
+	dty = prd - div;
 
 
 	ret = clk_enable(atmel_pwm->clk);
 	ret = clk_enable(atmel_pwm->clk);
 	if (ret) {
 	if (ret) {