tty: serial: cpm_uart: Adding proper request of GPIO used by cpm_uart driver
authorChristophe Leroy <christophe.leroy@c-s.fr>
Wed, 21 Aug 2013 15:59:24 +0000 (17:59 +0200)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Wed, 28 Aug 2013 05:06:22 +0000 (22:06 -0700)
cpm_uart serial driver uses GPIO for control signals. In order to be used
properly, GPIOs have to be reserved. Comment in gpiolib.c considers illegal
the use of GPIOs without requesting them. In addition, the direction of the
GPIO has to be set properly.

Signed-off-by: Christophe Leroy <christophe.leroy@c-s.fr>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
drivers/tty/serial/cpm_uart/cpm_uart_core.c

index f7672cae53212103c9283b2ff595d83a7f63ff17..1a535f70dc41b2886d9fa6d500a5f11f6556eab0 100644 (file)
@@ -1213,8 +1213,32 @@ static int cpm_uart_init_port(struct device_node *np,
                goto out_pram;
        }
 
-       for (i = 0; i < NUM_GPIOS; i++)
-               pinfo->gpios[i] = of_get_gpio(np, i);
+       for (i = 0; i < NUM_GPIOS; i++) {
+               int gpio;
+
+               pinfo->gpios[i] = -1;
+
+               gpio = of_get_gpio(np, i);
+
+               if (gpio_is_valid(gpio)) {
+                       ret = gpio_request(gpio, "cpm_uart");
+                       if (ret) {
+                               pr_err("can't request gpio #%d: %d\n", i, ret);
+                               continue;
+                       }
+                       if (i == GPIO_RTS || i == GPIO_DTR)
+                               ret = gpio_direction_output(gpio, 0);
+                       else
+                               ret = gpio_direction_input(gpio);
+                       if (ret) {
+                               pr_err("can't set direction for gpio #%d: %d\n",
+                                       i, ret);
+                               gpio_free(gpio);
+                               continue;
+                       }
+                       pinfo->gpios[i] = gpio;
+               }
+       }
 
 #ifdef CONFIG_PPC_EARLY_DEBUG_CPM
        udbg_putc = NULL;