spi/imx: simplify error handling to free gpios
authorAxel Lin <axel.lin@gmail.com>
Tue, 10 Jan 2012 07:27:36 +0000 (15:27 +0800)
committerGrant Likely <grant.likely@secretlab.ca>
Fri, 9 Mar 2012 23:26:48 +0000 (16:26 -0700)
Simplify the error handling by moving the code to free gpios in one place.

Signed-off-by: Axel Lin <axel.lin@gmail.com>
Acked-by: Shawn Guo <shawn.guo@linaro.org>
Signed-off-by: Grant Likely <grant.likely@secretlab.ca>
drivers/spi/spi-imx.c

index c6e697f5e007a7642db7e30e6025160bf783ded9..31054e3de4c11e496ba6f102fbf41c78d1b9d334 100644 (file)
@@ -793,13 +793,8 @@ static int __devinit spi_imx_probe(struct platform_device *pdev)
 
                ret = gpio_request(spi_imx->chipselect[i], DRIVER_NAME);
                if (ret) {
-                       while (i > 0) {
-                               i--;
-                               if (spi_imx->chipselect[i] >= 0)
-                                       gpio_free(spi_imx->chipselect[i]);
-                       }
                        dev_err(&pdev->dev, "can't get cs gpios\n");
-                       goto out_master_put;
+                       goto out_gpio_free;
                }
        }
 
@@ -881,10 +876,10 @@ out_iounmap:
 out_release_mem:
        release_mem_region(res->start, resource_size(res));
 out_gpio_free:
-       for (i = 0; i < master->num_chipselect; i++)
+       while (--i >= 0) {
                if (spi_imx->chipselect[i] >= 0)
                        gpio_free(spi_imx->chipselect[i]);
-out_master_put:
+       }
        spi_master_put(master);
        kfree(master);
        platform_set_drvdata(pdev, NULL);
This page took 0.026602 seconds and 5 git commands to generate.