# AC450 Application Note Timing Optimization for AXI3 DDR Interfaces Using SmartFusion2 and IGLOO2





a MICROCHIP company

#### Microsemi Headquarters

One Enterprise, Aliso Viejo, CA 92656 USA Within the USA: +1 (800) 713-4113 Outside the USA: +1 (949) 380-6100 Sales: +1 (949) 380-6136 Fax: +1 (949) 215-4996

Email: sales.support@microsemi.com www.microsemi.com

©2021 Microsemi, a wholly owned subsidiary of Microchip Technology Inc. All rights reserved. Microsemi and the Microsemi logo are registered trademarks of Microsemi Corporation. All other trademarks and service marks are the property of their respective owners.

Microsemi makes no warranty, representation, or guarantee regarding the information contained herein or the suitability of its products and services for any particular purpose, nor does Microsemi assume any liability whatsoever arising out of the application or use of any product or circuit. The products sold hereunder and any other products sold by Microsemi have been subject to limited testing and should not be used in conjunction with mission-critical equipment or applications. Any performance specifications are believed to be reliable but are not verified, and Buyer must conduct and complete all performance and other testing of the products, alone and together with, or installed in, any end-products. Buyer shall not rely on any data and performance specifications or parameters provided by Microsemi. It is the Buyer's responsibility to independently determine suitability of any products and to test and verify the same. The information provided by Microsemi hereunder is provided "as is, where is" and with all faults, and the entire risk associated with such information is entirely with the Buyer. Microsemi does not grant, explicitly or implicitly, to any party any patent rights, licenses, or any other IP rights, whether with regard to such information itself or anything described by such information. Information provided in this document is proprietary to Microsemi, and Microsemi reserves the right to make any changes to the information in this document or to any products and services at any time without notice.

#### **About Microsemi**

Microsemi, a wholly owned subsidiary of Microchip Technology Inc. (Nasdaq: MCHP), offers a comprehensive portfolio of semiconductor and system solutions for aerospace & defense, communications, data center and industrial markets. Products include high-performance and radiation-hardened analog mixed-signal integrated circuits, FPGAs, SoCs and ASICs; power management products; timing and synchronization devices and precise time solutions, setting the world's standard for time; voice processing devices; RF solutions; discrete components; enterprise storage and communication solutions, security technologies and scalable anti-tamper products; Ethernet solutions; Power-over-Ethernet ICs and midspans; as well as custom design capabilities and services. Learn more at www.microsemi.com.



### **Contents**

| 1  | 1.1 Revision 2.0            |                                       | 1     |
|----|-----------------------------|---------------------------------------|-------|
| 2  | Purpose                     |                                       | 2     |
| 3  | Introduction                |                                       | 3     |
| 4  | References                  |                                       | 4     |
| 5  | 0 1                         |                                       |       |
| 6  | 6.1 2:1 Ratio               | echniques                             | 6<br> |
| 7  | IGLOO2 Reference Des        | sign Description                      | 15    |
| 8  | SmartFusion2 Reference      | ce Design Description                 | 17    |
| 9  | SmartFusion2 Hardwar        | re Implementation                     | 19    |
| 10 | 0 SmartFusion2 Software     | e Implementation                      | 22    |
| 11 | 11.1 Jumper Settings for IG | Design                                | 23    |
| 12 | 2 USB Driver Installation   |                                       | 27    |
| 13 | 3 Running the Design        |                                       | 29    |
| 14 | 4 Conclusion                |                                       | 30    |
| 15 | 5 Appendix 1: Programmi     | ing the Device Using FlashPro Express | 31    |
| 16 | 6 Appendix 2: Implementa    | ation of Timing Optimization Logic    | 34    |



### **Figures**

| MDDR Data Path for AXI/AHB Interfaces                                      | 3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|----------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| AXI Timing Optimization Logic for 2:1 Ratio                                | 6                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| AXI Timing Optimization Logic for 4:1 Ratio                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| Timing Diagram for 4:1 Ratio                                               | 13                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| IGLOO2 Top-Level Block Diagram                                             | 15                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| SmartFusion2 Top-Level Block Diagram                                       | 17                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| SmartFusion2 Top-Level SmartDesign for 2:1 Ratio                           | 19                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| SmartFusion2 Top-Level SmartDesign for 3:1 Ratio                           | 20                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| SmartFusion2 Top-Level SmartDesign for 4:1 Ratio                           | 21                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| IGLOO2 Evaluation Kit Board                                                | 23                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| SmartFusion2 Advanced Development Kit                                      | 25                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| USB to UART Bridge Drivers for SmartFusion2 Advanced Development Kit Board | 27                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| USB to UART Bridge Drivers for IGLOO2 Evaluation Kit Board                 | 28                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| FlashPro Express Job Project                                               | 3′                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| New Job Project from FlashPro Express Job                                  | 32                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| Programming the Device                                                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| FlashPro Express—RUN PASSED                                                | 33                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| RTL Logic for the 2:1 DDR to AXI Clock Ratio                               | 34                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| RTL Logic for the 4:1 DDR to AXI Clock Ratio                               | 35                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| RTL Logic for the 4:1 DDR to AXI Clock Ratio                               | 36                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|                                                                            | AXI Timing Diagram for 2:1 Ratio  AXI Timing Diagram for 2:1 Ratio  AXI Timing Optimization Logic for 3:1 Ratio  Timing Diagram for 3:1 Ratio  AXI Timing Optimization Logic for 4:1 Ratio  Timing Diagram for 4:1 Ratio  IGLOO2 Top-Level Block Diagram  SmartFusion2 Top-Level Block Diagram  SmartFusion2 Top-Level SmartDesign for 2:1 Ratio  SmartFusion2 Top-Level SmartDesign for 3:1 Ratio  SmartFusion2 Top-Level SmartDesign for 4:1 Ratio  IGLOO2 Evaluation Kit Board  SmartFusion2 Advanced Development Kit  USB to UART Bridge Drivers for SmartFusion2 Advanced Development Kit Board  USB to UART Bridge Drivers for IGLOO2 Evaluation Kit Board  FlashPro Express Job Project  New Job Project from FlashPro Express Job  Programming the Device  FlashPro Express—RUN PASSED  RTL Logic for the 2:1 DDR to AXI Clock Ratio  RTL Logic for the 4:1 DDR to AXI Clock Ratio |



