Thread (6 messages) 6 messages, 4 authors, 2018-02-06

Re: [RESEND][PATCH] video: fbdev: atmel_lcdfb: convert to use GPIO descriptors

From: Ludovic Desroches <ludovic.desroches@microchip.com>
Date: 2018-02-05 15:32:02
Also in: linux-arm-kernel, linux-fbdev, lkml

On Mon, Feb 05, 2018 at 03:06:33PM +0200, Andy Shevchenko wrote:
On Mon, Feb 5, 2018 at 10:47 AM, Ludovic Desroches
[off-list ref] wrote:
quoted
Use GPIO descriptors instead of relying on the old method.
Reviewed-by: Andy Shevchenko <redacted>

Though few nitpicks below.

quoted
--- a/drivers/video/fbdev/atmel_lcdfb.c
+++ b/drivers/video/fbdev/atmel_lcdfb.c
@@ -18,6 +18,7 @@
 #include <linux/delay.h>
 #include <linux/backlight.h>
 #include <linux/gfp.h>
quoted
+#include <linux/gpio/consumer.h>
I think you forgot to remove of_gpio.h.
Right. I'll remove it.
quoted
 #include <linux/module.h>
 #include <linux/of.h>
 #include <linux/of_device.h>
quoted
        struct device_node *display_np;
        struct device_node *timings_np;
        struct display_timings *timings;
-       enum of_gpio_flags flags;
        struct atmel_lcdfb_power_ctrl_gpio *og;
        bool is_gpio_power = false;
        int ret = -ENOENT;
-       int i, gpio;
+       int i;
+       struct gpio_desc *gpiod;
I would rather preserve reversed tree style, i.e. put longer line upper.
Ok.
quoted
+       for (i = 0; i < gpiod_count(dev, "atmel,power-control"); i++) {
+               gpiod = devm_gpiod_get_index_optional(dev,
+                               "atmel,power-control", i, GPIOD_ASIS);
+               if (!gpiod)
                        continue;
What about IS_ERR() case?
if (!gpiod || IS_ERR(gpiod))
	continue;

Thanks.
quoted
                og = devm_kzalloc(dev, sizeof(*og), GFP_KERNEL);
                if (!og)
                        goto put_display_node;

+               og->gpiod = gpiod;
                is_gpio_power = true;

+               ret = gpiod_direction_output(gpiod, gpiod_is_active_low(gpiod));
                if (ret) {
I'm not sure this will be needed if you check IS_ERR() above.
When in doubt, I keep it.

Regards

Ludovic
quoted
+                       dev_err(dev, "set direction output gpio atmel,power-control[%d] failed\n", i);
                        goto put_display_node;
                }

-- 
With Best Regards,
Andy Shevchenko
_______________________________________________
dri-devel mailing list
dri-devel@lists.freedesktop.org
https://lists.freedesktop.org/mailman/listinfo/dri-devel
Keyboard shortcuts
hback out one level
jnext message in thread
kprevious message in thread
ldrill in
Escclose help / fold thread tree
?toggle this help