提交 28c9266b 编写于 作者: M Milo Kim 提交者: Bryan Wu

leds: lp5521/5523: Fix multiple engine usage bug

Whenever the engine is loaded by the user-application, the operation mode is
reset first. But it has a problem in case of multiple engine used because
previous engine settings are cleared.
The driver should update not whole 8bits but each engine bit by masking.

On the other hands, whole engines should be reset when the driver is unloaded
and on initializing the LP5523 driver.
So, new functions are used for this handling - lp5521/5523_stop_all_engines().

Cc: Pali Rohár <pali.rohar@gmail.com>
Signed-off-by: NMilo Kim <milo.kim@ti.com>
Signed-off-by: NBryan Wu <cooloney@gmail.com>
上级 1f431afd
...@@ -152,12 +152,26 @@ static void lp5521_load_engine(struct lp55xx_chip *chip) ...@@ -152,12 +152,26 @@ static void lp5521_load_engine(struct lp55xx_chip *chip)
lp5521_wait_opmode_done(); lp5521_wait_opmode_done();
} }
static void lp5521_stop_engine(struct lp55xx_chip *chip) static void lp5521_stop_all_engines(struct lp55xx_chip *chip)
{ {
lp55xx_write(chip, LP5521_REG_OP_MODE, 0); lp55xx_write(chip, LP5521_REG_OP_MODE, 0);
lp5521_wait_opmode_done(); lp5521_wait_opmode_done();
} }
static void lp5521_stop_engine(struct lp55xx_chip *chip)
{
enum lp55xx_engine_index idx = chip->engine_idx;
u8 mask[] = {
[LP55XX_ENGINE_1] = LP5521_MODE_R_M,
[LP55XX_ENGINE_2] = LP5521_MODE_G_M,
[LP55XX_ENGINE_3] = LP5521_MODE_B_M,
};
lp55xx_update_bits(chip, LP5521_REG_OP_MODE, mask[idx], 0);
lp5521_wait_opmode_done();
}
static void lp5521_run_engine(struct lp55xx_chip *chip, bool start) static void lp5521_run_engine(struct lp55xx_chip *chip, bool start)
{ {
int ret; int ret;
...@@ -568,7 +582,7 @@ static int lp5521_remove(struct i2c_client *client) ...@@ -568,7 +582,7 @@ static int lp5521_remove(struct i2c_client *client)
struct lp55xx_led *led = i2c_get_clientdata(client); struct lp55xx_led *led = i2c_get_clientdata(client);
struct lp55xx_chip *chip = led->chip; struct lp55xx_chip *chip = led->chip;
lp5521_stop_engine(chip); lp5521_stop_all_engines(chip);
lp55xx_unregister_sysfs(chip); lp55xx_unregister_sysfs(chip);
lp55xx_unregister_leds(led, chip); lp55xx_unregister_leds(led, chip);
lp55xx_deinit_device(chip); lp55xx_deinit_device(chip);
......
...@@ -187,12 +187,26 @@ static void lp5523_load_engine_and_select_page(struct lp55xx_chip *chip) ...@@ -187,12 +187,26 @@ static void lp5523_load_engine_and_select_page(struct lp55xx_chip *chip)
lp55xx_write(chip, LP5523_REG_PROG_PAGE_SEL, page_sel[idx]); lp55xx_write(chip, LP5523_REG_PROG_PAGE_SEL, page_sel[idx]);
} }
static void lp5523_stop_engine(struct lp55xx_chip *chip) static void lp5523_stop_all_engines(struct lp55xx_chip *chip)
{ {
lp55xx_write(chip, LP5523_REG_OP_MODE, 0); lp55xx_write(chip, LP5523_REG_OP_MODE, 0);
lp5523_wait_opmode_done(); lp5523_wait_opmode_done();
} }
static void lp5523_stop_engine(struct lp55xx_chip *chip)
{
enum lp55xx_engine_index idx = chip->engine_idx;
u8 mask[] = {
[LP55XX_ENGINE_1] = LP5523_MODE_ENG1_M,
[LP55XX_ENGINE_2] = LP5523_MODE_ENG2_M,
[LP55XX_ENGINE_3] = LP5523_MODE_ENG3_M,
};
lp55xx_update_bits(chip, LP5523_REG_OP_MODE, mask[idx], 0);
lp5523_wait_opmode_done();
}
static void lp5523_turn_off_channels(struct lp55xx_chip *chip) static void lp5523_turn_off_channels(struct lp55xx_chip *chip)
{ {
int i; int i;
...@@ -303,7 +317,7 @@ static int lp5523_init_program_engine(struct lp55xx_chip *chip) ...@@ -303,7 +317,7 @@ static int lp5523_init_program_engine(struct lp55xx_chip *chip)
} }
out: out:
lp5523_stop_engine(chip); lp5523_stop_all_engines(chip);
return ret; return ret;
} }
...@@ -778,7 +792,7 @@ static int lp5523_remove(struct i2c_client *client) ...@@ -778,7 +792,7 @@ static int lp5523_remove(struct i2c_client *client)
struct lp55xx_led *led = i2c_get_clientdata(client); struct lp55xx_led *led = i2c_get_clientdata(client);
struct lp55xx_chip *chip = led->chip; struct lp55xx_chip *chip = led->chip;
lp5523_stop_engine(chip); lp5523_stop_all_engines(chip);
lp55xx_unregister_sysfs(chip); lp55xx_unregister_sysfs(chip);
lp55xx_unregister_leds(led, chip); lp55xx_unregister_leds(led, chip);
lp55xx_deinit_device(chip); lp55xx_deinit_device(chip);
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册