

**Simply Better Results** 

# The Synplify Pro<sup>®</sup> Quick Start Guide

**Quick Start** 

July 2008

Synplicity, Inc. 600 West California Avenue Sunnyvale, CA 94086, USA (U.S.) +1 408 215-6000 direct (U.S.) +1 408 990-0263 fax www.synplicity.com

# Preface

## **Disclaimer of Warranty**

Synplicity, Inc. makes no representations or warranties, either expressed or implied, by or with respect to anything in this manual, and shall not be liable for any implied warranties of merchantability or fitness for a particular purpose of for any indirect, special or consequential damages.

## **Copyright Notice**

Copyright © 2008 Synplicity, Inc. All Rights Reserved.

Synplicity software products contain certain confidential information of Synplicity, Inc. Use of this copyright notice is precautionary and does not imply publication or disclosure. No part of this publication may be reproduced, transmitted, transcribed, stored in a retrieval system, or translated into any language in any form by any means without the prior written permission of Synplicity, Inc. While every precaution has been taken in the preparation of this book, Synplicity, Inc. assumes no responsibility for errors or omissions. This publication and the features described herein are subject to change without notice.

#### Trademarks

Synplicity, the Synplicity logo, "Simply Better Results", Amplify, Amplify FPGA, Behavior Extracting Synthesis Technology, Certify, HDL Analyst, Identify, SCOPE, Synplify, Synplify ASIC, and Synplify Pro are registered trademarks of Synplicity, Inc. BEST, IICE, MultiPoint, Physical Analyst, and System Designer are trademarks of Synplicity, Inc. All other names mentioned herein are trademarks or registered trademarks of their respective companies.

#### **Restricted Rights Legend**

Government Users: Use, reproduction, release, modification, or disclosure of this commercial computer software, or of any related documentation of any kind, is restricted in accordance with FAR 12.212 and DFARS 227.7202, and further restricted by the Synplicity Software License Agreement. Synplicity, Inc., 600 West California Avenue, Sunnyvale, CA 94086, U. S. A.

Printed in the U.S.A July 2008

#### Synplicity Software License Agreement

Important! READ CAREFULLY BEFORE PROCEEDING

BY INDICATING YOUR ACCEPTANCE OF THE TERMS OF THIS AGREEMENT, YOU ("LICENSEE") ARE REPRESENTING THAT YOU HAVE THE RIGHT AND AUTHORITY TO LEGALLY BIND YOURSELF OR YOUR COMPANY, AS APPLICABLE, AND CONSENTING TO BE LEGALLY BOUND BY ALL OF THE TERMS OF THIS AGREEMENT. IF YOU DO NOT AGREE TO ALL THESE TERMS DO NOT INSTALL OR USE THE SOFTWARE, AND RETURN THE SOFTWARE TO THE LOCATION OF PURCHASE FOR A REFUND. This is a legal agreement governing use of the software program provided by Synplicity, Inc. ("Synplicity") to you (the "SOFTWARE"). The term "SOFTWARE" also includes related documentation (whether in print or electronic form), any authorization keys, authorization codes, and license files, and any updates or upgrades of the SOFTWARE provided by Synplicity, but does <u>not</u> include certain "open source" software licensed by third party licensors and made available to you by Synplicity under the terms of such third party licensor's license (such as software licensed under the General Public License (GPL)) ("Third Party Software"). If Licensee is a participant in the University Program or has been granted an Evaluation License or Subscription License, then some of the following terms and conditions may not apply (refer to the sections entitled, respectively, **Evaluation License** and **Subscription License**, below).

License. Synplicity grants to Licensee a non-exclusive right to install the SOFTWARE and to use or authorize use of the SOFTWARE by up to the number of nodes for which Licensee has a license and for which Licensee has the security key(s) or authorization code(s) provided by Synplicity or its agents for the purpose of creating and modifying Designs (as defined below). If Licensee has obtained the SOFTWARE under a node-locked license, then a "node" refers to a specific machine, and the SOFTWARE may be installed only on the number of "nodes" or machines authorized, must be used only on the machine(s) on which it is installed, and may be accessed only by users who are physically present at that node or machine. A node-locked license may only be used by one user at a time running one instance of the software at a time. If Licensee has obtained the SOFT-WARE under a "floating" license, then a "node" refers to a concurrent user or session, and the SOFTWARE may be used concurrently by up to the number of users or sessions indicated. All SOFTWARE must be used within the country for which the systems were licensed and at Licensee's Site (contained within a one kilometer radius); however, if Licensee has a floating license then remote use is permitted by employees who work at the site but are temporarily telecommuting to that same site from less than 50 miles away (for example, an employee who works at a home office on occasion), but the maximum number of concurrent sessions or nodes still applies. In addition, Synplicity grants to Licensee a non-exclusive license to copy and distribute internally the documentation portion of the SOFTWARE in support of its license to use the program portion of the SOFT-WARE. For purposes of this Agreement the "Licensee's Site" means the location of the server on which the SOFTWARE resides, or when a server is not required, the location of the client computer for which the license was issued.

**Evaluation License**. If Licensee has obtained the SOFTWARE pursuant to an evaluation license, then, in addition to all other terms and conditions herein, the following restrictions apply: (a) the license to the SOFTWARE terminates after 20 days (unless otherwise agreed to in writing by Synplicity); and (b) Licensee may use the SOFTWARE only for the sole purpose of internal testing and evaluation to determine whether Licensee wishes to license the SOFTWARE on a commercial basis. Licensee shall not use the SOFTWARE to design any integrated circuits for production or pre-production purposes or any other commercial use including, but not limited to, for the benefit of Licensee's customers. If Licensee breaches any of the foregoing restrictions, then Licensee shall pay to Synplicity a license fee equal to Synplicity's perpetual list price plus maintenance for the commercial version of the SOFTWARE.

**Subscription (Time-Based) License.** If Licensee has obtained a Subscription License to the SOFTWARE, the, in addition to all other terms and conditions herein, the following restrictions apply: (a) Licensee is authorized to use the SOFTWARE only for a limited time (which time is indicated on the quotation or in the purchase confirmation documents); (b) Licensee's right to use the SOFTWARE terminates on the date the subscription term expires as set forth in the quotation or the purchase confirmation documents, unless Licensee has renewed the license by paying the applicable fees.

**Project Based License**. If Licensee has obtained a Project-Based License to the SOFTWARE, in addition to all other terms and conditions herein, the terms of Exhibit A will apply.

**Copy Restrictions**. This SOFTWARE is protected by United States copyright laws and international treaty provisions and Licensee may copy the SOFTWARE only as follows: (i) to directly support authorized use under the license, and (ii) in order to make a copy of the SOFTWARE for backup purposes. Copies must include all copyright and trademark notices.

**Use Restrictions**. This SOFTWARE is licensed to Licensee for internal use only. Licensee shall not (and shall not allow any third party to): (i) decompile, disassemble, reverse engineer or attempt to reconstruct, identify or discover any source code, underlying ideas, underlying user interface techniques or algorithms of the SOFT-WARE by any means whatever, or disclose any of the foregoing; (ii) provide, lease, lend, or use the SOFT-WARE for timesharing or service bureau purposes, on an application service provider basis, or otherwise circumvent the internal use restrictions; (iii) modify, incorporate into or with other software, or create a derivative work of any part of the SOFTWARE; (iv) disclose the results of any benchmarking of the SOFTWARE, or use such results for its own competing software development activities, without the prior written permission of Synplicity; or (v) attempt to circumvent any user limits, maximum gate count limits or other license, timing or use restrictions that are built into the SOFTWARE.

**Transfer Restrictions/No Assignment**. The SOFTWARE may only be used under this license at the designated locations and designated equipment as set forth in the license grant above, and may not be moved to other locations or equipment or otherwise transferred without the prior written consent of Synplicity. Any permitted transfer of the SOFTWARE will require that Licensee executes a "Software Authorization Transfer Agreement" provided by Synplicity. Further, Licensee shall not sublicense, or assign this Agreement or any of the rights or licenses granted under this Agreement, without the prior written consent of Synplicity.

**Security**. Licensee agrees to take all appropriate measures to safeguard the SOFTWARE and prevent unauthorized access or use thereof. Suggested ways to accomplish this include: (i) implementation of firewalls and other security applications, (ii) use of FLEXIm options file that restricts access to the SOFTWARE to identified users; (iii) maintaining and storing license information in paper format only; (iv) changing TCP port numbers every three (3) months; and (v) communicating to all authorized users that use of the SOFTWARE is subject to

the restrictions set forth in this Agreement.

**Ownership of the SOFTWARE**. Synplicity retains all right, title, and interest in the SOFTWARE (including all copies), and all worldwide intellectual property rights therein. Synplicity reserves all rights not expressly granted to Licensee. This license is not a sale of the original SOFTWARE or of any copy.

**Ownership of Design Techniques**. "Design" means the representation of an electronic circuit or device(s), derived or created by Licensee through the use of the SOFTWARE in its various formats, including, but not limited to, equations, truth tables, schematic diagrams, textual descriptions, hardware description languages, and netlists. "Design Techniques" means the data, circuit and logic elements, libraries, algorithms, search strategies, rule bases, techniques and technical information incorporated in the SOFTWARE and employed in the process of creating Designs. Synplicity retains all right, title and interest in and to Design Techniques incorporated in the SOFTWARE, including all intellectual property rights embodied therein, provided that to the extent any Design Techniques are included as part of or embedded within Licensee's Designs, Synplicity grants Licensee a personal, non exclusive, nontransferable license to reproduce the Design Techniques and distribute such Design Techniques solely as incorporated into Licensee's Designs and not on a standalone basis. Additionally, Licensee acknowledges that Synplicity has an unrestricted, royalty-free right to incorporate any Design Techniques disclosed by Licensee into its software, documentation and other products, and to sublicense third parties to use those incorporated design techniques.

**Protection of Confidential Information**. "Confidential Information" means (i) the SOFTWARE, in object and source code form, and any related technology, idea, algorithm or information contained therein, including without limitation Design Techniques, and any trade secrets related to any of the foregoing; (ii) either party's product plans, Designs, costs, prices and names; non-published financial information; marketing plans; business opportunities; personnel; research; development or know-how; (iii) any information designated by the disclosing party as confidential in writing or, if disclosed orally, designated as confidential at the time of disclosure and reduced to writing and designated as confidential in writing within thirty (30) days; and (iv) the terms and conditions of this Agreement; provided, however that "Confidential Information" will not include information that: (a) is or becomes generally known or available by publication, commercial use or otherwise through no fault of the receiving party; (b) is known and has been reduced to tangible form by the receiving party at the time of disclosure and is not subject to restriction; (c) is independently developed by the receiving party without use of the disclosure; and (e) is released for publication by the disclosing party in writing.

Each party will protect the other's Confidential Information from unauthorized dissemination and use with the same degree of care that each such party uses to protect its own like information. Neither party will use the other's Confidential Information for purposes other than those necessary to directly further the purposes of this Agreement. Neither party will disclose to third parties the other's Confidential Information without the prior written consent of the other party.

**Open Source Software**. The SOFTWARE may be delivered with software that is subject to open source licensing terms ("Open Source Software") which are available at http://www.synplicity.com/prod-ucts/license\_agreement.html. If the Open Source Software license also requires source code to be made available, Licensee may reference http://www.synplicity.com/products/opensource.html for information on how to obtain such source code. Licensee agrees that all Open Source Software shall be and shall remain subject to the terms and conditions under which it is provided. The Open Source Software is provided "AS IS," WITHOUT ANY WARRANTY OF ANY KIND, AND SYNPLICITY FURTHER DISCLAIMS ALL OTHER WARRANTIES, EXPRESS, IMPLIED OR STATUTORY, WITH RESPECT TO OPEN SOURCE SOFTWARE,

INCLUDING BUT NOT LIMITED TO THE IMPLIED WARRANTIES OF NONINFRINGEMENT, MER-CHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. NEITHER SYNPLICITY NOR THE LICENSORS OF OPEN SOURCE SOFTWARE SHALL HAVE ANY LIABILITY FOR ANY DIRECT, INDI-RECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING WITHOUT LIMITATION LOST PROFITS), HOWEVER CAUSED AN ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OR DISTRIBUTION OF THE ECLIPSE SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGES. Copyrights to the Open Source Software are held by the copyright holders indicated in the copyright notices in the corresponding source files.

**Termination**. Synplicity may terminate this Agreement immediately if Licensee breaches any provision, including without limitation, failure by Licensee to implement adequate security measures as set forth above. Upon notice of termination by Synplicity, all rights granted to Licensee under this Agreement will immediately terminate, and Licensee shall cease using the SOFTWARE and return or destroy all copies (and partial copies) of the SOFTWARE and documentation.

Limited Warranty and Disclaimer. Synplicity warrants that the program portion of the SOFTWARE will perform substantially in accordance with the accompanying documentation for a period of 90 days from the date of receipt. Synplicity's entire liability and Licensee's exclusive remedy for a breach of the preceding limited warranty shall be, at Synplicity's option, either (a) return of the license fee, or (b) providing a fix, patch, workaround, or replacement of the SOFTWARE. In either case, Licensee must return the SOFTWARE to Synplicity with a copy of the purchase receipt or similar document. Replacements are warranted for the remainder of the original warranty period or 30 days, whichever is longer. Some states/jurisdictions do not allow limitations, so the above limitation may not apply. EXCEPT AS EXPRESSLY SET FORTH ABOVE, NO OTHER WARRAN-TIES OR CONDITIONS, EITHER EXPRESS, IMPLIED, STATUTORY OR OTHERWISE, ARE MADE BY SYN-PLICITY OR ITS LICENSORS WITH RESPECT TO THE SOFTWARE AND THE ACCOMPANYING DOCUMENTATION, AND SYNPLICITY EXPRESSLY DISCLAIMS ALL WARRANTIES AND CONDITIONS NOT EXPRESSLY STATED HEREIN, INCLUDING BUT NOT LIMITED TO THE IMPLIED WARRANTIES OR CONDITIONS OF MERCHANTABILITY, NONINFRINGEMENT, AND FITNESS FOR A PARTICULAR PUR-POSE. SYNPLICITY AND ITS LICENSORS DO NOT WARRANT THAT THE FUNCTIONS CONTAINED IN THE SOFTWARE WILL MEET LICENSEE'S REQUIREMENTS, BE UNINTERRUPTED OR ERROR FREE, OR THAT ALL DEFECTS IN THE PROGRAM WILL BE CORRECTED. Licensee assumes the entire risk as to the results and performance of the SOFTWARE. Some states/jurisdictions do not allow the exclusion of implied warranties, so the above exclusion may not apply.

Limitation of Liability. IN NO EVENT SHALL SYNPLICITY OR ITS LICENSORS OR THEIR AGENTS BE LIABLE FOR ANY INDIRECT, SPECIAL, CONSEQUENTIAL OR INCIDENTAL DAMAGES WHATSOEVER (INCLUDING, WITHOUT LIMITATION, DAMAGES FOR LOSS OF BUSINESS PROFITS, BUSINESS INTER-RUPTIONS, LOSS OF BUSINESS INFORMATION, OR OTHER PECUNIARY LOSS) ARISING OUT OF THE USE OF OR INABILITY TO USE THE SOFTWARE, EVEN IF SYNPLICITY AND/OR ITS LICENSORS HAVE BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGES. FURTHER, IN NO EVENT SHALL SYNPLIC-ITY'S LICENSORS BE LIABLE FOR ANY DIRECT DAMAGES ARISING OUT OF LICENSEE'S USE OF THE SOFTWARE. IN NO EVENT WILL SYNPLICITY OR ITS LICENSORS BE LIABLE TO LICENSEE FOR DAMAGES IN AN AMOUNT GREATER THAN THE FEES PAID FOR THE USE OF THE SOFTWARE. Some states/jurisdictions do not allow the limitation or exclusion of incidental or consequential damages, so the above limitations or exclusions may not apply.

**Intellectual Property Right Infringement**. Synplicity will defend or, at its option, settle any claim or action brought against Licensee to the extent it is based on a third party claim that the SOFTWARE as used within the

scope of this Agreement infringes or violates any US patent, copyright, trade secret or trademark of any third party, and Synplicity will indemnify and hold Licensee harmless from and against any damages, costs and fees reasonably incurred that are attributable to such claim or action; provided that Licensee provides Synplicity with (i) prompt written notification of the claim or action; (ii) sole control and authority over the defense or settlement thereof (including all negotiations); and (iii) at Synplicity's expense, all available information, assistance and authority to settle and/or defend any such claim or action. Synplicity's obligations under this subsection do not apply to the extent that (i) such claim or action would have been avoided but for modifications of the SOFTWARE, or portions thereof, other than modifications made by Synplicity after delivery to Licensee; (ii) such claim or action would have been avoided but for the SOFTWARE, or portions thereof, processes or materials not supplied or specified in writing by Synplicity; (iii) Licensee continues allegedly infringing activity after being notified thereof or after being informed of modifications that would have avoided the alleged infringement; or (iv) Licensee's use of the SOFTWARE is not strictly in accordance with the terms of this Agreement. Licensee will be liable for all damages, costs, expenses, settlements and attorneys' fees related to any claim of infringement arising as a result of (i)-(iv) above.

If the SOFTWARE becomes or, in the reasonable opinion of Synplicity is likely to become, the subject of an infringement claim or action, Synplicity may, at Synplicity's option and at no charge to Licensee, (a) obtain a license so Licensee may continue use of the SOFTWARE; (b) modify the SOFTWARE to avoid the infringement; (c) replace the SOFTARE with a compatible, functionally equivalent, and non-infringing product, or (d) if Synplicity determines that options (a), (b), and (c) are not commercially reasonable, then Synplicity shall have the right to terminate the licenses granted hereunder and refund to Licensee the amount paid for the SOFTWARE, as depreciated on a straight-line 5-year basis, or such other shorter period applicable to Subscription Licenses.

THE FOREGOING PROVISIONS OF THIS SECTION STATE THE ENTIRE AND SOLE LIABILITY AND OBLIGATIONS OF SYNPLICTY, AND THE EXCLUSIVE REMEDY OF LICENSEE, WITH RESPECT TO ANY ACTUAL OR ALLEGED INFRINGEMENT OF ANY INTELLECTUAL PROPERTY RIGHTS BY THE SOFTWARE (INCLUDING DESIGN TECHNIQUES) AND DOCUMENTATION.

**Export**. Licensee warrants that it is not prohibited from receiving the SOFTWARE under U.S. export laws; that it is not a national of a country subject to U.S. trade sanctions; that it will not use the SOFTWARE in a location that is the subject of U.S. trade sanctions that would cover the SOFTWARE; and that to its knowledge it is not on the U.S. Department of Commerce's table of deny orders or otherwise prohibited from obtaining goods of this sort from the United States.

**Miscellaneous**. This Agreement is the entire agreement between Licensee and Synplicity with respect to the license to the SOFTWARE, and supersedes any previous oral or written communications or documents (including, if you are obtaining an update, any agreement that may have been included with the initial version of the Software). This Agreement is governed by the laws of the State of California, USA excluding its conflicts of laws principals. This Agreement will not be governed by the U. N. Convention on Contracts for the International Sale of Goods and will not be governed by any statute based on or derived from the Uniform Computer Information Transactions Act (UCITA). If any provision, or portion thereof, of this Agreement will remain in full force and effect. Failure to prosecute a party's rights with respect to a default hereunder will not constitute a waiver of the right to enforce rights with respect to the same or any other breach.

Government Users. If the SOFTWARE is licensed to the United States government or any agency thereof,

then the SOFTWARE and any accompanying documentation will be deemed to be "commercial computer software" and "commercial computer software documentation", respectively, pursuant to DFAR Section 227.7202 and FAR Section 12.212, as applicable. Any use, reproduction, release, performance, display or disclosure of the SOFTWARE and accompanying documentation by the U.S. Government will be governed solely by the terms of this Agreement and are prohibited except to the extent expressly permitted by the terms of this Agreement.

March 2008

# Contents

#### **Chapter 1: Quick Start Overview**

#### **Chapter 2: Process Flow**

| Top-Down and MultiPoint Design Flows | 2   | 2  |
|--------------------------------------|-----|----|
|                                      | . 2 | -0 |

#### **Chapter 3: Set up Design Information**

| Select a Target Device         | -3 |
|--------------------------------|----|
| Set Implementation Options     | -4 |
| State Machine Implementation 3 | -4 |
| Resource Sharing               | -5 |
| Pipelining                     | -5 |
| Retiming                       | -6 |
| Formal Verification            | -7 |

#### Chapter 4: Set up Timing Information

| Set Timing Constraints       | 4-2 |
|------------------------------|-----|
| Define Compile Points        | 4-3 |
| Set Constraints (MultiPoint) | 4-4 |
| Run                          | 4-6 |

#### **Chapter 5: Analyze Results**

| View the Log File                  | 5-3 |
|------------------------------------|-----|
| RTL View                           | 5-4 |
| Technology View                    | 5-5 |
| Design Hierarchy Exploration Tools | 5-5 |
| Advanced Find Capabilities         | 5-8 |
| Filtered and Flattened Views       | 5-9 |

| Crossprobing Across Views                                                                                                                                                                                         | 5-14<br>5-15      |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------|
| Use FSM Viewer                                                                                                                                                                                                    | 5-17              |
| Other Tools to Validate Synthesis Results       5         Use Formal Verification       5         Use syn_probe Attribute       5         Identify RTL debugger       5                                           | 5-20<br>5-21      |
| Chapter 6: Specify Directives and Attributes<br>syn_maxfan<br>syn_keep<br>syn_ramstyle                                                                                                                            | 6-2               |
| Chapter 7: Basics of Timing Constraints<br>Example                                                                                                                                                                | 7-8<br>7-10       |
| Chapter 8: Analyze Timing Results                                                                                                                                                                                 |                   |
| Timing Information Display<br>Critical Path Views<br>Generate a Technology View for the Most Critical Path<br>Generate Critical Path View in the Timing Analyzer<br>Generate Critical Path View from the Log File | 8-3<br>8-4<br>8-5 |
| Chapter 9: Refine Options to Improve Timing<br>Compare Synthesis Results with Place-and Route Results                                                                                                             | 9-2               |

| Compare Synthesis Results with Place-and Route Results | 9-2 |
|--------------------------------------------------------|-----|
| Add Route Delay Constraints                            | 9-3 |
| Forward Annotate Incremental Results                   | 9-4 |
|                                                        |     |

#### 

# CHAPTER 1 Quick Start Overview

What does the Synplify Pro software Offer? — The Synplify Pro software consists of a fast, high-performance, sophisticated logic synthesis engine that utilizes proprietary technology called Behavior Extracting Synthesis Technology<sup>®</sup> (BEST<sup>™</sup>) to deliver highly efficient FPGA and CPLD designs. Starting with Verilog and VHDL hardware description language input files, the software generates an optimized netlist in the most popular CPLD and FPGA vendor formats.

**Who Will Find This Guide Useful?** — This guide provides the steps and options of a design flow and can be used by:

- Engineers who want to evaluate the software without actually running it. The guide includes many graphic examples that show the capabilities of the software.
- Engineers who want to get a quick start to run synthesis.
- Managers who want to understand the capabilities and features of the software before purchasing.

**How is the information organized?** — The document is organized as described below. You can click on the links in the columns to take you to the sections:

