148 lines
6.8 KiB
Tcl
148 lines
6.8 KiB
Tcl
# create board design
|
|
# default ports
|
|
|
|
create_bd_port -dir O -from 2 -to 0 spi0_csn
|
|
create_bd_port -dir O spi0_sclk
|
|
create_bd_port -dir O spi0_mosi
|
|
create_bd_port -dir I spi0_miso
|
|
|
|
create_bd_port -dir I -from 94 -to 0 gpio_i
|
|
create_bd_port -dir O -from 94 -to 0 gpio_o
|
|
create_bd_port -dir O -from 94 -to 0 gpio_t
|
|
|
|
# instance: sys_ps8
|
|
|
|
ad_ip_instance zynq_ultra_ps_e sys_ps8
|
|
|
|
ad_ip_parameter sys_ps8 CONFIG.PSU__USE__M_AXI_GP0 0
|
|
ad_ip_parameter sys_ps8 CONFIG.PSU__USE__M_AXI_GP1 0
|
|
ad_ip_parameter sys_ps8 CONFIG.PSU__USE__M_AXI_GP2 1
|
|
ad_ip_parameter sys_ps8 CONFIG.PSU__MAXIGP2__DATA_WIDTH 32
|
|
ad_ip_parameter sys_ps8 CONFIG.PSU__FPGA_PL0_ENABLE 1
|
|
ad_ip_parameter sys_ps8 CONFIG.PSU__CRL_APB__PL0_REF_CTRL__SRCSEL {IOPLL}
|
|
ad_ip_parameter sys_ps8 CONFIG.PSU__CRL_APB__PL0_REF_CTRL__FREQMHZ 100
|
|
ad_ip_parameter sys_ps8 CONFIG.PSU__FPGA_PL1_ENABLE 1
|
|
ad_ip_parameter sys_ps8 CONFIG.PSU__CRL_APB__PL1_REF_CTRL__SRCSEL {IOPLL}
|
|
ad_ip_parameter sys_ps8 CONFIG.PSU__CRL_APB__PL1_REF_CTRL__FREQMHZ 200
|
|
ad_ip_parameter sys_ps8 CONFIG.PSU__FPGA_PL2_ENABLE 1
|
|
ad_ip_parameter sys_ps8 CONFIG.PSU__CRL_APB__PL2_REF_CTRL__SRCSEL {IOPLL}
|
|
ad_ip_parameter sys_ps8 CONFIG.PSU__CRL_APB__PL2_REF_CTRL__FREQMHZ 12.288
|
|
ad_ip_parameter sys_ps8 CONFIG.PSU__USE__IRQ0 1
|
|
ad_ip_parameter sys_ps8 CONFIG.PSU__USE__IRQ1 1
|
|
ad_ip_parameter sys_ps8 CONFIG.PSU__GPIO_EMIO__PERIPHERAL__ENABLE 1
|
|
ad_ip_parameter sys_ps8 CONFIG.PSU__SPI0__PERIPHERAL__ENABLE 1
|
|
ad_ip_parameter sys_ps8 CONFIG.PSU__SPI0__PERIPHERAL__IO {EMIO}
|
|
ad_ip_parameter sys_ps8 CONFIG.PSU__SPI0__GRP_SS1__ENABLE 1
|
|
ad_ip_parameter sys_ps8 CONFIG.PSU__SPI0__GRP_SS2__ENABLE 1
|
|
ad_ip_parameter sys_ps8 CONFIG.PSU__CRL_APB__SPI0_REF_CTRL__FREQMHZ 100
|
|
ad_ip_parameter sys_ps8 CONFIG.PSU__I2C0__PERIPHERAL__ENABLE {1}
|
|
ad_ip_parameter sys_ps8 CONFIG.PSU__I2C0__PERIPHERAL__IO {MIO 14 .. 15}
|
|
ad_ip_parameter sys_ps8 CONFIG.PSU__UART1__PERIPHERAL__ENABLE {1}
|
|
ad_ip_parameter sys_ps8 CONFIG.PSU__UART1__PERIPHERAL__IO {MIO 16 .. 17}
|
|
ad_ip_parameter sys_ps8 CONFIG.PSU__QSPI__PERIPHERAL__ENABLE {1}
|
|
ad_ip_parameter sys_ps8 CONFIG.PSU__SD1__PERIPHERAL__ENABLE {1}
|
|
ad_ip_parameter sys_ps8 CONFIG.PSU__SWDT0__PERIPHERAL__ENABLE {1}
|
|
ad_ip_parameter sys_ps8 CONFIG.PSU__SWDT1__PERIPHERAL__ENABLE {1}
|
|
ad_ip_parameter sys_ps8 CONFIG.PSU__TTC0__PERIPHERAL__ENABLE {1}
|
|
ad_ip_parameter sys_ps8 CONFIG.PSU__TTC1__PERIPHERAL__ENABLE {1}
|
|
ad_ip_parameter sys_ps8 CONFIG.PSU__TTC2__PERIPHERAL__ENABLE {1}
|
|
ad_ip_parameter sys_ps8 CONFIG.PSU__TTC3__PERIPHERAL__ENABLE {1}
|
|
ad_ip_parameter sys_ps8 CONFIG.PSU__USB0__PERIPHERAL__ENABLE {1}
|
|
ad_ip_parameter sys_ps8 CONFIG.PSU__USB3_0__PERIPHERAL__ENABLE {1}
|
|
ad_ip_parameter sys_ps8 CONFIG.PSU__USB3_0__PERIPHERAL__IO {GT Lane1}
|
|
ad_ip_parameter sys_ps8 CONFIG.PSU__ENET0__PERIPHERAL__ENABLE {1}
|
|
ad_ip_parameter sys_ps8 CONFIG.PSU__ENET0__PERIPHERAL__IO {GT Lane0}
|
|
ad_ip_parameter sys_ps8 CONFIG.PSU__ENET3__PERIPHERAL__ENABLE {1}
|
|
ad_ip_parameter sys_ps8 CONFIG.PSU__GPIO0_MIO__PERIPHERAL__ENABLE {0}
|
|
ad_ip_parameter sys_ps8 CONFIG.PSU__GPIO1_MIO__PERIPHERAL__ENABLE {0}
|
|
ad_ip_parameter sys_ps8 CONFIG.PSU__PMU__PERIPHERAL__ENABLE {0}
|
|
ad_ip_parameter sys_ps8 CONFIG.PSU__QSPI__PERIPHERAL__MODE {Dual Parallel}
|
|
ad_ip_parameter sys_ps8 CONFIG.PSU__QSPI__PERIPHERAL__DATA_MODE {x4}
|
|
ad_ip_parameter sys_ps8 CONFIG.PSU__DISPLAYPORT__PERIPHERAL__ENABLE {1}
|
|
ad_ip_parameter sys_ps8 CONFIG.PSU__DPAUX__PERIPHERAL__IO {MIO 27 .. 30}
|
|
ad_ip_parameter sys_ps8 CONFIG.PSU__ENET3__GRP_MDIO__ENABLE {1}
|
|
ad_ip_parameter sys_ps8 CONFIG.SUBPRESET1 {DDR4_MICRON_MT40A256M16GE_083E}
|
|
ad_ip_parameter sys_ps8 CONFIG.PSU__DDRC__BUS_WIDTH {64 Bit}
|
|
ad_ip_parameter sys_ps8 CONFIG.PSU__DDRC__DRAM_WIDTH {16 Bits}
|
|
ad_ip_parameter sys_ps8 CONFIG.PSU__DDRC__BG_ADDR_COUNT {1}
|
|
ad_ip_parameter sys_ps8 CONFIG.PSU__DDRC__PARITY_ENABLE {1}
|
|
ad_ip_parameter sys_ps8 CONFIG.PSU__DDRC__ECC {Enabled}
|
|
set_property -dict [list CONFIG.PSU__DDRC__ROW_ADDR_COUNT {16} CONFIG.PSU__DDRC__DEVICE_CAPACITY {8192 MBits} ] [get_bd_cells sys_ps8]
|
|
set_property -dict [list CONFIG.PSU__I2C1__PERIPHERAL__ENABLE {1} CONFIG.PSU__I2C1__PERIPHERAL__IO {MIO 32 .. 33}] [get_bd_cells sys_ps8]
|
|
set_property -dict [list CONFIG.PSU__CRF_APB__DP_VIDEO_REF_CTRL__SRCSEL {VPLL} CONFIG.PSU__CRF_APB__DP_AUDIO_REF_CTRL__SRCSEL {DPLL} CONFIG.PSU__CRF_APB__DP_STC_REF_CTRL__SRCSEL {DPLL}] [get_bd_cells sys_ps8]
|
|
set_property -dict [list CONFIG.PSU__CRF_APB__TOPSW_MAIN_CTRL__SRCSEL {APLL}] [get_bd_cells sys_ps8]
|
|
ad_ip_parameter sys_ps8 CONFIG.PSU__GPIO0_MIO__PERIPHERAL__ENABLE {1}
|
|
ad_ip_parameter sys_ps8 CONFIG.PSU__GPIO1_MIO__PERIPHERAL__ENABLE {1}
|
|
ad_ip_parameter sys_ps8 CONFIG.PSU__GPIO2_MIO__PERIPHERAL__ENABLE {1}
|
|
|
|
ad_ip_instance proc_sys_reset sys_rstgen
|
|
ad_ip_parameter sys_rstgen CONFIG.C_EXT_RST_WIDTH 1
|
|
|
|
# system reset/clock definitions
|
|
|
|
ad_connect sys_cpu_clk sys_ps8/pl_clk0
|
|
ad_connect sys_200m_clk sys_ps8/pl_clk1
|
|
ad_connect i2s_m_clk sys_ps8/pl_clk2
|
|
ad_connect sys_cpu_reset sys_rstgen/peripheral_reset
|
|
ad_connect sys_cpu_resetn sys_rstgen/peripheral_aresetn
|
|
ad_connect sys_cpu_clk sys_rstgen/slowest_sync_clk
|
|
ad_connect sys_ps8/pl_resetn0 sys_rstgen/ext_reset_in
|
|
|
|
# gpio
|
|
|
|
ad_connect gpio_i sys_ps8/emio_gpio_i
|
|
ad_connect gpio_o sys_ps8/emio_gpio_o
|
|
ad_connect gpio_t sys_ps8/emio_gpio_t
|
|
|
|
# add 1 bit GND signal
|
|
ad_ip_instance xlconstant GND_1_bit
|
|
ad_ip_parameter GND_1_bit CONFIG.CONST_VAL {0}
|
|
|
|
# spi
|
|
|
|
ad_ip_instance xlconcat spi0_csn_concat
|
|
ad_ip_parameter spi0_csn_concat CONFIG.NUM_PORTS 3
|
|
ad_connect sys_ps8/emio_spi0_ss_o_n spi0_csn_concat/In0
|
|
ad_connect sys_ps8/emio_spi0_ss1_o_n spi0_csn_concat/In1
|
|
ad_connect sys_ps8/emio_spi0_ss2_o_n spi0_csn_concat/In2
|
|
ad_connect spi0_csn_concat/dout spi0_csn
|
|
ad_connect sys_ps8/emio_spi0_sclk_o spi0_sclk
|
|
ad_connect sys_ps8/emio_spi0_m_o spi0_mosi
|
|
ad_connect sys_ps8/emio_spi0_m_i spi0_miso
|
|
ad_connect sys_ps8/emio_spi0_ss_i_n VCC
|
|
ad_connect sys_ps8/emio_spi0_sclk_i GND_1_bit/dout
|
|
ad_connect sys_ps8/emio_spi0_s_i GND_1_bit/dout
|
|
|
|
# interrupts
|
|
|
|
ad_ip_instance xlconcat sys_concat_intc_0
|
|
ad_ip_parameter sys_concat_intc_0 CONFIG.NUM_PORTS 8
|
|
|
|
ad_ip_instance xlconcat sys_concat_intc_1
|
|
ad_ip_parameter sys_concat_intc_1 CONFIG.NUM_PORTS 8
|
|
|
|
ad_connect sys_concat_intc_0/dout sys_ps8/pl_ps_irq0
|
|
ad_connect sys_concat_intc_1/dout sys_ps8/pl_ps_irq1
|
|
|
|
ad_connect sys_concat_intc_1/In7 GND
|
|
ad_connect sys_concat_intc_1/In6 GND
|
|
ad_connect sys_concat_intc_1/In5 GND
|
|
ad_connect sys_concat_intc_1/In4 GND
|
|
ad_connect sys_concat_intc_1/In3 GND
|
|
ad_connect sys_concat_intc_1/In2 GND
|
|
ad_connect sys_concat_intc_1/In1 GND
|
|
ad_connect sys_concat_intc_1/In0 GND
|
|
ad_connect sys_concat_intc_0/In7 GND
|
|
ad_connect sys_concat_intc_0/In6 GND
|
|
ad_connect sys_concat_intc_0/In5 GND
|
|
ad_connect sys_concat_intc_0/In4 GND
|
|
ad_connect sys_concat_intc_0/In3 GND
|
|
ad_connect sys_concat_intc_0/In2 GND
|
|
ad_connect sys_concat_intc_0/In1 GND
|
|
ad_connect sys_concat_intc_0/In0 GND
|
|
|
|
connect_bd_net [get_bd_pins sys_ps8/maxihpm0_lpd_aclk] [get_bd_pins sys_ps8/pl_clk0]
|
|
|
|
source adrv9009_zu11eg_som_bd.tcl
|
|
source carrier_bd.tcl
|