aboutsummaryrefslogtreecommitdiff
path: root/common/util.c
diff options
context:
space:
mode:
Diffstat (limited to 'common/util.c')
-rw-r--r--common/util.c37
1 files changed, 37 insertions, 0 deletions
diff --git a/common/util.c b/common/util.c
new file mode 100644
index 000000000..36afdd447
--- /dev/null
+++ b/common/util.c
@@ -0,0 +1,37 @@
1/*
2Copyright 2011 Jun Wako <wakojun@gmail.com>
3
4This program is free software: you can redistribute it and/or modify
5it under the terms of the GNU General Public License as published by
6the Free Software Foundation, either version 2 of the License, or
7(at your option) any later version.
8
9This program is distributed in the hope that it will be useful,
10but WITHOUT ANY WARRANTY; without even the implied warranty of
11MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12GNU General Public License for more details.
13
14You should have received a copy of the GNU General Public License
15along with this program. If not, see <http://www.gnu.org/licenses/>.
16*/
17
18#include "util.h"
19
20// bit population
21int bitpop(uint8_t bits)
22{
23 int c;
24 for (c = 0; bits; c++)
25 bits &= bits -1;
26 return c;
27}
28
29// most significant on-bit
30int biton(uint8_t bits)
31{
32 int n = 0;
33 if (bits >> 4) { bits >>= 4; n += 4;}
34 if (bits >> 2) { bits >>= 2; n += 2;}
35 if (bits >> 1) { bits >>= 1; n += 1;}
36 return n;
37}