|                                              | Describes                                                                    | Page |
|----------------------------------------------|------------------------------------------------------------------------------|------|
| Process Flow                                 | The top-down and MultiPoint flows.                                           | 2-1  |
| Set up Design Information                    | The steps used to set up your project                                        | 3-1  |
| Add Source Files                             | —for Synplify Pro synthesis.                                                 | 3-1  |
| Select a Target Device                       |                                                                              | 3-3  |
| Set Implementation Options                   |                                                                              | 3-4  |
| Set up Timing Information                    | How to set general timing                                                    |      |
| Set Timing Constraints                       | constraints and define compile points for the MultiPoint incremental         | 4-2  |
| Define Compile Points                        | flow.                                                                        | 4-3  |
| Set Constraints (MultiPoint)                 |                                                                              | 4-4  |
| Run                                          | How to synthesize the design.                                                | 4-6  |
| Analyze Results                              | How to view the synthesis results                                            | 5-1  |
| View the Log File                            | —using the log file and some built-in<br>tools like the HDL Analyst tool for | 5-3  |
| Use the HDL Analyst <sup>®</sup> Tool        | graphic analysis and the FSM viewer for state machine implementations.       | 5-3  |
| Use FSM Viewer                               | Also describes how to formally verify your results with LEC.                 | 5-17 |
| Other Tools to Validate Synthesis<br>Results |                                                                              | 5-20 |
| Use Formal Verification                      |                                                                              | 5-20 |
| Use syn_probe Attribute                      |                                                                              | 5-21 |
| Identify RTL debugger                        |                                                                              | 5-21 |
| Specify Directives and Attributes            | How to use attributes and directives                                         | 6-1  |
| syn_maxfan                                   | —to fine-tune the way the design is synthesized.                             | 6-2  |
| syn_keep                                     |                                                                              | 6-2  |
| syn_ramstyle                                 |                                                                              | 6-3  |

|                                                           | Describes                                                                                                                                  | Page |
|-----------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------|------|
| Basics of Timing Constraints                              | Basic timing concepts used in the                                                                                                          | 7-1  |
| Specifying Timing Information                             | —Synplify Pro tool.                                                                                                                        | 7-1  |
| Clock Descriptions                                        |                                                                                                                                            | 7-2  |
| Clock Groups                                              |                                                                                                                                            | 7-5  |
| Rise and Fall Constraints                                 |                                                                                                                                            | 7-6  |
| Input and Output Delays                                   |                                                                                                                                            | 7-7  |
| Multicycle Paths                                          |                                                                                                                                            | 7-11 |
| I/O Standard                                              |                                                                                                                                            | 7-13 |
| Analyze Timing Results                                    | How to analyze timing results and                                                                                                          | 8-1  |
| Critical Path Report                                      | —use options to improve timing.                                                                                                            | 8-1  |
| Timing Information Display                                |                                                                                                                                            | 8-3  |
| Critical Path Analysis in a Technology<br>View            |                                                                                                                                            | 8-3  |
| Refine Options to Improve Timing                          |                                                                                                                                            | 9-1  |
| Refine Timing Results                                     |                                                                                                                                            | 9-1  |
| Compare Synthesis Results with<br>Place-and Route Results |                                                                                                                                            | 9-2  |
| Forward Annotate Incremental<br>Results                   | How to forward annotate<br>incremental results (updates) in a<br>MultiPoint flow so that your<br>complete design project is<br>up-to-date. | 9-4  |

|                                                       | Describes                           | Page |
|-------------------------------------------------------|-------------------------------------|------|
| Additional Features and Topics:                       | Additional features and options for | 10-1 |
| Synplify Premier Physical Synthesis                   | -synthesis.                         |      |
| Synthesis Output Files                                | _                                   |      |
| Using Multiple Clock Domains                          | _                                   |      |
| Using Scripts and Batch Mode                          | _                                   |      |
| Using the Tcl Find Command for<br>Setting Constraints | _                                   |      |
| Running Place and Route                               | _                                   |      |
| Using Identify with Synplify Pro                      | _                                   |      |

#### CHAPTER 2

# **Process Flow**

The Synplify Pro software is designed to give you the best overall circuit performance with a minimal amount of effort.

Topics include the following process flows:

- Process Flow Diagram, on page 2-1
- Top-Down and MultiPoint Design Flows, on page 2-3

## **Process Flow Diagram**

The following figure shows you two Synplify Pro flows with simple steps to trade off between timing and area to help you reach your goals quickly.

The top-down flow is the traditional synthesis flow with a global approach to synthesis. With the MultiPoint<sup>TM</sup> synthesis flow, you can design incrementally and synthesize only what is necessary.



# Top-Down and MultiPoint Design Flows

A MultiPoint flow differs from a traditional top-down flow in that it divides the design into parts that can be processed independently or synthesized incrementally, using a team design approach. Unlike other bottom-up solutions, it is highly automated and eliminates the need for time consuming and error prone scripts. MultiPoint synthesis is based on compile points, which are smaller synthesis units of the main design that are treated as individual blocks.

The MultiPoint flow is available for certain design families. Check the Device tab of the Implementation Options dialog box for applicable technology families. For Altera designs, you can use this flow with the Altera Quartus II Incremental Compilation methodology to preserve design implementation data so as to make incremental place and route updates. Similarly, you can use the Xilinx Incremental flows with the place-and-route tool for team-based design. See the Synplify Pro software documentation and the appropriate application notes for details.

# CHAPTER 3

# Set up Design Information

There are three basic tasks involved in setting up a design. Both the top-down and MultiPoint flows use the same design setup. Topics include:

- Add Source Files, on page 3-1
- Select a Target Device, on page 3-3
- Set Implementation Options, on page 3-4

# Add Source Files

After you have installed the software, set up the design project. Then, add source files.



Source files need to be ordered such that the top-level file is last in the source file list. If you have mixed language source files (a combination of Verilog and VHDL files), specify the top-level file using Implementation Options ->Verilog or VHDL tab, as shown below.

|                               |                               |        | Verilog            |
|-------------------------------|-------------------------------|--------|--------------------|
| Top Level Module:             | Compiler Directives and Para  | meters |                    |
| eight_bit_uc                  |                               |        |                    |
|                               | Parameter Name                | Value  |                    |
| Verilog Language              |                               |        |                    |
| Verilog 2001                  |                               |        |                    |
| System Verilog                |                               |        |                    |
|                               |                               |        | Extract Parameters |
| ✓ Push Tristates              |                               |        |                    |
| Allow Duplicate Modules       | Compiler Directives: e.g. SIZ | E=8    |                    |
|                               |                               |        |                    |
|                               |                               |        |                    |
| Include Path Order: (Relative | to Project File)              |        |                    |
|                               |                               |        |                    |
|                               |                               |        |                    |
|                               |                               |        |                    |
|                               |                               |        |                    |
|                               |                               |        |                    |
|                               |                               |        |                    |
| Library Directories:          |                               |        |                    |
|                               |                               |        |                    |
|                               |                               |        |                    |
|                               |                               |        |                    |
|                               |                               |        |                    |
| L                             |                               |        |                    |

Selecting the Top Level Module for Mixed Language Source Files

# Select a Target Device

Choose the technology family using the Device panel of the Implementation Options dialog box. Select the part, package, and speed grade, as applicable. Remember that the speed grade you choose has a direct impact on timing estimates. For the MultiPoint flow, you must select an appropriate technology family.



# Set Implementation Options

Set options for the synthesis run from the Options tab of the Implementation Options dialog box. Some of the global options that influence the tradeoff between speed and area include:

- State Machine Implementation
- Resource Sharing
- Pipelining
- Retiming

Some of these options can also be set on a per instance basis.

Formal Verification is a global option that provides a netlist compatible with the LEC tool for design verification.

#### **State Machine Implementation**

Use the FSM Compiler and the FSM Explorer to automatically select encoding styles that determine how the state machines are implemented. The encoding style affects timing estimates. You also can define state machine implementations for individual instances using attributes such as syn\_encoding. You enable these options by selecting the FSM Compiler and FSM Explorer check boxes on the left side of the Project view.



## **Resource Sharing**

Resource sharing is another option that influences the tradeoff between speed and area. Turn on this option when you want to optimize area. You enable this option by selecting the Resource Sharing check box on the left side of the Project view.



## Pipelining

Pipelining is available for certain device families only. Check the Device or Options tab of the Implementation Options dialog box for applicable technology families. You can either set the options globally or on individual registers.

Pipelining is the process of moving adjacent registers into multipliers or ROMs so as to increase throughput and ensure faster circuit performance. It does not add new register stages. The following figure shows you how to set it globally.



## Retiming

Retiming is available for certain device families only and is a technique related to pipelining. Retiming improves the timing performance of sequential circuits by automatically moving registers (register balancing) across combinatorial gates or LUTs. This process improves timing while ensuring identical behavior as seen from the primary inputs and outputs of the design. Retiming moves registers across gates or LUTs, but does not change the number of registers in a cycle or path from a primary input to a primary output. However, it can change the total number of registers in a design. The algorithm retimes only edge-triggered registers. It does not retime level-sensitive latches.



When you turn on the retiming option, pipelining is turned on automatically.

#### **Formal Verification**

This option is available for certain device technologies, and lets you use the Cadence Conformal<sup>™</sup> Logic Equivalence Checker (LEC) tool for formal design verification. In verification mode, the software generates files that are used by Conformal LEC to verify equivalence between the RTL code and the post-synthesis netlist. See the application note for details.

| Fechnology:                     | Part:      | Speed: | Package: |   |
|---------------------------------|------------|--------|----------|---|
| Xilinx Virtex4                  | ▼ XC4VLX15 | ▼ -10  | ▼ SF363  | - |
| Device Mapping Options          |            |        |          |   |
| Option                          |            |        | Value    |   |
| Annotated Properties for Anal   | yst        |        | •        |   |
| Fanout Guide                    |            |        | 10000    |   |
| Disable I/O Insertion           |            |        |          |   |
| Pipelining                      |            |        | •        |   |
| Update Compile Point Timing D   | ata        |        |          |   |
| Verification Mode               |            |        | •        |   |
| Retiming                        |            |        |          |   |
| Disable Sequential Optimization | ns         |        |          |   |
| Fix gated clocks                |            |        | 3        |   |
| Fix generated clocks            |            |        | 3        |   |
|                                 |            |        |          |   |
| - Option Description            |            |        |          |   |
| option boothplion               |            |        |          |   |
| Generate verification data      |            |        |          |   |
|                                 |            |        |          |   |

# CHAPTER 4 Set up Timing Information

Synplify Pro synthesis is timing-driven. Consequently, the more precise and complete the information you supply, the more accurate the timing estimates, and the closer the synthesized implementation is to your design goals. The Synplify Pro tool begins optimizing for area once your timing performance constraints are set.

Define timing goals through constraints. Constraint setup steps differ for the two flows:



Refer to the following topics:

- Set Timing Constraints, on page 4-2
- Set Constraints (MultiPoint), on page 4-4
- Run, on page 4-6

# Set Timing Constraints

As a minimum, you must set a global clock frequency, which can be done in the Project view or through the Constraints tab of the Implementation Options dialog box. However, using a global frequency alone is not recommended because this option sets all clocks to the same value and assigns them to the same clock group. Synthesis assumes that all clocks are related and calculates timing for every path between the clocks.

When using multiple-clock designs, you should specify clock frequencies for each clock. Also, define timing exceptions like false path and multi-cycle path constraints. For defining timing constraints, use the SCOPE<sup>®</sup> interface which makes it easy to enter constraint definitions.



# **Define Compile Points**

Compile points are design modules that act as relatively independent synthesis units: they have their own constraint files and are optimized individually. They are resynthesized only as needed, based on an analysis of design dependencies and the nature of design changes. The synthesis process for compile points is called the MultiPoint flow. In this incremental flow, compile points are defined through the SCOPE interface.

