|
@@ -25,6 +25,7 @@ struct lpc32xx_pwm_chip {
|
|
|
};
|
|
|
|
|
|
#define PWM_ENABLE BIT(31)
|
|
|
+#define PWM_PIN_LEVEL BIT(30)
|
|
|
|
|
|
#define to_lpc32xx_pwm_chip(_chip) \
|
|
|
container_of(_chip, struct lpc32xx_pwm_chip, chip)
|
|
@@ -103,6 +104,7 @@ static int lpc32xx_pwm_probe(struct platform_device *pdev)
|
|
|
struct lpc32xx_pwm_chip *lpc32xx;
|
|
|
struct resource *res;
|
|
|
int ret;
|
|
|
+ u32 val;
|
|
|
|
|
|
lpc32xx = devm_kzalloc(&pdev->dev, sizeof(*lpc32xx), GFP_KERNEL);
|
|
|
if (!lpc32xx)
|
|
@@ -128,6 +130,11 @@ static int lpc32xx_pwm_probe(struct platform_device *pdev)
|
|
|
return ret;
|
|
|
}
|
|
|
|
|
|
+ /* When PWM is disable, configure the output to the default value */
|
|
|
+ val = readl(lpc32xx->base + (lpc32xx->chip.pwms[0].hwpwm << 2));
|
|
|
+ val &= ~PWM_PIN_LEVEL;
|
|
|
+ writel(val, lpc32xx->base + (lpc32xx->chip.pwms[0].hwpwm << 2));
|
|
|
+
|
|
|
platform_set_drvdata(pdev, lpc32xx);
|
|
|
|
|
|
return 0;
|