-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathcommon.h
42 lines (36 loc) · 1.12 KB
/
common.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
#ifndef __COMMON_H__
#define __COMMON_H__
#include <stdbool.h>
#include "sbi.h"
#include "printf.h"
#define RISCV_EXCP_INST_MISALIGNED 0
#define RISCV_EXCP_INST_FAULT 1
#define RISCV_EXCP_ILLEGAL_INST 2
#define RISCV_EXCP_BREAKPOINT 3
#define RISCV_EXCP_LOAD_MISALIGNED 4
#define RISCV_EXCP_LOAD_FAULT 5
#define RISCV_EXCP_STORE_MISALIGNED 6
#define RISCV_EXCP_STORE_FAULT 7
#define RISCV_EXCP_ECALL_U 8
#define RISCV_EXCP_ECALL_S 9
// reserved 10
#define RISCV_EXCP_ECALL_M 11
#define RISCV_EXCP_INST_PAGE_FAULT 12
#define RISCV_EXCP_LOAD_PAGE_FAULT 13
// reserved 14
#define RISCV_EXCP_STORE_PAGE_FAULT 15
#undef assert
#define assert(x) \
if(!(x)) { printf("assertion failed at %s:%d\r\n", __FILE__, __LINE__);\
sbi_exit_enclave(-1); \
}
#ifdef DEBUG
#define debug(format, ...) \
printf ("[debug] " format " (%s:%d)\r\n", ## __VA_ARGS__, __FILE__, __LINE__)
#else
#define debug(format, ...) \
;
#endif
#define warn(format, ...) \
printf ("[warn] " format " (%s:%d)\r\n", ## __VA_ARGS__, __FILE__, __LINE__)
#endif