On 22 October 2012 16:36, Shiraz Hashim <[email protected]> wrote: > Add support for PWM chips present on SPEAr platforms. These PWM > chips support 4 channel output with programmable duty cycle and > frequency. > > More details on these PWM chips can be obtained from relevant > chapter of reference manual, present at following[1] location. > > 1. http://www.st.com/internet/mcu/product/251211.jsp > > Cc: Thierry Reding <[email protected]> > Signed-off-by: Shiraz Hashim <[email protected]> > Signed-off-by: Viresh Kumar <[email protected]> > Reviewed-by: Vipin Kumar <[email protected]>
Acked-by: Viresh Kumar <[email protected]> > diff --git a/drivers/pwm/pwm-spear.c b/drivers/pwm/pwm-spear.c > +static int spear_pwm_probe(struct platform_device *pdev) > +{ > + ret = pwmchip_add(&pc->chip); > + if (ret < 0) { > + dev_err(&pdev->dev, "pwmchip_add() failed: %d\n", ret); > + return ret; > + } Sorry couldn't think of this complex situation earlier :( Can it happen that we get a request for a pwm here and its config or enable gets called...? If yes, then we must call clk_prepare() before doing pwmchip_add?? Otherwise you will see a crash :) @Thierry: Can this happen? > + ret = clk_prepare_enable(pc->clk); > + if (ret < 0) > + return pwmchip_remove(&pc->chip); -- viresh -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to [email protected] More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/

