]> err.no Git - linux-2.6/commitdiff
rt2x00: Use __builtin_choose_expr() instead of ?:
authorIvo van Doorn <IvDoorn@gmail.com>
Fri, 6 Jun 2008 20:58:29 +0000 (22:58 +0200)
committerJohn W. Linville <linville@tuxdriver.com>
Sat, 14 Jun 2008 16:17:57 +0000 (12:17 -0400)
To really force the FIELD macros to determine
the first bit of the register field we should
use the __builtin_choose_expr() function.

Signed-off-by: Ivo van Doorn <IvDoorn@gmail.com>
Signed-off-by: John W. Linville <linville@tuxdriver.com>
drivers/net/wireless/rt2x00/rt2x00reg.h

index c3f1202404d9a69ca59a599aa9018fbe787e2cb6..7e88ce5651b95041f35fde0a8ec682b09ca091eb 100644 (file)
@@ -145,23 +145,27 @@ struct rt2x00_field32 {
  * compile-time rather then run-time.
  */
 #define compile_ffs2(__x) \
-       ( ((__x) & 0x1) ? 0 : 1 )
+       __builtin_choose_expr(((__x) & 0x1), 0, 1)
 
 #define compile_ffs4(__x) \
-       ( ((__x) & 0x3) ? \
-           compile_ffs2(__x) : (compile_ffs2((__x) >> 2) + 2) )
+       __builtin_choose_expr(((__x) & 0x3), \
+                             (compile_ffs2((__x))), \
+                             (compile_ffs2((__x) >> 2) + 2))
 
 #define compile_ffs8(__x) \
-       ( ((__x) & 0xf) ? \
-           compile_ffs4(__x) : (compile_ffs4((__x) >> 4) + 4) )
+       __builtin_choose_expr(((__x) & 0xf), \
+                             (compile_ffs4((__x))), \
+                             (compile_ffs4((__x) >> 4) + 4))
 
 #define compile_ffs16(__x) \
-       ( ((__x) & 0xff) ? \
-           compile_ffs8(__x) : (compile_ffs8((__x) >> 8) + 8) )
+       __builtin_choose_expr(((__x) & 0xff), \
+                             (compile_ffs8((__x))), \
+                             (compile_ffs8((__x) >> 8) + 8))
 
 #define compile_ffs32(__x) \
-       ( ((__x) & 0xffff) ? \
-           compile_ffs16(__x) : (compile_ffs16((__x) >> 16) + 16) )
+       __builtin_choose_expr(((__x) & 0xffff), \
+                             (compile_ffs16((__x))), \
+                             (compile_ffs16((__x) >> 16) + 16))
 
 /*
  * This macro will check the requirements for the FIELD{8,16,32} macros