# **Table of Content** | 1 | INTE | RODUCTION | 5 | |---|-------|---------------------------------------------|----| | | 1.1 I | Purpose | 5 | | | 1.2 I | Reference Document | 5 | | | | Overview | | | | 1.4 | ACRONYMS AND ABBREVIATIONS | 5 | | 2 | IP CO | ONFIGURATION AND INSTANTIATION | 6 | | | 2.1 I | EXAMPLE DESIGN | 6 | | | | P Configuration | | | | 2.3 | STEPS TO INSTANTIATE SD HOST IP | 8 | | 3 | IMPI | LEMENTATION DETAILS | 10 | | | | CLOCK DOMAIN | | | | | CONSTRAINTS | | | | 3.2.1 | Clock constraints: | 10 | | | 3.2.2 | False path constraints: | 10 | | | 3.2.3 | LOC Constraints: | 11 | | | 3.2.4 | Pin Constraints: | 11 | | 4 | TEST | T SETUP | 12 | | | 4.1 | Test requirements | 12 | | | 4.2 | CONNECTIONS | 12 | | | 4.3 I | PROGRAMMING FPGA AND RUNNING USING VITIS. | 13 | | 5 | TEST | 「PROCEDURE | 16 | | | 5.1 | TERA TERM SETUP | 16 | | | 5.2 | FESTING PROCEDURE | 16 | | | 5.2.1 | Initial prints: | 16 | | | 5.2.2 | Basic Write Operation: | 18 | | | 5.2.3 | Basic Read Operation: | | | | 5.2.4 | Write, Read and Compare operation: | 19 | | 6 | DESI | GN MODIFICATION TO BE DONE FOR CUSTOM BOARD | 21 | | 7 | RESC | OURCE UTILIZATION | 22 | # **List Of Figures** | Figure 1:Design sources where SD host netlist is instantiated | 6 | |---------------------------------------------------------------------|----| | Figure 2:SD_Host Controller added to the block design | 7 | | Figure 3:Adding SD_Host_controller IP to the IP repository | | | Figure 4:Instantiation of block design IO signals in the top module | | | Figure 5:Clock constraints | | | Figure 6:False path constraints | 10 | | Figure 7:LOC Constraints | | | Figure 8:Pin Constraints in example design .xdc file | 11 | | Figure 9:Test Setup of KC705 board with iW_FMC card | | | Figure 10:SD Connector FMC | 13 | | Figure 11:Launching Vitis 2020.1 | | | Figure 12:Target setup in run configuration. | 15 | | Figure 13:Initial print after FPGA is programmed | | | Figure 14:Card Inserted to FMC | | | Figure 15:Card Initialization | | | Figure 16:Wrong choice | | | Figure 17:Basic Write Operation | | | Figure 18:Basic Read Operation | | | Figure 19:Write & Read Back and Compare | | # **List Of Tables** | Table 1: Acronyms & Abbreviations | | 5 | |-------------------------------------------------------------|---|---| | Table 2: Resource Utilization for device for KC705 dev. kit | 2 | 2 | # 1 Introduction # 1.1 Purpose The purpose of this document is to describe SD / SDIO Host Controller 3.0. IP Integration details. ## 1.2 Reference Document • IP data sheet #### 1.3 Overview SD/SDIO Host Controller interfaces the Microblaze through AXI4 bus and MiG Controller through AXI memory mapped interface, enabling the data transfers between each other. Microblaze IP will send the response to the SD host depending on the command issued and also communicates with the MIG controller for Data read & write. ## 1.4 Acronyms and Abbreviations Table 1: Acronyms & Abbreviations | Term | Meaning | |------|-------------------------------| | FPGA | Field Programmable Gate Array | | GPIO | General purpose input output | | FMC | FPGA Mezzanine Card | | LUT | Look Up Table | | IO | Input and Output | | FF | Flip Flop | # 2 IP Configuration and Instantiation ## 2.1 Example design The SD/SDIO host controller IP example design mainly consists of - 1. **Microblaze soft core:** User can provide the inputs to run the different tests using the bare metal code running in the Microblaze. This will pass the different control signals to SD host controller based on the user selection. - 2. **SD/SDIO Host Controller IP:** SD host controller IP takes the command given from the microblaze soft core to the register set and with the ADMA the read and write operation will happen from and to the SD Card. ## 2.2 IP Configuration The register set, ADMA configuration , tuning block , command and data path files are pre synthesized. After synthesis the post synthesis file i.e., sd\_host.edn file is instantiated in the design as shown in the Figure 1 . The SD Host controller with other files like the sd\_host.edn file, sd\_host stub file, axi4\_lite interface and the AXI memory mapped interface wrapper files are added to make a user configured IP. Figure 1:Design sources where SD host netlist is instantiated Module sd\_host\_controller is the top module of the project which integrates the all the other files (as shown in the Figure 1) to form a single IP. Once the IP is generated make sure that the IP needs to be added in the block design of the Vivado project 2020.1. Figure 2:SD Host Controller added to the block design ## 2.3 Steps to Instantiate SD HOST IP - Install the required Vivado Design Suite 2020.1 for the host PC adding the license path. https://www.xilinx.com/support/download/index.html/content/xil%09%09inx/en/downloadNav/vivado-design-tools/archive.html - Copy the project from "....\EMFEV\_Release1.0\_SD\_3.0\_Host\iW-EMFEV-PF-01-R1.0-REL1.0\iW-EMFEV-FF-01-R1.0-REL1.0\iW-EMFEV-ED-01-R1.0-REL1.0\iW\_EMFEV\_REL\_1.0\project\_1" to your project directory in the host PC. - Open the Xilinx Vivado tool 2020.1 and click on "Open Project" and select the required project from the folder by clicking ok. - Now the project selected will be opened in Vivado Design Suite 2020.1. - Go to settings of Vivado 2020.1 and add the IP to the Project Settings → IP → Repository→then add the IP path. Figure 3:Adding SD Host controller IP to the IP repository IP location is ..\EMFEV\_Release1.0\_SD\_3.0\_Host\iW-EMFEV-PF-01-R1.0-REL1.0\iW-EMFEV-FF-01-R1.0-REL1.0\iW-EMFEV-ED-01-R1.0-REL1.0\ iW\_EMFEV\_REL\_1.0\ project\_1.srcs \sources\_1 \IP .Add IP by clicking on the + sign as shown in Figure 3. After the IP is added click on Apply and close the dialogue box Once the IP is added in the project repository open the block design by clicking on mb\_preset under top\_module \(\rightarrow\) mb\_preset\_wrapper present in the source tab . 1. After adding the other IPs like Microblaze ,UART ,MIG Controller and Clocking Wizard, add the SD host controller IP to the block design as shown in Figure 2 by clicking on the + sign - 2. Synthesize the block design first by validating the design(F6) and generate the output products by right clicking on mb\_preset\_under top\_module → mb\_preset\_wrapper present in the source tab and create HDL Wrapper - 3. Instantiate mb\_preset\_wrapper in the top module with the ports and signals of block design, in the top\_module.v file as shown in Figure 4 ``` mb preset wrapper design inst ( .reset (!reset ), .ddr3_sdram_addr (ddr3_sdram_addr ), .ddr3_sdram_ba (ddr3_sdram_ba ), .ddr3_sdram_cas_n (ddr3_sdram_cas_n ), .ddr3_sdram_ck_n (ddr3_sdram_ck_n ), .ddr3_sdram_ck_p (ddr3_sdram_ck_p ), .ddr3_sdram_cke (ddr3_sdram_cke ), .ddr3_sdram_cs_n (ddr3_sdram_cs_n ), .ddr3_sdram_dm (ddr3_sdram_cs_n ), .ddr3_sdram_dm (ddr3_sdram_dm ), .ddr3_sdram_dq (ddr3_sdram_dq ), .ddr3_sdram_dqs_n (ddr3_sdram_dqs_n ), .ddr3_sdram_dqs_p (ddr3_sdram_dqs_n ), .ddr3_sdram_odt (ddr3_sdram_odt ), .ddr3_sdram_odt (ddr3_sdram_odt ), .ddr3_sdram_ras_n (ddr3_sdram_ras_n ), .ddr3_sdram_reset_n (ddr3_sdram_ras_n ), .ddr3_sdram_we_n (ddr3_sdram_we_n ), //UART IO signals //DDR3 IO signals //UART IO signals ) , //SD HOST IO signals .enable_o (enable_o .enable_o ( enable_o ) , .mmc_cd_n_i ( mmc_cd_n_i ) , .mmc_clk_o ( mmc_clk_o ) , .mmc_dat_io ( mmc_dat_io ) , .mmc_wp_n_i ( mmc_wp_n_i ) , .cmd_dir_o ( cmd_dir_o ) , .cmd_out ( cmd_out ) , .data0_dir_o ( data0_dir_o ) , .data1_3_dir_o ( sys_diff_clock_clk_n ) , .sys_diff_clock_clk_n ( sys_diff_clock_clk_p ) , .voltage 1 8 slct o ( voltage 1 8 slct o .voltage_1_8_slct_o ( voltage_1_8_slct_o ) ); ``` Figure 4:Instantiation of block design IO signals in the top module - 4. The Constraint file (.xdc) provided in the design is for the Xilinx KC705 Board. It should be changed for custom boards other than Xilinx KC705 Board. - 5. Give the required clock, Pin/IO constraints for SD host controller in the .xdc file and compile the custom design with SD host IP. # 3 Implementation Details #### 3.1 Clock Domain SD Host Controller 3.0 IP works on the SDR104 mode and the base clock mclk\_i drives the output clock to the SD card. User may need to adjust this clock between 104 MHz to 208 MHz based on the hardware setup. In other words, if user gets CRC error with say 200 MHz, then user can reduce the clock to say 190 MHz or below than to make sure write and read works fine with that base clock. mclk90\_i is a phase shifted version of the mclk\_i which is 200MHz and this clock is phase shifted based on the response from the SD card. By default, no phase shift is will be added.. Idelay\_ref\_clk\_i is the fixed 200 MHz clock which will be provided for the IDELAY primitive to be used for the tuning implementation block. s\_axi\_clk\_i or hclk\_i which is 100 MHz which will be used for the communication between the micro blaze and IP using the AXI4-lite interface for register access and AXI4-MM for DMA access. So to generate the all these clocks we give a 200MHz on board clock to MIG controller and 100 MHz is generated from the MIG and that is given to the clocking wizard to generate other required clocks. #### 3.2 Constraints #### 3.2.1 Clock constraints: The figure 5 shows the clock constraints used in this design. The constraints given here is the system clock whose frequency is 200Mhz for Xilinx KC705 board. This constraint is added in the .xdc file. All other generated clocks will be automatically handled by the Vivado tool since those are derived from the MMCM and will have known relationship. User need to make sure there is no unconstrained clock in the design by checking the clock network report in the Open implemented design from Vivado tool. ``` create clock -period 5.000 [get ports sys_diff_clock_clk_p] ``` Figure 5:Clock constraints #### **3.2.2** False path constraints: The Figure 6 shows the false path in between all the clocks which is configured for the SD host IP. This details will be available in the .xdc file. set false path -from [get\_clocks -of objects [get\_pins design\_inst/mb\_preset\_i/clk wiz\_0/inst/mmcm\_adv\_inst/CLKOUT2]] -to [get\_pins design inst/mb\_preset\_i/clk wiz\_0/inst/mmcm\_adv\_inst/CLKOUT1]] set false path -from [get\_pins design\_inst/mb\_preset\_i/sd host controller 0/inst/sd host controller 0/inst/sd host inst/TOUR2 mmc cmd iddr inst/R] Figure 6:False path constraints #### 3.2.3 LOC Constraints: The Figure 7 shows the LOC constraints that is been added to the sd\_host's idelaycntrl. Note that this LOC constraint is added because of the MIG GUI 7series idelaycntrl for Xilinx KC705 board was conflicting with idelaycntrl of the SD\_Host\_Controller IP. ``` set\_property \ \texttt{LOC} \ IDELAYCTRL\_X1Y1 \ [get\_cells \ design\_inst/mb\_preset\_i/sd\_host\_controller\_0/inst/sd\_host\_inst/tuning\_block\_inst/IdelayCtl] ``` **Figure 7:LOC Constraints** #### 3.2.4 Pin Constraints: Figure 8 shows the pin constraints in the .xdc file of example design. ``` set property PACKAGE_PIN H26 [get ports {mmc_dat_io[3]}] set property PACKAGE PIN E29 [get ports {mmc_dat_io[2]}] set property PACKAGE_PIN G28 [get ports {mmc_dat_io[1]}] set property PACKAGE PIN D29 [get ports {mmc dat io[0]}] set property PACKAGE_PIN H24 [get ports mmc_clk_o] set property PACKAGE PIN E28 [get ports mmc cmd io] set property PACKAGE_PIN G27 [get_ports data0_dir_o] set property PACKAGE PIN C29 [get ports datal 3 dir o] set property PACKAGE_PIN G29 [get ports cmd_dir_o] set property PACKAGE_PIN B30 [get ports voltage_1_8_slct_o] set property PACKAGE PIN H30 [get ports mmc cd n i] set property PACKAGE PIN G30 [get ports mmc wp n i] set property PACKAGE PIN D11 [get ports enable o] set property IOSTANDARD LVCMOS18 [get ports {mmc_dat_io[3]}] set property IOSTANDARD LVCMOS18 [get ports {mmc_dat_io[2]}] set property IOSTANDARD LVCMOS18 [get ports {mmc_dat_io[1]}] set property IOSTANDARD LVCMOS18 [get ports {mmc_dat_io[0]}] set property IOSTANDARD LVCMOS18 [get ports mmc clk o] set property IOSTANDARD LVCMOS18 [get ports mmc_cmd_io] set property IOSTANDARD LVCMOS18 [get ports data0_dir_o] set property IOSTANDARD LVCMOS18 [get ports datal 3 dir o] set property IOSTANDARD LVCMOS18 [get ports cmd_dir_o] set property IOSTANDARD LVCMOS18 [get ports voltage_1_8_slct_o] set property IOSTANDARD LVCMOS18 [get ports | mmc cd n i] set property IOSTANDARD LVCMOS18 [get ports mmc wp n i] set property IOSTANDARD LVCMOS18 [get ports enable o] ``` Figure 8:Pin Constraints in example design .xdc file **NOTE:** These constraints are in accordance to example design created for the KC705 Evaluation kit and there is no need of adding the MIG/DDR IO pins, UART IO pins. Define the constraints for clock, reset and UART pins accordingly for any other custom board. # 4 Test setup ## 4.1 Test requirements - Xilinx KC705 dev kit - iWave FMC daughter card - USB cables for JTAG and UART - SD card for testing - Power Supply 12 V NOTE: iWave FMC card requires $V_{adj}$ =1.8V for its operation. In order to set $V_{adj}$ to 1.8V, rework needs to be done in Xilinx KC705 board as its $V_{adj}$ =2.5v by default. User need to do below rework, - Remove resistor R576 - Removed inductor L47 The $V_{adj}$ value depends on the custom board and this rework is only needed for testing iWave FMC daughter card with KC705 dev kit. ## 4.2 Connections Figure 9:Test Setup of KC705 board with iW\_FMC card Please make sure that FMC card of SD connector interface is connected to HPC FMC of Xilinx KC705 board. Also make sure that SD connector FMC card is set to 1.8V and 2 Blue LED in FMC card is glowing as shown in the Figure 10. Figure 10:SD Connector FMC # 4.3 Programming FPGA and running using Vitis. - After generating bitstream in Vivado 2020.1 go to File→ Export hardware → select Fixed click next → select include bitstream and click next → give the XSA file name where you want to store your xsa and keep directory as local to project and click Finish - Create a local folder in the Vivado Project folder and give that as workspace folder for Vitis 2020.1 project and click ok - After exporting the project go to tools in Vivado and give the path of the local folder created as a workspace folder for Vitis (mentioned in step 2), click on launch Vitis IDE as shown in Figure 11 a new window will appear Figure 11:Launching Vitis 2020.1 - Once Vitis 2020.1 is opened then click on creates new application project and click on Create a new platform file →give the .xsa file path by browsing to that file where you had exported your xsa (project local folder)and click next ,give application project name and click next - In Available templates click on empty project and click on finish - Once the project is open, copy the source code from the release folder (\EMFEV\_Release1.0\_SD\_3.0\_Host\iW-EMFEV-PF-01-R1.0-REL1.0\iW-EMFEV-SF-01-R1.0-REL1.0\iW-EMFEY-SC-01-R1.0-REL1.0\iW\_EMFEV\_SD\_HOST\_vitis\_REL \_1.0\sd\_host\_test\src) to Vitis project src folder and then Save (CTRL+S) and Build(CTRL+B) the project - NOTE: Copy only iwsd\_hardware.h, iwsd\_host\_controller.h, iwsd\_host\_controller.c and main.c from the release folder to the src folder present under the application project. - Then right click on project go to run and click run configuration $\rightarrow$ system project debug - In the appeared window under target setup click on reset entire system and program FPGA as shown in the Figure 12 Figure 12: Target setup in run configuration. - Now click on Run - After clicking on Run, FPGA will be programmed and board is test ready. NOTE: Before clicking on Run please make sure Xilinx KC705 board is turned on with JTAG connections, 12V power supply and proper tera term setup. If program FPGA is done using Vivado 2020.1 please don't select program FPGA option in target setup Vitis 2020.1. ## 5 Test Procedure ## 5.1 Tera term setup - Open tera term in PC and select the com port other than COM1 (File→ New connection→Serial). - Select band rate as 115200 in setup $\rightarrow$ serial port $\rightarrow$ Speed. ## **5.2** Testing Procedure After set up follow the below procedure to test the SD Host controller IP. ## **5.2.1** Initial prints: Make the necessary connection to program the target FPGA board. Connect UART and JTAG along with FMC Card of SD Connector interface to target FPGA board as shown in the Figure 9 and do the Proper tera term setup. After clicking on Run in Run configuration, software will program the FPGA. Once the programming is done and .elf file is executed, then below print will be displayed in Tera term. Please wait for some time for the initial prints to be displayed. Figure 13:Initial print after FPGA is programmed As shown in the Figure 13 the application is waiting for the card to be Inserted , so insert the card and then the check that the D5 Red led on the FMC card is glowing which indicates that SD card is detected refer Figure 14, if that is glowing then the following prints will come as shown in Figure 15 Figure 14:Card Inserted to FMC ``` 👢 COM5:115200baud - Tera Term VT \times File Edit Setup Control Window Help Welcome To iWave Demo Of SD Host Controller 3.0 Card Removed!!! Waiting For Card To Be Inserted Card Inserted Driver version = 3 card_size in Gbytes = 30 GB SD initialization Successful! SCR_STRUCTURE = SCR_SD_SPEC SCR_DATA_STAT_AFTER_ERASE SCR_SECURITY SCR_SD_BUS_WIDTHS Card Supports 1 bit and 4 bit width Data Width Selected : 2 Card Supports SDR104 Mode Getting bus speed pass! Data transfer initiated at SDR104 Mode Tuning_reg0: 4886 Tuning_reg1: 4294959104 Initial Reading from card..... Total Block count is: 51200 Multi block Read during Initialization passed!!! Enter the following choice as needed and press enter: 1 -> Basic Write Operation. 2 -> Basic Read Operation. 3 -> Write and Read and compare internally and display the result as MATCHED or NOT Matched. ``` Figure 15:Card Initialization As shown in the Figure 15 test case is available i.e. - 1. Basic Write Operation - 2. Basic Read Operation - 3. Write and Read and compare internally and display the result as Matched or Not Matched 4. Any other test case than the mentioned above will result in wrong choice i.e." NOT Matched" as shown in Figure 16. ``` Enter the following choice as needed and press enter: 1 -> Basic Write Operation. 2 -> Basic Read Operation. 3 -> Write and Read and compare internally and display the result as MATCHED or NOT Matched. Entered Choice: 4 Select a valid option Enter the following choice as needed and press enter: 1 -> Basic Write Operation. 2 -> Basic Read Operation. 3 -> Write and Read and compare internally and display the result as MATCHED or NOT Matched. ``` Figure 16:Wrong choice #### **5.2.2** Basic Write Operation: - Basic write operation is the 1<sup>st</sup> testcase in the current design - After initial prints, press "1" and then enter the pattern enter "1" for **Incremental** pattern and enter "2" for **Toggling** pattern - Once pattern is selected then enter the block count with minimum value of "1" and maximum value of "1024" - Enter the block count and the enter the **Start address**, once the operation is completed successfully then user get the print "**Write Completed**" ``` Enter the following choice as needed and press enter: 1 -> Basic Write Operation. 2 -> Basic Read Operation. 3 -> Write and Read and compare internally and display the result as MATCHED or NOT Matched. Entered Choice: 1 Enter the pattern and press enter: 1 -> Incremental Pattern 2 -> Toggling Pattern Pattern Entered: 1 Enter the block count value between 1 and 1024 inclusive. Enter 1 for single block write. Enter value greater than 1 for multiple block write. Block Count Entered: 512 Address in decimal address Start Address Entered: 1000 Total Block count is: 262144 Write Completed Enter the following choice as needed and press enter: 1 -> Basic Write Operation. 2 -> Basic Read Operation. 3 -> Write and Read and compare internally and display the result as MATCHED or NOT Matched. ``` Figure 17:Basic Write Operation ### **5.2.3** Basic Read Operation: - After initial prints, press "2" for basic Read Operation and then enter the block count with minimum value of "1" and maximum value of "1024" - Enter the block count and the enter the **Start address** from where the read operation needs to be started, once the read operation is completed successfully then user get the print "**Read Completed**." ``` Enter the following choice as needed and press enter: 1 -> Basic Write Operation. 2 -> Basic Read Operation. 3 -> Write and Read and compare internally and display the result as MATCHED or NOT Matched. Entered Choice: 2 Enter the block count value between 1 and 1024 inclusive. Enter 1 for single block read. Enter value greater than 1 for multiple block read. Block Count Entered: 512 Enter the starting address (0 to 31293439). Address in decimal Start Address Entered: 1000 Total Block count is: 262144 Read Completed Enter the following choice as needed and press enter: 1 -> Basic Write Operation. 2 -> Basic Read Operation. 3 -> Write and Read and compare internally and display the result as MATCHED or NOT Matched. ``` Figure 18:Basic Read Operation #### 5.2.4 Write, Read and Compare operation: - The 3<sup>rd</sup> test case is Write and read back and compare and display whether it's a match or not match. - After initial prints, press "3" and then enter the pattern enter "1" for **Incremental** pattern and enter "2" for **Toggling** pattern. - Once pattern is selected then enter the block count where the minimum value is "1" and maximum value is "1024" enter the block count and then enter the Start address of the write and read operation to start. - Once the address is entered the Write to Card Operation will start and once the operation is completed successfully then user get the print "Write Completed," then Read from Card operation will start and print will be obtained same as in write operation. - Write and read data is "Matched or Not Matched" print will be observed in the Console. ``` Enter the following choice as needed and press enter: 1 -> Basic Write Operation. 2 -> Basic Read Operation. 3 -> Write and Read and compare internally and display the result as MATCHED or NOT Matched. Entered Choice: 3 Enter the pattern and press enter: 1 -> Incremental Pattern 2 -> Toggling Pattern Pattern Entered: 2 Enter the block count value between 1 and 1024 inclusive. Enter 1 for single block write. Enter value greater than 1 for multiple block write. Block Count Entered: 512 Enter the starting address (0 to 31293439). Address in decimal Start Address Entered: 1000 Writing to card. Total Block count is: 262144 Write Completed Reading from the card. Total Block count is: 262144 MATCHED Read Completed Enter the following choice as needed and press enter: 1 -> Basic Write Operation. 2 -> Basic Read Operation. 3 -> Write and Read and compare internally and display the result as MATCHED or NOT Matched. ``` Figure 19:Write & Read Back and Compare #### **NOTES:** - The current base clock is running at 200 MHz which is the maximum clock that can be used with KC705 dev kit. - Block count up to 1024 is supported. # 6 Design modification to be done for Custom Board - Update the FPGA part number/board according to the FPGA device used - Update the complete design for the selected FPGA device - Update the pin constraints for SD interface, clock, reset and UART pins - Update the clock constraint according to the input clock frequency for the selected FPGA device - Recompile the design to generate the new binaries and use the XSA file to create the new application project in Vitis # **7 Resource Utilization** The table below shows the resource utilization summary for KC705 dev. kit. for SD Host Controller IP. Table 2: Resource Utilization for device for KC705 dev. kit. | Resource | Utilization | Available | |----------|-------------|-----------| | LUT | 1564 | 203800 | | FF | 2154 | 407600 | | BRAM | 1 | 445 |