summaryrefslogtreecommitdiff
path: root/common/util.c
diff options
context:
space:
mode:
authortmk <nobody@nowhere>2013-05-14 23:03:23 +0900
committertmk <nobody@nowhere>2013-05-14 23:03:23 +0900
commitcbb9c408e46a7a7a567f3d6e07713256152106d0 (patch)
treebd8e7c789fbb7f191b4de31498160f05d2f80229 /common/util.c
parentb9f558b3d89fc434d6dab348698d5100ff82d16b (diff)
parentff2d276b193632136c785d92ed01df48aea8461f (diff)
Merge branch 'fix_print'
Diffstat (limited to 'common/util.c')
-rw-r--r--common/util.c22
1 files changed, 22 insertions, 0 deletions
diff --git a/common/util.c b/common/util.c
index 6d4d6bfda1..7e0d542993 100644
--- a/common/util.c
+++ b/common/util.c
@@ -77,3 +77,25 @@ uint8_t biton32(uint32_t bits)
if (bits >> 1) { bits >>= 1; n += 1;}
return n;
}
+
+
+
+uint8_t bitrev(uint8_t bits)
+{
+ bits = (bits & 0x0f)<<4 | (bits & 0xf0)>>4;
+ bits = (bits & 0b00110011)<<2 | (bits & 0b11001100)>>2;
+ bits = (bits & 0b01010101)<<1 | (bits & 0b10101010)>>1;
+ return bits;
+}
+
+uint16_t bitrev16(uint16_t bits)
+{
+ bits = bitrev(bits & 0x00ff)<<8 | bitrev((bits & 0xff00)>>8);
+ return bits;
+}
+
+uint32_t bitrev32(uint32_t bits)
+{
+ bits = (uint32_t)bitrev16(bits & 0x0000ffff)<<16 | bitrev16((bits & 0xffff0000)>>16);
+ return bits;
+}