### **Tables**

| Table 1 | Design Requirements                                   | 5    |
|---------|-------------------------------------------------------|------|
| Table 2 | HPMS Generated Clocks for 2:1, 3:1, and 4:1           |      |
| Table 3 | MSS CCC Generated Clocks                              | . 18 |
| Table 4 | IGLOO2 Evaluation Kit Jumper Settings                 | . 23 |
| Table 5 | SmartFusion2 Advanced Development Kit Jumper Settings | . 24 |



### 1 Revision History

The revision history describes the changes that were implemented in the document. The changes are listed by revision, starting with the most current publication.

#### 1.1 **Revision 2.0**

The following is a summary of the changes made in this revision.

- Updated the document for Libero SoC v2021.1.
- · Removed the references to Libero version numbers.

#### 1.2 **Revision 1.0**

The first publication of the document.



### 2 Purpose

This application note describes the optimization techniques used for meeting timing closure on SmartFusion®2 and IGLOO®2 designs that use non-1:1 Double Data Rate (DDR) to Advanced eXtensible Interface (AXI) clock ratios (2:1, 3:1, and 4:1). It provides reference designs for the SmartFusion2 Advanced Development Kit board and IGLOO2 Evaluation Kit board.



#### 3 Introduction

SmartFusion2 and IGLOO2 devices have two high-speed Application-Specific Integrated Circuit (ASIC) memory controllers, that is, microcontroller or memory subsystem (MSS) DDR (MDDR) and fabric DDR (FDDR). Microcontroller subsystem DDR present in SmartFusion2 devices, Memory Subsystem DDR in IGLOO2 devices, and FDDR in both SmartFusion2 and IGLOO2 devices are used for interfacing with external memories DDR2, DDR3, and Low Power DDR1 (LPDDR1) SDRAM memories. The MDDR and FDDR subsystems are used to access high-speed DDR memories for high-speed data transfer and code execution.

The DDR memory connected to the MDDR subsystem can be accessed by the MSS master in SmartFusion2 devices and by High-Performance Memory Subsystem (HPMS) master in IGLOO2 devices. Another way to access the DDR memory in both SmartFusion2 and IGLOO2 devices is by using any master logic implemented in the FPGA fabric master. The DDR memory connected to the FDDR subsystem can only be accessed by an FPGA fabric master.

FPGA fabric master communicates with the MDDR and FDDR subsystems through the AXI or Advanced High-performance Bus (AHB) interfaces. MDDR or FDDR subsystems operated in AXI mode provide the highest throughput interface to the external memory device.

When the MDDR or FDDR FIC64 interface is configured in AXI mode and is operating at a ratio of 2:1 or higher, depending on the design, timing violations may occur intermittently. For cases where design timing is not met, Microsemi recommends implementing optimization techniques explained in this application note to achieve timing closure. Timing closure optimization methods discussed in this application note apply only to the FDDR and MDDR FIC64 interfaces configured in AXI mode and running with a ratio of 2:1 or higher. They do not apply to DDR memory in AHB or AXI mode running with a 1:1 ratio.

Figure 1 shows the MDDR data path for AXI/AHB interfaces:

Figure 1 • MDDR Data Path for AXI/AHB Interfaces





### 4 References

For more information about the reference design for the SmartFusion2 Advanced Development Kit board and IGLOO2 Evaluation Kit board, refer to:

- DG0568: Interfacing SmartFusion2 SoC FPGA with External LPDDR Memory through MDDR Controller Demo Guide
- UG0446: SmartFusion2 and IGLOO2 FPGA High Speed DDR Interfaces User Guide
- DG0534: Interfacing IGLO02 FPGA with External LPDDR Memory through MDDR Controller
- AC424: IGLOO2 Optimizing DDR Controller for Improved Efficiency Application Note
- AC409: Connecting User Logic to AXI Interfaces of High-Performance Communication Blocks in the SmartFusion2 Devices
- UG0557: SmartFusion2 SoC FPGA Advanced Development Kit User Guide



### 5 Design Requirements

The following table lists the hardware and software required for this application:

Table 1 • Design Requirements

| Requirement                                                                                                            | Version                                                                          |  |  |
|------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------|--|--|
| Operating System                                                                                                       | 64 bit Windows 7 and 10                                                          |  |  |
| Hardware                                                                                                               |                                                                                  |  |  |
| SmartFusion2 Advanced Development Kit or IGLOO2 Evaluation Kit FlashPro4 programmer 12 V adapter USB A to mini-B cable | <ul> <li>SmartFusion2: Rev B or later</li> <li>IGLOO2: Rev C or later</li> </ul> |  |  |
| Host PC or laptop                                                                                                      |                                                                                  |  |  |
| Software                                                                                                               |                                                                                  |  |  |
| FlashPro Express                                                                                                       | Note: Refer to the readme.txt file provided in the                               |  |  |
| Libero® System-on-Chip (SoC)                                                                                           | design files for the software versions used with this reference design.          |  |  |
| SoftConsole                                                                                                            |                                                                                  |  |  |
| Host PC drivers                                                                                                        | USB to UART drivers                                                              |  |  |

**Note:** Libero SmartDesign and configuration screen shots shown in this guide are for illustration purpose only. Open the Libero design to see the latest updates.

#### 5.1 Prerequisites

Before you begin:

 Download and install Libero SoC (as indicated in the website for this design) on the host PC from the following location.

https://www.microsemi.com/product-directory/design-resources/1750-libero-soc

2. For demo design files download link:

http://soc.microsemi.com/download/rsc/?f=m2s\_m2gl\_ac450\_df



### 6 Timing Optimization Techniques

This section describes timing optimization techniques for the following DDR to AXI clock ratios:

- 2:1 Ratio
- 3:1 Ratio
- 4:1 Ratio

#### 6.1 2:1 Ratio

