aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/leds/leds-lp5523.c
diff options
context:
space:
mode:
authorMilo(Woogyom) Kim <milo.kim@ti.com>2013-02-05 03:58:01 -0500
committerBryan Wu <cooloney@gmail.com>2013-02-06 18:59:26 -0500
commitf6c64c6fc8d793b414446f1a655a37b7bfce68e3 (patch)
tree4190d716484d160738eecddf33e98aa162bc5f1b /drivers/leds/leds-lp5523.c
parent86eb7748cef00faa3eaefc8fc450ed30281a09e7 (diff)
leds-lp55xx: do chip specific configuration on device init
Chip specific function is configured when the device is initialized. So _configure() is moved to each device init function. If chip configuration gets failed, the device is de-initialized in each _init_device(), not probe(). For compile error fix, function type declarations are added. Signed-off-by: Milo(Woogyom) Kim <milo.kim@ti.com> Signed-off-by: Bryan Wu <cooloney@gmail.com>
Diffstat (limited to 'drivers/leds/leds-lp5523.c')
-rw-r--r--drivers/leds/leds-lp5523.c26
1 files changed, 19 insertions, 7 deletions
diff --git a/drivers/leds/leds-lp5523.c b/drivers/leds/leds-lp5523.c
index cac492b0abf3..fefe27c3f377 100644
--- a/drivers/leds/leds-lp5523.c
+++ b/drivers/leds/leds-lp5523.c
@@ -953,6 +953,7 @@ static void lp5523_reset_device(struct lp5523_chip *chip)
953 lp5523_write(client, LP5523_REG_RESET, 0xff); 953 lp5523_write(client, LP5523_REG_RESET, 0xff);
954} 954}
955 955
956static void lp5523_deinit_device(struct lp5523_chip *chip);
956static int lp5523_init_device(struct lp5523_chip *chip) 957static int lp5523_init_device(struct lp5523_chip *chip)
957{ 958{
958 struct lp5523_platform_data *pdata = chip->pdata; 959 struct lp5523_platform_data *pdata = chip->pdata;
@@ -978,7 +979,22 @@ static int lp5523_init_device(struct lp5523_chip *chip)
978 * Exact value is not available. 10 - 20ms 979 * Exact value is not available. 10 - 20ms
979 * appears to be enough for reset. 980 * appears to be enough for reset.
980 */ 981 */
981 return lp5523_detect(client); 982 ret = lp5523_detect(client);
983 if (ret)
984 goto err;
985
986 ret = lp5523_configure(client);
987 if (ret < 0) {
988 dev_err(&client->dev, "error configuring chip\n");
989 goto err_config;
990 }
991
992 return 0;
993
994err_config:
995 lp5523_deinit_device(chip);
996err:
997 return ret;
982} 998}
983 999
984static void lp5523_deinit_device(struct lp5523_chip *chip) 1000static void lp5523_deinit_device(struct lp5523_chip *chip)
@@ -1018,7 +1034,7 @@ static int lp5523_probe(struct i2c_client *client,
1018 1034
1019 ret = lp5523_init_device(chip); 1035 ret = lp5523_init_device(chip);
1020 if (ret) 1036 if (ret)
1021 goto fail1; 1037 goto err_init;
1022 1038
1023 dev_info(&client->dev, "%s Programmable led chip found\n", id->name); 1039 dev_info(&client->dev, "%s Programmable led chip found\n", id->name);
1024 1040
@@ -1030,11 +1046,6 @@ static int lp5523_probe(struct i2c_client *client,
1030 goto fail1; 1046 goto fail1;
1031 } 1047 }
1032 } 1048 }
1033 ret = lp5523_configure(client);
1034 if (ret < 0) {
1035 dev_err(&client->dev, "error configuring chip\n");
1036 goto fail1;
1037 }
1038 1049
1039 ret = lp5523_register_leds(chip, id->name); 1050 ret = lp5523_register_leds(chip, id->name);
1040 if (ret) 1051 if (ret)
@@ -1050,6 +1061,7 @@ fail2:
1050 lp5523_unregister_leds(chip); 1061 lp5523_unregister_leds(chip);
1051fail1: 1062fail1:
1052 lp5523_deinit_device(chip); 1063 lp5523_deinit_device(chip);
1064err_init:
1053 return ret; 1065 return ret;
1054} 1066}
1055 1067