aboutsummaryrefslogtreecommitdiff
path: root/src/helper
diff options
context:
space:
mode:
authorAntonio Borneo <borneo.antonio@gmail.com>2022-02-24 11:30:56 +0100
committerAntonio Borneo <borneo.antonio@gmail.com>2022-03-26 13:35:55 +0000
commit6c9dd1c6ba9fba806ed7ed6f6ecb59723beb9cad (patch)
tree71b101c2039515397909d02b8375f40a9bb2dc41 /src/helper
parent3fa695be2401c88dbd93b2c9dad1c098a948c4ca (diff)
downloadriscv-openocd-6c9dd1c6ba9fba806ed7ed6f6ecb59723beb9cad.zip
riscv-openocd-6c9dd1c6ba9fba806ed7ed6f6ecb59723beb9cad.tar.gz
riscv-openocd-6c9dd1c6ba9fba806ed7ed6f6ecb59723beb9cad.tar.bz2
helper/bits: add BIT_ULL and GENMASK macros
To support 64 bits bit and masks Replace local definition of BIT in rtos/chromium-ec Change-Id: I1f268d6e8790f1b07bf798680b797878ce81064b Signed-off-by: Antonio Borneo <borneo.antonio@gmail.com> Reviewed-on: https://review.openocd.org/c/openocd/+/6857 Tested-by: jenkins
Diffstat (limited to 'src/helper')
-rw-r--r--src/helper/bits.h4
1 files changed, 4 insertions, 0 deletions
diff --git a/src/helper/bits.h b/src/helper/bits.h
index 00d3c02..6151b33 100644
--- a/src/helper/bits.h
+++ b/src/helper/bits.h
@@ -28,8 +28,12 @@
#include <helper/types.h>
#define BIT(nr) (1UL << (nr))
+#define BIT_ULL(nr) (1ULL << (nr))
#define BITS_PER_BYTE 8
#define BITS_PER_LONG (BITS_PER_BYTE * sizeof(long))
+#define BITS_PER_LONG_LONG (BITS_PER_BYTE * sizeof(long long))
+#define GENMASK(h, l) (((~0UL) - (1UL << (l)) + 1) & (~0UL >> (BITS_PER_LONG - 1 - (h))))
+#define GENMASK_ULL(h, l) (((~0ULL) - (1ULL << (l)) + 1) & (~0ULL >> (BITS_PER_LONG_LONG - 1 - (h))))
#define BITS_TO_LONGS(nr) DIV_ROUND_UP(nr, BITS_PER_BYTE * sizeof(long))
#define BIT_MASK(nr) (1UL << ((nr) % BITS_PER_LONG))
#define BIT_WORD(nr) ((nr) / BITS_PER_LONG)