diff options
author | Milo(Woogyom) Kim <milo.kim@ti.com> | 2013-02-05 05:07:34 -0500 |
---|---|---|
committer | Bryan Wu <cooloney@gmail.com> | 2013-02-06 18:59:28 -0500 |
commit | 0e2023463a3c9412728cb2c36c79aca0bb731cc8 (patch) | |
tree | d88e84842ab9b3fcca01e56da349f7c94e61ae0a | |
parent | 9e9b3db1b2f725bacaf1b7e8708a0c78265bde97 (diff) |
leds-lp55xx: use lp55xx_init_led() common function
lp5521_init_led() and lp5523_init_led() are replaced with one common function,
lp55xx_init_led().
Max channels is configurable, so it's used in lp55xx_init_led().
'LP5523_LEDS' are changed to 'LP5523_MAX_LEDS'.
lp55xx_set_brightness, lp55xx_led_attributes: skeleton
Will be filled in next patches.
Signed-off-by: Milo(Woogyom) Kim <milo.kim@ti.com>
Signed-off-by: Bryan Wu <cooloney@gmail.com>
-rw-r--r-- | drivers/leds/leds-lp5521.c | 50 | ||||
-rw-r--r-- | drivers/leds/leds-lp5523.c | 62 | ||||
-rw-r--r-- | drivers/leds/leds-lp55xx-common.c | 66 | ||||
-rw-r--r-- | drivers/leds/leds-lp55xx-common.h | 2 |
4 files changed, 76 insertions, 104 deletions
diff --git a/drivers/leds/leds-lp5521.c b/drivers/leds/leds-lp5521.c index dc58f4106d09..bda03049fb3c 100644 --- a/drivers/leds/leds-lp5521.c +++ b/drivers/leds/leds-lp5521.c | |||
@@ -689,55 +689,6 @@ static void lp5521_unregister_sysfs(struct i2c_client *client) | |||
689 | &lp5521_led_attribute_group); | 689 | &lp5521_led_attribute_group); |
690 | } | 690 | } |
691 | 691 | ||
692 | static int lp5521_init_led(struct lp5521_led *led, | ||
693 | struct i2c_client *client, | ||
694 | int chan, struct lp5521_platform_data *pdata) | ||
695 | { | ||
696 | struct device *dev = &client->dev; | ||
697 | char name[32]; | ||
698 | int res; | ||
699 | |||
700 | if (chan >= LP5521_MAX_LEDS) | ||
701 | return -EINVAL; | ||
702 | |||
703 | if (pdata->led_config[chan].led_current == 0) | ||
704 | return 0; | ||
705 | |||
706 | led->led_current = pdata->led_config[chan].led_current; | ||
707 | led->max_current = pdata->led_config[chan].max_current; | ||
708 | led->chan_nr = pdata->led_config[chan].chan_nr; | ||
709 | |||
710 | if (led->chan_nr >= LP5521_MAX_LEDS) { | ||
711 | dev_err(dev, "Use channel numbers between 0 and %d\n", | ||
712 | LP5521_MAX_LEDS - 1); | ||
713 | return -EINVAL; | ||
714 | } | ||
715 | |||
716 | led->cdev.brightness_set = lp5521_set_brightness; | ||
717 | if (pdata->led_config[chan].name) { | ||
718 | led->cdev.name = pdata->led_config[chan].name; | ||
719 | } else { | ||
720 | snprintf(name, sizeof(name), "%s:channel%d", | ||
721 | pdata->label ?: client->name, chan); | ||
722 | led->cdev.name = name; | ||
723 | } | ||
724 | |||
725 | res = led_classdev_register(dev, &led->cdev); | ||
726 | if (res < 0) { | ||
727 | dev_err(dev, "couldn't register led on channel %d\n", chan); | ||
728 | return res; | ||
729 | } | ||
730 | |||
731 | res = sysfs_create_group(&led->cdev.dev->kobj, | ||
732 | &lp5521_led_attribute_group); | ||
733 | if (res < 0) { | ||
734 | dev_err(dev, "couldn't register current attribute\n"); | ||
735 | led_classdev_unregister(&led->cdev); | ||
736 | return res; | ||
737 | } | ||
738 | return 0; | ||
739 | } | ||
740 | |||
741 | static void lp5521_unregister_leds(struct lp5521_chip *chip) | 692 | static void lp5521_unregister_leds(struct lp5521_chip *chip) |
742 | { | 693 | { |
743 | int i; | 694 | int i; |
@@ -758,6 +709,7 @@ static struct lp55xx_device_config lp5521_cfg = { | |||
758 | .addr = LP5521_REG_ENABLE, | 709 | .addr = LP5521_REG_ENABLE, |
759 | .val = LP5521_ENABLE_DEFAULT, | 710 | .val = LP5521_ENABLE_DEFAULT, |
760 | }, | 711 | }, |
712 | .max_channel = LP5521_MAX_LEDS, | ||
761 | .post_init_device = lp5521_post_init_device, | 713 | .post_init_device = lp5521_post_init_device, |
762 | }; | 714 | }; |
763 | 715 | ||
diff --git a/drivers/leds/leds-lp5523.c b/drivers/leds/leds-lp5523.c index 41ac502ff82f..ca2f8134909f 100644 --- a/drivers/leds/leds-lp5523.c +++ b/drivers/leds/leds-lp5523.c | |||
@@ -94,7 +94,7 @@ | |||
94 | #define LP5523_PROGRAM_PAGES 6 | 94 | #define LP5523_PROGRAM_PAGES 6 |
95 | #define LP5523_ADC_SHORTCIRC_LIM 80 | 95 | #define LP5523_ADC_SHORTCIRC_LIM 80 |
96 | 96 | ||
97 | #define LP5523_LEDS 9 | 97 | #define LP5523_MAX_LEDS 9 |
98 | #define LP5523_ENGINES 3 | 98 | #define LP5523_ENGINES 3 |
99 | 99 | ||
100 | #define LP5523_ENG_MASK_BASE 0x30 /* 00110000 */ | 100 | #define LP5523_ENG_MASK_BASE 0x30 /* 00110000 */ |
@@ -136,7 +136,7 @@ struct lp5523_chip { | |||
136 | struct mutex lock; /* Serialize control */ | 136 | struct mutex lock; /* Serialize control */ |
137 | struct i2c_client *client; | 137 | struct i2c_client *client; |
138 | struct lp5523_engine engines[LP5523_ENGINES]; | 138 | struct lp5523_engine engines[LP5523_ENGINES]; |
139 | struct lp5523_led leds[LP5523_LEDS]; | 139 | struct lp5523_led leds[LP5523_MAX_LEDS]; |
140 | struct lp5523_platform_data *pdata; | 140 | struct lp5523_platform_data *pdata; |
141 | u8 num_channels; | 141 | u8 num_channels; |
142 | u8 num_leds; | 142 | u8 num_leds; |
@@ -285,7 +285,7 @@ static int lp5523_mux_parse(const char *buf, u16 *mux, size_t len) | |||
285 | int i; | 285 | int i; |
286 | u16 tmp_mux = 0; | 286 | u16 tmp_mux = 0; |
287 | 287 | ||
288 | len = min_t(int, len, LP5523_LEDS); | 288 | len = min_t(int, len, LP5523_MAX_LEDS); |
289 | for (i = 0; i < len; i++) { | 289 | for (i = 0; i < len; i++) { |
290 | switch (buf[i]) { | 290 | switch (buf[i]) { |
291 | case '1': | 291 | case '1': |
@@ -308,7 +308,7 @@ static int lp5523_mux_parse(const char *buf, u16 *mux, size_t len) | |||
308 | static void lp5523_mux_to_array(u16 led_mux, char *array) | 308 | static void lp5523_mux_to_array(u16 led_mux, char *array) |
309 | { | 309 | { |
310 | int i, pos = 0; | 310 | int i, pos = 0; |
311 | for (i = 0; i < LP5523_LEDS; i++) | 311 | for (i = 0; i < LP5523_MAX_LEDS; i++) |
312 | pos += sprintf(array + pos, "%x", LED_ACTIVE(led_mux, i)); | 312 | pos += sprintf(array + pos, "%x", LED_ACTIVE(led_mux, i)); |
313 | 313 | ||
314 | array[pos] = '\0'; | 314 | array[pos] = '\0'; |
@@ -324,7 +324,7 @@ static ssize_t show_engine_leds(struct device *dev, | |||
324 | { | 324 | { |
325 | struct i2c_client *client = to_i2c_client(dev); | 325 | struct i2c_client *client = to_i2c_client(dev); |
326 | struct lp5523_chip *chip = i2c_get_clientdata(client); | 326 | struct lp5523_chip *chip = i2c_get_clientdata(client); |
327 | char mux[LP5523_LEDS + 1]; | 327 | char mux[LP5523_MAX_LEDS + 1]; |
328 | 328 | ||
329 | lp5523_mux_to_array(chip->engines[nr - 1].led_mux, mux); | 329 | lp5523_mux_to_array(chip->engines[nr - 1].led_mux, mux); |
330 | 330 | ||
@@ -417,7 +417,7 @@ static ssize_t lp5523_selftest(struct device *dev, | |||
417 | 417 | ||
418 | vdd--; /* There may be some fluctuation in measurement */ | 418 | vdd--; /* There may be some fluctuation in measurement */ |
419 | 419 | ||
420 | for (i = 0; i < LP5523_LEDS; i++) { | 420 | for (i = 0; i < LP5523_MAX_LEDS; i++) { |
421 | /* Skip non-existing channels */ | 421 | /* Skip non-existing channels */ |
422 | if (chip->pdata->led_config[i].led_current == 0) | 422 | if (chip->pdata->led_config[i].led_current == 0) |
423 | continue; | 423 | continue; |
@@ -773,55 +773,6 @@ static void lp5523_set_mode(struct lp5523_engine *engine, u8 mode) | |||
773 | /*--------------------------------------------------------------*/ | 773 | /*--------------------------------------------------------------*/ |
774 | /* Probe, Attach, Remove */ | 774 | /* Probe, Attach, Remove */ |
775 | /*--------------------------------------------------------------*/ | 775 | /*--------------------------------------------------------------*/ |
776 | static int lp5523_init_led(struct lp5523_led *led, struct device *dev, | ||
777 | int chan, struct lp5523_platform_data *pdata, | ||
778 | const char *chip_name) | ||
779 | { | ||
780 | char name[32]; | ||
781 | int res; | ||
782 | |||
783 | if (chan >= LP5523_LEDS) | ||
784 | return -EINVAL; | ||
785 | |||
786 | if (pdata->led_config[chan].led_current) { | ||
787 | led->led_current = pdata->led_config[chan].led_current; | ||
788 | led->max_current = pdata->led_config[chan].max_current; | ||
789 | led->chan_nr = pdata->led_config[chan].chan_nr; | ||
790 | |||
791 | if (led->chan_nr >= LP5523_LEDS) { | ||
792 | dev_err(dev, "Use channel numbers between 0 and %d\n", | ||
793 | LP5523_LEDS - 1); | ||
794 | return -EINVAL; | ||
795 | } | ||
796 | |||
797 | if (pdata->led_config[chan].name) { | ||
798 | led->cdev.name = pdata->led_config[chan].name; | ||
799 | } else { | ||
800 | snprintf(name, sizeof(name), "%s:channel%d", | ||
801 | pdata->label ? : chip_name, chan); | ||
802 | led->cdev.name = name; | ||
803 | } | ||
804 | |||
805 | led->cdev.brightness_set = lp5523_set_brightness; | ||
806 | res = led_classdev_register(dev, &led->cdev); | ||
807 | if (res < 0) { | ||
808 | dev_err(dev, "couldn't register led on channel %d\n", | ||
809 | chan); | ||
810 | return res; | ||
811 | } | ||
812 | res = sysfs_create_group(&led->cdev.dev->kobj, | ||
813 | &lp5523_led_attribute_group); | ||
814 | if (res < 0) { | ||
815 | dev_err(dev, "couldn't register current attribute\n"); | ||
816 | led_classdev_unregister(&led->cdev); | ||
817 | return res; | ||
818 | } | ||
819 | } else { | ||
820 | led->led_current = 0; | ||
821 | } | ||
822 | return 0; | ||
823 | } | ||
824 | |||
825 | static void lp5523_unregister_leds(struct lp5523_chip *chip) | 776 | static void lp5523_unregister_leds(struct lp5523_chip *chip) |
826 | { | 777 | { |
827 | int i; | 778 | int i; |
@@ -842,6 +793,7 @@ static struct lp55xx_device_config lp5523_cfg = { | |||
842 | .addr = LP5523_REG_ENABLE, | 793 | .addr = LP5523_REG_ENABLE, |
843 | .val = LP5523_ENABLE, | 794 | .val = LP5523_ENABLE, |
844 | }, | 795 | }, |
796 | .max_channel = LP5523_MAX_LEDS, | ||
845 | .post_init_device = lp5523_post_init_device, | 797 | .post_init_device = lp5523_post_init_device, |
846 | }; | 798 | }; |
847 | 799 | ||
diff --git a/drivers/leds/leds-lp55xx-common.c b/drivers/leds/leds-lp55xx-common.c index 1fab1d1c4502..75ab1c3c03ed 100644 --- a/drivers/leds/leds-lp55xx-common.c +++ b/drivers/leds/leds-lp55xx-common.c | |||
@@ -63,9 +63,75 @@ static int lp55xx_post_init_device(struct lp55xx_chip *chip) | |||
63 | return cfg->post_init_device(chip); | 63 | return cfg->post_init_device(chip); |
64 | } | 64 | } |
65 | 65 | ||
66 | static struct attribute *lp55xx_led_attributes[] = { | ||
67 | NULL, | ||
68 | }; | ||
69 | |||
70 | static struct attribute_group lp55xx_led_attr_group = { | ||
71 | .attrs = lp55xx_led_attributes | ||
72 | }; | ||
73 | |||
74 | static void lp55xx_set_brightness(struct led_classdev *cdev, | ||
75 | enum led_brightness brightness) | ||
76 | { | ||
77 | } | ||
78 | |||
66 | static int lp55xx_init_led(struct lp55xx_led *led, | 79 | static int lp55xx_init_led(struct lp55xx_led *led, |
67 | struct lp55xx_chip *chip, int chan) | 80 | struct lp55xx_chip *chip, int chan) |
68 | { | 81 | { |
82 | struct lp55xx_platform_data *pdata = chip->pdata; | ||
83 | struct lp55xx_device_config *cfg = chip->cfg; | ||
84 | struct device *dev = &chip->cl->dev; | ||
85 | char name[32]; | ||
86 | int ret; | ||
87 | int max_channel = cfg->max_channel; | ||
88 | |||
89 | if (chan >= max_channel) { | ||
90 | dev_err(dev, "invalid channel: %d / %d\n", chan, max_channel); | ||
91 | return -EINVAL; | ||
92 | } | ||
93 | |||
94 | if (pdata->led_config[chan].led_current == 0) | ||
95 | return 0; | ||
96 | |||
97 | led->led_current = pdata->led_config[chan].led_current; | ||
98 | led->max_current = pdata->led_config[chan].max_current; | ||
99 | led->chan_nr = pdata->led_config[chan].chan_nr; | ||
100 | |||
101 | if (led->chan_nr >= max_channel) { | ||
102 | dev_err(dev, "Use channel numbers between 0 and %d\n", | ||
103 | max_channel - 1); | ||
104 | return -EINVAL; | ||
105 | } | ||
106 | |||
107 | led->cdev.brightness_set = lp55xx_set_brightness; | ||
108 | |||
109 | if (pdata->led_config[chan].name) { | ||
110 | led->cdev.name = pdata->led_config[chan].name; | ||
111 | } else { | ||
112 | snprintf(name, sizeof(name), "%s:channel%d", | ||
113 | pdata->label ? : chip->cl->name, chan); | ||
114 | led->cdev.name = name; | ||
115 | } | ||
116 | |||
117 | /* | ||
118 | * register led class device for each channel and | ||
119 | * add device attributes | ||
120 | */ | ||
121 | |||
122 | ret = led_classdev_register(dev, &led->cdev); | ||
123 | if (ret) { | ||
124 | dev_err(dev, "led register err: %d\n", ret); | ||
125 | return ret; | ||
126 | } | ||
127 | |||
128 | ret = sysfs_create_group(&led->cdev.dev->kobj, &lp55xx_led_attr_group); | ||
129 | if (ret) { | ||
130 | dev_err(dev, "led sysfs err: %d\n", ret); | ||
131 | led_classdev_unregister(&led->cdev); | ||
132 | return ret; | ||
133 | } | ||
134 | |||
69 | return 0; | 135 | return 0; |
70 | } | 136 | } |
71 | 137 | ||
diff --git a/drivers/leds/leds-lp55xx-common.h b/drivers/leds/leds-lp55xx-common.h index 219780a2d4eb..70d2bdf54b8e 100644 --- a/drivers/leds/leds-lp55xx-common.h +++ b/drivers/leds/leds-lp55xx-common.h | |||
@@ -32,6 +32,7 @@ struct lp55xx_reg { | |||
32 | * struct lp55xx_device_config | 32 | * struct lp55xx_device_config |
33 | * @reset : Chip specific reset command | 33 | * @reset : Chip specific reset command |
34 | * @enable : Chip specific enable command | 34 | * @enable : Chip specific enable command |
35 | * @max_channel : Maximum number of channels | ||
35 | * @post_init_device : Chip specific initialization code | 36 | * @post_init_device : Chip specific initialization code |
36 | * @brightness_work_fn : Brightness work function | 37 | * @brightness_work_fn : Brightness work function |
37 | * @set_led_current : LED current set function | 38 | * @set_led_current : LED current set function |
@@ -39,6 +40,7 @@ struct lp55xx_reg { | |||
39 | struct lp55xx_device_config { | 40 | struct lp55xx_device_config { |
40 | const struct lp55xx_reg reset; | 41 | const struct lp55xx_reg reset; |
41 | const struct lp55xx_reg enable; | 42 | const struct lp55xx_reg enable; |
43 | const int max_channel; | ||
42 | 44 | ||
43 | /* define if the device has specific initialization process */ | 45 | /* define if the device has specific initialization process */ |
44 | int (*post_init_device) (struct lp55xx_chip *chip); | 46 | int (*post_init_device) (struct lp55xx_chip *chip); |