Lines Matching +full:led +full:- +full:mode

1 // SPDX-License-Identifier: GPL-2.0-only
3 * LP5521 LED chip driver.
18 #include <linux/platform_data/leds-lp55xx.h>
22 #include "leds-lp55xx-common.h"
44 /* Base register to set LED current */
60 #define LP5521_PWRSAVE_EN 0x20 /* 1 = Power save mode */
62 #define LP5521_CP_MODE_BYPASS 8 /* CP forced to bypass mode */
63 #define LP5521_CP_MODE_1X5 0x10 /* CP forced to 1.5x mode */
64 #define LP5521_CP_MODE_AUTO 0x18 /* Automatic mode selection */
80 #define LP5521_MODE_R_M 0x30 /* Operation Mode Register */
87 #define LP5521_R_IS_LOADING(mode) \ argument
88 ((mode & LP5521_MODE_R_M) == LP5521_LOAD_R)
89 #define LP5521_G_IS_LOADING(mode) \ argument
90 ((mode & LP5521_MODE_G_M) == LP5521_LOAD_G)
91 #define LP5521_B_IS_LOADING(mode) \ argument
92 ((mode & LP5521_MODE_B_M) == LP5521_LOAD_B)
104 /* operation mode change needs to be longer than 153 us */ in lp5521_wait_opmode_done()
114 static void lp5521_set_led_current(struct lp55xx_led *led, u8 led_current) in lp5521_set_led_current() argument
116 led->led_current = led_current; in lp5521_set_led_current()
117 lp55xx_write(led->chip, LP5521_REG_LED_CURRENT_BASE + led->chan_nr, in lp5521_set_led_current()
123 enum lp55xx_engine_index idx = chip->engine_idx; in lp5521_load_engine()
149 enum lp55xx_engine_index idx = chip->engine_idx; in lp5521_stop_engine()
164 u8 mode; in lp5521_run_engine() local
177 * operation mode and enable register should updated at the same time in lp5521_run_engine()
180 ret = lp55xx_read(chip, LP5521_REG_OP_MODE, &mode); in lp5521_run_engine()
188 /* change operation mode to RUN only when each engine is loading */ in lp5521_run_engine()
189 if (LP5521_R_IS_LOADING(mode)) { in lp5521_run_engine()
190 mode = (mode & ~LP5521_MODE_R_M) | LP5521_RUN_R; in lp5521_run_engine()
194 if (LP5521_G_IS_LOADING(mode)) { in lp5521_run_engine()
195 mode = (mode & ~LP5521_MODE_G_M) | LP5521_RUN_G; in lp5521_run_engine()
199 if (LP5521_B_IS_LOADING(mode)) { in lp5521_run_engine()
200 mode = (mode & ~LP5521_MODE_B_M) | LP5521_RUN_B; in lp5521_run_engine()
204 lp55xx_write(chip, LP5521_REG_OP_MODE, mode); in lp5521_run_engine()
214 enum lp55xx_engine_index idx = chip->engine_idx; in lp5521_update_program_memory()
228 while ((offset < size - 1) && (i < LP5521_PROGRAM_LENGTH)) { in lp5521_update_program_memory()
250 return -EINVAL; in lp5521_update_program_memory()
256 dev_err(&chip->cl->dev, "wrong pattern format\n"); in lp5521_update_program_memory()
257 return -EINVAL; in lp5521_update_program_memory()
262 const struct firmware *fw = chip->fw; in lp5521_firmware_loaded()
264 if (fw->size > LP5521_PROGRAM_LENGTH) { in lp5521_firmware_loaded()
265 dev_err(&chip->cl->dev, "firmware data size overflow: %zu\n", in lp5521_firmware_loaded()
266 fw->size); in lp5521_firmware_loaded()
272 * 1) set engine mode to "LOAD" in lp5521_firmware_loaded()
277 lp5521_update_program_memory(chip, fw->data, fw->size); in lp5521_firmware_loaded()
287 * current reg. This is dummy read is required on some platforms - in lp5521_post_init_device()
289 * LP5521_REG_ENABLE register will not have any effect - strange! in lp5521_post_init_device()
293 dev_err(&chip->cl->dev, "error in resetting chip\n"); in lp5521_post_init_device()
297 dev_err(&chip->cl->dev, in lp5521_post_init_device()
300 ret = -EINVAL; in lp5521_post_init_device()
305 /* Set all PWMs to direct control mode */ in lp5521_post_init_device()
317 /* Initialize all channels PWM to zero -> leds off */ in lp5521_post_init_device()
334 struct lp55xx_platform_data *pdata = chip->pdata; in lp5521_run_selftest()
342 if (pdata->clock_mode != LP55XX_CLOCK_EXT) in lp5521_run_selftest()
347 return -EIO; in lp5521_run_selftest()
352 static int lp5521_multicolor_brightness(struct lp55xx_led *led) in lp5521_multicolor_brightness() argument
354 struct lp55xx_chip *chip = led->chip; in lp5521_multicolor_brightness()
358 mutex_lock(&chip->lock); in lp5521_multicolor_brightness()
359 for (i = 0; i < led->mc_cdev.num_colors; i++) { in lp5521_multicolor_brightness()
362 led->mc_cdev.subled_info[i].channel, in lp5521_multicolor_brightness()
363 led->mc_cdev.subled_info[i].brightness); in lp5521_multicolor_brightness()
367 mutex_unlock(&chip->lock); in lp5521_multicolor_brightness()
371 static int lp5521_led_brightness(struct lp55xx_led *led) in lp5521_led_brightness() argument
373 struct lp55xx_chip *chip = led->chip; in lp5521_led_brightness()
376 mutex_lock(&chip->lock); in lp5521_led_brightness()
377 ret = lp55xx_write(chip, LP5521_REG_LED_PWM_BASE + led->chan_nr, in lp5521_led_brightness()
378 led->brightness); in lp5521_led_brightness()
379 mutex_unlock(&chip->lock); in lp5521_led_brightness()
388 struct lp55xx_led *led = i2c_get_clientdata(to_i2c_client(dev)); in show_engine_mode() local
389 struct lp55xx_chip *chip = led->chip; in show_engine_mode()
390 enum lp55xx_engine_mode mode = chip->engines[nr - 1].mode; in show_engine_mode() local
392 switch (mode) { in show_engine_mode()
410 struct lp55xx_led *led = i2c_get_clientdata(to_i2c_client(dev)); in store_engine_mode() local
411 struct lp55xx_chip *chip = led->chip; in store_engine_mode()
412 struct lp55xx_engine *engine = &chip->engines[nr - 1]; in store_engine_mode()
414 mutex_lock(&chip->lock); in store_engine_mode()
416 chip->engine_idx = nr; in store_engine_mode()
420 engine->mode = LP55XX_ENGINE_RUN; in store_engine_mode()
424 engine->mode = LP55XX_ENGINE_LOAD; in store_engine_mode()
427 engine->mode = LP55XX_ENGINE_DISABLED; in store_engine_mode()
430 mutex_unlock(&chip->lock); in store_engine_mode()
442 struct lp55xx_led *led = i2c_get_clientdata(to_i2c_client(dev)); in store_engine_load() local
443 struct lp55xx_chip *chip = led->chip; in store_engine_load()
446 mutex_lock(&chip->lock); in store_engine_load()
448 chip->engine_idx = nr; in store_engine_load()
452 mutex_unlock(&chip->lock); in store_engine_load()
464 struct lp55xx_led *led = i2c_get_clientdata(to_i2c_client(dev)); in lp5521_selftest() local
465 struct lp55xx_chip *chip = led->chip; in lp5521_selftest()
468 mutex_lock(&chip->lock); in lp5521_selftest()
470 mutex_unlock(&chip->lock); in lp5521_selftest()
524 struct lp55xx_led *led; in lp5521_probe() local
525 struct lp55xx_platform_data *pdata = dev_get_platdata(&client->dev); in lp5521_probe()
526 struct device_node *np = dev_of_node(&client->dev); in lp5521_probe()
528 chip = devm_kzalloc(&client->dev, sizeof(*chip), GFP_KERNEL); in lp5521_probe()
530 return -ENOMEM; in lp5521_probe()
532 chip->cfg = &lp5521_cfg; in lp5521_probe()
536 pdata = lp55xx_of_populate_pdata(&client->dev, np, in lp5521_probe()
541 dev_err(&client->dev, "no platform data\n"); in lp5521_probe()
542 return -EINVAL; in lp5521_probe()
546 led = devm_kcalloc(&client->dev, in lp5521_probe()
547 pdata->num_channels, sizeof(*led), GFP_KERNEL); in lp5521_probe()
548 if (!led) in lp5521_probe()
549 return -ENOMEM; in lp5521_probe()
551 chip->cl = client; in lp5521_probe()
552 chip->pdata = pdata; in lp5521_probe()
554 mutex_init(&chip->lock); in lp5521_probe()
556 i2c_set_clientdata(client, led); in lp5521_probe()
562 dev_info(&client->dev, "%s programmable led chip found\n", id->name); in lp5521_probe()
564 ret = lp55xx_register_leds(led, chip); in lp5521_probe()
570 dev_err(&client->dev, "registering sysfs failed\n"); in lp5521_probe()
584 struct lp55xx_led *led = i2c_get_clientdata(client); in lp5521_remove() local
585 struct lp55xx_chip *chip = led->chip; in lp5521_remove()
620 MODULE_DESCRIPTION("LP5521 LED engine");