diff options
| author | Linus Torvalds <torvalds@linux-foundation.org> | 2018-04-13 15:46:21 -0700 | 
|---|---|---|
| committer | Linus Torvalds <torvalds@linux-foundation.org> | 2018-04-13 15:46:21 -0700 | 
| commit | daf3ef6e965d1d51d6ec604a8fc9919b75d5ec3c (patch) | |
| tree | 643eeb6adc04a5e0a038d1a1dcbb2f6c8169c47e /drivers/pwm/pwm-stm32.c | |
| parent | 41531f58a6513b86f8f379117eca82502022b4a9 (diff) | |
| parent | 6873842235d678a245a378669f35e145df2441b9 (diff) | |
Merge tag 'pwm/for-4.17-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/thierry.reding/linux-pwm
Pull pwm updates from Thierry Reding:
 "This set of changes adds support for more generations of the RCar
  controller as well as runtime PM support. The JZ4740 driver gains
  support for device tree and can now be used on all Ingenic SoCs.
  Rounding things off is a random assortment of fixes and cleanups all
  across the board"
* tag 'pwm/for-4.17-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/thierry.reding/linux-pwm: (29 commits)
  pwm: rcar: Add suspend/resume support
  pwm: rcar: Use PM Runtime to control module clock
  dt-bindings: pwm: rcar: Add bindings for R-Car M3N support
  pwm: rcar: Fix a condition to prevent mismatch value setting to duty
  pwm: sysfs: Use put_device() instead of kfree()
  dt-bindings: pwm: sunxi: Add new compatible strings
  pwm: sun4i: Simplify controller mapping
  pwm: sun4i: Drop unused .has_rdy member
  pwm: sun4i: Properly check current state
  pwm: Remove depends on AVR32
  pwm: stm32: LPTimer: Use 3 cells ->of_xlate()
  dt-bindings: pwm-stm32-lp: Add #pwm-cells
  pwm: stm32: Protect common prescaler for all channels
  pwm: stm32: Remove unused struct device
  pwm: mediatek: Improve precision in rate calculation
  pwm: mediatek: Remove redundant MODULE_ALIAS entries
  pwm: mediatek: Fix up PWM4 and PWM5 malfunction on MT7623
  pwm: jz4740: Enable for all Ingenic SoCs
  pwm: jz4740: Add support for devicetree
  pwm: jz4740: Implement ->set_polarity()
  ...
Diffstat (limited to 'drivers/pwm/pwm-stm32.c')
| -rw-r--r-- | drivers/pwm/pwm-stm32.c | 22 | 
1 files changed, 18 insertions, 4 deletions
| diff --git a/drivers/pwm/pwm-stm32.c b/drivers/pwm/pwm-stm32.c index 6139512aab7b..2708212933f7 100644 --- a/drivers/pwm/pwm-stm32.c +++ b/drivers/pwm/pwm-stm32.c @@ -1,10 +1,9 @@ +// SPDX-License-Identifier: GPL-2.0  /*   * Copyright (C) STMicroelectronics 2016   *   * Author: Gerald Baeza <gerald.baeza@st.com>   * - * License terms: GNU General Public License (GPL), version 2 - *   * Inspired by timer-stm32.c from Maxime Coquelin   *             pwm-atmel.c from Bo Shen   */ @@ -21,7 +20,7 @@  struct stm32_pwm {  	struct pwm_chip chip; -	struct device *dev; +	struct mutex lock; /* protect pwm config/enable */  	struct clk *clk;  	struct regmap *regmap;  	u32 max_arr; @@ -214,9 +213,23 @@ static int stm32_pwm_apply(struct pwm_chip *chip, struct pwm_device *pwm,  	return ret;  } +static int stm32_pwm_apply_locked(struct pwm_chip *chip, struct pwm_device *pwm, +				  struct pwm_state *state) +{ +	struct stm32_pwm *priv = to_stm32_pwm_dev(chip); +	int ret; + +	/* protect common prescaler for all active channels */ +	mutex_lock(&priv->lock); +	ret = stm32_pwm_apply(chip, pwm, state); +	mutex_unlock(&priv->lock); + +	return ret; +} +  static const struct pwm_ops stm32pwm_ops = {  	.owner = THIS_MODULE, -	.apply = stm32_pwm_apply, +	.apply = stm32_pwm_apply_locked,  };  static int stm32_pwm_set_breakinput(struct stm32_pwm *priv, @@ -336,6 +349,7 @@ static int stm32_pwm_probe(struct platform_device *pdev)  	if (!priv)  		return -ENOMEM; +	mutex_init(&priv->lock);  	priv->regmap = ddata->regmap;  	priv->clk = ddata->clk;  	priv->max_arr = ddata->max_arr; | 
