]> Git Repo - J-linux.git/commitdiff
leds: leds-lp5569: Enable chip after chip configuration
authorChristian Marangi <[email protected]>
Fri, 12 Jul 2024 00:45:54 +0000 (02:45 +0200)
committerLee Jones <[email protected]>
Fri, 12 Jul 2024 07:32:37 +0000 (08:32 +0100)
Documentation say that clock internal config needs to be set BEFORE chip
is enabled. Align code to this and move the CHIP enable after the CHIP
is configured.

While at it also make use of STATUS reg and check when STARTUP is
completed instead of sleep for 1-2 ms.

Signed-off-by: Christian Marangi <[email protected]>
Link: https://lore.kernel.org/r/[email protected]
Signed-off-by: Lee Jones <[email protected]>
drivers/leds/leds-lp5569.c

index c976b10b65580cd275b726010edca983bafafd4d..786f2aa35319e3de3232a94ea4857ab0bd15e77a 100644 (file)
@@ -8,6 +8,7 @@
 #include <linux/delay.h>
 #include <linux/firmware.h>
 #include <linux/i2c.h>
+#include <linux/iopoll.h>
 #include <linux/leds.h>
 #include <linux/module.h>
 #include <linux/mutex.h>
@@ -92,6 +93,8 @@
 #define LP5569_ENG2_MUX_ADDR           0xd0
 #define LP5569_ENG3_MUX_ADDR           0xe0
 
+#define LP5569_STARTUP_SLEEP           500
+
 #define LEDn_STATUS_FAULT(n, status)   ((status) >> (n) & BIT(0))
 
 #define LP5569_DEFAULT_CONFIG \
@@ -169,14 +172,7 @@ out:
 static int lp5569_post_init_device(struct lp55xx_chip *chip)
 {
        int ret;
-       int val;
-
-       ret = lp55xx_write(chip, LP5569_REG_ENABLE, LP5569_ENABLE);
-       if (ret)
-               return ret;
-
-       /* Chip startup time is 500 us, 1 - 2 ms gives some margin */
-       usleep_range(1000, 2000);
+       u8 val;
 
        val = LP5569_DEFAULT_CONFIG;
        val |= FIELD_PREP(LP5569_CP_MODE_MASK, chip->pdata->charge_pump_mode);
@@ -199,6 +195,13 @@ static int lp5569_post_init_device(struct lp55xx_chip *chip)
                        return ret;
        }
 
+       ret = lp55xx_write(chip, LP5569_REG_ENABLE, LP5569_ENABLE);
+       if (ret)
+               return ret;
+
+       read_poll_timeout(lp55xx_read, ret, !(val & LP5569_STARTUP_BUSY),
+                         LP5569_STARTUP_SLEEP, LP5569_STARTUP_SLEEP * 10, false,
+                         chip, LP5569_REG_STATUS, &val);
 
        return lp5569_init_program_engine(chip);
 }
This page took 0.046824 seconds and 4 git commands to generate.