# system\_pl\_wrapper.v

#### **AUTHORS**

### **JAY CONVERTINO**

#### **DATES**

#### 2023/11/02

## **INFORMATION**

#### **Brief**

System wrapper for pl only for zcu102 board.

#### **License MIT**

Copyright 2023 Jay Convertino

Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:

The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.

THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.

# system\_pl\_wrapper

```
module system_pl_wrapper #(
parameter
FPGA_TECHNOLOGY
=
0,
parameter
FPGA_FAMILY
=
0,
parameter
SPEED_GRADE
```

System wrapper for pl only for zcu102 board.

#### **Parameters**

**FPGA TECHNOLOGY** Type of FPGA, such as Ultrascale, Arria 10. 1 is for 7 series.

Initial Delay for the ADC

parameter

**FPGA\_FAMILY** Sub type of fpga, such as GX, SX, etc. 4 is for zynq.

parameter

**SPEED\_GRADE** Number that corresponds to the ships recommended

parameter speed. 10 is for -1.

**DEV\_PACKAGE** Specify a number that is equal to the manufactures

parameter package. 14 is for cl.

DELAY\_REFCLK\_FREQUENCY

parameter

Reference clock frequency used for ad\_data\_in instances

ADC\_INIT\_DELAY

parameter

**DAC\_INIT\_DELAY** Initial Delay for the DAC

oarameter

#### **Ports**

| axi_aclk      | AXI Lite control bus |
|---------------|----------------------|
| axi_aresetn   | AXI Lite control bus |
| s_axi_awvalid | AXI Lite control bus |
| s_axi_awaddr  | AXI Lite control bus |
| s_axi_awready | AXI Lite control bus |
| s_axi_awprot  | AXI Lite control bus |
| s_axi_wvalid  | AXI Lite control bus |
| s_axi_wdata   | AXI Lite control bus |
| s_axi_wstrb   | AXI Lite control bus |
| s_axi_wready  | AXI Lite control bus |
| s_axi_bvalid  | AXI Lite control bus |
| s_axi_bresp   | AXI Lite control bus |
| s_axi_bready  | AXI Lite control bus |

s axi arvalid AXI Lite control bus s\_axi\_araddr AXI Lite control bus s\_axi\_arready AXI Lite control bus s\_axi\_arprot AXI Lite control bus s\_axi\_rvalid AXI Lite control bus s\_axi\_rready AXI Lite control bus s axi rresp AXI Lite control bus s axi rdata AXI Lite control bus adc\_dma\_irq fmcomms5 ADC ira dac\_dma\_irq fmcomms5 DAC irq delay\_clk fmcomms5 delay clock

fmcomms5 0 rx clk rx clk in 0 p rx\_clk\_in\_0\_n fmcomms5 0 rx clk rx frame in 0 p fmcomms5 0 rx frame rx\_frame\_in\_0\_n fmcomms5 0 rx frame rx\_data\_in\_0\_p fmcomms5 0 rx data fmcomms5 0 rx data rx\_data\_in\_0\_n tx clk out 0 p fmcomms5 0 tx clk tx\_clk\_out\_0\_n fmcomms5 0 tx clk tx\_frame\_out\_0\_p fmcomms5 0 tx frame fmcomms5 0 tx frame tx\_frame\_out\_0\_n fmcomms5 0 tx data tx\_data\_out\_0\_p tx\_data\_out\_0\_n fmcomms5 0 tx data txnrx\_0 fmcomms5 0 txnrx enable 0 fmcomms5 0 enable up\_enable\_0 fmcomms5 0 enable input up\_txnrx\_0 fmcomms5 0 txnrx select input

tdd\_sync\_0\_t

tdd\_sync\_0\_i tdd\_sync\_0\_o