When the AXI mode is used with the MDDR or FDDR subsystem operating at 2:1 DDR to AXI clock ratio, timing closure can be achieved by inserting a flip-flop on the AWVALID, ARVALID, and WVALID signal paths. A two-input AND gate with inputs from the fabric AXI master VALID signals and the FDDR/MDDR READY signals are fed to the flip-flop. This technique uses a negative edge-triggered flip-flop clocked using the AXI clock (DDR\_FIC\_SUBSYSTEM\_CLK) on the VALID signal paths.

The optimization method can reside between an existing AXI master and the DDR fabric interface control (DDR\_FIC) AXI slave interface, and no changes are required to the AXI master design. As the AXI VALID signals are delayed by half AXI clock cycle, AXI data lines going into the DDR\_FIC get an additional half AXI clock cycle time to become stable before the active edge of the latching clock.

Figure 2 shows the block diagram of the optimization technique for the 2:1 DDR to AXI clock ratio.

Figure 2 • AXI Timing Optimization Logic for 2:1 Ratio





Figure 3 shows the AXI transaction timing diagram with the optimization logic for the 2:1 ratio. The AXI data signals must meet two DDR clock or one AXI clock cycle setup time.

Figure 3 • Timing Diagram for 2:1 Ratio



When implementing the 2:1 ratio timing optimization technique, the following SDC constraints need to be added to the timing constraint file (.sdc), which is provided as part of the design files. For more information, refer to Prerequisites, page 5.

#### For FDDR

# The following constraints provide a relaxation constraint on the signals of 1.5 AXI clock period. The users must adjust the ddr clock frequency to match their application.

#Apply new max delay for 2:1 clock ratio (new valid paths need to meet one DDR clock cycle setup time and other paths need to meet one AXI clock setup time)

```
# DDR_AXI FF setup time (Libero SoC v(x.x)) = DDR_AXI FF setup time (Libero SoC v(x.x)) + (n - 1) * DDR clock period == DDR_AXI FF setup time (Libero SoC v(x.x)) + 1* DDR clock period set ddr_clock_frequency 333
```

set delay1 [expr 3000/\$ddr\_clock\_frequency]

set delay2 [expr 2000/\$ddr clock frequency]

set max delay \$delay1 -to [get pins {\

\*/INST\_FDDR\_IP:F\_ARADDR\* \*/INST\_FDDR\_IP:F\_ARBURST\* \*/INST\_FDDR\_IP:F\_ARID\* \*/INST\_FDDR\_IP:F\_ARLEN\*\

\*/INST\_FDDR\_IP:F\_ARLOCK\* \*/INST\_FDDR\_IP:F\_ARSIZE\* \*/INST\_FDDR\_IP:F\_AWADDR\* \*/INST\_FDDR\_IP:F\_AWBURST\* \

\*/INST\_FDDR\_IP:F\_AWID\* \*/INST\_FDDR\_IP:F\_AWLEN\* \*/INST\_FDDR\_IP:F\_AWLOCK\* \*/INST\_FDDR\_IP:F\_AWSIZE\* \

\*/INST\_FDDR\_IP:F\_WDATA\* \*/INST\_FDDR\_IP:F\_WID\* \*/INST\_FDDR\_IP:F\_WLAST \*/INST\_FDDR\_IP:F\_WSTRB\* \



```
*/INST_FDDR_IP:F_BREADY */INST_FDDR_IP:F_RMW_AXI */INST_FDDR_IP:F_RREADY\
}]
/* The following constraints provide a relaxation constraint on the signals of 1 AXI clock period. */
set_max_delay $delay2 -to [get_pins {\
*/INST FDDR IP:F ARVALID* \
*/INST_FDDR_IP:F_AWVALID* \
*/INST_FDDR_IP:F_WVALID \
}]
For MDDR
# The following constraints provide a relaxation constraint on the signals of 1.5 AXI clock periods. The
users must adjust the ddr clock frequency to match their application.
#Apply new max delay for 2:1 clock ratio (new valid paths need to meet one DDR clock cycle setup time,
and other paths need to meet one AXI clock setup time)
# DDR AXI FF setup time (Libero SoC v(x.x)) = DDR AXI FF setup time (Libero SoC v(x.x)) + (n - 1) *
DDR clock period == DDR AXI FF setup time (Libero SoC v(x.x)) + 1* DDR clock period
set ddr_clock_frequency 333
set delay1 [expr 3000/$ddr clock frequency]
set delay2 [expr 2000/$ddr clock frequency]
set_max_delay $delay1 -to [get_pins {\
*/INST_MSS * IP:F_ARADDR* */INST_MSS_*_IP:F_ARBURST* */INST_MSS_*_IP:F_ARID*
*/INST_MSS_*_IP:F_ARLEN*\
*/INST_MSS_*_IP:F_ARLOCK* */INST_MSS_*_IP:F_ARSIZE* */INST_MSS_*_IP:F_AWADDR*
*/INST MSS * IP:F AWBURST* \
*/INST MSS * IP:F AWID* */INST MSS * IP:F AWLEN* */INST MSS * IP:F AWLOCK*
*/INST MSS * IP:F AWSIZE* \
*/INST MSS * IP:F WDATA* */INST MSS * IP:F WID* */INST MSS * IP:F WLAST
*/INST MSS * IP:F WSTRB* \
*/INST_MSS_*_IP:F_BREADY */INST_MSS_*_IP:F_RMW_AXI */INST_MSS_*_IP:F_RREADY\
}]
/* The following constraints provide a relaxation constraint on the signals of 1 AXI clock period. */
set_max_delay $delay2 -to [get_pins {\
*/INST_MSS_*_IP:F_ARVALID* \
```

\*/INST\_MSS\_\*\_IP:F\_AWVALID\*\
\*/INST\_MSS\_\*\_IP:F\_WVALID\

}]



#### 6.2 3:1 Ratio

When the AXI mode is used with the MDDR or FDDR subsystem operating at 3:1 DDR to AXI clock ratio, timing closure can be achieved by inserting two flip-flops on the AWVALID, ARVALID, and WVALID signal paths. A two-input AND gate with inputs from the fabric AXI master VALID signals and the FDDR/MDDR READY signals are fed to the two-stage pipeline flip-flops.

