CI130X SDK API手册  2.2.0
本手册用于描述CI130X SDK各个组件和驱动API
riscv_bits.h
浏览该文件的文档.
1 #ifndef _RISCV_BITS_H
2 #define _RISCV_BITS_H
3 
4 #define likely(x) __builtin_expect((x), 1)
5 #define unlikely(x) __builtin_expect((x), 0)
6 
7 #define ROUNDUP(a, b) ((((a)-1)/(b)+1)*(b))
8 #define ROUNDDOWN(a, b) ((a)/(b)*(b))
9 
10 #define MAX(a, b) ((a) > (b) ? (a) : (b))
11 #define MIN(a, b) ((a) < (b) ? (a) : (b))
12 #define CLAMP(a, lo, hi) MIN(MAX(a, lo), hi)
13 
14 #define EXTRACT_FIELD(val, which) (((val) & (which)) / ((which) & ~((which)-1)))
15 #define INSERT_FIELD(val, which, fieldval) (((val) & ~(which)) | ((fieldval) * ((which) & ~((which)-1))))
16 
17 #define STR(x) XSTR(x)
18 #define XSTR(x) #x
19 
20 #if __riscv_xlen == 64
21 # define SLL32 sllw
22 # define STORE sd
23 # define LOAD ld
24 # define LWU lwu
25 # define LOG_REGBYTES 3
26 #else
27 # define SLL32 sll
28 # define STORE sw
29 # define LOAD lw
30 # define LWU lw
31 # define LOG_REGBYTES 2
32 #endif
33 #define REGBYTES (1 << LOG_REGBYTES)
34 
35 #endif