Commit cedb1881 authored by Anton Vorontsov's avatar Anton Vorontsov Committed by Grant Likely

gpiolib: cosmetic improvements for error handling in gpiochip_add()

Hopefully it makes the code look nicer and makes it easier to extend
this function.
Signed-off-by: default avatarAnton Vorontsov <avorontsov@ru.mvista.com>
Signed-off-by: default avatarAndrew Morton <akpm@linux-foundation.org>
Signed-off-by: default avatarGrant Likely <grant.likely@secretlab.ca>
CC: devicetree-discuss@lists.ozlabs.org
CC: linux-kernel@vger.kernel.org
parent ac80a51e
...@@ -1101,14 +1101,20 @@ int gpiochip_add(struct gpio_chip *chip) ...@@ -1101,14 +1101,20 @@ int gpiochip_add(struct gpio_chip *chip)
unlock: unlock:
spin_unlock_irqrestore(&gpio_lock, flags); spin_unlock_irqrestore(&gpio_lock, flags);
if (status == 0)
status = gpiochip_export(chip); if (status)
goto fail;
status = gpiochip_export(chip);
if (status)
goto fail;
return 0;
fail: fail:
/* failures here can mean systems won't boot... */ /* failures here can mean systems won't boot... */
if (status) pr_err("gpiochip_add: gpios %d..%d (%s) failed to register\n",
pr_err("gpiochip_add: gpios %d..%d (%s) failed to register\n", chip->base, chip->base + chip->ngpio - 1,
chip->base, chip->base + chip->ngpio - 1, chip->label ? : "generic");
chip->label ? : "generic");
return status; return status;
} }
EXPORT_SYMBOL_GPL(gpiochip_add); EXPORT_SYMBOL_GPL(gpiochip_add);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment