|
| 1 | +############################################################################### |
| 2 | +## Copyright (C) 2025 Analog Devices, Inc. All rights reserved. |
| 3 | +### SPDX short identifier: ADIBSD |
| 4 | +############################################################################### |
| 5 | + |
| 6 | +create_bd_intf_port -mode Master -vlnv analog.com:interface:spi_engine_rtl:1.0 ltc2378_spi |
| 7 | + |
| 8 | +create_bd_port -dir O ltc2378_spi_cnv |
| 9 | +create_bd_port -dir I ltc2378_ext_clk |
| 10 | + |
| 11 | +source $ad_hdl_dir/library/spi_engine/scripts/spi_engine.tcl |
| 12 | + |
| 13 | +set data_width 32 |
| 14 | +set async_spi_clk 1 |
| 15 | +set num_cs 1 |
| 16 | +set num_sdi 1 |
| 17 | +set num_sdo 1 |
| 18 | +set sdi_delay 0 |
| 19 | +set echo_sclk 0 |
| 20 | + |
| 21 | +set hier_spi_engine spi_ltc2378 |
| 22 | + |
| 23 | +spi_engine_create $hier_spi_engine $data_width $async_spi_clk $num_cs $num_sdi $num_sdo $sdi_delay $echo_sclk |
| 24 | + |
| 25 | +# activate internal SPI Engine Offload synchronizer |
| 26 | +ad_ip_parameter $hier_spi_engine/${hier_spi_engine}_offload CONFIG.ASYNC_TRIG 1 |
| 27 | + |
| 28 | +# clkgen - 140 MHz |
| 29 | +ad_ip_instance axi_clkgen spi_clkgen |
| 30 | +ad_ip_parameter spi_clkgen CONFIG.CLK0_DIV 5 |
| 31 | +ad_ip_parameter spi_clkgen CONFIG.VCO_DIV 1 |
| 32 | +ad_ip_parameter spi_clkgen CONFIG.VCO_MUL 7 |
| 33 | + |
| 34 | +ad_connect $sys_cpu_clk spi_clkgen/clk |
| 35 | +ad_connect spi_clk spi_clkgen/clk_0 |
| 36 | + |
| 37 | +# pwm generator |
| 38 | +ad_ip_instance axi_pwm_gen ltc2378_trigger_gen |
| 39 | + |
| 40 | +ad_ip_parameter ltc2378_trigger_gen CONFIG.N_PWMS 2 |
| 41 | +ad_ip_parameter ltc2378_trigger_gen CONFIG.PULSE_0_PERIOD 100 |
| 42 | +ad_ip_parameter ltc2378_trigger_gen CONFIG.PULSE_0_WIDTH 2 |
| 43 | +ad_ip_parameter ltc2378_trigger_gen CONFIG.PULSE_1_PERIOD 100 |
| 44 | +ad_ip_parameter ltc2378_trigger_gen CONFIG.PULSE_1_WIDTH 2 |
| 45 | +ad_ip_parameter ltc2378_trigger_gen CONFIG.PULSE_1_OFFSET 1 |
| 46 | + |
| 47 | +ad_connect $sys_cpu_clk ltc2378_trigger_gen/s_axi_aclk |
| 48 | +ad_connect sys_cpu_resetn ltc2378_trigger_gen/s_axi_aresetn |
| 49 | +ad_connect ltc2378_ext_clk ltc2378_trigger_gen/ext_clk |
| 50 | + |
| 51 | +ad_connect ltc2378_spi_cnv ltc2378_trigger_gen/pwm_0 |
| 52 | +ad_connect ltc2378_trigger_gen/pwm_1 $hier_spi_engine/${hier_spi_engine}_offload/trigger |
| 53 | + |
| 54 | +# dma to receive data stream |
| 55 | +ad_ip_instance axi_dmac ltc2378_dma |
| 56 | +ad_ip_parameter ltc2378_dma CONFIG.DMA_TYPE_SRC 1 |
| 57 | +ad_ip_parameter ltc2378_dma CONFIG.DMA_TYPE_DEST 0 |
| 58 | +ad_ip_parameter ltc2378_dma CONFIG.CYCLIC 0 |
| 59 | +ad_ip_parameter ltc2378_dma CONFIG.SYNC_TRANSFER_START 0 |
| 60 | +ad_ip_parameter ltc2378_dma CONFIG.AXI_SLICE_SRC 0 |
| 61 | +ad_ip_parameter ltc2378_dma CONFIG.AXI_SLICE_DEST 1 |
| 62 | +ad_ip_parameter ltc2378_dma CONFIG.DMA_2D_TRANSFER 0 |
| 63 | +ad_ip_parameter ltc2378_dma CONFIG.DMA_DATA_WIDTH_SRC $data_width |
| 64 | +ad_ip_parameter ltc2378_dma CONFIG.DMA_DATA_WIDTH_DEST 64 |
| 65 | + |
| 66 | +ad_connect $sys_cpu_clk $hier_spi_engine/clk |
| 67 | +ad_connect ltc2378_dma/s_axis $hier_spi_engine/M_AXIS_SAMPLE |
| 68 | +ad_connect $hier_spi_engine/m_spi ltc2378_spi |
| 69 | +ad_connect spi_clk $hier_spi_engine/spi_clk |
| 70 | +ad_connect sys_cpu_resetn $hier_spi_engine/resetn |
| 71 | +ad_connect spi_clk ltc2378_dma/s_axis_aclk |
| 72 | +ad_connect sys_cpu_resetn ltc2378_dma/m_dest_axi_aresetn |
| 73 | + |
| 74 | +# AXI address definitions |
| 75 | +ad_cpu_interconnect 0x44a00000 $hier_spi_engine/${hier_spi_engine}_axi_regmap |
| 76 | +ad_cpu_interconnect 0x44a30000 ltc2378_dma |
| 77 | +ad_cpu_interconnect 0x44a70000 spi_clkgen |
| 78 | +ad_cpu_interconnect 0x44b00000 ltc2378_trigger_gen |
| 79 | + |
| 80 | +ad_cpu_interrupt "ps-13" "mb-13" ltc2378_dma/irq |
| 81 | +ad_cpu_interrupt "ps-12" "mb-12" /$hier_spi_engine/irq |
| 82 | + |
| 83 | +ad_mem_hp1_interconnect $sys_cpu_clk sys_ps7/S_AXI_HP1 |
| 84 | +ad_mem_hp1_interconnect $sys_cpu_clk ltc2378_dma/m_dest_axi |
0 commit comments