提交 a39b9854 编写于 作者: K Kim, Milo 提交者: Bryan Wu

leds-lp5523: set the brightness to 0 forcely on removing the driver

Turning off the brightness of each channel is required
when removing the driver.

So use flush_work() rather than cancel_work_sync() to execute
remaining brightness works.
Signed-off-by: NMilo(Woogyom) Kim <milo.kim@ti.com>
Signed-off-by: NBryan Wu <bryan.wu@canonical.com>
上级 94b43b67
...@@ -974,7 +974,7 @@ static int __devinit lp5523_probe(struct i2c_client *client, ...@@ -974,7 +974,7 @@ static int __devinit lp5523_probe(struct i2c_client *client,
fail2: fail2:
for (i = 0; i < chip->num_leds; i++) { for (i = 0; i < chip->num_leds; i++) {
led_classdev_unregister(&chip->leds[i].cdev); led_classdev_unregister(&chip->leds[i].cdev);
cancel_work_sync(&chip->leds[i].brightness_work); flush_work(&chip->leds[i].brightness_work);
} }
fail1: fail1:
if (pdata->enable) if (pdata->enable)
...@@ -993,7 +993,7 @@ static int lp5523_remove(struct i2c_client *client) ...@@ -993,7 +993,7 @@ static int lp5523_remove(struct i2c_client *client)
for (i = 0; i < chip->num_leds; i++) { for (i = 0; i < chip->num_leds; i++) {
led_classdev_unregister(&chip->leds[i].cdev); led_classdev_unregister(&chip->leds[i].cdev);
cancel_work_sync(&chip->leds[i].brightness_work); flush_work(&chip->leds[i].brightness_work);
} }
if (chip->pdata->enable) if (chip->pdata->enable)
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册