If the design uses a DDR to AXI clock ratio greater than 2:1, increasing the pipeline stages helps increase the timing margin without changing the clock frequency. For the 3:1 DDR to AXI clock ratio, two positive edge-triggered flip-flops are used in the pipeline. These flip-flops are clocked using the DDR clock (DDR\_FIC\_SUBSYSTEM\_CLK\*3) on the VALID signal paths. The DDR clock is derived using user PLL (Fabric CCC), as shown in Figure 4, page 9.

The optimization method can reside between an existing AXI master and the DDR\_FIC AXI slave interface, and no changes are required to the AXI master design. As the AXI VALID signals are delayed by two DDR clock cycles, AXI data lines going into the DDR\_FIC get an additional two DDR clock cycle periods to become stable before the active edge of the latching clock.

Figure 4 shows the block diagram of the technique for 3:1 clock ratio.

Figure 4 • AXI Timing Optimization Logic for 3:1 Ratio





Figure 5 shows the AXI transaction timing diagram with the optimization logic for a 3:1 ratio. The AXI data signals must meet three DDR clock or one AXI clock cycle setup time.

Figure 5 • Timing Diagram for 3:1 Ratio



When implementing the 3:1 ratio timing optimization technique, the following SDC constraints need to be added to the timing constraint file (.sdc), which is provided as part of the design files. For more information about design files, refer to Prerequisites, page 5.

#### For FDDR

# The users must adjust the ddr clock frequency to match their application.

set ddr\_clock\_frequency 333

# Apply new max delay for a 3:1 clock ratio (new valid paths need to meet one DDR clock cycle setup time and other paths need to meet one AXI clock setup time)

# DDR\_AXI FF setup time (Libero SoC v(x.x)) = DDR\_AXI FF setup time (Libero SoC v(x.x)) + (n - 1) \* DDR clock period == DDR\_AXI FF setup time (Libero SoC v(x.x)) + 2\* DDR clock period

set delay1 [expr 5000/\$ddr\_clock\_frequency]

set delay2 [expr 3000/\$ddr\_clock\_frequency]

