pwm_get() in core.c does not save best match before setting period and polarity

From: Ralph Hempel
Date: Tue Sep 09 2014 - 08:22:50 EST


The PWM core does not appear to respect the settings in the pwm_lookup table in the ev3dev projects implementation of a board file. Root cause is that pwm_get() does not save the pwm_lookup entry for the best matching device, and therefore ends up using period and polarity from a pointer that's past the end of the table.

These values are often 0, which translates to PWM_POLARITY_NORMAL, but it can be anything really...

First patch ever submitted - fun times finding this one - the bug was in the last place I looked
-----------------------------------------------------------------------

Make the match loop save the best match so that period and polarity can be set correctly

-----------------------------------------------------------------------


diff --git a/drivers/pwm/core.c b/drivers/pwm/core.c
index 4b66bf0..f244e2c 100644
--- a/drivers/pwm/core.c
+++ b/drivers/pwm/core.c
@@ -605,6 +605,7 @@ struct pwm_device *pwm_get(struct device *dev, const char *con_id)
unsigned int index = 0;
unsigned int best = 0;
struct pwm_lookup *p;
+ struct pwm_lookup *pl = NULL;
unsigned int match;

/* look up via DT first */
@@ -651,6 +652,7 @@ struct pwm_device *pwm_get(struct device *dev, const char *con_id)
}

if (match > best) {
+ pl = p;
chip = pwmchip_find_by_name(p->provider);
index = p->index;

@@ -668,8 +670,8 @@ struct pwm_device *pwm_get(struct device *dev, const char *con_id)
if (IS_ERR(pwm))
return pwm;

- pwm_set_period(pwm, p->period);
- pwm_set_polarity(pwm, p->polarity);
+ pwm_set_period(pwm, pl->period);
+ pwm_set_polarity(pwm, pl->polarity);


return pwm;

Ralph Hempel (rhempel@xxxxxxxxxxxxxxxxxxxxx)
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/