| With the       | e co<br>nfo                | mpilec<br>rmatio | design, the SCOP                                                                           | о с<br>Е | open th<br>interfac |                      | ick the Selec<br>p Level, and |        |       | e tab, select<br>to initialize. |
|----------------|----------------------------|------------------|--------------------------------------------------------------------------------------------|----------|---------------------|----------------------|-------------------------------|--------|-------|---------------------------------|
|                |                            |                  |                                                                                            |          |                     | Create a New S       | COPE File                     |        |       |                                 |
|                |                            |                  |                                                                                            |          |                     | Initialize Constrain | ts Select File                | е Туре |       |                                 |
| selec<br>the c | t th<br>ons                | e com            | mpile Points tab, and<br>bile point modules. Save<br>ile, and add the file to the          |          |                     | • Top I              | .evel 🔾 Block                 |        | Ŭ     | mpile Point                     |
| proje          | CI.                        |                  |                                                                                            |          |                     | Select a Module      |                               |        | Compi | le Point Type                   |
|                |                            |                  | <b>V</b>                                                                                   |          |                     |                      |                               |        |       |                                 |
|                |                            | Enabled          | Module                                                                                     |          |                     | Туре                 | Commer                        | nt     | -     | ]                               |
|                |                            |                  | Fibuaic                                                                                    |          |                     |                      |                               |        |       |                                 |
|                | 1                          |                  | Fibuaic                                                                                    | -        | locked              |                      |                               |        |       |                                 |
|                | <b>1</b><br>2              |                  | prep4<br>ins_decode                                                                        | -        | locked              |                      |                               |        |       |                                 |
|                |                            |                  | prep4                                                                                      | -        | locked              |                      |                               |        |       |                                 |
|                | 2                          |                  | prep4<br>ins_decode<br>prgm_cntr                                                           |          |                     |                      |                               |        |       | J                               |
|                | 2                          |                  | prep4<br>i <mark>ns_decode</mark><br>prgm_cntr<br>reg_file<br>data_mux                     | -<br>-   |                     |                      |                               |        |       | 1                               |
|                | 2<br>3<br>4                |                  | prep4<br>ins_decode<br>prgm_cntr<br>reg_file<br>data_mux<br>alu<br>mult                    | <b>-</b> |                     |                      |                               |        |       | J                               |
|                | 2<br>3<br>4<br>5           |                  | prep4<br>ins_decode<br>prgm_cntr<br>reg_file<br>data_mux<br>alu<br>mult<br>spcl_regs<br>io |          |                     |                      |                               |        |       | ]                               |
|                | 2<br>3<br>4<br>5<br>6<br>7 | Collections      | prep4<br>ins_decode<br>prgm_cntr<br>reg_file<br>data_mux<br>alu<br>mult<br>spcl_regs<br>io | •        |                     | tes I/O Standards    | Compile Points                | Other  |       |                                 |

#### Set Constraints (MultiPoint)

# Set Constraints (MultiPoint)

Set constraints at the top level and for each compile point.

## **Set Top-level Constraints**

In a MultiPoint flow, set top-level constraints as you do in a normal synthesis flow. See the following figure.



## **Set Compile Point Constraints**

Compile points can be nested. Parent compile points contain compile points within. Child compile points are nested within compile points. Parent constraints do not propagate to the child compile point, so you must set constraints for each compile point. However, compile point constraints are considered during synthesis of the parent.

Run

Open the SCOPE Go to the Select File Type tab, click Compile Point, select interface a compile point module, and then click OK to initialize. ? × Create a New SCOPE File Select File Type Initialize Constraints O Top Level O Block Level O Compile Point Select a Module Compile Point Type INS\_ROM --default--alu Select --default-- to use the default data\_mux compile point type (soft) or to preserve ins\_decode your current type. io mult Define clocks, specify I/O delays, and set port constraints for the compile point C:\synplify\_pro1\INS\_ROM\_cp.sdc \* Frequency (MHz) Fall At Duty Cycle (%) Period Rise At Enabled Clock Object Clock Alias Clock Group (ns) (ns) (ns) 4 clock2 95 10.5263 default\_clkgroup\_1 2 4 default\_clkgroup\_2 3 • • Clocks Clock to Clock Collections Inputs/Outputs Registers Delay Paths Attributes I/O Standards Other Add file to project Save compile point constraint file.

## Run

After you have set all the options and constraints, click Run. View the results of synthesis in the log file, or analyze them graphically using various built-in tools.

| Done !      Analyze Results     Analyze Timing Results |
|--------------------------------------------------------|
|--------------------------------------------------------|

#### CHAPTER 5

# Analyze Results

There are many ways in which you can check the implementation results. Use any of the following tools:

- View the Log File, on page 5-3
- Use the HDL Analyst<sup>®</sup> Tool, on page 5-3
- Use FSM Viewer, on page 5-17
- Other Tools to Validate Synthesis Results, on page 5-20

A summary is shown in the figure below.



## View the Log File

The log file contains detailed information about the synthesis results, including details of the most critical paths, the number of primitives in the netlist, and the FSM encoding style. It is a good idea to run place and route even if the log file reports a timing goal failure. This is due to the fact the Synplify Pro tool is not knowledgeable about the final placement and routing of your design. The timing data given in the log file is an estimate.

### Use the HDL Analyst® Tool

The HDL Analyst environment provides graphical means to debug and analyze your design at two different stages of the design process: compilation (RTL View) and mapping (Technology View). The software maintains the names extracted from your code, so you can more easily follow the mapping of the logic from RTL to Technology view.



In addition to the RTL and Technology views and the timing analysis features (described separately in *Analyze Timing Results*, on page 8-1), the HDL Analyst tool has the following features that help you debug your implementation.

- Design Hierarchy Exploration Tools
- Advanced Find Capabilities
- Filtered and Flattened Views
- Crossprobing Across Views
- Cross-tool Crossprobing
- Other Options
- Mouse Strokes

### **RTL View**

This view shows the design after it is compiled. The software extracts the structure implied by the HDL language. The RTL view does not display target-specific components, so components are represented in a generic style.

To open the RTL view you must have a compiled design (use F7 to compile or click Run to synthesize). Then click on the icon, as shown in this figure:



### **Technology View**

This view shows the design after synthesis is complete. The design is optimized and mapped to components that are specific to the target architecture. If the technology has the structure, a DFF with synchronous reset is mapped to a synchronous reset DFF.

The technology view shows you how the generic RTL structure is implemented for your technology. You also can view the critical path.

To open the Technology view, you must have a synthesized design (click Run to synthesize). Then click on the icon shown in the following figure:



### **Design Hierarchy Exploration Tools**

Since most large designs are hierarchical, the Synplify Pro HDL Analyst tool helps you view hierarchy details and put the details in context. You can browse and navigate hierarchy with Push/Pop mode and the Hierarchy Browser.

### **Push/Pop Mode**

You can navigate design hierarchy by pushing down into a high-level schematic object and popping back up. Pushing down into an object takes you to a lower-level schematic that shows the internal logic of the object. Popping up from a lower level brings you back to the parent higher-level object. You cannot pop up from the top level.

You can push down into the following kinds of schematic objects:

- Non-hidden hierarchical instances. To push into a hidden instance, unhide it first.
- Technology-specific primitives (not logic primitives)
- Inferred ROMs<sup>1</sup> and state machines in RTL views. Inferred ROMs, RAMs, and state machines do not appear in Technology views, because they are resolved into technology-specific primitives.



Click on the Push/Pop icon to traverse the design hierarchy. These cursors appear (  $\frown \frown$  ) when the design hierarchy can be traversed. This cursor appears ( X ) when the design hierarchy has reached its lowest or highest level.

Push or pop as follows:

• To *pop*, place the pointer in an empty area of the schematic background, then click or use the appropriate mouse stroke. See *Mouse Strokes*, on page 5-16.

<sup>1.</sup> An inferred ROM is one that is created during synthesis; the ROM is not instantiated in your RTL code.

• To *push* into an object, place the mouse pointer over the object and click or use the appropriate mouse stroke. See *Mouse Strokes*, on page 5-16.

The following figure shows an additional use for the Push/Pop icon. You can push into a lookup table in a Technology view and check the mapped functions.



#### **Hierarchy Browser Navigation**

When you open an RTL view or a Technology view, the Hierarchy Browser appears in the left pane of the view. The browser in the RTL view displays the hierarchy specified in the RTL design description; in the Technology view it displays the hierarchy after mapping.

A schematic and its associated Hierarchy Browser are linked so that you can crossprobe objects between them. Selecting an object in one displays it in the other.



### **Advanced Find Capabilities**

You can locate objects using the command Edit -> Find. In an HDL Analyst view, this displays the Object Query dialog box, which lists candidate schematic objects by type (Instances, Symbols, Nets, or Ports) and lets you use wildcards to find objects by name.

You can find objects at any level of your design:

- Entire Design (all levels at once)
- Current Level & Below
- Current Level Only

All found objects are selected, whether or not they are displayed in the current schematic, so that you then can perform other operations on them.



in the HDL Analyst. views.

### **Filtered and Flattened Views**

Filtering is a useful first step in analysis, because it focuses analysis on the relevant parts of the design. Flattening eliminates the hierarchy of the design. Default flattening operations are global: the entire design is flattened from the current level down.

### Filtering

A filtered schematic shows a subset of your design.



Any command that results in a filtered schematic is a filtering command. Some commands, like the Expand commands, increase the amount of logic displayed, but they are still considered filtering commands because the resulting view is still a subset. Other commands like Filter Schematic remove objects from the current display.

You can use filtering commands to trace signals at a single level of hierarchy or across the entire design. If you select a net, then right-click in the view and select Go to Net Driver, the view highlights the element driving the selected net. If the driver is on another schematic sheet, the software automatically moves to the correct sheet.



Similarly, you can start with the output of an AND gate, and use the Expand command to see what this gate drives:



Right-click in the HDL Analyst views to access the pop-up menu. The following table lists the most common filtering commands:

| Filtering Command                  | Description                                                               |
|------------------------------------|---------------------------------------------------------------------------|
| Filter Schematic, Isolate Paths    | Reduces the displayed logic.                                              |
| Dissolve Instances (filtered view) | Makes selected instances transparent, exposing their lower-level details. |

| Filtering Command                                                                                                | Description                                        |
|------------------------------------------------------------------------------------------------------------------|----------------------------------------------------|
| Expand<br>Expand to Register/Port<br>Expand Paths<br>Expand Inwards<br>Select Net Driver<br>Select Net Instances | Displays logic connected to the current selection. |
| Show Critical Path<br>Flattened Critical Path<br>Hierarchical Critical Path                                      | Shows critical paths.                              |

### Flattening

A flattened schematic contains no hierarchical objects. The flattening commands shown below are from the HDL Analyst menu. The most versatile commands are Dissolve Instances and Flatten Current Schematic, which you can also use for selective flattening.

| Command                                             | Unfiltered Schematic                                                                                                                                         | Filtered Schematic                                                                                                                      |
|-----------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------|
| Dissolve Instances                                  | Flattens selected instances                                                                                                                                  |                                                                                                                                         |
| Flatten Current<br>Schematic (Flatten<br>Schematic) | Flattens at the current level<br>and all lower levels. RTL view:<br>flattens to generic logic level<br>Technology view: flattens to<br>technology-cell level | Flattens only non-hidden<br>transparent hierarchical<br>instances; opaque and<br>hidden hierarchical<br>instances are not<br>flattened. |
| RTL -> Flattened View                               | Creates a new, unfiltered RTL<br>schematic of the entire<br>design, flattened to the level<br>of generic logic cells.                                        |                                                                                                                                         |
| Technology -><br>Flattened View                     | Creates a new, unfiltered<br>Technology schematic of the<br>entire design, flattened to the<br>level of technology cells.                                    |                                                                                                                                         |

