Re: [PATCH 04/22] gpiolib: cdev: refactor gpiohandle_flags_to_desc_flags

2020-06-24 Thread Bartosz Golaszewski
wt., 23 cze 2020 o 06:02 Kent Gibson  napisaƂ(a):
>
> Refactor the mapping from handle flags to desc flags into a helper
> function.
>
> The assign_bit is overkill where it is replacing the set_bit cases, as is
> rechecking bits known to be clear in some circumstances, but the DRY
> simplification more than makes up for any performance degradation,
> especially as this is not a hot path.
>
> Signed-off-by: Kent Gibson 
>

Agreed and I like the code shrink.

Reviewed-by: Bartosz Golaszewski 


[PATCH 04/22] gpiolib: cdev: refactor gpiohandle_flags_to_desc_flags

2020-06-22 Thread Kent Gibson
Refactor the mapping from handle flags to desc flags into a helper
function.

The assign_bit is overkill where it is replacing the set_bit cases, as is
rechecking bits known to be clear in some circumstances, but the DRY
simplification more than makes up for any performance degradation,
especially as this is not a hot path.

Signed-off-by: Kent Gibson 

---
 drivers/gpio/gpiolib-cdev.c | 60 -
 1 file changed, 19 insertions(+), 41 deletions(-)

diff --git a/drivers/gpio/gpiolib-cdev.c b/drivers/gpio/gpiolib-cdev.c
index 889ed2dc9e58..e64613b8d0ba 100644
--- a/drivers/gpio/gpiolib-cdev.c
+++ b/drivers/gpio/gpiolib-cdev.c
@@ -106,6 +106,22 @@ static int linehandle_validate_flags(u32 flags)
return 0;
 }
 
+static void linehandle_flags_to_desc_flags(u32 lflags, unsigned long *flagsp)
+{
+   assign_bit(FLAG_ACTIVE_LOW, flagsp,
+  lflags & GPIOHANDLE_REQUEST_ACTIVE_LOW);
+   assign_bit(FLAG_OPEN_DRAIN, flagsp,
+  lflags & GPIOHANDLE_REQUEST_OPEN_DRAIN);
+   assign_bit(FLAG_OPEN_SOURCE, flagsp,
+  lflags & GPIOHANDLE_REQUEST_OPEN_SOURCE);
+   assign_bit(FLAG_PULL_UP, flagsp,
+  lflags & GPIOHANDLE_REQUEST_BIAS_PULL_UP);
+   assign_bit(FLAG_PULL_DOWN, flagsp,
+  lflags & GPIOHANDLE_REQUEST_BIAS_PULL_DOWN);
+   assign_bit(FLAG_BIAS_DISABLE, flagsp,
+  lflags & GPIOHANDLE_REQUEST_BIAS_DISABLE);
+}
+
 static long linehandle_set_config(struct linehandle_state *lh,
  void __user *ip)
 {
@@ -113,7 +129,6 @@ static long linehandle_set_config(struct linehandle_state 
*lh,
struct gpio_desc *desc;
int i, ret;
u32 lflags;
-   unsigned long *flagsp;
 
if (copy_from_user(, ip, sizeof(gcnf)))
return -EFAULT;
@@ -125,25 +140,7 @@ static long linehandle_set_config(struct linehandle_state 
*lh,
 
for (i = 0; i < lh->numdescs; i++) {
desc = lh->descs[i];
-   flagsp = >flags;
-
-   assign_bit(FLAG_ACTIVE_LOW, flagsp,
-   lflags & GPIOHANDLE_REQUEST_ACTIVE_LOW);
-
-   assign_bit(FLAG_OPEN_DRAIN, flagsp,
-   lflags & GPIOHANDLE_REQUEST_OPEN_DRAIN);
-
-   assign_bit(FLAG_OPEN_SOURCE, flagsp,
-   lflags & GPIOHANDLE_REQUEST_OPEN_SOURCE);
-
-   assign_bit(FLAG_PULL_UP, flagsp,
-   lflags & GPIOHANDLE_REQUEST_BIAS_PULL_UP);
-
-   assign_bit(FLAG_PULL_DOWN, flagsp,
-   lflags & GPIOHANDLE_REQUEST_BIAS_PULL_DOWN);
-
-   assign_bit(FLAG_BIAS_DISABLE, flagsp,
-   lflags & GPIOHANDLE_REQUEST_BIAS_DISABLE);
+   linehandle_flags_to_desc_flags(gcnf.flags, >flags);
 
/*
 * Lines have to be requested explicitly for input
@@ -306,19 +303,7 @@ static int linehandle_create(struct gpio_device *gdev, 
void __user *ip)
goto out_free_descs;
lh->descs[i] = desc;
count = i + 1;
-
-   if (lflags & GPIOHANDLE_REQUEST_ACTIVE_LOW)
-   set_bit(FLAG_ACTIVE_LOW, >flags);
-   if (lflags & GPIOHANDLE_REQUEST_OPEN_DRAIN)
-   set_bit(FLAG_OPEN_DRAIN, >flags);
-   if (lflags & GPIOHANDLE_REQUEST_OPEN_SOURCE)
-   set_bit(FLAG_OPEN_SOURCE, >flags);
-   if (lflags & GPIOHANDLE_REQUEST_BIAS_DISABLE)
-   set_bit(FLAG_BIAS_DISABLE, >flags);
-   if (lflags & GPIOHANDLE_REQUEST_BIAS_PULL_DOWN)
-   set_bit(FLAG_PULL_DOWN, >flags);
-   if (lflags & GPIOHANDLE_REQUEST_BIAS_PULL_UP)
-   set_bit(FLAG_PULL_UP, >flags);
+   linehandle_flags_to_desc_flags(handlereq.flags, >flags);
 
ret = gpiod_set_transitory(desc, false);
if (ret < 0)
@@ -685,14 +670,7 @@ static int lineevent_create(struct gpio_device *gdev, void 
__user *ip)
le->desc = desc;
le->eflags = eflags;
 
-   if (lflags & GPIOHANDLE_REQUEST_ACTIVE_LOW)
-   set_bit(FLAG_ACTIVE_LOW, >flags);
-   if (lflags & GPIOHANDLE_REQUEST_BIAS_DISABLE)
-   set_bit(FLAG_BIAS_DISABLE, >flags);
-   if (lflags & GPIOHANDLE_REQUEST_BIAS_PULL_DOWN)
-   set_bit(FLAG_PULL_DOWN, >flags);
-   if (lflags & GPIOHANDLE_REQUEST_BIAS_PULL_UP)
-   set_bit(FLAG_PULL_UP, >flags);
+   linehandle_flags_to_desc_flags(lflags, >flags);
 
ret = gpiod_direction_input(desc);
if (ret)
-- 
2.27.0