summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorManuel Fombuena <fombuena@outlook.com>2025-02-26 20:06:40 +0300
committerLee Jones <lee@kernel.org>2025-03-13 18:28:26 +0300
commita17d9e736ddd78323e77d3066c1e86371a99023c (patch)
treeda9777f408c7401509db693d17688977bfb619c7
parent6d91124e7edc109f114b1afe6d00d85d0d0ac174 (diff)
downloadlinux-a17d9e736ddd78323e77d3066c1e86371a99023c.tar.xz
leds: leds-st1202: Initialize hardware before DT node child operations
Arguably, there are more chances of errors occurring during the initialization of the hardware, so this should complete successfully before the devicetree node's children are initialized. st1202_dt_init() fills the led_classdev struct. st1202_setup() initializes the hardware. Specifically, resets the chip, enables its phase-shift delay feature, enables the device and disables all the LEDs channels. All that writing to registers, with no input from st1202_dt_init(). Real-world testing corroborates that calling st1202_setup() before st1202_dt_init() doesn't cause any issue during initialization. Switch the order of st1202_dt_init() and st1202_setup() to ensure the hardware is correctly initialized before the led_classdev struct is filled. Signed-off-by: Manuel Fombuena <fombuena@outlook.com> Link: https://lore.kernel.org/r/CWLP123MB54731877A8DC54EDD33F0229C5C22@CWLP123MB5473.GBRP123.PROD.OUTLOOK.COM Signed-off-by: Lee Jones <lee@kernel.org>
-rw-r--r--drivers/leds/leds-st1202.c4
1 files changed, 2 insertions, 2 deletions
diff --git a/drivers/leds/leds-st1202.c b/drivers/leds/leds-st1202.c
index 360e9db78dc1..3ddf2786a745 100644
--- a/drivers/leds/leds-st1202.c
+++ b/drivers/leds/leds-st1202.c
@@ -360,11 +360,11 @@ static int st1202_probe(struct i2c_client *client)
return ret;
chip->client = client;
- ret = st1202_dt_init(chip);
+ ret = st1202_setup(chip);
if (ret < 0)
return ret;
- ret = st1202_setup(chip);
+ ret = st1202_dt_init(chip);
if (ret < 0)
return ret;