Institut für Automation Abt. für Automatisierungssysteme Technische Universität Wien Projektbericht Nr. 183/1-68 October 1996 # A Primer to Digital Design with Synopsys and Cadence Martin Horauer Salvador Dali, "Die Beständigkeit der Erinnerung" | Notes | | |-------|----------------------------------------------------------------------------------------------------------------------| | | | | | | | | | | | ved. | | | nts rese | | | . All righ | | | Vienna | | | niversity | | | nical Ur | | | yy, Tech | | | chnológ | | | outer Te | | | of Com | | | tement | | | , Depar | | | Horauer | | | D. S. C. | | ä | -idin k | | | © 1996 by DiplIng. M. Horauer, Departement of Computer Technology, Technical University Vienna. All rights reserved. | | | <i>⊎</i> | | | | | | | | | | # **Contents** | ı | 7 | |----|-----------------| | ı | ã | | ı | Ç | | L | ű | | ı | Œ | | ı | ď | | l | z | | l | <u>,</u> | | l | _ | | ı | ₹ | | ı | ~ | | ı | č | | ı | S | | ı | ۳ | | ľ | < | | ١. | € | | ı | 5 | | ı | Š | | | Ē | | | $\bar{\supset}$ | | ŀ | ~ | | ١. | ŭ | | | ⋤ | | | ರ | | ١, | Φ | | 1 | _ | | | ≥ | | | ŏ | | ٠ | ਰ | | | ⋍ | | • | ਨੂ | | ŀ | Φ. | | ٠, | _ | | | 9 | | | ⋈ | | i | Ξ | | i | ੋ | | ( | ر | | 7 | 5 | | 4 | ≕ | | 3 | ī | | 1 | Ξ | | 3 | Ū | | 3 | ₹ | | Ġ | ž. | | ć | 2 | | - | Τ, | | ì | D | | ; | 2 | | , | ž | | ì | 2 | | _ | - | | 2 | ≥ | | | ה | | Ž | = | | _ | | | C | <u> </u> | | Č | 5 | | 2 | > | | 2 | 2 | | ä | ? | | | | | σ | Ś | | l | Syn | ppsys | 2 | |---|---------------------|--------------------------------------------|----| | | 1.1 | Synopsys documentation | 2 | | | 1.2 | Analyzing source files | 2 | | | 1.3 | Directory hierarchy and file-naming policy | 3 | | | 1.4 | Simulation before synthesis | | | | 1.5 | Synthesis | | | | 1.6 | A design example | 7 | | | <b>Y</b> 2 <b>Y</b> | | | | , | Back | c-End design with CADENCE | 25 | | Notes | | | |-------|----------------------------------------------------------------------------------------------------------------------|--| | | | | | | | | | | Ped. | | | | rights rese | | | | enna. All r | | | | niversity Vi | | | | chnical Un | | | | ology, Te | | | | uter Techr | | | | of Compu | | | | partemeni | | | | orauer, De | | | | .mm. | | | | © 1996 by DipiIng. M. Horauer, Departement of Computer Technology, Technical University Vienna. All rights reserved. | | | | <u>B</u> B<br>B<br>∋ | | | | | | | | | | | | | | # **Chapter 1** # **Synopsys** Here we will give a brief description of the basic programs and shells, that can be used in conjunction with an ASIC development. I will not cover the use of the schematic entry tool sge, that is (thats just another prejudice of mine) preferably useful for interconnect management at the top level. Figure 1.1: SGE fronted after invocation If you're intending to make use of this tool, see the online documentation for an extensive description. # 1.1 Synopsys documentation The large collection of the Synopsys manuals can be read and searched online via the very powerful inter-leaf viewer. Type **iview** at the Unix command prompt to bring it up onto your screen. Figure 1.2 shows the outline after invocation. Very powerful context search is available via **Search** → **Collection**. This documentation is an excellent guide to further work, so I'll recommend it for your use not only when you're a novice. Furthermore there is a collection of books available at our department, that are primarily related to HDL coding [R.94], [P.90], [J.92], [HYE95], [R.93], [D.91], [IEE87], [IEE93], [PT95] and [S.96]. # 1.2 Analyzing source files The program vhdlan can be used to analyze the VHDL-files for correct syntax. % vhdlan -nc vhdl/test\_ent.vhd vhdl/test\_beh\_arch.vhd by Dipl.-Ing. M. Horauer, Departement of Computer Technology, Technical University Vienna. All rights reserved | Notes | | |------------|----------------------------------------------------------------------------------------------------------------------| | | | | | | | | © 1996 by DiptIng. M. Horauer, Departement of Computer Technology, Technical University Vienna. All rights reserved. | | | anna. All rigl | | | niversity Vič | | | Technical U | | | echnology, | | | Computer 1 | | | artement of | | | orauer, Dep | | | i.·ing. M. Ho | | 000<br>000 | dia da aaaa | | | ∌ | | | | | | | Figure 1.2: Synopsys online documentation The -nc option avoids just an annoying header displayed at every invocation. Beside vhdlan has many other useful options and switches. See the online help *iview* or type **vhdlan** —**help** to get more information on them. When you're dealing with several source files that are depending on each other you can generate a *Makefile* using the command **simdepends**. Once you've got you're Makefile, you'll only need to enter **make**, and all depending VHDL-source files, that were modified more recently, are analyzed again. In the case when the analysis of your code succeeds, you can start with your simulation. Otherwise the lines and locations of the error prone code fragments are displayed. You'll have to identify the error an rerun the analysis. # 1.3 Directory hierarchy and file-naming policy To ease file manipulation and navigation through a project, everybody in the design team should follow some general naming and structure conventions. The following directory tree serves as an example how to structure the design. The cds directory holds all Cadence related files, while syn all Synopsys related. In the M. Horauer, Departement of Computer Technology, Technical University Vienna. All rights reserved © 1996 by Dipl.-Ing. | Notes | | |-------|----------------------------------------------------------------------------------------------------------------------| | | | | | | | | ρ́ | | | nts reserv | | | All right | | | rsity Vien | | | ical Unive | | | Jy, Techni | | | © 1996 by DiplIng. M. Horauer, Departement of Computer Technology, Technical University Vienna. All rights reserved. | | | Somputer | | | ment of O | | | r, Departe | | | 4. Horaue | | | JiplIng. I | | | 1996 by [ | | | | | | | | | | | | | Synopsys tree the subdirectories *mdu*, *tdu* and *exu* hold the VHDL-source files for the three modules of the design. The directory *scr* contains all related script files for synthesis and simulation, under *comp* all synthesized files are stored and *scan* holds all files after scan-path insertion. Finally the contents of directory *s2c* are made up with several files necessary for the design transfer to Cadence (physical place and route). In the Cadence tree, many subdirectories are instantiated by the tools and therefore you should avoid to manipulate to much in there. Use the tools supplied with Cadence instead. | filename | description | |-----------------------|---------------------------------| | dd_pkg.vhd | project package declaration | | dd_pbdy.vhd | project package body | | exu_ent.vhd | top-module entity | | exu_beh_arch.vhd | top-module architecture | | exu_beh_cfg.vhd | top-module configuration | | exu_body_ent.vhd | sub-module entity (body varies) | | exu_body_beh_arch.vhd | sub-module architecture | Table 1.1: Filenaming policy Table 1.1 summarizes a possible filenaming convention. It is of course a bit tedious to split everything, but benefits of a highly modular design should always be kept in mind. Beside, every file should contain a header, that includes the project name, the name of the designer, the version number, the filename itself, the title and type of the module, the tools it is targeted for, which libraries and packages are used and of course a timestamp. A few of these header lines are of course obvious and could be taken from the file properties itself, but they are nice to have when included also in the header. For examples consult the source-code listings in the further sections. # 1.4 Simulation before synthesis Within Synopsys either the graphical interface **vhdldbx** (see Figure 1.3) or the command line version **vhdlsim** can be used. In both cases you need to specify the name of the configuration you're intending to simulate. Afterwards you'll have to specify the signals you're willing to trace. The later can also be specified in an include file that is applied to the simulator during invocation. You can single-step the code, set/delete breakpoints, evaluate signals and variables, set them to specific values, interrupt the simulation, .... In the waveform window you can add several cursors to measure timings between different signals, zoom in and out, .... Furthermore you can implement file i/o, to ease comparison of your simulation results at different levels of simulation. The later can in addition also be performed via a post-processor program **gpp**. Gpp takes two wif files (file-extesion .ow), and compares them at periodic times you specify at the command line. A wif file is automatically created when the variable WAVEFORM is set to wif+waves within the .synopsys\_vss\_setup configuration file. The simulator is usually invoked with an include file, which consists of several control sequences for the simulator itself. The following gives an idea of such a file. It traces several signals in different levels of the hierarchy and displays them in the waveform window. Horauer, Departement of Computer Technology, Technical University Vienna. All rights reserved Š by Dipl.-Ing. | Notes | ] | | |-------|----------------------------------------------------------------------------------------------------------------------|--| | | | | | | | | | | | | | | , p | | | | reserve | | | | I rights | | | | enna. A | | | | rsity Vie | | | | Unive | | | | echnics | | | | ology, T | | | | Techno | | | | mputer | | | | nt of O | | | | arteme | | | | er, Dep | | | | . Horau | | | | -Ing. M | | | | by Dipl. | | | | © 1996 by DiplIng. M. Horauer, Departement of Computer Technology, Technical University Vienna. All rights reserved. | | | | • | | | | | | | | | | | | | | | | | | Execute Presidents Spatter. Proces Gerry Standar High Figure Presidents Spatter. Proces Gerry Standar High Figure Presidents Spatter. Proces Gerry Standar High Figure Process Spatter. Process Gerry Standar High Figure Process Spatter. Process Gerry Standar High Figure Process Spatter. Process Gerry Standar High Figure Process Spatter. Pro Figure 1.3: The graphical user interface for simulation An analogue file for the post-processor could be for e.g. as the following. ``` load cmp/EXU.TB.LTU.PRE.ow cmp/EXU.TB.LTU.POST.ow files timespec t1=40530,40530,repeat 500 times~40000 end show t1 compare file=1;timespec=t1 all to file=2;timeapec=t1 all ... ``` Here two wif files, that must be created previously with the simulator, are loaded first. The files command displays all files in memory. The timespec command declares a periodic point in simulation time, starting at time 40530 and repeating 40000 times every 500 time increments. The resolution for the time increments (ns, ps, ...) is determined via the setup-file .synopsys\_vss\_setup. # 1.5 Synthesis The programs for synthesis are the graphical user interface **design\_analyzer** (see Figure 1.4) and the command line shell **dc\_shell**. Both have the same functionality, although the shell version is of course more appropriate for most synthesis runs, while the graphical interface can be used primarily for cross-checkings and is easier to use by new users. Both programs have many options and commands built-in. A few of them will be illustrated a little along with some scripts we'll illustrate along with the following sections. © 1996 by Dipl.-Ing. M. Horauer, Departement of Computer Technology, Technical University Vienna. All rights reserved | <br>Notes | |-----------| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | To get more information on specific commands just type help <topic> at the shell prompt or within the command window. Figure 1.4: The graphical user interface for synthesis To illustrate the funcionality a bit more in depth, take a look at the following example. ``` PACKAGES={pkg/ExU_pkg.vhd pkg/ExU_pbdy.vhd} analyze -{ vhdl PACKAGES /* BTU -{ ``` First a dc\_shell variable PACKAGES is defined that consists of two files. They are analyzed in the subsequent line. Within this package you could have defined several constants or functions that are used from within several other source files. The subsequent variable holds all VHDL-files of the module in a bootom up fashion. These files are analyzed and elaborated. In the case this operation succeeds, the module is ready to accept several constraints for logic synthesis. Afterwards a submodule NTPADDER, that consits of pure combinational logic is synthesized in front of the rest. Therefore you've to set the current design to this submodule. Then the outputs of this submodule are constrained with a maximum output delay of 28 ns. – Use a realistic value for constraining, otherwise you'll end up with an unnessecarily huge bulk of logic and in addition you'll waste much processing power of your workstation. – The submodule then is synthesiszed and ungrouped, so that you'll end up with a flat logic. If the module has registered inputs and outputs the following sequence would be an appropriate constraining scenario. 1996 by Dipl.-Ing. M. Horauer, Departement of Computer Technology, Technical University Vienna. All rights reserved | Notes | | | |----------|----------------------------------------------------------------------------------------------------------------------|--| | | | | | | | | | | <u></u> | | | | © 1996 by DiplIng. M. Horauer, Departement of Computer Technology, Technical University Vienna. All rights reserved. | | | | All rights | | | | y Vienna. | | | | Universit | | | | echnical | | | | nology, T | | | | uter Techi | | | | of Compu | | | Į.<br>Į. | artement | | | 4 | uer, Depč | | | | M. Hora | | | - | DiplIng. | | | | 1996 by | | | | <b>⊚</b> | | | | | | | | | | | | | | current\_design{btu} clock\_name = ITCLK create\_clock\_clock\_name -period 40 -waveform 0 20 set\_dont\_touch\_network\_(clock\_name) set\_coperating\_conditions\_"IND\_MAX" set\_wire\_load\_"1407X1407\_with\_routing"\_-library\_ecpd07\_ind set\_test\_methodology\_full\_sean set\_sean\_style\_multiplexed\_flip\_flop set\_input\_delay\_6 find(port\_"IANBUS")\_-clock\_clock\_name set\_input\_delay\_16 find(port\_"TSGATE")\_-clock\_clock\_name set\_input\_delay\_12 find(port\_"TSGATE")\_-clock\_clock\_name set\_input\_delay\_10 find(port\_"CSUMSTROBEPURE")\_-clock\_clock\_name ... set\_output\_delay\_30 find(port,"TESTSEL")\_-clock\_clock\_name ... set\_load\_0.2 all\_outputs() set\_max\_fanout\_1 all\_inputs() remove\_attribute\_find(port\_"TCLK") max\_fanout set\_driving\_cell\_-cell\_tBINV\_-library\_sec\_pd07\_ind\_all\_inputs() set\_driving\_cell\_-cell\_tBINV\_-library\_sec\_pd07\_ind\_all\_inputs() set\_driving\_cell\_-cell\_ence\_mental\_map write\_f\_vhcl\_-hier\_o\_btu\_vhcl write\_f\_do\_hier\_o\_btu\_vhcl write\_f\_do\_hier\_o\_btu\_vhcl write\_f\_do\_hier\_o\_btu\_vhcl write\_f\_do\_hier\_o\_btu\_vhcl report\_area\_> btu\_area\_rep report\_tliming\_> btu\_tliming\_rep ... After the current design is set, a variable *clock\_name* is defined with the name of the clock signal. In this case the name of the clock signal is ITCLK. Then a clock constraint is instantiated, that defines the clock with a period of 40 ns and the rising edge set to 0 ns and the falling to 20 ns. The next constraint set\_dont\_touch\_network prevents the instantiation of buffers within this network. - For e.g. ES2 uses only one large buffer, strong enough to drive the whole clock tree. Such a buffer is usually instantiated manually after synthesis. - Then according to the technology library you're syntesizing for, you'll have to set operating conditions and provide a wire load model for area estimation of the interconnections. The next two commands are used if you're intending to insert scan-path logic after synthesis. They set some restrictions for the optimisation of sequential cells to ease the scan-path insertion afterwards. – In the case, you're willing to omit scan insertion, leave these commands aside. - Then set input and output delay constraints in relation to the clock edge to all appropriate signals. -The set\_input\_delay defines the delay of the path to an input. This value is the total time a signal takes to propagate through logic in front of the input port. In contrast the set\_output\_delay value is the delay through the logic hooked to the output port. The common time reference is the rising edge of the clock signal. Include library setup time and instance-specific clock skew in this calculation. - Use the set\_load command with library dependent typical values to constrain the output ports, and the set\_max\_fanout for the input ports. An inverter is than specified as a driving cell for the according inputs. Again these attributes are removed from the clock network, because it should be considered special. Finally compile the module. The switch incremental\_map takes care of the already precompiled submodule. With the write command you are able to save the results in different formats, e.g. vhdl, verilog or the Synopsys internal database format (.db). After synthesis you usually create several reports to verify if the synthesized results meet your desired requirements. If you're unaware of the meaning or usage of certain commands, you can type **help** <**command>** at the dc\_shell prompt or contact the online documentation **iview** from the Unix prompt. # 1.6 A design example To illustrate the design flow and to make it a bit more clear and concise imagine the following example displayed in figure 1.5. This example consists of two submodules, the EXU\_BODY, that holds the core functionality of the module, and a submodule called EXU\_MDMUX, that is split from the body, due to the fact that it is for e.g. reused within other modules. The block diagram entails the interconnect lines to other modules, and 1996 by Dipl.-Ing. M. Horauer, Departement of Computer Technology, Technical University Vienna. All rights reserved | , y, | Notes | |------|-------| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Figure 1.5: A design example: Example Unit (EXU) gives a rough impression on the internal structure of the module. This file which holds the entity of the EXU top module, is saved in the directory exu under the filename exu\_ent.vhd. ``` ICT Computer Technology Dept University of Technology, Vienna All Rights Reserved ``` © 1996 by Dipl.-Ing. M. Horauer, Departement of Computer Technology, Technical University Vienna. All rights reserved | <br>Notes | |-----------| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | All rights reserved. Vienna. Horauer, Departement of Computer Technology, Technical University ≥ Dipl.-Ing. I © 1996 by ``` project designer version file name title module tools ref. lib. UTCSU Martin HORAUER 1.0 exu_beh_arch.vhd Example UNIT architecture Synopsys ref. lib. : ref. pkg. : Roadmap : Date : · description: >>>> EXU +----+ exu_body exu_mdmux architecture BEHAVIORAL of exu is signal MDATABR0: std_logic_vector( 31 downto 0); signal MDATABR1: std_logic_vector( 31 downto 0); signal MDATABR2: std_logic_vector( 31 downto 0); signal MDATABR3: std_logic_vector( 31 downto 0); COMPONENT exu_body port( EXUBUS: in std_logic_vector(63 downto 0); MDATAW: in std_logic_vector(31 downto 0); RESET: in std_logic; RESET: in std_logic; CLK: in std_logic; ADDR: in std_logic_vector(1 downto 0); BE: in std_logic_vector(3 downto 0); BE: in std_logic_vector(3 downto 0); RWBAR: in std_logic; INTTSRCV: out std_logic; TSRVCVGATE: in std_logic; INTINDUTY: out std_logic; INTDSXMT: out std_logic; SDUTY: out std_logic; MSRCV: out std_logic_vector(31 downto 0); TSRCV: out std_logic_vector(31 downto 0); MSXMT: out std_logic_vector(31 downto 0); TSXMT: out std_logic_vector(31 downto 0); TSXMT: out std_logic_vector(31 downto 0); end COMPONENT: COMPONENT exu_mdmux MDATABRO: in std_logic_vector(31 downto 0); MDATABRY: in std_logic_vector(31 downto 0); MDATABRA: in std_logic_vector(31 downto 0); MDATABRA: in std_logic_vector(31 downto 0); MDATABRA: in std_logic_vector(31 downto 0); MDATABRA: out std_logic_vector(31 downto 0); READMUX: in std_logic_vector(1 downto 0); begin UEXUBODY: exu_body port map(EXUBUS,MDATAW,RESET. CLK, ADDR, BE, RWBAR, INTTSRCV, TSRCVGATE, TSXMTGATE, INTISXMI, INTOUTY, SDUTY, MDATABRO, MDATABR1, MDATABR2, MDATABR3 ``` The architecture of the EXU top module is saved as exw/exu\_beh\_arch.vhd. Finally the configuration is stored as exw/exu\_beh\_cfg.vhd. ``` Computer Technology Dept University of Technology, Vienna All Rights Reserved project: UTCSU designer: Martin HORAUER version: 1.0 file name: exu_beh_cfg.vhd title: Example UNIT module: configuration tools: Synopsys ref. lib.: ref. pkg.: Roadmap: Date: 10/96 description: This file containts the top of the EXU. ``` | Notes | | | | |-------|----------------------------------------------------------------------------------------------------------------------|--|--| | | | | | | | | | | | | eserved. | | | | | © 1996 by DiplIng. M. Horauer, Departement of Computer Technology, Technical University Vienna. All rights reserved. | | | | | sity Vienna | | | | | ical Univers | | | | | ogy, Techn | | | | | er Technol | | | | | of Compute | | | | | partement | | | | | orauer, De | | | | | I-Ing. M. H | | | | | 996 by Dip | | | | | <del>-</del><br>⊚ | | | | | | | | | | | | | Figure 1.6: Schematic of the submodule EXU\_MDMUX ``` ... >>>> EXU ... | ... | ... | ... | ... | ... exu_body exu_mdmux ... | exu_body exu_mdmux ... | exu_body exu_mdmux ... | exu_body exu_mdmux ... | exu_body exu_mdmux ... | exu_body exu_mdmux ... | exu_body exu_mdmux use entity work.exu_mdmux(BEHAVIORAL); end for; end for; end for; end for; end for; ``` Now that the top elements are specified, lets work out the interior of the submodules. Figure 1.6 entails the schematic of the module EXU\_MDMUX, which consists only of one large multiplexer, that feeds one of four 32-bit wide buses, depending on the value of the lines READMUX to the output MDATAR. For larger modules a table should summarize the functionality, such as provided with the following submodule, to ease understanding and to write down a functional mapping. The following code saved in <code>exu/exu\_mdmux\_ent.vhd</code> holds the entity. ``` .. I C T Computer Technology Dept .. University of Technology, Vienna .. All Rights Reserved .. Project : UTCSU .. designer : Martin HORAUER .. version : 1.0 .. file name : exupkg_mdmux_ent.vhd .. title : Modul Data Bus Multiplexer .. module : entity .. tools : Synopsys .. ref. lib. : IEEE .. ref. pkg. : 1164 .. Roadmap : .. Date : 10/96 library IEEE; .. use IEEE.std_logic_l164 .all; .. USE work.exupkg.all; entity exu_mdmux is .. port( .. MDATABR0: in std_logic_vector(31 downto 0); .. MDATABR1: in std_logic_vector(31 downto 0); .. MDATABR3: in std_logic_vector(31 downto 0); .. MDATABR3: in std_logic_vector(31 downto 0); .. MDATABR3: in std_logic_vector(31 downto 0); .. MDATABR3: in std_logic_vector(31 downto 0); .. MDATABR3: in std_logic_vector(31 downto 0); .. MDATARS: out std_logic_vector(31 downto 0); .. KEDMUX: in std_logic_vector(31 downto 0); .. KEDMUX: in std_logic_vector(1 downto 0) .. }; end exu_mdmux; ``` And in addition exw/exu\_mdmux\_beh\_arch.vhd specifies the architecture. ``` Computer Technology Dept University of Technology, Vienna All Rights Reserved ``` © 1996 by Dipl.-Ing. M. Horauer, Departement of Computer Technology, Technical University Vienna. All rights reserved. | Notes | | | |-------|----------------------------------------------------------------------------------------------------------------------|--| | | | | | | | | | | | | | | | | | | , ed. | | | | © 1996 by DiplIng. M. Horauer, Departement of Computer Technology, Technical University Vienna. All rights reserved. | | | | l rights | | | | na. Al | | | | ity Vier | | | | niversi | | | | U local | | | | Tech | | | | Ygolor | | | | Tech | | | | mputer | | | | of Co | | | | ement | | | | Depart | | | | auer, l | | | | Ä<br>H<br>P | | | | -Ing. | | | | by Dip | | | | 1996 | | | | ◎ | | | | | | | | | | | | | | | | | | | | | | project ``` Martin HORAUER designer version file name exu_mdmux_beh_arch.vhd tile name title module tools ref. lib. ref. pkg. Modul Data Bus Multiplexer adopted for EXU architecture Synopsys IEEE 1164 Roadmap 10/96 architecture BEHAVIORAL of exu_mdmux is reserved -- MDATAMUX - inputs: MDATABRX, READMUX - outputs: MDATAR - description: Data Multiplexer All rights P_READMUX: process(READMUX, MDATABR3, MDATABR2, MDATABR1, MDATABR0) ............. if (READMUX = *11*) then MDATAR <= MDATABR3; -- MSXMT elsif (READMUX = *10*) then MDATAR <= MDATABR2; -- TSRCV elsif (READMUX = *01*) then elsif (READMUX = *00*) then MDATAR <= MDATABR0; else MDATAR <= ZERO32; end process; ``` The second submodule EXU\_BODY consists of an input bus EXUBUS, that provides the EXU with varying data. The registers MSRCV and TSRCV sample the data of this bus on the activation of the gate signal TSRCVGATE, that is exteranlly activated synchronous to the bus. In analogy, the registers MSXMT and TSXMT are sampled by TSXMTGATE. Both signals are additionally fed through this unit (INTTSRCV and INTTSXMT) to a follow up module. All these four 32-bit registers can than be read via a 32-bit access from the address MDATABR[X]. At the bottom, there are two registers DUTYH and DUTYL located, that can be written. The 32-bit DUTYH and the lower 16 bits of DUTYL serve as DUTY input for a comparator module. Bit 17 of register DUTYL enables or disables this comparator, that performs a comparison of 48 bits between EXUBUS[55,8] and the Duty value. When the Exubus is greater than or equal to Duty, a pulse is generated on the output-line INTDUTY, that is active for one clock period, whilst signal SDUTY is active as long as the EXUBUS $\geq$ DUTY. | Element | Width | R/W | ADDR | BE | Reset | description | |---------|-------|-----|------|-----|-------|---------------------| | MSRCV | 32 | R | 0 | Х | 0 | Macrostamp receive | | TSRCV | 32 | R | 1 | X | 0 | Timestamp receive | | MSXMT | 32 | R | 2 | X | 0 | Macrostamp transmit | | TSXMT | 32 | R | 3 | X | 0 | Timestamp transmit | | DUTYH | 32 | W | 0 | 3:0 | 0 | DUTYH high | | DUTYL | 17 | W | 1 | 2:0 | 0 | Enable and DUTYL | The following listings belong to the files *exu/exu\_body\_ent.vhd* and *exu\_body\_beh\_arch.vhd*. ··· I C T Computer Technology Dept 1996 by Dipl.-Ing. M. Horauer, Departement of Computer Technology, Technical University Vienna. end BEHAVIORAL; | Notes | |-------| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | © 1996 by Dipl.-Ing. M. Horauer, Departement of Computer Technology, Technical University Vienna. All rights reserved. Figure 1.7: Schematic of the submodule EXU\_BODY ``` University of Technology, Vienna All Rights Reserved UTCSU Martin HORAUER 1.0 exu_body_ent.vhd Example Unit entity Synopeys IEEE 1164 project designer version file name title module : tools : ref. lib. : ref. pkg. : Roadmap 10/96 Date LIBRARY IEEE; USE IEEE.std_logic_1164.all; USE IEEE.std_logic_unsigned.">==*; USE work.exupkg.all; ENTITY exu_body IS port( f exu_body IS t( EXUBUS: in std_logic_vector(63 downto 0); MDATAW: in std_logic_vector(31 downto 0); RESET: in std_logic; CLK: in std_logic; CLK: in std_logic; ADDR: in std_logic,vector(1 downto 0); BE: in std_logic_vector(3 downto 0); RWBAR: in std_logic; INTTSRCV: out std_logic; TSXMTGATE: in std_logic; INTTSRMT: out std_logic; INTDUTY: out std_logic; INTDUTY: out std_logic; SDUTY: out std_logic; MSRCV: out std_logic_vector(31 downto 0); TSRCV: out std_logic_vector(31 downto 0); MSXMT: out std_logic_vector(31 downto 0); MSXMT: out std_logic_vector(31 downto 0); TSXMT: out std_logic_vector(31 downto 0); TSXMT: out std_logic_vector(31 downto 0); TSXMT: out std_logic_vector(31 downto 0); }; END exu_body; ICT Computer Technology Dept University of Technology, Vienna All Rights Reserved UTCSU Martin HORAUER 1.0 exu_body_beh_arch.vhd Example Unit architecture Synopsys IEEE 1164 project designer version file name title module tools ref. lib. ref. pkg. Roadmap Date -- The example unit samples timestamps on external events, as ``` | Notes | | | |----------------------------------------------------------------------------------------------------------------------|--|--| | | | | | | | | | erved. | | | | rights rese | | | | © 1996 by DiplIng. M. Horauer, Departement of Computer Technology, Technical University Vienna. All rights reserved. | | | | niversity V | | | | rchnical U | | | | nology, Te | | | | uter Tech | | | | t of Comp | | | | partemen | | | | orauer, De | | | | Ing. M. Ho | | | | s by Dipl | | | | © 1996 | | | | | | | | | | | | | | | ``` can be transmit or receive packets. Receive packets trigger via TSRCV a time- stamp, which is sampled into the MSRCV and TSRCV registers. Transmit packets trigger TSXMT wich samples a timestamp into MSXMT and TSXMT. The duty-timer DUTY is responsible to periodically trigger S/R/D/A-duties. The duty-registers are loaded via two 32-bit wide registers and are enabled via the 17th bit of the lower register. When the EXUBUS-DUTY an INTOUTY + SDUTY are driven active. EXUBUS-DUTY restores SDUTY w. the consecutive rising edge of CLK. Otherwise SDUTY is restored one clock-period after the falling edge of the enable of the current timer. The INTDUTY is just one period active. ARCHITECTURE BEHAVIORAL OF exu_body IS SIGNAL DUTYH : std_logic_vector(31 downto 0); SIGNAL DUTYL : std_logic_vector(15 downto 0); SIGNAL BB: std_logic; SIGNAL LSDUTY: std_logic; SIGNAL TMPINTDUTY,TMPSDUTY: std_logic; SIGNAL QBARSDUTY: std_logic; rights reserved. BEGIN ·· BEHAVIORAL -- instantiation ₹ INTTSRCV <= TSRCVGATE; INTTSXMT <= TSXMTGATE; SDUTY <= LSDUTY;</pre> Vienna. -- Process: P_MSRCV Technical University Putpose: - Inputs: EXUBUS,RESET,MTCLK,TSRCVGATE - Outputs: MSRCV P_MSCRV : PROCESS (EXUBUS, TSRCVGATE, CLK, RESET) _Mbun . BEGIN IF (RESET='0') THEN MSRCV <= ZERO32; IF (CLK='1' AND CLK'event) THEN IF (TSRCVGATE='1') THEN MSRCV <= EXUBUS(63 downto 32); END IF; of Computer Technology, END IF; END IF; END IF; END PROCESS P_MSCRV; Process: P_TSRCV -- Purpose: -- Inputs: EXUBUS, RESET, CLK, TSRCVGATE -- Outputs: TSRCV P_TSRCV : PROCESS (RESET, CLK, TSRCVGATE, EXUBUS) Horauer, Departement TSRCV : PROCESS (RES) BEGIN IF (RESET='0') THEN TSRCV <= ZERO32; ELSE IF (CLK='1' and CLK'event) THEN IF (TSRCVGATE='1') THEN TSRCV <= EXUBUS(31 downto 0);</pre> END IF; END IF; END IF; END IF; END PROCESS P_TSRCV; Ξ · · Process: P_MSXMT by Dipl.-Ing. Purpose: Inputs: CLK,RESET,EXUBUS,TSXMTGATE Outputs: MSXMT P_MSXMT : PROCESS (CLK, RESET, EXUBUS, TSXMTGATE) BEGIN IF (RESET='0') THEN MSXOMT <= ZERG32; ELSE IF (CLK='1' and CLK'event) THEN IF (TSXMTGATE='1') THEN 19961 0 MSXMT <= EXUBUS(63 downto 32); END IF: END IF; END IF; END PROCESS P_MSXMT; Process: P_TSXMT Purpose: Inputs: RESET,CLK,EXU Outputs: TSXMT RESET, CLK, EXUBUS, TSXMTGATE P_TSXMT : PROCESS (RESET,CLK,EXUBUS,TSXMTGATE) IF (RESET='0') THEN TSXMT <= ZERO32; ELSE IF (CLK='1' and CLK'event) THEN ``` | Notes | | | |-------|----------------------------------------------------------------------------------------------------------------------|--| | | | | | | | | | | /ed. | | | | hts resen | | | | na. All rig | | | | ersity Vier | | | | © 1996 by DiplIng. M. Horauer, Departement of Computer Technology, Technical University Vienna. All rights reserved. | | | | ogy, Techi | | | | Technolo | | | | Computer | | | | ement of | | | | er, Depart | | | | M. Horaue | | | | DiplIng. | | | | 1996 by I | | | | <b>◎</b> | | | | | | | | | | | | | | ``` IF (TSXMTGATE='1') THEN TSXMT <= EXUBUS(31 downto 0): END IF: END IF; END PROCESS P_TSXMT; Process: P_DUTYH Purpose: Purpose: RWBAR, BE, RESET, CLK, MDATAW Outputs: DUTYH P_DUTYH : PROCESS (RWBAR, BE, RESET, CLK, MDATAW) BEGIN BEGIN IF (RESET='0') THEN DUTYH <= ZERO32; ELSE IF (CLK='1' and CLK'event) THEN IF (ADDR='10* and RMBAR='0' and BE=*0001*) THEN DUTYH(7 downto 0) <= MDATAW(7 downto 0); ELSIF (ADDR='10* and RMBAR='0' and BE=*0010*) THEN DUTYH(15 downto 8) <= MDATAW(15 downto 8); ELSIF (ADDR='10* and RMBAR='0' and BE=*0100*) THEN DUTYH(23 downto 16) <= MDATAW(31 downto 16); ELSIF (ADDR='10* and RMBAR='0' and BE=*0100*) THEN DUTYH(31 downto 24) <= MDATAW(31 downto 24); ELSIF (ADDR='10* and RMBAR='0' and BE=*0011*) THEN DUTYH(15 downto 0) <= MDATAW(15 downto 0); ELSIF (ADDR='10* and RMBAR='0' and BE=*0110*) THEN DUTYH(31 downto 16) <= MDATAW(15 downto 16); IF (RESET='0') THEN All rights reserved University Vienna. ELSIF (ADDR="10" and RWBAR='0' and BE="1100") THEN DUTTH(31 downto 16) <= MDATAW(31 downto 16); ELSIF (ADDR="10" and RWBAR='0' and BE="1111") THEN DUTTH <= MDATAW; END IF; END IF; END IF; END PROCESS P DUTYH: Technical Purpose: Inputs: ADDR,RWBAR,BE,RESET,CLK,MDATAW Outputs: DUTYL,EB Departement of Computer Technology, P_DUTYL : PROCESS (RWBAR, BE, RESET, CLK, MDATAW) BEGIN IF (RESET='0') THEN DUTYL <= ZER016; EB <= '0'; END IF: END IF; END IF; END PROCESS P_DUTYL; Horauer, -- Process: P_DUTY Ξ Purpose: DutyH, DutyL, EB, EXUBUS, CLK, RESET Outputs: INTDUTY, SDUTY by Dipl.-Ing. INTDUTY <= (TMPSDUTY AND OBARSDUTY): LSDUTY <= TMPSDUTY; 19961 P_DUTY: PROCESS (DUTYH, DUTYL, EB, EXUBUS, CLK, RESET) BEGIN IF (RESET='0') THEN TMPSDUTY <= '0'; 0 ELSE ELGE IF (CLK='1' and CLK'event) THEN IF ((EXUBUS(55 downto 8) >= (DUTYH & DUTYL)) and EB='1') THEN TMPSDUTY <= '1'; ELSIF ((EXUBUS(55 downto 8) >= (DUTYH & DUTYL)) and EB='0') THEN TMPSDUTY <= '0';</pre> ELSE TMPSDUTY <= '0': FIND IF END IF; END IF; END IF; END PROCESS P_DUTY; Process: P_DUTYGATE Purpose: CLK, TMPSDUTY, RESET Inputs: CLK, TMPSD Outputs: QBARSDUTY ``` | Notes | | | |-------|-----------------------------------------------------------------------------------------------------------------------|--| | | | | | | | | | | erved. | | | | rights rese | | | | © 1990 by DipiIng. M. Horauer, Departement of Computer echnology, Technical University Vienna. All rights reserved. | | | | niversity v | | | | Chnical Ur | | | | nology, 1e | | | | uter i ecni | | | | of Compu | | | | овпете | | | | rauer, De | | | | ρη<br>Σ | | | | i. idio<br>A | | | | 06<br>66<br>1<br>3<br>3 | | | | | | | | | | | | | | ``` P_DUTYGATE : PROCESS (TMPSDUTY,CLK,RESET) BEGIN IF (RESET='0') THEN QBARSDUTY <= '0'; ELSE IF (CLK='1' and CLK'event) THEN QBARSDUTY <= not (TMFSDUTY); END IF; END IF; END FROCESS P_DUTYGATE; END BEHAVIORAL; ``` The Figure 1.5, the previously description and the Table ?? are a fundamental description that should exist in any case before one starts coding. It eases VHDL-coding drastically, clarifies the the dataflow and gives always a brief overview of the module. Sometimes in the previous files we've included our own package. This could look like the following one. In the package we declare constants, functions and procedures that are frequently used, whilst their code remains in the package\_body section. In our example there are only constants, which can be used either for HDL-coding or for simulation. Note that the type *time* must be hidden from the synthesis tools, therefore use the Synopsys synthesis off and on switches (they are special comments treated seperately) as illustrated. ``` Computer Technology Dept University of Technology, Vienna All Rights Reserved project designer version file name Martin HORAUER exupkg_pkg.vhd title module tools Synopsys ref. lib. ref. pkg. Roadmap library IEEE; use IEEE.std_logic_1164.all; package exupkg is constant ZER016 :std_logic_vector:= *00000000000000000; constant ZER032 :std_logic_vector:= *000000000000000000000000000000; --synopsys synthesis off constant t_CLK_period : time := 40 ns; constant t_half_CLK_period : time := 20 ns; constant t_WAITCYCLE: time := 0 ns; · · x Waitestates (x*CLK) constant t_waitcycle_pulse_width: time := 0 ns; constant t_ADDR_setup : time := 5 ns; constant t_ADDR_hold : time := 5 ns; constant t_ADDR_wild : time := (t_ADDR_setup+t_CLK_period+t_ADDR_hold); constant t_ADDR_finish: time := (t_CLR_period-t_ADDR_hold); constant t_rwb_setup : time :* 5 ns; constant t_rwb_hold : time :* 5 ns; constant t_rwb_valid : time :* (t_ADDR_valid*t_rwb_setup*t_rwb_hold); constant t_rwb_finish: time := (t_ADDR_finish-t_rwb_hold); constant t_data_write_setup : time := 10 ns ; constant t_data_write_hold : time := 5 ns ; constant t_data_write_finish: time := (t_CLK_period-t_data_write_hold); constant t_be_setup : time := 5 ns; constant t_be_hold : time := 5 ns; constant t_be_valid : time := (t_ADDR_valid+t_be_setup+t_be_hold); constant t_be_finish: time := (t_ADDR_finish-t_be_hold); constant t_gate_hold : time : 2 3 ns; constant t_gate_metup : time := t_half_CLK_period; constant t_gate_finish: time := (t_CLK_period-t_gate_hold); --synopsys synthesis_on end exupkg; package body exupkg is ``` 1996 by Dipl.-Ing. M. Horauer, Departement of Computer Technology, Technical University Vienna. All rights reserved. | Nictor | | | |----------------------------------------------------------------------------------------------------------------------|--|--| | Notes | | | | | | | | | | | | ρ̈́θ | | | | is reserv | | | | . All right | | | | © 1996 by DiplIng. M. Horauer, Departement of Computer Technology, Technical University Vienna. All rights reserved. | | | | Jniversit | | | | chnical L | | | | logy, Te | | | | Techno | | | | ompute | | | | nent of C | | | | Departen | | | | orauer, [ | | | | ng. M. | | | | y DiplI | | | | © 1996 F | | | | | | | | | | | | | | | Now analyze the files with the command: %vhdlan -nc -spc exu\_pkg.vhd exu\_mdmux\_ent.vhd exu\_mdmux\_beh\_arch.vhd exu\_body\_ent.vhd exu\_body\_beh\_arch.vhd exu\_beh\_arch.vhd exu\_beh\_arch.vhd exu\_beh\_arch.vhd exu\_beh\_arch.vhd The first switch avoids printing a header to the standard output, and the second (-spc) forces the analyzer to check the code for fragments that wouldn't be syntesizable. When all errors are diminished, proceed with simulation. ``` Computer Technology Dept University of Technology, Vienna All Rights Reserved project : UTCSU designer : Martin version : 1.0 UTCSU Martin HORAUER 1.0 exu_tb.vhd Example Unit - Testbench IEEE version : 1.0 file name : exu_tb.vhd title : Example Un: module : TERE tools : Synopsys ref. lib. : IEEE ref. pkg. : 1164,arith Roadmap : Date : 10/96 library IEEE; ary iEEE; use IEEE.std_logic_1164.all; use IEEE.std_logic_arith.all; synopsys translate_off use IEEE.std_logic_textio.all; use Std.textio.all; synopsys translate_on USE work.exupkg.all; entity exu_tb is architecture tb of exu_tb is FILE afile: TEXT is in "exu_control.dat"; FILE rfile: TEXT is in "exu_control.dat"; FILE dfile: TEXT is in "exu_control.dat"; FILE bfile: TEXT is in "exu_control.dat"; FILE hfile: TEXT is in "exu_control.dat"; FILE yfile: TEXT is in "exu_control.dat"; FILE file: TEXT is in "exu_control.dat"; FILE file: TEXT is in "exu_control.dat"; FILE ifile: TEXT is in "exu_control.dat"; FILE jfile: TEXT is in "exu_control.dat"; signal ADDR: std_logic_vector(1 downto 0); signal RWBAR: std_logic; signal EE: std_logic_vector(3 downto 0); signal CLK: std_logic; signal RESST: std_logic; signal MDATAW: std_logic_vector(31 downto 0); signal MDATAW: std_logic_vector(31 downto 0); signal INTPBUS: std_logic_vector(63 downto 0); signal INTPSUS: std_logic; signal TSRCVGATE: std_logic; signal SAWTGATE: std_logic; signal INTTSXMT: std_logic; signal INTTSXMT: std_logic; signal INTDUTY: std_logic; signal INTDUTY: std_logic; signal SDUTY: std_logic; signal READMUX: std_logic_vector(1 downto 0); port( ADDR: in std_logic_vector(1 downto 0); ADDR: in std_logic_vector(1 downto 0); RMBAR: in std_logic; BE: in std_logic; CLK: in std_logic; RESET: in std_logic; MDATAR: out std_logic_vector(31 downto 0); MDATAW: in std_logic_vector(31 downto 0); READMUX: in std_logic_vector(1 downto 0); INTPRUS: in std_logic_vector(63 downto 0); mcscrvatare: in std logic; INTPBUS: in std_logic_we TSRCVGATE: in std_logic; TSXMTGATE: in std_logic; INTTSRCV: out std_logic; INTTSXMT: out std_logic; INTDUTY: out std_logic; SDUTY: out std_logic; end component; example unit: exu port map (ADDR, RWBAR BE, CLK, RESET, MDATAR, MDATAW, READMUX, INTPBUS, TSRCVGATE, TSXMTGATE, INTTSRCV, INTTSXMT, INTDUTY, SDUTY ``` Technical University Vienna. All rights reserved. M. Horauer, Departement of Computer Technology, 1996 by Dipl.-Ing. 0 P CLK: process | ., <del>11</del> | Notes | 1 | |------------------|-------|----------------------------------------------------------------------------------------------------------------------| | | Notes | | | | | | | | | B. | | | | nts reserve | | | | ınna. All rigi | | | | iversity Vie | | | | echnical Un | | | | © 1996 by DiplIng. M. Horauer, Departement of Computer Technology, Technical University Vienna. All rights reserved. | | | | nputer Tech | | | | nent of Con | | | | r, Departen | | | | M. Horauer | | | | y DiplIng. | | | | © 1996 by | | | | | | | | | | | | | ``` begin CLK <= '1'; wait for t_half_CLK_period; CLK <= '0'; wait for t_half_CLK_period; end process P_CLK;</pre> begin w.=true: while w loop if endfile(afile) then assert false report *Testfile zu Ende*; w:=false; All rights reserved. wait; end if; end it; readline(afile, r_line); read(r_line, control); if (control*'A') then readline(afile, r_line); read(r_line, cADDR); ADDR <= *00*; ADDR <= CADDR; wait for t_ADDR_valid; wait for t_NAITCYCLE; ADDR <= *00*; wait for t_ADDR_finish; wait for (t_CLK_period-t_ADDR_setup); Vienna. else readline(afile, r_line); Departement of Computer Technology, Technical University end if; end loop; wait; end process P_ADDR; P_RWBAR: PROCESS P_RWBAR:PROCESS variable r_line: line; variable control: character; variable crwb: std_logic; variable w: boolean; begin begin w:=true; while w loop if endfile(rfile) then assert false report *Testfile zu Ende*; w:=false; wait; read(r_line_control); read(r_line, r_line); read(r_line, control); if (control='R') then readline(rfile, r_line); read(r_line, crwb); RWBAR <= '1';</pre> RWBAR <= '1'; RWBAR <= Crwb; wait for (t_CLK_period·t_rwb_setup); wait for t_rwb_valid; wait for t_WAITCYCLE; RWBAR <= '1'; wait for t_rwb_finish; elea</pre> else readline(rfile, r_line); end if; end loop; wait; Horauer, end process P_RWBAR; P_DATA: PROCESS Ξ variable r_line: line; Dipl.-Ing. ģ w:=true; while w loop 1996 if endfile(dfile) then assert false report *Testfile zu Ende*; w:=false; wat; end if; 0 wait for (2*t_CLR_period+t_WAITCYCLE-t_data_write_setup); MDATAW <= cdata; else readline(dfile, r_line); end if; end loop; wait; end process P_DATA; ``` | Γ | Notes | |---|-------| | | NOLES | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | ``` P BE: PROCESS variable r_line: line; variable control: character; variable cbe: std_logic_vector{3 downto 0}; variable w: boolean; if endfile(bfile) then assert false report *Testfile zu Ende*; w:=false; ass. w:=false; wait; end if; read(ine(bfile, r_line); read(r_line, control); if (control='8') then read(ine(bfile, r_line); hread(r_line, cbe); BE <= *0000*; wait for (t_CLK_period-t_ADDR_setup); 'for t_be_valid; '**TCYCLE;</pre> All rights reserved. wait for t_be_finish; else else readline(bfile, r_line); end if; end loop; wait; end process P_BE; Departement of Computer Technology, Technical University Vienna. P_RESET: PROCESS variable r_line: line; variable control: character; variable creset: std_logic; variable w: boolean; begin RESET <= '1'; w:=true; while w loop</pre> else readline(hfile, r_line); end if; end loop; wait; end process P_RESET; Horauer, P READMUX: PROCESS variable r_line: line; variable control: character; variable creadmux: std_logic_vector(1 downto 0); variable w: boolean; Σ begin READMUX <= *00*; Dipl.-Ing. I w:=true; while w loop while w loop if endfile(jffie) then assert false report "Testfile zu Ende*; w=false; wait; end if; readine(hfile, r_line); read(r_line, control); if (control='J') then readine(hfile, r_line); read(r_line, creadmux); READMUX <= cedmux; wait for 3*t_CLK_period; READMUX <= *CO*; wait for t_WAITCYCLE; else ģ 19961 else readline(jfile, r_line); end if; end loop; end process P_READMUX; P_INTPBUS: PROCESS variable r_line: line; variable control: character; variable cINTPBUS: std_logic_vector(63 downto 0); ``` | Notes | |-------| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | ``` variable w: boolean; begin w:=true; while w loop if endfile(yfile) then assert false report *Testfile zu Ende*; w: *false; wait; end if; readline(yfile, r_line); All rights reserved. readline(yfile, r_line); end if; end loop; wait; end process P_INTPBUS; Technical University Vienna. P_TSRCVGATE: PROCESS variable r_line: line; variable control: character; variable ctsrcv: std_logic; variable w: boolean; begin w:=true; while w loop if endfile(ffile) then assert false report "Testfile zu Ende"; w:≃false: Horauer, Departement of Computer Technology, else readline(ffile, r_line); end if; end loop; end process P_TSRCVGATE; P_TSXMTGATE: PROCESS variable r_line: line; variable control: character; variable ctsxmt: std_logic; variable w: boolean; w:=true; while w loop if endfile(ifile) then assert false report *Teatfile zu Ende*; w:=false; wait; end if; read(ine(ifile, r_line); Ξ 1996 by Dipl.-Ing. readline(ifile, r_line); end if; end loop; wait; end process P TSXMTGATE: configuration cfg_exu_tb of exu_tb is for tb for example_unit; exu use entity work.EXU(BEHAVIORAL); end for; end for: end cfg_exu_tb; ``` The testbench that is illustrated now should explain a way of coding to make testing a bit more modular and easy to use. It is based on some preassumptions, that when they | Notes | |-------| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | are met by the design, make it easy to use the testbench with little modifications on all different kinds of modules. The assumption is that you have a periodic bus-cycle and that all signals that don't apply to such a category can be modeled in the same periodic fashion. What follows is a testbench file that reads stimuli data from an ASCII data file. According to the periodic signals, the stimuli are taken from this file only, when they should be valid. In the gaps between, when the values are of no interest for the bus-cycle, they are set to a default value, that is usually related to the idle time. The testbench is structured into several processes, where every process reads simultaneously to all others the stimuli data. The data file consists of a comment line followed by the data. The relevant data for a process checks, if the first letter in a comment line corresponds to the letter that is applied to it. If the comparison is true the following data in the next line is applied to the described models. Therefore to keep all processes simultaneous, within every bus-cycle must exist a data value for every process. ``` rights reserved ₹ A - Address **** RESET ********** 00 R - RWB University Vienna. J - REAMUX · INTERIIS 00FFFFFFFFFFF00 F · TSRCVGATE · Byte Enable I · TSXMTGATE H - RESET A - Address **** DUTYH ********** J - REAMIN Technical Y - INTPBUS 0123ACDE5432F012 F - TSRCVGATE B - Byte Enable I - TSXMTGATE H - RESET Departement of Computer Technology, - MDATAW FFFFFFFF F - TSRCVGATE · Byte Enable J - REAMUX 00 Y - INTPBUS 00FFFFFFFFFFD00 - MDATAW ----- EB=1 - Address **** DUTYL ********** J - REAMUX R · RWB - INTERNIS MDATAW ···· EB≈1 00FFFFFFFFFFD00 F · TSRCVGATE 0A37FFFE B - Byte Enable F H - RESET Horauer, - TSXMTGATE A - Address **** nothing ********* J - REAMUX Ξ - RMB OFFFFFFFFFFD00 TSRCVGATE Dipl.-Ing. · Byte Enable I - TSXMTGATE H - RESET A - Address **** nothing ********** 1996 by [ F - TSRCVGATE B - Byte Enable H - RESET · Address **** nothing ********* R - RWB INTPBUS D - MDATAW TSRCVGATE Byte Enable · Address **** nothing ********* - REAMUX - RWB TAMPDRIE · TSXMTGATE ``` | <br> | |-----------| | <br>Notes | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | rights reserved ₹ Departement of Computer Technology, Technical University Vienna. Horauer, Ś 1996 by Dipl.-Ing. ``` H - RESET - RWB J - REAMUX 11 Y - INTEBUS · MDATAW ····· EB=0 0123ACDE5432F012 F · TSRCVGATE B - Byte Enable H - RESET I - TSXMTGATE J - REAMUX 00 Y - INTPBUS A - Address **** MSRCV *********** · RWB 60FFFFFFFFFFF00 F · TSRCVGATE I - TSXMTGATE B - Byte Enable A - Address **** nothing ********** H - RESET 00 R · RWB J · REAMUX OG Y · INTPBUS D - MDATAW 03C10E23 B - Byte Enable 0123ACDE5432F012 P TSRCVGATE L · Big/Little Endian I - TSXMTGATE H - RESET J - REAMUX Y - INTPBUS 0000111100001100 F - TSRCVGATE MDATAW B - Byte Enable I · TSXMTGATE J - REAMUX 01 0123ACDE5432F012 F - TSRCVGATE 0 I - TSXMTGATE D - MDATAW B · Byte Enable 0 A - Address **** MSXMT *********** H · RESET 10 R - RWB 1 J · REAMUX 01 Y · INTPBUS 000000FFFFFFE00 F · TSRCVGATE D - MDATAW 03C10E23 B - Byte Enable F H - RESET - Address **** nothing ********* - REAMUX R - RWB Y - INTPBUS 0123ACDE5432F012 F - TSRCVGATE · MDATAW D - MDATAW 03C10E23 B - Byte Enable F H - RESET 0 I - TSXMTGATE J - REAMUX 00 Y - INTPBUS 0000000AAAAAAAAOO F - TSRCVGATE D - MDATAW 03C10E23 B - Byte Enable F H - RESET I · TSXMTGATE A - Address **** TSXMT ********** J - REAMUX 11 · INTPBUS 0123ACDE5432F012 F - TSRCVGATE - TSRCVGATE B - Byte Enable ``` Due to the fact that simulation is often a very interactive process, create an include file that holds the relevant commands for the simulator (e.g. which signals to trace). The following could be an example for the previously described EXU. ``` cd /EXU_TB trace CLK trace RESET trace ADDR trace BBE trace RWBAR trace MDATAW trace MDATAW trace EXUBUS cd /EXU_TB/EXAMPLE_UNIT/UEXUBODY trace DUTYL trace EB trace HNDUTY ``` Figure 1.8: The waveform window trace SDUTY trace TSRCVGATE trace TSXMTGATE trace MSRCV trace TSRCV Now analyze the testbench with the command %vhdlan -nc exu\_tb.vhd and start the simulator either via %vhdldbx -i exu\_tb.inc CFG\_EXU\_TB %vhdlsim -i exu\_tb.inc CFG\_EXU\_TB. In addition to the commands specified in the include file, you can enter commands at the command prompt (e.g. *run 3000*). The waveform window (see Figure 1.8) is rather intuitive. When the simulation runs perform as intended, you can continue with synthesis. The major functionalities for synthesis were already described in the prior sections. Therfore the commands of the following script should already be at hand. Ξ 1996 by Dipl.-Ing. 0 /\* targeted for SynopsysV3.4a \*/ ``` PACKAGES=(exu_pkg.vhd) analyze of vhdl PACKAGES EXU_MDL_FILES=(exu_body_ent.vhd exu_body_beh_srch.vhd exu_mdmux_ent.vhd exu_mdmux_beh_arch.vhd exu_ent.vhd exu_beh_arch.vhd) analyze -f vhdl EXU_VHDL_FILES elaborate exu current_design(exu) current_design(exu) clock_name = CLK create_clock clock_name -period 40 -waveform (0 20) set_dont_touch_network (clock_name) set_dont_touch_network (clock_name) set_dont_touch_network (clock_name) set_dont_touch_network (clock_name) set_dont_touch_network (clock_name) set_scan_style multiplexed_flip_flop set_input_delay 8 find(port.*TEXUBURS*) -clock clock_name set_input_delay 8 find(port.*TEXUBURS*) -clock clock_name set_output_delay 20 find(port.*TINTTSXMTCN*) -clock clock_name set_output_delay 20 find(port.*INTTSXMT*) -clock clock_name set_load 0.2 all_outputs() set_max_fanout 1 all_inputs() remove_attribute find(port.*CLK*) max_fanout set_driving_cell -cell LIBINV -library ecpd07_ind all_inputs() set_driving_cell -none find(port.*CLK*) compile All rights reserved compile write -f vhdl -hier -o comp/exu.vhd write -f db -hier -o comp/exu.db report_area > comp/exu.area.rep report_timing > comp/exu_timing.rep Vienna. Horauer, Departement of Computer Technology, Technical University /* SCANpath insertion */ /* In the case you have a bidirectional databus create a new level of hierarchy, where only the bidirectional function of the data bus is described. On top of this file insert scan path logic. After scan insertion you'll have to replace the file with the bidir information with a file where the pads are instantiated. */ set_test_methodology full_scan set_scan_style multiplexed_file_flop test_default_period = 1000.0 test_default_bidir_delay = 55.0 test_default_bidir_delay = 550.0 create_test_clock CLK -waveform (450.0 550.0) check_test check_test check_test insert_test ·no_disable ·max_scan_chain_length 500 check_test > scan/check_test_after_testinsertion.rep /* generate buffer tree for test_scan_enable signal */ set_max_fanout 1 find[port, *test_set] compile only_design_rule write of db hier o scan/exu_scaned.db write of vhdl hier o scan/exu_scaned.vhd check test /* generate reports on the final design */ /***** check_design > scan/check_exu.rep report_area > scan/exu_area.rep report_cell > scan/exu_cell.rep report_net > scan/exu_trep report_net > scan/exu_trep report_hierarchy > scan/exu_trep report_timing > scan/exu_trep report_timing > scan/exu_trep report_transitive_fanout -clock_tree > scan/exu_fanout.rep report_test :port > scan/exu_ports.rep report_test -port > scan/exu_scan_path.rep report_test -coverage > scan/exu_scan_path.rep report_test -faults > scan/exu_faults.rep report_test -faults > scan/exu_faults.rep report_test -mask_fault > scan/exu_mask_fault.rep report_test -mask_fault > scan/exu_assertions.rep report_test -atpg_conflicts > scan/exu_astrions.rep report_test -atpg_conflicts > scan/exu_astrions.rep /* instantiate the pads */ read of vhdl top_exu.vhd change_names ·rules cadence_verilog ·hierarchy current_design exu_mdmux ungroup -all write f verilog o s2c/exu_mdmux.v current_design exu_body_test_1 ungroup -all write f verilog o s2c/exu_body_test_1.v current_design exu write f verilog o s2c/exu.v current_design top_exu write f verilog o s2c/top_exu.v current_design exu_mdmux ``` | <br>Notes | |-----------| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | The first part of this script analyzes, constrains and syntesizes the example unit (EXU). Refer to previous sections for an explanation. Afterwards scan-path-insertion is performed. First the scan methodology is set to *full-scan* and the scan-style is set to *multiplexed flip flop*. The next few lines define the timing related test attributes given by the ES2 documents. The *check\_test* command is useful to identify non-scanable sequential cells. Then with the command *insert\_test* scan-cells are inserted and the scan-path is instantiated. Afterwards the test select input (*test\_se*) is constrained and buffers are instantiated to fix design-rule violations. The *create\_test\_patterns* instruction calculates test patterns for this path. Next the reports give an overview of the derived results. Before the modules are made ready for transfer to Cadence, pads should be instantiated. One way would be to write a structural VHDL-source file, that instantiates several VERILOG-files after this stage, that can be read into CAdence via the Verilog-In procedure. –Refer to the next section how to continue then with the layout.— Now before you proceed with Cadence, you should perform a post-synthesis simulation. – Take the last saved design unit (in our case <code>scan/exu\_scaned.db</code>) and load it into dc\_shell: ``` >read -f db scan/exu_scaned.db >current_design exu_body_test_1 >ungroup -all >current_design exu >ungroup -all >write -f vhdl -o scan/exu_synthesized.vhd ``` Than edit this VHDL-file, to check that the lines for the library inclusion are correct (e.g. *use work.ECPD07.all;*), and the name of the instantiated architecture (e.g. *SYN\_BEHAVIORAL*). In general both items are handled via the setup-files and should be already instantiated as intended. In addition you have to edit your testbench file now to add a process that drives the test-select and test-input lines, the component to match the entity with the newly added test-ports, the port-mapping to the component and finally the configuration at the end of the testbench to point to the correct architecture. Analyze the VHDL-netlist *exu\_synthesized.vhd* and the modified testbench and invoke the simulator the same way you did for simulation at the logic level. | Notes | |-------| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | ### **Chapter 2** ### **Back-End design with CADENCE** Before you start with the back-end design of your project using CADENCE, make sure you got an own directory from within your project directory available (e.g. /project/< projectname >/cds). You can make a soft-link from within your home-directory to ease traversing through the system. Furthermore you need to have two files (or two links) in this directory called .cdsinit and .simrc. All this should already have been done by your project head, if not contact him. Before invoking Cadence you must allow the program to display the windows on your terminal. Therefore type % xhost +[terminalname] within an xterm window. Change to the working directory (e.g. /project/< projectname >/cds) and enter % icfb &. The command interface window (CIW) is displayed as illustrated in figure 2.1. Figure 2.1: The CIW interface First create a new library that corresponds to the name of your project (e.g. exu) with **Open** $\rightarrow$ **Library** $\hookleftarrow$ . In the displayed form fill in: Library Name $\boxed{\text{exu}}$ $\hookleftarrow$ . You are now prompted to create a new library - select $\hookleftarrow$ . Then in the next form specify a working and/or user group and apply the according permissions, leave all other items to their default. Open the library browser **Design Manager** $\rightarrow$ **Library Browser** you should see your newly created library. At the CIW command line prompt enter load "/project/proto/VerilogIn.il". The form for importing Verilog files, with some defaults preset, is displayed in table 2.1. From several items check and adjust the following settings: The import session can take several minutes up to several hours - stay patient. - The CIW reports many Warnings and Errors that should be checked carefully. - After the import process has finished you should have at least one schematic view in your design library, which you should open (e.g. via the Library Browser). Within the schematic view of your top-level design perform a **Check and Save** in every level of the hierarchy in a | Notes | | | |-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | | | | | | | | | λ<br>Θ<br>Q | | | | ights rese | | | | enna. All r | | | | iversity Vi | | | | chnical Ur | Michigan Company of the t | | | nology, Te | The second secon | | | outer Tech | | | | of Comp | | | | eparteme | | | | 4. Horauer, Γ | S. Other Present Live | | | MIng. MI | | | | © 1996 by DiplIng. M. Horauer, Departement of Computer Technology, Technical University Vienna. All rights reserved. | | | | <ul><li>○</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-<li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><li>-</li><l< th=""><th></th></l<></li></ul> | | | | | | | | | | | | | | Target Library Name Reference Libraries Verilog Design Files Verilog Options Verilog Cell Modules View exu StdLib PadLib basic /project/exu/syn/s2c /users/ict2/staff/es2lib/ecpd07/utl/verilog/dllib\_ind -y/project/dd/exu/syn/s2c +libext+.v ♦Import **♦**Schematic Table 2.1: The VerilogIn form bottom up manner. Before doing so at the top instance, perform the last final changes as instantiating and connecting an oscillator cell, a power-on reset and all the other elements that make up the final design. Furthermore you require for e.g. a cell called LIBTOPNETS, that adds information for the supply nets, and some pads for both supply of core and peripheral. How many and what kind of pads have to be used therefore is described in [ES294] on page 3-3 ff. Figure 2.2: The Schematic View When you have fixed everything and done the final 'check and save' operation, bring up the hierarchy browser via **Tools** $\rightarrow$ **Floorplan/Schematics** and **Floorplan** $\rightarrow$ **Hierarchy Browser**. For a flat design, click on the top instance and perform **Hierarchy** $\rightarrow$ **Generate Physical Hierarchy**. The views *autoLayout* and *autoAbstract* are created. For a hierarchical design, the above action should be repeated for every level of hierarchy - therefore expand the top element **by instance**. Alternatively you can also open the flat *autoLayout* and use the browser to cross select the instances of each hierarchy and perform a **Create** $\rightarrow$ **Softblock**. Anyway don't *regroup* the hierarchy due to the fact that CADENCE would rename several nets. Then you would no longer be able to run an LVS check later on. The previously generated *autoLayout* can now be opened into Cell Ensemble by selecting **Tools** $\rightarrow$ **Floorplan/P&R** $\rightarrow$ **Cell Ensemble**. As a first step load the net information for routing (track widths and separation of distinct nets). © 1996 by Dipl.-Ing. M. Horauer, Departement of Computer Technology, Technical University Vienna. All rights reserved. ### Route → Modify Net → Net Properties File - ♦/users/ict2/staff/es2lib/ecpd07/utl/startup/netData - **♦**reac This file contains information for the nets vdd! and gnd!. Now add glue cells such as LIBCORNER with Place $\rightarrow$ Glue Cell $\rightarrow$ Add. – To move the cells out of the placement region perform Floorplan $\rightarrow$ Reinitialize. Then make Region selectable in the Object Selection Window (OSW) and click on the default region, that was created after reinitialisation. Perform Floorplan $\rightarrow$ Analyze Floorplan Objects and enter the desired number of rows (use an even number preferably) and a percentage for the desired row utilization. Both values require some experience and must be derived in an interactive manner. (e.g. 90% row utilization) – Keep in mind that the router expands primarily up and a bit on both sides but not down! – Drag the placement region in a way that the routing channels between the standard cell rows become a bit smaller in height than the standard cells. Therefore considering these aspects, the width of the placement region should be greater than the height in case you have a square core area in mind. Now adjust the design outline to the default region and perform a second reinitialisation with only the *instance status* left on. Load the floorplan file Place $\rightarrowtail$ I/O commands $\rightarrowtail$ Read Initial File to place the pads around the placement region. When the file is correct all but the LIBCORNER pads should be moved to their desired places. In some cases the placer swaps a few pads, therefore control the placement carefully. Than move $\boxed{m}$ and rotate $\boxed{F3}$ the corner cells to their locations and use the command Edit $\rightarrowtail$ Align Cells to position them and change the property $\boxed{q}$ from unplaced to placed. | VDDPY1 | left | 1 | |---------------|--------|----| | PIN_TEST_SE | left | 2 | | PIN_TEST_SI1 | left | 3 | | | | | | GNDPY1 | bottom | 1 | | PIN_DATAI_0 | bottom | 2 | | PIN_DATAI_1 | bottom | 3 | | | | | | PIN_CSUTIME13 | right | 23 | | VDDPY5 | right | 24 | | GNDPY2 | top | 1 | | PIN_CSUTIME14 | top | 2 | | | | | The example on the left shows how such a placement file should be constructed. The first column lists the pin names, the second the position and the third the order they are positioned. A counter clockwise placement is performed. Start the placement of the standard cells with Place >-- Automatic ### ♦Insert Feedthru Feedthru Library Name: **StdLib** Feedthru Master Name: **LIBFEED** Placement Snap Grid: **0.1** (Ecpd07) Sometimes after placement of the standard cells you have to fix up the position of the corner cells again. Now bring up the menu for the power cells $Place \rightarrow Power Cell \rightarrow Add$ Manual. Depending on the size of the placement region you add either only cap cells on each end of a row, or when the length of a row exceeds some values, influenced by the operating frequency (see [ES294] on page 3-6), you'll have to add power bars. For the later take care that the cells have all the same x-positions after placement, otherwise the routing becomes worse. In the **Define Power Cell** menu select LIBLCAP and LIBRCAP for the cap cells. For powerbar grid routing add also LIBPGB40 and LIBPGFILL and disable the distribute feedthru option. Usually the later two should be omitted in most cases ←. Now draw two rectangles over the left and right side of the standard cell rows and select ←. Power cells should be inserted, if not correct the placement and repeat the above step. Figure 2.3 gives a glimpse of an exemplary Figure 2.3: A placed design placement. <u>\!/</u> Now select *all* instances and do a **Place** $\rightarrow$ **Snap to Grid** with a value of 0.1. Placement is now finished and can be saved as for e.g. placed. The next step is **Route** $\rightarrow$ **Channels** $\rightarrow$ **Create** and to modify the net properties of dedicated nets, such as for e.g. the clock net, via **Route** $\rightarrow$ **Modify Net** $\rightarrow$ **Modify Net Properties**. – To determine the width and separation of the clock net see [ES294] on page C-6. – Set the preferred layer to CME2, the signal type to *clock* and the criticality to 105. Then invoke interactive global route on the clock and supply nets. Route →Global Route →Interactive Global Route, select Initialize Net and enter a net name for global routing (e.g. |Clock, vdd!, gnd!). With Settings you can enlarge the snap points from 1 to say 19. You should recognize all available snap points for the selected net. You can select those you want to connect either by clicking on them or via the Select Scan Chain menu. – Take care of the order you select points, because it can influence the desired routing order. – When you've all desired nets selected, Connect Set will tie them together. Via Modify Set you can apply a routing width and a preferred layer for the selected segments. Therefore if you want different widths of segments (e.g. the main clock trunk is in general far thicker than the clock net within a channel), you've to modify those separate parts individually. Before you push the Exit Net button, the modified snap points should be selected, otherwise you can get malicious routing results. On exiting the net, select the Fix Global Route option and to remove all the snap points. If you're prompted for an edge connected attribute, you've obviously | <br>Notes | |-----------| | | | | | | | | | | | | | | | | | | | | | | | | | | | ! | | | | | | | | | | | forgotten to connect some instances. After all special nets are global routed, you can exit the Interactive Global Route menu by hitting the Done button. Now perform global routing Route $\rightarrow$ Global Route $\rightarrow$ Automatic $\leftarrow$ . This takes a while - take a look at the CIW. Then continue with Route $\rightarrow$ Detail Route $\rightarrow$ Automatic. Choose the Compact button to set the routing grid to 0.1 microns and start the detail router. If errors occur they are prompted in the CIW whilst routing. Then save the design under a meaningful name (e.g. layout), as shown in figure 2.4. Figure 2.4: The final layout Now that placement and routing is finished, finalize the chip by performing a DRC and LVS run followed by a final sign-off simulation. Open the previously saved view and change to the layout interface $Tools \rightarrow Layout$ . In the CIW window select Technology $File \rightarrow Compile Technology$ and specify /users/ict2/staff/es2lib/ecpd07/utl/startup/diva.PR♦load In the layout view choose **Verify** $\rightarrowtail$ **DRC** in full and flat mode, with the switches *grid* and *correct* set. In the case that errors are reported, you can view them via **Verify** $\rightarrowtail$ **Markers** $\rightarrowtail$ **Find**. TIP: In the layout view you can modify segments easily by changing the values of the geometries you get from the properties window. Modification takes place on a solely segmented basis, therefore if you move a segment it is disconnected from the rest. In contrast the cell ensemble view remains the segments tied to each other when modified. If you're not able to select a wire, you must first descend into the desired module/channel and perform the check there once more to locate the same errors again. If you want to circumfere the required steps of traversing through the hierarchy, you can explode the channels from within the cell-ensemble view by **Route** $\rightarrow$ **Detail Route** $\rightarrow$ **Explode Channels**, which will promote the channels to the upper hierarchy level. In the case when the DRC checker reports zero faults proceed with Verify → Extract and select ♦ Macro Cell as extract method. When succeeding a view called extracted is created, that is used for the LVS run. Prior to the LVS run compile the technology file diva.lvs, that resides under the same directory as the one before for the DRC run. Then start Verify $\rightarrow$ LVS to compare the schematic versus the extracted view. In the case the run succeeds check the log file if the two views match; – if not search the directories LVS/schematic and LVS/layout for files with a .out extension (e.g. mergenet.out). These files contain information about the nets that caused the mismatch. (e.g. A merged net in the schematic is mostly caused by a short in the layout.) Open the layout in cell ensemble and highlight the conflicting nets with Edit $\rightarrow$ Search. Zoom into the regions where these nets cross and search for violations. Correct them and run the DRC, EXTRACT and LVS again. Hopefully you've corrected everything without introducing new errors, and the netlists now match. – Save the design! How to perform a post layout simulation? Within the cell ensemble view select all global nets with [.\*] and perform an Analyze → Parasitics → Extract on them. Than make sure that you have enough swap space available, before succeeding with the next step Analyze → Parasitics → Write reduced SPF with the option physical name mapping ◆. The name of the SPF file should be < top\_cellname > .spf. At the CIW command prompt enter > ES2generateSDF. This brings up a form, where you have to enter the library name, the name of the top\_cell and which kind of SDF (min, typ or max) to generate. When you select all three, you'll end up with six files (three sdf files and three reports with an extension .out). Check the reports carefully whether you're violating fanout and fan-in rules or not. If you got violations cross check them with the library data book. NOTE: If you connect two clock buffers in parallel and the load is greater than the one a buffer can drive, you'll see a warning. Check if the given load is less than the added load of the buffers. Now lets start with simulation. Open from within the schematic via **Tools** $\rightarrow$ **Simulation** the **Verilog-XL** environment. Change **Setup** $\rightarrow$ **Record Signals** from *Top Level I/O* to *All Signals*. Enter at the CIW prompt > **ES2simTemplate** and leave all options to their default values. Change to the simulation run-directory and edit the generated file *ES2testfixture.v.* At the bottom of the file you'll see a line for inclusion of an SDF file (top.sdf) and an inclusion of another verilog file (default\_stim.v) that supplies the user provided stimuli. An example of such a stimuli file is provided in appendix ??. Change the name to point to your file. What is still missing, is a file top.sdf in the simulation directory that has valid back-annotation information. Therefore enter at the CIW > **ES2sdfTranslation**. This copies the appropriate SDF file into the directory, generates a report that should be checked, and produces a soft-link called top.sdf that points to the real SDF file. TIP: If you have connected two clock buffers in parallel, check that the back-annotated SDF values for the buffer delays don't differ too much, otherwise your simulation run won't be successful. Make the two delays for CKBUF1 and CKBUF2 equal. Now press the **Start Interactive** button and simulation will start unless you haven't introduced any error in a previous stage. When simulation ends bring up the waveform viewer via **Debug** $\rightarrow$ **Utilities** $\rightarrow$ **View Waveform**. The simulation results that are stored below *shmDir/shm.db* in the run-directory is loaded automatically. You can now add signals of different levels to the waveform window by **Edit** $\rightarrow$ **Browser/Display Tool**. When all desired signals are on screen save the setup for other/later sessions. After you've checked the simulation (see figure 1.8) rename the directory *shm.db* and edit the previously saved setup-file to point there. This will avoid that the simulation run can be overwritten by follow-up runs. Figure 2.5: The Waveform window When everything's fine you can create a gds2 file out of the final layout view via **Translators** $\rightarrow$ **Stream Out**from the CIW. Fill in the working directory, choose Stream DB, Library Version 5.0, microns, append a layer map table (see appendix ?? for details) and activate in the options form the items report bad polygons and precision report. In the end you can load the script >load "/project/proto/retr.il". Then evaluate these script via >eval (retr()) to get some statistics and reports of the final layout. | Notes | | | |----------------------------------------------------------------------------------------------------------------------|--|--| | | | | | | | | | - eq | | | | nts reserv | | | | na. All rigi | | | | rsity Vien | | | | ical Unive | | | | Jy, Techn | | | | Fechnolog | | | | computer : | | | | ment of C | | | | ; Берапе | | | | . Horauer | | | | iplIng. M | | | | © 1996 by DiplIng. M. Horauer, Departement of Computer Technology, Technical University Vienna. All rights reserved. | | | | 9 | | | | | | | | | | | ### **Bibliography** © 1996 by Dipt.-Ing. M. Horauer, Departement of Computer Technology, Technical University Vienna. All rights reserved. [D.91] Perry D. VHDL. McGraw Hill, 1991. [ES294] ES2 ECPD07 Library Handbook, ES2 Process-Independent Library Handbook, ES2 Asic Design Handbook, 1994. [HYE95] Liu J. Hsu Y., Tsai K. and Lin E. VHDL Modelling for Digital Design Synthesis. Kluwer Academic Publishers, 1995. [IEE87] IEEE Standard VHDL Language Reference Manual - Std 1076-1987, 1987. [IEE93] IEEE Standard VHDL Language Reference Manual - Std 1076-1993, 1993. [J.92] Basker J. A VHDL Primer. Prentice Hall, 1992. [P.90] Ashden P. *The VHDL Cookbook*. available in postscript on the Internet, South Australia, 1990. [PT95] Kurup P. and Abbasi T. Logic Synthesis Using Synopsys. Kluwer Academic Publishers, 1995. [R.93] Lipsett R. VHDL: Hardware Description and Design. Kluwer Academic Publishers, 1993. [R.94] Ariau R. Circuit Synthesis with VHDL. Kluwer Academic Publishers, 1994. [S.96] Palnitkar S. Verilog HDL, A Guide to Digital Design and Synthesis. Prentice Hall, 1996.