Xilinx Vivado Design Suite User Guide: Implementation (UG904)

Total Page:16

File Type:pdf, Size:1020Kb

Load more

Vivado Design Suite User Guide Implementation UG904 (v2012.4) December 18, 2012 Notice of Disclaimer The information disclosed to you hereunder (the “Materials”) is provided solely for the selection and use of Xilinx products. To the maximum extent permitted by applicable law: (1) Materials are made available "AS IS" and with all faults, Xilinx hereby DISCLAIMS ALL WARRANTIES AND CONDITIONS, EXPRESS, IMPLIED, OR STATUTORY, INCLUDING BUT NOT LIMITED TO WARRANTIES OF MERCHANTABILITY, NON-INFRINGEMENT, OR FITNESS FOR ANY PARTICULAR PURPOSE; and (2) Xilinx shall not be liable (whether in contract or tort, including negligence, or under any other theory of liability) for any loss or damage of any kind or nature related to, arising under, or in connection with, the Materials (including your use of the Materials), including for any direct, indirect, special, incidental, or consequential loss or damage (including loss of data, profits, goodwill, or any type of loss or damage suffered as a result of any action brought by a third party) even if such damage or loss was reasonably foreseeable or Xilinx had been advised of the possibility of the same. Xilinx assumes no obligation to correct any errors contained in the Materials or to notify you of updates to the Materials or to product specifications. You may not reproduce, modify, distribute, or publicly display the Materials without prior written consent. Certain products are subject to the terms and conditions of the Limited Warranties which can be viewed at http://www.xilinx.com/warranty.htm; IP cores may be subject to warranty and support terms contained in a license issued to you by Xilinx. Xilinx products are not designed or intended to be fail-safe or for use in any application requiring fail-safe performance; you assume sole risk and liability for use of Xilinx products in Critical Applications: http://www.xilinx.com/warranty.htm#critapps. © Copyright 2012 Xilinx, Inc. Xilinx, the Xilinx logo, Artix, ISE, Kintex, Spartan, Virtex, Vivado, Zynq, and other designated brands included herein are trademarks of Xilinx in the United States and other countries. All other trademarks are the property of their respective owners. Revision History The following table shows the revision history for this document. Date Version Revision 07/25/2012 2012.2 Initial Xilinx release. 08/20/2012 2012.2 Added details of route_design command regarding re-entrant routing and timing constraints. 10/16/2012 2012.3 Added table mapping ISE options to Vivado commands. See Appendix B, ISE Command Map. Added detaills regarding relative paths in the tcl.pre and tcl.post scripts. See Changing Implementation Run Settings in Chapter 1. 11/16/2012 2012.3 Updated route_design example scripts. See Routing in Chapter 3. 12/18/2012 2012.4 Added Incremental Place and Route in Chapter 1. Added Chapter 2, Defining Relatively Placed Macros. Implementation www.xilinx.com 2 UG904 (v2012.4) December 18, 2012 Table of Contents Chapter 1: Implementation Process Implementation Overview . 5 Getting to Implementation . 7 Project and Non-Project Modes . .7 RTL and Synthesized Design . .8 Constraints . .10 Design Checkpoints . .11 Running Implementation in Non-Project Mode . 12 Non-Project Mode Sample Script. .12 Details of Sample Script . .13 Running Implementation in Project Mode. 15 Creating Implementation Runs . .15 Customizing Implementation Strategies . .23 Launching Runs . .28 Running Implementation in Steps . .30 Monitoring the Implementation Run . .30 Determining the Project Status . .32 Incremental Place and Route . 34 Using Incremental Compilation . .36 Moving Forward After Implementation . 39 Viewing Messages . .40 Viewing Implementation Reports . .42 Chapter 2: Defining Relatively Placed Macros Introduction . 46 Assigning Cells to RPM Sets. 46 Assigning Relative Locations . 48 Assigning a Fixed Location to an RPM . 50 Chapter 3: Implementation Commands Introduction . 52 Opening the Synthesized Design. 53 synth_design . 53 read_checkpoint . 54 open_run . 54 link_design . 55 Logic Optimization . 56 opt_design . .56 Implementation www.xilinx.com 3 UG904 (v2012.4) December 18, 2012 Logic Optimization Constraints . .57 Power Optimization. 57 power_opt_design . .58 Placement. 59 place_design . .60 Physical Synthesis . 61 phys_opt_design . .61 Routing . 62 route_design . .62 Appendix A: Using Remote Hosts Launching Runs on Remote Linux Hosts. 65 Configuring Remote Hosts . .65 Setting Up SSH Key Agent Forward. 68 Appendix B: ISE Command Map Tcl Commands and Options. 69 Appendix C: Additional Resources Xilinx Resources . ..
Recommended publications
  • Open Source Synthesis and Verification Tool for Fixed-To-Floating and Floating-To-Fixed Points Conversions

    Open Source Synthesis and Verification Tool for Fixed-To-Floating and Floating-To-Fixed Points Conversions

    Circuits and Systems, 2016, 7, 3874-3885 http://www.scirp.org/journal/cs ISSN Online: 2153-1293 ISSN Print: 2153-1285 Open Source Synthesis and Verification Tool for Fixed-to-Floating and Floating-to-Fixed Points Conversions Semih Aslan1, Ekram Mohammad1, Azim Hassan Salamy2 1Ingram School of Engineering, Electrical Engineering Texas State University, San Marcos, Texas, USA 2School of Engineering, Electrical Engineering University of St. Thomas, St. Paul, Minnesota, USA How to cite this paper: Aslan, S., Mo- Abstract hammad, E. and Salamy, A.H. (2016) Open Source Synthesis and Verification Tool for An open source high level synthesis fixed-to-floating and floating-to-fixed conver- Fixed-to-Floating and Floating-to-Fixed Points sion tool is presented for embedded design, communication systems, and signal Conversions. Circuits and Systems, 7, 3874- processing applications. Many systems use a fixed point number system. Fixed point 3885. http://dx.doi.org/10.4236/cs.2016.711323 numbers often need to be converted to floating point numbers for higher accuracy, dynamic range, fixed-length transmission limitations or end user requirements. A Received: May 18, 2016 similar conversion system is needed to convert floating point numbers to fixed point Accepted: May 30, 2016 numbers due to the advantages that fixed point numbers offer when compared with Published: September 23, 2016 floating point number systems, such as compact hardware, reduced verification time Copyright © 2016 by authors and and design effort. The latest embedded and SoC designs use both number systems Scientific Research Publishing Inc. together to improve accuracy or reduce required hardware in the same design.
  • Placement and Routing in Computer Aided Design of Standard Cell Arrays by Exploiting the Structure of the Interconnection Graph

    Placement and Routing in Computer Aided Design of Standard Cell Arrays by Exploiting the Structure of the Interconnection Graph

    325 Computer-Aided Design and Applications © 2008 CAD Solutions, LLC http://www.cadanda.com Placement and Routing in Computer Aided Design of Standard Cell Arrays by Exploiting the Structure of the Interconnection Graph Ioannis Fudos1, Xrysovalantis Kavousianos 1, Dimitrios Markouzis 1 and Yiorgos Tsiatouhas1 1University of Ioannina, {fudos,kabousia,dimmark,tsiatouhas}@cs.uoi.gr ABSTRACT Standard cell placement and routing is an important open problem in current CAD VLSI research. We present a novel approach to placement and routing in standard cell arrays inspired by geometric constraint usage in traditional CAD systems. Placement is performed by an algorithm that places the standard cells in a spiral topology around the center of the cell array driven by a DFS on the interconnection graph. We provide an improvement of this technique by first detecting dense graphs in the interconnection graph and then placing cells that belong to denser graphs closer to the center of the spiral. By doing so we reduce the wirelength required for routing. Routing is performed by a variation of the maze algorithm enhanced by a set of heuristics that have been tuned to maximize performance. Finally we present a visualization tool and an experimental performance evaluation of our approach. Keywords: CAD VLSI design, geometric constraints, graph algorithms. DOI: 10.3722/cadaps.2008.325-337 1. INTRODUCTION VLSI circuits become more and more complex increasingly fast. This denotes that the physical layout problem is becoming more and more cumbersome. From the early years of VLSI design, engineers have sought techniques for automated design targeted to a) decreasing the time to market and b) increasing the robustness of the final product.
  • Xilinx Vivado Design Suite User Guide: Release Notes, Installation, And

    Xilinx Vivado Design Suite User Guide: Release Notes, Installation, And

    Vivado Design Suite User Guide Release Notes, Installation, and Licensing UG973 (v2013.3) October 23, 2013 Notice of Disclaimer The information disclosed to you hereunder (the “Materials”) is provided solely for the selection and use of Xilinx products. To the maximum extent permitted by applicable law: (1) Materials are made available "AS IS" and with all faults, Xilinx hereby DISCLAIMS ALL WARRANTIES AND CONDITIONS, EXPRESS, IMPLIED, OR STATUTORY, INCLUDING BUT NOT LIMITED TO WARRANTIES OF MERCHANTABILITY, NON-INFRINGEMENT, OR FITNESS FOR ANY PARTICULAR PURPOSE; and (2) Xilinx shall not be liable (whether in contract or tort, including negligence, or under any other theory of liability) for any loss or damage of any kind or nature related to, arising under, or in connection with, the Materials (including your use of the Materials), including for any direct, indirect, special, incidental, or consequential loss or damage (including loss of data, profits, goodwill, or any type of loss or damage suffered as a result of any action brought by a third party) even if such damage or loss was reasonably foreseeable or Xilinx had been advised of the possibility of the same. Xilinx assumes no obligation to correct any errors contained in the Materials or to notify you of updates to the Materials or to product specifications. You may not reproduce, modify, distribute, or publicly display the Materials without prior written consent. Certain products are subject to the terms and conditions of the Limited Warranties which can be viewed at http://www.xilinx.com/warranty.htm; IP cores may be subject to warranty and support terms contained in a license issued to you by Xilinx.
  • "Routing-Directed Placement for the Triptych FPGA" (PDF)

    "Routing-Directed Placement for the Triptych FPGA" (PDF)

    ACM/SIGDA Workshop on Field-Programmable Gate Arrays, Berkeley, February, 1992. Routing-directed Placement for the TRIPTYCH FPGA Elizabeth A. Walkup, Scott Hauck, Gaetano Borriello, Carl Ebeling Department of Computer Science and Engineering, FR-35 University of Washington Seattle, WA 98195 [Carter86], where the routing resources consume more Abstract than 90% of the chip area. Even so, the largest Xilinx Currently, FPGAs either divorce the issues of FPGA (3090) seldom achieves more than 50% logic placement and routing by providing logic and block utilization for random logic. A lack of interconnect as separate resources, or ignore the issue interconnect resources also leads to decreased of routing by targeting applications that use only performance as critical paths are forced into more nearest-neighbor communication. Triptych is a new circuitous routes. FPGA architecture that attempts to support efficient Domain-specific FPGAs like the Algotronix implementation of a wide range of circuits by blending CAL1024 (CAL) and the Concurrent Logic CFA6000 the logic and interconnect resources. This allows the (CFA) increase the chip area devoted to logic by physical structure of the logic array to more closely reducing routing to nearest-neighbor communication match the structure of logic functions, thereby [Algotronix91, Concurrent91]. The result is that these providing an efficient substrate (in terms of both area architectures are restricted to highly pipelined dataflow and speed) in which to implement these functions. applications, for which they are more efficient than Full utilization of this architecture requires an general-purpose FPGAs. Implementing circuits using integrated approach to the mapping process which these FPGAs requires close attention to routing during consists of covering, placement, and routing.
  • Research Needs in Computer-Aided Design: Logic and Physical Design and Analysis

    Research Needs in Computer-Aided Design: Logic and Physical Design and Analysis

    Research Needs in Computer-Aided Design: Logic and Physical Design and Analysis Logic synthesis and physical design, once considered separate topics, have grown together with the increasing need for tools which reach upward toward design at the system level and at the same time require links to detailed physical and electrical circuit characteristics. This list is a summary of important areas of research in computer-aided design seen by SRC members, ranging from behavioral-level design and synthesis to capacitance and inductance analysis. Note that research in CAD for analog/mixed signal is particularly encouraged, in addition to digital and hybrid system-on-chip design and analysis tools. Not included here are research needs in test and in verification, which are addressed in separate needs documents, and needs in circuit and system design itself, rather than tools research; these needs are assessed in the science area page for Integrated Circuits and Systems Sciences. Earlier needs lists with additional details are found in the "Top Ten" lists in synthesis and physical design developed by SRC task forces. System-Level Estimation and Partitioning System-level design tools require estimates to rapidly select a small number of potentially optimum candidates from a possibly enormous set of possible solutions. Models should consider power consumption, performance, die area (manufacturing cost), package size and cost, noise, test cost and other requirements and constraints. Partitioning of functional tasks between multiple hardware and software components, considering trade-offs between requirements and constraints, must be made using reasonably accurate models. Standard methods are also needed to estimate the performance of microprocessors and DSP cores to enable automated core selection.
  • PDF of the Configured Flow

    PDF of the Configured Flow

    mflowgen Sep 20, 2021 Contents 1 Quick Start 3 2 Reference: Graph-Building API7 2.1 Class Graph...............................................7 2.1.1 ADK-related..........................................7 2.1.2 Adding Steps..........................................7 2.1.3 Connecting Steps Together...................................8 2.1.4 Parameter System........................................8 2.1.5 Advanced Graph-Building...................................8 2.2 Class Step................................................9 2.3 Class Edge................................................ 10 3 User Guide 11 3.1 User Guide................................................ 11 3.2 Connecting Steps Together........................................ 11 3.2.1 Automatic Connection by Name................................ 11 3.2.2 Explicit Connections...................................... 13 3.3 Instantiating a Step Multiple Times................................... 14 3.4 Sweeping Large Design Spaces..................................... 15 3.4.1 More Details.......................................... 17 3.5 ADK Paths................................................ 19 3.6 Assertions................................................ 20 3.6.1 The File Class and Tool Class................................ 21 3.6.2 Adding Assertions When Constructing Your Graph...................... 21 3.6.3 Escaping Special Characters.................................. 21 3.6.4 Multiline Assertions...................................... 21 3.6.5 Defining Python Helper Functions..............................
  • Vivado Design Suite User Guide: High-Level Synthesis (UG902)

    Vivado Design Suite User Guide: High-Level Synthesis (UG902)

    Vivado Design Suite User Guide High-Level Synthesis UG902 (v2018.3) December 20, 2018 Revision History Revision History The following table shows the revision history for this document. Section Revision Summary 12/20/2018 Version 2018.3 Schedule Viewer Updated information on the schedule viewer. Optimizing the Design Clarified information on dataflow and loops throughout section. C++ Arbitrary Precision Fixed-Point Types: Reference Added note on using header files. Information HLS Math Library Updated information on how hls_math.h is used. The HLS Math Library, Fixed-Point Math Functions Updated functions. HLS Video Library, HLS Video Functions Library Moved the HLS video library to the Xilinx GitHub (https:// github.com/Xilinx/xfopencv) HLS SQL Library, HLS SQL Library Functions Updated hls::db to hls::alg functions. System Calls Added information on using the __SYNTHESIS__ macro. Arrays Added information on array sizing behavior. Command Reference Updated commands. config_dataflow, config_rtl Added the option -disable_start_propagation Class Methods, Operators, and Data Members Added guidance on specifying data width. UG902 (v2018.3) December 20, 2018Send Feedback www.xilinx.com High-Level Synthesis 2 Table of Contents Revision History...............................................................................................................2 Chapter 1: High-Level Synthesis............................................................................ 5 High-Level Synthesis Benefits....................................................................................................5
  • Vivado Tutorial

    Vivado Tutorial

    Lab Workbook Vivado Tutorial Vivado Tutorial Introduction This tutorial guides you through the design flow using Xilinx Vivado software to create a simple digital circuit using Verilog HDL. A typical design flow consists of creating model(s), creating user constraint file(s), creating a Vivado project, importing the created models, assigning created constraint file(s), optionally running behavioral simulation, synthesizing the design, implementing the design, generating the bitstream, and finally verifying the functionality in the hardware by downloading the generated bitstream file. You will go through the typical design flow targeting the Artix-100 based Nexys4 board. The typical design flow is shown below. The circled number indicates the corresponding step in this tutorial. Figure 1. A typical design flow Objectives After completing this tutorial, you will be able to: • Create a Vivado project sourcing HDL model(s) and targeting a specific FPGA device located on the Nexys4 board • Use the provided partially completed Xilinx Design Constraint (XDC) file to constrain some of the pin locations • Add additional constraints using the Tcl scripting feature of Vivado • Simulate the design using the XSim simulator • Synthesize and implement the design • Generate the bitstream • Configure the FPGA using the generated bitstream and verify the functionality • Go through the design flow in batch mode using the Tcl script Procedure This tutorial is broken into steps that consist of general overview statements providing information on the detailed instructions that follow. Follow these detailed instructions to progress through the tutorial. www.xilinx.com/university Nexys4 Vivado Tutorial-1 [email protected] © copyright 2013 Xilinx Vivado Tutorial Lab Workbook Design Description The design consists of some inputs directly connected to the corresponding output LEDs.
  • Xilinx Vivado Design Suite 7 Series FPGA and Zynq-7000 All Programmable Soc Libraries Guide (UG953)

    Xilinx Vivado Design Suite 7 Series FPGA and Zynq-7000 All Programmable Soc Libraries Guide (UG953)

    Vivado Design Suite 7 Series FPGA and Zynq-7000 All Programmable SoC Libraries Guide UG953 (v 2013.1) March 20, 2013 Notice of Disclaimer The information disclosed to you hereunder (the "Materials") is provided solely for the selection and use of Xilinx products. To the maximum extent permitted by applicable law: (1) Materials are made available "AS IS" and with all faults, Xilinx hereby DISCLAIMS ALL WARRANTIES AND CONDITIONS, EXPRESS, IMPLIED, OR STATUTORY, INCLUDING BUT NOT LIMITED TO WARRANTIES OF MERCHANTABILITY, NON-INFRINGEMENT, OR FITNESS FOR ANY PARTICULAR PURPOSE; and (2) Xilinx shall not be liable (whether in contract or tort, including negligence, or under any other theory of liability) for any loss or damage of any kind or nature related to, arising under, or in connection with, the Materials (including your use of the Materials), including for any direct, indirect, special, incidental, or consequential loss or damage (including loss of data, profits, goodwill, or any type of loss or damage suffered as a result of any action brought by a third party) even if such damage or loss was reasonably foreseeable or Xilinx had been advised of the possibility of the same. Xilinx assumes no obligation to correct any errors contained in the Materials or to notify you of updates to the Materials or to product specifications. You may not reproduce, modify, distribute, or publicly display the Materials without prior written consent. Certain products are subject to the terms and conditions of the Limited Warranties which can be viewed at http://www.xilinx.com/warranty.htm; IP cores may be subject to warranty and support terms contained in a license issued to you by Xilinx.
  • Vivado Design Suite User Guide: Implementation

    Vivado Design Suite User Guide: Implementation

    See all versions of this document Vivado Design Suite User Guide Implementation UG904 (v2021.1) August 30, 2021 Revision History Revision History The following table shows the revision history for this document. Section Revision Summary 08/30/2021 Version 2021.1 Sweep (Default) Added more information. Incremental Implementation Controls Corrected Block Memory and DSP placement example. Using Incremental Implementation in Project Mode Corrected steps and updated image. Using report_incremental_reuse Updated Reuse Summary example and Reference Run Comparison. Physical Optimization Reports Updated to clarify that report is not cumulative. Available Logic Optimizations Added -resynth_remap. Resynth Remap Added logic optimization. opt_design Added [-resynth_remap] to opt_design Syntax. Physical Synthesis Phase Added entry for Property-Based Retiming. 02/26/2021 Version 2020.2 General Updates General release updates. 08/25/2020 Version 2020.1 Appendix A: Using Remote Hosts and Compute Clusters Updated section. UG904 (v2021.1) August 30, 2021Send Feedback www.xilinx.com Implementation 2 Table of Contents Revision History...............................................................................................................2 Chapter 1: Preparing for Implementation....................................................... 5 About the Vivado Implementation Process............................................................................. 5 Navigating Content by Design Process...................................................................................
  • Magic: an Industrial-Strength Logic Optimization, Technology Mapping, and Formal Verification Tool

    Magic: an Industrial-Strength Logic Optimization, Technology Mapping, and Formal Verification Tool

    Magic: An Industrial-Strength Logic Optimization, Technology Mapping, and Formal Verification Tool Alan Mishchenko Niklas Een Robert Brayton Stephen Jang Maciej Ciesielski Thomas Daniel Department of EECS LogicMill Technology Abound Logic University of California, Berkeley San Jose, CA / Amherst, MA Santa Clara, CA {alanmi, een, brayton}@eecs.berkeley.edu {sjang, mciesielski}@logic-mill.com [email protected] ABSTRACT The present paper outlines the result of integrating ABC into one commercial flow and shows the results produced. This paper presents an industrial-strength CAD system for logic We named the result of this integration “Magic” to distinguish it optimization, technology mapping, and formal verification of from ABC as a public-domain system. The two are closely related synchronous designs. The new system, Magic, is based on the but not the same: ABC is a store-house of implementations called code of ABC that has been improved by adding industrial application packages, most of which are experimental, requirements. Distinctive features include: global-view incomplete, or have known bugs, while Magic integrates and optimizations for area and delay, scalable sequential synthesis, the extends only those features that create a robust optimization flow. use of white-boxes for instances that should not be mapped, and a Magic features an all-new design database developed within built-in formal verification framework to run combinational and ABC to meet industrial requirements. The database was developed sequential equivalence checking. Comparison against a reference from scratch, based on our experience gained while applying ABC industrial flow shows that Magic is capable of reducing both area to industrial designs.
  • Application-Specific Integrated Circuits

    Application-Specific Integrated Circuits

    Application-Specific Integrated Circuits (ASICS) S. K. Tewksbury Microelectronic Systems Research Center Dept. of Electrical and Computer Engineering West Virginia University Morgantown, WV 26506 (304)293-6371 May 15, 1996 Contents 1 Introduction 1 2 The Primary Steps of VLSI ASIC Design 3 3 The Increasing Impact of Interconnection Delays on Design 5 4 General Transistor Level Design of CMOS Circuits 6 5 ASIC Technologies 8 5.1 Full Custom Design ......................................... 8 5.2 Standard Cell ASIC Technology ................................... 9 5.3 Gate Array ASIC Technology .................................... 10 5.4 Sea-of-Gates ASIC Technology ................................... 10 5.5 CMOS Circuits using Megacell Elements .............................. 10 5.6 Field Programmable Gate Arrays: Evolving to an ASIC Technology .............. 11 6 Interconnection Performance Modeling 12 7 Clock Distribution 14 8 Power Distribution 15 9 Analog and Mixed-Signal ASICs 16 10 Summary 16 1 Introduction Today’s VLSI CMOS technologies can place and interconnect several million transistors (representing over a million gates) on a single integrated circuit (IC) approximately 1 cm square. Provided with such a vast number of gates, a digital system designer can implement very sophisticated and complex system functions (including full systems) on a single IC. However, ecient design (including optimized performance) of such functions using all these gates is a complex puzzle of immense complexity. If this technology were to have been provided to the world overnight, it is doubtful that designers could in fact make use of this vast amount of logic on an IC. 1 Figure 1: Photomicrograph of the SHARC digital signal processor of Analog Devices, Inc., provided for this chapter by Douglas Garde, Analog Devices, Inc., Norwood, MA.