-
Notifications
You must be signed in to change notification settings - Fork 8
/
Copy pathcl_ports.vh
534 lines (460 loc) · 23.2 KB
/
cl_ports.vh
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
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
//---------------------------------------------------------------------------------------
// 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.
//---------------------------------------------------------------------------------------
//-----------------------------------------------------------------------------------------------------
// Note please see the Shell Interface Specification for more details on the interfaces:
//
// https://github.com/aws/aws-fpga/blob/master/hdk/docs/AWS_Shell_Interface_Specification.md
//
//-----------------------------------------------------------------------------------------------------
//--------------------------------
// Globals
//--------------------------------
input clk_main_a0, //Main clock. This is the clock for all of the interfaces to the SH
input clk_extra_a1, //Extra clock A1 (phase aligned to "A" clock group)
input clk_extra_a2, //Extra clock A2 (phase aligned to "A" clock group)
input clk_extra_a3, //Extra clock A3 (phase aligned to "A" clock group)
input clk_extra_b0, //Extra clock B0 (phase aligned to "B" clock group)
input clk_extra_b1, //Extra clock B1 (phase aligned to "B" clock group)
input clk_extra_c0, //Extra clock C0 (phase aligned to "B" clock group)
input clk_extra_c1, //Extra clock C1 (phase aligned to "B" clock group)
input kernel_rst_n, //Kernel reset (for SDA platform)
input rst_main_n, //Reset sync'ed to main clock.
input sh_cl_flr_assert, //Function level reset assertion. Level signal that indicates PCIe function level reset is asserted
output logic cl_sh_flr_done, //Function level reset done indication. Must be asserted by CL when done processing function level reset.
output logic[31:0] cl_sh_status0, //Functionality TBD
output logic[31:0] cl_sh_status1, //Functionality TBD
output logic[31:0] cl_sh_id0, //15:0 - PCI Vendor ID
//31:16 - PCI Device ID
output logic[31:0] cl_sh_id1, //15:0 - PCI Subsystem Vendor ID
//31:16 - PCI Subsystem ID
input[31:0] sh_cl_ctl0, //Functionality TBD
input[31:0] sh_cl_ctl1, //Functionality TBD
input[15:0] sh_cl_status_vdip, //Virtual DIP switches. Controlled through FPGA management PF and tools.
output logic[15:0] cl_sh_status_vled, //Virtual LEDs, monitored through FPGA management PF and tools
input[1:0] sh_cl_pwr_state, //Power state, 2'b00: Normal, 2'b11: Critical
// These signals relate to the dma_pcis interface (BAR4). They should be
// asserted when the CL is running out of resources and will not be able
// to accept certain types of transactions.
output logic cl_sh_dma_wr_full, // Resources low for dma writes (DMA_PCIS AXI ID: 0x00-0x03)
output logic cl_sh_dma_rd_full, // Resources low for dma reads (DMA_PCIS AXI ID: 0x00-0x03)
//-------------------------------------------------------------------------------------------
// PCIe Master interface from CL
//
// AXI-4 master interface per PCIe interface. This is for PCIe transactions mastered
// from the SH targetting the host (DMA access to host). Standard AXI-4 interface.
//-------------------------------------------------------------------------------------------
output logic[15:0] cl_sh_pcim_awid,
output logic[63:0] cl_sh_pcim_awaddr,
output logic[7:0] cl_sh_pcim_awlen,
output logic[2:0] cl_sh_pcim_awsize,
output logic[18:0] cl_sh_pcim_awuser, //RESERVED (not used)
output logic cl_sh_pcim_awvalid,
input sh_cl_pcim_awready,
output logic[511:0] cl_sh_pcim_wdata,
output logic[63:0] cl_sh_pcim_wstrb,
output logic cl_sh_pcim_wlast,
output logic cl_sh_pcim_wvalid,
input sh_cl_pcim_wready,
input logic[15:0] sh_cl_pcim_bid,
input logic[1:0] sh_cl_pcim_bresp,
input logic sh_cl_pcim_bvalid,
output logic cl_sh_pcim_bready,
output logic[15:0] cl_sh_pcim_arid, //Note max 32 outstanding txns are supported, width is larger to allow bits for AXI fabrics
output logic[63:0] cl_sh_pcim_araddr,
output logic[7:0] cl_sh_pcim_arlen,
output logic[2:0] cl_sh_pcim_arsize,
output logic[18:0] cl_sh_pcim_aruser, // RESERVED (not used)
output logic cl_sh_pcim_arvalid,
input sh_cl_pcim_arready,
input[15:0] sh_cl_pcim_rid,
input[511:0] sh_cl_pcim_rdata,
input[1:0] sh_cl_pcim_rresp,
input sh_cl_pcim_rlast,
input sh_cl_pcim_rvalid,
output logic cl_sh_pcim_rready,
input[1:0] cfg_max_payload, //Max payload size - 00:128B, 01:256B, 10:512B
input[2:0] cfg_max_read_req //Max read requst size - 000b:128B, 001b:256B, 010b:512B, 011b:1024B
// 100b-2048B, 101b:4096B
//-----------------------------------------------------------------------------------------------
// DDR-4 Interface
//
// x3 DDR is instantiated in CL. This is the physical interface (fourth DDR is in SH)
// These interfaces must be connected to an instantiated sh_ddr in the CL logic.
// Note even if DDR interfaces are not used, sh_ddr must be instantiated and connected
// to these interface ports. The sh_ddr block has parameters to control which DDR
// controllers are instantiated. If a DDR controller is not instantiated it will not
// take up FPGA resources.
//-----------------------------------------------------------------------------------------------
`ifndef NO_CL_DDR
,
// ------------------- DDR4 x72 RDIMM 2100 Interface A ----------------------------------
input CLK_300M_DIMM0_DP,
input CLK_300M_DIMM0_DN,
output M_A_ACT_N,
output [16:0] M_A_MA,
output [1:0] M_A_BA,
output [1:0] M_A_BG,
output [0:0] M_A_CKE,
output [0:0] M_A_ODT,
output [0:0] M_A_CS_N,
output [0:0] M_A_CLK_DN,
output [0:0] M_A_CLK_DP,
output M_A_PAR,
inout [63:0] M_A_DQ,
inout [7:0] M_A_ECC,
inout [17:0] M_A_DQS_DP,
inout [17:0] M_A_DQS_DN,
output cl_RST_DIMM_A_N,
// ------------------- DDR4 x72 RDIMM 2100 Interface B ----------------------------------
input CLK_300M_DIMM1_DP,
input CLK_300M_DIMM1_DN,
output M_B_ACT_N,
output [16:0] M_B_MA,
output [1:0] M_B_BA,
output [1:0] M_B_BG,
output [0:0] M_B_CKE,
output [0:0] M_B_ODT,
output [0:0] M_B_CS_N,
output [0:0] M_B_CLK_DN,
output [0:0] M_B_CLK_DP,
output M_B_PAR,
inout [63:0] M_B_DQ,
inout [7:0] M_B_ECC,
inout [17:0] M_B_DQS_DP,
inout [17:0] M_B_DQS_DN,
output cl_RST_DIMM_B_N,
// ------------------- DDR4 x72 RDIMM 2100 Interface D ----------------------------------
input CLK_300M_DIMM3_DP,
input CLK_300M_DIMM3_DN,
output M_D_ACT_N,
output [16:0] M_D_MA,
output [1:0] M_D_BA,
output [1:0] M_D_BG,
output [0:0] M_D_CKE,
output [0:0] M_D_ODT,
output [0:0] M_D_CS_N,
output [0:0] M_D_CLK_DN,
output [0:0] M_D_CLK_DP,
output M_D_PAR,
inout [63:0] M_D_DQ,
inout [7:0] M_D_ECC,
inout [17:0] M_D_DQS_DP,
inout [17:0] M_D_DQS_DN,
output cl_RST_DIMM_D_N
`endif
//-----------------------------------------------------------------------------
// DDR Stats interfaces for DDR controllers in the CL. This must be hooked up
// to the sh_ddr.sv for the DDR interfaces to function. If the DDR controller is
// not used (removed through parameter on the sh_ddr instantiated), then the
// associated stats interface should not be hooked up and the ddr_sh_stat_ackX signal
// should be tied high.
//-----------------------------------------------------------------------------
,
input [7:0] sh_ddr_stat_addr0, //Stats address
input sh_ddr_stat_wr0, //Stats write strobe
input sh_ddr_stat_rd0, //Stats read strobe
input [31:0] sh_ddr_stat_wdata0, //Stats write data
output logic ddr_sh_stat_ack0, //Stats cycle ack
output logic[31:0] ddr_sh_stat_rdata0, //Stats cycle read data
output logic[7:0] ddr_sh_stat_int0, //Stats interrupt
input [7:0] sh_ddr_stat_addr1,
input sh_ddr_stat_wr1,
input sh_ddr_stat_rd1,
input [31:0] sh_ddr_stat_wdata1,
output logic ddr_sh_stat_ack1,
output logic[31:0] ddr_sh_stat_rdata1,
output logic[7:0] ddr_sh_stat_int1,
input [7:0] sh_ddr_stat_addr2,
input sh_ddr_stat_wr2,
input sh_ddr_stat_rd2,
input [31:0] sh_ddr_stat_wdata2,
output logic ddr_sh_stat_ack2,
output logic[31:0] ddr_sh_stat_rdata2,
output logic[7:0] ddr_sh_stat_int2,
//-----------------------------------------------------------------------------------
// AXI4 Interface for DDR_C
// This is the DDR controller that is instantiated in the SH. CL is the AXI-4
// master, and the DDR_C controller in the SH is the slave.
//-----------------------------------------------------------------------------------
output [15:0] cl_sh_ddr_awid,
output [63:0] cl_sh_ddr_awaddr,
output [7:0] cl_sh_ddr_awlen,
output [2:0] cl_sh_ddr_awsize,
output [1:0] cl_sh_ddr_awburst, //Burst mode, only INCR is supported, must be tied to 2'b01
output cl_sh_ddr_awvalid,
input sh_cl_ddr_awready,
output [15:0] cl_sh_ddr_wid,
output [511:0] cl_sh_ddr_wdata,
output [63:0] cl_sh_ddr_wstrb,
output cl_sh_ddr_wlast,
output cl_sh_ddr_wvalid,
input sh_cl_ddr_wready,
input[15:0] sh_cl_ddr_bid,
input[1:0] sh_cl_ddr_bresp,
input sh_cl_ddr_bvalid,
output cl_sh_ddr_bready,
output [15:0] cl_sh_ddr_arid,
output [63:0] cl_sh_ddr_araddr,
output [7:0] cl_sh_ddr_arlen,
output [2:0] cl_sh_ddr_arsize,
output [1:0] cl_sh_ddr_arburst, //Burst mode, only INCR is supported, must be tied to 2'b01
output cl_sh_ddr_arvalid,
input sh_cl_ddr_arready,
input[15:0] sh_cl_ddr_rid,
input[511:0] sh_cl_ddr_rdata,
input[1:0] sh_cl_ddr_rresp,
input sh_cl_ddr_rlast,
input sh_cl_ddr_rvalid,
output cl_sh_ddr_rready,
input sh_cl_ddr_is_ready
//---------------------------------------------------------------------------------------
// The user-defined interrupts. These map to MSI-X vectors through mapping in the SH.
//---------------------------------------------------------------------------------------
,
output logic[15:0] cl_sh_apppf_irq_req, //Interrupt request. The request (cl_sh_apppf_irq_req[n]) should be pulsed (single clock) to generate
// an interrupt request. Another request should not be generated until ack'ed by the SH
input [15:0] sh_cl_apppf_irq_ack //Interrupt ack. SH asserts sh_cl_apppf_irq_ack[n] (single clock pulse) to acknowledge the corresponding
// interrupt request (cl_sh_apppf_irq_req[n]) from the CL
//----------------------------------------------------
// PCIS AXI-4 interface to master cycles to CL
//----------------------------------------------------
`ifndef SH_NO_PCIS
,
input[5:0] sh_cl_dma_pcis_awid,
input[63:0] sh_cl_dma_pcis_awaddr,
input[7:0] sh_cl_dma_pcis_awlen,
input[2:0] sh_cl_dma_pcis_awsize,
input sh_cl_dma_pcis_awvalid,
output logic cl_sh_dma_pcis_awready,
input[511:0] sh_cl_dma_pcis_wdata,
input[63:0] sh_cl_dma_pcis_wstrb,
input sh_cl_dma_pcis_wlast,
input sh_cl_dma_pcis_wvalid,
output logic cl_sh_dma_pcis_wready,
output logic[5:0] cl_sh_dma_pcis_bid,
output logic[1:0] cl_sh_dma_pcis_bresp,
output logic cl_sh_dma_pcis_bvalid,
input sh_cl_dma_pcis_bready,
input[5:0] sh_cl_dma_pcis_arid,
input[63:0] sh_cl_dma_pcis_araddr,
input[7:0] sh_cl_dma_pcis_arlen,
input[2:0] sh_cl_dma_pcis_arsize,
input sh_cl_dma_pcis_arvalid,
output logic cl_sh_dma_pcis_arready,
output logic[5:0] cl_sh_dma_pcis_rid,
output logic[511:0] cl_sh_dma_pcis_rdata,
output logic[1:0] cl_sh_dma_pcis_rresp,
output logic cl_sh_dma_pcis_rlast,
output logic cl_sh_dma_pcis_rvalid,
input sh_cl_dma_pcis_rready
`endif
//------------------------------------------------------------------------------------------
// AXI-L maps to any inbound PCIe access through ManagementPF BAR4 for developer's use
// If the CL is created through Xilinx’s SDAccel, then this configuration bus
// would be connected automatically to SDAccel generic logic (SmartConnect, APM etc)
//------------------------------------------------------------------------------------------
`ifndef SH_NO_SDA
,
input sda_cl_awvalid,
input[31:0] sda_cl_awaddr,
output logic cl_sda_awready,
//Write data
input sda_cl_wvalid,
input[31:0] sda_cl_wdata,
input[3:0] sda_cl_wstrb,
output logic cl_sda_wready,
//Write response
output logic cl_sda_bvalid,
output logic[1:0] cl_sda_bresp,
input sda_cl_bready,
//Read address
input sda_cl_arvalid,
input[31:0] sda_cl_araddr,
output logic cl_sda_arready,
//Read data/response
output logic cl_sda_rvalid,
output logic[31:0] cl_sda_rdata,
output logic[1:0] cl_sda_rresp,
input sda_cl_rready
`endif
//------------------------------------------------------------------------------------------
// AXI-L maps to any inbound PCIe access through AppPF BAR0
// For example, this AXI-L interface can connect to OpenCL Kernels
// This would connect automatically to the required logic
// if the CL is created through SDAccel flow
//------------------------------------------------------------------------------------------
,
input sh_ocl_awvalid,
input[31:0] sh_ocl_awaddr,
output logic ocl_sh_awready,
//Write data
input sh_ocl_wvalid,
input[31:0] sh_ocl_wdata,
input[3:0] sh_ocl_wstrb,
output logic ocl_sh_wready,
//Write response
output logic ocl_sh_bvalid,
output logic[1:0] ocl_sh_bresp,
input sh_ocl_bready,
//Read address
input sh_ocl_arvalid,
input[31:0] sh_ocl_araddr,
output logic ocl_sh_arready,
//Read data/response
output logic ocl_sh_rvalid,
output logic[31:0] ocl_sh_rdata,
output logic[1:0] ocl_sh_rresp,
input sh_ocl_rready
//------------------------------------------------------------------------------------------
// AXI-L maps to any inbound PCIe access through AppPF BAR1
// For example,
//------------------------------------------------------------------------------------------
`ifndef SH_NO_BAR1
,
input sh_bar1_awvalid,
input[31:0] sh_bar1_awaddr,
output logic bar1_sh_awready,
//Write data
input sh_bar1_wvalid,
input[31:0] sh_bar1_wdata,
input[3:0] sh_bar1_wstrb,
output logic bar1_sh_wready,
//Write response
output logic bar1_sh_bvalid,
output logic[1:0] bar1_sh_bresp,
input sh_bar1_bready,
//Read address
input sh_bar1_arvalid,
input[31:0] sh_bar1_araddr,
output logic bar1_sh_arready,
//Read data/response
output logic bar1_sh_rvalid,
output logic[31:0] bar1_sh_rdata,
output logic[1:0] bar1_sh_rresp,
input sh_bar1_rready
`endif
//-------------------------------------------------------------------------------------------
// Debug bridge -- This is for Virtual JTAG. If enabling the CL for
// Virtual JTAG (chipcope) debug, connect this interface to the debug bridge in the CL
//-------------------------------------------------------------------------------------------
,
input drck,
input shift,
input tdi,
input update,
input sel,
output logic tdo,
input tms,
input tck,
input runtest,
input reset,
input capture,
input bscanid_en
//-------------------------------------------------------------
// These are global counters that increment every 4ns. They
// are synchronized to clk_main_a0. Note if clk_main_a0 is
// slower than 250MHz, the CL will see skips in the counts
//-------------------------------------------------------------
,
input[63:0] sh_cl_glcount0, //Global counter 0
input[63:0] sh_cl_glcount1 //Global counter 1
//-------------------------------------------------------------------------------------
// Serial GTY interface
// AXI-Stream interface to send/receive packets to/from Serial interfaces.
// This interface TBD.
//-------------------------------------------------------------------------------------
//
//------------------------------------------------------
// Aurora Interface from CL (AXI-S)
//------------------------------------------------------
`ifdef AURORA
,
//-------------------------------
// GTY
//-------------------------------
output [NUM_GTY-1:0] cl_sh_aurora_channel_up,
input [NUM_GTY-1:0] gty_refclk_p,
input [NUM_GTY-1:0] gty_refclk_n,
input [(NUM_GTY*4)-1:0] gty_txp,
input [(NUM_GTY*4)-1:0] gty_txn,
input [(NUM_GTY*4)-1:0] gty_rxp,
input [(NUM_GTY*4)-1:0] gty_rxn
,
input [7:0] sh_aurora_stat_addr,
input sh_aurora_stat_wr,
input sh_aurora_stat_rd,
input [31:0] sh_aurora_stat_wdata,
output logic aurora_sh_stat_ack,
output logic[31:0] aurora_sh_stat_rdata,
output logic[7:0] aurora_sh_stat_int
`endif // `ifdef AURORA
`ifdef HMC_PRESENT
//-----------------------------------------------------------------
// HMC Interface -- this is not currently used
//-----------------------------------------------------------------
,
input dev01_refclk_p ,
input dev01_refclk_n ,
input dev23_refclk_p ,
input dev23_refclk_n ,
/* HMC0 interface */
output wire hmc0_dev_p_rst_n ,
input wire hmc0_rxps ,
output wire hmc0_txps ,
output wire [7 : 0] hmc0_txp ,
output wire [7 : 0] hmc0_txn ,
input wire [7 : 0] hmc0_rxp ,
input wire [7 : 0] hmc0_rxn ,
/* HMC1 interface */
output wire hmc1_dev_p_rst_n ,
input wire hmc1_rxps ,
output wire hmc1_txps ,
output wire [7 : 0] hmc1_txp ,
output wire [7 : 0] hmc1_txn ,
input wire [7 : 0] hmc1_rxp ,
input wire [7 : 0] hmc1_rxn ,
/* HMC2 interface */
output wire hmc2_dev_p_rst_n ,
input wire hmc2_rxps ,
output wire hmc2_txps ,
output wire [7 : 0] hmc2_txp ,
output wire [7 : 0] hmc2_txn ,
input wire [7 : 0] hmc2_rxp ,
input wire [7 : 0] hmc2_rxn ,
/* HMC3 interface */
output wire hmc3_dev_p_rst_n ,
input wire hmc3_rxps ,
output wire hmc3_txps ,
output wire [7 : 0] hmc3_txp ,
output wire [7 : 0] hmc3_txn ,
input wire [7 : 0] hmc3_rxp ,
input wire [7 : 0] hmc3_rxn
,
input hmc_iic_scl_i,
output logic hmc_iic_scl_o,
output logic hmc_iic_scl_t,
input hmc_iic_sda_i,
output logic hmc_iic_sda_o,
output logic hmc_iic_sda_t,
input[7:0] sh_hmc_stat_addr,
input sh_hmc_stat_wr,
input sh_hmc_stat_rd,
input[31:0] sh_hmc_stat_wdata,
output logic hmc_sh_stat_ack,
output logic [31:0] hmc_sh_stat_rdata,
output logic[7:0] hmc_sh_stat_int
`endif