set\_max\_delay \$delay1 -to [get\_pins {\

\*/INST\_FDDR\_IP:F\_ARADDR\* \*/INST\_FDDR\_IP:F\_ARBURST\* \*/INST\_FDDR\_IP:F\_ARID\* \*/INST\_FDDR\_IP:F\_ARLEN\*\

\*/INST\_FDDR\_IP:F\_ARLOCK\* \*/INST\_FDDR\_IP:F\_ARSIZE\* \*/INST\_FDDR\_IP:F\_AWADDR\* \*/INST\_FDDR\_IP:F\_AWBURST\* \

\*/INST\_FDDR\_IP:F\_AWID\* \*/INST\_FDDR\_IP:F\_AWLEN\* \*/INST\_FDDR\_IP:F\_AWLOCK\* \*/INST\_FDDR\_IP:F\_AWSIZE\* \



```
*/INST_FDDR_IP:F_WDATA* */INST_FDDR_IP:F_WID* */INST_FDDR_IP:F_WLAST
*/INST FDDR IP:F WSTRB* \
*/INST FDDR IP:F BREADY */INST FDDR IP:F RMW AXI */INST FDDR IP:F RREADY \
set max delay $delay2 -to [get pins {\
*/INST FDDR IP:F ARVALID* \
*/INST_FDDR_IP:F_AWVALID* \
*/INST FDDR IP:F WVALID \
}]
For MDDR
# The users must adjust the ddr clock frequency to match their application.
set ddr clock frequency 333
# Apply new max delay for a 3:1 clock ratio (new valid paths need to meet one DDR clock cycle setup
time and other paths need to meet 1 AXI clock cycle setup time)
# DDR AXI FF setup time (Libero SoC v(x.x)) = DDR AXI FF setup time (Libero SoC v(x.x)) + (n - 1) *
DDR clock period == DDR AXI FF setup time (Libero SoC v(x.x)) + 2* DDR clock period
set delay1 [expr 5000/$ddr clock frequency]
set delay2 [expr 3000/$ddr clock frequency]
set_max_delay $delay1 -to [get_pins {\
*/INST_MSS_*_IP:F_ARADDR* */INST_MSS_*_IP:F_ARBURST* */INST_MSS_*_IP:F_ARID*
*/INST_MSS_*_IP:F_ARLEN*\
*/INST_MSS_*_IP:F_ARLOCK* */INST_MSS_*_IP:F_ARSIZE* */INST_MSS_*_IP:F_AWADDR*
*/INST MSS * IP:F AWBURST* \
*/INST MSS * IP:F AWID* */INST MSS * IP:F AWLEN* */INST MSS * IP:F AWLOCK*
*/INST MSS * IP:F AWSIZE* \
*/INST MSS * IP:F WDATA* */INST MSS * IP:F WID* */INST MSS * IP:F WLAST
*/INST MSS * IP:F WSTRB* \
*/INST_MSS_*_IP:F_BREADY */INST_MSS_*_IP:F_RMW_AXI */INST_MSS_*_IP:F_RREADY \
}]
set_max_delay $delay2 -to [get_pins {\
*/INST_MSS_*_IP:F_ARVALID* \
*/INST_MSS_*_IP:F_AWVALID* \
*/INST_MSS_*_IP:F_WVALID \
}]
```



#### 6.3 4:1 Ratio

When the AXI mode is used with MDDR or FDDR subsystem operating at 4:1 DDR to AXI clock ratio, timing closure can be achieved by inserting three flip-flops on the AWVALID, ARVALID, and WVALID signal paths. A two-input AND gate with inputs from the fabric AXI master VALID signals and the FDDR/MDDR READY signals are fed to the three-stage pipeline flip-flops.

If the design uses DDR to AXI clock ratio greater than 2:1, increasing the pipeline stages helps to increase the timing margin without changing the clock frequency. For the 4:1 DDR to AXI clock ratio, three positive edges triggered flip-flops are used in the pipeline. These flip-flops are clocked using the DDR clock (DDR\_FIC\_SUBSYSTEM\_CLK\*4) on the VALID signal paths. DDR clock is derived using user PLL (Fabric CCC), as shown in Figure 6, page 12.

The optimization method can reside between an existing AXI master and the DDR\_FIC AXI slave interface, and no changes are required to the AXI master design. As the AXI VALID signals are delayed by three DDR clock cycles, AXI data lines going into the DDR\_FIC get an additional three DDR clock cycle time to become stable before the active edge of the latching clock.

Figure 6 shows the block diagram of the optimization technique for the 4:1 clock ratio.

Figure 6 • AXI Timing Optimization Logic for 4:1 Ratio





Figure 7 shows the AXI transaction timing diagram with optimization logic for the 4:1 ratio. The AXI data signal must meet four DDR clock or one AXI clock cycle setup time.

Figure 7 • Timing Diagram for 4:1 Ratio



Data transfer on xVALID/xREADY handshake

When implementing a 4:1 ratio timing optimization technique, the following SDC constraints need to be added to the timing constraint file (.sdc), which is provided as part of the design files. For more information about design files, refer to Prerequisites, page 5.

#### For FDDR

# The users must adjust the ddr\_clock\_frequency to match their application.

set ddr\_clock\_frequency 320

# Apply new max delay for a 4:1 clock ratio (new valid paths need to meet one DDR clock cycle setup time and other paths need to meet one AXI clock cycle setup time)

# DDR\_AXI FF setup time (Libero SoC v(x.x)) = DDR\_AXI FF setup time (Libero SoC v(x.x)) + (n - 1) \* DDR clock period == DDR\_AXI FF setup time (Libero SoC v(x.x)) +3\* DDR clock period

set delay1 [expr 7000/\$ddr\_clock\_frequency]

set delay2 [expr 4000/\$ddr\_clock\_frequency]

set\_max\_delay \$delay1 -to [get\_pins {\

\*/INST\_FDDR\_IP:F\_ARADDR\* \*/INST\_FDDR\_IP:F\_ARBURST\* \*/INST\_FDDR\_IP:F\_ARID\* \*/INST\_FDDR\_IP:F\_ARLEN\*\

\*/INST\_FDDR\_IP:F\_ARLOCK\* \*/INST\_FDDR\_IP:F\_ARSIZE\* \*/INST\_FDDR\_IP:F\_AWADDR\* \*/INST\_FDDR\_IP:F\_AWBURST\* \

\*/INST\_FDDR\_IP:F\_AWID\* \*/INST\_FDDR\_IP:F\_AWLEN\* \*/INST\_FDDR\_IP:F\_AWLOCK\* \*/INST\_FDDR\_IP:F\_AWSIZE\* \



```
*/INST_FDDR_IP:F_WDATA* */INST_FDDR_IP:F_WID* */INST_FDDR_IP:F_WLAST
*/INST FDDR IP:F WSTRB* \
*/INST FDDR IP:F BREADY */INST FDDR IP:F RMW AXI */INST FDDR IP:F RREADY \
set max delay $delay2 -to [get pins {\
*/INST FDDR IP:F ARVALID* \
*/INST_FDDR_IP:F_AWVALID* \
*/INST FDDR IP:F WVALID \
}]
For MDDR
# The users must adjust the ddr clock frequency to match their application.
set ddr clock frequency 320
# Apply new max delay for a 4:1 clock ratio (new valid paths need to meet one DDR clock cycle setup
time and other paths need to meet one AXI clock cycle setup time)
# DDR AXI FF setup time (Libero SoC v(x.x)) = DDR AXI FF setup time (Libero SoC v(x.x)) + (n - 1) *
DDR clock period == DDR AXI FF setup time (Libero SoC v(x,x)) +3* DDR clock period
set delay1 [expr 7000/$ddr clock frequency]
set delay2 [expr 4000/$ddr clock frequency]
set_max_delay $delay1 -to [get_pins {\
*/INST_MSS_*_IP:F_ARADDR* */INST_MSS_*_IP:F_ARBURST* */INST_MSS_*_IP:F_ARID*
*/INST_MSS_*_IP:F_ARLEN*\
*/INST_MSS_*_IP:F_ARLOCK* */INST_MSS_*_IP:F_ARSIZE* */INST_MSS_*_IP:F_AWADDR*
*/INST MSS * IP:F AWBURST* \
*/INST MSS * IP:F AWID* */INST MSS * IP:F AWLEN* */INST MSS * IP:F AWLOCK*
*/INST MSS * IP:F AWSIZE* \
*/INST MSS * IP:F WDATA* */INST MSS * IP:F WID* */INST MSS * IP:F WLAST
*/INST MSS * IP:F WSTRB* \
*/INST_MSS_*_IP:F_BREADY */INST_MSS_*_IP:F_RMW_AXI */INST_MSS_*_IP:F_RREADY \
}]
set_max_delay $delay2 -to [get_pins { \
*/INST_MSS_*_IP:F_ARVALID* \
*/INST_MSS_*_IP:F_AWVALID* \
*/INST_MSS_*_IP:F_WVALID \
}]
```



### 7 IGLOO2 Reference Design Description

The reference design consists of the MDDR controller, which is configured to access the LPDDR memory available in the IGLOO2 Evaluation Kit board. DDR\_FIC is configured for the AXI bus interface. It also uses a TPSRAM IP. Figure 8 shows the top-level view of the design. The highlighted block contains the timing optimization logic based on the DDR to the AXI clock ratio used in the design (2:1, 3:1, and 4:1). Separate design files are provided for each DDR to the AXI ratio. For more information about design files, refer to Prerequisites, page 5.

Figure 8 • IGLOO2 Top-Level Block Diagram





Table 2 lists the HPMS generated clocks for 2:1, 3:1, and 4:1 DDR to AXI CLK ratio designs.

Table 2 • HPMS Generated Clocks for 2:1, 3:1, and 4:1

| 2:1 Ratio       |                  |  |  |
|-----------------|------------------|--|--|
| Clock Name      | Frequency in MHz |  |  |
| HPMS_CLK        | 83               |  |  |
| MDDR_CLK        | 166              |  |  |
| DDR_SMC_FIC_CLK | 83               |  |  |
| FIC_0_CLK       | 20.75            |  |  |
| 3:1 Ratio       |                  |  |  |
| Clock Name      | Frequency in MHz |  |  |
| HPMS_CLK        | 55.3             |  |  |
| MDDR_CLK        | 166              |  |  |
| DDR_SMC_FIC_CLK | 55.3             |  |  |
| FIC_0_CLK       | 13.825           |  |  |
| 4:1 Ratio       |                  |  |  |
| Clock Name      | Frequency in MHz |  |  |
| HPMS_CLK        | 41.5             |  |  |
| MDDR_CLK        | 166              |  |  |
| DDR_SMC_FIC_CLK | 41.5             |  |  |
| FIC_0_CLK       | 10.375           |  |  |
|                 |                  |  |  |

In this reference design, the AXI master implemented in the FPGA fabric accesses the LPDDR memory present in the IGLOO2 Evaluation Kit board using the MDDR controller. The AXI master logic communicates to the MDDR controller through the CoreAXI interface and the DDR\_FIC interface. The read/write operations initiated by the IGL2\_MDDR\_Demo utility are sent to the UART\_IF block using the UART protocol. AXI master receives the address and data from the UART\_IF block.

During a write operation, the UART\_IF block sends the address and data to the AXI master logic. During a read operation, the UART\_IF block sends the address to AXI master and stores the read data in TPSRAM. When the read operation is complete, the read data is sent to the host PC through UART.

Note: IGLOO2 hardware implementation is similar to SmartFusion2.

For more information about the IGLOO2 reference design for 2:1, 3:1, and 4:1 DDR to AXI clock ratio, and how to run the design on the IGLOO2 Evaluation kit, refer to Prerequisites, page 5 and DG0534: Interfacing IGLOO2 FPGA with External LPDDR Memory through MDDR Controller.



### 8 SmartFusion2 Reference Design Description

The design consists of the MDDR controller, which is configured to access the DDR3 memory available in the SmartFusion2 Advanced Development Kit board. DDR fabric interface controller (DDR\_FIC) is configured for the AXI bus interface. It also uses a two-port static random-access memory (TPSRAM) IP. Figure 9 shows the top-level view of the design. The highlighted block contains the timing optimization logic based on the DDR to the AXI clock ratio used in the design, that is, 2:1, 3:1, and 4:1 ratio. Separate design files are provided for each DDR to the AXI ratio. For more information about design files, refer to Prerequisites, page 5.

Figure 9 • SmartFusion2 Top-Level Block Diagram





Table 3 lists the MSS CCC generated clocks for 2:1, 3:1, and 4:1 DDR to AXI CLK ratio designs.

Table 3 • MSS\_CCC Generated Clocks

| 2:1 Ratio       |                  |
|-----------------|------------------|
| Clock Name      | Frequency in MHz |
| M3_CLK          | 166              |
| MDDR_CLK        | 332              |
| DDR_SMC_FIC_CLK | 166              |
| APB_0           | 166              |
| APB_1           | 166              |
| FIC_0_CLK       | 83               |
| 3:1 Ratio       |                  |
| Clock Name      | Frequency in MHz |
| M3_CLK          | 111              |
| MDDR_CLK        | 333              |
| DDR_SMC_FIC_CLK | 111              |
| APB_0           | 111              |
| APB_1           | 111              |
| FIC_0_CLK       | 111              |
| 4:1 Ratio       |                  |
| Clock Name      | Frequency in MHz |
| M3_CLK          | 80               |
| MDDR_CLK        | 320              |
| DDR_SMC_FIC_CLK | 80               |
| APB_0           | 80               |
| APB_1           | 80               |
| FIC_0_CLK       | 80               |
|                 |                  |

The reference design provided in this application note consists of an AXI master implemented in the FPGA fabric, which accesses the DDR3 memory present in the SmartFusion2 Advanced Development Kit board using the MDDR controller. The AXI master logic communicates to the MDDR controller through the AXI interface and the DDR\_FIC interface. The optimization method can reside between an existing AXI master and the DDR\_FIC AXI slave interface, and no changes are required to the AXI master design. If there are multiple masters, the user can add arbiter logic and use the same optimization method.

The FIC\_0 interface is configured to use a slave interface with the AHB-Lite (AHBL) interface. The FIC\_2 interface is configured to initialize the MSS DDR using the ARM Cortex-M3 processor along with the CoreConfigP macro. MMUART\_0 is used as an interface for communicating with the host PC. MDDR is configured to use the DDR3 interface and routes the AXI interface to the FPGA fabric.

The read/write operations initiated by the SF2\_MDDR\_Demo utility are sent to the UART\_IF block using the Universal Asynchronous Receiver/Transmitter (UART) protocol. AXI master receives the address and the data from the UART\_IF block. During a write operation, the UART\_IF block sends the address and data to the AXI master logic. During a read operation, it sends the address to the AXI master and stores the read data in TPSRAM. When the read operation is complete, the read data is sent to the host PC through UART.



### 9 SmartFusion2 Hardware Implementation

This section describes how the timing optimization logic is added to the reference design for the SmartFusion2 Advanced Development Kit board.

Figure 10 shows the top-level SmartDesign of the reference design for the 2:1 DDR to the AXI clock ratio. The highlighted block is a Register-Transfer Level (RTL) logic, which implements the AXI interconnect logic to connect an AXI master and a slave and the timing optimization logic for a 2:1 ratio, as discussed in the Timing Optimization Techniques, page 6.

Figure 10 • SmartFusion2 Top-Level SmartDesign for 2:1 Ratio





Figure 11 shows the top-level SmartDesign of the reference design for 3:1 DDR to the AXI clock ratio. The highlighted block is an RTL logic, which implements the AXI interconnect logic to connect an AXI master and a slave and the timing optimization logic for a 3:1 ratio as discussed in the Timing Optimization Techniques, page 6.

Figure 11 • SmartFusion2 Top-Level SmartDesign for 3:1 Ratio





Figure 12 shows the top-level SmartDesign of the reference design for 4:1 DDR to the AXI clock ratio. The highlighted block is an RTL logic, which implements the AXI interconnect logic to connect an AXI master and a slave and the timing optimization logic for a 4:1 ratio as discussed in the Timing Optimization Techniques, page 6.

Figure 12 • SmartFusion2 Top-Level SmartDesign for 4:1 Ratio



For more information about other SmartDesign blocks, how to configure system builder, MDDR/FDDR subsystem, and DDR3 memory, refer the following documents:

- DG0534: Interfacing IGLOO2 FPGA with External LPDDR Memory through MDDR Controller Demo Guide
- UG0446: SmartFusion2 and IGLOO2 FPGA High Speed DDR Interfaces User Guide

**Note:** The simulation model of timing optimization for AXI3 DDR interfaces using Smartfusion2 and IGLOO2 is not supported in the current software release.



### 10 SmartFusion2 Software Implementation

The software design reference performs the following operations:

- Setting the DDR3 SDRAM base address to 0xA0000000 and the FIC0 region base address to 0x30000000
- Initializing and configuring MMUART\_0 to have a 115200 baud rate, 8 data bits, 1 stop bit, no parity, and no flow control
- · Reading user-selected options from the GUI utility
- · Reading 32-bit address and 64-bit data value from GUI utility, if user option is single or burst write
- · Reading 32-bit address value, if user option is single or burst read
- Storing user option, data, and address value into the FIC0 registers, which are used to initiate AXI
  write or read transactions
- If the user option is single or burst write, address and data from UART\_IF block are sent to AXI
  master
- If the user option is single or burst read, address value from UART\_IF block is sent to AXI master, and the read data is read from TPSRAM

List of firmware drivers used in this application:

- SmartFusion2 MSS NVM driver Provides access to SmartFusion2 eNVM
- SmartFusion2 MSS HPDMA driver
- SmartFusion2 MSS UART driver To communicate with the serial terminal program running on the host PC



### 11 Setting Up the Demo Design

The following sections describe how to set up the demo design.

### 11.1 Jumper Settings for IGLOO2

The following table lists the jumpers that need to be connected on the IGLOO2 Evaluation Kit board:

Table 4 • IGLOO2 Evaluation Kit Jumper Settings

| Jumper | Pin (From) | Pint (To) | Comments |
|--------|------------|-----------|----------|
| J22    | 1          | 2         | Default  |
| J23    | 1          | 2         | Default  |
| J24    | 1          | 2         | Default  |
| J8     | 1          | 2         | Default  |
| J3     | 1          | 2         | Default  |

**Note:** Switch OFF the power switch(SW7), while connecting the jumpers.

- 1. Connect the power supply to the J6 connector.
- 2. Switch ON the power supply switch (SW7).

Figure 13 shows the board setup on the IGLOO2 Evaluation Kit board.

Figure 13 • IGLOO2 Evaluation Kit Board





### 11.2 Jumper Settings for SmartFusion2

The following table lists the jumpers that need to be connected on the SmartFusion2 Advanced Development Kit board:

Table 5 • SmartFusion2 Advanced Development Kit Jumper Settings

| Jumper                | Pin (From) | Pint (To) | Comments                                                                                               |
|-----------------------|------------|-----------|--------------------------------------------------------------------------------------------------------|
| J116, J353, J354, J54 | 1          | 2         | These are the default jumper settings of the                                                           |
| J123                  | 2          | 3         | <ul> <li>Advanced Development Kit board. Ensure that<br/>these jumpers are set accordingly.</li> </ul> |
| J124, J121, J32       | 1          | 2         | JTAG programing through FTDI                                                                           |

Note: Switch OFF the power switch (SW7), while connecting the jumpers.

- 1. Connect the power supply to the J42 connector.
- Connect the J33 connector on the SmartFusion2 Advanced Development Kit board to the host PC using the USB mini-B (FTDI interface) cable.



Figure 14 shows the board setup on the SmartFusion2 Advanced Development Kit board.

Figure 14 • SmartFusion2 Advanced Development Kit





#### 12 USB Driver Installation

The FTDI D2XX driver for serial terminal communication can be installed through the FTDI mini USB cable. The drivers and the installation guide can be downloaded from

www.microsemi.com/soc/documents/CDM\_2.08.24\_WHQL\_Certified.zip.

Check the Device Manager to verify that the USB to UART bridge drivers are detected, as shown in Figure 15, page 27 and Figure 16, page 28.

For the SmartFusion2 Advanced Development Kit board, ensure that the COM port location is specified as **on USB Serial Converter C**, as shown in Figure 15.

Figure 15 • USB to UART Bridge Drivers for SmartFusion2 Advanced Development Kit Board





For the IGLOO2 Evaluation Kit board, ensure that the COM port location is specified as **on USB Serial Converter D**, as shown in Figure 16.

Figure 16 • USB to UART Bridge Drivers for IGLOO2 Evaluation Kit Board



For using USB 3.0, refer the "Appendix B: Finding Correct COM port number when using the USB 3.0" section of the DG0568: Interfacing SmartFusion2 SoC FPGA with External LPDDR Memory through MDDR Controller Demo Guide.



### 13 Running the Design

- Connect the power supply to the J42 connector for the SmartFusion2 Advanced Development Kit board or the J6 connector for the IGLOO2 Evaluation Kit board.
- 2. Connect the FlashPro4 programmer to the FP4 HEADER J37 connector for the SmartFusion2 Advanced Development Kit board or J5 connector for the IGLOO2 Evaluation Kit board.
- 3. Switch ON the power supply switch (SW7).
- 4. Program the SmartFusion2 Advanced Development Kit or IGLOO2 Evaluation Kit board with the job file provided as part of the design files using FlashPro Express software, refer to Appendix 1: Programming the Device Using FlashPro Express, page 31.

For detailed instructions to run the design, refer 'Running the Hardware Demo' section of the following document:

DG0534: Interfacing IGLOO2 FPGA with External LPDDR Memory through MDDR Controller for running the design on the IGLOO2 Evaluation Kit board.



### 14 Conclusion

This application note describes the recommended optimization techniques for meeting timing closure on the SmartFusion2 and IGLOO2 designs that use non 1:1 DDR to AXI clock ratios, that is, 2:1, 3:1, and 4:1 ratios.d



# 15 Appendix 1: Programming the Device Using FlashPro Express

This section describes how to program the SmartFusion2 and IGLOO2 devices with the programming job file using FlashPro Express.

To program the device, perform the following steps:

1. Ensure that the jumper settings on the board are the same as those listed in Table 4, page 23 for IGLOO2 device and Table 5, page 24 for SmartFusion2 device.

Note: The power supply switch must be switched off while making the jumper connections.

- Connect the power supply cable to the J42 connector for the SmartFusion2 device and the J6 connector for the IGL002 device on the board.
- 3. Power **ON** the power supply switch **SW7**.
- 4. On the host PC, launch the FlashPro Express software.
- Click New or select New Job Project from FlashPro Express Job from Project menu to create a new job project, as shown in Figure 17.

Figure 17 • FlashPro Express Job Project





6. Enter the following in the **New Job Project from FlashPro Express Job** dialog box:

or

- **Programming job file:** Click **Browse**, and navigate to the location where the .job file is located and select the file. The default location is:
  - $< download\_folder > m2s\_m2g1\_ac450\_df \setminus IGLOO2 \setminus 2to1\_DDRtoAXI\_clk\_ratio \setminus Programming\ file ,\ similarly\ browse\ IGLOO2 \setminus 3to1\_DDRtoAXI\_clk\_ratio \setminus Programming\ file\ and\ 4to1\_DDRtoAXI\_clk\_ratio \setminus Programming\ file\ and\ select\ them.$
- <download\_folder>m2s\_m2gl\_ac450\_df\SmartFusion2\2to1\_DDRtoAXI\_clk\_ratio\Programming file, similarly browse SmartFusion2\
  3to1\_DDRtoAXI\_clk\_ratio\Programming file and 4to1\_DDRtoAXI\_clk\_ratio\Programming file and select them.
- FlashPro Express job project name: Click Browse and navigate to the location where you want to save the project.



Figure 18 • New Job Project from FlashPro Express Job



- 7. Click **OK**. The required programming file is selected and ready to be programmed in the device.
- 8. The FlashPro Express window appears as shown in Figure 19. Confirm that a programmer number appears in the Programmer field. If it does not, confirm the board connections and click **Refresh/Rescan** Programmers.

Figure 19 • Programming the Device



9. Click **RUN**. When the device is programmed successfully, a **RUN PASSED** status is displayed as shown in Figure 20.



Figure 20 • FlashPro Express—RUN PASSED



10. Close FlashPro Express or in the Project tab, click Exit.



## 16 Appendix 2: Implementation of Timing Optimization Logic

This appendix provides information on the RTL logic to be added to the AXI interconnect block when implementing the timing optimization logic for 2:1, 3:1, and 4:1 DDR: AXI clock ratio-based designs. The registers highlighted in red are the new VALID signals sent to the AXI slave interface.

Add the following RTL logic for the 2:1 DDR to AXI clock ratio designs in the AXI interconnect block.

Figure 21 • RTL Logic for the 2:1 DDR to AXI Clock Ratio



Add the following RTL logic for the 3:1 DDR to AXI clock ratio designs in the AXI interconnect block.

#### Figure 22 • RTL Logic for the 4:1 DDR to AXI Clock Ratio

```
/*************3:1 DDR:AXI clock ratio timing optimization technique ************/
always@(posedge DDRCLK, negedge RESETn)
begin
 if( RESETn == 1'b0 )
   begin
       AWVALID_1 <= 1'b0;
       WVALID_1 <= 1'b0;
       ARVALID_1 <= 1'b0;
   end
  else
   begin
       AWVALID_1 <= AWVALID && AWREADY;
       WVALID 1 <= WVALID && WREADY;
       ARVALID_1 <= ARVALID && ARREADY;
end
always@(posedge DDRCLK, negedge RESETn)
begin
 if( RESETn == 1'b0 )
       AWVALID_new <= 1'b0;
       WVALID_new <= 1'b0;
       ARVALID new <= 1'b0;
   end
  else
   begin
       AWVALID new <= AWVALID 1;
       WVALID new <= WVALID 1;
       ARVALID_new <= ARVALID_1;
end
/********3:1 DDR:AXI clock ratio timing optimization technique ***************/
```



Add the following RTL logic for the 4:1 DDR to AXI clock ratio designs in the AXI interconnect block.

Figure 23 • RTL Logic for the 4:1 DDR to AXI Clock Ratio

```
/************=4:1 DDR:AXI clock ratio timing optimization technique ****************/
always@(posedge DDRCLK, negedge RESETn)
begin
  if( RESETn == 1'b0 )
    begin
        AWVALID_1 <= 1'b0;
        WVALID 1 <= 1'b0;
        ARVALID_1 <= 1'b0;
  else
    begin
        AWVALID 1 <= AWVALID && AWREADY;
        WVALID_1 <= WVALID && WREADY;</pre>
        ARVALID 1 <= ARVALID && ARREADY;
end
always@(posedge DDRCLK, negedge RESETn)
begin
  if( RESETn == 1'b0 )
    begin
        AWVALID_2 <= 1'b0;
        WVALID 2 <= 1'b0;
        ARVALID_2 <= 1'b0;
  else
    begin
        AWVALID 2 <= AWVALID 1;
        WVALID_2 <= WVALID_1;
        ARVALID 2 <= ARVALID 1;
end
 always@ (posedge DDRCLK, negedge RESETn)
 begin
   if( RESETn == 1'b0 )
        AWVALID_new <= 1'b0;
         WVALID_new <= 1'b0;</pre>
         ARVALID_new <= 1'b0;
     end
   else
     begin
         AWVALID_new <= AWVALID_2;
         WVALID new <= WVALID 2;
         ARVALID_new <= ARVALID_2;
 end
 /**************=4:1 DDR:AXI clock ratio timing optimization technique ***************/
```

For more information about how to connect user logic with AXI interface and how to configure AXI interconnect on SmartFusion2 devices, refer to the AC409: Connecting User Logic to AXI Interfaces of High-Performance Communication Blocks in the SmartFusion2 Devices Application Note.