Optimize g_nearest_pow() function in glib/garray.c

Closes issue #83
This commit is contained in:
Jeffrey Stedfast 2019-08-09 14:16:51 +02:00 committed by Emmanuel Fleury
parent 10be2c12ab
commit 2f8c61314c

View File

@ -874,12 +874,20 @@ g_array_binary_search (GArray *array,
static guint
g_nearest_pow (guint num)
{
guint n = 1;
guint n = num - 1;
while (n < num && n > 0)
n <<= 1;
g_assert (num > 0);
return n ? n : num;
n |= n >> 1;
n |= n >> 2;
n |= n >> 4;
n |= n >> 8;
n |= n >> 16;
#if GLIB_SIZEOF_INT == 8
n |= n >> 32;
#endif
return n + 1;
}
static void