Lab structure --- In this lab we will run Caravel SoC's simulation on FPGA(PYNQ) as following structure: ![image](https://hackmd.io/_uploads/Sy5kdJjqgx.png) In before lab , we run caravel's simulation on testbench,now we use FPGA to run simulation. And there are many modules needed for this lab like read_romcode(use to load romcode from host DDR memory to BRAM) 、spiflash(use to interconnect bram & caravel's spiflash pins)、outpin(use to control reset)、caravel-ps(use to read write caravel's mprj_io pins). Also,we need to prepare host code run on PYNQ's core to excute simulation. Readromcode (IP generated by vitis_hls) --- Source code ![image](https://hackmd.io/_uploads/H1m2Untqgl.png) This IP is used to read/write ROM code(for Caravel's core) to BRAM. ![read_romdcode](https://hackmd.io/_uploads/Sy9a8at9lx.png) Synthesis report : ![image](https://hackmd.io/_uploads/SJRkdaF5gg.png) ![addr](https://hackmd.io/_uploads/Hkw6Dpt5xx.png) ![image](https://hackmd.io/_uploads/SJz7O6Y9gx.png) ======================================================== 💡I think that this design doesn't support read request to BRAM for rom_code(in BRAM) checking , maybe we can modify the source C++ code and pragma as following to expand this function : ``` void read_romcode( // PS side interace int romcode[CODE_SIZE/sizeof(int)], int internal_bram[CODE_SIZE/sizeof(int)], int length , int read_bram ) { #pragma HLS INTERFACE s_axilite port=return #pragma HLS INTERFACE m_axi port=romcode offset=slave max_read_burst_length=64 bundle=BUS0 #pragma HLS INTERFACE bram port=internal_bram #pragma HLS INTERFACE s_axilite port=length #pragma HLS INTERFACE s_axilite port=read_bram // Check length parameter can't over than CODE_SIZE/4 if(length > (CODE_SIZE/sizeof(int))) length = CODE_SIZE/sizeof(int); int i; if(read_bram){ for(i = 0; i < length; i++) { #pragma HLS PIPELINE romcode[i] = internal_bram[i] ; } }else{ // load ROMCODE for(i = 0; i < length; i++) { #pragma HLS PIPELINE internal_bram[i] = romcode[i]; } } return; } ``` synthesis report ![image](https://hackmd.io/_uploads/Skky6TKqge.png) ![hwio](https://hackmd.io/_uploads/BkCLTTY9xe.png) ![未命名](https://hackmd.io/_uploads/r1KTh6Ycel.png) Now we can send our request of Read/write BRAM's rom_code by writing axi-lite's address 0x24.(But I think maybe this function isn't essential). spiflash.v (RTL module between BRAM and caravel SOC's spi pins) --- As lab4 we know that Caravel SoC store the RISCV's firmware code in externel SPI-flash , and its protocal is different from BRAM(we use to store firmware code of caravel).So we use this module to connect BRAM's interface and spi's interface . ![image](https://hackmd.io/_uploads/HJwAWRKqll.png) ![image](https://hackmd.io/_uploads/Skjyz0K9gg.png) (Picture from TA's PPT) Caravel PS (IP generated by vitis_hls) --- Source code : ![image](https://hackmd.io/_uploads/rkkNhjq5xg.png) This IP is used to transfer caravel's mprj signal into axi-lite protocal interface ![caravel-ps](https://hackmd.io/_uploads/rkp38h59ee.png) Synthesis report ![image](https://hackmd.io/_uploads/SJdTth55le.png) ![image](https://hackmd.io/_uploads/HkLLjhc5ll.png) ![image](https://hackmd.io/_uploads/HyyDT255xx.png) Verilog imformation : ![image](https://hackmd.io/_uploads/H19Jhhqcxe.png) output_pin --- Source : ![image](https://hackmd.io/_uploads/rkVXJTqceg.png) ![未命名](https://hackmd.io/_uploads/H1pAQpc5gg.png) Synthesis report : ![image](https://hackmd.io/_uploads/rJzcwp5cge.png) ![image](https://hackmd.io/_uploads/S1ZhDa5qex.png) ![image](https://hackmd.io/_uploads/B1S1OT99eg.png) Host code (excuted on PYNQ's core) --- Following are the steps of host code in Caravel simulation on FPGA (PYNQ) : (1) Load bitstream into PYNQ ![image](https://hackmd.io/_uploads/rkDFZJsceg.png) (2) Declare the IP (kernel functions) in bitstream as following name ![image](https://hackmd.io/_uploads/Hk39Zkj9le.png) (3) Allocate buffer (npROM) to store ROM code(for Caravel's RISCV),and load ROM code from .hex files (fiROM) to buffer ![image](https://hackmd.io/_uploads/B13_zyoqlg.png) (4) Move ROM code from host buffer to IP read_rom_code and then store into BRAM ![未命名](https://hackmd.io/_uploads/H1crBJoclx.png) (5) Read the data of Caravel-PS to check mprj_io ![image](https://hackmd.io/_uploads/HyN48ki5xx.png) (6) write request to IP outpin to release Caravel SoC's reset state ![image](https://hackmd.io/_uploads/H1yULyoqlg.png) (now Caravel SoC will start working -> read BRAM's firmware code) (7) After Caravel SoC start working , read the mprj_io's signal through caravel-PS ![image](https://hackmd.io/_uploads/BkjpLJocel.png) Block design (on vivado) --- (1) create project => create block design (2) add IP generated by hls tool ![未命名](https://hackmd.io/_uploads/Sy1IMZhcxg.png) ![image](https://hackmd.io/_uploads/SJAWMW25gl.png) (3) add RTL header files、RTL files(caravel SOC) ![未命名](https://hackmd.io/_uploads/ryOuU-35el.png) ![未命名](https://hackmd.io/_uploads/Hk2TI-2qll.png) * we need to global include this header files for caravel's inside module first ![未命名](https://hackmd.io/_uploads/rkQc3Xn9xl.png) ![未命名](https://hackmd.io/_uploads/Bye_3m25le.png) * Then we can import carave; soc's RTL ![ccar](https://hackmd.io/_uploads/BkXvaXh5xl.png) (4) Now we successfully import caravel soc into this projject ![未命名](https://hackmd.io/_uploads/rJBskN2qeg.png) (4) Then we can add IP and RTL module in our block design ![未命名](https://hackmd.io/_uploads/S1-dlVhcgg.png) (5) HLS IP 、 RTL modules in block design ![image](https://hackmd.io/_uploads/Byl7V4h5ex.png) (6) add axi interconnext ![未命名](https://hackmd.io/_uploads/HJZ04435eg.png) and modfiy the number of master to 1 (in this lab, we only have one axi master " read_romcode" ) ![image](https://hackmd.io/_uploads/rkdfBE3qgg.png) ![未命名](https://hackmd.io/_uploads/SJp3rV3qgl.png) (7) add block ram (xilinx's IP) ![未命名](https://hackmd.io/_uploads/B1DRLE2cxx.png) modify to dual port here ![未命名](https://hackmd.io/_uploads/Hk6jDEh9gl.png) ![未命名](https://hackmd.io/_uploads/H12XO4h5xe.png) (8)add PYNQ's processor (這塊設定太複雜了,建議直接用最後附的tcl!! => 我試過GUI手動,必需跟script內一樣才能讓 caravel soc 跑起來) ![未命名](https://hackmd.io/_uploads/Hk9T7S29ee.png) => actually after I import all the ip and RTL modules into block design,we can use "run block automation " to setup processor. (9) connect all ![image](https://hackmd.io/_uploads/ByiKbI3clg.png) (10)edit the MMIO address map !(this will correspond to hostside's code of address used to control our device) ![未命名](https://hackmd.io/_uploads/Bk1_X825eg.png) ![image](https://hackmd.io/_uploads/ryMz4In9gl.png) (11) We can check the address map ![未命名](https://hackmd.io/_uploads/B17tHLhclx.png) (12) create HDL wrapper and generate bitstream then we can run FPGA test on jupyter notebook ![image](https://hackmd.io/_uploads/BkjAlda9ex.png) Test on fpga(PYNQ) --- ![image](https://hackmd.io/_uploads/BJpMbbEjge.png) ![image](https://hackmd.io/_uploads/r1-HWbEsxx.png) ![image](https://hackmd.io/_uploads/SJ-U-b4oll.png) ![image](https://hackmd.io/_uploads/HJ3-W-4oex.png) ![image](https://hackmd.io/_uploads/BJoJWZ4ilg.png) ![image](https://hackmd.io/_uploads/BJ9xZb4sxg.png) ![image](https://hackmd.io/_uploads/rJKaeZ4igg.png) TCL to create the ZYNQ processor in block design --- ``` # Create instance: processing_system7_0, and set properties set processing_system7_0 [ create_bd_cell -type ip -vlnv xilinx.com:ip:processing_system7:5.5 processing_system7_0 ] set_property -dict [ list \ CONFIG.PCW_ACT_APU_PERIPHERAL_FREQMHZ {650.000000} \ CONFIG.PCW_ACT_CAN0_PERIPHERAL_FREQMHZ {23.8095} \ CONFIG.PCW_ACT_CAN1_PERIPHERAL_FREQMHZ {23.8095} \ CONFIG.PCW_ACT_CAN_PERIPHERAL_FREQMHZ {10.000000} \ CONFIG.PCW_ACT_DCI_PERIPHERAL_FREQMHZ {10.096154} \ CONFIG.PCW_ACT_ENET0_PERIPHERAL_FREQMHZ {125.000000} \ CONFIG.PCW_ACT_ENET1_PERIPHERAL_FREQMHZ {10.000000} \ CONFIG.PCW_ACT_FPGA0_PERIPHERAL_FREQMHZ {50.000000} \ CONFIG.PCW_ACT_FPGA1_PERIPHERAL_FREQMHZ {10.000000} \ CONFIG.PCW_ACT_FPGA2_PERIPHERAL_FREQMHZ {10.000000} \ CONFIG.PCW_ACT_FPGA3_PERIPHERAL_FREQMHZ {10.000000} \ CONFIG.PCW_ACT_I2C_PERIPHERAL_FREQMHZ {50} \ CONFIG.PCW_ACT_PCAP_PERIPHERAL_FREQMHZ {200.000000} \ CONFIG.PCW_ACT_QSPI_PERIPHERAL_FREQMHZ {200.000000} \ CONFIG.PCW_ACT_SDIO_PERIPHERAL_FREQMHZ {50.000000} \ CONFIG.PCW_ACT_SMC_PERIPHERAL_FREQMHZ {10.000000} \ CONFIG.PCW_ACT_SPI_PERIPHERAL_FREQMHZ {10.000000} \ CONFIG.PCW_ACT_TPIU_PERIPHERAL_FREQMHZ {200.000000} \ CONFIG.PCW_ACT_TTC0_CLK0_PERIPHERAL_FREQMHZ {108.333336} \ CONFIG.PCW_ACT_TTC0_CLK1_PERIPHERAL_FREQMHZ {108.333336} \ CONFIG.PCW_ACT_TTC0_CLK2_PERIPHERAL_FREQMHZ {108.333336} \ CONFIG.PCW_ACT_TTC1_CLK0_PERIPHERAL_FREQMHZ {108.333336} \ CONFIG.PCW_ACT_TTC1_CLK1_PERIPHERAL_FREQMHZ {108.333336} \ CONFIG.PCW_ACT_TTC1_CLK2_PERIPHERAL_FREQMHZ {108.333336} \ CONFIG.PCW_ACT_TTC_PERIPHERAL_FREQMHZ {50} \ CONFIG.PCW_ACT_UART_PERIPHERAL_FREQMHZ {100.000000} \ CONFIG.PCW_ACT_USB0_PERIPHERAL_FREQMHZ {60} \ CONFIG.PCW_ACT_USB1_PERIPHERAL_FREQMHZ {60} \ CONFIG.PCW_ACT_WDT_PERIPHERAL_FREQMHZ {108.333336} \ CONFIG.PCW_APU_CLK_RATIO_ENABLE {6:2:1} \ CONFIG.PCW_APU_PERIPHERAL_FREQMHZ {650} \ CONFIG.PCW_ARMPLL_CTRL_FBDIV {26} \ CONFIG.PCW_CAN0_BASEADDR {0xE0008000} \ CONFIG.PCW_CAN0_HIGHADDR {0xE0008FFF} \ CONFIG.PCW_CAN0_PERIPHERAL_CLKSRC {External} \ CONFIG.PCW_CAN0_PERIPHERAL_FREQMHZ {-1} \ CONFIG.PCW_CAN1_BASEADDR {0xE0009000} \ CONFIG.PCW_CAN1_HIGHADDR {0xE0009FFF} \ CONFIG.PCW_CAN1_PERIPHERAL_CLKSRC {External} \ CONFIG.PCW_CAN1_PERIPHERAL_FREQMHZ {-1} \ CONFIG.PCW_CAN_PERIPHERAL_CLKSRC {IO PLL} \ CONFIG.PCW_CAN_PERIPHERAL_DIVISOR0 {1} \ CONFIG.PCW_CAN_PERIPHERAL_DIVISOR1 {1} \ CONFIG.PCW_CAN_PERIPHERAL_FREQMHZ {100} \ CONFIG.PCW_CAN_PERIPHERAL_VALID {0} \ CONFIG.PCW_CLK0_FREQ {50000000} \ CONFIG.PCW_CLK1_FREQ {10000000} \ CONFIG.PCW_CLK2_FREQ {10000000} \ CONFIG.PCW_CLK3_FREQ {10000000} \ CONFIG.PCW_CORE0_FIQ_INTR {0} \ CONFIG.PCW_CORE0_IRQ_INTR {0} \ CONFIG.PCW_CORE1_FIQ_INTR {0} \ CONFIG.PCW_CORE1_IRQ_INTR {0} \ CONFIG.PCW_CPU_CPU_6X4X_MAX_RANGE {667} \ CONFIG.PCW_CPU_CPU_PLL_FREQMHZ {1300.000} \ CONFIG.PCW_CPU_PERIPHERAL_CLKSRC {ARM PLL} \ CONFIG.PCW_CPU_PERIPHERAL_DIVISOR0 {2} \ CONFIG.PCW_CRYSTAL_PERIPHERAL_FREQMHZ {50} \ CONFIG.PCW_DCI_PERIPHERAL_CLKSRC {DDR PLL} \ CONFIG.PCW_DCI_PERIPHERAL_DIVISOR0 {52} \ CONFIG.PCW_DCI_PERIPHERAL_DIVISOR1 {2} \ CONFIG.PCW_DCI_PERIPHERAL_FREQMHZ {10.159} \ CONFIG.PCW_DDRPLL_CTRL_FBDIV {21} \ CONFIG.PCW_DDR_DDR_PLL_FREQMHZ {1050.000} \ CONFIG.PCW_DDR_HPRLPR_QUEUE_PARTITION {HPR(0)/LPR(32)} \ CONFIG.PCW_DDR_HPR_TO_CRITICAL_PRIORITY_LEVEL {15} \ CONFIG.PCW_DDR_LPR_TO_CRITICAL_PRIORITY_LEVEL {2} \ CONFIG.PCW_DDR_PERIPHERAL_CLKSRC {DDR PLL} \ CONFIG.PCW_DDR_PERIPHERAL_DIVISOR0 {2} \ CONFIG.PCW_DDR_PORT0_HPR_ENABLE {0} \ CONFIG.PCW_DDR_PORT1_HPR_ENABLE {0} \ CONFIG.PCW_DDR_PORT2_HPR_ENABLE {0} \ CONFIG.PCW_DDR_PORT3_HPR_ENABLE {0} \ CONFIG.PCW_DDR_RAM_BASEADDR {0x00100000} \ CONFIG.PCW_DDR_RAM_HIGHADDR {0x1FFFFFFF} \ CONFIG.PCW_DDR_WRITE_TO_CRITICAL_PRIORITY_LEVEL {2} \ CONFIG.PCW_DM_WIDTH {4} \ CONFIG.PCW_DQS_WIDTH {4} \ CONFIG.PCW_DQ_WIDTH {32} \ CONFIG.PCW_ENET0_BASEADDR {0xE000B000} \ CONFIG.PCW_ENET0_ENET0_IO {MIO 16 .. 27} \ CONFIG.PCW_ENET0_GRP_MDIO_ENABLE {1} \ CONFIG.PCW_ENET0_GRP_MDIO_IO {MIO 52 .. 53} \ CONFIG.PCW_ENET0_HIGHADDR {0xE000BFFF} \ CONFIG.PCW_ENET0_PERIPHERAL_CLKSRC {IO PLL} \ CONFIG.PCW_ENET0_PERIPHERAL_DIVISOR0 {8} \ CONFIG.PCW_ENET0_PERIPHERAL_DIVISOR1 {1} \ CONFIG.PCW_ENET0_PERIPHERAL_ENABLE {1} \ CONFIG.PCW_ENET0_PERIPHERAL_FREQMHZ {1000 Mbps} \ CONFIG.PCW_ENET0_RESET_ENABLE {1} \ CONFIG.PCW_ENET0_RESET_IO {MIO 9} \ CONFIG.PCW_ENET1_BASEADDR {0xE000C000} \ CONFIG.PCW_ENET1_GRP_MDIO_ENABLE {0} \ CONFIG.PCW_ENET1_HIGHADDR {0xE000CFFF} \ CONFIG.PCW_ENET1_PERIPHERAL_CLKSRC {IO PLL} \ CONFIG.PCW_ENET1_PERIPHERAL_DIVISOR0 {1} \ CONFIG.PCW_ENET1_PERIPHERAL_DIVISOR1 {1} \ CONFIG.PCW_ENET1_PERIPHERAL_ENABLE {0} \ CONFIG.PCW_ENET1_PERIPHERAL_FREQMHZ {1000 Mbps} \ CONFIG.PCW_ENET1_RESET_ENABLE {0} \ CONFIG.PCW_ENET_RESET_ENABLE {1} \ CONFIG.PCW_ENET_RESET_POLARITY {Active Low} \ CONFIG.PCW_ENET_RESET_SELECT {Share reset pin} \ CONFIG.PCW_EN_4K_TIMER {0} \ CONFIG.PCW_EN_CAN0 {0} \ CONFIG.PCW_EN_CAN1 {0} \ CONFIG.PCW_EN_CLK0_PORT {1} \ CONFIG.PCW_EN_CLK1_PORT {0} \ CONFIG.PCW_EN_CLK2_PORT {0} \ CONFIG.PCW_EN_CLK3_PORT {0} \ CONFIG.PCW_EN_CLKTRIG0_PORT {0} \ CONFIG.PCW_EN_CLKTRIG1_PORT {0} \ CONFIG.PCW_EN_CLKTRIG2_PORT {0} \ CONFIG.PCW_EN_CLKTRIG3_PORT {0} \ CONFIG.PCW_EN_DDR {1} \ CONFIG.PCW_EN_EMIO_CAN0 {0} \ CONFIG.PCW_EN_EMIO_CAN1 {0} \ CONFIG.PCW_EN_EMIO_CD_SDIO0 {0} \ CONFIG.PCW_EN_EMIO_CD_SDIO1 {0} \ CONFIG.PCW_EN_EMIO_ENET0 {0} \ CONFIG.PCW_EN_EMIO_ENET1 {0} \ CONFIG.PCW_EN_EMIO_GPIO {0} \ CONFIG.PCW_EN_EMIO_I2C0 {0} \ CONFIG.PCW_EN_EMIO_I2C1 {0} \ CONFIG.PCW_EN_EMIO_MODEM_UART0 {0} \ CONFIG.PCW_EN_EMIO_MODEM_UART1 {0} \ CONFIG.PCW_EN_EMIO_PJTAG {0} \ CONFIG.PCW_EN_EMIO_SDIO0 {0} \ CONFIG.PCW_EN_EMIO_SDIO1 {0} \ CONFIG.PCW_EN_EMIO_SPI0 {0} \ CONFIG.PCW_EN_EMIO_SPI1 {0} \ CONFIG.PCW_EN_EMIO_SRAM_INT {0} \ CONFIG.PCW_EN_EMIO_TRACE {0} \ CONFIG.PCW_EN_EMIO_TTC0 {0} \ CONFIG.PCW_EN_EMIO_TTC1 {0} \ CONFIG.PCW_EN_EMIO_UART0 {0} \ CONFIG.PCW_EN_EMIO_UART1 {0} \ CONFIG.PCW_EN_EMIO_WDT {0} \ CONFIG.PCW_EN_EMIO_WP_SDIO0 {0} \ CONFIG.PCW_EN_EMIO_WP_SDIO1 {0} \ CONFIG.PCW_EN_ENET0 {1} \ CONFIG.PCW_EN_ENET1 {0} \ CONFIG.PCW_EN_GPIO {1} \ CONFIG.PCW_EN_I2C0 {0} \ CONFIG.PCW_EN_I2C1 {0} \ CONFIG.PCW_EN_MODEM_UART0 {0} \ CONFIG.PCW_EN_MODEM_UART1 {0} \ CONFIG.PCW_EN_PJTAG {0} \ CONFIG.PCW_EN_PTP_ENET0 {0} \ CONFIG.PCW_EN_PTP_ENET1 {0} \ CONFIG.PCW_EN_QSPI {1} \ CONFIG.PCW_EN_RST0_PORT {1} \ CONFIG.PCW_EN_RST1_PORT {0} \ CONFIG.PCW_EN_RST2_PORT {0} \ CONFIG.PCW_EN_RST3_PORT {0} \ CONFIG.PCW_EN_SDIO0 {1} \ CONFIG.PCW_EN_SDIO1 {0} \ CONFIG.PCW_EN_SMC {0} \ CONFIG.PCW_EN_SPI0 {0} \ CONFIG.PCW_EN_SPI1 {0} \ CONFIG.PCW_EN_TRACE {0} \ CONFIG.PCW_EN_TTC0 {0} \ CONFIG.PCW_EN_TTC1 {0} \ CONFIG.PCW_EN_UART0 {1} \ CONFIG.PCW_EN_UART1 {0} \ CONFIG.PCW_EN_USB0 {1} \ CONFIG.PCW_EN_USB1 {0} \ CONFIG.PCW_EN_WDT {0} \ CONFIG.PCW_FCLK0_PERIPHERAL_CLKSRC {IO PLL} \ CONFIG.PCW_FCLK0_PERIPHERAL_DIVISOR0 {5} \ CONFIG.PCW_FCLK0_PERIPHERAL_DIVISOR1 {4} \ CONFIG.PCW_FCLK1_PERIPHERAL_CLKSRC {IO PLL} \ CONFIG.PCW_FCLK1_PERIPHERAL_DIVISOR0 {1} \ CONFIG.PCW_FCLK1_PERIPHERAL_DIVISOR1 {1} \ CONFIG.PCW_FCLK2_PERIPHERAL_CLKSRC {IO PLL} \ CONFIG.PCW_FCLK2_PERIPHERAL_DIVISOR0 {1} \ CONFIG.PCW_FCLK2_PERIPHERAL_DIVISOR1 {1} \ CONFIG.PCW_FCLK3_PERIPHERAL_CLKSRC {IO PLL} \ CONFIG.PCW_FCLK3_PERIPHERAL_DIVISOR0 {1} \ CONFIG.PCW_FCLK3_PERIPHERAL_DIVISOR1 {1} \ CONFIG.PCW_FCLK_CLK0_BUF {TRUE} \ CONFIG.PCW_FCLK_CLK1_BUF {FALSE} \ CONFIG.PCW_FCLK_CLK2_BUF {FALSE} \ CONFIG.PCW_FCLK_CLK3_BUF {FALSE} \ CONFIG.PCW_FPGA0_PERIPHERAL_FREQMHZ {50} \ CONFIG.PCW_FPGA1_PERIPHERAL_FREQMHZ {50} \ CONFIG.PCW_FPGA2_PERIPHERAL_FREQMHZ {50} \ CONFIG.PCW_FPGA3_PERIPHERAL_FREQMHZ {50} \ CONFIG.PCW_FPGA_FCLK0_ENABLE {1} \ CONFIG.PCW_FPGA_FCLK1_ENABLE {0} \ CONFIG.PCW_FPGA_FCLK2_ENABLE {0} \ CONFIG.PCW_FPGA_FCLK3_ENABLE {0} \ CONFIG.PCW_GPIO_BASEADDR {0xE000A000} \ CONFIG.PCW_GPIO_EMIO_GPIO_ENABLE {0} \ CONFIG.PCW_GPIO_EMIO_GPIO_WIDTH {64} \ CONFIG.PCW_GPIO_HIGHADDR {0xE000AFFF} \ CONFIG.PCW_GPIO_MIO_GPIO_ENABLE {1} \ CONFIG.PCW_GPIO_MIO_GPIO_IO {MIO} \ CONFIG.PCW_GPIO_PERIPHERAL_ENABLE {0} \ CONFIG.PCW_I2C0_BASEADDR {0xE0004000} \ CONFIG.PCW_I2C0_HIGHADDR {0xE0004FFF} \ CONFIG.PCW_I2C0_RESET_ENABLE {0} \ CONFIG.PCW_I2C1_BASEADDR {0xE0005000} \ CONFIG.PCW_I2C1_HIGHADDR {0xE0005FFF} \ CONFIG.PCW_I2C1_RESET_ENABLE {0} \ CONFIG.PCW_I2C_PERIPHERAL_FREQMHZ {25} \ CONFIG.PCW_I2C_RESET_ENABLE {0} \ CONFIG.PCW_I2C_RESET_POLARITY {Active Low} \ CONFIG.PCW_IMPORT_BOARD_PRESET {None} \ CONFIG.PCW_INCLUDE_ACP_TRANS_CHECK {0} \ CONFIG.PCW_INCLUDE_TRACE_BUFFER {0} \ CONFIG.PCW_IOPLL_CTRL_FBDIV {20} \ CONFIG.PCW_IO_IO_PLL_FREQMHZ {1000.000} \ CONFIG.PCW_IRQ_F2P_INTR {0} \ CONFIG.PCW_IRQ_F2P_MODE {DIRECT} \ CONFIG.PCW_MIO_0_DIRECTION {inout} \ CONFIG.PCW_MIO_0_IOTYPE {LVCMOS 3.3V} \ CONFIG.PCW_MIO_0_PULLUP {enabled} \ CONFIG.PCW_MIO_0_SLEW {slow} \ CONFIG.PCW_MIO_10_DIRECTION {inout} \ CONFIG.PCW_MIO_10_IOTYPE {LVCMOS 3.3V} \ CONFIG.PCW_MIO_10_PULLUP {enabled} \ CONFIG.PCW_MIO_10_SLEW {slow} \ CONFIG.PCW_MIO_11_DIRECTION {inout} \ CONFIG.PCW_MIO_11_IOTYPE {LVCMOS 3.3V} \ CONFIG.PCW_MIO_11_PULLUP {enabled} \ CONFIG.PCW_MIO_11_SLEW {slow} \ CONFIG.PCW_MIO_12_DIRECTION {inout} \ CONFIG.PCW_MIO_12_IOTYPE {LVCMOS 3.3V} \ CONFIG.PCW_MIO_12_PULLUP {enabled} \ CONFIG.PCW_MIO_12_SLEW {slow} \ CONFIG.PCW_MIO_13_DIRECTION {inout} \ CONFIG.PCW_MIO_13_IOTYPE {LVCMOS 3.3V} \ CONFIG.PCW_MIO_13_PULLUP {enabled} \ CONFIG.PCW_MIO_13_SLEW {slow} \ CONFIG.PCW_MIO_14_DIRECTION {in} \ CONFIG.PCW_MIO_14_IOTYPE {LVCMOS 3.3V} \ CONFIG.PCW_MIO_14_PULLUP {enabled} \ CONFIG.PCW_MIO_14_SLEW {slow} \ CONFIG.PCW_MIO_15_DIRECTION {out} \ CONFIG.PCW_MIO_15_IOTYPE {LVCMOS 3.3V} \ CONFIG.PCW_MIO_15_PULLUP {enabled} \ CONFIG.PCW_MIO_15_SLEW {slow} \ CONFIG.PCW_MIO_16_DIRECTION {out} \ CONFIG.PCW_MIO_16_IOTYPE {LVCMOS 1.8V} \ CONFIG.PCW_MIO_16_PULLUP {enabled} \ CONFIG.PCW_MIO_16_SLEW {slow} \ CONFIG.PCW_MIO_17_DIRECTION {out} \ CONFIG.PCW_MIO_17_IOTYPE {LVCMOS 1.8V} \ CONFIG.PCW_MIO_17_PULLUP {enabled} \ CONFIG.PCW_MIO_17_SLEW {slow} \ CONFIG.PCW_MIO_18_DIRECTION {out} \ CONFIG.PCW_MIO_18_IOTYPE {LVCMOS 1.8V} \ CONFIG.PCW_MIO_18_PULLUP {enabled} \ CONFIG.PCW_MIO_18_SLEW {slow} \ CONFIG.PCW_MIO_19_DIRECTION {out} \ CONFIG.PCW_MIO_19_IOTYPE {LVCMOS 1.8V} \ CONFIG.PCW_MIO_19_PULLUP {enabled} \ CONFIG.PCW_MIO_19_SLEW {slow} \ CONFIG.PCW_MIO_1_DIRECTION {out} \ CONFIG.PCW_MIO_1_IOTYPE {LVCMOS 3.3V} \ CONFIG.PCW_MIO_1_PULLUP {enabled} \ CONFIG.PCW_MIO_1_SLEW {slow} \ CONFIG.PCW_MIO_20_DIRECTION {out} \ CONFIG.PCW_MIO_20_IOTYPE {LVCMOS 1.8V} \ CONFIG.PCW_MIO_20_PULLUP {enabled} \ CONFIG.PCW_MIO_20_SLEW {slow} \ CONFIG.PCW_MIO_21_DIRECTION {out} \ CONFIG.PCW_MIO_21_IOTYPE {LVCMOS 1.8V} \ CONFIG.PCW_MIO_21_PULLUP {enabled} \ CONFIG.PCW_MIO_21_SLEW {slow} \ CONFIG.PCW_MIO_22_DIRECTION {in} \ CONFIG.PCW_MIO_22_IOTYPE {LVCMOS 1.8V} \ CONFIG.PCW_MIO_22_PULLUP {enabled} \ CONFIG.PCW_MIO_22_SLEW {slow} \ CONFIG.PCW_MIO_23_DIRECTION {in} \ CONFIG.PCW_MIO_23_IOTYPE {LVCMOS 1.8V} \ CONFIG.PCW_MIO_23_PULLUP {enabled} \ CONFIG.PCW_MIO_23_SLEW {slow} \ CONFIG.PCW_MIO_24_DIRECTION {in} \ CONFIG.PCW_MIO_24_IOTYPE {LVCMOS 1.8V} \ CONFIG.PCW_MIO_24_PULLUP {enabled} \ CONFIG.PCW_MIO_24_SLEW {slow} \ CONFIG.PCW_MIO_25_DIRECTION {in} \ CONFIG.PCW_MIO_25_IOTYPE {LVCMOS 1.8V} \ CONFIG.PCW_MIO_25_PULLUP {enabled} \ CONFIG.PCW_MIO_25_SLEW {slow} \ CONFIG.PCW_MIO_26_DIRECTION {in} \ CONFIG.PCW_MIO_26_IOTYPE {LVCMOS 1.8V} \ CONFIG.PCW_MIO_26_PULLUP {enabled} \ CONFIG.PCW_MIO_26_SLEW {slow} \ CONFIG.PCW_MIO_27_DIRECTION {in} \ CONFIG.PCW_MIO_27_IOTYPE {LVCMOS 1.8V} \ CONFIG.PCW_MIO_27_PULLUP {enabled} \ CONFIG.PCW_MIO_27_SLEW {slow} \ CONFIG.PCW_MIO_28_DIRECTION {inout} \ CONFIG.PCW_MIO_28_IOTYPE {LVCMOS 1.8V} \ CONFIG.PCW_MIO_28_PULLUP {enabled} \ CONFIG.PCW_MIO_28_SLEW {slow} \ CONFIG.PCW_MIO_29_DIRECTION {in} \ CONFIG.PCW_MIO_29_IOTYPE {LVCMOS 1.8V} \ CONFIG.PCW_MIO_29_PULLUP {enabled} \ CONFIG.PCW_MIO_29_SLEW {slow} \ CONFIG.PCW_MIO_2_DIRECTION {inout} \ CONFIG.PCW_MIO_2_IOTYPE {LVCMOS 3.3V} \ CONFIG.PCW_MIO_2_PULLUP {disabled} \ CONFIG.PCW_MIO_2_SLEW {slow} \ CONFIG.PCW_MIO_30_DIRECTION {out} \ CONFIG.PCW_MIO_30_IOTYPE {LVCMOS 1.8V} \ CONFIG.PCW_MIO_30_PULLUP {enabled} \ CONFIG.PCW_MIO_30_SLEW {slow} \ CONFIG.PCW_MIO_31_DIRECTION {in} \ CONFIG.PCW_MIO_31_IOTYPE {LVCMOS 1.8V} \ CONFIG.PCW_MIO_31_PULLUP {enabled} \ CONFIG.PCW_MIO_31_SLEW {slow} \ CONFIG.PCW_MIO_32_DIRECTION {inout} \ CONFIG.PCW_MIO_32_IOTYPE {LVCMOS 1.8V} \ CONFIG.PCW_MIO_32_PULLUP {enabled} \ CONFIG.PCW_MIO_32_SLEW {slow} \ CONFIG.PCW_MIO_33_DIRECTION {inout} \ CONFIG.PCW_MIO_33_IOTYPE {LVCMOS 1.8V} \ CONFIG.PCW_MIO_33_PULLUP {enabled} \ CONFIG.PCW_MIO_33_SLEW {slow} \ CONFIG.PCW_MIO_34_DIRECTION {inout} \ CONFIG.PCW_MIO_34_IOTYPE {LVCMOS 1.8V} \ CONFIG.PCW_MIO_34_PULLUP {enabled} \ CONFIG.PCW_MIO_34_SLEW {slow} \ CONFIG.PCW_MIO_35_DIRECTION {inout} \ CONFIG.PCW_MIO_35_IOTYPE {LVCMOS 1.8V} \ CONFIG.PCW_MIO_35_PULLUP {enabled} \ CONFIG.PCW_MIO_35_SLEW {slow} \ CONFIG.PCW_MIO_36_DIRECTION {in} \ CONFIG.PCW_MIO_36_IOTYPE {LVCMOS 1.8V} \ CONFIG.PCW_MIO_36_PULLUP {enabled} \ CONFIG.PCW_MIO_36_SLEW {slow} \ CONFIG.PCW_MIO_37_DIRECTION {inout} \ CONFIG.PCW_MIO_37_IOTYPE {LVCMOS 1.8V} \ CONFIG.PCW_MIO_37_PULLUP {enabled} \ CONFIG.PCW_MIO_37_SLEW {slow} \ CONFIG.PCW_MIO_38_DIRECTION {inout} \ CONFIG.PCW_MIO_38_IOTYPE {LVCMOS 1.8V} \ CONFIG.PCW_MIO_38_PULLUP {enabled} \ CONFIG.PCW_MIO_38_SLEW {slow} \ CONFIG.PCW_MIO_39_DIRECTION {inout} \ CONFIG.PCW_MIO_39_IOTYPE {LVCMOS 1.8V} \ CONFIG.PCW_MIO_39_PULLUP {enabled} \ CONFIG.PCW_MIO_39_SLEW {slow} \ CONFIG.PCW_MIO_3_DIRECTION {inout} \ CONFIG.PCW_MIO_3_IOTYPE {LVCMOS 3.3V} \ CONFIG.PCW_MIO_3_PULLUP {disabled} \ CONFIG.PCW_MIO_3_SLEW {slow} \ CONFIG.PCW_MIO_40_DIRECTION {inout} \ CONFIG.PCW_MIO_40_IOTYPE {LVCMOS 1.8V} \ CONFIG.PCW_MIO_40_PULLUP {enabled} \ CONFIG.PCW_MIO_40_SLEW {slow} \ CONFIG.PCW_MIO_41_DIRECTION {inout} \ CONFIG.PCW_MIO_41_IOTYPE {LVCMOS 1.8V} \ CONFIG.PCW_MIO_41_PULLUP {enabled} \ CONFIG.PCW_MIO_41_SLEW {slow} \ CONFIG.PCW_MIO_42_DIRECTION {inout} \ CONFIG.PCW_MIO_42_IOTYPE {LVCMOS 1.8V} \ CONFIG.PCW_MIO_42_PULLUP {enabled} \ CONFIG.PCW_MIO_42_SLEW {slow} \ CONFIG.PCW_MIO_43_DIRECTION {inout} \ CONFIG.PCW_MIO_43_IOTYPE {LVCMOS 1.8V} \ CONFIG.PCW_MIO_43_PULLUP {enabled} \ CONFIG.PCW_MIO_43_SLEW {slow} \ CONFIG.PCW_MIO_44_DIRECTION {inout} \ CONFIG.PCW_MIO_44_IOTYPE {LVCMOS 1.8V} \ CONFIG.PCW_MIO_44_PULLUP {enabled} \ CONFIG.PCW_MIO_44_SLEW {slow} \ CONFIG.PCW_MIO_45_DIRECTION {inout} \ CONFIG.PCW_MIO_45_IOTYPE {LVCMOS 1.8V} \ CONFIG.PCW_MIO_45_PULLUP {enabled} \ CONFIG.PCW_MIO_45_SLEW {slow} \ CONFIG.PCW_MIO_46_DIRECTION {out} \ CONFIG.PCW_MIO_46_IOTYPE {LVCMOS 1.8V} \ CONFIG.PCW_MIO_46_PULLUP {enabled} \ CONFIG.PCW_MIO_46_SLEW {slow} \ CONFIG.PCW_MIO_47_DIRECTION {in} \ CONFIG.PCW_MIO_47_IOTYPE {LVCMOS 1.8V} \ CONFIG.PCW_MIO_47_PULLUP {enabled} \ CONFIG.PCW_MIO_47_SLEW {slow} \ CONFIG.PCW_MIO_48_DIRECTION {inout} \ CONFIG.PCW_MIO_48_IOTYPE {LVCMOS 1.8V} \ CONFIG.PCW_MIO_48_PULLUP {enabled} \ CONFIG.PCW_MIO_48_SLEW {slow} \ CONFIG.PCW_MIO_49_DIRECTION {inout} \ CONFIG.PCW_MIO_49_IOTYPE {LVCMOS 1.8V} \ CONFIG.PCW_MIO_49_PULLUP {enabled} \ CONFIG.PCW_MIO_49_SLEW {slow} \ CONFIG.PCW_MIO_4_DIRECTION {inout} \ CONFIG.PCW_MIO_4_IOTYPE {LVCMOS 3.3V} \ CONFIG.PCW_MIO_4_PULLUP {disabled} \ CONFIG.PCW_MIO_4_SLEW {slow} \ CONFIG.PCW_MIO_50_DIRECTION {inout} \ CONFIG.PCW_MIO_50_IOTYPE {LVCMOS 1.8V} \ CONFIG.PCW_MIO_50_PULLUP {enabled} \ CONFIG.PCW_MIO_50_SLEW {slow} \ CONFIG.PCW_MIO_51_DIRECTION {inout} \ CONFIG.PCW_MIO_51_IOTYPE {LVCMOS 1.8V} \ CONFIG.PCW_MIO_51_PULLUP {enabled} \ CONFIG.PCW_MIO_51_SLEW {slow} \ CONFIG.PCW_MIO_52_DIRECTION {out} \ CONFIG.PCW_MIO_52_IOTYPE {LVCMOS 1.8V} \ CONFIG.PCW_MIO_52_PULLUP {enabled} \ CONFIG.PCW_MIO_52_SLEW {slow} \ CONFIG.PCW_MIO_53_DIRECTION {inout} \ CONFIG.PCW_MIO_53_IOTYPE {LVCMOS 1.8V} \ CONFIG.PCW_MIO_53_PULLUP {enabled} \ CONFIG.PCW_MIO_53_SLEW {slow} \ CONFIG.PCW_MIO_5_DIRECTION {inout} \ CONFIG.PCW_MIO_5_IOTYPE {LVCMOS 3.3V} \ CONFIG.PCW_MIO_5_PULLUP {disabled} \ CONFIG.PCW_MIO_5_SLEW {slow} \ CONFIG.PCW_MIO_6_DIRECTION {out} \ CONFIG.PCW_MIO_6_IOTYPE {LVCMOS 3.3V} \ CONFIG.PCW_MIO_6_PULLUP {disabled} \ CONFIG.PCW_MIO_6_SLEW {slow} \ CONFIG.PCW_MIO_7_DIRECTION {out} \ CONFIG.PCW_MIO_7_IOTYPE {LVCMOS 3.3V} \ CONFIG.PCW_MIO_7_PULLUP {disabled} \ CONFIG.PCW_MIO_7_SLEW {slow} \ CONFIG.PCW_MIO_8_DIRECTION {out} \ CONFIG.PCW_MIO_8_IOTYPE {LVCMOS 3.3V} \ CONFIG.PCW_MIO_8_PULLUP {disabled} \ CONFIG.PCW_MIO_8_SLEW {slow} \ CONFIG.PCW_MIO_9_DIRECTION {out} \ CONFIG.PCW_MIO_9_IOTYPE {LVCMOS 3.3V} \ CONFIG.PCW_MIO_9_PULLUP {enabled} \ CONFIG.PCW_MIO_9_SLEW {slow} \ CONFIG.PCW_MIO_PRIMITIVE {54} \ CONFIG.PCW_MIO_TREE_PERIPHERALS {\ GPIO#Quad SPI Flash#Quad SPI Flash#Quad SPI Flash#Quad SPI Flash#Quad SPI\ Flash#Quad SPI Flash#GPIO#Quad SPI Flash#ENET Reset#GPIO#GPIO#GPIO#GPIO#UART\ 0#UART 0#Enet 0#Enet 0#Enet 0#Enet 0#Enet 0#Enet 0#Enet 0#Enet 0#Enet 0#Enet\ 0#Enet 0#Enet 0#USB 0#USB 0#USB 0#USB 0#USB 0#USB 0#USB 0#USB 0#USB 0#USB 0#USB\ 0#USB 0#SD 0#SD 0#SD 0#SD 0#SD 0#SD 0#USB Reset#SD 0#GPIO#GPIO#GPIO#GPIO#Enet\ 0#Enet 0} \ CONFIG.PCW_MIO_TREE_SIGNALS {\ gpio[0]#qspi0_ss_b#qspi0_io[0]#qspi0_io[1]#qspi0_io[2]#qspi0_io[3]/HOLD_B#qspi0_sclk#gpio[7]#qspi_fbclk#reset#gpio[10]#gpio[11]#gpio[12]#gpio[13]#rx#tx#tx_clk#txd[0]#txd[1]#txd[2]#txd[3]#tx_ctl#rx_clk#rxd[0]#rxd[1]#rxd[2]#rxd[3]#rx_ctl#data[4]#dir#stp#nxt#data[0]#data[1]#data[2]#data[3]#clk#data[5]#data[6]#data[7]#clk#cmd#data[0]#data[1]#data[2]#data[3]#reset#cd#gpio[48]#gpio[49]#gpio[50]#gpio[51]#mdc#mdio} \ CONFIG.PCW_M_AXI_GP0_ENABLE_STATIC_REMAP {0} \ CONFIG.PCW_M_AXI_GP0_ID_WIDTH {12} \ CONFIG.PCW_M_AXI_GP0_SUPPORT_NARROW_BURST {0} \ CONFIG.PCW_M_AXI_GP0_THREAD_ID_WIDTH {12} \ CONFIG.PCW_M_AXI_GP1_ENABLE_STATIC_REMAP {0} \ CONFIG.PCW_M_AXI_GP1_ID_WIDTH {12} \ CONFIG.PCW_M_AXI_GP1_SUPPORT_NARROW_BURST {0} \ CONFIG.PCW_M_AXI_GP1_THREAD_ID_WIDTH {12} \ CONFIG.PCW_NAND_CYCLES_T_AR {1} \ CONFIG.PCW_NAND_CYCLES_T_CLR {1} \ CONFIG.PCW_NAND_CYCLES_T_RC {11} \ CONFIG.PCW_NAND_CYCLES_T_REA {1} \ CONFIG.PCW_NAND_CYCLES_T_RR {1} \ CONFIG.PCW_NAND_CYCLES_T_WC {11} \ CONFIG.PCW_NAND_CYCLES_T_WP {1} \ CONFIG.PCW_NAND_GRP_D8_ENABLE {0} \ CONFIG.PCW_NAND_PERIPHERAL_ENABLE {0} \ CONFIG.PCW_NOR_CS0_T_CEOE {1} \ CONFIG.PCW_NOR_CS0_T_PC {1} \ CONFIG.PCW_NOR_CS0_T_RC {11} \ CONFIG.PCW_NOR_CS0_T_TR {1} \ CONFIG.PCW_NOR_CS0_T_WC {11} \ CONFIG.PCW_NOR_CS0_T_WP {1} \ CONFIG.PCW_NOR_CS0_WE_TIME {0} \ CONFIG.PCW_NOR_CS1_T_CEOE {1} \ CONFIG.PCW_NOR_CS1_T_PC {1} \ CONFIG.PCW_NOR_CS1_T_RC {11} \ CONFIG.PCW_NOR_CS1_T_TR {1} \ CONFIG.PCW_NOR_CS1_T_WC {11} \ CONFIG.PCW_NOR_CS1_T_WP {1} \ CONFIG.PCW_NOR_CS1_WE_TIME {0} \ CONFIG.PCW_NOR_GRP_A25_ENABLE {0} \ CONFIG.PCW_NOR_GRP_CS0_ENABLE {0} \ CONFIG.PCW_NOR_GRP_CS1_ENABLE {0} \ CONFIG.PCW_NOR_GRP_SRAM_CS0_ENABLE {0} \ CONFIG.PCW_NOR_GRP_SRAM_CS1_ENABLE {0} \ CONFIG.PCW_NOR_GRP_SRAM_INT_ENABLE {0} \ CONFIG.PCW_NOR_PERIPHERAL_ENABLE {0} \ CONFIG.PCW_NOR_SRAM_CS0_T_CEOE {1} \ CONFIG.PCW_NOR_SRAM_CS0_T_PC {1} \ CONFIG.PCW_NOR_SRAM_CS0_T_RC {11} \ CONFIG.PCW_NOR_SRAM_CS0_T_TR {1} \ CONFIG.PCW_NOR_SRAM_CS0_T_WC {11} \ CONFIG.PCW_NOR_SRAM_CS0_T_WP {1} \ CONFIG.PCW_NOR_SRAM_CS0_WE_TIME {0} \ CONFIG.PCW_NOR_SRAM_CS1_T_CEOE {1} \ CONFIG.PCW_NOR_SRAM_CS1_T_PC {1} \ CONFIG.PCW_NOR_SRAM_CS1_T_RC {11} \ CONFIG.PCW_NOR_SRAM_CS1_T_TR {1} \ CONFIG.PCW_NOR_SRAM_CS1_T_WC {11} \ CONFIG.PCW_NOR_SRAM_CS1_T_WP {1} \ CONFIG.PCW_NOR_SRAM_CS1_WE_TIME {0} \ CONFIG.PCW_OVERRIDE_BASIC_CLOCK {0} \ CONFIG.PCW_P2F_CAN0_INTR {0} \ CONFIG.PCW_P2F_CAN1_INTR {0} \ CONFIG.PCW_P2F_CTI_INTR {0} \ CONFIG.PCW_P2F_DMAC0_INTR {0} \ CONFIG.PCW_P2F_DMAC1_INTR {0} \ CONFIG.PCW_P2F_DMAC2_INTR {0} \ CONFIG.PCW_P2F_DMAC3_INTR {0} \ CONFIG.PCW_P2F_DMAC4_INTR {0} \ CONFIG.PCW_P2F_DMAC5_INTR {0} \ CONFIG.PCW_P2F_DMAC6_INTR {0} \ CONFIG.PCW_P2F_DMAC7_INTR {0} \ CONFIG.PCW_P2F_DMAC_ABORT_INTR {0} \ CONFIG.PCW_P2F_ENET0_INTR {0} \ CONFIG.PCW_P2F_ENET1_INTR {0} \ CONFIG.PCW_P2F_GPIO_INTR {0} \ CONFIG.PCW_P2F_I2C0_INTR {0} \ CONFIG.PCW_P2F_I2C1_INTR {0} \ CONFIG.PCW_P2F_QSPI_INTR {0} \ CONFIG.PCW_P2F_SDIO0_INTR {0} \ CONFIG.PCW_P2F_SDIO1_INTR {0} \ CONFIG.PCW_P2F_SMC_INTR {0} \ CONFIG.PCW_P2F_SPI0_INTR {0} \ CONFIG.PCW_P2F_SPI1_INTR {0} \ CONFIG.PCW_P2F_UART0_INTR {0} \ CONFIG.PCW_P2F_UART1_INTR {0} \ CONFIG.PCW_P2F_USB0_INTR {0} \ CONFIG.PCW_P2F_USB1_INTR {0} \ CONFIG.PCW_PACKAGE_DDR_BOARD_DELAY0 {0.279} \ CONFIG.PCW_PACKAGE_DDR_BOARD_DELAY1 {0.260} \ CONFIG.PCW_PACKAGE_DDR_BOARD_DELAY2 {0.085} \ CONFIG.PCW_PACKAGE_DDR_BOARD_DELAY3 {0.092} \ CONFIG.PCW_PACKAGE_DDR_DQS_TO_CLK_DELAY_0 {-0.051} \ CONFIG.PCW_PACKAGE_DDR_DQS_TO_CLK_DELAY_1 {-0.006} \ CONFIG.PCW_PACKAGE_DDR_DQS_TO_CLK_DELAY_2 {-0.009} \ CONFIG.PCW_PACKAGE_DDR_DQS_TO_CLK_DELAY_3 {-0.033} \ CONFIG.PCW_PACKAGE_NAME {clg400} \ CONFIG.PCW_PCAP_PERIPHERAL_CLKSRC {IO PLL} \ CONFIG.PCW_PCAP_PERIPHERAL_DIVISOR0 {5} \ CONFIG.PCW_PCAP_PERIPHERAL_FREQMHZ {200} \ CONFIG.PCW_PERIPHERAL_BOARD_PRESET {None} \ CONFIG.PCW_PLL_BYPASSMODE_ENABLE {0} \ CONFIG.PCW_PRESET_BANK0_VOLTAGE {LVCMOS 3.3V} \ CONFIG.PCW_PRESET_BANK1_VOLTAGE {LVCMOS 1.8V} \ CONFIG.PCW_PS7_SI_REV {PRODUCTION} \ CONFIG.PCW_QSPI_GRP_FBCLK_ENABLE {1} \ CONFIG.PCW_QSPI_GRP_FBCLK_IO {MIO 8} \ CONFIG.PCW_QSPI_GRP_IO1_ENABLE {0} \ CONFIG.PCW_QSPI_GRP_SINGLE_SS_ENABLE {1} \ CONFIG.PCW_QSPI_GRP_SINGLE_SS_IO {MIO 1 .. 6} \ CONFIG.PCW_QSPI_GRP_SS1_ENABLE {0} \ CONFIG.PCW_QSPI_INTERNAL_HIGHADDRESS {0xFCFFFFFF} \ CONFIG.PCW_QSPI_PERIPHERAL_CLKSRC {IO PLL} \ CONFIG.PCW_QSPI_PERIPHERAL_DIVISOR0 {5} \ CONFIG.PCW_QSPI_PERIPHERAL_ENABLE {1} \ CONFIG.PCW_QSPI_PERIPHERAL_FREQMHZ {200} \ CONFIG.PCW_QSPI_QSPI_IO {MIO 1 .. 6} \ CONFIG.PCW_SD0_GRP_CD_ENABLE {1} \ CONFIG.PCW_SD0_GRP_CD_IO {MIO 47} \ CONFIG.PCW_SD0_GRP_POW_ENABLE {0} \ CONFIG.PCW_SD0_GRP_WP_ENABLE {0} \ CONFIG.PCW_SD0_PERIPHERAL_ENABLE {1} \ CONFIG.PCW_SD0_SD0_IO {MIO 40 .. 45} \ CONFIG.PCW_SD1_GRP_CD_ENABLE {0} \ CONFIG.PCW_SD1_GRP_POW_ENABLE {0} \ CONFIG.PCW_SD1_GRP_WP_ENABLE {0} \ CONFIG.PCW_SD1_PERIPHERAL_ENABLE {0} \ CONFIG.PCW_SDIO0_BASEADDR {0xE0100000} \ CONFIG.PCW_SDIO0_HIGHADDR {0xE0100FFF} \ CONFIG.PCW_SDIO1_BASEADDR {0xE0101000} \ CONFIG.PCW_SDIO1_HIGHADDR {0xE0101FFF} \ CONFIG.PCW_SDIO_PERIPHERAL_CLKSRC {IO PLL} \ CONFIG.PCW_SDIO_PERIPHERAL_DIVISOR0 {20} \ CONFIG.PCW_SDIO_PERIPHERAL_FREQMHZ {50} \ CONFIG.PCW_SDIO_PERIPHERAL_VALID {1} \ CONFIG.PCW_SINGLE_QSPI_DATA_MODE {x4} \ CONFIG.PCW_SMC_CYCLE_T0 {NA} \ CONFIG.PCW_SMC_CYCLE_T1 {NA} \ CONFIG.PCW_SMC_CYCLE_T2 {NA} \ CONFIG.PCW_SMC_CYCLE_T3 {NA} \ CONFIG.PCW_SMC_CYCLE_T4 {NA} \ CONFIG.PCW_SMC_CYCLE_T5 {NA} \ CONFIG.PCW_SMC_CYCLE_T6 {NA} \ CONFIG.PCW_SMC_PERIPHERAL_CLKSRC {IO PLL} \ CONFIG.PCW_SMC_PERIPHERAL_DIVISOR0 {1} \ CONFIG.PCW_SMC_PERIPHERAL_FREQMHZ {100} \ CONFIG.PCW_SMC_PERIPHERAL_VALID {0} \ CONFIG.PCW_SPI0_BASEADDR {0xE0006000} \ CONFIG.PCW_SPI0_GRP_SS0_ENABLE {0} \ CONFIG.PCW_SPI0_GRP_SS1_ENABLE {0} \ CONFIG.PCW_SPI0_GRP_SS2_ENABLE {0} \ CONFIG.PCW_SPI0_HIGHADDR {0xE0006FFF} \ CONFIG.PCW_SPI0_PERIPHERAL_ENABLE {0} \ CONFIG.PCW_SPI1_BASEADDR {0xE0007000} \ CONFIG.PCW_SPI1_GRP_SS0_ENABLE {0} \ CONFIG.PCW_SPI1_GRP_SS1_ENABLE {0} \ CONFIG.PCW_SPI1_GRP_SS2_ENABLE {0} \ CONFIG.PCW_SPI1_HIGHADDR {0xE0007FFF} \ CONFIG.PCW_SPI1_PERIPHERAL_ENABLE {0} \ CONFIG.PCW_SPI_PERIPHERAL_CLKSRC {IO PLL} \ CONFIG.PCW_SPI_PERIPHERAL_DIVISOR0 {1} \ CONFIG.PCW_SPI_PERIPHERAL_FREQMHZ {166.666666} \ CONFIG.PCW_SPI_PERIPHERAL_VALID {0} \ CONFIG.PCW_S_AXI_ACP_ARUSER_VAL {31} \ CONFIG.PCW_S_AXI_ACP_AWUSER_VAL {31} \ CONFIG.PCW_S_AXI_ACP_ID_WIDTH {3} \ CONFIG.PCW_S_AXI_GP0_ID_WIDTH {6} \ CONFIG.PCW_S_AXI_GP1_ID_WIDTH {6} \ CONFIG.PCW_S_AXI_HP0_DATA_WIDTH {64} \ CONFIG.PCW_S_AXI_HP0_ID_WIDTH {6} \ CONFIG.PCW_S_AXI_HP1_DATA_WIDTH {64} \ CONFIG.PCW_S_AXI_HP1_ID_WIDTH {6} \ CONFIG.PCW_S_AXI_HP2_DATA_WIDTH {64} \ CONFIG.PCW_S_AXI_HP2_ID_WIDTH {6} \ CONFIG.PCW_S_AXI_HP3_DATA_WIDTH {64} \ CONFIG.PCW_S_AXI_HP3_ID_WIDTH {6} \ CONFIG.PCW_TPIU_PERIPHERAL_CLKSRC {External} \ CONFIG.PCW_TPIU_PERIPHERAL_DIVISOR0 {1} \ CONFIG.PCW_TPIU_PERIPHERAL_FREQMHZ {200} \ CONFIG.PCW_TRACE_BUFFER_CLOCK_DELAY {12} \ CONFIG.PCW_TRACE_BUFFER_FIFO_SIZE {128} \ CONFIG.PCW_TRACE_PIPELINE_WIDTH {8} \ CONFIG.PCW_TTC0_BASEADDR {0xE0104000} \ CONFIG.PCW_TTC0_CLK0_PERIPHERAL_CLKSRC {CPU_1X} \ CONFIG.PCW_TTC0_CLK0_PERIPHERAL_DIVISOR0 {1} \ CONFIG.PCW_TTC0_CLK0_PERIPHERAL_FREQMHZ {133.333333} \ CONFIG.PCW_TTC0_CLK1_PERIPHERAL_CLKSRC {CPU_1X} \ CONFIG.PCW_TTC0_CLK1_PERIPHERAL_DIVISOR0 {1} \ CONFIG.PCW_TTC0_CLK1_PERIPHERAL_FREQMHZ {133.333333} \ CONFIG.PCW_TTC0_CLK2_PERIPHERAL_CLKSRC {CPU_1X} \ CONFIG.PCW_TTC0_CLK2_PERIPHERAL_DIVISOR0 {1} \ CONFIG.PCW_TTC0_CLK2_PERIPHERAL_FREQMHZ {133.333333} \ CONFIG.PCW_TTC0_HIGHADDR {0xE0104fff} \ CONFIG.PCW_TTC1_BASEADDR {0xE0105000} \ CONFIG.PCW_TTC1_CLK0_PERIPHERAL_CLKSRC {CPU_1X} \ CONFIG.PCW_TTC1_CLK0_PERIPHERAL_DIVISOR0 {1} \ CONFIG.PCW_TTC1_CLK0_PERIPHERAL_FREQMHZ {133.333333} \ CONFIG.PCW_TTC1_CLK1_PERIPHERAL_CLKSRC {CPU_1X} \ CONFIG.PCW_TTC1_CLK1_PERIPHERAL_DIVISOR0 {1} \ CONFIG.PCW_TTC1_CLK1_PERIPHERAL_FREQMHZ {133.333333} \ CONFIG.PCW_TTC1_CLK2_PERIPHERAL_CLKSRC {CPU_1X} \ CONFIG.PCW_TTC1_CLK2_PERIPHERAL_DIVISOR0 {1} \ CONFIG.PCW_TTC1_CLK2_PERIPHERAL_FREQMHZ {133.333333} \ CONFIG.PCW_TTC1_HIGHADDR {0xE0105fff} \ CONFIG.PCW_TTC_PERIPHERAL_FREQMHZ {50} \ CONFIG.PCW_UART0_BASEADDR {0xE0000000} \ CONFIG.PCW_UART0_BAUD_RATE {115200} \ CONFIG.PCW_UART0_GRP_FULL_ENABLE {0} \ CONFIG.PCW_UART0_HIGHADDR {0xE0000FFF} \ CONFIG.PCW_UART0_PERIPHERAL_ENABLE {1} \ CONFIG.PCW_UART0_UART0_IO {MIO 14 .. 15} \ CONFIG.PCW_UART1_BASEADDR {0xE0001000} \ CONFIG.PCW_UART1_BAUD_RATE {115200} \ CONFIG.PCW_UART1_GRP_FULL_ENABLE {0} \ CONFIG.PCW_UART1_HIGHADDR {0xE0001FFF} \ CONFIG.PCW_UART1_PERIPHERAL_ENABLE {0} \ CONFIG.PCW_UART_PERIPHERAL_CLKSRC {IO PLL} \ CONFIG.PCW_UART_PERIPHERAL_DIVISOR0 {10} \ CONFIG.PCW_UART_PERIPHERAL_FREQMHZ {100} \ CONFIG.PCW_UART_PERIPHERAL_VALID {1} \ CONFIG.PCW_UIPARAM_ACT_DDR_FREQ_MHZ {525.000000} \ CONFIG.PCW_UIPARAM_DDR_ADV_ENABLE {0} \ CONFIG.PCW_UIPARAM_DDR_AL {0} \ CONFIG.PCW_UIPARAM_DDR_BANK_ADDR_COUNT {3} \ CONFIG.PCW_UIPARAM_DDR_BL {8} \ CONFIG.PCW_UIPARAM_DDR_BOARD_DELAY0 {0.279} \ CONFIG.PCW_UIPARAM_DDR_BOARD_DELAY1 {0.260} \ CONFIG.PCW_UIPARAM_DDR_BOARD_DELAY2 {0.085} \ CONFIG.PCW_UIPARAM_DDR_BOARD_DELAY3 {0.092} \ CONFIG.PCW_UIPARAM_DDR_BUS_WIDTH {16 Bit} \ CONFIG.PCW_UIPARAM_DDR_CL {7} \ CONFIG.PCW_UIPARAM_DDR_CLOCK_0_LENGTH_MM {27.95} \ CONFIG.PCW_UIPARAM_DDR_CLOCK_0_PACKAGE_LENGTH {80.4535} \ CONFIG.PCW_UIPARAM_DDR_CLOCK_0_PROPOGATION_DELAY {160} \ CONFIG.PCW_UIPARAM_DDR_CLOCK_1_LENGTH_MM {27.95} \ CONFIG.PCW_UIPARAM_DDR_CLOCK_1_PACKAGE_LENGTH {80.4535} \ CONFIG.PCW_UIPARAM_DDR_CLOCK_1_PROPOGATION_DELAY {160} \ CONFIG.PCW_UIPARAM_DDR_CLOCK_2_LENGTH_MM {0} \ CONFIG.PCW_UIPARAM_DDR_CLOCK_2_PACKAGE_LENGTH {80.4535} \ CONFIG.PCW_UIPARAM_DDR_CLOCK_2_PROPOGATION_DELAY {160} \ CONFIG.PCW_UIPARAM_DDR_CLOCK_3_LENGTH_MM {0} \ CONFIG.PCW_UIPARAM_DDR_CLOCK_3_PACKAGE_LENGTH {80.4535} \ CONFIG.PCW_UIPARAM_DDR_CLOCK_3_PROPOGATION_DELAY {160} \ CONFIG.PCW_UIPARAM_DDR_CLOCK_STOP_EN {0} \ CONFIG.PCW_UIPARAM_DDR_COL_ADDR_COUNT {10} \ CONFIG.PCW_UIPARAM_DDR_CWL {6} \ CONFIG.PCW_UIPARAM_DDR_DEVICE_CAPACITY {4096 MBits} \ CONFIG.PCW_UIPARAM_DDR_DQS_0_LENGTH_MM {32.14} \ CONFIG.PCW_UIPARAM_DDR_DQS_0_PACKAGE_LENGTH {105.056} \ CONFIG.PCW_UIPARAM_DDR_DQS_0_PROPOGATION_DELAY {160} \ CONFIG.PCW_UIPARAM_DDR_DQS_1_LENGTH_MM {31.12} \ CONFIG.PCW_UIPARAM_DDR_DQS_1_PACKAGE_LENGTH {66.904} \ CONFIG.PCW_UIPARAM_DDR_DQS_1_PROPOGATION_DELAY {160} \ CONFIG.PCW_UIPARAM_DDR_DQS_2_LENGTH_MM {0} \ CONFIG.PCW_UIPARAM_DDR_DQS_2_PACKAGE_LENGTH {89.1715} \ CONFIG.PCW_UIPARAM_DDR_DQS_2_PROPOGATION_DELAY {160} \ CONFIG.PCW_UIPARAM_DDR_DQS_3_LENGTH_MM {0} \ CONFIG.PCW_UIPARAM_DDR_DQS_3_PACKAGE_LENGTH {113.63} \ CONFIG.PCW_UIPARAM_DDR_DQS_3_PROPOGATION_DELAY {160} \ CONFIG.PCW_UIPARAM_DDR_DQS_TO_CLK_DELAY_0 {-0.051} \ CONFIG.PCW_UIPARAM_DDR_DQS_TO_CLK_DELAY_1 {-0.006} \ CONFIG.PCW_UIPARAM_DDR_DQS_TO_CLK_DELAY_2 {-0.009} \ CONFIG.PCW_UIPARAM_DDR_DQS_TO_CLK_DELAY_3 {-0.033} \ CONFIG.PCW_UIPARAM_DDR_DQ_0_LENGTH_MM {32.2} \ CONFIG.PCW_UIPARAM_DDR_DQ_0_PACKAGE_LENGTH {98.503} \ CONFIG.PCW_UIPARAM_DDR_DQ_0_PROPOGATION_DELAY {160} \ CONFIG.PCW_UIPARAM_DDR_DQ_1_LENGTH_MM {31.08} \ CONFIG.PCW_UIPARAM_DDR_DQ_1_PACKAGE_LENGTH {68.5855} \ CONFIG.PCW_UIPARAM_DDR_DQ_1_PROPOGATION_DELAY {160} \ CONFIG.PCW_UIPARAM_DDR_DQ_2_LENGTH_MM {0} \ CONFIG.PCW_UIPARAM_DDR_DQ_2_PACKAGE_LENGTH {90.295} \ CONFIG.PCW_UIPARAM_DDR_DQ_2_PROPOGATION_DELAY {160} \ CONFIG.PCW_UIPARAM_DDR_DQ_3_LENGTH_MM {0} \ CONFIG.PCW_UIPARAM_DDR_DQ_3_PACKAGE_LENGTH {103.977} \ CONFIG.PCW_UIPARAM_DDR_DQ_3_PROPOGATION_DELAY {160} \ CONFIG.PCW_UIPARAM_DDR_DRAM_WIDTH {16 Bits} \ CONFIG.PCW_UIPARAM_DDR_ECC {Disabled} \ CONFIG.PCW_UIPARAM_DDR_ENABLE {1} \ CONFIG.PCW_UIPARAM_DDR_FREQ_MHZ {525} \ CONFIG.PCW_UIPARAM_DDR_HIGH_TEMP {Normal (0-85)} \ CONFIG.PCW_UIPARAM_DDR_MEMORY_TYPE {DDR 3} \ CONFIG.PCW_UIPARAM_DDR_PARTNO {MT41J256M16 RE-125} \ CONFIG.PCW_UIPARAM_DDR_ROW_ADDR_COUNT {15} \ CONFIG.PCW_UIPARAM_DDR_SPEED_BIN {DDR3_1066F} \ CONFIG.PCW_UIPARAM_DDR_TRAIN_DATA_EYE {1} \ CONFIG.PCW_UIPARAM_DDR_TRAIN_READ_GATE {1} \ CONFIG.PCW_UIPARAM_DDR_TRAIN_WRITE_LEVEL {1} \ CONFIG.PCW_UIPARAM_DDR_T_FAW {40.0} \ CONFIG.PCW_UIPARAM_DDR_T_RAS_MIN {35.0} \ CONFIG.PCW_UIPARAM_DDR_T_RC {48.91} \ CONFIG.PCW_UIPARAM_DDR_T_RCD {7} \ CONFIG.PCW_UIPARAM_DDR_T_RP {7} \ CONFIG.PCW_UIPARAM_DDR_USE_INTERNAL_VREF {0} \ CONFIG.PCW_UIPARAM_GENERATE_SUMMARY {NA} \ CONFIG.PCW_USB0_BASEADDR {0xE0102000} \ CONFIG.PCW_USB0_HIGHADDR {0xE0102fff} \ CONFIG.PCW_USB0_PERIPHERAL_ENABLE {1} \ CONFIG.PCW_USB0_PERIPHERAL_FREQMHZ {60} \ CONFIG.PCW_USB0_RESET_ENABLE {1} \ CONFIG.PCW_USB0_RESET_IO {MIO 46} \ CONFIG.PCW_USB0_USB0_IO {MIO 28 .. 39} \ CONFIG.PCW_USB1_BASEADDR {0xE0103000} \ CONFIG.PCW_USB1_HIGHADDR {0xE0103fff} \ CONFIG.PCW_USB1_PERIPHERAL_ENABLE {0} \ CONFIG.PCW_USB1_PERIPHERAL_FREQMHZ {60} \ CONFIG.PCW_USB1_RESET_ENABLE {0} \ CONFIG.PCW_USB_RESET_ENABLE {1} \ CONFIG.PCW_USB_RESET_POLARITY {Active Low} \ CONFIG.PCW_USB_RESET_SELECT {Share reset pin} \ CONFIG.PCW_USE_AXI_FABRIC_IDLE {0} \ CONFIG.PCW_USE_AXI_NONSECURE {0} \ CONFIG.PCW_USE_CORESIGHT {0} \ CONFIG.PCW_USE_CROSS_TRIGGER {0} \ CONFIG.PCW_USE_CR_FABRIC {1} \ CONFIG.PCW_USE_DDR_BYPASS {0} \ CONFIG.PCW_USE_DEBUG {0} \ CONFIG.PCW_USE_DEFAULT_ACP_USER_VAL {0} \ CONFIG.PCW_USE_DMA0 {0} \ CONFIG.PCW_USE_DMA1 {0} \ CONFIG.PCW_USE_DMA2 {0} \ CONFIG.PCW_USE_DMA3 {0} \ CONFIG.PCW_USE_EXPANDED_IOP {0} \ CONFIG.PCW_USE_EXPANDED_PS_SLCR_REGISTERS {0} \ CONFIG.PCW_USE_FABRIC_INTERRUPT {0} \ CONFIG.PCW_USE_HIGH_OCM {0} \ CONFIG.PCW_USE_M_AXI_GP0 {1} \ CONFIG.PCW_USE_M_AXI_GP1 {0} \ CONFIG.PCW_USE_PROC_EVENT_BUS {0} \ CONFIG.PCW_USE_PS_SLCR_REGISTERS {0} \ CONFIG.PCW_USE_S_AXI_ACP {0} \ CONFIG.PCW_USE_S_AXI_GP0 {0} \ CONFIG.PCW_USE_S_AXI_GP1 {0} \ CONFIG.PCW_USE_S_AXI_HP0 {1} \ CONFIG.PCW_USE_S_AXI_HP1 {0} \ CONFIG.PCW_USE_S_AXI_HP2 {0} \ CONFIG.PCW_USE_S_AXI_HP3 {0} \ CONFIG.PCW_USE_TRACE {0} \ CONFIG.PCW_USE_TRACE_DATA_EDGE_DETECTOR {0} \ CONFIG.PCW_VALUE_SILVERSION {3} \ CONFIG.PCW_WDT_PERIPHERAL_CLKSRC {CPU_1X} \ CONFIG.PCW_WDT_PERIPHERAL_DIVISOR0 {1} \ CONFIG.PCW_WDT_PERIPHERAL_FREQMHZ {133.333333} \ ] $processing_system7_0 ```