# **Application Note 1.DNIX Introduction to the DAISY** | Table of Contents | 3 | |--------------------------------------|-----| | Introduction | 5 | | DED (DED I steps in graphic capture) | | | DANCE | | | DRINK | 24 | | RUN_AMCC | 24 | | RUN_DD | 24 | | RUN_AGIF | 25 | | RUN_ERC, AMCCERC | 25 | | RUN_ANN, AMCCANN | 26 | | RUN_SIFT | 33 | | SING, FMT_CSD.SING | 34 | | SOM_MCF.SING (simulation control) | 36 | | RUN_SOM | 38 | | DLS | 38 | | AMCCSIMFMT | 41 | | AMCCV RC | 52 | | Sample RUN_DLS (user-created) | 53 | | Parametric Tests | 54 | | Best Approach to Running the DAISY | 55 | | - | | | Appendix A Circuit Transcript | A-1 | ### Figures: | Figure | 1: | 1.DRAW for 16:1 MUX (Q5000T) | 14 | |--------|-----|-------------------------------------|----| | Figure | 2: | 2.DRAW for 16:1 MUX | 15 | | Figure | 3: | 3.DRAW for 16:1 MUX | 17 | | Figure | 4: | 4.DRAW for 16:1 MUX; thermal diodes | 18 | | Figure | 5: | 4.DRAW for 16:1 MUX; gate tree | 19 | | Figure | 6: | Screen transcript | 20 | | Figure | 7: | RUN_DD, DANCE.ERR, DRINK.ERR | 23 | | Figure | 8: | Running AMCCANN (preliminary | | | | | version of the release shown) | 27 | | Figure | 9: | AMCCPKG.LST (partial) | 31 | | Figure | 10: | FMT_SCD.SING file | 35 | | Figure | 11: | SOM_MCF.SING - unedited | 37 | | Figure | 12: | RUN_SOM screen transcript | 39 | | Figure | 13: | End of screen transcript | 40 | | Figure | 14: | DLS Format window | 42 | | Figure | 15: | Edited Format window - HEX | 43 | | Figure | 16: | DLS Mode window - unedited | 44 | | Figure | 17: | DLS Mode window - edited for MAX | 45 | | Figure | 18: | DLS Wave window - HEX | 46 | | Figure | 19: | DLS List window - HEX | 47 | | Figure | 20: | Partial Saved LIST file | 48 | | Figure | 21: | Output VLAIF file FUNCTION.VLAF | 49 | | Figure | 22: | AMCCSIMFMT transcript | 50 | | Figure | 23: | FUNCTION.VEC file from AMCCSIMFMT . | 51 | | Figure | 24: | RUN_DLS, RUN_ASDLS sample scripts . | 53 | ### INTRODUCTION TO THE DAISY ### Q5000 16:1 MUX MIXED MODE EXAMPLE The following provides a simple introduction to design with the AMCC Q5000 Series Logic Array on a DAISY EWS (Engineering Workstation) under the DNIX operating system, using the DED character graphics editor or DED2 character graphics editor. The problem is to design a 16:1 MUX which has TTL input and ECL output with a single +5V power supply. This requires the use of the TTL and ECL sections of the Q5000 macro library. The output is to pass through a D flip/flop. A parametric test gate tree has been added, along with extra power and ground and two thermal diodes. The circuit selected demonstrates: 1) the use of mixed-mode +5V ECL/TTL I/O; 2) the use of the ECL output with a latch; 3) proper naming of wires and macros; 4) the use of extensive notes on the drawing page to document the design; 5) the use of the FOD fan-out derating net parameter; 6) the use of the SWGROUP switch group macro parameter; 7) the chip macro parameters; and 8) the logic required for the optional parametric test vectors. This is a flat design. Logging in requires a user-name and may require a password. The AMCC seminar students use: USER: CLASS CLASS> CLASS> is the prompt for all actions at the command level, set in the AMCC supplied loginfile. If the /USER/CLASS user directory is not programmed, the system will come up at the top of the tree, i.e., at /, with a message to that effect. The user must make a directory: MKDIR /USER/CLASS and then change to it: CD /USER/CLASS From there, copy in an existing loginfile from another directory, if available: COPY /NET/D\_a/USER/CLASS/loginfile TO . If none is available, use the text editor and create your own, for example: TEC loginfile %SUBMIT /AMCC/Qnnn\_LIBS/QnnnnSETUP ... and whatever else you want there may be a networked datapath that needs to be in here - see your system manager Activate the loginfile by logging off and logging back on or by: ### %SUBMIT loginfile Always verify that: 1) you are in the correct directory, in the correct current context; and 2) that the correct library has been referenced in the loginfile. There is another way to do this but it sometimes has problems. Before starting schematic capture, any EWS user should make two checks: 1) that there is sufficient space for a new circuit (space on the hard disk); and 2) that the directory area to be used is either empty or loaded with known files. Check on the system disk memory available by typing: ### SPACE Display an inventory of the directory by typing one of these commands (there are other options): | INVS | [ S for sorted ] | |------------------------|----------------------| | INVL | [ L for long ] | | INV /USER/CLASS -L -DE | [ DE for deep nest ] | The loginfile at AMCC is currently preprogrammed to select the Q5000 library, as shown above. (Other libraries may be used by altering the loginfile to reflect that library.) AMCC provides preprogrammed shell scripts. The users may choose to add/modify/delete shell scripts at their own location on their own systems at any time - move them to another directory first! Beginners should stay with the provided shell scripts until they understand the actual commands. Following selection of the library, and the rest of the "housekeeping", the drawing editor DED is invoked by typing: | DED1: | DED 1 | [ DED n ] | DED | I | |-------|--------|------------|-----|----| | DED2: | DED2 1 | [ DED2 n ] | DED | ΙI | See the DAISY DED II introduction booklet for the comprable DED2 commands. DED1 will be operable under DNIX 5.02 but the user should begin to switch to the new editor in preparation for the ACE system. This application note was written for DED1. As soon as the editor is ready, a blank page is presented (if there is no page 1.DRAW already in the directory). For a new page, a border should be placed on the page and edited. When beginning a multiple-page drawing, plan ahead. If a page will not be created by replicating an existing page, it will always start with a border. Create several blank pages by copying a page with a border, comments, etc. into several page files. A border is placed one grid point up diagonally from the lower left corner. For any circuit, the border is: /AMCCPAGEB and is a component in the library. If the cursor is positioned, type: DED1: CO /AMCCPAGEB{EXTRACT}...{EXECUTE} The page should be given a unique six-character alphameric name (such as PAGEI), and then notes should be added in the lower right-hand block to document the date, page number, drawn by and a description of what is on the page. Multiple notes are created by {EXTRACT}ing notes from other notes. Multiple names are not allowed but {EXTRACT} can be used to make a copy of a name. Name: DED1: NA {SELECT}name{DEF}{PLACE}...{EXECUTE} DED1: NA (EXTRACT) {PLACE) ... {EXECUTE} This last version copies the same name from one place to another. Note: DED1: NOT {SELECT} any text{DEF}{PLACE}...{EXECUTE} DED1: NOT {EXTRACT} any text{DEF}{PLACE}...{EXECUTE} DED1: NOT {EXTRACT} {PLACE} ... {EXECUTE} This last version copies the same note from one place to another. A name or a note is deleted by opening the command through {SELECT} and then typing D{MACRO}EXECUTE}. A name or nore is edited by opening the command through {SELECT}, typing the new name or text and then typing {DEF} {PLACE} {EXECUTE}. The body of the drawing itself is then created by first fetching the basic macros and positioning them on the page. Use a paper sketch to design the initial layout for a circuit, to minimize wasted partial macros, minimize cross-overs, clarify where replication of macros, blocks and pages will save design entry time, and to identify the macros that will be used. (Don't do seat-of-the-pants design at the screen! It leads to frustration and error. Plan ahead.) For a new design, the first macro on page one should be a chip macro. Once it is properly parameterized, this macro will characterize the array as to its grade (military or commercial), its power supply, the type of ECL (10K or 100K) and power supply, and identify the product with a unique name and number. Parameters are added with a simplified form of the PARAMETER command. For this design, the chip macro is Q5000TTTL10K (this design fits into a Q1300T). DED1: CO /Q5000TTTL10K{EXTRACT}{PLACE}...{EXECUTE} Three parameters need to be attached to the chip macro, PRODUCT\_NAME, DEVICE\_NUMBER, PRODUCT\_GRADE. A fourth, POWER\_SUPPLY, does not apply to the I/O mode chosen (TTL10K is a single power-supply of +5V only). Position the cursor on the first of these parameters, located in the lower left side of the macro symbol, and type: DED1: PARA {SELECT}param-value{DEF}{PLACE}...{EXECUTE} The {PLACE} can be skipped if you positioned on the first character of the parameter name on the graphic symbol. Repeat for all of the parameters listed on the chip macro. The value possible for PRODUCT\_GRADE is either MIL or COM. The default power supplies are listed on the chip macro. The only time the POWER\_SUPPLY may be altered is for the STD ECL circuits, or MIXED ECL/TTL, where 5VREF, STD4 (-4.5V) or STD5 (-5.2V) can be specified. AMCC customer service assigns the PRODUCT\_NAME and DEVICE\_NUMBER. Regardless of technology, the input pins on a chip macro are tied to global ground. If the pin is a power pin (VCC), aim the wire up. If the pin is a ground pin, aim the wire down. The EWS and the software does not care - this is a human readable convention. The output of the chip macro is wired to a terminator or it is wired to a page connector. For this design the terminator is used. Use /LWTERM and connect it to the macro output pin with a wire. Do not allow the pins of any two macros to touch as the system may reboot and you will loose the page. Add any extra power or ground macros desired. For all AMCC Series arrays, the extra power and ground macros are ITPWR, ITGND and IEVCC. Regardless of technology, the extra power and ground macros, like the chip macros, have all input pins tied to GND. Draw a wire out and down and name the wire GND. For the VCC or ITPWR pins, the wire is drawn up by convention. (IEVCC is a power pin in a +5V REF ECL system.) The output of the power or ground macro is terminated. The basic wire command is: ### W {MARK}...{EXECUTE} Use {MARK} to draw bends. Using {MARK} twice without moving will cause DAISY to try to straighten out the wire. A partial wire requires specific connection steps befoe it can be picked up and continued. Dot-connects are formed by anding one wire on top of another (not at the end). There are on-page connectors that allow a cumbersom wire to be "broken" on a page. These should be used with care to avoid unintelligible drawings. Refer to the DED command summary for further wiring instruction. DED2 mouse wiring operations are sometimes preferrable. Any design begun in DED2 can switch back and forth between editors without leaving the DED environment. Any drawing begun in DED1 may be invoked from DED2. Name the macros, including the chip macro (CHIP00). Power and ground macros have a naming convention as do static drivers. Try to follow AMCC naming conventions. As an aid to debug and to avoid duplicate names which can be catastrophic, put the page number into the macro names. MX0000 on page four would become MX4000. Proceed to the second drawing page by typing: ### DED1: {NEXT}{EXECUTE}Y{EXECUTE} Bring up a border on the new page, name and note it and begin to capture the schematic. To save time, when a border is brought up and commented for page one, copy it (use the SAVE command) to all following pages (SAVE 2; SAVE 3, SAVE 4, etc.). (809) All interface and logic Macros are components and are called by: DED1: CO /macro name{EXTRACT}{PLACE}...{EXECUTE} The 2{ZOOM} feature allows the entire drawing page to be seen and is a great assist in initial page layout. It will not detail the macros and you cannot wire while in 2{ZOOM}. (You can, but it won't be right.) Return to 1{ZOOM} or one step beyond (1{ZOOM}{ZOOM}) to do the wiring. Use the {VIDEO GRID} key to obtain a dotted background but turn it off (it is a toggle) when doing printout. Changing pages will reset ZOOM to the original 1{ZOOM} setting. Use the {REDRAW} key to reconnect the displayed lines after names, notes and moves. What is on the screen is what is plotted. You can plot 1{ZOOM} and even higher - higher will provide interesting artwork but it will not be valid as a circuit schematic. Following macro placement, the page and chip connectors and terminators are added. After these, the wires are added, and then the wires and macros are named and notes are added. The DAISY connector names are decoded as: R right L left W wire B bundle or bus H hierarchical P page I input O output CON connector PI page in IP intrapage There are page-to-page connectors (/RWPICON, /RWPOCON), bundled wire connectors (/RBHICON, /RBHOCON, /RBPICON, /RBPOCON), and bidirectional connectors (/RWPBCON, /RWHBCON, /RBHBCON, /RBHBCON). There are others. The DAISY library also provides the terminators /LWTERM, /RWTERM, /UWTERM and /DWTERM. Other terminators, for bundles, bidirectionals, etc., also exist. Avoid using /UWTERM and /DWTERM since they resemble the ground symbol and this is visually confusing. Terminators are added by first fetching them from the library, and then wiring the terminator to the desired wire stub. Treat terminators as components, except for the fact they need not be named. Wires are used to tie unused macro inputs to global ground. A wire is added to the input pin and drawn out and down. It is named GND and the symbol appears in place of the name. (Same as for the chip macro.) ### DED1: NA {SELECT}GND{DEF}{PLACE}{EXECUTE} Bundles are useful to route bundles of wires. The BU command is used in place of W in the routing of the bundle. Instead of a name, give a bundle a contents parameter (/CONTS) that contains the identification of what is in the bundle. There is a 64 character limit on the value of the /CONTS parameter. The /CONTS parameter is assigned by the full PARAMETER command: ### PARA {SELECT}/CONTS{EXTRACT}xxxx{DEF}{PLACE}...{EXECUTE} Wires coming from a bundle are individually named. DATO, DATI, ABUS12 are wires to the bundle with the /CONTS parameter DAT(0:15),ABUS(0:12). All macros should be named in a flat design or in a hierarchy non-nested design, and all off-chip and off-page connections must be named. Internal wires may be named if you will be interested in them during debug of the design. Internal wires that MUST be named are the enable signals into 3-state output macros or bidirectional macros. Internal wires (nets) in critical paths <u>must be named</u> or the default name must be made visible (via NA {SELECT}{PLACE}..{EXECUTE}) on the schematic. This is for use in Front- and Back-Annotation analysis. If you are going to take the trouble to make it visible - change its name! It takes little additional effort and speeds the design analysis process. Naming an internal signal allows it to be easily placed in the FMT file for wave and list display later on. Any signal that might help a debug problem should be named. Hint: since the Front-Annotation file sorts the net names, begin all nets in a critical path with the same first three letters. The nets will sort near each other, making analysis easier. A full Q5000 design could easily have 900 nets. The macro naming rules are by AMCC convention (see the EWS Schematic Rules and Conventions) including Lxxx for a latch, Bxxx for a buffer, Mxxx for a MUX, Dxxx for a driver, and so on. Macro instance names should be 1 to 6 characters long. Wire names should be 1 to 8 characters long, and should follow AMCC rules (alphameric only); no special characters. All names should be meaningful, which implies at least 3 characters. Names can begin with a number or a letter. As mentioned before, AMCC recommends that one character of the name be reserved for page identification to avoid interpage name duplication. The rules are also designed to help avoid using a pin-name or other confusing names. They are designed to allow ease of transfer between various support programs. All names must be unique on a page and for the design. For example, if AOUT appears on page 1.DRAW, it can only appear on page 1.DRAW one time as a chip/page input or chip/page output. A name can be extracted to appear somewhere else along the same wire or wirenet. A name can appear on several intrapage connectors (same-page connector - used to break a long wire for visual clarity). Each time the same wire name appears it is attached to the wire-net with that name. The positioning of the wire names for on- and off-chip connectors: The names are attached to the wires but placed to the left of the input (/RWHICON) connectors and to the right of the output (/RWHOCON) connectors, or placed just above the wires. All DAISY components may be rotated. AMCC prefers that rotation not be used since AMCC may run a graphic UPDATE of all submitted schematics against the in-house working library to verify the data. UPDATE does not rotate but puts the macros on the page in unrotated form, breaking connections and destroying the page. Structured design flow is left to right across the page and this flow should be maintained. At any time during the creation of the drawing page, the page may be saved by typing: DED1: SAVE {EXECUTE} DED1: SAVE n {EXECUTE} [ where n is a digit ] <u>Perform SAVE once every 15-20 minutes</u> or when a complex structure has been entered or edited. The use of "SAVE" with a file reference (usually a number for an n.DRAW page) allows pages to be copied while in the editor. At any time during the creation of the drawing page the page may be plotted by typing: PL {EXECUTE}. <--- direct connect PL /NET/D\_n{MACRO}{EXECUTE} <---- thru another The second version is for plotting through another ETHERNET node at AMCC. If there are no more pages or the page is complete or the user is interrupted, then DED is exited by: DED1: EXIT {EXECUTE} save DEDI: QUIT {EXECUTE} do not save The use of "QUIT" instead of "EXIT" will cause the current workspace page to be lost and the contents of the hard disk file will remain unchanged. If a file has been SAVEd then a QUIT is reasonable; or if an edit session has been abortive, then QUIT is preferred. QUIT will prompt the user to verify that drawing page edits are to be discarded. Use of the menu and the mouse. Type the blue button to find the menus and select "WINDOW MANAGER". Use the blue button to select "Plot Screen". Do not use "Plot Window". By toggling the yellow button twice, the entire screen is plotted. The yellow button can also be used to block out that part of the screen that is desired and a partial plot made. Other selections available are "Shell Window". A shell window can be opened by {SHIFT}{ZOOM}. After use, it is deleted by {CTL}{E}. The cursor must be in the window for the command line to function. Flip a window backward and forward in the window stack by selecting the yellow button on the banner for the window. The use of multiple windows will slow down the system due to overhead. Limit the windows to two and use no sub windows when running simulation. To speed simulation, some users turn off NCP (sign off the net). The next pages show the circuit created, a 16:1 MUX with two thermal diodes and with a gate-tree to allow parametric testing. The parametric tree inputs were taken from the unused pins on the input macros (all were YN), allowing the testing logic to be added without adding time delay to the actual function. This may not always be possible. The parametric logic will need to be tested with functional vectors - the sample shown herein is 100% fault-coverage of the function but not necessarily of the test logic. Any expansion of the vector set needed to fault-cover the gate tree is left as a student exercise. FIGURE 1 FIGURE 2 FIGURE 2 CONTINUED FIGURE 3 EXTERNALLY CONNECT TO <= 30 MICROAMP SOURCE FIGURE 4 FIGURE 5 ``` 1 plot strip(s) will be produced. Please relax... DED> NEXT >> (EXECUTE) !! You are leaving a modified page. Do you wish to save it? Y i plot strip(s) will be produced. Please relax... DED> NEXT >> (EXECUTE) !! You are leaving a modified page. Do you wish to save it? Y (DEFINE) >> (PLACE) >> (EXECUTE) >> (PLACE) >> (EXECUTE) > (EXECUTE) >>800 (DEFINE) >> (PLACE) >> (EXECUTE) > (EXECUTE) > (PLACE) ED > COMPONENT >> AMCCPAGEB (EXTRACT) >> (EXECUTE) >>THERMAL DIODES FOR THE ( >>SAMPLE CIRCUIT (DEFINE) >>(FOR REFERENCE) (DEFINE) (PLACE) < (SELECT) >> (PLACE) >> (EXECUTE) The screen will be rasterized and plotted. The screen will be rasterized and plotted. >>824 (BFINE) DED > NOTE %5 %R( .SX+1, .SY)2%D %P %X %L SAVED ASER/CLASS/MUX16/3, DRAW SAVED /USER/CLASS/MUX16/4.DRAW DED> NOTE >> (EXTRACT) DED> PLOT >> (EXECUTE) EXTRACT (EXTRACT) (EXTRACT) (EXECUTE) DED REDRAM :: REDROY. DED PLOT >> $ HQ $ ₩ SED OUIT > ``` # FIGURE 6 Begin compress of components on drawing page Library - End compress (EXECUTE) !! Begin squeeze of drawing page - End squeeze # AFTER DED - LOG OF ACTIONS ON THE SCREEN To copy drawing pages when <u>outside</u> of one of the DED editors, copy one page to another by: COPY filename TO filename When inside any DED editor simply save the page: SAVE n {RETURN} Initialize a floppy by: INITDISK -DEMO ..... ONLY IF NOT INITIALIZED (or you are wiping the file) Use an initialized or previously used floppy by: MOUNT /F ..... ALWAYS MOUNT THE FLOPPY Note: Never delete the /F directory. If you do not mount a floppy before executing a copy command where /F is the destination, the file(s) are put on the main hard disk in the /F directory. Do not erase /F if you do not know what is in the directory (if the files are not your own). Erase the /TEMP directory contents periodically. These are created during print or plot. These files are DAISY software temp files. A large /TEMP directory can cause system failures. COPY 1.DRAW TO /F ...... WHATEVER OR COPY 1.DRAW TO /F -B COPY /F/\* to . -B -DE .... reloading from floppy COPY \* TO /F .... overkill; gets BAK, etc. COPY \* TO /F -B -DE DIS .....WHEN DONE, DISMOUNT Note: Backup copies of drawings should be kept on a floppy disk or tape. Make a back-up everyday. Keeping copies on the disk in another directory will slow down the system and waste memory. If there is a hard disk failure, you would loose both directories anyway. If you are working at the AMCC design center, ask about storage on the EAGLE hard disk. Do not leave a floppy on-line during execution. Mount it, use it and dismount. Floppy drives are shared drives at AMCC. The circuit shown in Figure 1 is flat (all pages in one directory area, no design tree), is not nested, has no parameterized components other than the chip macro, and does not use bundles, blocks or cells, although these features are available on the DAISY. It is a simple design suitable for instructional use. Hierarchical design rules are covered in Application Note 2. Nested design rules are covered in Application Note 3. When setting up the floppy, use a master index to keep track of what has been saved. One trick that AMCC likes you to use is the creation of a master index for your design files by typing: ### INV /F -S -L -DE > /F/INDEX.INV The file INDEX.INV contains a complete inventory of what has been stored on the floppy. The first execution creates an empty INDEX.INV file. You can also do this within a directory as a means of indexing that directory. The next step is to DANCE the design (DAISY Network Connectivity Extractor). All pages in a design may be DANCEd at once or they may be processed individually. Call DANCE by: DANCE one page DANCE -M3 -T all pages, tree, individual short reports DANCE -M3 -T -N all pages, nested mode, concatenated reports M3 is a message level, and is usually sufficiently detailed. You can change from M3 to M5 for more detail, or to M1 for less. DANCE will flag errors to the screen and to files x.DFR. The files n.DFR will be produced for this circuit for the first three versions of the command; file ERR.DFR will be produced by the concatenated request. By omitting R, the report will only contain error messages. This is preferred to keep memory usage down. TYPE 1.DFR use {OUTPUT CONTROL} to read TYPE 1.DFR > /DEV/LP to line printer (plotter) TYPE 1.DFR > /NET/D\_a/DEV/LP plot through AMCC remote node to plotter TYPE ERR.DFR concatenated report TYPE ERR.DFR > /DEV/LP -HEA type with header Use this last option (-HEA) with TYPE to keep a header on all outputs. It saves time during submission assembly. Whenever there is a question about a DAISY command, use HELP and select the command you need help with. Figure 2 shows the screen during the HELP command with the system uppercase command TYPE selected for explanation. CLASS> RUN\_DD DANCE : DANCE \*\*\*\*\* RUNNING DANCE -T -N -ERR -M3 \*\*\*\*\*\* \*\*\*\*\*\*\*\*\*\*\*\* DANCE OK !!!!! \*\*\*\*\*\*\*\*\* \*\*\*\*\*\*\*\* RUNNING DRINK -T -M3 \*\*\*\*\*\*\*\* \*\*\*\*\*\*\*\*\*\*\*\* DRINK OK !!!!! \*\*\*\*\*\*\*\*\* /USER/CLASS/MUX16 Date: 25 MAY 86 Ø8:44 File: DANCE . ERR LOGICIAN DANCE VERSION V5.02.02 BEGIN BLOCK BEGIN PAGE ``` DANCE EXTRACTING PRIMITIVES COMPILING PRIMITIVES COMPILING CONNECTIVITY DANCE DANCE DANCE GENERATING LISTINGS DANCE : END PAGE. 2 ERRORS FLAGGED. HIGHEST SEVERITY WAS Ø. BEGIN PAGE 2.DRAW DANCE EXTRACTING PRIMITIVES DANCE COMPILING PRIMITIVES COMPILING CONNECTIVITY DANCE DANCE DANCE : GENERATING LISTINGS DANCE END PAGE. 2 ERRORS FLAGGED. HIGHEST SEVERITY WAS Ø. DANCE BEGIN PAGE 3.DRAW EXTRACTING PRIMITIVES DANCE : COMPILING PRIMITIVES COMPILING CONNECTIVITY DANCE DANCE : GENERATING LISTINGS DANCE DANCE END PAGE. 2 ERRORS FLAGGED. HIGHEST SEVERITY WAS Ø. BEGIN PAGE 4.DRAW DANCE DANCE EXTRACTING PRIMITIVES COMPILING PRIMITIVES DANCE ``` COMPILING DANCE CONNECTIVITY GENERATING LISTINGS DANCE DANCE END PAGE. 2 ERRORS FLAGGED. HIGHEST SEVERITY WAS Ø. DANCE : END BLOCK DANCE COMPLETE: 4 PAGES FLAGGED. HIGHEST SEVERITY WAS Ø Date: 25 MAY 86 Ø8:44 File: DRINK.ERR LOGICIAN DRINK VERSION V5.02.02 ``` DRINK: BEGIN COMPLETE LINK TRAVERSING TREE BEGIN BLOCK /USER/CLASS/MUX16 COLLECTING RECORDS DRINK: DRINK: DRINK: DRINK: PROCESSING BLOCK DATA DRINK: END BLOCK Ø ERRORS FLAGGED, HIGHEST SEVERITY WAS Ø. PROCESSING TREE DATA LINKING ENTRIES DRINK: DRINK: DRINK: BLOCK TAB LOADED PAGE TAB LOADED DRINK: RESERVING MAP DRINK: DR INK SORTING RECORDS DR INK: MERGING RECORDS ``` DRINK COMPLETE: Ø BLOCKS FLAGGED. HIGHEST SEVERITY WAS Ø ### FIGURE 7: RUN\_DD, DANCE,ERR, DRINK,ERR DANCE can be executed for one drawing page as the next is being edited. Move off the page to be danced, open a shell window and execute the DANCE command for the completed page. This is a preferred way of working since commonly made errors that DANCE could catch are detected early before they become ingrained bad habits. Anytime an individual page is edited, it can be re-DANCED by itself. If DANCE does not produce any errors, the next step is to run DRINK (DAISY Resolving Linker). DANCE acts as a compiler, while DRINK acts as the corresponding linker. DRINK is run against the entire circuit. (There are sophisticated alternatives for update mode that will not be covered here.) Call it by: > DRINK short error-only report DRINK -T -M3 -E3 messages to the screen If there are errors in file TREE.DFR then you must return to DED to the page or pages flagged and make the corrections. The page(s) must repass through DED, DANCE and DRINK until there are no errors. Note: DRINK can be executed on a partial circuit; DAISY will simulate a partial circuit, MacroMatrix will execute on a partial circuit. A design cannot be SUBMITTED until all errors are removed. DANCE and DRINK both can be executed by typing the shell execution command: RUN DD (recommended) (part of Super-Shell) RUN\_DD will produce DANCE.ERR (a concatenated report of all pages) and DRINK. ERR (same as TREE. DFR). Scan DANCE.ERR before proceeding with the ERCs and other software. There should be two errors per page (the border has no pins and is not connected to anything - a pinless macro). If more than two errors, go fix the page. (Note: The Super Shell will continue to execute with level 0 errors - it currently only halts on level 1 errors.) If this process has been done before and you think all errors are removed, or you want to fire off processes while you do something else, call the AMCC super-shell and run DANCE, DRINK, AGIF, and ERC. RUN\_AMCC (The Super-Shell) If there are no errors from DRINK, and you have not run the Super-Shell, run the netlist transfer file generation software by first executing: RUN\_AGIF (part of Super-Shell) This routine changes the DAISY-produced netlist into the AMCC generic interface format file (AGIF) (using SING) that will be transmitted to the VAX for layout and other software access. It will also create files in a new sub-directory /ERC. The principal file that is created is CIRCUIT.SDI, the AMCC-formatted netlist. This file is a design-submission file. It is an input file for: ERCs, Front-, Intermediate- and Back-Annotation, AMCCSIMFMT, AMCCVRC, place and route, LASAR6 simulation and fault-grading and the tester programs. Do not type this file out - it is very large and is encoded. The AMCC ERC (Engineering Rules Check) software must be run before proceeding with DAISY simulation. The DAISY system doesn't care about this (it is a parallel process) but you should. Why waste time performing and evaluating simulations when there are fundamental interconnection or population errors in the design? Running the ERCs first saves design time. The ERC software is system-resident and is executed by moving down to the ERC subdirectory created by RUN\_AGIF and typing: AMCCERC (need to change directory) The AMCC shell script RUN\_ERC can be run without moving down to the ERC subdirectory. RUN\_ERC calls AMCCERC. RUN\_ERC (part of Super-Shell) (preferred execution) The AMCC ERC program is a set of routines that will flag various errors such as fan-out exceeded, unconnected pins, improper wire-ORs, invalid names, grounded outputs, duplicate names, and other similar errors. Type out the reports to the screen by: TYPE ERC/AMCCERC.LST TYPE ERC/AMCCIO.LST TYPE ERC/AMCCXREF.LST If there are ERC-flagged errors, you must return to DED to fix the pages flagged. This is one reason why individual steps might be more efficient than the Super-Shell for the first pass through the drawing. Before the next step can be run, the changed pages must be re-DANCED, the circuit re-DRINKed, SING-TO AGIF rerun and ERC re-executed with no errors. Any time an error is found, the process must be restarted. The ERC software should pick up most of the more commonly encountered oversights and slips made in a design schematic capture. The ERCs assume that catastrophic DANCE and DRINK errors are removed. If there is an incorrect pin-wire interconnect (contact not really made) it can survive the ERCs but fail in simulation. Unless you are running a partial circuit, always remove DANCE and DRINK errors BEFORE running ERCs. If you are running a partial circuit, remove those errors pertinent to the pages that are captured. After the ERC software is executed without error, execute the Front-Annotation software while in the /ERC subdirectory by typing: AMCCANN (need to change directory) Again, the AMCC shell script RUN\_ANN can be run without moving to the ERC subdirectory. RUN\_ANN Or by using the Super-Shell RUN\_AMCC (part of Super-Shell) (preferred execution) In the delay files produced, each net is identified by name (user-defined or default) and is followed by six numbers representing the min, typ and max net delay for both rising and falling edges. Only one file is referenced in the simulation at one time. These Front-Annotation delay files provide the internal net interconnect delays due to fan-out, wire-ORs and metal loading. The metal load delay is estimated. The output net delays due to system and package pin capacitance loading is also computed. The program will prompt for a response which can be as simple as defaulting all values or as intricate as specifying different system and package capacitance loading for each of the primary output signals in the circuit. The package type selected determines the default values for the package pin capacitance. The default system load is 15pF for TTL and 5pF for ECL. The output macros for the AMCC arrays in the Q14000, Q5000, Q20000 and future arrays are specified under no load. CURRENTS CONTEXT: SOURCE FOR SUPPLY OF SUPPLY OF SUPPLY CONTEXT: SOURCE OF SUPPLY CONTEXT: APPLIED MICRO CIRCUITS CORPORATION 11111111111111111111111 > Run DANCE, DRINK, AGIF and ERCs 1: Part One: 2: Part Two: Run AMCCANN 3: Part Three: Run SIFT and SOM\_MAKER 4: Part Four: Run SOM and TCAL 5: Part Five: Run AMCCSIMEMT 6: Part Six: Run AMCCURC 0: Exit Program: Please Enter [0 - 6] : >2 Need to Edit Package Pin Data? (Y or N); >Y AMCC Delay Annotation UERSION 3.30 Loading Netlist ... Welcome to the output loading system. (0) Generate a report and exit. (1) Change the package type. 🖊 (2) Edit the default package pin capacitance.(3) Edit the default system capacitive load for TTL outputs. (4) Edit the default system capacitive load for ECL outputs. (5) Edit the system capacitive load for a specific pin or pins. (6) Edit the package pin capacitance for a specific pin or pins. (7) Edit the ECL Resistive Load for a specific pin or pins. (8) Edit the Frequency for a specific pin or pins. Enter the number of the item you wish to perform: 1 ### **Running AMCCANN** FIGURE 8 ``` (2) Edit the default package pin capacitance. (3) Edit the default system capacitive load for TTL outputs. (4) Edit the default system capacitive load for ECL outputs. (5) Edit the system capacitive load for a specific pin or pins. (6) Edit the package pin capacitance for a specific pin or pins. (7) Edit the ECL Resistive Load for a specific pin or pins. (8) Edit the Frequency for a specific pin or pins. Enter the number of the item you wish to perform: 1 0) OTHER Choose parkage. 1) 224 PGA cavity down 2) 132 leaded chip carrier cavity up. 3) 196 leaded chip carrier cavity down. .4) 149 PGA cavity down. 5) 149 PGA cavity up. Tupe the number of the package that this design will be using. 224-PGA-CD (0) Generate a report and exit. (1) Change the package type. 1 (2) Edit the default package pin capacitance. (3) Edit the default system capacitive load for TTL outputs. (4) Edit the default system capacitive load for ECL outputs. (5) Edit the system capacitive load for a specific pin or pins. (6) Edit the package pin capacitance for a specific pin or pins. (7) Edit the ECL Resistive Load for a specific pin or pins. (8) Edit the Frequency for a specific pin or pins. Enter the number of the item you wish to perform: 2 The current default value for package pin capacitance is 4.9 pf: Enter (Retn) for no change or enter a new value: (0) Generate a report and exit. < KET > (1) Change the package type. (2) Edit the default package pin capacitance. (3) Edit the default system capacitive load for TTL outputs. (4) Edit the default system capacitive load for ECL outputs. (5) Edit the system capacitive load for a specific pin or pins. (6) Edit the package pin capacitance for a specific pin or pins. (7) Edit the ECL Resistive Load for a specific pin or pins. (8) Edit the Frequency for a specific pin or pins. Enter the number of the item you wish to perform: 3 The current default value for TTL system capacitance is 1.5e+01 pf. Enter (Retn) for no change or enter a new value: 20 (0) Generate a report and exit. するようなまでいる。 Change the package type. (2) Edit the default package pin capacitance. (3) Edit the default system capacitive load for TTL outputs. (4) Edit the default system capacitive load for ECL outputs. (5) Edit the system capacitive load for a specific pin or pins. (6) Edit the package pin capacitance for a specific pin or pins. (7) Edit the ECL Resistive Load for a specific pin or pins. (8) Edit the Frequency for a specific pin or pins. Enter the number of the item you wish to perform: 1 ``` ### FIGURE 8 CONTINUED ``` (5) Edit the system capacitive load for a specific pin or pins. (6) Edit the package pin capacitance for a specific pin or pins. (7) Edit the ECL Resistive Load for a specific pin or pins. (8) Edit the Frequency for a specific pin or pins. Enter the number of the item you wish to perform: 4 The current default value for ECL system capacitace is 5.0 pf. Enter (Retn) for no change or enter a new value: 64. Ect load ! (0) Generate a report and exit. (1) Change the package type. (2) Edit the default package pin capacitance. (3) Edit the default system capacitive load for TTL outputs. (4) Edit the default system capacitive load for ECL outputs. (5) Edit the system capacitive load for a specific pin or pins. (6) Edit the package pin capacitance for a specific pin or pins. (7) Edit the ECL Resistive Load for a specific pin or pins. (8) Edit the Frequency for a specific pin or pins. Enter the number of the item you wish to perform: 5 OUTRAL OUTRA PARAM YOUTPT OUTE OUTC Enter the signal name or signal names separated by spaces. Enter the new value (pf): 12 4 Enter the signal name or signal names separated by spaces. (0) Generate a report and exit. Change the package type. (2) Edit the default package pin capacitance.(3) Edit the default system capacitive load for TTL outputs. (4) Edit the default system capacitive load for ECL outputs. (5) Edit the system capacitive load for a specific pin or pins. (6) Edit the package pin capacitance for a specific pin or pins. (7) Edit the ECL Resistive Load for a specific pin or pins. (8) Edit the Frequency for a specific pin or pins. Enter the number of the item you wish to perform: 6 OUTO OUTE PARAM YOUTPT Enter the signal name or signal names separated by spaces. Enter the new value (pf): 8 4 Enter the signal name or signal names separated by spaces. (0) Generate a report and exit. Change the package type. (2) Edit the default package pin capacitance. (3) Edit the default system capacitive load for TTL outputs. (4) Edit the default system capacitive load for ECL outputs. (5) Edit the system capacitive load for a specific pin or pins. (6) Edit the package pin capacitance for a specific pin or pins. (7) Edit the ECL Resistive Load for a specific pin or pins. (8) Edit the Frequency for a specific pin or pins. Enter the number of the item you wish to perform: ``` ### FIGURE 8 CONTINUED ``` A SECULAR CURRENT CONTEXTS: AUSER/CLASS/MUXT (6) Edit the package pin capacitance for a specific pin or pins. (7) Edit the ECL Resistive Load for a specific pin or pins. (7) Edit the ECL Resistive Load for a specific pin or pins. (8) Edit the Frequency for a specific pin or pins. Enter the number of the item you wish to perform: 7 PATIO DATII DATII DAT13 DAT14 DAT15 DAT2 DAT3 DAT4 DAT5 DAT6 DAT7 DATA DAT9 EXTCLK EXTRST IN001 OUT@01 OUTC OUTE PARAM SELCTA SELCT1 SELCT2 SELCT3 YOUTPT Enter the signal name or signal names separated by spaces. OUTC A Enter the new value (Ohms): 50 42 Enter the signal name or signal names separated by spaces. (0) Generate a report and exit. (1) Change the package type. (2) Edit the default package pin capacitance.(3) Edit the default system capacitive load for TTL outputs. (4) Edit the default system capacitive load for ECL outputs.(5) Edit the system capacitive load for a specific pin or pins. (6) Edit the package pin capacitance for a specific pin or pins. (7) Edit the ECL Resistive Load for a specific pin or pins. (8) Edit the Frequency for a specific pin or pins. Enter the number of the item you wish to perform: B DATØ DAT1 DAT10 DAT11 DAT12 () DAT13 DAT14 DAT15 DAT2 DAT3 DAT4 DAT5 DAT6 DAT7 DATE DATS EXTCLK EXTRST INØ01 100TUO OUTC OUTE PARAM SELCTØ SELCT1. SELCT2 SELCT3 YOUTPT Enter the signal name or signal names separated by spaces. Enter the new value (MHz): 100 ** Enter the signal name or signal names separated by spaces. (0) Generate a report and exit. (1) Change the package type. (2) Edit the default package pin capacitance. (3) Edit the default system capacitive load for TTL outputs. (4) Edit the default system capacitive load for ECL outputs. (5) Edit the system capacitive load for a specific pin or pins. (6) Edit the package pin capacitance for a specific pin or pins. (7) Edit the ECL Resistive Load for a specific pin or pins. (8) Edit the Frequency for a specific pin or pins. Enter the number of the item you wish to perform: ZRET? Exiting and writing AMCCPKG.LST. Processing MIN Front Annotation Delay File ... Processing NOM Front Annotation Delay File ... ``` ### FIGURE 8 CONTINUED ## AMCCPKG.LST Using the interface, the frequency for any primary input or output may be specified (commentary documentation) and the ECL resistive loading for any ECL output may be specified (also commentary). Resistive loads should be specified when they do match that assumed for the macro (25 or 50 ohms). Frequency should be entered for any TTL I/O toggling faster than 50 MHz and any ECL I/O toggling faster than 100 MHz. AMCCANN (AMCC Annotation) can be run as many times as required to fine-tune the simulation. The file OUTPUT.DLY is the data file created in the first session and then edited by successive executions. A previously entered specific pin capacitance or load capacitance for a signal is deleted (reverting to the default value) by giving its name and typing an \* for the new value. When AMCCANN is completed, it will have generated the Front-Annotation files FNTMIL.DSY or FNTCOM.DSY, FNTNOM.DSY and FNTMIN.DSY as well as the report file AMCCPKG.LST and the data file OUTPUT.DLY. All of these files are to be submitted. Note: The BicMos library has two commercial timing libraries, one for COMMERCIAL circuits running with a -4.5V power supply (COM4) and one for all other COMMERCIAL circuits (COM5). The Front-Annotation file is still named FNTCOM.DSY and provides correct timing based on the ARRAY\_FAMILY, PRODUCT\_GRADE and the POWER\_SUPPLY parameters. After the ERC software and the Front-Annotation software has successfully run, the next step is to run a simulation to verify that the basic logic is correct. When the proper loginfile, such as the one shown earlier, is used, the PROFILE file is correctly set for the library. THE LIBRARY MUST BE INSTALLED AS AMCC INTENDS FOR PROPER OPERATION. Run SIFT (Simulator Intermediate Files Translator) to append the appropriate timing data to the macros. These are the intrinsic delays for the paths through the macros themselves. SIFT can be run for MINIMUM, NOMINAL, COMMERCIAL or MILITARY timing. The worst-case multipliers are those that support the Front- and Back-Annotation software (1.35 \* typical = COM and 1.45 \* typical = MIL for the Q5000). Run SIFT using the AMCC supplied shell: RUN\_SIFT xxx where xxx = NOM, MIL or COM, COM4 or COM5 Note: for large designs, SIFT may run overnight. Within the SIFT library, there are three multipliers: ### BIPOLAR | RANGE<br>IN TYP | MAX | ۱ | FRONT-<br>ANNOTATION | |-----------------|---------|----------------------------------------------|------------------------------------------------------| | .19 1.32 | 1.35 | | FNTNOM.DSY<br>FNTCOM.DSY<br>FNTMIL.DSY<br>FNTMIN.DSY | | • | 19 1.32 | 11 1.23 1.35<br>19 1.32 1.45<br>70 0.78 0.86 | 19 1.32 1.45 <br>70 0.78 0.86 | ### BICMOS\* COM4 uses multipliers for -4.5V supply - use with FNTCOM.DSY COM5 uses multipliers for -5.2V or +5V supply - use with FNTCOM.DSY The use of MIN, TYP or MAX within a timing library is specified in the MODE format under the DAISY Logical Simulator (DLS) or the DAISY Timing Verifier (DTV). SIFT is also run under the Super-Shell by typing: RUN\_AMCC (Super-Shell) AMCC recommends that the Super-Shell be used after the initial debug pass has been made since the menu will prompt you for necessary parameters and options for the commands. Normally, a simulation will be run using MINIMUM data and then rerun using COMMERCIAL or MILITARY data. If the results are not functionally identical, a timing dependency (problem) is indicated which requires further evaluation or a re-design. AMCC requires both of these simulations (MINIMUM, and MAXIMUM MIL OR COM) be performed and submitted if they are different. Otherwise, submit just the maximum worst-case simulation results. <sup>\*</sup> see the tables in Volume I of the Design Manual These numbers are based on a 20% maximum worst-case processing variation across the chip, with 10% the more usual variation. These multipliers are the same multipliers used in the FNTxxx.DSY files. All submitted simulations should be run under timing checks "ON" and all timing errors removed. In special cases, an AMCC waiver may be required. Following SIFT, the SING TO DAISY process is initiated. SING is the Simulator Input Generator used to extract information from the netlist. AMCC usually combines this into the following routines: 1) generate a default time=0 simulation control file, SOM\_MCF.SING; 2) generate a default FMT file for DLS/DTV use; and open the SOM\_MCF.SING file for editing under TEC. SING -T -M3 -MCF /AMCC/SOM\_MAKER/SOM\_MCF FMT\_CSD.SING TEC SOM\_MCF.SING (all part of Super-Shell) At the end of the last command (and the end of menu selection 3 for the Super-Shell), the text-editor TEC is open to the simulation control file, SOM\_MCF.SING. The time-zero SOM\_MCF.SING file comes up with all input (all primary input signals) shown forced to zero at time zero (= 0:F0;). The user must edit this file to include the simulation stimuli by using the DAISY text editor, TEC. Stimuli can be described using the signal generator approach or by using a remote data file. The example at the end of the text shows a SOM\_MCF.SING file after it has been edited. This one uses the \$SIGNAL\_GENERATORS section to input values. TIMING\_CHECK := 1; is present so this file can be used to run timing checks under both DLS and DTV. AMCC prefers that all files be commented for identification (company, circuit, designer, date, rev level, what is being tested, etc.). After all edits to the SOM\_MCF.SING file have been made, TEC is exited by: ### {ENTER}EXIT(EXECUTE) (exit TEC) The SOM CTL file must include an \$OUTPUTS section. The output file referenced in the \$OUTPUTS section is created by the system and not by the user. The user must describe which signals go in the file in what order. AMCC requires that all primary inputs, all primary outputs, all primary bidirectionals and all internal 3-state enable or bidirectional enable signals be listed in that file in that order. The files produced during simulation include the LIST file, the WAVE, the VLAF output file. The VLAF output file is the file that becomes the input file to ``` Date: 25 MAY 86 11:17 File: FMT_CSD.SING SOM SOM_MCF.SING -M3 DLS <<! FORMAT DATØ@MUX16/3:DATØ 3DATIGMUX16/3:DATI 3DATI@@MUX16/3:DATI@ 3DAT11@MUX16/3:DAT11 3DAT12@MUX16/3:DAT12 3DAT13@MUX16/3:DAT13 3DAT14@MUX16/3:DAT14 3DAT15@MUX16/3:DAT15 3DAT2@MUX16/3:DAT2 3DAT3@MUX16/3:DAT3 3DAT4@MUX16/3:DAT4 3DAT50MUX16/3:DAT5 3DAT60MUX16/3:DAT6 3DAT70MUX16/3:DAT7 3DATS@MUX16/3:DAT8 3DAT90MUX16/3:DAT9 3EXTCLK@MUX16/2:EXTCLK 3EXTRST@MUX16/2:EXTRST 3 I NØØ 1 @MUX 16/4 : I NØØ 1 3SELCTØ@MUX16/3:SELCTØ 3SELCT1@NUX16/3:SELCT1 3SELCT2@MUX16/3:SELCT2 3SELCT3@MUX16/3:SELCT3 3OUTAGIONUX16/4:OUTGG1 3OUTC@HUX16/4:OUTC 3OUTEQMUX16/4:OUTE 3YOUTPT@MUX16/2:YOUTPT 3$ PUT FMT QUIT N ``` ### FIGURE 10: FMT\_CSD.SING used to build FMT FMT is used by DLS AMCCSIMFMT. AMCC does not need to see the FMT file, LIST files, WAVE plots or the VLAF file. The first three (FMT controls LIST and WAVE contents) are useful for debugging. For example, the user can reference internal signals in the LIST file while the final \$OUTPUTS section is not allowed to show them. The Super-Shell step 3 will end with the text editor open. When TEC is exited, the shell menu will return. If you need to create a remote data file, exit the Super-Shell and open the data file under TEC. If this is the case, exit the Super-Shell by: (exit Super-Shell) If the input stimulus is to be provided by a remote data file, the TEC must be reopened to create whatever input file name was referenced in the simulation control file. To open, use TEC input-filename. TEC DEMO.DAT (example) TEC filename.extension user-defined filename The data files are created from scratch by the designer; there is no fill-in-the-blank formatted file to edit as there is for the SOM\_MCF.SING file. The data file must be created following a specified time-value, with comments and blank lines allowed. If comments and blank line appear after the \$END\$ statement, then run AMCCFILUTL to prepare the file for execution. The source file is commented, the executable file is not. Maintanence is performed using the source file. ALWAYS RENAME AN EDITED SOM\_MCF.SING FILE. The SOM \_MCF.SING file is destroyed in favor of a default version any time SING is rerun or anytime Super-Shell step 3 is executed. AMCC prefers to have meaningful names used on the control files such as FUNCTION. SING, ATSPEED. SING, ACR4PROP. SING. Do not forget to include these in the submission index. Once the data file and the SOM\_MCF.SING file are completed, then run SOM, the Simulator Object Module Generator. This can be executed with the Front-Annotation file, and should be. The AMCC supplied shell is an easy way to do this. SOM the control file only - for debug: SOM SOM\_MCF.SING -M3 -L SOM.ERR | /****<br>* | |-----------------------------------------------------------------| | * DESIGN PATH /USER/CLASS/MUX16 DATE 16-SEP-1988 14:50 | | * * COMPANY CIRCUIT_NAME | | * ARRAY PO# REV | | * | | * | | * What tests does this control file support: | | * | | * | | ****/ | | /*** Configuration section ****/ | | /*** Configuration section ****/ | | \$CONFIGURATION | | GATE_ACTIVITY_LEVEL := 180;<br>IMMEDIATE_ACTIVITY_LEVEL := 100; | | TIMING_CHECK := 1; | | /*** Signal generator section ****/ | | \$SIGNAL_GENERATORS | | QMUX16/3:DATØ := QØ:FØ ; | | @MUX16/3:DAT1 := @Ø:FØ ;<br>@MUX16/3:DAT1Ø := @Ø:FØ ; | | @MUX16/3:DAT11 := @Ø:FØ ; | | @MUX16/3:DAT12 := @Ø:FØ ; | | @MUX16/3:DAT13 := @Ø:FØ ;<br>@MUX16/3:DAT14 := @Ø:FØ ; | | @MUX16/3:DAT15 := @#:F# : | | @MUX16/3:DAT2 := @Ø:FØ ; | | @MUX16/3:DAT3 := @Ø:FØ ; | | @MUX16/3:DAT4 := @Ø:FØ ;<br>@MUX16/3:DAT5 := @Ø:FØ ; | | @MUX16/3:DAT6 := @#:F# ; | | @MUX16/3:DAT7 := @Ø:FØ ; | | QMUX16/3:DATB := @Ø:FØ ; | | @MUX16/3:DAT9 := @Ø:FØ ; | | @MUX16/2:EXTCLK := @Ø:FØ ;<br>@MUX16/2:EXTRST := @Ø:FØ : | | @MUX16/4:INØØ1 := @Ø:FØ ; | | @MUX16/3:SELCTØ := @Ø:FØ : | | @MUX16/3:SELCT1 := @Ø:FØ : | | @MUX16/3:SELCT2 := @#:F# : @MUX16/3:SELCT2 := @#:F# : | # SOM\_MCF.SING FIGURE 11 SOM and TCAL combined: ## RUN SOM SOM MCF.SING FNTMIL.DSY (part of Super-Shell) Caution: RUN\_SOM looks for the FNTxxx.DSY files in the top level directory. Always run DANCE, DRINK, SOM and SING from the top of the design tree. SOM must be executed anytime the SOM\_MCF.SING file is edited to link the new information to the simulation database. > RUN\_AMCC (if you aren't in the shell) select SOM control file name <control\_file\_name> Annotation file name FNTxxx. DSY exit shell When the steps represented in the AMCC Super-Shell are completed, the next step is to run either DLS, the DAISY Logic Simulator, or DTV, the DAISY Timing Verifier. DLS is called by: DLS GET FMT using the default - use unless YOU want something different; leave no spaces after FMT MODE set mode {edit for MAX} for military or commercial; {edit for MIN} for minimum {ENTER} PUT DLS FMT save the FMT and MODE windows VIEW 9999 10000 proper view step for Q5000 Series; Q3500 Series; Q14000 Series run as long as you need to run RUN 1000000 position data in display buffer START 0 WAVE (ENTER) plot by "Plot Screen" mouse menu LIST S DEMO listing saved as file "DEMO" {ENTER} RESTART 0 VIEW 99 100 closer look - not for vectors that will be submitted RUN 200000 WAVE {ENTER} don't save QUIT {EXECUTE } N {EXECUTE } After DLS is run to satisfaction (the vector set in the example is 100% fault coverage), the vectors that will be submitted for use in test are generated using the AMCCSIMFMT program. This program will take the file produced by the \$OUTPUTS section and reformat it. ``` FUNCTION. SING 25-May-86 15:32:80 Daisy Simulator Object Module(SOM) Generator 5.2.9 (SOM U5.02.02 NOW RISE MIN RISE MAX RISE NOW FALL MIN FALL MAX FALL ******* RUMMING SOM and TCAL ********* ********* SON FORMET OK !!!!! ******** TCAL: PARSING INPUT FILE COMPLETED, NO ERROR FOUND. Copyright (C) 1984 DAISY SYSTEMS Incorporated. ***** PARSING INPUT FILE COMPLETED. LOADING DATA FROM SOM FILE PARSING CONTROL SECTION PARSING DELAY SECTIONS TIMING CALCULATION, US.02.02 TCAL: TCAL: PROCESSING BELAY CALCULATION TCAL: 13, 12, 14, 26, 23, 28 @UKIG.2:IMTCK(*94) : 26, 23, 28, 25, 23, 28 @UKIG.2:IMTRST(*97) : TOPL: NULL INPUT FROM SIFT FILES. PAPSING SIFT FILES @11X16/2:INTQN(#86) INITIALIZATION SIGNAL NAME: 전 전 - : : : <u>1</u> ``` CLASS RUNLSOM FUNCTION. SING FNIMIL. DSV ``` эмбенгийн байган байган жайган жайган жайган байган байг 13, 12, 26, 23, 28 . 14 @MUX16/3:INP6(#605): 13, 12, 14 26, 23, 28 @MUX16/3:INP7(#607) · 12, . 14 26, 23, 28 @MUX16/3:INP8(#609) : 14, 13. 12, 26, 23, 28 @MUX16/3:INP9(#611): 13, 12, 14, 26 : (134) (134) (134) (14) 26, 23, 28 13, 12, 14, 2 @MUX16/3:INP11(#615) 26, 23, 28 13, 12, 14, 26 @MUX16/3:INP12(#617) : 26, 23, 28 13, 12, 14, 2 @MUX16/3:[NP13(#619) 26, 23, 28 13, 12, 14, 26 @MUX16/3:INP14(#621): 26, 23, 28 13, 12, 14, 26, 23, 28 @MUX16/3:INP15(#623) 13, 12, 14, 26, 23, 28 @MUX16/3:SEL3(#625): 13, 12, 14, 26, 23, 28 @MUX16/3:SÉL2(#627) : 13, 12, 14, 26, 23, 28 @MUX16/3:SÉL1(#629): 36, 33, 40, 72, 65, 80 @MUX16/3:SEL0(#631): 36, 33, 40, <u>7</u>2,65,80 @MUX16/4:GÓ000.C(#652): 2 0,0,0,0,0,0,0 @MUX16/4:G0000.E(#653): 0, 0, 0, 0. 0.0 @MUX16/4:XSIG5(#654) 0, 0, 0, 0, 0, 0 **** DELAY CALCULATION COMPLETED. **** TOTAL NUMBER OF ERRORS FOUND = 0 DELAY CALCULATION COMPLETED, NO ERROR TCAL: TCAL: UPDATING DT TABLE TCAL: UNLOADING DATA TO SOM FILE TCAL: TCAL: TERMINATION ********* TCAL FORMAT OK !!!!! ******** CLASS> 3 ``` FIGURE 13: END OF RUN\_SOM - TCAL APPLICATION NOTE 1.DNIX DESIGN METHODOLOGY - DAISY (05000 EXAMPLE) DLS output file format must be binary for a proper submission. An example AMCCSIMFMT output is shown with the example. When 3-state macros are included in a design, it is often desirable to see the high-Z state in the listing during debug. The DLS/DTV format can be edited by: FO edit use switch key to toggle options {ENTER} PUT DLS\_FMT save for later reference The FORMAT file and the MODE file can be printed out using the PLOT\_SCREEN menu command. They can also be saved to a file for printing using the clipsheet options and they can be saved on disk and recalled in another run. All formats (FORMAT, MODE, ACQUIRE, BREAK, TRIGGER) are saved at the same time using: ## PUT <filename> Another feature that is useful is the PRINT\_ON\_CHANGE file which can be created. The PRINT\_ON\_CHANGE file can be requested by editing the SOM\_MCF.SING control file \$OUTPUTS section to provide the instruction to collect data only on the change of monitored signals, rather than collect sampled data as before. Only the output file is affected. The format for the LIST and WAVE are tied to the FORMAT file and will not vary. The format for the output file is what is listed in the \$OUTPUTS section of the simulation control file. Only those signals listed in the control file \$OUTPUTS section will be monitored or recorded. When the output file is the one desired, run AMCCSIMFMT by typing: #### AMCCSIMFMT and responding to the prompts. You can also call the program using the Super-Shell: ## RUN\_AMCC 5 calls AMCCSIMFMT You will be asked for the name of the output file (as listed in the SOUTPUTS section of the control file), the new name you want to use, what format you want with parenthesis (choose "l") and if you want spaces between columns or groups of columns. The spacing is up to you. | ** REPLACE ** | | | | | | |----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-----------------------------------------|-----------------------------------------|-----------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | HAME | BASE | POLARITY | STRN | TRC? | SIGNAL_LIST | | DATO DAT1 DAT10 DAT11 DAT12 DAT13 DAT13 DAT14 DAT2 DAT3 DAT3 DAT6 DAT6 DAT6 DAT7 DAT8 DAT8 DAT8 DAT9 EXTCLK EXTRST IN001 SELCT0 SELCT1 SELCT2 SUT001 OUTC OUTC OUTE YOUTPT | | + + + + + + + + + + + + + + + + + + + + | OFF | 333333333333333333333333333333333333333 | EMUX.16-3:DAT0 eMUX.16-3:DAT10 eMUX.16-3:DAT10 eMUX.16-3:DAT11 eMUX.16-3:DAT12 eMUX.16-3:DAT13 eMUX.16-3:DAT13 eMUX.16-3:DAT14 eMUX.16-3:DAT15 eMUX.16-3:DAT3 eMUX.16-3:DAT3 eMUX.16-3:DAT3 eMUX.16-3:DAT3 eMUX.16-3:DAT3 eMUX.16-3:DAT3 eMUX.16-3:DAT6 eMUX.16-3:DAT6 eMUX.16-3:DAT6 eMUX.16-3:DAT7 eMUX.16-3:DAT8 eMUX.16-3:DAT7 eMUX.16-3:DAT8 eMUX.16-3:DAT8 eMUX.16-3:DAT8 eMUX.16-3:DAT9 eMUX.16-3:DAT9 eMUX.16-3:DAT9 eMUX.16-3:DAT9 eMUX.16-3:DAT0 eMUX.16-3:DAT | | <br> <br> TOTAL NUMBER 0 | F PRIM | ITIUES = | | 671 | | | DLS > FORMAT > FORMAT > | ·> | | | | | FIGURE 14: DLS FORMAT WINDOW ``` 15 DES USEQUE DE PROPRIO DE PROPRIO DE LA CONTRATA DE PROPRIO DE PROPRIO DE LA CONTRATA DE PROPRIO DE LA CONTRATA DEL CONTRATA DE LA DEL CONTRATA DE LA CONTRATA DE LA CONTRATA DE LA CONTRATA DEL CONTRATA DEL CONTRATA DEL CONTRATA DE LA CONTRATA DE LA CONTRATA DE LA CONTRATA DE LA CONTRATA DE LA CONTRATA DEL CONTRATA DE LA CONTRATA DE LA CONTRATA DE LA CONTRATA DE LA CONTRATA DEL CONTRATA DE LA CONTRATA DE LA CONTRATA DEL ** REPLACE ** NAME BASE POLARITY STRN TRC? SIGNAL_LIST YOUTPT BIN OFF ON EMUX16/2:YOUTPT emuxib/2: You PT emuxib/3: DAT13, DAT13, DAT13 emuxib/3: DAT11, DAT10, DAT3, DAT8 emuxib/3: DAT7, DAT6, DAT5, DAT4 emuxib/3: DAT7, DAT6, DAT1, DAT0 emuxib/3: DAT3, DAT2, DAT1, DAT0 emuxib/2: EXTCLK emuxib/3: EXTCLK emuxib/3: SELCT3, SELCT1, SELCT0 Data HEX OFF OH OH DATE OFF HEX 2222 DATO HEX ŎFF OFF OFF OFF DATD HEX EXTCLK BIN EXTRST BIN SELCTA ŎN HEX TOTAL NUMBER OF PRIMITIVES = 671 1 DLS > FORMAT >> FORMAT_SPEC> ŀ ``` FIGURE 15: Edited DLS FORMAT WINDOW - HEX | 95-401 Se #5-402-502 paja-riiki 2009 r<br>** REPLACE ** | | oli Irakeliy T <sub>a</sub> regoy | กั <i>ยรสักษา</i> สบริษยรธนิกร | ray MUZALOW, MARKAN | |------------------------------------------------------------------------------------------------|-----------------------------------------------|-----------------------------------|---------------------------------------------------------------------------|-----------------------------------------------| | SIMULATION MODE ( reserved ) ( reserved ) ( reserved ) | МОМ | | | | | SETUP/HOLD TIME MINIMUM PULSE HIDTH SIGNAL RELATIONSHIP ( reserved ) ( reserved ) ( reserved ) | OFF<br>OFF<br>OFF<br>OFF<br>OFF<br>OFF<br>OFF | TRC? OFF OFF OFF OFF OFF | SORTI<br>MAJOR KEY<br>"I"<br>TIME<br>TIME<br>TIME<br>TIME<br>TIME<br>TIME | ED BY MINOR KEY PATH PATH PATH PATH PATH PATH | | <br> <br> TOTAL NUMBER OF PRIMITIU <br> <br> <br> US > PUT >> DLS_FMT | ES = | 671 | | | FIGURE 16: DLS MODE WINDOW - NOMINAL | ** REPLACE ** | danskar 19 | aurrent don | TEXTE: HAUSTRACT POS | i/HU/ilfi: ««÷ | |------------------------------------------------------------------------------------------------|-------------------------------|-------------------------------|--------------------------------------|------------------------------------------------------| | CTM// ONT OF HORS | | | | | | SIMULATION MODE ( reserved ) | MAX | | | | | ( reserved ) | | | | | | ( reserved ) | | | | | | | II<br>ENABLE | TRC? | Sorte<br>Major Key | ED BY<br>MINOR KEY | | SETUP-HOLD TIME MINIMUM PULSE WIDTH SIGNAL RELATIONSHIP ( reserved ) ( reserved ) ( reserved ) | ON<br>ON<br>OFF<br>OFF<br>OFF | ON<br>ON<br>OFF<br>OFF<br>OFF | TIME<br>TIME<br>TIME<br>TIME<br>TIME | Path<br>Path<br>Path<br>Path<br>Path<br>Path<br>Path | | TOTAL NUMBER OF PRIMITI | UES = | 671 | | | FIGURE 17: DLS MODE WINDOW - Edited for MAXIMUM | 7.00<br>7.00<br>7.00<br>7.00<br>7.00<br>7.00<br>7.00<br>7.00 | ************************************** | 74 16 18 19 18 15 11 13 17 1 18 18 16 1 | | |--------------------------------------------------------------|----------------------------------------|-----------------------------------------|---------------| | GRIDGRES RES | YOUTPT DATA DATA DATA DATA EXTERST | SELCTR<br>SELCTR<br>BUS > STREET | DLS > HAUE >> | FIGURE 18: DLS WAVE - HEX FORMAT FIGURE 19: DLS LIST WITH HEX FORMAT | ABEL<br>ASE<br>OLARITY | тіме собит | YOUTPT<br>BIN | HEX | HEX | DATC<br>HEX | BATD<br>HEX<br>+ | BEN | EXTRST<br>3 IN | HEX | |------------------------|------------------------------------|---------------|--------|--------|------------------|------------------|--------|------------------|-------------| | TRENGTH | | OFF | ø | 9999 <i>8</i> | ø | 9 | 6<br>6 | 6 | 9 | Ø | 1 | Ø | | 1 | 19999 8 | Đ. | 9 | 6 | 6 | 9 | 1 | 1 | æ | | 2 | 29999 #<br>39999 # | ģi<br>1 | 9 | 6 | 5<br>6 | 9 | Ø | A<br>I | ġ<br>B | | ž | 49999 # | i | ŝ | ŝ | ě | 8 | Ŕ | ğ | ij | | 5 | 59999 Ø | ġ | 9 | 6 | 5 | 8 | ĩ | ã | ğ<br>g | | 6 | 69999 # | ā | 9 | 6 | 6 | 9 | ø | ũ | ŋ | | 7<br>8 | 79999 Ø<br>89999 Ø | 1 | 9 | 6 | 6<br>6 | 9 | i<br>i | g | J<br>1 | | 9 | 99999 # | å | š | Ĝ | 6 | 9 | Ĭ | F<br>F | 4 | | iø | 1899998 | ã | 9<br>9 | š | 7 | ģ | ė | ő | 4 | | 11 | 119999# | 1 | 9 | 6 | 7 | 9 | 1 | ø | 3 | | 12 | 1299990 | 1 | 9 | 6 | 6 | 9 | à | J | d | | 13 | 139999Ø<br>149999Ø | Ø | 9 | 6 | 6 | 9 | l<br>ø | g | ; | | 15 | 159999Ø | ĩ | ģ | 6<br>6 | 6<br>6 | 9 | 1 | <b>9</b> | ž | | 16 | 169999# | 1 | 8 | Ğ | 6 | | Ĵ | a<br>a | č | | 17 | 1799998 | Ð | 8 | 6 | 6 | 9 | i | 3 | Ç . | | 18<br>19 | 189939# | #<br>1 | 9 | ē | 6<br>6 | 9 | ä | Ą. | Ç | | 20 | 199999Ø<br>209999Ø | 1 | 9 | 6 | 6 | 9 | i<br>A | 2<br>2<br>2<br>2 | | | Žĩ | 219999# | å | 9 | Ğ | 6 | 9<br>9<br>9 | í | 3 | 3 | | 22 | 229999# | Í | 9 | 7 | 5<br>6 | ğ | ġ | ž | 3 | | 23 | 239999# | 1 | 9 | 7 | 6 | 9 | i | บั | Ġ | | 24 | 249999 <i>8</i><br>259999 <i>8</i> | t<br>o | 9 | 6 | 6 | 9 | Ø | 9 | 3 | | 25<br>26 | 2699998 | វ | 9 | 6<br>6 | 6 | 9 | i<br>B | J<br>O | 7 | | 27 | 2799998 | ĩ | ģ | 6 | š | 9 | ĩ | j<br>J | 9 | | 28 | 2399999 | i | 9 | 4 | š | 9 | ġ | ũ | ă | | 29 | 2999999 | ដ | 9 | 4 | 6<br>6<br>6 | 9 | 1 | ü | 3<br>0<br>3 | | 30 | 3099990 | ö | 9 | 6 | ē | 9 | g | .7 | à | | 31<br>32 | 319999Ø<br>329999Ø | l I | ğ | 6<br>6 | 5<br>6 | 9 | į<br>ž | j<br>J | 9 | | 33 | 339999# | ġ | á | Ğ | 6 | å | ĩ | Ĵ | ŏ · | | 34 | 349999# | ğ | B | 6 | 6 | 9 | ġ | Ĵ | 5 I | | 35 | 359999# | l . | В | 6 | 6 | 9 | 1 | 27 | 0 | | 36<br>37 | 369999#<br>379999# | l<br>Ø | 9 | é | Ģ | 9 | ay. | .3 | 0 | | 38 | 3899990 | ø | 9 | 6 | 6<br>6 | 9 | i<br>Ø | 2 | 6 | | 39 | 3999999 | ĩ | 9 | 6 | Ğ | 9 | ĩ | 3<br>3<br>3<br>3 | 5 | | 48 | 4099990 | 1 | 9 | 6 | Ā | 9 | ø | 3 | 0 0000000 | | 41 | 4199998 | ŭ | 9 | 6 | 4 | 9 | 1 | g. | 5 | | 42<br>43 | 429999Ø<br>439999Ø | Ø<br>L | 9 | 6 | 6<br>6 | 9 | ð | 3 | 3 | | 44 | 4499998 | i | 9 | 6 | 6 | 9 | ū | i<br>g<br>g | 1 | | 45 | 459999Ø | ĝ | ģ | ĕ | 6 | ģ | ĭ | ñ | i | | 46 | 469999# | Ø | 9 | 6 | 6 | 9<br>B | â | Ĩ | i | | 47 | 479999# | 1 | 3. | 6 | 6<br>6 | В | 1 | I | : | | 48 | 489999 <i>8</i><br>499999 <i>8</i> | ! | 9 | 6 | 5 | 9 | ġ | 2 | : | | SØ | 5#9999# | ي.<br>ور | 9 | 6 | 5 | 9 | 1<br>O | 3<br>3<br>3<br>J | 3 | | 5 i | 5199993 | 1 | 9 | 6 | 6<br>6<br>6<br>6 | 9 | ĭ | :3 | 5000007-5 | | 52 | 529595~ | 1 | 9 | 6 | 6 | 1 | ē | 3 | 2 | | 53 | 5399290 | ø | 9 | 6 | 6 | 1 | i. | ų | 3 | | 54<br>55 | 549999 <i>3</i><br>5599996 | g<br>1 | 9 | 6<br>6 | 6 | 9 | ø | ŭ | 3 | | 56 | 569999# | i | 9 | 6 | 6 | 9 | l<br>Ø | 3<br>8 | 4 | | 57 | 5799990 | å | ģ | å | 6 | 9 | i i | Ĵ | 4 | FIGURE 20: PARTIAL 'SAVED' LIST FILE USE: DLS>LIST S SAM FIGURE 22: AMCCSIMFMT sample execution 1\*\*\*CIRCUIT IDENTIFICATION = TIME ``` 9999 19999 29999 01000010010110011010010 11888818818118811818818 0000001001011001101010 39999 10000018810110011010011 49999 000000000010110011011011 59999 100000000010110011011010 69999 0000001801011001101101012 79999 10000010010110011010011 89999 00010010010110011010011 99999 189999 88818818811118811818818 119999 10010010011110011010011 529999 88881118888118811818811 129999 00010010010110011010011 539999 10001110000110011010010 139999 1001001001010110011010010 549999 000011100101100110101010 149999 559999 10001118010118011010011 159999 569999 579999 80811118818110011018611 169999 00110010010110011000011 19811119819119811919919 179999 1011001001011001100010 589999 88811118818111811818818 189999 00112010019119811010010 18511118815111811813811 86811118816118811818011 1881111881611881181818 599999 199999 101100100101110011010011 209999 8818881881811881181811 619999 219999 10100010015115511015010 86111118818118811810618 18111118818118811813 629999 229999 00190010019118111010010 18190010010118111010011 639999 239999 649999 659999 88111118812118811810881 1811111881811881181181888 249999 88188818818118811818811 259999 101000100101100110110010 669999 8011111001911001101010 269999 88188118818118811818818 19111110610110911610011 98101110910110011819011 18101110912118911818919 279999 10100110010110011010011 689999 289999 8819811081511086191081 18188118819110881818818 88198118818118811818818 699999 299999 88191118819118811119818 18181118818118811119818 88181118818118811118811 789999 389999 319999 719999 18188118818118811818811 729999 329999 881181188181188118811 739999 339999 191911100101100110101010 18110110010110011910010 749999 349999 0610101001511001101010 88118118818118811811818 16181818818118511818811 759999 359999 10118118818118811811811 769999 369999 779999 101010100101110010017010 379999 789999 799999 0015101061011001101010010 389999 00010110010110011010010 399999 18181818818118811811818 100101100101100110101011 809999 8811181881811881181181 489999 88818118818818811818811 819999 419999 19111919919119911919910 10010110012010011010010 829999 881118188181118811818118 18111818815118811818111 429999 80818118818118811819818 839999 439999 10010110010110011019011 849999 449999 859999 459999 10000110010110011010010 869999 879999 0001101001011001101212010 469999 479999 88858111819118811818818 18811818818118811818011 88811818818188811819011 10050111813110011010011 889999 489999 00000110010110011010011 899999 1001 18100 181000 11010310 8081 18100 181100 110 10110 1001 18100 181100 11010 11 808918188101 188110 13011 499999 1000011001511001101010 909999 589999 00001110019110011019710 919999 519999 1000111001911001101011 929999 939999 1000101001011001101010 949999 000010101101100110010 959999 10001010111111001101011 969999 88931818813118811819811 979999 10001010013110011010310 ``` FIGURE 23: OUTPUT FROM AMCCSIMFMT When the AMCCSIMFMT program is complete, execute AMCCVRC, the AMCC Vector Rules Checker. This program operates on the AMCCSIMFMT output file. All VRC errors must be removed before submission. Create a signal analysis file using TEC and then call AMCCVRC by typing #### AMCCVRC and responding to the prompts. AMCCVRC is also called by the Super-Shell: RUN\_AMCC Sample session for AMCCVRC: TEC signal\_control\_file\_name {edit} (create signal analysis file) {ENTER}EXIT{EXECUTE} AMCCVRC ERC/CIRCUIT.SDI (netlist - subdirectory) AMCCSIMFMT\_file\_name {select test or tests} signal\_control\_file (for race test) AMCCVRC is only run against the maximum worst-case sampled functional simulation output. It produces AMCCVRC.LST and must be error-free for submission. Note: RESET, SET will usually generate Vector SSO errors that can be documented for what they are. These are the only allowed "errors". Consult AMCC if you have others. After the logic has been verified via the functional simulation, run the at-speed simulation. This will require a smaller VIEW step than was used with the functional simulation to pick up the resolution. The timing step should reflect the speed at which the circuit will be operated (hence the term "at-speed" simulation). The simulation should be run at the Maximum specified operating frequency. The "at-speed" simulation is used to check timing. At-speed simulation can be performed with either DLs or DTV. Using DTV allows an uncertainty range analysis. (Verify if DTV is operational on your system before scheduling its use in the design process.) If the resolution of the waveform is good enough, the T and {ENTER} keys can be used to find the propagation delay between two edges when a waveform is on the screen. Put the cursor on one and strike T . Put the cursor on the other and strike (ENTER). The time will be displayed. Note: AMCC requires sampled (uniform step) vectors for functional, at-speed and AC test simulations and requires PRINT\_ON\_CHANGE results for at-speed and AC Test. The designer should refer to Section 4, <u>Vector Submission Rules and Guidelines</u> for further information on vector requirements. Date: 20 SEP 88 12:12 File: RUN\_DLS DLS <<! GET DLS\_FMT VIEW 9999 18888 RUN 1838888 GUIT N Date: 20 SEP 88 12:12 File: RUN\_ASDLS OLS <<! GET DLS\_FMT VIEW 499 588 RUN 58888 QUIT N #### FIGURE 24 ### PARAMETRIC TESTS This circuit was constructed with a gate tree to allow the development of a parametric vector set using the preferred AMCC methodology. The SOM control file previously created for the function vectors can be copied into a new area (PARAMETER.SING was used as the file name) and the signal generators edited to allow one and only one input at a time to switch from "1" to "0" and back to "1". Because the usued output on the input macro was used, the input signal is inverted. The logic gate used requires all input signals start at "l". The output "PARAM" starts at "0" and switches with each change. All inputs are exercised, including clock, reset and enables, if any. The output format for the simulation output file is the same as for the functional simulation output file. The sampling is the same as for the functional simulation (100ns). Figures A-20 and A-21 in Appendix A show the control file and the AMCCSIMFMT output file. The output file is SIMFMTPR.01 The simulation was run using the commands: RUN\_SOM PARAMETER.SING FNTMIL.DSY DLS GET FMT VIEW 9999 10000 RUN 450000 QUIT N AMCCSIMFMT FUNCTION.VLAF SIMFMTPR.01 1 Y 22 TYPE SIMFMTPR.01 > /DEV/LP -HEA ## THE BEST APPROACH (FLAT DESIGN): - 1. Capture page or pages - Run DANCE on each page after proceeding to the next page - use a window DANCE n -M3 - Check individual pages as they run and correct errors and rerun DANCE TYPE n.DFR in a window - When enough captured (the critical path, other areas of concern, etc.), then run DRINK DRINK -M3 - NOTE: NOT ALL DANCE ERRORS MUST BE REMOVED FOR DRINK TO RUN SO BE CERTAIN ALL n.DFR FILES ARE 2 ERRORS ONLY (THE BORDER ERRORS) - NOTE: NOT ALL DRINK ERRORS MUST BE REMOVED FOR ERCS TO RUN - When DANCE and DRINK are error free or as you want them (partial circuits will still have errors) then run individual shells (on a large circuit this is faster): RUN\_AGIF RUN\_ERC RUN ANN Use TEC to add comments to FNTMIL.DSY or FNTCOM.DSY as well as FNTMIN.DSY 3. Now run the super-shell: RUN\_AMCC and select "3" SIFT Answer the prompts - 4. Step 3 leaves you in TEC so edit the SOM\_MCF.SING file and create any data file needed - 5. Run or continue to run the super shell: RUN\_AMCC and select "4" SOM Answer the prompts - 6. Exit the shell and run DLS or DTV - 7. Run AMCCSIMFMT - 8. Use TEC to create the signal analysis file - 9. Run AMCCVRC