[rtems commit] score: Use builtin for _Bitfield_Find_first_bit()

Sebastian Huber sebh at rtems.org
Thu Jun 9 08:49:38 UTC 2016


Module:    rtems
Branch:    master
Commit:    80bbb4eda36cf00e13fa49a206b88e80cf2acdc7
Changeset: http://git.rtems.org/rtems/commit/?id=80bbb4eda36cf00e13fa49a206b88e80cf2acdc7

Author:    Sebastian Huber <sebastian.huber at embedded-brains.de>
Date:      Wed Jun  8 08:52:38 2016 +0200

score: Use builtin for _Bitfield_Find_first_bit()

In case the CPU architecture provides no specialized
_CPU_Bitfield_Find_first_bit() macro, then use the __builtin_clz()
builtin in case __GNUC__ is defined.

---

 cpukit/score/include/rtems/score/prioritybitmapimpl.h | 2 ++
 1 file changed, 2 insertions(+)

diff --git a/cpukit/score/include/rtems/score/prioritybitmapimpl.h b/cpukit/score/include/rtems/score/prioritybitmapimpl.h
index 2041a20..0082720 100644
--- a/cpukit/score/include/rtems/score/prioritybitmapimpl.h
+++ b/cpukit/score/include/rtems/score/prioritybitmapimpl.h
@@ -60,6 +60,8 @@ RTEMS_INLINE_ROUTINE unsigned int _Bitfield_Find_first_bit(
 
 #if ( CPU_USE_GENERIC_BITFIELD_CODE == FALSE )
   _CPU_Bitfield_Find_first_bit( value, bit_number );
+#elif defined(__GNUC__)
+  bit_number = __builtin_clz( value ) - __SIZEOF_INT__ * __CHAR_BIT__ + 16;
 #else
   if ( value < 0x100 ) {
     bit_number = _Bitfield_Leading_zeros[ value ] + 8;



More information about the vc mailing list