提交 d379ee8a 编写于 作者: D David Brownell 提交者: Richard Purdie

leds: just ignore invalid GPIOs in leds-gpio

Sometimes it's awkward to make sure that the array in the
platform_data handed to the leds-gpio driver has only valid
data ... some leds may not be always available, and coping
with that currently requires patching or rebuilding the array.

This patch fixes that by making it be OK to pass an invalid
GPIO (such as "-EINVAL") ... such table entries are skipped.

[rpurdie@linux.intel.com: adjusted to apply against other led tree changes]
Signed-off-by: NDavid Brownell <dbrownell@users.sourceforge.net>
Tested-by: NDiego Dompe <diego.dompe@ridgerun.com>
Signed-off-by: NRichard Purdie <rpurdie@linux.intel.com>
上级 7fbc3a9b
...@@ -78,6 +78,13 @@ static int __devinit create_gpio_led(const struct gpio_led *template, ...@@ -78,6 +78,13 @@ static int __devinit create_gpio_led(const struct gpio_led *template,
{ {
int ret; int ret;
/* skip leds that aren't available */
if (!gpio_is_valid(template->gpio)) {
printk(KERN_INFO "Skipping unavilable LED gpio %d (%s)\n",
template->gpio, template->name);
return;
}
ret = gpio_request(template->gpio, template->name); ret = gpio_request(template->gpio, template->name);
if (ret < 0) if (ret < 0)
return ret; return ret;
...@@ -114,6 +121,8 @@ static int __devinit create_gpio_led(const struct gpio_led *template, ...@@ -114,6 +121,8 @@ static int __devinit create_gpio_led(const struct gpio_led *template,
static void delete_gpio_led(struct gpio_led_data *led) static void delete_gpio_led(struct gpio_led_data *led)
{ {
if (!gpio_is_valid(led->gpio))
return;
led_classdev_unregister(&led->cdev); led_classdev_unregister(&led->cdev);
cancel_work_sync(&led->work); cancel_work_sync(&led->work);
gpio_free(led->gpio); gpio_free(led->gpio);
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册