-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathdpi.c
executable file
·57 lines (48 loc) · 1.64 KB
/
dpi.c
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
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
//#include "svdpi.h"
extern void writew(unsigned int addr, unsigned int data);
extern void readw(unsigned int addr, unsigned int *data);
extern void wait_cycles(int n);
extern void report_info(const char* msg);
extern void report_info_para(const char* msg, int para);
extern void report_warning(const char* msg);
extern void report_error(const char* msg);
extern void report_fatal(const char* msg);
extern void finish();
extern void wait_time(int nb, const char* unit);
#define MCDF_REG_ADDR_START 0x0000
#define MCDF_REG_ADDR_END 0x0FFF
#define MCDF_CH0_ADDR_START 0x1000
#define MCDF_CH0_ADDR_END 0x10FF
#define MCDF_CH1_ADDR_START 0x1100
#define MCDF_CH1_ADDR_END 0x11FF
#define MCDF_CH2_ADDR_START 0x1200
#define MCDF_CH2_ADDR_END 0x12FF
#define MCDF_CH3_ADDR_START 0x1300
#define MCDF_CH3_ADDR_END 0x13FF
#define MCDF_FMT_ADDR_START 0x2000
#define MCDF_FMT_ADDR_END 0x2FFF
int diff_value(unsigned int val1, unsigned int val2) {
if(val1 != val2) {
report_info_para("val1 = %8x", val1);
report_info_para("val2 = %8x", val1);
report_error("EROR! val1 != val2");
return 0;
}
else {
report_info_para("SUCCESS! val1 == val2, value = %8x", val1);
return 1;
}
}
int dpi_c_thread(void) {
unsigned int wr_val, rd_val;
unsigned int i, j;
unsigned int is_equal;
// TODO translate the mcdf_dpi_c_test::run_top_virtual_sequence()
// from UVM sequence to C code.
// USER CODE to implement here
wr_val = (0x1<<3) + (0x1<<2) + (0x1<<1) + 1;
writew(MCDF_REG_ADDR_START+0x00, wr_val);
readw(MCDF_REG_ADDR_START+0x00, &rd_val);
// ...
return 0;
}