]> git.sur5r.net Git - freertos/blob - FreeRTOS/Demo/RISC-V-Qemu-sifive_e-FreedomStudio/freedom-e-sdk/include/sifive/bits.h
Recreate the RISC-V-Qemu demo using Vanilla Eclipse in place of Freedom Studio as...
[freertos] / FreeRTOS / Demo / RISC-V-Qemu-sifive_e-FreedomStudio / freedom-e-sdk / include / sifive / bits.h
1 // See LICENSE for license details.\r
2 #ifndef _RISCV_BITS_H\r
3 #define _RISCV_BITS_H\r
4 \r
5 #define likely(x) __builtin_expect((x), 1)\r
6 #define unlikely(x) __builtin_expect((x), 0)\r
7 \r
8 #define ROUNDUP(a, b) ((((a)-1)/(b)+1)*(b))\r
9 #define ROUNDDOWN(a, b) ((a)/(b)*(b))\r
10 \r
11 #define MAX(a, b) ((a) > (b) ? (a) : (b))\r
12 #define MIN(a, b) ((a) < (b) ? (a) : (b))\r
13 #define CLAMP(a, lo, hi) MIN(MAX(a, lo), hi)\r
14 \r
15 #define EXTRACT_FIELD(val, which) (((val) & (which)) / ((which) & ~((which)-1)))\r
16 #define INSERT_FIELD(val, which, fieldval) (((val) & ~(which)) | ((fieldval) * ((which) & ~((which)-1))))\r
17 \r
18 #define STR(x) XSTR(x)\r
19 #define XSTR(x) #x\r
20 \r
21 #if __riscv_xlen == 64\r
22 # define SLL32    sllw\r
23 # define STORE    sd\r
24 # define LOAD     ld\r
25 # define LWU      lwu\r
26 # define LOG_REGBYTES 3\r
27 #else\r
28 # define SLL32    sll\r
29 # define STORE    sw\r
30 # define LOAD     lw\r
31 # define LWU      lw\r
32 # define LOG_REGBYTES 2\r
33 #endif\r
34 #define REGBYTES (1 << LOG_REGBYTES)\r
35 \r
36 #endif\r