]> git.karo-electronics.de Git - linux-beck.git/commitdiff
gpio: octeon: Convert to use devm_ioremap_resource
authorAxel Lin <axel.lin@ingics.com>
Fri, 18 Mar 2016 13:05:16 +0000 (21:05 +0800)
committerLinus Walleij <linus.walleij@linaro.org>
Wed, 30 Mar 2016 08:38:51 +0000 (10:38 +0200)
Signed-off-by: Axel Lin <axel.lin@ingics.com>
Signed-off-by: Linus Walleij <linus.walleij@linaro.org>
drivers/gpio/gpio-octeon.c

index 47aead1ed1cc4218378bd13683e627c60728ed05..9373d4e091854e1cd9ed7a956c6dfdc3b6a1d7a1 100644 (file)
@@ -83,6 +83,7 @@ static int octeon_gpio_probe(struct platform_device *pdev)
        struct octeon_gpio *gpio;
        struct gpio_chip *chip;
        struct resource *res_mem;
+       void __iomem *reg_base;
        int err = 0;
 
        gpio = devm_kzalloc(&pdev->dev, sizeof(*gpio), GFP_KERNEL);
@@ -91,21 +92,11 @@ static int octeon_gpio_probe(struct platform_device *pdev)
        chip = &gpio->chip;
 
        res_mem = platform_get_resource(pdev, IORESOURCE_MEM, 0);
-       if (res_mem == NULL) {
-               dev_err(&pdev->dev, "found no memory resource\n");
-               err = -ENXIO;
-               goto out;
-       }
-       if (!devm_request_mem_region(&pdev->dev, res_mem->start,
-                                       resource_size(res_mem),
-                                    res_mem->name)) {
-               dev_err(&pdev->dev, "request_mem_region failed\n");
-               err = -ENXIO;
-               goto out;
-       }
-       gpio->register_base = (u64)devm_ioremap(&pdev->dev, res_mem->start,
-                                               resource_size(res_mem));
+       reg_base = devm_ioremap_resource(&pdev->dev, res_mem);
+       if (IS_ERR(reg_base))
+               return PTR_ERR(reg_base);
 
+       gpio->register_base = (u64)reg_base;
        pdev->dev.platform_data = chip;
        chip->label = "octeon-gpio";
        chip->parent = &pdev->dev;
@@ -119,11 +110,10 @@ static int octeon_gpio_probe(struct platform_device *pdev)
        chip->set = octeon_gpio_set;
        err = devm_gpiochip_add_data(&pdev->dev, chip, gpio);
        if (err)
-               goto out;
+               return err;
 
        dev_info(&pdev->dev, "OCTEON GPIO driver probed.\n");
-out:
-       return err;
+       return 0;
 }
 
 static struct of_device_id octeon_gpio_match[] = {