-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathtb12.3.19.2.v
184 lines (164 loc) · 3.93 KB
/
tb12.3.19.2.v
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
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
`timescale 1 ns / 100 ps
module tb_tb;
reg timx_int0;
reg timx_int1;
reg timx_int2;
reg timx_int3;
reg css_ck_fail;
reg debug_mode;
reg timx_dbg_stop;
reg timx_etr;//极性选择,边沿检测和预分频器
reg timx_bkin;//刹车信号
reg [6:0] timx_dma_ack;
reg apb_clk;
reg apb_rst_n;
reg timx_psel;
reg timx_penable;
reg timx_pwrite;
reg [15:0] timx_paddr;
reg [31:0] timx_pwdata;
reg timx_ch1_in;
reg timx_ch2_in;
reg timx_ch3_in;
reg timx_ch4_in;
reg scan_mode;
reg scan_enable;
reg cfg_timx_break_ossi0_disout;
wire [7:0] tim_dbg_sigs;
wire timx_trgo;
wire timx_int;
wire timx_int_cc4of;
wire timx_int_cc3of;
wire timx_int_cc2of;
wire timx_int_cc1of;
wire timx_int_bk;
wire timx_int_trigger;
wire timx_int_com;
wire timx_int_cc4;
wire timx_int_cc3;
wire timx_int_cc2;
wire timx_int_cc1;
wire timx_int_ud;
wire [31:0] timx_prdata;
wire [6:0] timx_dma_req;
wire [6:0] timx_dma_single;
wire cc1_event;
wire cc2_event;
wire cc3_event;
wire cc4_event;
wire timx_ch1_out;
wire timx_ch1_out_en;
wire timx_ch1n_out;
wire timx_ch1n_out_en;
wire timx_ch2_out;
wire timx_ch2_out_en;
wire timx_ch2n_out;
wire timx_ch2n_out_en;
wire timx_ch3_out;
wire timx_ch3_out_en;
wire timx_ch3n_out;
wire timx_ch3n_out_en;
wire timx_ch4_out;
wire timx_ch4_out_en;
apoip_timer u1(
//regs
.timx_int0(timx_int0),
.timx_int1(timx_int1),
.timx_int2(timx_int2),
.timx_int3(timx_int3),
.css_ck_fail(css_ck_fail),
.debug_mode(debug_mode),
.timx_dbg_stop(timx_dbg_stop),
.timx_etr(timx_etr),
.timx_bkin(timx_bkin),
.timx_dma_ack(timx_dma_ack),
.apb_clk(apb_clk),
.apb_rst_n(apb_rst_n),
.timx_psel(timx_psel),
.timx_penable(timx_penable),
.timx_pwrite(timx_pwrite),
.timx_paddr(timx_paddr),
.timx_pwdata(timx_pwdata),
.timx_ch1_in(timx_ch1_in),
.timx_ch2_in(timx_ch2_in),
.timx_ch3_in(timx_ch3_in),
.timx_ch4_in(timx_ch4_in),
.scan_mode(scan_mode),
.scan_enable(scan_enable),
.cfg_timx_break_ossi0_disout(cfg_timx_break_ossi0_disout),
//wires
.tim_dbg_sigs(tim_dbg_sigs),
.timx_trgo(timx_trgo),
.timx_int(timx_int),
.timx_int_cc4of(timx_int_cc4of),
.timx_int_cc3of(timx_int_cc3of),
.timx_int_cc2of(timx_int_cc2of),
.timx_int_cc1of(timx_int_cc1of),
.timx_int_bk(timx_int_bk),
.timx_int_trigger(timx_int_trigger),
.timx_int_com(timx_int_com),
.timx_int_cc4(timx_int_cc4),
.timx_int_cc3(timx_int_cc3),
.timx_int_cc2(timx_int_cc2),
.timx_int_cc1(timx_int_cc1),
.timx_int_ud(timx_int_ud),
.timx_prdata(timx_prdata),
.timx_dma_req(timx_dma_req),
.timx_dma_single(timx_dma_single),
.cc1_event(cc1_event),
.cc2_event(cc2_event),
.cc3_event(cc3_event),
.cc4_event(cc4_event),
.timx_ch1_out(timx_ch1_out),
.timx_ch1_out_en(timx_ch1_out_en),
.timx_ch1n_out(timx_ch1n_out),
.timx_ch1n_out_en(timx_ch1n_out_en),
.timx_ch2_out(timx_ch2_out),
.timx_ch2_out_en(timx_ch2_out_en),
.timx_ch2n_out(timx_ch2n_out),
.timx_ch2n_out_en(timx_ch2n_out_en),
.timx_ch3_out(timx_ch3_out),
.timx_ch3_out_en(timx_ch3_out_en),
.timx_ch3n_out(timx_ch3n_out),
.timx_ch3n_out_en(timx_ch3n_out_en),
.timx_ch4_out(timx_ch4_out),
.timx_ch4_out_en(timx_ch4_out_en)
);
always #5 apb_clk=~apb_clk;
initial begin
apb_clk=0;
apb_rst_n=0;
timx_ch1_in=0;
#100
apb_rst_n=1;
timx_psel=1;
timx_penable=0;
timx_pwrite=1;
timx_paddr=16'h002c;//自动重装载寄存器
timx_pwdata=32'h00000036;
#10000
timx_paddr=16'h0018;//CCMR1
timx_pwdata=32'h00000001;
#10000
timx_paddr=16'h0020;//CCER
timx_pwdata=32'h00000002;
#10000
timx_paddr=16'h0008;//SMCR
timx_pwdata=32'h00000055;
#10000
timx_paddr=16'h000C;//DIER
timx_pwdata=32'h00000040;
#10000
timx_paddr=16'b0;//控制寄存器1
timx_pwdata=32'h00000001;
#100
timx_pwrite=0;
timx_paddr=16'h0010;
#100050
timx_ch1_in=1;
#50
timx_ch1_in=0;
#1000000
$stop;
end
endmodule