Commit acf3402d authored by Uwe Kleine-König's avatar Uwe Kleine-König Committed by Thierry Reding

pwm: ab8500: Implement .apply instead of .config, .enable and .disable

To eventually get rid of all legacy drivers convert this driver to the
modern world implementing .apply().
Signed-off-by: default avatarUwe Kleine-König <u.kleine-koenig@pengutronix.de>
Reviewed-by: default avatarLinus Walleij <linus.walleij@linaro.org>
Signed-off-by: default avatarThierry Reding <thierry.reding@gmail.com>
parent ca0d2fb7
...@@ -24,23 +24,37 @@ struct ab8500_pwm_chip { ...@@ -24,23 +24,37 @@ struct ab8500_pwm_chip {
struct pwm_chip chip; struct pwm_chip chip;
}; };
static int ab8500_pwm_config(struct pwm_chip *chip, struct pwm_device *pwm, static int ab8500_pwm_apply(struct pwm_chip *chip, struct pwm_device *pwm,
int duty_ns, int period_ns) const struct pwm_state *state)
{ {
int ret = 0; int ret;
unsigned int higher_val, lower_val;
u8 reg; u8 reg;
unsigned int higher_val, lower_val;
if (state->polarity != PWM_POLARITY_NORMAL)
return -EINVAL;
if (!state->enabled) {
ret = abx500_mask_and_set_register_interruptible(chip->dev,
AB8500_MISC, AB8500_PWM_OUT_CTRL7_REG,
1 << (chip->base - 1), 0);
if (ret < 0)
dev_err(chip->dev, "%s: Failed to disable PWM, Error %d\n",
pwm->label, ret);
return ret;
}
/* /*
* get the first 8 bits that are be written to * get the first 8 bits that are be written to
* AB8500_PWM_OUT_CTRL1_REG[0:7] * AB8500_PWM_OUT_CTRL1_REG[0:7]
*/ */
lower_val = duty_ns & 0x00FF; lower_val = state->duty_cycle & 0x00FF;
/* /*
* get bits [9:10] that are to be written to * get bits [9:10] that are to be written to
* AB8500_PWM_OUT_CTRL2_REG[0:1] * AB8500_PWM_OUT_CTRL2_REG[0:1]
*/ */
higher_val = ((duty_ns & 0x0300) >> 8); higher_val = ((state->duty_cycle & 0x0300) >> 8);
reg = AB8500_PWM_OUT_CTRL1_REG + ((chip->base - 1) * 2); reg = AB8500_PWM_OUT_CTRL1_REG + ((chip->base - 1) * 2);
...@@ -48,15 +62,11 @@ static int ab8500_pwm_config(struct pwm_chip *chip, struct pwm_device *pwm, ...@@ -48,15 +62,11 @@ static int ab8500_pwm_config(struct pwm_chip *chip, struct pwm_device *pwm,
reg, (u8)lower_val); reg, (u8)lower_val);
if (ret < 0) if (ret < 0)
return ret; return ret;
ret = abx500_set_register_interruptible(chip->dev, AB8500_MISC, ret = abx500_set_register_interruptible(chip->dev, AB8500_MISC,
(reg + 1), (u8)higher_val); (reg + 1), (u8)higher_val);
if (ret < 0)
return ret; return ret;
}
static int ab8500_pwm_enable(struct pwm_chip *chip, struct pwm_device *pwm)
{
int ret;
ret = abx500_mask_and_set_register_interruptible(chip->dev, ret = abx500_mask_and_set_register_interruptible(chip->dev,
AB8500_MISC, AB8500_PWM_OUT_CTRL7_REG, AB8500_MISC, AB8500_PWM_OUT_CTRL7_REG,
...@@ -64,25 +74,12 @@ static int ab8500_pwm_enable(struct pwm_chip *chip, struct pwm_device *pwm) ...@@ -64,25 +74,12 @@ static int ab8500_pwm_enable(struct pwm_chip *chip, struct pwm_device *pwm)
if (ret < 0) if (ret < 0)
dev_err(chip->dev, "%s: Failed to enable PWM, Error %d\n", dev_err(chip->dev, "%s: Failed to enable PWM, Error %d\n",
pwm->label, ret); pwm->label, ret);
return ret;
}
static void ab8500_pwm_disable(struct pwm_chip *chip, struct pwm_device *pwm)
{
int ret;
ret = abx500_mask_and_set_register_interruptible(chip->dev, return ret;
AB8500_MISC, AB8500_PWM_OUT_CTRL7_REG,
1 << (chip->base - 1), 0);
if (ret < 0)
dev_err(chip->dev, "%s: Failed to disable PWM, Error %d\n",
pwm->label, ret);
} }
static const struct pwm_ops ab8500_pwm_ops = { static const struct pwm_ops ab8500_pwm_ops = {
.config = ab8500_pwm_config, .apply = ab8500_pwm_apply,
.enable = ab8500_pwm_enable,
.disable = ab8500_pwm_disable,
.owner = THIS_MODULE, .owner = THIS_MODULE,
}; };
......
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