mirror of
https://git.code.sf.net/p/quake/quakeforge
synced 2025-01-20 07:50:45 +00:00
cfaf158ebc
Just 32-bit rounding to next higher power of two, and base 2 logarithm. Most importantly, they are suitable for use in initializers as they are constant in, constant out.
73 lines
2.1 KiB
C
73 lines
2.1 KiB
C
/*
|
|
bitop.h
|
|
|
|
bit-op functions
|
|
|
|
Copyright (C) 2022 Bill Currie <bill@taniwha.org>
|
|
|
|
Author: Bill Currie <bill@taniwha.org>
|
|
Date: 2022/1/23
|
|
|
|
This program is free software; you can redistribute it and/or
|
|
modify it under the terms of the GNU General Public License
|
|
as published by the Free Software Foundation; either version 2
|
|
of the License, or (at your option) any later version.
|
|
|
|
This program is distributed in the hope that it will be useful,
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
|
|
|
|
See the GNU General Public License for more details.
|
|
|
|
You should have received a copy of the GNU General Public License
|
|
along with this program; if not, write to:
|
|
|
|
Free Software Foundation, Inc.
|
|
59 Temple Place - Suite 330
|
|
Boston, MA 02111-1307, USA
|
|
|
|
*/
|
|
|
|
#ifndef __QF_math_bitop_h
|
|
#define __QF_math_bitop_h
|
|
|
|
/** \defgroup mathlib_bitop Bit-op functions
|
|
\ingroup utils
|
|
*/
|
|
///@{
|
|
|
|
#include "QF/qtypes.h"
|
|
|
|
#define BITOP_RUP1__(x) ( (x) | ( (x) >> 1))
|
|
#define BITOP_RUP2__(x) (BITOP_RUP1__(x) | (BITOP_RUP1__(x) >> 2))
|
|
#define BITOP_RUP4__(x) (BITOP_RUP2__(x) | (BITOP_RUP2__(x) >> 4))
|
|
#define BITOP_RUP8__(x) (BITOP_RUP4__(x) | (BITOP_RUP4__(x) >> 8))
|
|
#define BITOP_RUP16__(x) (BITOP_RUP8__(x) | (BITOP_RUP8__(x) >> 16))
|
|
/** Round x up to the next power of two.
|
|
|
|
Rounds x up to the next power of two leaving exact powers of two
|
|
untouched.
|
|
|
|
\param x The value to round
|
|
\return The next higher power of two or x if it already is a power
|
|
of two.
|
|
*/
|
|
#define BITOP_RUP(x) (BITOP_RUP16__((uint32_t)(x) - 1) + 1)
|
|
|
|
#define BITOP_LOG2__(x) (((((x) & 0xffff0000) != 0) << 4) \
|
|
|((((x) & 0xff00ff00) != 0) << 3) \
|
|
|((((x) & 0xf0f0f0f0) != 0) << 2) \
|
|
|((((x) & 0xcccccccc) != 0) << 1) \
|
|
|((((x) & 0xaaaaaaaa) != 0) << 0))
|
|
/** Log base 2 rounded up.
|
|
|
|
Finds the base 2 logarithm of x rounded up (ceil(log2(x))).
|
|
|
|
\param x The value for which to find the base 2 logarithm.
|
|
\return Log base 2 of x, rounded up (2 -> 1, 3 -> 2, 4 -> 2)
|
|
*/
|
|
#define BITOP_LOG2(x) BITOP_LOG2__(BITOP_RUP(x))
|
|
|
|
///@}
|
|
|
|
#endif // __QF_math_bitop_h
|