CI130X SDK API手册
2.2.0
本手册用于描述CI130X SDK各个组件和驱动API
概述
API参考
components
RISCV
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
制作者
1.8.14