| Command                                     | Unfiltered Schematic                                                                                                                                                                                                                                                         | Filtered Schematic |
|---------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------|
| Technology -><br>Flattened to Gates<br>View | Creates a new, unfiltered<br>Technology schematic of the<br>entire design, flattened to the<br>level of Boolean logic gates.<br>Creates a filtered, flattened<br>Technology view schematic<br>that shows only the instances<br>with the worst slack times<br>and their path. |                    |
| Technology -><br>Flattened Critical Path    | Creates a new, unfiltered<br>Technology schematic of the<br>entire design, flattened to the<br>level of Boolean logic gates.<br>Creates a filtered, flattened<br>Technology view schematic<br>that shows only the instances<br>with the worst slack times<br>and their path. |                    |
| Unflatten Schematic                         | Undoes any flattening done<br>by Dissolve Instances and<br>Flatten Current Schematic at<br>the current schematic level.<br>Returns to the original<br>schematic, as it was before<br>flattening (and any filtering).                                                         |                    |

### **Crossprobing Across Views**

You can crossprobe between HDL Analyst views, the Text Editor, the Tcl window, and the FSM viewer, because the views are tightly linked to your code. Double-clicking on a component in a HDL Analyst view takes you to the section of code from which it was generated. If you double click a mux, you open the section of code from which it was generated. In this example, the mux is generated from the VHDL case statement shown.



Conversely, you can select a section of code from the Text Editor and the corresponding RTL gates for that code are highlighted in the RTL view. You must first have an RTL view open. Then, select the code in the source file. You can crossprobe from any text file, for instance, place-and-route files.

To see just the structures that correspond to the selected code on one sheet, click Filter icon. This isolates the selected structures on one schematic sheet. Click the Back icon to return to the previous view.

### **Cross-tool Crossprobing**

The Synplify Pro software allows easy crossprobing between Synplify Pro processes and several other third-party tools:

• Altera Quartus Place & Route software allows bidirectional crossprobing between Quartus II Floorplanner and the Synplify Pro synthesis tool's HDL Analyst tool.

• Xilinx Place & Route software allows crossprobing from the Xilinx timing file (.twr) to the HDL Analyst tool.

The Synplify Pro software also crossprobes between Synplify Pro processes. When two copies of the Synplify Pro tool are running simultaneously on one machine, enabling crossprobing allows both HDL Analyst tools to communicate with each other. For example, if external crossprobing is engaged and the same design is open in two copies of the software, selecting an instance in the HDL Analyst tool in one copy of the Synplify Pro tool results in the same instance being highlighted in the HDL Analyst tool of the second Synplify Pro tool.

### **Other Options**

There are a number of useful options you can set using the Options -> HDL Analyst Options command. For example, you can view cell interiors in the Technology view, like the LUTs in this figure:



You can copy images from any schematic view to the clipboard. To do so, open a schematic view, and select Edit -> Copy Image. The cursor changes to a camera. Hold down the left button and drag the cursor to define the rectangular area you want to capture, and then release the button. The image is copied to the clipboard.

### **Mouse Strokes**

To access several frequently used menu commands, you can use the mouse while holding down the right mouse button as you draw the pattern. The mouse strokes you draw are interpreted on an invisible grid of one or three rows, depending on the stroke.



For information about all the mouse strokes, select Help -> Mouse Stroke Tutor.

## Use FSM Viewer

The FSM (finite state machine) viewer is a graphic analysis tool that displays state transition bubble diagrams and implementation information for FSMs in the design. You can use this viewer to view state machines implemented by either the FSM Compiler or the FSM Explorer.

- 1. To start the FSM viewer, open the RTL view and either
  - Select the FSM instance, click the right mouse button and select View FSM from the popup menu.
  - Push down into the FSM instance using the Push/Pop icon or the command from the popup menu.

The FSM viewer opens. The viewer consists of a transition bubble diagram and a table for the encoding and transitions.

2. The following table summarizes basic analysis operations.

| To View                                                                              | Do this                                                                                                      |
|--------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------|
| From and to states, and conditions for each transition                               | Click the Transitions tab at the bottom of the table.                                                        |
| The correspondence between the states<br>and the FSM registers in the RTL view       | Click the RTL Encoding tab.                                                                                  |
| The correspondence between the states<br>and the registers in the Technology<br>View | Click the Mapped Encodings tab<br>(available after synthesis).                                               |
| Only the transition diagram without the table                                        | Select View -> FSM table or click the FSM<br>Table icon. You might have to scroll to<br>the right to see it. |

This figure shows you the mapping information for a state machine. The Transitions tab shows you simple equations for conditions for each state. The RTL Encodings tab has a State column that shows the state names in the source code, and a Registers column for the corresponding RTL encoding. The Mapped Encoding tab shows the state names in the code mapped to actual values.

| SP FSI | ₩ Viewer - cui           | r_state[6:0]                    | counter                            | 12           | StapSerand<br>StapFrst |             |              |              |           | Bubble Dia   | gram |
|--------|--------------------------|---------------------------------|------------------------------------|--------------|------------------------|-------------|--------------|--------------|-----------|--------------|------|
|        | From State               | To State                        |                                    |              | Condition              |             |              | _            |           |              |      |
| 2      |                          | 1 1 7 1                         | p&!Start&!Reset                    |              |                        |             |              |              | 4         |              |      |
| 3      |                          |                                 | ap&IStart&IReset                   |              |                        |             |              |              |           |              |      |
| 4<br>5 |                          | StopSecond La<br>StopSecond Sta | p&!Start&!Reset                    |              |                        |             |              |              |           |              |      |
|        |                          |                                 | gs A Mapped Enco                   |              |                        |             |              | •            |           |              |      |
| 4 1    | Transitions /            |                                 | gs 👗 Mapped Enco                   | dings / 📕    |                        |             |              |              |           |              |      |
|        | •                        |                                 |                                    |              |                        | _           |              |              |           |              |      |
|        | From State               | To State                        |                                    |              | Condition              |             |              |              |           |              |      |
| 1      | LapDisplay               | LapDisplay                      | Laplevel&!Reset                    |              |                        | _           |              | 1            |           |              |      |
| 2      | Zero                     | LapDisplay                      | Lap&!Start&!Reset                  |              |                        | _           |              |              |           |              |      |
| 3      |                          |                                 | !Lap&!Start&!Reset                 |              |                        | _           | State        | Register     |           |              |      |
| -      | StopFirst                | · ·                             | Lap&!Start&!Reset                  |              |                        | _           | Zero         | cur_state[0] |           |              |      |
| 5      | CountCont                | · ·                             | Start&!Reset                       |              |                        | _           | CountFirst   | cur_state[1] |           |              |      |
| ;      | StopSecond               | · ·                             | Lap&!Start&!Reset                  |              |                        | _           |              | cur_state[2] |           |              |      |
| ;      | StopDiff                 | StopDiff                        | Lap&Start&Reset                    |              |                        | _           |              | cur_state[3] |           |              |      |
|        | StopFirst                | StopFirst                       | ILap&IStart&IReset<br>Start&IReset |              |                        | -           |              | cur_state[4] |           |              |      |
| 9      | CountFirst<br>StopSecond | StopFirst                       | Start&Reset                        |              |                        | _           | StopSecond   |              |           |              |      |
| 0      |                          | Councon                         | Startoineset                       |              |                        |             | LapDisplay   | cur_state[6] |           |              |      |
|        |                          |                                 |                                    |              |                        |             |              |              |           |              |      |
|        |                          |                                 |                                    |              |                        |             |              |              |           | 1            |      |
|        |                          | State                           | cur_state[6]                       | cur_state[5] | cur_state[4]           | cur_sta     | te[3] cur_st | ate[2] cur   | _state[1] | cur_state[0] |      |
|        |                          | Zero                            | 0                                  | 0            |                        | 0           | 0            | 0            |           | 1            |      |
|        |                          | CountFirs                       |                                    | 0            | 0                      | 0           | 0            | 1            |           | 0            |      |
|        |                          | CountCon                        |                                    | 0            | 0                      | 0           | 1            | 0            |           | 0            |      |
|        |                          | StopFirst                       | 0                                  | 0            | 0                      | 1           | 0            | 0            |           | 0            |      |
|        |                          |                                 | -                                  | 0            | 4                      | ~           | 0            | 0            |           | 0            |      |
|        |                          | StopDiff                        | 0                                  | 0            | 1                      | 0           | 0            | 0            |           | 0            |      |
|        |                          |                                 | 0<br>ond 0                         | 0<br>1<br>0  | 1<br>0<br>0            | 0<br>0<br>0 | 0<br>0<br>0  | 0            |           | 0            |      |

3. To view just one state, click the bubble for the state to select it. Then click the right mouse button and select the filtering criteria from the popup menu: output, input, or any transition.

The transition diagram now shows only the filtered states you set. The following figure shows filtered views for output and input transitions for one state.



Similarly, you can check the relationship between two or more states by selecting the states, filtering them, and checking their properties.

4. To view properties for a state, select the state, click the right mouse button, and select Properties from the popup menu. A form shows you the properties for that state.

To view properties for the entire state machine like encoding style, number of states, and total number of transitions between states, deselect any selected states, click the right mouse button outside the diagram area, and select Properties from the popup menu.

5. To crossprobe from the FSM viewer, open the view to which you want to crossprobe (source code file for example) and click the state bubble in the FSM viewer.

The software highlights the corresponding object or code in the open view. You can also crossprobe from the transition table if you use a onehot encoding style. With all other styles, you cannot crossprobe from the transition table because the number of registers in the table may not match the number of registers in the RTL or Technology views. A one-toone correspondence might not exist because of optimizations during synthesis.

## Other Tools to Validate Synthesis Results

Validate Synplify Pro synthesis results with the following tools:

- Use Formal Verification
- Use syn\_probe Attribute, on page 5-21
- Identify RTL debugger, on page 5-21

### **Use Formal Verification**

For certain Xilinx technologies, you can validate your results using the Cadence Conformal LEC tool. See the application note at www.synplicity.com/literature for more information. The following figure is an overview of the flow.



6. Validate Synthesis Results with Simulation

You can optionally generate a post-synthesis netlist file in Verilog (.vm) or VHDL (.vhm) format. This is a structural netlist of the synthesized design, and differs from the original RTL you used as input for synthesis.

Typically, you use this netlist for gate-level simulation, to verify your synthesis results. Some designers prefer to simulate before and after synthesis, and also after place and route. This approach helps to isolate the stage of the design process where a problem occurred.

### Use syn\_probe Attribute

The syn\_probe attribute works as a debugging aid, inserting probe points for testing and debugging the internal signals of a design without HDL source modification.

### Identify RTL debugger

The Identify product is the first and only software tool that allows FPGA designers and ASIC prototyping designers to functionally debug their hardware directly in their RTL source code. This allows functional verification with RTL designs 10,000 times faster than RTL simulators, and enables the use of in-system stimulus for applications like networking, audio and video, and hardware/software designs. Identify software allows designers to directly select signals and conditions in their RTL source code. The Identify tool can also save results in standard VCD format that can be used with most waveform viewers. See *Using Identify with Synplify Pro*, on page 10-5 for more information.

### CHAPTER 6

# **Specify Directives and Attributes**

Directives and attributes influence the way your design is synthesized (compile stage) and optimized (map stage), respectively, and can be used to improve design quality of results (QoR). Refer to the following topics:

- Using Directives and Attributes
  - syn\_maxfan
  - syn\_keep
  - syn\_ramstyle

## Using Directives and Attributes

Directives must be specified in the HDL source code because they affect the compile stage and the inference of high-level structures. Attributes can be specified using any of the following methods:

- source code
- the SCOPE interface
- Tcl constraint file (.sdc)
- RTL or Technology views (right-click for pop-up menu)

There are two classes of attributes: target-specific attributes and general attributes. For details about directives and attributes, select Help -> Help, and then scroll down to the section shown below. It is strongly advised that you review this section of help. For discussions of target-specific attributes, check the help section on your target technology.

