Commit b6a00fae authored by Tim Kryger's avatar Tim Kryger Committed by Thierry Reding

pwm: Add pwmchip_add_with_polarity() API

Add a new function to register a PWM chip with channels that have their
initial polarity as specified by an additional parameter. This benefits
drivers of controllers that by default operate with inversed polarity
by removing the need to modify the polarity during initialization.
Signed-off-by: default avatarTim Kryger <tim.kryger@gmail.com>
Signed-off-by: default avatarJonathan Richardson <jonathar@broadcom.com>
[thierry.reding@gmail.com: export pwmchip_add_with_polarity()]
Signed-off-by: default avatarThierry Reding <thierry.reding@gmail.com>
parent 472ac3dc
...@@ -223,13 +223,16 @@ void *pwm_get_chip_data(struct pwm_device *pwm) ...@@ -223,13 +223,16 @@ void *pwm_get_chip_data(struct pwm_device *pwm)
EXPORT_SYMBOL_GPL(pwm_get_chip_data); EXPORT_SYMBOL_GPL(pwm_get_chip_data);
/** /**
* pwmchip_add() - register a new PWM chip * pwmchip_add_with_polarity() - register a new PWM chip
* @chip: the PWM chip to add * @chip: the PWM chip to add
* @polarity: initial polarity of PWM channels
* *
* Register a new PWM chip. If chip->base < 0 then a dynamically assigned base * Register a new PWM chip. If chip->base < 0 then a dynamically assigned base
* will be used. * will be used. The initial polarity for all channels is specified by the
* @polarity parameter.
*/ */
int pwmchip_add(struct pwm_chip *chip) int pwmchip_add_with_polarity(struct pwm_chip *chip,
enum pwm_polarity polarity)
{ {
struct pwm_device *pwm; struct pwm_device *pwm;
unsigned int i; unsigned int i;
...@@ -259,6 +262,7 @@ int pwmchip_add(struct pwm_chip *chip) ...@@ -259,6 +262,7 @@ int pwmchip_add(struct pwm_chip *chip)
pwm->chip = chip; pwm->chip = chip;
pwm->pwm = chip->base + i; pwm->pwm = chip->base + i;
pwm->hwpwm = i; pwm->hwpwm = i;
pwm->polarity = polarity;
radix_tree_insert(&pwm_tree, pwm->pwm, pwm); radix_tree_insert(&pwm_tree, pwm->pwm, pwm);
} }
...@@ -279,6 +283,19 @@ int pwmchip_add(struct pwm_chip *chip) ...@@ -279,6 +283,19 @@ int pwmchip_add(struct pwm_chip *chip)
mutex_unlock(&pwm_lock); mutex_unlock(&pwm_lock);
return ret; return ret;
} }
EXPORT_SYMBOL_GPL(pwmchip_add_with_polarity);
/**
* pwmchip_add() - register a new PWM chip
* @chip: the PWM chip to add
*
* Register a new PWM chip. If chip->base < 0 then a dynamically assigned base
* will be used. The initial polarity for all channels is normal.
*/
int pwmchip_add(struct pwm_chip *chip)
{
return pwmchip_add_with_polarity(chip, PWM_POLARITY_NORMAL);
}
EXPORT_SYMBOL_GPL(pwmchip_add); EXPORT_SYMBOL_GPL(pwmchip_add);
/** /**
......
...@@ -182,6 +182,8 @@ struct pwm_chip { ...@@ -182,6 +182,8 @@ struct pwm_chip {
int pwm_set_chip_data(struct pwm_device *pwm, void *data); int pwm_set_chip_data(struct pwm_device *pwm, void *data);
void *pwm_get_chip_data(struct pwm_device *pwm); void *pwm_get_chip_data(struct pwm_device *pwm);
int pwmchip_add_with_polarity(struct pwm_chip *chip,
enum pwm_polarity polarity);
int pwmchip_add(struct pwm_chip *chip); int pwmchip_add(struct pwm_chip *chip);
int pwmchip_remove(struct pwm_chip *chip); int pwmchip_remove(struct pwm_chip *chip);
struct pwm_device *pwm_request_from_chip(struct pwm_chip *chip, struct pwm_device *pwm_request_from_chip(struct pwm_chip *chip,
...@@ -217,6 +219,11 @@ static inline int pwmchip_add(struct pwm_chip *chip) ...@@ -217,6 +219,11 @@ static inline int pwmchip_add(struct pwm_chip *chip)
return -EINVAL; return -EINVAL;
} }
static inline int pwmchip_add_inversed(struct pwm_chip *chip)
{
return -EINVAL;
}
static inline int pwmchip_remove(struct pwm_chip *chip) static inline int pwmchip_remove(struct pwm_chip *chip)
{ {
return -EINVAL; return -EINVAL;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment