1
1
openmpi/opal/class
Rainer Keller 4e6a6fc146 - Check, whether the compiler supports __builtin_clz (count leading
zeroes);
   if so, use it for bit-operations like opal_cube_dim and opal_hibit.
   Implement two versions of power-of-two.
   In case of opal_next_poweroftwo, this reduces the average execution
   time from 83 cycles to 4 cycles (Intel Nehalem, icc, -O2, inlining,
   measured rdtsc, with loop over 2^27 values).
   Numbers for other functions are similar (but of course heavily depend
   on the usage, e.g. opal_hibit() with a start of 4 does not save
   much).  The bsr instruction on AMD Opteron is also not as fast.

 - Replace various places where the next power-of-two is computed.
   
   Tested on Intel Nehalem Cluster with openib, compilers GNU-4.6.1 and
   Intel-12.0.4 using mpi_testsuite -t "Collective" with 128 processes.

This commit was SVN r25270.
2011-10-11 22:49:01 +00:00
..
Makefile.am Add opal_tree class. This will be used in the future by sysinfo to store hw maps to be used by rmaps for the new affinity code. 2011-03-30 08:05:28 +00:00
opal_atomic_lifo.c Save the ghost pointer once the element is initialized. 2007-04-01 16:18:48 +00:00
opal_atomic_lifo.h Continue clean up of thread options started in r22841, 22842, and 22849. 2011-03-18 21:36:35 +00:00
opal_bitmap.c Some assorted opal_bitmap extensions 2011-06-09 14:43:54 +00:00
opal_bitmap.h Some assorted opal_bitmap extensions 2011-06-09 14:43:54 +00:00
opal_free_list.c Remove include/opal/sys/cache.h -- its only purpose in life was to 2010-07-06 14:33:36 +00:00
opal_free_list.h ... Delayed due to notifier commits earlier this day ... 2009-04-29 01:32:14 +00:00
opal_graph.c Cosmetics, only typos. 2008-07-28 13:33:08 +00:00
opal_graph.h Fix visibility issues with opal_graph functions. 2009-06-09 15:02:57 +00:00
opal_hash_table.c - Check, whether the compiler supports __builtin_clz (count leading 2011-10-11 22:49:01 +00:00
opal_hash_table.h - We're using uint16_t, uint32_t, and friends, 2009-03-21 01:26:27 +00:00
opal_list.c This is a very large change to rename several #define values from 2009-05-06 20:11:28 +00:00
opal_list.h This is a very large change to rename several #define values from 2009-05-06 20:11:28 +00:00
opal_object.c Apply a patch from Bert Wesarg. 2007-03-06 16:38:06 +00:00
opal_object.h Continue clean up of thread options started in r22841, 22842, and 22849. 2011-03-18 21:36:35 +00:00
opal_pointer_array.c - As discussed revert r21330, Fortran-configure info should 2009-06-01 19:02:34 +00:00
opal_pointer_array.h Replace all occurences of orte_pointer_array by opal_pointer_array. Remove the 2008-02-28 05:32:23 +00:00
opal_ring_buffer.c Provide a way to look at the head of the ring 2011-06-28 19:46:48 +00:00
opal_ring_buffer.h Provide a way to look at the head of the ring 2011-06-28 19:46:48 +00:00
opal_tree.c Add opal_tree class. This will be used in the future by sysinfo to store hw maps to be used by rmaps for the new affinity code. 2011-03-30 08:05:28 +00:00
opal_tree.h Add opal_tree class. This will be used in the future by sysinfo to store hw maps to be used by rmaps for the new affinity code. 2011-03-30 08:05:28 +00:00
opal_value_array.c This is a very large change to rename several #define values from 2009-05-06 20:11:28 +00:00
opal_value_array.h This is a very large change to rename several #define values from 2009-05-06 20:11:28 +00:00