forked from firesim/aws-fpga-firesim
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathcl_sda_slv.sv
102 lines (86 loc) · 3.1 KB
/
cl_sda_slv.sv
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
// Amazon FPGA Hardware Development Kit
//
// Copyright 2016 Amazon.com, Inc. or its affiliates. All Rights Reserved.
//
// Licensed under the Amazon Software License (the "License"). You may not use
// this file except in compliance with the License. A copy of the License is
// located at
//
// http://aws.amazon.com/asl/
//
// or in the "license" file accompanying this file. This file is distributed on
// an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, express or
// implied. See the License for the specific language governing permissions and
// limitations under the License.
module cl_sda_slv (
input aclk,
input aresetn,
axi_bus_t.master sda_cl_bus
);
axi_bus_t sda_cl_q();
//---------------------------------
// flop the input SDA bus
//---------------------------------
axi_register_slice_light AXIL_SDA_REG_SLC (
.aclk (aclk),
.aresetn (aresetn),
.s_axi_awaddr (sda_cl_bus.awaddr[31:0]),
.s_axi_awvalid (sda_cl_bus.awvalid),
.s_axi_awready (sda_cl_bus.awready),
.s_axi_wdata (sda_cl_bus.wdata[31:0]),
.s_axi_wstrb (sda_cl_bus.wstrb[3:0]),
.s_axi_wvalid (sda_cl_bus.wvalid),
.s_axi_wready (sda_cl_bus.wready),
.s_axi_bresp (sda_cl_bus.bresp),
.s_axi_bvalid (sda_cl_bus.bvalid),
.s_axi_bready (sda_cl_bus.bready),
.s_axi_araddr (sda_cl_bus.araddr[31:0]),
.s_axi_arvalid (sda_cl_bus.arvalid),
.s_axi_arready (sda_cl_bus.arready),
.s_axi_rdata (sda_cl_bus.rdata[31:0]),
.s_axi_rresp (sda_cl_bus.rresp),
.s_axi_rvalid (sda_cl_bus.rvalid),
.s_axi_rready (sda_cl_bus.rready),
.m_axi_awaddr (sda_cl_q.awaddr[31:0]),
.m_axi_awvalid (sda_cl_q.awvalid),
.m_axi_awready (sda_cl_q.awready),
.m_axi_wdata (sda_cl_q.wdata[31:0]),
.m_axi_wstrb (sda_cl_q.wstrb[3:0]),
.m_axi_wvalid (sda_cl_q.wvalid),
.m_axi_wready (sda_cl_q.wready),
.m_axi_bresp (sda_cl_q.bresp),
.m_axi_bvalid (sda_cl_q.bvalid),
.m_axi_bready (sda_cl_q.bready),
.m_axi_araddr (sda_cl_q.araddr[31:0]),
.m_axi_arvalid (sda_cl_q.arvalid),
.m_axi_arready (sda_cl_q.arready),
.m_axi_rdata (sda_cl_q.rdata[31:0]),
.m_axi_rresp (sda_cl_q.rresp),
.m_axi_rvalid (sda_cl_q.rvalid),
.m_axi_rready (sda_cl_q.rready)
);
//---------------------------------
// RAM slave for SDA accesses
//---------------------------------
axil_slave AXIL_SLAVE(
.clk(aclk),
.rst_n(aresetn),
.awvalid(sda_cl_q.awvalid),
.awaddr({54'b0, sda_cl_q.awaddr[9:0]}),
.awready(sda_cl_q.awready),
.wvalid(sda_cl_q.wvalid),
.wdata(sda_cl_q.wdata[31:0]),
.wstrb(sda_cl_q.wstrb[3:0]),
.wready(sda_cl_q.wready),
.bvalid(sda_cl_q.bvalid),
.bresp(sda_cl_q.bresp),
.bready(sda_cl_q.bready),
.arvalid(sda_cl_q.arvalid),
.araddr({54'b0, sda_cl_q.araddr[9:0]}),
.arready(sda_cl_q.arready),
.rvalid(sda_cl_q.rvalid),
.rdata(sda_cl_q.rdata[31:0]),
.rresp(sda_cl_q.rresp),
.rready(sda_cl_q.rready)
);
endmodule