fmcomms5 1 rx clk rx clk in 1 p rx\_clk\_in\_1\_n fmcomms5 1 rx clk rx\_frame\_in\_1\_p fmcomms5 1 rx frame rx\_frame\_in\_1\_n fmcomms5 1 rx frame rx data in 1 p fmcomms5 1 rx data fmcomms5 1 rx data rx\_data\_in\_1\_n tx clk out 1 p fmcomms5 1 tx clk tx\_clk\_out\_1\_n fmcomms5 1 tx clk tx\_frame\_out\_1\_p fmcomms5 1 tx frame fmcomms5 1 tx frame tx\_frame\_out\_1\_n fmcomms5 1 tx data tx\_data\_out\_1\_p

fmcomms5 0 TDD sync i/o fmcomms5 0 TDD sync i/o

fmcomms5 0 TDD sync i/o

tx\_data\_out\_1\_n fmcomms5 1 tx data txnrx\_1 fmcomms5 1 txnrx enable 1 fmcomms5 1 enable up\_enable\_1 fmcomms5 1 enable input up\_txnrx\_1 fmcomms5 1 txnrx select input tdd\_sync\_1\_t fmcomms5 1 TDD sync i/o tdd\_sync\_1\_i fmcomms5 1 TDD sync i/o tdd sync 1 o fmcomms5 1 TDD sync i/o m axi aclk DMA Clock adc\_m\_dest\_axi\_awaddr fmcomms5 ADC DMA fmcomms5 ADC DMA adc\_m\_dest\_axi\_awlen adc\_m\_dest\_axi\_awsize fmcomms5 ADC DMA adc m dest axi awburst fmcomms5 ADC DMA adc m dest axi awprot fmcomms5 ADC DMA adc m dest axi awcache fmcomms5 ADC DMA adc\_m\_dest\_axi\_awvalid fmcomms5 ADC DMA adc m dest axi awready fmcomms5 ADC DMA adc\_m\_dest\_axi\_wdata fmcomms5 ADC DMA adc\_m\_dest\_axi\_wstrb fmcomms5 ADC DMA adc\_m\_dest\_axi\_wready fmcomms5 ADC DMA adc m dest axi wvalid fmcomms5 ADC DMA adc\_m\_dest\_axi\_wlast fmcomms5 ADC DMA adc\_m\_dest\_axi\_bvalid fmcomms5 ADC DMA adc\_m\_dest\_axi\_bresp fmcomms5 ADC DMA adc\_m\_dest\_axi\_bready fmcomms5 ADC DMA dac\_m\_src\_axi\_arready fmcomms5 DAC DMA dac\_m\_src\_axi\_arvalid fmcomms5 DAC DMA dac m src axi araddr fmcomms5 DAC DMA dac\_m\_src\_axi\_arlen fmcomms5 DAC DMA fmcomms5 DAC DMA dac\_m\_src\_axi\_arsize dac\_m\_src\_axi\_arburst fmcomms5 DAC DMA dac m src axi arprot fmcomms5 DAC DMA dac\_m\_src\_axi\_arcache fmcomms5 DAC DMA dac\_m\_src\_axi\_rdata fmcomms5 DAC DMA dac\_m\_src\_axi\_rready fmcomms5 DAC DMA fmcomms5 DAC DMA dac\_m\_src\_axi\_rvalid fmcomms5 DAC DMA dac\_m\_src\_axi\_rresp dac m src axi rlast fmcomms5 DAC DMA

### **INSTANTIANTED MODULES**

# inst\_dma\_rstgen

```
dma_rstgen inst_dma_rstgen (
    slowest_sync_clk(m_axi_aclk),
    ext_reset_in(axi_aresetn),
    aux_reset_in(1'b1),
    mb_debug_sys_rst(1'b0),
    dcm_locked(1'b1),
    mb_reset(),
    bus_struct_reset(),
    peripheral_reset(),
    interconnect_aresetn(),
    peripheral_aresetn(m_axi_aresetn)
    )
```

Generate a new DMA reset based on delay clock.