| 🖨 🛄 Synplicity FPGA Reference Manual  |  |
|---------------------------------------|--|
| ⊕ Product Overview                    |  |
| 🕂 User Interface Overview             |  |
| 🗄 - User Interface Commands           |  |
| ⊡ • Input and Result Files            |  |
| ter Tel Commands and Scripts          |  |
| ⊕- HDL Analyst Tool                   |  |
| ⊕- SCOPE and Timing Constraints       |  |
| ⊕ Synthesis Attributes and Directives |  |
| Li Vicilia Longuago Support           |  |

A few commonly used attributes and directives are described below.

### syn\_maxfan

Sets a guide for maximum fanout. You can set this globally from the Implementation Options dialog box, or set it on individual modules. The following figure shows the syn\_maxfan attribute entered in the SCOPE Attributes pane for an individual module:

|   | Enabled | Object Type | Object       | Attribute  | ¥alue | Val Type   | Description                  | Comment |  |
|---|---------|-------------|--------------|------------|-------|------------|------------------------------|---------|--|
| 1 | •       | <any></any> | Data_1[11:0] | syn_maxfan | 0     | integer    | Overrides the default fanout |         |  |
| 2 |         |             |              |            |       |            |                              |         |  |
| 3 |         |             |              |            |       |            |                              |         |  |
|   |         |             |              |            |       | Attributes |                              |         |  |

#### Attributes

### syn\_keep

Preserves the specified net from being optimized away during synthesis. The software places a temporary buffer on the net as a placeholder so that it is not optimized. You can view this buffer in the HDL Analyst views, but it is not in the final netlist.



### syn\_ramstyle

Determines how inferred RAMs are implemented. The valid values vary depending on the target technology family. You can turn off RAM inference by setting the value of this attribute to registers.

### CHAPTER 7

# **Basics of Timing Constraints**

Synplify Pro synthesis is timing-based. Its algorithms are governed by the timing requirements of your design as set by the constraints, attributes and directives you specify. The more precise the timing information you provide, the better the results produced.

Refer to the following topics:

- Specifying Timing Information
- Clock Descriptions
- Clock Groups
- Rise and Fall Constraints
- Input and Output Delays
- Multicycle Paths
- I/O Standard

## **Specifying Timing Information**

The following are some of the ways in which you provide timing information to the Synplify Pro tools (use the tabs in the SCOPE UI):

• Clock definitions For designs with multiple clocks, use a combination of individual clock constraints and a default global frequency to define all the clocks in your design accurately. See *Clock Descriptions*, on page 7-2 for an explanation. Clock domains

Assign unrelated clocks to separate clock groups. Clocks that are in the same clock group are considered to be related and affect timing calculations. See *Clock Groups*, on page 7-5 for more information. Use Rise and Fall values to define relationships between source and destination clocks. See *Rise and Fall Constraints*, on page 7-6 for details.

- Multicycle paths and false paths If your design has multicycle paths or false paths that you do not want the Synplify Pro tool to consider during timing based synthesis, you may identify these in the constraints file. The software considers paths to asynchronous sets and resets as false paths, so you do not have to constrain these paths explicitly.
- Resource sharing

Turn this OFF to get better circuit performance. When OFF, the tool does not share the arithmetic modules in your design across multiple functions.

- Symbolic FSM (finite state machine) compiler Turn this ON to get better circuit performance. When on, the synthesis software looks for state machines in your design, analyzes and optimizes them, and encodes them based on size.
- FSM Explorer

Turn this ON to get better circuit performance. When on, the FSM Explorer tries different encoding styles and picks the best style for the state machine based on overall design constraints.

## **Clock Descriptions**

You must accurately describe timing in your design, because it can significantly impact what the software considers the most critical path. The most important information you can provide is the performance of each clock in your design, including the top-level clocks, derived clocks, gated clocks, or other signals in your design acting as clocks.

Set a global frequency. The software applies this default frequency to all clocking signals that you have not specifically identified with individual clock constraints.

**Note:** Do not over-constrain your clocks. Keep the value within 5%-10% of the actual target.

Here is an example of some clocking situations.

### Example

This design has two top-level clocks, clk and ins\_clk. When the constraint file is initialized, the SCOPE interface shows both clocks assigned the default frequency of 8MHz. Setting the default to a small value allows parts of the design that are not timing-critical to be optimized for area.

|     | Enabled | Clock Object | Clock Alias | Frequency<br>(MHz) | Period<br>(ns) | Clock Group        | Rise At<br>(ns) | Fall At<br>(ns) | Duty Cycle<br>(%) | Route<br>(ns) | F |
|-----|---------|--------------|-------------|--------------------|----------------|--------------------|-----------------|-----------------|-------------------|---------------|---|
| 1   | ◄       | clk          |             | 8                  | 125            | default_clkgroup_0 |                 |                 |                   |               |   |
| 2   | •       | ins_clk      |             | 8                  | 125            | default_clkgroup_1 |                 |                 |                   |               |   |
| 3   |         |              |             |                    |                |                    |                 |                 |                   |               | • |
| •   |         |              |             |                    |                |                    |                 |                 |                   |               |   |
| Clo | icks    |              |             |                    |                |                    |                 |                 |                   |               |   |

Now set clk and ins\_clk to the frequencies you want and enable the constraints.

|   | Enabled | Clock Object | Clock Alias | Frequency<br>(MHz) | Period<br>(ns) | Clock Group        | Rise At<br>(ns) | Fall At<br>(ns) | Duty Cycle<br>(%) | Route<br>(ns) |    |
|---|---------|--------------|-------------|--------------------|----------------|--------------------|-----------------|-----------------|-------------------|---------------|----|
| 1 | •       | clk          |             | 75                 | 13.3333        | default_clkgroup_0 |                 |                 |                   |               |    |
| 2 | •       | ins_clk      |             | 33                 | 30.303         | default_clkgroup_1 |                 |                 |                   |               |    |
| 3 |         |              |             |                    |                |                    |                 |                 |                   |               | •  |
|   |         |              |             |                    |                |                    |                 |                 |                   | ••            |    |
|   | ocks    |              |             |                    |                |                    |                 |                 |                   |               | •• |

The design includes three other clocking situations: a divided clock off a register, a gated clock, and some unregistered clock logic. The default frequency of 8MHz is applied to the unregistered logic, and the log file reports it as a system clock (System).

| Starting Clock          | Requested<br>Frequency |
|-------------------------|------------------------|
| Clk                     | 75.0 MHz               |
| SPECIAL_REGS.gatedclock | 10.0 MHz               |
| UC_ALU.halfclk          | 25.0 MHz               |
| ins_clk                 | 33.0 MHz               |
| System                  | 1.0 MHz                |

To identify the divided clock for the software, locate the register in the RTL view (see *RTL View*, on page 5-4 for a description). Drag and drop or type the name of the register into the SCOPE Clocks pane and specify a frequency that is half (37.5Mhz) of clk (75.0Mhz). When you type a name in the SCOPE interface, be sure to type the name accurately because the constraint file is written out in Tcl format, which is case-sensitive.



The gated clock is the most interesting clocking situation. To attach a clock to the signal coming off an inferred AND gate, attach a syn\_keep synthesis directive to the signal or wire. This directive does two things: it creates a virtual buffer (shown in the following figure) and it does not optimize the net. The virtual buffer provides a "synthesis handle" to which you can attach attributes like clock definitions or multicycle paths. You can view this buffer in the RTL view (the schematic view generated after the compile stage) and drag-and-drop it into the SCOPE spreadsheet if you need to attach a constraint to it.



By preventing an internal net from being optimized away, the syn\_keep directive guarantees that the net name is maintained. This can be helpful for probing internal nets or to prevent nets from being optimized.

## **Clock Groups**

The timing engine uses clock groups to define clocking schemes. It assumes that clocks in the same clock group are synchronized with each other and treats them as related clocks. Typically, clocks in a clock group are derived from the same base clock. The timing analyzer automatically calculates the relationships between clocks in a clock group and analyzes all paths between them. It calculates the time available based on the periods of two related clocks.

The waveforms in the following figure show how the software determines the worst posedge-to-posedge timing between clocks CLK1 and CLK2. All paths that begin at CLK1 rising and end at CLK2 rising are constrained at 10ns.



Conversely, clocks in different clock groups are considered unrelated or asynchronous. Paths between clocks from different groups are automatically marked as false paths and ignored during timing analysis and optimization.

By default, all clocks in a design are assigned to separate clock groups and named default\_clkgroup<n>. If clocks are related, you must re-assign them to the same clock group using the Clock Group field in the SCOPE interface. See *Using Multiple Clock Domains*, on page 10-3 for more information.

## **Rise and Fall Constraints**

By default, the Synplify Pro tool assumes an ideal clock network; the clock arrives at all clocked registers at the time specified in the Rise and Fall fields. By default, the constraints assume a 50% duty cycle clock with the rising edge at 0 and the falling edge at period/2.

The synthesis tool computes relationships between the source clock and destination clock on a path by using the Rise and Fall numbers. To understand how the relationships between source and destination clocks are computed using the Rise and Fall numbers, consider the following example.

• Clk1 is a clock with a period of 10 ns in clock group default\_clkgroup. Since none of the other fields are specified, this is a 50% duty cycle clock rising at 0 and falling at 5. There is no propagation delay between the clock source and the clock ports on the registers clocked by Clk1.



- Clk2 is a 200 MHz (5ns) clock, also in the default\_clkgroup. This means that the timing analyzer considers all paths from Clk1 to Clk2 and from Clk2 to Clk1.
- Clk3 is a clock with a period of 20 ns in clkgrp2. This means all paths between Clk3 and either Clk1 or Clk2 are automatically treated as false paths. In addition, Clk3 has a Rise of 0 and a Fall of 12, which means it has a 60% duty cycle.



• Clk4 is a virtual clock. This means that there can be no port or instance named Clk4 in this design. However, there may be top-level ports on the

chip which are clocked by Clk5 outside the chip. Input arrival times and output required times for such ports can be specified relative to Clk5.

## Input and Output Delays

It is important to understand the role of input and output delays as they apply to Synplify Pro synthesis. You need to recognize which constraint is most effective in a given situation: a synthesis or place-and-route constraint.

The Synplify Pro engine can minimize logic between an input and a register or between a register and an output. If there is no logic between these points, the synthesis engine cannot affect the constraint. In this case, it would be better to use a place-and-route constraint to minimize the routing between the two points.

The log file contains a section for the interface. It reports required times, arrival times, slack, and user constraint information for inputs and outputs according to the register that they are driving or driven by, and the clock which controls that register.

### **Input Ports**

A typical log file report for input ports looks like the one below. Let's take a closer look at how the numbers are calculated and see how you can influence them with an input\_delay constraint.



In the following example, data1[0] feeds a register that is controlled by clk (the reference clock). The period for clk is set at 10ns, so data1[0] is required to arrive at the input a certain time after the controlling edge of clock so that it can propagate to the register in time for the next controlling edge. The required time is determined as follows:

```
Required Time = Clock Period - (intrinsic + setup time)
```



Add an input delay of 3ns to data1[0]. Do this in the SCOPE Inputs/Outputs pane:

|   | Enabled | Port                         | Туре         | Clock Edge | Value<br>(ns) | Route<br>(ns) | Comment |
|---|---------|------------------------------|--------------|------------|---------------|---------------|---------|
| 1 | •       | data[1:]                     | input_delay  |            | 3             |               |         |
| 2 |         | <output default=""></output> | output_delay |            |               |               |         |

This constraint indicates that data1[0] arrives 3ns later than the default 0ns. This reduces the slack margin available. When you resynthesize, the log file reflects these changes.



### **Output Ports**

