staging: Use available error codes
authorJulia Lawall <julia@diku.dk>
Mon, 16 Aug 2010 16:26:36 +0000 (18:26 +0200)
committerGreg Kroah-Hartman <gregkh@suse.de>
Tue, 31 Aug 2010 22:05:12 +0000 (15:05 -0700)
An error code is stored in a variable, but 0 is returned instead.  Use the
variable instead of 0.

The semantic match that finds this problem is as follows:
(http://coccinelle.lip6.fr/)

// <smpl>
@r@
local idexpression x;
constant C;
@@

if (...) { ...
  x = -C
  ... when != x
(
  return <+...x...+>;
|
  return NULL;
|
  return;
|
* return ...;
)
}
// </smpl>

Signed-off-by: Julia Lawall <julia@diku.dk>
Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
drivers/staging/lirc/lirc_sasem.c
drivers/staging/vt6655/iwctl.c
drivers/staging/vt6656/iwctl.c

index 73166c3..856487e 100644 (file)
@@ -512,7 +512,7 @@ exit:
        mutex_unlock(&context->ctx_lock);
 
        mutex_unlock(&disconnect_lock);
-       return 0;
+       return retval;
 }
 
 /**
index 4322761..4009c0b 100644 (file)
@@ -1900,7 +1900,7 @@ int iwctl_siwgenie(struct net_device *dev,
        }
 
        out://not completely ...not necessary in wpa_supplicant 0.5.8
-       return 0;
+       return ret;
 }
 
 int iwctl_giwgenie(struct net_device *dev,
index 9c855f0..0004be8 100644 (file)
@@ -1719,7 +1719,7 @@ int iwctl_siwgenie(struct net_device *dev,
        }
 
        out://not completely ...not necessary in wpa_supplicant 0.5.8
-       return 0;
+       return ret;
 }
 
 int iwctl_giwgenie(struct net_device *dev,