diff options
author | oliver@schinagl.nl <oliver@schinagl.nl> | 2016-08-25 18:47:09 +0200 |
---|---|---|
committer | Thierry Reding <thierry.reding@gmail.com> | 2016-09-08 10:55:05 +0200 |
commit | fe0e2cf931fc3c156850ae5184e7ecf9576431f8 (patch) | |
tree | ca56774cf1c5cf091b23915a3b807d4914dca4be /drivers/pwm/pwm-lpc18xx-sct.c | |
parent | 42ddcf4f9ebbfeac75fac3851f2807833b222399 (diff) | |
download | linux-stable-fe0e2cf931fc3c156850ae5184e7ecf9576431f8.tar.gz linux-stable-fe0e2cf931fc3c156850ae5184e7ecf9576431f8.tar.bz2 linux-stable-fe0e2cf931fc3c156850ae5184e7ecf9576431f8.zip |
pwm: lpc-18xx: use pwm_set_chip_data
The lpc-18xx driver currently manipulates the pwm_device struct directly
rather than using the pwm_set_chip_data() function. While the current
method may save a clock cycle or two, using the explicit function call
makes it more obvious that data is set to the local chip data pointer.
Signed-off-by: Olliver Schinagl <oliver@schinagl.nl>
Reviewed-by: Ariel D'Alessandro <ariel@vanguardiasur.com.ar>
Signed-off-by: Thierry Reding <thierry.reding@gmail.com>
Diffstat (limited to 'drivers/pwm/pwm-lpc18xx-sct.c')
-rw-r--r-- | drivers/pwm/pwm-lpc18xx-sct.c | 12 |
1 files changed, 8 insertions, 4 deletions
diff --git a/drivers/pwm/pwm-lpc18xx-sct.c b/drivers/pwm/pwm-lpc18xx-sct.c index 19dc64cab2f0..d7f5f7de030d 100644 --- a/drivers/pwm/pwm-lpc18xx-sct.c +++ b/drivers/pwm/pwm-lpc18xx-sct.c @@ -413,14 +413,18 @@ static int lpc18xx_pwm_probe(struct platform_device *pdev) } for (i = 0; i < lpc18xx_pwm->chip.npwm; i++) { + struct lpc18xx_pwm_data *data; + pwm = &lpc18xx_pwm->chip.pwms[i]; - pwm->chip_data = devm_kzalloc(lpc18xx_pwm->dev, - sizeof(struct lpc18xx_pwm_data), - GFP_KERNEL); - if (!pwm->chip_data) { + + data = devm_kzalloc(lpc18xx_pwm->dev, sizeof(*data), + GFP_KERNEL); + if (!data) { ret = -ENOMEM; goto remove_pwmchip; } + + pwm_set_chip_data(pwm, data); } platform_set_drvdata(pdev, lpc18xx_pwm); |