A typical log file report for output ports looks like the one below. Look at how the numbers are calculated and see how you can influence them with an output\_delay constraint. The required time is derived from the period of the reference clock for the register minus any user delay. The arrival time is the clock to output time plus intrinsic delay. The slack then is the required time minus the arrival time.



In the following example, initially the required time is equal to the clock period, because no user constraint is set. The arrival time of 3.7ns is the sum of the clock-to-output delay and the intrinsic delay, leaving a slack margin of 6.3ns.



Add a 3 ns output delay constraint using the SCOPE Inputs/Outputs pane:

|   | Enabled | Port     | Туре         | Clock Edge | Value<br>(ns) | Route<br>(ns) | Comment |
|---|---------|----------|--------------|------------|---------------|---------------|---------|
| 1 | •       | data[1:] | output_delay |            | 3             |               |         |
| 2 |         |          |              |            |               |               |         |

The result of the output\_delay constraint is to reduce the required time, thus reducing the available slack. The resulting log file change is shown below:



## **Multicycle Paths**

The multicycle path constraint identifies certain paths that take multiple clock cycles to complete and which you should exclude from single-clock-cycle based synthesis. You can specify a multicycle path from an origination register (from), to a destination register (to), or as passing through a net (through). By setting the cycle multiplier to a high value (e.g. 100), you identify the false paths to be ignored.

You set a multicycle path constraint from the SCOPE Path Delays tab, by selecting a Delay Type of Multicycle. You can use one of the following methods to specify the register or net: drag-and-drop it from an RTL view, select from the cell pulldown menu, or manually type in the full hierarchical name. Regard-less of whether you are coding VHDL or Verilog, all SCOPE names are case-sensitive because the constraints are recorded in Tcl, which is case-sensitive. The following figure shows a from-to multicycle constraint.

|   | Enabled | Delay Type | From             | То            | Through    | Start/End | Cycles | Max Delay(ns) |
|---|---------|------------|------------------|---------------|------------|-----------|--------|---------------|
| 1 | •       | Multicycle | i:dmux.alua[7:0] | i:uc_alu.aluz |            |           | 2      |               |
| 2 |         |            |                  |               |            |           |        |               |
| 3 |         |            |                  |               |            |           |        |               |
| • |         |            |                  |               |            |           |        | ( )<br>( )    |
| _ |         |            |                  | D             | elay Paths |           |        |               |

You can also edit constraints (\*.sdc file) with a text editor. To do so, select the file in the Project window, right-click, and select Edit as Text from the popup menu.

### **Setting Multicycle Path Constraints**

To and from constraints are the simplest to set because they start or end at a register. The following example shows how to set a multicycle path through constraint. The filtered RTL view generated after the compilation stage shows a partial circuit where the signals all propagate to the register Dmux.ALUB in one clock cycle. However, reg\_fout is allowed two clock cycles. If this causes the Synplify Pro tool to identify the path from reg\_fout to ALUB as a critical path, you must define the two-cycle propagation correctly for the tool. You cannot define the multicycle path with a to constraint on Dmux.ALUB, because this would cause the other signals to be allowed two clock cycles, which is not correct.



Instead, to single out the specific two-cycle path, use a through constraint on the reg\_fout net highlighted above in addition to the from and to points. Make sure you precede the net name with an n: (to identify the object as a net) if you type it manually in the SCOPE interface.

# I/O Standard

Available for certain technology families, you can use the I/O Standards panel of the SCOPE interface to specify a standard I/O pad type to use in the design. See help in the tool for information.

#### CHAPTER 8

# Analyze Timing Results

There are many tools to analyze the timing of your design:

- Critical Path Report
- Timing Information Display
- Critical Path Analysis in a Technology View

## **Critical Path Report**

You can check details of the critical path in the log file.

- Note the start and end points of the critical path. For multi-clock designs, look for the clock with the worst slack.
- Check fanout. To limit fanout on a given net, use the syn\_maxfan attribute. When enabled, the synthesis software replicates logic to reduce the fanout. For an example of adding an attribute, see Specify Directives and Attributes.

The following figure shows a critical path in the log file.

| Path information for path number | 1:    |              |                    |             |              |     |  |  |
|----------------------------------|-------|--------------|--------------------|-------------|--------------|-----|--|--|
| - Setup time:                    | 0.392 |              |                    |             |              |     |  |  |
| = Required time:                 |       | 6.275        |                    |             |              |     |  |  |
|                                  |       |              |                    |             |              |     |  |  |
| - Propagation time:              |       | 7.914        |                    |             |              |     |  |  |
| = Slack (non-critical) :         |       | -1.639       |                    |             |              |     |  |  |
| Chambin and and                  |       | Der en Certe | PromCntr.PC[7] / Q |             |              |     |  |  |
| Starting point:                  |       |              |                    |             |              |     |  |  |
| Ending point:                    |       |              |                    | ST[0] / D   |              |     |  |  |
| The start point is clocked h     |       | -            | sing] on           | -           |              |     |  |  |
| The end point is clocked h       | Ϋ́Υ   | SPECIAL      | _REGS.ga           | седстоск [: | rising] on p | int |  |  |
| Instance / Net                   |       | Pin          | Pin                |             | Arrival      | Fan |  |  |
| Name                             | Type  | Name         | Dir                | Delay       | Time         | Out |  |  |
|                                  |       |              |                    |             |              |     |  |  |
| PrgmCntr.PC[7]                   | FD PE | Q            | Out                | 1.995       | 1.995        |     |  |  |
| pc[7]                            | Net   |              |                    |             |              | 3   |  |  |
| ROM.G_464                        | LUT4  | Il           | In                 |             | 1.995        |     |  |  |
| ROM.G_464                        | LUT4  | 0            | Out                | 1.471       | 3.465        |     |  |  |
| G_464                            | Net   |              |                    |             |              | 4   |  |  |
| ROM.N 8 i                        | LUT3  | IO           | In                 |             | 3.465        |     |  |  |
| ROM.N 8 i                        | LUT3  | 0            | Out                | 1.992       | 5.457        |     |  |  |
| N 8 i                            | Net   |              |                    |             |              | 12  |  |  |
| ROM.dataien0 2comp0tri0          | BUFT  | Т            | In                 |             | 5.457        |     |  |  |
| ROM.dataien0_2comp0tri0          | BUFT  | 0            | Out                | 1.111       | 6.567        |     |  |  |
| romdata[0]                       | Net   |              |                    |             |              | 4   |  |  |
| SPECIAL_REGS.inst_3_0_and4[0]    | LUT4  | IO           | In                 |             | 6.567        |     |  |  |
| SPECIAL_REGS.inst_3_0_and4[0]    | LUT4  | 0            | Out                | 1.347       | 7.914        |     |  |  |
| inst 3[0]                        | Net   |              |                    |             |              | 2   |  |  |
| SPECIAL_REGS.INST[0]             | FDC   | D            | In                 |             | 7.914        |     |  |  |
|                                  |       |              |                    |             |              |     |  |  |
| 4                                |       |              |                    |             |              |     |  |  |

You can also use the Log Watch window to quickly check parameters like Worst Slack, Requested Frequency, Estimated Frequency, and so on. To view the critical path graphically, use the procedure described in Generate a Technology View for the Most Critical Path.

# **Timing Information Display**

To help you analyze timing, enable HDL Analyst -> Show Timing Information in a Technology view. This annotates all instances, showing their timing numbers. Two timing numbers are displayed above each instance:

| Delay<br>(first<br>number)          | For combinational logic, delay is the cumulative path delay to the<br>output of the instance, which includes the net delay of the output.<br>For flip-flops, delay is the portion of the path delay attributed to the flip-<br>flop. The delay can be associated with either the input path or the<br>output path, whichever is worse, because the flip-flop is the end of one<br>path and the start of another. |
|-------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Slack<br>Time<br>(second<br>number) | This is the slack time of the worst path that goes through the instance.<br>A negative value indicates that timing constraints could not be met. The<br>command Show Critical Path uses the slack time, together with the slack<br>margin, to determine which instances to display.                                                                                                                              |

# Critical Path Analysis in a Technology View

This section describes the critical path views and how to analyze critical paths:

- Critical Path Views
- Generate a Technology View for the Most Critical Path
- Generate Critical Path View in the Timing Analyzer
- Generate Critical Path View from the Log File
- Critical Path Report

#### **Critical Path Views**

The HDL Analyst tool makes it simple to find and examine critical paths and the relevant source code. Display the most critical path in the Technology view, using one of the following methods. The Technology view displays a hierarchical view that highlights the instances and nets in the most critical path of your design.

- To generate a hierarchical view of the critical path, click the Show Critical Path icon (stopwatch icon ), select HDL Analyst -> Technology -> Hierarchical Critical Path or select the command from the popup menu. The view displayed is a filtered view in the same window, with hierarchical logic shown in transparent instances.
- To flatten the hierarchical critical path described above, right-click and select Flatten Schematic. The software generates a new view in the current window, and flattens only the transparent instances needed to show the critical path; the rest of the design remains hierarchical. Click Back to go the top-level design.
- To generate a flattened critical path in a new window, select HDL Analyst -> Technology -> Flattened Critical Path. This uses more memory because it flattens the entire design and generates a new view for the flattened critical path in a new window. Click Back in this window to go to the flattened top-level design, or return to the previous window.

#### Generate a Technology View for the Most Critical Path

This is the easiest way to generate a technology view for the most critical path:

- 1. Generate a Technology view.
- 2. Select the Show Critical Path icon from the toolbar.

This filters the critical path and displays timing numbers above each element. The critical path is the path with the worst (most negative, or smallest positive) slack of all your clock domains. If you have three clock domains and the worst clock domain has a slack of -2.4ns, this is the path that is displayed in the Technology view. The timing numbers above each element are the cumulative delay through that point, including estimated routing delay based on fanout.



3. Analyze the critical path.

#### Generate Critical Path View in the Timing Analyzer

Use the Timing Analyzer to generate views for any critical path or for point-topoint analysis between registers without re-running synthesis.

Select the instances in a Technology view, then right-click and select Timing Analyst from the pop-up menu.



Set the appropriate information in the Timing Report Generation dialog box. Buses are grouped to reduce the number of signals shown. Buses cannot be split into their individual elements.

|                                                                                                          | Select the From and<br>if you did not presele |                     |
|----------------------------------------------------------------------------------------------------------|-----------------------------------------------|---------------------|
| STIMING Report Generation                                                                                | <u>?</u> ×                                    |                     |
| Filters From: PrgmCntr[8] Through: To: DECODE_FWE.fast Generate Asynchronous Clock Repor                 |                                               |                     |
| Limit Number of Critical Start/End Pol Limit Number of Paths To: Enable Slack-Margin (nc): Ø Open Report | Ints To: 5<br>5<br>Generate<br>Generate       | ) (3) Click         |
| Output Files<br>Async Clock Report File:<br>TA File:<br>SRM FIle:<br>C:\synplify_r                       | ro\tutorial\rev_1\eight_bit_uc_ta.srm         | ② Set these options |
| Constraint Files                                                                                         | File                                          |                     |

The software generates a critical path view and a timing report like the one below:

