-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathvadd.v
42 lines (33 loc) · 1.14 KB
/
vadd.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
`line 2 "vadd.tlv" 0 //_\TLV_version 1d: tl-x.org, generated by SandPiper(TM) 1.11-2021/01/28-beta
`include "sp_default.vh" //_\SV
module vadd_kernel#(parameter DATA_WIDTH = 512)(
input axi_clk,
input axi_reset_n,
//AXI-S Slave interface --incoming data
input s_axis_valid, //from master
input [DATA_WIDTH-1:0] s_axis_data,
output s_axis_ready,
//AXI-M Master interface --outgoing data
output reg m_axis_valid,
output reg [DATA_WIDTH-1:0] m_axis_data,
input m_axis_ready
);
//No internal buffer , so full stream mode
integer i;
assign s_axis_ready = m_axis_ready; //When the my slave is ready to accept data I am ready to accept
always @(posedge axi_clk) //Valid data as input and it is already processed 1 clock after
begin
m_axis_valid <= s_axis_valid & s_axis_ready;
end
`include "vadd_gen.v" //_\TLV
/*SV_plus*/
always_ff @(posedge axi_clk)
begin
if (s_axis_valid & s_axis_ready)
begin
for(i=0;i<DATA_WIDTH/32;i=i+1)
m_axis_data[i * 32+:32] <= 1 + s_axis_data[i* 32+: 32];
end
end
//_\SV
endmodule