1 // See LICENSE for license details. 2 #ifndef _RISCV_BITS_H 3 #define _RISCV_BITS_H 4 5 #define likely(x) __builtin_expect((x), 1) 6 #define unlikely(x) __builtin_expect((x), 0) 7 8 #define ROUNDUP(a, b) ((((a)-1)/(b)+1)*(b)) 9 #define ROUNDDOWN(a, b) ((a)/(b)*(b)) 10 11 #define MAX(a, b) ((a) > (b) ? (a) : (b)) 12 #define MIN(a, b) ((a) < (b) ? (a) : (b)) 13 #define CLAMP(a, lo, hi) MIN(MAX(a, lo), hi) 14 15 #define EXTRACT_FIELD(val, which) (((val) & (which)) / ((which) & ~((which)-1))) 16 #define INSERT_FIELD(val, which, fieldval) (((val) & ~(which)) | ((fieldval) * ((which) & ~((which)-1)))) 17 18 #define STR(x) XSTR(x) 19 #define XSTR(x) #x 20 21 #if __riscv_xlen == 64 22 # define SLL32 sllw 23 # define STORE sd 24 # define LOAD ld 25 # define LWU lwu 26 # define LOG_REGBYTES 3 27 #else 28 # define SLL32 sll 29 # define STORE sw 30 # define LOAD lw 31 # define LWU lw 32 # define LOG_REGBYTES 2 33 #endif 34 #define REGBYTES (1 << LOG_REGBYTES) 35 36 #endif 37