| Path information for path nu  | umber 1: |           |             |             |         |     |  |  |  |
|-------------------------------|----------|-----------|-------------|-------------|---------|-----|--|--|--|
| Requested Period:             |          |           | 40.000      |             |         |     |  |  |  |
| - Setup time:                 |          | 0.518     |             |             |         |     |  |  |  |
| = Required time:              |          | 39.482    |             |             |         |     |  |  |  |
| -                             |          |           |             |             |         |     |  |  |  |
| - Propagation time:           |          | 12.974    | 12.974      |             |         |     |  |  |  |
| = Slack :                     |          | 26.508    |             |             |         |     |  |  |  |
|                               |          |           |             |             |         |     |  |  |  |
| Starting point:               |          |           | DATAO[6]    |             |         |     |  |  |  |
| Ending point:                 |          |           | DATAO[7]    |             |         |     |  |  |  |
| The start point is clocked by |          |           |             | ising] on p |         |     |  |  |  |
| The end point is cloc         | prep2_3  | ZICLK [r: | ising] on p | in C        |         |     |  |  |  |
| Instance / Net                |          | Pin       | Pin         |             | Arrival | Fan |  |  |  |
| Name                          | Type     | Name      | Dir         | Delay       |         | Out |  |  |  |
|                               |          |           |             |             |         |     |  |  |  |
| instl.DATA0[6]                | FDC      | Q         | Out         | 2.712       | 2.712   |     |  |  |  |
| DATA0_internal[6]             | Net      |           |             |             |         | 3   |  |  |  |
| instl.compare_output_NE_4     | LUT4     | I1        | In          |             | 2.712   |     |  |  |  |
| instl.compare_output_NE_4     | LUT4     | 0         | Out         | 1.620       | 4.332   |     |  |  |  |
| compare_output_NE_4           | Net      |           |             |             |         | 1   |  |  |  |
| instl.compare_output_NE       | LUT4     | 12        | In          |             | 4.332   |     |  |  |  |
| instl.compare_output_NE       | LUT4     | 0         | Out         | 3.273       | 7.605   |     |  |  |  |
| DATA0_1cry                    | Net      |           |             |             |         | 18  |  |  |  |
| instl.DATA0_6[0]              | LUT4     | 12        | In          |             | 7.605   |     |  |  |  |
| instl.DATA0_6[0]              | LUT4     | 0         | Out         | 1.620       | 9.225   |     |  |  |  |
| DATA0_6[0]                    | Net      |           |             |             |         | 1   |  |  |  |
| instl.DATA0_qxu[0]            | LUT4     | Il        | In          |             | 9.225   |     |  |  |  |
| instl.DATA0_qxu[0]            | LUT4     | 0         | Out         | 1.890       | 11.114  |     |  |  |  |
| DATA0_qxu[0]                  | Net      |           |             |             |         | 2   |  |  |  |
| instl.DATA0_cry[0]            | MUXCY_L  | s         | In          |             | 11.114  |     |  |  |  |
| instl.DATA0_cry[0]            | MUXCY_L  | LO        | Out         | 0.899       | 12.013  |     |  |  |  |

#### Generate Critical Path View from the Log File

You can generate a view for any critical path listed in the log file with this method:

- 1. Open the RTL and Technology views. If you want to see details of the path, select HDL Analyst -> Technology -> Flattened View to open a flattened Technology view.
- 2. Select View Log and open the log file.
- 3. Scroll down to the critical path you want to view.
- 4. Hold down the Alt key and select the columns with the objects in the critical path.
- 5. Hold down the right mouse button and select Filter in Analyst. The objects in the critical path are highlighted in the log file and the critical path is selected in the open views.



#### CHAPTER 9

# **Refine Options to Improve Timing**

The vast majority of the time, you only need to identify the clocks and multicycle/false paths to get the best results.

- Occasionally, you might have to fine-tune the synthesis process (see *Refine Timing Results*, on page 9-1).
- You can also check your synthesis results against the place-and-route results and refine your synthesis constraints (see *Compare Synthesis Results with Place-and Route Results*, on page 9-2).
- In the MultiPoint flow, you can annotate incremental results after you resynthesize a compile point (see*Forward Annotate Incremental Results*, on page 9-4).

# **Refine Timing Results**

You can refine timing results in a few ways:

- Adjust the SCOPE timing constraints.
- Add attributes or directives, in the source code, in the SCOPE interface, or in a constraint file.
- Rework the RTL source code.

#### **Compare Synthesis Results with Place-and Route Results**

Synplify Pro synthesis is timing-driven, so it is important to ensure that the place-and-route and Synplify Pro tools are both working on the same critical path. You only need to follow the tips here if the design *does not* meet timing. The flowchart shows that your goal is a critical path correlation between the place-and-route (P&R) and Synplify Pro results. Follow these steps to check results.



- 1. Place and route the design and run timing analysis.
- 2. Check the critical path and note its start and end points.
- 3. Compare the P&R start and end points to the start and end points of the path generated after synthesis.

If P&R identifies a critical path from alu.dffa to decode.dffb while the Synplify Pro critical path goes from spec\_reg.dffr to dtc.dffc, you need to make sure that Synplify Pro optimization routines are concentrated on the same path as the P&R tool. You can do this by adding a route delay constraint.

#### Add Route Delay Constraints

The following example shows you how to add a route delay constraint.

- 1. Double-click the constraints file to open the SCOPE interface.
- 2. Go to the Registers pane, and add a small amount of incremental route delay to one of the registers on the critical path identified during P&R. The following figure shows the constraint applied to the end point in the previous example, decode.dffb.

|           | Enabled | Register    | Туре            | Route<br>(ns) | Comment |  |
|-----------|---------|-------------|-----------------|---------------|---------|--|
| 1         | ◄       | decode_dffb | reg_input_delay |               |         |  |
| 2         |         |             |                 |               |         |  |
| 3         |         |             |                 |               |         |  |
| Registers |         |             |                 |               |         |  |

Do not overload the path. Keep the value of this constraint low, just enough to raise the criticality of this path so that Synplify Pro optimization focuses on this path. You can then place and route the design again and check results. Typically this process is only necessary once, occasionally twice.

## Forward Annotate Incremental Results

In the MultiPoint flow, you can annotate incremental results after you resynthesize a compile point.

- 1. Resynthesize the design:
  - Make the changes you need to fix errors or improve your design.
     Define any required constraints and set the proper implementation options.
  - Click Run to resynthesize the design.

When a design is resynthesized, compile points are not resynthesized unless source code logic, implementation options, or constraints have been modified. If there are no compile point interface changes, the software synthesizes the immediate parent using the previously generated model file for the compile point. The following figure illustrates this.



2. To force the software to generate a new model file for the compile point, select click Impl Options and enable Update Compile Point Timing Data. Click Run.

The software regenerates the model file for each compile point when it synthesizes the compile points. The new model file is used to synthesize the parent. The option remains in effect until you disable it.

- 3. To override incremental synthesis and force the software to resynthesize all compile points whether or not there have been changes made, use the Run -> Resynthesize All command.
- 4. Use the output files generated after synthesis to forward annotate incremental synthesis information to your place-and-route tool.

#### CHAPTER 10

# Additional Features and Topics

This section includes additional information to accompany your design flows. Topics include:

- Synplify Premier Physical Synthesis
- Synthesis Output Files
- Using Multiple Clock Domains
- Using Scripts and Batch Mode
- Using the Tcl Find Command for Setting Constraints
- Running Place and Route
- Using Identify with Synplify Pro
- For More Information

# Synplify Premier Physical Synthesis

The Synplify Premier tool, as with all Synplicity synthesis products, provides the capability to compile, synthesize and optimize a design. However, physical synthesis also provides the benefit of physical placement that is recognized by the tool during optimization. With access to physical information, the tool can correlate between front- and back-end environments and provide more accurate estimates than can be achieved through using standard wire load model synthesis. With the Synplify Premier tool, you can floorplan, place, and optimize a design based on physical constraints as well as timing constraints, and physical and technology libraries. The output is a fully-optimized netlist with an architecture and locations best suited for the design based on the floorplan, technology, and constraints. Analysis reports include a design summary, physical-based timing information, and congestion analysis. See Help in the tool or the section: *Physical Synthesis Design Flows* of the *User Guide*.

# Synthesis Output Files

This section lists the output files that are written to the results specified directory for the implementation (Implementation Options->Implementation Results tab).

- .areasrr—Reports area-specific information on each module in the design, such as sequential and combinational ATOMS, RAMs, DSPs, and black boxes.
- .edf—Output EDIF netlist. See *Output Netlist*, below, for more information.
- .fse —contains information about FSMs in the design.
- .htm—display report files in an HTML viewer that provides links for easier navigation to the various sections of the file.
- .info—design component files contain detailed information about components such as state machines or ROMs.
- .ncf—place-and-route constraints file.
- pfl—output file created when filtering messages in the Messages window.
- .sap—generated when you use the Annotated Properties for Analyst option and used by the Find command when searching for design properties.
- .srd—saves mapping information between synthesis runs; file is used internally by the tool.
- .srm—output by the mapper stage of the process, contains the actual technology-specific mapped design. This is the representation of the design displayed through the Technology view.
- .srr—synthesis log file that provides messages and information on the synthesis run as well as timing and area reports.

- .srs—output by the compiler stage of the process, contains the RTLlevel (schematic) view of the design. This is the representation displayed in the RTL view.
- .ta—stand-alone timing report that contains the timing parameters specified when using the Analysis->Timing Analyst command. You can also graphically display the results of this report using the ta.srm file.
- .tap— this file is generated when the Annotated Properties for Analyst switch is enabled (Implementation Options->Options tab) and is used to annotate timing properties for the RTL view, Design Planner and the Find command.
- ta.srm—contains the graphical representation of the stand-alone timing report (.ta) that you can display in the Technology view.
- .tasrr—timing analysis log file, output only when you run the standalone timing report program.
- .vif— verification interface format file that contains Tcl commands to forward annotate sequential optimizations for formal verification.

#### **Output Netlist**

The output netlist is usually written out as an EDIF file. However, the netlist can be written out in other formats appropriate to the technology and placeand-route tool that you are using, such as .acf or .vgm for Altera or the .edf format for Xilinx. Choose the format from the Implementation Options->Implementation Results tab (Result Format field).

To find information on the features specified in the sections below, you can use the online help system in the tool (Help-> Help, or F1), or the *User Guide* and *Reference Manual* (Help->Online Documents).

# **Using Multiple Clock Domains**

When using multiple clock domains in a design, you can define the relationship between clocks using the Clock Group parameter. By default, each clock is automatically assigned to a separate clock group (called default\_clkgroup<n>). Clocks in different clock groups are treated by the timing analyzer as unrelated, meaning any paths between them are treated as false paths and ignored during timing analysis. Clocks defined in the same clock group are assumed to be related and all timing paths between them are calculated during timing analysis. Also, by default, all inferred and other clocks that use the global frequency are assigned the same clock group. To group related clocks and separate unrelated clocks, use the SCOPE editor ->Clocks tab-> Clock Group parameter.

See Help in the tool or the section: *Defining Clocks->Defining Other Clock Requirements* of the *User Guide*.

## Using Scripts and Batch Mode

You can create scripts for running synthesis projects to run in batch mode. See Help in the tool or the sections: *Using Batch Mode* and *Working with Tcl Scripts and Commands* of the *User Guide*.

# Using the Tcl Find Command for Setting Constraints

Use the Tcl find command to search for design objects and properties, such as registers, clocks parameters, ports, and so on. You can group the search results into collections, and use these collections to apply constraints to the different design objects. See Help in the tool or the sections:

- Tcl find Command of the Reference Manual,.
- Using Collections of the User Guide.

# **Running Place and Route**

You can create a place-and-route implementation that will launch from within the tool or from batch mode following the synthesis run. See Help in the tool or the section: *Running Place and Route After Synthesis* of the *User Guide*.

# Using Identify with Synplify Pro

The Synplicity Identify RTL Debugger is a dual-component system that consists of an Identify Instrumentor that allows you to select a design instrumentation at the HDL level, then create an on-chip hardware probe, and the Identify Debugger tool that interacts with the on-chip hardware probe and from which you can interactively debug the design. The combination of these tools allows you to probe the HDL design in the target environment and debug the design faster, and more efficiently.

See Help in the tool or the section: *Working with the Identify RTL Debugger* of the *User Guide*.

## For More Information

- The Synplicity documentation set is available in the tool through the integrated help system (Help->Help) and PDF documents accessible through Help->Online Documents.
- Synplicity Technical Support:

http://www.synplicity.com/support

• Synplicity online training:

http://www.synplicity.com/training