## **PALASM 4 VERSION 1.5 RELEASE NOTES**

Л

© 1992 Advanced Micro Devices, Inc. P.O. Box 3453 Sunnyvale, CA 94088-3453 TWX: 910339-9280 TELEX: 34-6306 TOLL FREE: 800-538-8450

APPLICATIONS HOTLINE: 800-222-9323

Advanced Micro Devices reserves the right to make changes in specifications at any time and without notice. The information furnished by Advanced Micro Devices is believed to be accurate and reliable. However, no responsibility is assumed by Advanced Micro Devices for its use, nor for any infringements of patents or other rights of third parties resulting from its use. No license is granted under any patents or patent rights of Advanced Micro Devices.

MS-DOS and Windows are trademarks of Microsoft Corporation.

PAL and PALASM are registered trademarks, and MACH a trademark of Advanced Micro Devices, Inc.

QEMM is a registered trademark of Quarterdeck Office Systems. DR-DOS is a trademark of Digital Research

| CHAPTER 1. PALASM 4 VERSION 1.5 GENERAL NOTES                        |                                       |
|----------------------------------------------------------------------|---------------------------------------|
| 1.1 Operating System Compatibility                                   |                                       |
| 1.1.1 MS-DOS™ 5.0                                                    |                                       |
| 1.1.2 Memory Managers and the Extended Memory Version PALASM 4       |                                       |
| 1.1.3 DR-DOS                                                         |                                       |
| 1.1.4 Microsoft Windows®                                             | 5                                     |
| 1.1.5 IBM OS/2™                                                      | 5                                     |
| 1.1.6 Networks                                                       |                                       |
| 1.2 Changes to the Installation Program                              | 5                                     |
| 1.3 Installing From an Alternate Drive                               |                                       |
| 1.4 Extended Memory Problems Reported With IBM/AT®s and Compatibles  | 5                                     |
| 1.4.1 Designs Not Compiling                                          | 5                                     |
| 1.4.2 BIOS ROMs and Early IBM/AT Compatibles                         | 6                                     |
| 1.5 Documentation Errors                                             |                                       |
|                                                                      |                                       |
| CHAPTER 2. GENERAL OPERATION                                         |                                       |
| 2.1 Menu Changes - Minimizer                                         |                                       |
| 2.2 Simulator Usage Notes                                            |                                       |
| 2.2.1 Devices Still Supported by the Old Simulator (SIM)             |                                       |
| 2.2.2 Assumptions Made by Previous Versions of the Current Simulator |                                       |
| 2.2.3 Correct Modeling of Registers and Latches                      |                                       |
| 2.2.4 Programer Emulation at Power-Up                                |                                       |
| 2.2.5 Power-Up Sequence                                              |                                       |
| 2.2.6 Software Preload Sequence                                      |                                       |
| 2.2.7 Full Evaluation of Input Pins                                  |                                       |
| 2.2.8 Driving Active-Low and Active-High Clocks for the MACH215      | 11                                    |
| 2.2.9 Product-Term-Driven Clocks                                     |                                       |
| 2.2.10 Simultaneous Events                                           |                                       |
| 2.2.11 Power-up Preload on Floating Pins                             |                                       |
| 2.2.12 Simulation of Three-State Pins for Input and Output           |                                       |
| 2.2.13 Input Signal Ordering                                         |                                       |
| CHAPTER 3. AMD MACH FITTER VERSION 1.5                               |                                       |
| 3.1 General Operation                                                |                                       |
| 3.1.1 Fitting Process                                                |                                       |
| 3.1.2 Tristate Resources in MACH 1 Devices                           |                                       |
| 3.1.3 How to Use Latches on MACH Devices                             |                                       |
| 3.1.4 Save Old Versions of the AMD Fitter and PALASM Software        |                                       |
| 3.2 New Behavioral Features of the AMD MACH Fitter                   |                                       |
| 3.2.1 Product Term Reservation for Logic Functions                   |                                       |
| 3.2.2 Unused Input Registers Now Ignored by the Fitter               |                                       |
| 3.2.3 Reduced Block Limits                                           |                                       |
| 3.2.4 Product Term Redistribution                                    |                                       |
|                                                                      | · · · · · · · · · · · · · · · · · · · |

| 3.3 MACH Fitting Options Menu Changes                                                 | 24       |
|---------------------------------------------------------------------------------------|----------|
| 3.3.1 Partition and Re-Fit                                                            |          |
| 3.3.2 "Default Fuse Options" Controlling the Logic State Unused Pins Are Driven To    |          |
| 3.3.3 Extra Macrocell Assignment Iterations                                           |          |
| EXTRA Option                                                                          |          |
| STD Option                                                                            |          |
| 3.4 Changes to the Fitter Report File                                                 |          |
| 3.4.1 Report File Changes - "Run Until 1st Success" Intermediate Error Counts         |          |
| 3.4.2 Calculation of Total Block Fanout                                               |          |
| 3.4.3 Run Until 1st Success: EXTRA Fitting Option Lists Multiple .RPT Files           | 31       |
| 3.4.4 Block Partitioning Results Table                                                | 31       |
| 3.4.5 Block Signals List Table                                                        | 31       |
| 3.4.6 Block Input List                                                                |          |
| 3.4.7 Using the Block Input and the Block Signal Lists to Manually Partition a Design | 33       |
| CHAPTER 4. MACH230 DEVICE                                                             |          |
| 4.1 MACH230 General Notes                                                             | 35       |
| 4.1.1 MACH230 Buried Macrocells Drive Only Sibling Blocks                             | 35       |
| 4.1.2 Manually Partitioning a MACH230 Design                                          |          |
| More Complex Manual Partitioning Process                                              |          |
| MACH230 Grouping Controls                                                             |          |
| 4.1.3 MACH230 Input Registers and Latches                                             |          |
| 4.2 MACH230 Fitter Features                                                           |          |
| 4.2.1 Buried Logic and I/O Macrocell Partitioning                                     |          |
| 4.2.2 Buried Logic and I/O Macrocell Assignment                                       |          |
| 4.2.3 Block Relettering                                                               |          |
| 4.2.4 Input Storage Removal                                                           | 40       |
| CHAPTER 5. MACH215 DEVICE                                                             |          |
| 5.1 MACH215 Silicon Information                                                       |          |
| 5.2 Control of Special MACH215 Features                                               |          |
| 5.3 MACH215 Input Macrocell Behavior                                                  | 42       |
| 5.4 MACH215 Fitter Issues                                                             | 43       |
| 5.4.1 PAIRing in the MACH215 Can Restrict the Fitter                                  |          |
| 5.4.2 Input Setup Times Affected by Clock Functions Implemented Through Clock         |          |
| Product Term Resources                                                                | 43       |
| 5.4.3 SET, RESET and CLK Product Term Resources Not Supported Within Input            |          |
| PAIR Statements                                                                       | 44       |
| 5.4.4 Changes to the Fitting Algorithm for Assigning Clocks                           |          |
| 5.5 MACH215 Design Example - Flag Register                                            |          |
| Part 1) Sequential Differences                                                        |          |
| Part 1) Sequential Differences                                                        | 40<br>A7 |
| Fait 2) Output from the Eitter                                                        | 4/       |
| Part 3) Output from the Fitter<br>Part 4) Resource Displays from .RPT file            | 4/       |
|                                                                                       |          |
| Chapter 6 - MACH220 Device                                                            |          |
| 6.1 MACH220 Silicon Information                                                       |          |
| 6.2 Documentation Error in PALASM 4 User's Manual                                     | 49       |

| Appendix 1 - PALASM 4 Version 1.5 Fitter Messages                      | 51 |
|------------------------------------------------------------------------|----|
| "F065 - Unused pins default to outputs"                                | 51 |
| "F130 - Extra pin or node declarations"                                | 51 |
| "F170 - No Set/Reset initialization function found! - <n> missing"</n> | 51 |
| "F176 - MACH230 Block Reletter"                                        | 51 |
| "F177 - Pair Declaration Ignored"                                      | 52 |
| "F178 - Pair Declaration Ignored"                                      |    |
| F178 Warning Conditions                                                | 52 |
| Multiple PAIRing                                                       |    |
| No MACH1XX Reg Inp                                                     | 52 |
| Transfer Eq. Missing                                                   | 52 |
| Unused node                                                            |    |
| No PAIRing with CLK                                                    | 52 |
| Physically impossible                                                  | 53 |
| Xfer Ops                                                               | 53 |
| Eqs. not Same                                                          | 53 |
| "F180 - User Pre-placement Ignored"                                    | 53 |
| F180 Warning Conditions                                                | 53 |
| Block Letter too high                                                  | 53 |
| Not a clock pin                                                        | 53 |
| Pin is not within Block                                                |    |
| PAIR Placements                                                        |    |
| "F210 - Design contains both floating and fixed placements"            | 53 |
| "F570 - Invalid signal for MACH architecture"                          | 54 |
| F570 Warning Conditions                                                |    |
| No TRST on Buried Eq                                                   | 54 |
| No CLKF on Comb Eq                                                     | 54 |
| No SETF on Comb Eq                                                     | 54 |
| No RSTF on Comb Eq                                                     | 54 |
| No Node1 Logic Eq                                                      | 54 |
| No Aux Eq. on Input                                                    | 54 |
| Output Always Disabled                                                 | 54 |
| Invalid Clk Eq                                                         | 54 |
| CLKf -> IOM                                                            | 54 |
| Logic on Clkf                                                          | 54 |
| clkf Product Terms                                                     | 54 |
| trst Product Terms                                                     | 54 |
| setf Product Terms                                                     | 54 |
| rstf Product Terms                                                     | 55 |
| Inverted Aux Eq                                                        |    |
| Too many TRST/Bank                                                     | 55 |
| APPENDIX 2 - KNOWN PROBLEMS WITH PALASM 4 VERSION 1.5                  | 57 |
| General                                                                |    |
| Pre-processing                                                         |    |
| Minimizer                                                              |    |
| Fitting MACH devices                                                   |    |
| Fitting PAL devices                                                    |    |
| Simulation                                                             |    |
| Backannotating MACH designs                                            |    |
| Pinouts                                                                |    |
|                                                                        |    |

| APPENDIX 3 - PALASM 4 .PDS FILE - MACH215 APPLICATION EXAMPLE  | 61 |
|----------------------------------------------------------------|----|
| MACH215 Application Example - Flag Register                    | 61 |
| MACH215 Application Example - Flag Register Simulation Results |    |

٠

PALASM® 4 version 1.5, an upgrade to PALASM 4 version 1.4, supports the new MACH220 and MACH215 devices as well as existing AMD PAL® and MACH™ devices. PALASM 4 users need only read the portion of the release notes that pertain to the device(s) they currently use in their designs.

- If you are <u>not</u> using MACH devices, read chapters 1 and 2.
- - MACH230 devices, read chapter 4
  - MACH215 devices, read chapter 5
  - MACH220 devices, read chapter 6

The appendices explain error messages and describe known problems.

Related documents -

- MACH Family Data Book (PID #14051 revision F or later)
- PALASM 4 User's Manual
- MACH Technical Briefs (PID #15972)
- 1992 PAL Device Data Book (PID #10173)

To obtain a copy of the latest databook or MACH Technical Briefs, contact your local AMD sales representative or call AMD Literature at (800) 222-9323.

## CHAPTER 1. PALASM 4 VERSION 1.5 GENERAL NOTES

| IC What to read in Chapter 1                                                                                                                                                                                                                               | lf yo      | ou are a<br>Previous PALASM 4 v1.4 user<br>New user                                                         | read sections 1.1.2 - 1.5<br>read all of chapter 1 |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|-------------------------------------------------------------------------------------------------------------|----------------------------------------------------|
| 1.1 Operating System<br>Compatibility                                                                                                                                                                                                                      |            |                                                                                                             |                                                    |
| 1.1.1 MS-DOS™ 5.0                                                                                                                                                                                                                                          | PAI        | ASM 4 is compatible with MS-D                                                                               | OS™ version 5.0.                                   |
| 1.1.2 Memory Managers and<br>the Extended Memory Version<br>PALASM 4                                                                                                                                                                                       | mei        | e extended memory version of PA<br>mory manager such as Microsoft<br>arterdeck's QEMM. Two tested co<br>ow. | 's EMM386 or                                       |
| CONFIG.SYS file<br>DEVICE=C:\SYS\SETVER.EXE<br>DEVICE=C:\SYS\HIMEM.SYS<br>DOS=high,umb<br>device=C:\sys\emm386.exe 2<br>break = on<br>buffers = 10<br>files = 35<br>device=C:\sys\smartdrv.sys<br>devicehigh=C:\sys\ansi.sys<br>shell c:\command.com /e:15 | 048<br>20- | 48 1024                                                                                                     | ∕manager:                                          |

Table 1. CONFIG.SYS for Microsoft EMM386

**Note** that the suggested CONFIG.SYS for QEMM (below) has changed; the information published in the PALASM 4 version 1.4 Release Notes was incorrect:

CONFIG.SYS file for Quarterdeck's QEMM memory manager: DEVICE=C:\QEMM\QEMM386.SYS EXTMEM=4096 RAM rem DEVICE=C:\QEMM\QEMM386.SYS RAM MAPS=12 HANDLES=96 NS -incorrect!!! SHELL =c:\COMMAND.COM /E:880 /P DOS=HIGH,UMB break=on FILES=20 BUFFERS=20 rem install= c:\qemm\loadhi.com /tsr /r:3 c:\dos\fastopen.exe c:=80 /x

Table 2. CONFIG.SYS File compatible with MS-DOS 5.0 and EMM386

These configurations have been tested on a system configured with most utilities and device drivers in a \sys directory. Your system may be different.

1.1.3 DR-DOS

PALASM 4 version 1.5 is not supported under Digital Research's DR-DOS.

However, some users have run PALASM 4 successfully under DR-DOS 6.0 with QEMM 6.0, using the configuration below. AMD has not completely tested this configuration and therefore cannot assume responsibility for supporting customers in this environment.

| DR-DOS Configuration - AUTOEXEC.BAT                                                                                                                                                                                                                                                                                                                                                                           |  |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| <pre>@echo off<br/>:DRDOSBEG<br/>PATH C:\DRDOS;c:\QEMM;C:\pc;C:\PALASM\EXE;<br/>@<br/>LOADHI BUFFERS=40<br/>LOADHI FILES=40<br/>LOADHI=FCBS 4,4<br/>VERIFY OFF<br/>PROMPT \$p\$g<br/>SET PALASM=C:\PALASM\<br/>SET ORCAD=c:\ORCAD\<br/>@<br/>rem LOADHI C:DRDOS\SHARE.EXE /L:40 MUST BE REMOVED!!!<br/>cls<br/>ECHO PALASM 4 Software - (c)Copyright AMD 1992 All Rights Reserved<br/>rem<br/>:DRDOSEND</pre> |  |
| DR-DOS Configuration - CONFIG.SYS<br>DEVICE=C:\QEMM\QEMM386.SYS RAM NOSH<br>SHELL =c:\COMMAND.COM C:\ /P /E:512<br>BREAK=ON<br>BUFFERS=1<br>FILES=10<br>FCBS=4,4<br>FASTOPEN=512<br>LASTDRIVE=E<br>HISTORY=ON, 256, ON, OFF, OFF<br>COUNTRY=001,,C:\DRDOS\COUNTRY.SYS<br>HIDOS=ON<br>DEVICE=C:QEMM\LOADHI.SYS C:\DRDOS\ANSI.SYS                                                                               |  |

Table 3. AUTOEXEC.BAT and CONFIG.SYS files for DR-DOS 6.0 with QEMM 6.0

Again, AMD has not completely tested this configuration and cannot assume responsibility for supporting customers in this environment.

1.1.4 Microsoft Windows® PALASM 4 version 1.5 is not a WINDOWS program and must be run as a stand-alone program. PALASM 4 version 1.5 is not supported under and is not 1.1.5 IBM OS/2™ compatible with OS/2. 1.1.6 Networks PALASM is not supported for use in networked environments. 1.2 Changes to the PALASM 4 version 1.5 software takes 5-7 MB hard disk space, depending on whether the regular or extended memory version Installation Program is installed. Beginning with this release, the INSTALL program now asks whether to load the Examples and On-line Help files. Not loading these files will save disk space. Install Examples 350KB (Y/N) ? Y Install On Line Help 750KB (Y/N) ? Y Even if the Examples are not installed, the \PALASM\EXAMPLE subdirectory and its associated subdirectories are still created by the INSTALL program. These empty subdirectories may be deleted. The same is true of the On-Line Help. The INSTALL program creates subdirectories within \PALASM\DOC directory, even if the On-line Help is not installed. With the exception of the LOOKUP.HLP file (used the PALASM 4 menu system), the empty subdirectories under \PALASM\DOC may be deleted. 1.3 Installing From an To install PALASM 4 or the MACH Libraries from a drive other Alternate Drive than "A", use the letter of the drive you are installing from both before and after the INSTALL command. For example: B:INSTALL B: This command will install the software from the B drive onto whatever hard drive is chosen later in the installation program. 1.4 Extended Memory **Problems Reported With** 

#### 1.4.1 Designs Not Compiling

**IBM/AT®s and Compatibles** 

Problems have been reported running the extended memory version of PALASM 4 on IBM AT (80286) compatibles. These same PCs are able to run the standard memory version successfully. When the problem occurs, compilation of a design would begin under the extended memory version, only to have the menu reappear in a few seconds with no error message or results.

The problem occurs because the INSTALL program, which calls a "tuning" program, did not successfully adapt the

extended memory version of PALASM 4 to your PC. The tuning program is not called if you are using extended memory memory manager or a machine-specific memory access program.

Work Around: Try "tuning" PALASM 4 manually. After installing this release, type:

#### C:> TUNE\_MAN 1

The numerical arguments 1, 2 or 3 implement different tuning strategies effective on many PCs. If the same problem in running the extended memory version of PALASM 4 continues, try running the TUNE\_MAN program again using the numerical argument 2 or 3 instead. PALASM 4 must be already installed in order to use TUNE\_MAN. It does not have to be installed again from floppy disks each time, or re-run each time you reboot or reprocess a design.

1.4.2 BIOS ROMs and Early IBM/AT Compatibles Some customers with early IBM/AT compatibles have reported problems with the extended memory version of PALASM 4. The problem has been traced to problems in early versions of the ROM BIOS shipped with IBM/AT compatibles manufactured before 1989. If you have one of these PCs, consider upgrading the BIOS ROMs. This inexpensive investment will solve problems with many software packages, not just PALASM 4.

## **1.5 Documentation Errors** The following error appears in all copies of the PALASM 4 User's Manual.

page 11-167 Defining Clock Pins: Pin 16 should be listed as CLK1 for the MACH120 and 220 devices, not pin 17.

The errors listed below (previously described in PALASM 4 version 1.4) appear in older, three-hole-punched PALASM 4 User's Manuals acquired prior to August 1992.

| page 11-169 | Pin Declaratio | n Segn   | nent: Pin      | 4 should  | be REGIS      | TERE             | D, not CO  | OMBINATORIAL. |
|-------------|----------------|----------|----------------|-----------|---------------|------------------|------------|---------------|
|             | Pin            | 4        | 102            | COM       | BINATORI      | <del>al</del> Ri | EGISTEI    | RED           |
| page 11-170 | Top of page: ( | Change   | the T-reg      | istered s | signal inside | e the N          | ote as fo  | ollows        |
|             | A6.T: =        | = {IO2.7 | Γ}             |           |               |                  |            |               |
| page 11-171 | Top of page: ( | Change   | e the Pin D    | eclaratio | ons as follo  | ws               |            |               |
|             | Pin            | ?        | <del>lO2</del> | 101       | REG           |                  |            |               |
|             | Node           | ?        | A4             |           | PAIR          | 102              | IO1        | REG           |
| page 11-171 | Middle of page | e: Char  | nge the Pi     | n Declar  | ation to add  | I PAIR           | A3 to Pi   | in 33         |
|             | Pin            | 33       | 14             |           | PAIR A        | 3                |            |               |
| page 11-172 | Top of page: ( | Change   | e the Pin D    | eclaratio | on to add P   | AIR A3           | 8 to Pin 3 | 33            |
|             | Pin            | 33       | l4             |           | PAIR A        | 3                |            |               |

What to read in Chapter 2

2.1 Menu Changes -Minimizer If you are a ....

Previous PALASM 4 v1.4 user read just section 2.2 New user read all of chapter 2

Beginning with PALASM 4 version 1.4, a new Minimizer was added which has a new Logic Synthesis menu option and two improvements. The two improvements are -

- It reduces the memory utilization of most designs by 50% or more.
- The old Minimizer "hung" if more than 14 variables were used in an equation, while the new one is guaranteed to reduce 32 variable equations.

The menu option shown in Figure 1, *Use fast minimization*, allows the user to run an abbreviated version of the new Minimizer. If it is OFF, a more exhaustive minimization is performed. It should be turned ON only if an *Out of memory* error is generated or Minimizer compilation times are unusually long, since the *fast minimization option* may produce equations with more product terms than the standard Minimizer does.



Figure 1. Logic Synthesis Options Menu.

## **2.2 Simulator Usage Notes** The Simulator has been revised for PALASM 4 version 1.5. Most devices, including MACH devices are affected.

## 2.2.1 Devices Still Supported by the Old Simulator (SIM)

The following devices are supported by the old Simulator and are not affected by the changes discussed in sections 2.2.3 through 2.2.11:

- PAL16RA8
- PAL20RA10
- PAL22IP6
- AMPAL23S8
- PAL32R16
- PAL64R32

2.2.2 Assumptions Made by Previous Versions of the Current Simulator (PLDSIM) The revised PALASM 4 version 1.5 Simulator is less tolerant of incompletely specified simulation files. Some previously clean simulation files may now generate error messages and simulation miscompares, or fail programmer JEDEC verification <u>if</u> the simulation file is incompletely specified.

Previous versions of this Simulator (PLDSIM) made several assumptions based on the evaluation of the programmer at power-up that sometimes resulted in devices being modeled incorrectly:

- Registers and latches were incorrectly modeled:
  - Registers powered up to a known state regardless of the state of the input pins.
  - The effect of the control signals on the state of the registers was not evaluated at power-up.
  - Clocks were triggered if clock fan-in went from a low or an unknown to a high.
- MACH devices were incompletely modeled.
- After preload, there was no evaluation of the effect of the control signals on the state of the registers.
- An unknown SET or RESET or CLOCK had no effect on the state of the registers.
- Pins that where unassigned were not evaluated.

The PALASM 4 version 1.5 Simulator corrects modeling problems with registers and latches:

- Register and latches with unknown SET, PRE-SET or CLK/LE signals now generate an unknown state at the output Q.
- The clock will now trigger only if it rises from a low to a high in the case of an active high clock, or from high to a low in the case of an active-low clock.
- The Simulator now reflects the specifications in the MACH Family Data Book. For example, it is legal to have SET and RESET signals high at the same time.
- For devices with preload pins, asserting PRELOAD with SET or RESET results in an unknown fanout at the register output Q.

PLD programmers and testers forced a default test condition on pins set to unknown logic states. On some programmers the default test condition value is programmable. The JEDEC format for the default test condition is "X0\*" for a LOW state, and "X1\*" for a HIGH state. This field must be placed before the first test vector and after the number of pins (QP) and the number of fuses (QF) fields.

Nearly all AMD approved programmers support the default test condition X0\*. The new Simulator assumes that all pins are

PALASM 4 VERSION 1.5 RELEASE NOTES

#### 2.2.3 Correct Modeling of Registers and Latches

## 2.2.4 Programer Emulation at Power-Up

forced to a SOFT-LOW before power-up, and places a "X0\*" before the first test vector.

The unknown state cannot be realized in a physical sense in hardware. Individual programmers can set pins HIGH or LOW, and some programmers are even able to set pins to float (normally not done because the effect of a floating pin cannot be determined for all devices and test cases).

Uninitialized pins are generally set to the default test condition before the power is turned on to the device under test. Programmers cannot determine which pins are inputs and which are outputs, and therefore must use "soft conditions". Under soft conditions, pins are driven high or low by a resistance low enough to drive an input pin but not low enough to override or destroy an output pin.

The Simulator shows the default test condition for uninitialized pins in the history file. However, uninitialized pins remain as "X"s or unknown in the JEDEC test vectors because some testers have a limit on the amount of pins that can be toggled on each single vector.

# 2.2.5 Power-Up Sequence A two stage power-up routine was added to the Simulator to simulate the behavior of registered devices better. The routine evaluates the device state before the first user vector is applied, and takes in account all control signals connected to registers.

Stage 1

- Load all inputs with the default condition (currently 0) and enter affected signals into event queue.
- Load all registers with power-up preload value and enter affected signals into event queue.
- Fix registers so they will not change in response to control signals CLK/ LE, SET, RESET, or PRELOAD.
- Evaluate until steady state.

Stage 2

- Load all inputs with the default condition (currently 0) and enter affected signals into event queue.
- Allow registers to be affected by control signals.
- Evaluate until steady state.

A two stage preload routine was added to the Simulator for the same reasons as at power-up. Control signals such as

PALASM 4 VERSION 1.5 RELEASE NOTES

#### 2.2.6 Software Preload Sequence

SET, RESET, CLK/LE and output enables can affect the register states after they have been preloaded.

Stage 1

- Load all registers with the preload value and enter affected signals into the event queue.
- Fix registers so they will not change in response to the control signals CLK/LE, SET, RESET, and PRELOAD.
- Evaluate until steady state.

Stage 2

- Allow registers to be affected by control signals.
- Evaluate until steady state.

When the software encounters the PRELOAD statement, test vectors are no longer appended to the JEDEC file.

#### 2.2.7 Full Evaluation of Input Pins

2.2.8 Driving Active-Low and Active-High Clocks for the MACH215  All input pins are assumed to be initialized to the default test conditions at power-up.

• The effect of all input pins is now evaluated upon power-up.

The MACH215 and future MACH devices with active-low clocks can be driven with an active-low clock signal at the pin. An active-low clock (a JEDEC "K" clock) is a high-to-low-to-high pulse.

Polarity conventions are consistent with the polarity convention for the SETF command:

- To generate a JEDEC "C" clock force for the active-high pin, CLK, use the simulator command "CLOCKF CLK". If the pin CLK is active-low, use the simulator command "CLOCKF /CLK".
- To generate a JEDEC "K" clock force for the active-high pin, CLK, use the simulator command "CLOCKF /CLK". If the pin CLK is active-low, use the simulator command "CLOCKF CLK".

An example is shown on the following page.

| PIN 1 CLK1<br>PIN 2 /CLK2 | ; Active-high pin<br>; Active-low pin |
|---------------------------|---------------------------------------|
| SIMULATION                | , Accure for prin                     |
| ; For active-high pins    |                                       |
| SETF CLK1                 | ; Generates JEDEC "1" force           |
| SETF / CLK1               | ; Generates JEDEC "O" force           |
| ; For active-low pins     |                                       |
| SETF CLK2                 | ; Generates JEDEC "O" force           |
| SETF / CLK2               | ; Generates JEDEC "1" force           |
| ; Global clock            |                                       |
| CLOCKF                    | ; Generates JEDEC "C" clock           |
| ; For active-high pins    |                                       |
| CLOCKF CLK1               | ; Generates JEDEC "C" clock           |
| CLOCKF / CLK1             | ; Generates JEDEC "K" clock           |
| ; For active-low pins     |                                       |
| CLOCKF CLK2               | ; Generates JEDEC "K" clock           |
| CLOCKF / CLK2             | ; Generates JEDEC "C" clock           |

Table 4. Active-Low and Active-High Clocks for the MACH 215

| Waveform | Test<br>Condition | Description                        |
|----------|-------------------|------------------------------------|
|          | 0                 | Drive input low                    |
|          | 1                 | Drive input high                   |
|          | С                 | Drive input low, high, low         |
|          | D                 | Drive input low, fast transistion  |
|          | к                 | Drive input high, low, high        |
|          | U                 | Drive input high, fast transistion |

Table 5. Driving Test Conditions.

Errors are generated if a "C" clock is asserted on a pin whose state is initially high, or if a "K" clock is asserted on a pin whose state is initially low.

#### 2.2.9 Product-Term-Driven Clocks

The PALASM 4 version 1.5 Simulator supports JEDEC "U" and "D" transitions for dedicated clock pins. If a transition occurs on a dedicated clock pin it is translated to a "U" or "D" transition. The purpose of "U" and "D" clocks is to allow data from all other inputs to be stable before a latch enable or clock transition occurs. Some dedicated clock pins can be used both as clock and as data pins. The user should be aware that on a JEDEC tester this can cause some data lines to be driven at the same time or later than clock signals.

To avoid potential test problems with the simulator command "SETF" the data and CLOCK/LE transitions should occur in separate test vectors. "C" and "K" clock transitions should be used to drive pins that affect register clocks.

The version 1.5 Simulator supports both fast rise and fall transitions for dedicated clock pins on all devices controlled by the SETF syntax. Data from all other inputs must be stable before a latch enable or a clock transition occurs.

Because some dedicated clock pins can be used as both clock and data pins, customers should be aware that some data lines could be driven at the same time or later than clock signals on a JEDEC tester, leading to differences between simulated and observed programmer behavior.

To avoid this problem, Simulator SETF commands and test patterns should be written so that data and CLOCK/LE transitions occur in separate vectors. AMD recommends that CLOCKF commands drive pins that affect register clocks.

Fast rise and fall transitions are not supported for devices with non-dedicated clock pins driving product term clock resources. Unless the programmer is set up to create fast edges on all input transitions, input changes are too slow to properly trigger CMOS storage elements on devices such as the MACH215. Any JEDEC vector verification errors must be individually analyzed to determine the cause of the miscompare.

2.2.10 Simultaneous Events While the MACH devices allow the application of SET and RESET signals at the same time, removing both signals at the same time results in an unknown state. Because the PALASM Simulator is a functional simulator, not a timing simulator, it cannot detect simultaneous events. Take care to remove SET and RESET signals in separate vectors.

2.2.11 Power-up Preload on Floating Pins The PALASM 4 version 1.5 Simulator requires a physical location to preload pins with a power-up state. If there are floating pins, the register value will be set to "X" (the unknown value) at start-up. As a result, some test cases will generate different results if they are executed with floating pins. The work around is to manually place registered pins and nodes.

#### 2.2.12 Simulation of Three-State Pins for Input and Output

The PALASM 4 version 1.5 Simulator may not always properly chose the input symbol set over the output one when a common clock is used to both load an input register and control the output enable.

When the effect of using a single vector for both input and output operations is considered, the problem becomes apparent. When a pin changes from an input logic state (represented by "0" or "1" in the JEDEC signal vector) to an output (represented by "H" or "L") a conflicts arises between which symbol should be used to denote the signal level during that window. Erroneous results may occur:





To avoid this problem, separate the three-state control from the clock event on the input register by adding an extra input to the three-state control PT.

#### 2.2.13 Input Signal Ordering

Programmers apply inputs to a device in different sequences. Some apply inputs in sequential pin order, some apply them in groups of eight pins at a time, and others follow still other patterns. With so many possibilities, no simulator can handle all situations.

Therefore, users should define vectors with device logic in mind, avoiding potential races in vector definition so that any variation in the input sequences will produce the same result. In conventional synchronous logic, this is not a problem - all data input transitions are applied before the device is clocked. However, simultaneous clock events should be avoided.

The problem is more difficult for asynchronous logic designs. Control functions like set and reset should be applied and removed in separate vectors with an "idle" state in between, so that even if input changes are skewed, both will not be applied simultaneously. Likewise, data changes should be separated from storage-enabling or clocking events, so that the ordering of input changes is less likely to have an effect on the output.

## CHAPTER 3. AMD MACH FITTER VERSION 1.5

| what to read in Chapter 2    | Kusu are using MACII devices and are a                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| IS What to read in Chapter 3 | If you are using <u>MACH devices</u> and are a<br>Previous PALASM 4 v1.4 user <i>read sections 3.1.3, 3.2,</i><br><i>3.2.1, 3.2.2, 3.2.3, 3.3,</i><br><i>3.3.1, 3.3.2, 3.3, 3.4, 3.4.1</i><br><i>and 3.4.2</i>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|                              | New user read all of chapter 3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 3.1 General Operation        | <ul> <li>This section describes the MACH fitting process section (3.1.1) and two traits of the AMD Fitter. These are -</li> <li>If more than two tristates are used in a MACH1XX block, the logic may not fit. See section 3.1.2.</li> <li>Some designs which fit when compiled under previous versions of PALASM 4 may not fit when compiled with subsequent versions. See section 3.1.3.</li> </ul>                                                                                                                                                                                                                                                                                                                                      |
| 3.1.1 Fitting Process        | <ul> <li>Pin and node locations should not be specified before the design is compiled. Users should follow the following steps- <ul> <li>First, float pins in the design and compile.</li> <li>Next, manually partition the design and recompile (if necessary).</li> <li>After the design is fitted, back-annotate pin and node locations and re-compile.</li> </ul> </li> <li>Figure 3 shows the processes for fitting MACH230 and other MACH designs. Note that optimization of fitted designs is done so that a design meets speed requirements and is more likely to accept future design modifications without changing the pinout. (Refer to the MACH Technical Brief titled, "Designing for Change with MACH Devices".)</li> </ul> |



Figure 3. MACH Fitting Process.

The fitting process differs if the pinout is fixed. When changes must be implemented to the design after the pinout for the design has been fixed, the process illustrated in Figure 3 is not applicable. In order to maintain the existing pinout, the design should be compiled with the pins corresponding to the original design fixed. New signals may be floated to aid in fitting. Once the design is fitted, all pins should be backannotated and the design re-fitted.

# 3.1.2 Tristate Resources in MACH 1 Devices

The tristate resources in a MACH 1 device blocks are segmented into two banks of macrocells, one bank associated with macrocells 0-7 and the other associated with macrocells 8-15. Two tristate resources are provided for each bank, as shown in Figure 4.





If two or fewer independent tristate resources are used in a block, tristate placement will not affect fitting. However, if more than two tristates are used in a block, macrocells using common tristates must be placed in the same bank. Since the Fitter doesn't take banking into account, it may place equations into a block so that only two tristate signals are available per block.

An example will clarify this. Consider the case where two equations (X & Z) use tristate signal A, and two (W & Y) use tristate signal B. By placing equations using both tristate signals into each bank as illustrated in Figure 5, the Fitter uses all tristate resources in that block.



Figure 5. Non-optimal placement of equations W, X, Y and Z uses all tristates.

If, however, the two equations using tristate A are placed in one bank and the two equations using tristate B are placed in the other, two "free" tristate resources are still available for use. See Figure 6.



Figure 6. Optimal placement of equations W, X, Y and Z leaves 2 "Free" Tristates.

The following steps should be taken to guide the Fitter in placing logic when three or four tristate signals are used in a block and an error message indicates that too many tristates are used -

- Refit the design with the tristate signals removed from the design file, then fit the design with pin placements from this design back-annotated and the tristate signals added.
- If this doesn't result in a successful fit, the equations should be placed in appropriate banks

by specifying pin numbers for them in the declaration section of the design file.

 If the design still will not fit, partition it into blocks manually to move tristate resources into other blocks. (Refer to the "MACH Devices - Manual Logic Partitioning" MACH Technical Brief.)

#### ■ 3.1.3 How to Use Latches on MACH Devices

MACH1XX and 2XX devices, excluding the MACH215, only support active low latches. The correct syntax for the latch enable for these MACH devices is listed below:

/signal.clkf =

The MACH215 device, however, has both active low and active high latches. The correct syntax for enabling active-low and active-high latches is listed below:

| /signal.clkf = | ;active low  |
|----------------|--------------|
| signal.clkf =  | ;active high |

The following example shows how to use latch enables in design files for MACH devices other than the MACH215:

Pin ? AO LATCHED ; output Node ANO LATCHED ; output Pin ? LATCH Pin ? BO ; input Pin ? B1 ; input Pin ? LE ; input AO \*= BO + B1 ANO \*= {AO} /LATCH.CLKF = LE

Because the MACH110, 120, 130, 210, 220 and 230 devices do not support active high latches, if an active high latched equation such as:

LATCH.CLKF = LE

is used in this example, the Fitter will generate the following error message:

>ERROR F570 - Invalid Signal for MACH Arch. (Logic on Clk Eq) - ANO

\_\_\_\_\_

An Auxiliary equation's (Trst/Clk/Setf/Rstf) logic configuration was detected that is not compatible with the MACH device architecture. Please correct the design & rerun all processing steps.

3.1.4 Save Old Versions of the AMD Fitter and PALASM Software

New versions of the AMD Fitter software are not guaranteed to fit designs which old versions did. Old versions of the software used to fit existing designs should be saved in case changes must be made to the design.

As a precaution, save the original PALASM 4 software disks from other releases.

Several new features, applicable to all MACH devices, have been added to the Fitter with PALASM 4 version 1.5, in addition to those previously added with version 1.4:

- New Fitter features in PALASM 4 version 1.5
  - Product Term Reservation for Logic Functions (section 3.2.1)
  - Unused Input Registers are now ignored by the Fitter (section 3.2.2)
  - Reduced block limits. This feature was first implemented in PALASM 4 version 1.4. Turning off "Maximize packing of logic blocks" limits the amount of logic the Fitter places in a block. The resource limits table has been updated to include the new MACH215 device (section 3.2.3).
- New Fitter Features in PALASM 4 version 1.4
  - Product Term Redistibution. Beginning with PALASM 4 version 1.4, the Fitter redistributes product terms within a block until a fit is found (section 3.2.4).

### 3.2 New Behavioral Features of the AMD MACH Fitter



Figure 7. Flowchart of the Fitter process with new Fitter features highlighted.

The MACH230 specific features are discussed in Chapter 4.

If you are already familiar with PALASM 4 version 1.4, read sections 3.2.1 through 3.2.3 before moving to section 3.3.

# 3.2.1 Product Term Reservation for Logic Functions

In the past, all logic functions placed by the Fitter were allocated only the exact number of product term clusters needed to realize the desired logic. The new "Product Term Reservation" feature allows you to choose a placement of free product terms directly for a particular logic function.

The syntax for product term reservation is similar to definition of logical groups:

GROUP MACH\_PTS\_8 Sig\_List

The number used with the GROUP MACH\_PTS statement (i.e. 8) sets the <u>minimum</u> space allocated to each of the signals listed.

Allocating additional terms to logic functions can use up available resources within a block and can reduce the chances of a successful fit. As a reminder, PALASM 4 will generate the informational message below whenever Product Term Reservation is used and a design fails to fit:

|                                                                | pansion was enabled for this design, and the<br>ou may want to reevaluate the PT expansion used<br>sign.                                                                                             |
|----------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                                                | See also the MACH Technical Brief titled "Designing for Change with MACH Devices".                                                                                                                   |
| I 3.2.2 Unused Input<br>Registers Now Ignored by the<br>Fitter | Unused pins, buried nodes and input registers are now ignored in all fitting operations.                                                                                                             |
|                                                                | In the past these items were connected using conventional<br>array logic transfers and consumed PT resources. Unused<br>registered inputs are now highlighted with the following<br>warning message: |
| > WARNING F179 - Pair                                          | Declaration Ignored: (Unused RI) - Sig_Name                                                                                                                                                          |

\_

**3.2.3 Reduced Block Limits** Early versions (pre-PALASM 4 version 1.4) of the Fitter sometimes partitioned too much logic into one block even when other blocks were unused, and then could not fit the design. By reducing block limits, the software attempts to overcome this problem through limiting how much logic the Fitter places in a block.

If the *Maximize packing of logic blocks* Fitter flag is OFF, this feature is enabled and the Fitter uses reduced resource limits to determine how much logic to place in a block, as illustrated in Table 6. If, in contrast, the *Maximize packing of logic blocks* flag is ON, the Fitter uses the limits listed in the ">70%" column.

| Resource                            | D.U.<50% | 50%>D.U.<70% | D.U.>70% |
|-------------------------------------|----------|--------------|----------|
| 🕞 Array Inputs (MACH120,130,220,3   | 230) 23  | 25           | 26       |
| Array Inputs (MACH110,210,215)      | 19       | 21           | 22       |
| Product Terms (MACH110,130,210,230) | 48       | 56           | 64       |
| Product Terms (MACH120,220)         | 32       | 40           | 48       |
| Product Terms (MACH215)             | 16       | 24           | 32       |
| I/O Macros (MACH110,130)            | 14       | 15           | 16       |
| I/O Macros (MACH210,230)            | 6        | 7            | 8        |
| I/O Macros (MACH12O)                | 10       | 11           | 12       |
| I/O Macros (MACH220)                | 4        | 5            | 6        |
| I/O Macros (MACH215)                | 6        | 7            | 8        |

Table 6. Reduced Block Limits (Maximize packing of logic blocks flag OFF).

The benefit of this approach is that it spaces logic evenly among blocks in a MACH device, allowing designs to fit that otherwise would not.

The drawback is that this Fitter may not successfully partition some high utilization designs which previous versions did.

To prevent the software from reducing block limits, run the Fitter with the *Maximize packing of logic blocks* flag ON using the *Select one combination* Fitter option or manually partition the design.

# 3.2.4 Product Term Redistribution Previous versions of the Fitter allocated product terms to macrocells within a block using a fixed algorithm that did not redistribute product terms if a particular allocation would not fit. In contrast, the PALASM 4 version 1.4 Fitter redistributes product terms within a block until a fit is found.

The benefit of this feature is that the PALASM 4 version 1.4 software fits some designs that earlier versions could not.

### 3.3 MACH Fitting Options Menu Changes

Changes to the MACH Fitting Options menu in both PALASM 4 version 1.4 and version 1.5 have added extra functionality to the Fitter, as shown in Figure 8.

| MACH FITTING OP                                                                                                                                                     | TIONS                                                       |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------|
| OUTPUT:<br>Report level                                                                                                                                             | Detailed                                                    |
| SIGNAL PLACEMENT:<br>Float all signals and ignore grouping?<br>Use placement data from<br>Save last successful placement<br>Press <f9> to edit file containing</f9> | N<br>Design file<br><f3><br/>Last successful placement</f3> |
| PARTITION and Re-Fit?<br>DEFAULT FUSE OPTIONS:<br>Unused I/O pins configured as outputs?                                                                            | Y<br>Y if 'Y', Level = H                                    |
| FITTING OPTIONS:<br>When compiling                                                                                                                                  | Run until 1st success: EXTRA                                |

Figure 8. MACH Fitting Options Menu.

Changes made to the MACH Fitting Options menu in PALASM 4 version 1.5

- Partition and Refit improves the likelihood of finding logic partitions after an unsuccessful fit for MACH110, MACH210, MACH130, MACH120, and MACH220 devices (section 3.3.1).
- Default Fuse Options allow you to control the logic state unused pins are driven to (section 3.3.2).

Changes made to the MACH Fitting Options menu in PALASM 4 version 1.4

 Improve the chance of fitting by running extra iterations for macrocell assignment (section 3.3.3).

If you are already familiar with PALASM 4 version 1.4, read sections 3.3.1 and 3.3.2 before moving to section 3.4.

**3.3.1 Partition and Re-Fit** After obtaining an unsuccessful fit with the PALASM 4 version 1.5 Fitter, you now have the option of calling an improved partitioning program for solving such problems. This new fitting option - "Partition and Refit" - can be used with all MACH devices <u>except the MACH215 and MACH230</u> devices.

| OUTPUT:                                 |                              |
|-----------------------------------------|------------------------------|
| Report level                            | Detailed                     |
| SIGNAL PLACEMENT:                       |                              |
| Float all signals and ignore grouping?  | Ν                            |
| Use placement data from                 | Design file                  |
| Save last successful placement          | <f3></f3>                    |
| Press <f9> to edit file containing</f9> | Last successful placement    |
| PARTITION and Re-Fit?                   | Y                            |
| DEFAULT FUSE OPTIONS:                   |                              |
| Unused I/O pins configured as outputs?  | Y if 'Y', Level = H          |
| FITTING OPTIONS:                        |                              |
| When compiling                          | Run until 1st success: EXTRA |

By using the "Partition and Refit" option, you will have a somewhat higher success rate in finding logic partitions. The improved partitioning program optimizes the block placement of logic functions to minimize the required interconnect. It continues to swap functions while improving the chance of a successful fit.

The "Partition and Re-fit" option can only be used <u>after</u> running the Fitter and getting an <u>unsuccessful</u> fit.

When enabled, the Partition and Re-Fit option asks if the block partitions (GROUP MACH\_SEG commands) used in the design file should be kept:

Partition option: KEEP GROUP MACH\_SEGs (Y/N)? N

Choosing "N" allows the Fitter to freely move all signals as needed. Choosing "Y" allows the Fitter to move only those signals not declared in GROUP MACH\_SEG statements in the design file, and possibly keep much of the old pinout.

#### ■ 3.3.2 "Default Fuse Options" Controlling the Logic State Unused Pins Are Driven To

Unused device pins can potentially conduct switching noise into the logic arrays and float between logic thresholds, dissipating additional power. Proper signal termination with a pull-up resistor (> $20k\Omega$ ) can prevent this from happening, but at the cost of additional components. New MACH devices such as the MACH220 and MACH215 have

internal pull-ups, but older MACH devices, such as the MACH110, 210, 130, 230 and 120 do not.

PALASM 4 version 1.5 allows the user to choose the logic state (high or low) that unused pins are driven to from the MACH Fitting Options menu:

| ILE MACH F                             | ITTING OPTIONS                  |
|----------------------------------------|---------------------------------|
| OUTPUT:                                |                                 |
| Report level                           | Detailed                        |
| SIGNAL PLACEMENT:                      |                                 |
| Float all signals and ignore grou      | uping? N                        |
| Use placement data from                | Design file                     |
| Save last successful placemen          | t <f3></f3>                     |
| Press <f9> to edit file containir</f9> | ng Last successful placement    |
| PARTITION and Re-Fit?                  | Y                               |
| DEFAULT FUSE OPTIONS:                  |                                 |
|                                        | is outputs? Y if 'Y', Level = H |
| FITTING OPTIONS:                       |                                 |
| When compiling                         | Run until 1st success: EXTRA    |

Figure 10. MACH Fitting Options - Default Fuse Options.

Note: PALASM 4 version 1.4 allowed the user to configure unused I/O pins as inputs, but did not allow the user to control what state they were driven to.

An informational message is produced when DEFAULT FUSE OPTIONS is set to "Y":

INFORMATION F065 - Unused pins default to outputs - High

Explanation:

. Unused pins are being defaulted to be outputs and enabled.

- . This diminishes the coupling of external noise into the MACH device
- . and removes the need for external resistor pull-up terminations.

Note that unused pins associated with buried logic are still not enabled. Any internal logic changes would cause the pin to change, dissipating additional power and "broadcasting" the buried signal for all to see.

3.3.3 Extra Macrocell Assignment Iterations

**EXTRA** Option

This Fitter feature is enabled from the PALASM 4 compilation menu.

The new *Run until 1st Success: EXTRA* option executes extra macrocell assignment iterations. When the *EXTRA* Fitter option is selected, the Fitter process is altered. The state of the *Maximize packing of logic blocks* flag, which controls block partitioning, is determined before macrocell assignment occurs.

| FILE       EDIT       RUN       VIEW       DOWNLOAD       DOCUMENTATION <f1> for Help         Begin new design       Retrieve existing design       MACH FITTING OPTIONS         Merg       OUTPUT:       Brief         Chan       OUTPUT:       Brief         Delett       SIGNAL PLACEMENT:       Float all signals and ignore grouping?       N         Use placement data from       Design file       Save last successful containing         Sin       Press <f9> to edit file containing       Use all fitting options         Mun until fat success: STD       Run until fat success: EXTRA         DEFAULT FUSE OPTIONS:       Unused I/O pins configured as ou       Select one combination         FITTING OPTIONS:       When compiling       Run until 1st success: STD</f9></f1> |   |                      |                                                         |                                                                                          |                                                                                                                          |                                                                                                          | SM4 ve                                   | rsion 1.5                                                                                                                   |                                         |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|----------------------|---------------------------------------------------------|------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------|------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------|-----------------------------------------|
| Retrieve existing design       MACH FITTING OPTIONS         Merg       OUTPUT:         Chan       OUTPUT:         Delet       Brief         SignAL PLACEMENT:       Float all signals and ignore grouping? N         Use placement data from       Design file         Co       Save last successful containing         Press <f9> to edit file containing         Log       DEFAULT FUSE OPTIONS:         Unused I/O pins configured as ou       Select one combination         FITTING OPTIONS:       Select one combination</f9>                                                                                                                                                                                                                                                            | F | ILE                  | EDI                                                     | T RUN                                                                                    | VIEW                                                                                                                     | DOWNLO                                                                                                   | DAD                                      | DOCUMENTATION                                                                                                               | <f1> for Help</f1>                      |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |   | Re<br>Mi<br>Cł<br>De | etrieve<br>erg<br>an<br>elet<br>et u<br>Wc<br>Co<br>Sin | existing of<br>OUTPU<br>Re<br>SIGNAL<br>Flo<br>Us<br>Sa<br>Pro<br>DEFAU<br>Un<br>FITTINO | T:<br>port level<br>PLACEMI<br>e placement<br>ve last suc<br>ass <f9> to<br/>LT FUSE C<br/>used I/O p<br/>G OPTIONS</f9> | ENT:<br>Is and ignor<br>t data from<br>cessful cont<br>o edit file con<br>OPTIONS:<br>ns configure<br>S: | e group<br>aining<br>ntaining<br>ed as o | Brief<br>bing? N<br>Design file<br>Use all fitting option<br>Run until 1st succ<br>Run until 1st succ<br>Select one combina | ns<br>sess: STD<br>sess: EXTRA<br>ation |

Figure 11. Fitting Options Menu.

If during the fitting process the design is fitted or an error occurs which causes the Fitter to abort, the process is terminated. A message is included in the final error count of the .RPT file which indicates whether the Fitter has aborted:

"%% FITR %% Program Aborted - Errors: 1, Warnings: 0"

If the Fitter does not abort, the process works as follows:

Initially the *Maximize packing of logic blocks* flag is OFF. If the design is successfully partitioned, the macrocell assignment iterations in Table 7 are run. If it fails partitioning, the *Maximize packing of logic blocks* 

flag is turned ON and partitioning is re-run. If the design is then successfully partitioned, the macrocell assignment iterations in Table 7 are run. If not, the design has failed to fit.

If the design has failed to fit with the *EXTRA* iterations, the *Run until 1st success: STD* Fitter iterations (see *STD* option) are then executed.

The macrocell assignment iterations in Table 7 include four *STD* Fitter flag combinations and four *EXTRA* iterations. The extra iterations attempt placements which cannot be duplicated using the *Run until first success: STD* or *Select one combina-tion* menu options. Therefore, it may be necessary to backannotate pins in order to duplicate *Run until 1st success: EXTRA* Fitter runs using these menu options.

| Expand small PT spacing<br>N | Expand all PT spacing<br>N | <u>Comments</u><br>same as <i>STD</i>    |
|------------------------------|----------------------------|------------------------------------------|
| Ŷ                            | N                          | same as <i>STD</i>                       |
| N                            | Ŷ                          | same as <i>STD</i><br>same as <i>STD</i> |
| N                            | N                          | 1st EXTRA Iteration                      |
| N                            | N                          | 2nd EXTRA Iteration                      |
| N                            | N                          | 3rd EXTRA Iteration                      |
| N                            | N                          | 4th EXTRA Iteration                      |

Table 7. EXTRA option fitting flags.

The benefit of the *EXTRA* Fitter option is that additional macrocell assignments are attempted for a given block partition, allowing designs to fit that otherwise would not.

The drawbacks of the option are that compilation times are longer and a larger .RPT file is generated. It is larger because it includes all Fitter iterations (see section 3.4.2).

STD Option

The Run until 1st success: STD Fitter option operates the same as the PALASM 4 Version 1.2 Run until first success option. It does not execute extra macrocell assignment iterations. When the STD option is selected, the Fitter executes up to eight iterations, each using a different combination of the three Fitter flags: Expand small PT spacing, Expand all PT spacing and Maximize packing of logic blocks. Fewer than eight iterations will be run if the design is fitted or an error occurs which causes the Fitter to abort.

The *STD* option creates a .RPT file reflecting the last Fitter iteration.

3.4 Changes to the Fitter Several changes were made to the Fitter report (.RPT) file for PALASM 4 version 1.4 and version 1.5: **Report File** Report file changes for PALASM 4 version 1.5 "Run Until 1st Success - EXTRA" Intermediate Error Counts (section 3.4.1) "Total Block Fanout" (section 3.4.2) Report file changes for PALASM 4 version 1.4 The Run Until 1st Success: EXTRA fitting option lists multiple .RPT files (section 3.4.3) **Block Partitioning Results table** (section 3.4.4) Block Signal List Table (section 3.4.5) Block Input List (section 3.4.6) Using the Block Input List and the Block Signal List Table to Manually Partition a Design (section 3.4.7) If you are already familiar with PALASM 4 version 1.4, just read sections 3.4.1 and 3.4.2 before moving on to Chapter 4. 3.4.1 Report File Changes -The wording of the informational message about "partial" error counts given by the Run Until 1st Success: EXTRA "Run Until 1st Success" fitting option has been changed to "intermediate" error Intermediate Error Counts counts:

|> INFORMATION F085 - Intermediate Error Count: %1, Warning Count: %2 Explanation: . The Fitter has calculated an intermediate total of all error(s) and . warning(s) detected to this point in the processing sequence. It will . try different placement and assignment options automatically for the . user. The error count is reset to zero before beginning this additional . processing.

# 3.4.2 Calculation of Total Block Fanout

A complete description on how the total incremental current due to switching inputs  $(i_{i\tau})$  is calculated is presented in the General Information section of the MACH Family Data Book (revision F or later), under "Approximiating Actual Application Supply Current".

The AMD MACH Fitter reports the fanout for each individual input in the "Blocks" column on the far right side of the "Signals - Tabular Information" portion of the MACH report file. The total block fanout - the sum of all the fanouts of the individual inputs - is listed just above that table as part of an informational message from the Fitter. For example:

INFORMATION F058 - Total Block Fanout (all Signals) \*: 40

| ) | 3.4.3 Run Until 1st Su<br>EXTRA Fitting Option<br>Multiple .RPT Files | 1st Suce<br>Run Un<br>combine<br>.RPT file | A single .RPT file is created during compilation if the Run Until<br>1st Success: STD fitting option is chosen. However, when the<br>Run Until 1st Success: EXTRA option is chosen, the Fitter<br>combines the .RPT files from all fitting attempts in one large<br>.RPT file. This provides the user with more fitting information,<br>but uses additional disk space. |                                                                                                         |                                                                                         |                                                                                                             |                                                 |   |
|---|-----------------------------------------------------------------------|--------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------|-------------------------------------------------|---|
|   |                                                                       |                                            | Two tec<br>•                                                                                                                                                                                                                                                                                                                                                            | Select the B<br>Until 1st Suc                                                                           | ninimizing the<br>rief report leve<br>ccess: EXTRA<br>n Until 1st Suc                   | el when using<br>A fitting option                                                                           | the Run                                         |   |
|   | 3.4.4 Block Partitionii<br>Table                                      | ng Result                                  | Results<br>the seco                                                                                                                                                                                                                                                                                                                                                     | table. One ch                                                                                           | nd "Macros R                                                                            | Product terms                                                                                               | itioning<br>s" are listed in<br>ted in the last |   |
| ) |                                                                       |                                            | reflectin<br><i>logic blo</i><br>resourc<br><i>packing</i><br>appear<br>Block Li                                                                                                                                                                                                                                                                                        | g high resour<br>ocks Fitter op<br>e numbers re<br>of logic block<br>when utilization<br>imits, section | ce utilization.<br>tion is ON, ast<br>flecting 100%<br>ts option is Ol<br>ons are lower | If the <i>Maximi</i><br>terisks are as<br>utilization. If<br>FF, however,<br>. See Table 7<br>& limits when | the <i>Maximize</i> asterisks may               |   |
|   | *** Block Part                                                        | itioning                                   | Results                                                                                                                                                                                                                                                                                                                                                                 |                                                                                                         |                                                                                         |                                                                                                             |                                                 | ] |
|   | Block-> A                                                             | Array<br>Inputs<br>26*                     | Product<br>Terms<br>48                                                                                                                                                                                                                                                                                                                                                  | ∦ I/O<br>Macro<br>8*                                                                                    | Buried<br>Logic<br>4                                                                    | Signal<br>Fanout<br>9                                                                                       | Macros<br>Remain<br>4                           |   |
|   | <br>Block-> H                                                         | 7                                          | 64*                                                                                                                                                                                                                                                                                                                                                                     | 7                                                                                                       | 0                                                                                       | 9                                                                                                           | 9                                               |   |

Table 8. Block Partitioning Results.

#### 3.4.5 Block Signals List Table

There are two additions to the Block Signal List (shown in Table 9): 1) a number following each equation which represents the number of array inputs driving it, and 2) an asterisk, appearing only in MACH230 designs, which flags equations that must be placed in I/O macrocells.

If an equation drives only one array input, it is likely to be a good choice for moving to another block during the manual partitioning process.

The asterisks are used to determine which buried MACH230 equations have been placed in I/O macrocells. When manually partitioning a MACH230 design, users should scan this list for buried equations with asterisks, and re-partition logic so that these equations drive sibling blocks only. If the buried equations drive only sibling blocks, on subsequent attempts to fit the design the Fitter will put them in buried macrocells.

| *** Block St | ignal List |   |        |   |         |   |           |
|--------------|------------|---|--------|---|---------|---|-----------|
| B1k-> A      | ONESHOT    | 3 | WRITE  | 1 | DS      | 1 | S2* 4     |
|              | S1*        | 3 | DATHI* | 4 | L_DS*   | 3 | VLDATA* 5 |
|              | DSACKO*    | 7 | SIZ1*  | 2 | DSACK1* | 7 | SIZO* 2   |

Table 9. Block Signal List.

#### 3.4.6 Block Input List

A new section, Block Input List, has been added to the .RPT file (see Table 10). The "Blk" segment lists the array inputs and number of equations using each array input in a block.

Below the *Blk* segment is the *Singular* segment, which lists each array input in the *Blk* segment that drives only one equation and, in brackets to the right of each array input, the equation it drives. Equations listed in the singular list are likely to be good choices when moving logic between blocks during manual partitioning.

| B1k-> A   | SIZO    | 2  | AWRITE | 1   | VLDATA | 1  | XRDY     | 2                    |
|-----------|---------|----|--------|-----|--------|----|----------|----------------------|
|           | LBGACK  | 7  | SIZ1   | 2   | L_DS   | 1  | LWRITE   | 1                    |
|           | SCSISEL | 2  | LDS    | 2   | UDS    | 2  | DTACK    | 2                    |
|           | SA1     | 1  | AAS    | 3   | EXTERN | 1  | AMIGAMEM | 3                    |
|           | S0      | 2  | S1     | 1   | S2     | 0  | DSACK    | 2                    |
|           | ONESHOT | 1  |        |     |        |    |          |                      |
| Singular: | AWRIT   | Έ{ | VLDAT  | `A} | VLDAT  | A{ | ONESHO   | T)                   |
|           | L_D     | S{ | D      | S}  | LWRIT  | E{ | WRIT     | E)                   |
|           | SA      | 1{ | DATH   | I}  | EXTER  | N{ | DATH     | $ \mathbf{I}\rangle$ |
|           | S       | 1{ | S      | 2}  | ONESHO | T{ | VLDAT    | A)                   |

Table 10. Block Input List.

3.4.7 Using the Block Input and the Block Signal Lists to Manually Partition a Design The Singular list in Table 10 identifies WRITE and DS as the only equations driven by the signals LWRITE and L\_DS. From the Block Signal List we see that these equations use only one array input each (LWRITE and L\_DS); therefore they are good choices for moving to another block if we wish to reduce the array input or product term cluster utilization in block A.

| B What to read in Chapter 4                                     | If you are using <u>MACH230</u> devices and are a<br>Previous PALASM 4 v1.4 user skip chapter 4<br>New user read all of chapter 4                                                                                                                                                                                                                                                       |  |  |  |  |
|-----------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| 4.1 MACH230 General<br>Notes                                    | The MACH230 switch matrix has a buried macrocell intercon-<br>nect limitation not present in other MACH devices. This<br>limitation has made necessary the addition of new Fitter<br>features discussed in Section 4.2. Specifically, the user will fin-<br>that -                                                                                                                      |  |  |  |  |
|                                                                 | <ul> <li>MACH230 designs are more likely to require<br/>manual partitioning than other MACH designs.</li> </ul>                                                                                                                                                                                                                                                                         |  |  |  |  |
|                                                                 | <ul> <li>The manual partitioning process is more com-<br/>plex.</li> </ul>                                                                                                                                                                                                                                                                                                              |  |  |  |  |
|                                                                 | <ul> <li>The changed Fitter algorithm causes partitioning<br/>commands in MACH230 designs to operate<br/>differently than partitioning commands in other<br/>MACH designs.</li> </ul>                                                                                                                                                                                                   |  |  |  |  |
|                                                                 | In this section -                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |
|                                                                 | <ul> <li>Section 4.1.1 discusses the buried macrocell<br/>interconnect scheme.</li> </ul>                                                                                                                                                                                                                                                                                               |  |  |  |  |
|                                                                 | <ul> <li>Section 4.1.2 describes the differences between<br/>manually partitioning a MACH230 design and<br/>manually partitioning other MACH designs.</li> </ul>                                                                                                                                                                                                                        |  |  |  |  |
|                                                                 | <ul> <li>Section 4.1.3 covers issues concerning manually<br/>partitioning MACH230 input registers and<br/>latches.</li> </ul>                                                                                                                                                                                                                                                           |  |  |  |  |
| 4.1.1 MACH230 Buried<br>Macrocells Drive Only Sibling<br>Blocks | I/O macrocells in the MACH230 device, and all macrocells in<br>every other MACH device, can drive any block in the device.<br>In contrast, buried macrocells in the MACH230 device (macro-<br>cells with odd numbers) can only drive macrocells in their<br>"sibling" blocks. Each MACH230 buried macrocell has two<br>sibling blocks, its own and one other. Sibling blocks are listed |  |  |  |  |

in Table 11.

| Buried macrocells | Can only drive macrocells |
|-------------------|---------------------------|
| in MACH230 blocks | in "sibling" blocks       |
| A                 | A H                       |
| B                 | BG                        |
| c c               | C F                       |
| D                 | DE                        |
| E                 | E D                       |
| F                 | F C                       |
| G                 | G B                       |
| Н                 | H A                       |
|                   |                           |

Table 11. Sibling Blocks of MACH230 Buried Macrocells.

| 4.1.2 Manually Partitioning a MACH230 Design | The two differences between manually partitioning a MACH230 design and partitioning other MACH designs are that the process is more complex and the manual partition-ing controls operate differently.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|----------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| More Complex Manual<br>Partitioning Process  | While other MACH designs may be partitioned as de-<br>scribed in the "Manual Logic Partitioning" MACH Technical<br>Brief, an additional factor must be considered for MACH230<br>designs. Since MACH230 I/O macrocells can drive all<br>blocks in the device, but buried macrocells can drive only<br>sibling blocks, I/O macrocells are a more valuable resource<br>than buried macrocells. Therefore, logic should be<br>partitioned so that as many buried signals as possible drive<br>only sibling blocks. If buried signals are partitioned so that<br>they drive only sibling blocks, they will be placed in buried<br>macrocells. Otherwise they will be placed in I/O macrocells.                               |
| MACH230 Grouping Controls                    | The MACH230 manual partitioning command<br>GROUP_MACH_SEG_X is interpreted differently from<br>GROUP_MACH_SEG_X commands for other MACH<br>devices because the Fitter contains a MACH230 Block<br>Relettering feature which "swaps" block letters within the<br>device. (Refer to section 4.2.3 for an explanation of Block<br>Relettering.)                                                                                                                                                                                                                                                                                                                                                                             |
|                                              | MACH230 designs may be manually partitioned with or<br>without the Block Relettering feature enabled (see Figure<br>3). It is recommended that Block Relettering be disabled so<br>that the user retains maximum control. To disable<br>relettering, specify the pin or node location of at least one<br>signal in the declaration section of the .PDS file. If possible,<br>the user should place a clock signal because it will deacti-<br>vate Block Relettering without affecting fitting. Note in<br>Figure 12 that a clock signal (CLK) is pre-placed in the<br>.PDS file; consequently, the equations in the .RPT file are<br>placed in block E as specified by the<br>GROUP_MACH_SEG_E command in the .PDS file. |





If no signal locations are declared, the relettering capability is enabled, and the Fitter is free to swap block letters. Note in Figure 13 that no signals are pre-placed in the .PDS file. Subsequently, the equations associated with the GROUP\_MACH\_SEG\_E command are placed in block F, not E, as shown in the .RPT file.





# 4.1.3 MACH230 Input Registers and Latches

Since input registers and latches use buried macrocells, they are capable of driving only sibling blocks. Therefore, it may not be feasible to use an input register or latch for an equation; the feasibility depends on how much logic it drives and where the logic is placed.

Input registers and latches that drive macrocells in non-sibling blocks must be placed in I/O macrocells. The Fitter does this automatically for signals driving non-sibling blocks and issues the following warning:

"Warning F177 - Pair Declaration Ignored: ..."

Users should realize that placing an input register or latch in an I/O macrocell increases the setup time of the register/latch and consumes an extra array input and product term cluster.

To force the Fitter to place the input register/latch in a buried macrocell, the design must be manually partitioned as described above in section 4.1.2 so that the input register/latch drives only sibling blocks.

# 4.2 MACH230 Fitter Features

Several new Fitter features were added with PALASM 4 version 1.4. Four of these features, which apply only to MACH230 designs, are described here (see Figure 14). The other four are described in Section 3.2 of this document.



#### 4.2.1 Buried Logic and I/O Macrocell Partitioning

Buried Logic and I/O Macrocell Partitioning has been implemented so that partitioning is consistent with the placement changes that will be made later in the fitting process during Buried Logic and I/O Macrocell Assignment (see section 4.2.2).

When partitioning logic into blocks, the Fitter counts the equations each buried signal drives. If a buried signal drives many equations, the Fitter assumes the buried signal will drive non-sibling blocks and will be placed in an I/O macrocell. Thus, during block partitioning, the Fitter counts the buried signal as an I/O signal.

The benefit of this feature is that if the resulting partition does not cause the design to exceed block-resource limits, it increases the likelihood that logic can be successfully assigned to macrocells in a block.

The drawback to this feature is that, in some instances when a feasible partition exists for a design, it will cause fitting failures during the block partitioning phase.

To disable Buried Logic and I/O Macrocell Partitioning, manually partition the design.

Buried Logic and I/O Macrocell Assignment occurs after a design is partitioned. If a buried equation drives non-sibling blocks, the Fitter places the equation in an I/O macrocell.

The benefit of Buried Logic and I/O Macrocell Assignment is that it causes designs which contain buried equations driving non-sibling blocks to fit.

The drawback is that I/O macrocells are a more critical MACH230 device resource than buried macrocells, and the Fitter may use additional I/O macrocells for buried equations when simply re-partitioning logic into sibling blocks will keep them in buried macrocells.

To keep buried logic from being placed in I/O macrocells, manually partition the logic so that the buried signal drives only sibling blocks.

Block relettering occurs after block partitioning. If no signal locations are specified in the declaration section of the .PDS design file, the Fitter automatically reletters blocks so that buried logic drives sibling blocks.

Block relettering helps fit designs by moving buried signals and the equations they drive into sibling blocks.

There are two drawbacks to this feature: 1) It causes MACH230 grouping commands to operate differently than

PALASM 4 VERSION 1.5 RELEASE NOTES

#### 4.2.2 Buried Logic and I/O Macrocell Assignment

#### 4.2.3 Block Relettering

grouping commands for other MACH devices, as described in section 4.1.2, and 2) .RPT file messages listed above the relettering warning message "Warning F176 - MACH 230 Block Reletter" may refer to the wrong blocks.

To disable Block Relettering, pre-place one or more signals in the design. To avoid mixing fixed and floating signals in a design, pre-place a clock signal.

#### 4.2.4 Input Storage Removal

Input Storage Removal occurs after the logic is partitioned into blocks. If an input register/latch drives non-sibling blocks, the input register/latch is configured as a standard register/latch and placed in an I/O macrocell.

The benefit of Input Storage Removal is that it causes designs to fit that otherwise would not.

The drawback of Input Storage Removal is that moving logic from input registers/latches to standard registers/ latches causes additional resources to be used and increases the storage element's setup times. See section 4.1.3 for a detailed explanation of the ramifications of Input Storage Removal.

To keep logic in input registers/latches, manually partition the logic so that it drives only sibling blocks.

| By What to read in Chapter 5           | If you are using <u>MACH215</u> devices<br>Previous PALASM 4 v1.4 user<br>New user                                                                                                                                                                          |  |  |  |  |  |
|----------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| ISP 5.1 MACH215 Silicon<br>Information | The MACH215 is the first asynchronous MACH device. A complete description of the device can be found in the new MACH Device Databook, (PID #14051 revision F or later) available from your local AMD sales representative or AMD Literature (800) 222-9323. |  |  |  |  |  |
|                                        | The MACH215 Node Numbers and following page. Pin 13 is the default                                                                                                                                                                                          |  |  |  |  |  |



Figure 15. Pin and Node Numbering for the MACH215.

## 5.2 Control of Special MACH215 Features

∎ 5.3 MACH215 Input Macrocell Behavior The individual output enable and flip-flop controls for clocking, preset and reset within the MACH215 are controlled by standard PALASM 4 software syntax.

PALASM 4 version 1.5 attempts to map the user's design to the physical resources of the device. Two restrictions in the input macrocells of the MACH215 affect software operation, particularly the Fitter:

The input storage element, present for each I/O pin, has independent control of the clocking functions. However, they can only be generated by the two dedicated clock pins (designated as "Clk/Inputs"), not the internal clock product term functions.

 The input storage element is only initialized by power-on reset. It does not have preset or reset.

# ISSUES 5.4 MACH215 Fitter

The MACH215 device has special features which affect the operation of the MACH Fitter. Specifically:

- PAIRing in the MACH215 can restrict the Fitter's ability to place and route a design (section 5.4.1).
- Input setup times can be adversely affected by clock functions implemented through clock product term resources (section 5.4.2).
- SET, RESET and CLK product term resources are not supported within input PAIR statements (section 5.4.3).
- The fitting algorithm for assigning clocks has been changed (section 5.4.4).

### 5.4.1 PAIRing in the MACH215 Can Restrict the Fitter

PAIRing directs the Fitter to treat paired signals as one structure for placement purposes. Output pairs are implemented in the same macrocell, while input pairs are implemented in adjacent macrocells.

The presence of input pairs can restrict the Fitter's ability to place and route the design. Removing input PAIRs and using clock product term resources instead for "extra" clock inputs can improve the Fitter's ability to realize the design.

5.4.2 Input Setup Times Affected by Clock Functions Implemented Through Clock Product Term Resources

MACH215 input setup times can be adversely affected by clock functions implemented through a clock product term resource. For example:

XYZ.CLKF = /ABC

If pin ABC is placed on a dedicated clock/input pin, it becomes a high-speed direct connection, and both polarities of the connection are available. However, if more than one clock source is involved, or if other signals are already placed on the dedicated clock/input pins, this CLKF function must be implemented as a clock product term resource, at a slight performance penalty. If this occurs, input setup times may be adversely affected. A warning message will appear:

> WARNING F138 - Clock signal(s) connected by PT logic: Sig\_Name

Explanation:

The Fitter software has used the PT clock logic to connect the CLKF to this storage element. This was done because the direct clock pin connection was already used for another clock source. PT clocks are slower than dedicated pin connections. If this is acceptable, no action is required.

As long as this is acceptable, no action is required. A correct JEDEC file is produced.

#### 5.4.3 SET, RESET and CLK Product Term Resources Not Supported Within Input PAIR Statements

The MACH215 does not support SET, RESET or CLK product term resources within an input PAIR statements. If it encounters an illegal PAIR declaration, the Fitter places the logic in separate macrocells and displays the warning message below:

|> WARNING F179 -Pair Declaration Ignored: 215 PAIR S/R found- Sig\_Name Explanation: The PAIR declarations for the indicated signals are slightly contrary to the supported device features. The design will be completed ignoring the user provided PAIR declaration in independent logical resources chosen by the Fitter. (Both Pin and Node are floated.) (Input registers, realized in the array will have longer setup times.) If fitting subsequently fails, check the construction of this logical PAIRing for accuracy. Correction of the PAIRing problem may allow more efficient realization as a single resource.

Presence of S/R PT's on 215 input PAIRs is incompatible w/ macrocell. Presence of Clk PT's on 215 input PAIRs is incompatible w/ macrocell. An excess of single literal clocks (>2) must be realized as PT clocks. \* . Note: PT clocks are also slower than dedicated pin connections.

5.4.4 Changes to the Fitting Algorithm for Assigning Clocks The same warning message is displayed when the total number of declared clock sources exceeds the clock resources available.

The fitting algorithm for assigning clocks has been changed to accommodate the MACH215:

- First, the Fitter analyzes any pre-placed pins and their usage. If any of the pre-placed pins are for clock sources, or involve dedicated clock/input pins, the appropriate resources are set aside during automatic assignment.
- Next, the Fitter attempts to make the most use of the remaining resources and clock requirements for realizing single pin name connections from the right-hand side of the CLKF equation.
- All floating clocks driving logic macrocells (0, 2, 4, ...14) are counted. The most frequently used source is assigned the default clock, pin 13, if available. The other remaining clocks are implemented using clock product term resources. These clocks are noted with

warning message F138 "Clock signal(s) connected by PT logic".

 Finally, floating clocks driving input macrocells (1, 3, 5, ..15) are counted. Up to two of the most frequently used signals are assigned to dedicated clock/input pins. Signal connections for other cells are implemented by ignoring PAIR declarations, resulting in these signals being placed in separate macrocells. These signals are noted with warning message F179 "Pair Declaration Ignored: 215 PAIR Clk excess".

This simple flag register example that can be loaded and read from a single three-state bus performs two logic fuctions: monitoring sequential differences; and merging several stored conditions into a single device.

The description that follows focuses on the the description of the logic functions and the resulting report files produced by the MACH Fitter. The full text of the .PDS file is presented in Appendix 3.

## Part 1) Sequential Differences

5.5 MACH215 Design

**Example - Flag Register** 

A stored status bit reflects the presence of a difference between the current value of a three-state bus (pin P1 in figure 16) and the value previously stored in latch B2 at the time it was clocked. The status flag is computed by XORing the current and the previous bus values, and is stored to be read on that bus.



Figure 16. Flag Register Status Bit

|                                                                 | The PALASM 4 syntax below declares the pin signal name<br>and the two node names associated with the stored status<br>bit.                                                                                                                                                                                                                                                                                                     |
|-----------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| PIN ? P1 IPAIR B2<br>NODE ? B1 OPAIR P1<br>NODE ? B2            |                                                                                                                                                                                                                                                                                                                                                                                                                                |
| EQUATIONS                                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                |
| P1.T := /B1 * (B2 :+: P<br>B1.T := {P1.T}<br>B2 *= P1<br>X = B2 | 1)<br>; Node equation identical to pin equation<br>; Transfer function input latch<br>; Display output for testing                                                                                                                                                                                                                                                                                                             |
|                                                                 | The three signal names (P1, B1 and B2) uniquely specify<br>the desired feedback connection. A special connection<br>equation must be provided to confirm the PAIR configura-<br>tion. The equation B1.T, identical to the pin equation,<br>insures that the PALASM simulator develops and stores the<br>correct value while remaining device independent. The<br>separate latch equation for node B2 plays a similar role.     |
|                                                                 | When signals are declared without PAIR declarations, the<br>Fitter makes connections using signal paths found in simple<br>PAL devices, according to the type of logic. Registered<br>signals are connected using internally developed register<br>output; combinatorial signals are connected using pin<br>connections. Buried signals are developed using internal<br>connections, leaving the pin free for use as an input. |
|                                                                 | To complete the sequential differences portion of the design, auxiliary control equations must be added:                                                                                                                                                                                                                                                                                                                       |
| P1.TRST = ENA<br>P1.RSTF = R<br>B1.RSTF = R                     |                                                                                                                                                                                                                                                                                                                                                                                                                                |
| P1.CLKF = CLK1<br>B1.CLKF = {P1.CLKF}<br>B2.CLKF = CLK2         | ; Must minimize to 1 PT<br>; Must be same as CLK for pin function                                                                                                                                                                                                                                                                                                                                                              |
|                                                                 | The MACH215 only has one product term per clock:                                                                                                                                                                                                                                                                                                                                                                               |

The MACH215 only has one product term per clock; therefore the clocking function must minimize to one PT. Note that the same equation is required for both P1 and B1.

#### Part 2) Merging Stored Conditions

The single status bit reflects the OR of several stored conditions, as shown in Figure 17.



Figure 17. Multiple Stored Conditions

The other stored condition is defined as a registered input cell:

```
? I1 IPAIR BI1
                      NODE ? BI1
PIN
PIN
     ? I2 IPAIR BI2
                      NODE ? BI2
                      NODE ? BI3
     ? I3 IPAIR BI3
PIN
       Y IPAIR BI4
PIN
     ?
                      NODE ? BI4
EQUATIONS
Y := BI1 + BI2 + BI3 + BI4
Y.TRST = ENA
Y.CLKF = /CLK1
BI1 := I1
            BI1.CLKF = /CLK2
                                             ; MACH215 macrocell
                                 BI1.SETF=P
BI2 := I2
           /BI2.CLKF = /CLK2
                                 BI2.RSTF=R
                                             ; Set/Reset on IPAIR
BI3 := I3
            BI3.CLKF = /CLK1 + /CLK2
                                              : CLK PT use
BI4 := Y
           /BI4.CLKF = CLKS
                                              : Excess CLK resources
```

Part 3) Output from the Fitter

Several warnings appear when the design is compiled, illustrating MACH215 device-specific architectural issues:

```
PAIR Analysis...
|> WARNING F179 - Pair Declaration Ignored: 215 PAIR S/R found - I1/BI1
|> WARNING F179 - Pair Declaration Ignored: 215 PAIR S/R found - I2/BI2
|> WARNING F179 - Pair Declaration Ignored: 215 PAIR Clk PT found - I3/BI3
Pre-Placement and Equation Usage Checks...
|> WARNING F138 - Clock signal(s) connected by PT logic: Y/BI4
```

These warnings are normal. Be sure to evaluate the set-up times of each of the signals.

| Part 4) Resource | <b>Displays from</b> |  |
|------------------|----------------------|--|
| .RPT file        |                      |  |

The Device Resources Checks table counts input registers within the listed Total Macro figure.

|                 | Available    | Used | Remaining |    |     |
|-----------------|--------------|------|-----------|----|-----|
| Clocks:         | 2            | 2    | 0         |    |     |
| Pins:           | 38           | 12   | 26        | -> | 31% |
| I/O Macro:      | 32           | 3    | 29        |    |     |
| Total Macro:    | 64           | 8    | 56        |    |     |
| Product Terms:  | 128          | 14   | 96        | -> | 24% |
| ACH-PLD Resourc | a Chacks OKI |      |           |    |     |

The Block Signal List (below) has an entry for equations with zero signal inputs (B2). These are registered input signals realized in dedicated input cells.

| *** Block S | ignal List             | t      |        |           |        |           |        |  |
|-------------|------------------------|--------|--------|-----------|--------|-----------|--------|--|
| B1k-> A     | BI4 1<br>BI1 1<br>P1 6 | Y<br>X | 5<br>1 | BI3<br>B2 | 1<br>0 | BI2<br>B1 | 1<br>5 |  |

The Logic Map and accompanying key (below) show that MACH215 cells 16-21 are not available for use; these are array input cells. Alternate cells (1, 3, 5,...) in the MACH215 device can only be used as input registers; a zero indicates when one is used. No array PTs are used in this design.

| *** Logic Map                                                                                                                      | - Demo 215 Features Test                              |                                                       |
|------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------|-------------------------------------------------------|
| Gb] Inp<br>CLKS  0 <br>R  1 <br>  2 <br>P  3 <br>ENA  4 <br>  5 <br>K: * Used<br>. Avail<br># N/A<br>0 RegIn<br>. Avail<br>- No.PT | $\begin{array}{c ccccccccccccccccccccccccccccccccccc$ | $\begin{array}{c ccccccccccccccccccccccccccccccccccc$ |

# CHAPTER 6 - MACH220 DEVICE

| I What to read in Chapter 6                             | If you are using <u>MACH220</u> devices<br>Previous PALASM 4 v1.4 user<br>New user                                                                 |                                                      |
|---------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------|
| IS 6.1 MACH220 Silicon<br>Information                   | A complete description of the MACH<br>in the new MACH Device Databook<br>4Q 1991 or later), available from yo<br>representative or AMD Literature. | H220 device can be found<br>(PID#14051, revision E - |
|                                                         | The MACH220 node numbers and<br>Chapter 11 of the PALASM 4 User's                                                                                  |                                                      |
| 6.2 Documentation<br>Error in PALASM 4 User's<br>Manual | The table on page 11-167 of the PA<br>incorrectly identifies pin 17 as CLK1<br>devices. It should be pin 16.                                       |                                                      |

|                                                                              | This appendix lists and explains some of the messages which<br>the PALASM 4 version 1.5 Fitter may report. Other messages<br>are described in chapter 5 of the PALASM 4 User's Manual.<br>Also, the PALASM 4 .LOG file and on-line help provide<br>explanations of many errors not described in these documents.                       |
|------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| "F065 - Unused pins default<br>to outputs"                                   | A Fitter option has been selected which configures all unused I/O pins as outputs. This eliminates the need for external pull up or pull down resistors on unused I/O pins. If this message is not displayed, all unused I/O pins are configured as inputs and should be pulled up or down.                                            |
| "F130 - Extra pin or node<br>declarations"                                   | This warning applies to signals which are declared in the design file, but are not used in any equations. The Fitter ignores them. Beware! The unused signals must be removed from the declarations section of the design file for a .JDC file to be created after simulation.                                                         |
| "F170 - No Set/Reset<br>initialization function<br>found! - <n> missing"</n> | This warning indicates that preset and reset terms are not<br>specified in the design file for a registered signal. If the<br>message reports two missing, then at least one signal is<br>missing both reset and preset terms. If the message reports<br>one missing, one or more signals are missing either reset or<br>preset terms. |
|                                                                              | Beware! The signal's reset/preset terms will be defaulted to a<br>"don't care" state, not "off". If the signal then gets placed in a<br>block with other registered signals, its reset/preset states will<br>become those of the other signals in the block since all signals<br>in a block have the same reset/preset states.         |
|                                                                              | When this warning message occurs, users should check the<br>reset/preset states assumed by signals listed in the message.<br>If the states which they assume impede functionality, their<br>reset/preset states should be defined appropriately in the<br>design file.                                                                 |
| "F176 - MACH230 Block<br>Reletter"                                           | This warning applies to MACH230 designs containing<br>GROUP_MACH_SEG_X statements which manually partition<br>logic into blocks. It indicates that the Fitter has swapped block<br>letters (e.g., the logic partitioned into block B is placed in block<br>G, and the logic partitioned into block G is placed in block B).            |
|                                                                              | To disable Block Relettering, pre-place a signal in the design.<br>Clock pins are generally good choices for this pre-placement.                                                                                                                                                                                                       |
|                                                                              |                                                                                                                                                                                                                                                                                                                                        |

| "F177 - Pair Declaration<br>Ignored" | This warning applies to input register/latch (input paired)<br>signals in MACH230 designs. It indicates that input register/<br>latch signals drive non-sibling blocks (see section 4.1.3). If<br>they do, the Fitter unpairs the signals and configures them<br>as standard registers/latches. Note that standard registers/<br>latches have longer setup times than input registers/<br>latches. |
|--------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                      | To force the Fitter to use the input register/latch configura-<br>tion, manually block partition the logic so that the input<br>registers/latches drive only sibling blocks.                                                                                                                                                                                                                       |
| "F178 - Pair Declaration<br>Ignored" | The Fitter issues this warning message when it ignores<br>illegal PAIR requests in a design file. Pairing syntax<br>specifies that a buried equation be placed in the same<br>macrocell as a specified I/O pin (output pairing), or in the<br>adjacent macrocell (input pairing).                                                                                                                  |
|                                      | A typical F178 warning message appears below (note the highlighted warning condition) followed by a list of F178 warning conditions.                                                                                                                                                                                                                                                               |

"Warning F178 - Pair Declaration Ignored: Transfer Eq. Missing - <signal name/signal name>"

| F178 WARNING CONDITIONS |                                                                                                                                                                                                                                                |  |  |
|-------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Warning Condition       | <u>Description</u>                                                                                                                                                                                                                             |  |  |
| Multiple PAIRing        | The design file contains any of the following syntax errors:<br>1) a pin is paired with more than one buried equation, 2) a<br>buried equation is paired with more than one pin, or 3) a<br>buried equation is input <b>and</b> output paired. |  |  |
| No MACH1XX Reg Inp      | An input pair is specified in a MACH1XX design.<br>MACH1XX devices do not support input pairing.                                                                                                                                               |  |  |
| Transfer Eq. Missing    | An input pair is specified, but the equation that should be associated with it (e.g., <i>buried equation := pin equation</i> ) is not included in the equation section of the design file.                                                     |  |  |
| Unused node             | An input paired equation is not used in any equations.<br>Unused logic such as this is removed by the Fitter.                                                                                                                                  |  |  |
| No PAIRing with CLK     | The registered output of an input paired signal is used as a clock. Clocks must be driven by an input pin, not a macro-cell.                                                                                                                   |  |  |

| Physically impossible                  | A paired buried equation and the associated I/O pin are pre-<br>placed such that pairing is impossible. Paired signals must be<br>located in the same block in identical locations (output pairing)<br>or adjacent locations (input pairing).                                              |
|----------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Xfer Ops                               | A buried equation is output paired with an I/O pin that uses a different macrocell configuration (e.g., the buried signal uses a D flip-flop, but the I/O signal uses a T flip-flop). Paired signals must have identical macrocell configurations.                                         |
| Eqs. not Same                          | Buried and I/O equations that are "output-paired" must be identical. The equations listed in this message are not.                                                                                                                                                                         |
| "F180 - User Pre-placement<br>Ignored" | The Fitter issues this warning message whenever it must<br>ignore statements in a design file that pre-place logic in a block<br>or macrocell. A typical F180 warning message is shown below<br>(note the highlighted warning condition) followed by a list of<br>F180 warning conditions. |

"Warning F180 - Pre-placement Ignored: Not a clock pin - <signal name>"

### **F180 WARNING CONDITIONS**

| Warning Condition                                           | <u>Description</u>                                                                                                                                                                                                                                                                                                                                                        |
|-------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Block Letter too high                                       | You have used an invalid block letter in a block partitioning or<br>group statement. If, for example, you specify block E in a<br>group statement in a MACH210 design, you will get this<br>warning message. MACH210 devices have only four blocks:<br>A, B, C, and D.                                                                                                    |
| Not a clock pin                                             | This design has a clock signal on an I/O pin. Clock signals must be on dedicated clock (CLK) pins.                                                                                                                                                                                                                                                                        |
| Pin is not within Block                                     | A pin pre-placement and a block partitioning statement conflict<br>- the pin pre-placement places the signal in one block, yet the<br>block partitioning (GROUP) statement places the signal in<br>another block.                                                                                                                                                         |
| PAIR Placements                                             | A pair statement and a block partitioning statement conflict -<br>signals which are paired together are placed in different blocks.                                                                                                                                                                                                                                       |
| "F210 - Design contains both floating and fixed placements" | The Fitter issues this warning when processing a design in<br>which some signals are pre-placed on pins and/or in nodes<br>while others are not. If all signals are pre-placed with the<br>placements generated when the design is compiled (pin and<br>node placements are back-annotated) and the design is re-<br>compiled, it is likely that the logic would not fit. |
|                                                             | After fitting the design with partially fixed/partially floating signals, back-annotate all pins and nodes and refit the design.                                                                                                                                                                                                                                          |

# "F570 - Invalid signal for MACH architecture"

The Fitter issues this error message when a designer uses reset, preset, clock, or tristate resources improperly. A typical F570 error message appears below (note the highlighted error condition) followed by a list of all F570 error conditions.

"ERROR F570 - Invalid Signal for MACH Arch. (Logic on cikf) - <signal name>"

#### **F570 WARNING CONDITIONS**

| Error Condition        | <u>Description</u>                                                                                                                                                                                                       |
|------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| No TRST on Buried Eq   | A tristate is used with a buried equation.                                                                                                                                                                               |
| No CLKF on Comb Eq     | A clock is used to control a combinatorial equation.                                                                                                                                                                     |
| No SETF on Comb Eq     | A preset is used to control a combinatorial equation.                                                                                                                                                                    |
| No RSTF on Comb Eq     | A reset is used to control a combinatorial equation.                                                                                                                                                                     |
| No Node1 Logic Eq      | An equation has been placed in node1. Node1 is reserved for global set and reset.                                                                                                                                        |
| No Aux Eq. on Input    | A reset, preset, tristate, or clock is used to control an input signal.                                                                                                                                                  |
| Output Always Disabled | A tristate equation is set equal to GND. The pin signal associated with this equation should be declared as an input, the nodal signal should be declared as a buried node, and the tristate equation should be removed. |
| Invalid Clk Eq         | A clock signal is set equal to VCC or GND.                                                                                                                                                                               |
| CLKf -> IOM            | A clock signal is placed on an I/O pin. A clock signal must be placed on a clock pin.                                                                                                                                    |
| Logic on Clkf          | Equations cannot drive clock inputs. Only input pins can.<br>This design has an equation driving a clock input. If the<br>storage is a latch, the left hand side of the .CLKF equation<br>must be inverted.              |
| clkf Product Terms     | Equations cannot drive clock inputs. Only input pins can.<br>This design has an equation driving a clock input.                                                                                                          |
| trst Product Terms     | A tristate equation consists of logic requiring more than one product term. One product term is available per tristate.                                                                                                  |
| setf Product Terms     | A preset equation consists of logic requiring more than one product term. One product term is available per preset.                                                                                                      |

| rstf Product Terms | A reset equation consists of logic requiring more than one product term. One product term is available per reset.             |
|--------------------|-------------------------------------------------------------------------------------------------------------------------------|
| Inverted Aux Eq    | A reset, preset, clock, or tristate equation is inverted. The MACH architecture doesn't support inversion of these resources. |
|                    |                                                                                                                               |

Too many TRST/Bank More than two tristate equations are used in a bank of eight I/O macrocells. Only two tristates are available per bank.

General

The problems listed here are an addendum to the problems listed in PALASM 4 on-line help.

PALASM 4 is not supported under DR DOS.

PALASM 4 is not supported under any NETWORK environments.

PALASM 4 does not issue an error if there is not enough memory to perform a task. If a process does not run or you are returned back to the MAIN menu unexpectedly, check whether there is enough free memory. PALASM needs 580 KB of available memory, but can operate with less for smaller designs.

The DOS 5.0 standard editor QEDIT is not compatible with PALASM 4. Use another editor such as "ED", the supplied editor, or edit files outside PALASM.

.LOG files larger than 64 KB cannot be VIEWed with the supplied editor, "ED".

Most PALASM sub-programs do not check the available disk space. If a SYSTEM\_ERROR message is given and seems to be out of place, check the available disk space and free some if needed.

T input equations are not allowed for MACH devices.

Extended Memory Problems Reported With IBM/AT®s and Compatibles - Designs Not Compiling: Problems have been reported running the extended memory version of PALASM 4 on IBM AT (80286) compatibles. These same PCs are able to run the standard memory version successfully. When the problem occurs, compilation of a design would begin under the extended memory version, only to have the menu reappear in a few seconds with no error message or results.

The problem occurs because the INSTALL program, which calls a "tuning" program, did not successfully adapt the extended memory version of PALASM 4 to your PC. The tuning program is not called if you are using extended memory memory manager or a machine-specific memory access program.

Work Around: Try "tuning" PALASM 4 manually. After installing this release, type:

C:> TUNE\_MAN 1

The numerical arguments 1, 2 or 3 implement different tuning strategies effective on many PCs. If the same problem in running the extended memory version of PALASM 4 continues, try running the TUNE\_MAN program again using the numerical argument 2 or 3 instead. PALASM 4 must be already installed in order to use TUNE\_MAN. It does not have to be installed again from floppy disks each time, or re-run each time you reboot or reprocess a design.

Extended Memory Problems Reported With IBM/AT®s and Compatibles - BIOS ROMs and Early IBM/AT Compatibles: Some customers with early IBM/AT compatibles have reported problems with the extended memory version of PALASM 4. The problem has been traced to problems in early versions of the ROM BIOS shipped with IBM/AT compatibles manufactured before 1989. If you have one of these PCs, consider upgrading the BIOS ROMs. This inexpensive investment will solve problems with many software packages, not just PALASM 4.

PARSE sometimes incorrectly points to a statement that is correct or does not exist, complaining about a syntax error, when the problem is in a statement immediately preceding it.

Vectored signals are not expanded out to individual signals on SET CHECK PRELOAD statements in the simulation section. Work around: Expand the signals by hand or create a string statement which will be substituted.

Large CASE statements or many STRING statements sometimes generate a "SYSTEM\_ERROR P103 Out of system memory" message during PARSE. It is caused by a compiler limitation. Work around: Try to cut down the number of STRING statements or the size of the CASE statement.

No error or warning is given by PARSE if a condition is set to the value '1'. The EXPAND program will issue an "UNKNOWN TOKEN" error. Work around: Substitute VCC for 1 and GND for 0. These are equivalent.

POWER\_UP can only be used with the START\_UP keyword. No error is given if it is used with another state until it is detected by the EXPAND program, which produces an internal error message.

'IF-THEN-ELSE' and 'CASE' statements: When a signal is set to '1' the ON cover is generated, and when a signal is set to '0', the OFF cover is generated. If the logic synthesis option for the 'IF-THEN-ELSE' CASE default value is set to

PALASM 4 VERSION 1.5 RELEASE NOTES

Pre-processing

OFF (treating the "don't cares" as zero) then only one output cover is produced - the cover defined first in the design.

No warning message is given by the pre-processor when a PIN signal is input paired with a NODE signal, and that NODE signal is output paired with another PIN signal until the fitting stage. The Fitter issues a warning that the NODE output pairing is ignored.

For devices with a fixed power-up, reset and set signals are generated only if the global node is specified in the pin list. (Physical node 1 is always designated as the global node in PALASM 4 syntax.)

An incorrect warning message (B616) is given by the preprocessor for an input paired pin, stating a CLKF equation is not generated for that pin. This has no effect on the design and can be ignored.

Sparse equations with more than 32 inputs are noted with a memory allocation error by the Minimizer. Work around: Set MINIMIZE\_OFF for that equation or run the Minimizer with the "Use Fast Minimization" logic synthesis option (see section 1.4 of these Release Notes).

If state machine syntax is used and the keyword CHECK is used to verify a signal value at the pin, setting the Logic Synthesis Option "Ensure polarity after minimization" to "Best for Device" may cause check clashes during simulation. Work around: Change the Logic Synthesis Option "Ensure polarity after minimization" to "As specified in the design file".

If product term reservation is used and any signals require more terms for logic than are provided, no error message is given by the Fitter.

If a design cannot be successfully routed again once it has been fully placed by the Fitter, report the problem to AMD Corporate Applications (USA: 800-222-9323) or your local AMD Field Application Engineer who will give you assistance. This problem is rare and is caused by changes in the signal routing order.

16V8: Placing a signal name of "TEST" on pin 16 produces the error "Error X3670 illegal signal attribute(s) reg". This affects only pin 16. Work around: Change the name of the signal on pin 16 to something other than "TEST".

16V8: The three-state equation is product-term driven only when used in combinatorial I/O mode. If the equation is set to GND the program does not give an error and a incorrect JEDEC file is produced.

PALASM 4 VERSION 1.5 RELEASE NOTES

#### Minimizer

**Fitting MACH devices** 

**Fitting PAL devices** 

|                             | PALCE610: An incorrect JEDEC file can be generated if a "/"<br>is a PIN signal is defined as "/" and active high or low, T, J/K,<br>or R/S equations are used. Work around: Do not define a PIN<br>signal with a "/". Create active high or low equations by<br>defining the "/" in the equation.                                                                                                                                                                                                                   |  |
|-----------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Simulation                  | The user cannot SETF to the value of "X" for unknown inputs.                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |
|                             | Some dedicated clock pins can be used as both clock and<br>data pins. Transitions on dedicated clock pins result in a<br>JEDEC "U" or "D" vector being produced, allowing data from<br>all other inputs to stabilize before a latch enable or clock<br>transition happens. This can cause problems later as some<br>data lines will be driven at the same time as clock signals on<br>the JEDEC tester. To avoid this problem, write test patterns<br>so that data and clock transitions occur in separate vectors. |  |
|                             | 20RA10: If pin 1 is not defined in the design file, simulation<br>appears to continue but produces no output. Work around:<br>Define pin 1 as something.                                                                                                                                                                                                                                                                                                                                                            |  |
|                             | PLS167, PLS168 and PLS105 devices: If a preset or reset is<br>written for one specific pin, the Simulator cannot apply that<br>preset or reset to other pins. Workaround: Use the global<br>preset and reset equations.                                                                                                                                                                                                                                                                                             |  |
|                             | If the MACH Fitting option "Float all signals" has been used,<br>the resulting placement file (.PLC) file and the original pin list<br>will look very different. The simulator looks at both the last pin<br>placement (.PLC) file and the original pin list and lists the<br>conflicts between the two as errors instead of ignoring the<br>orignal pin list.                                                                                                                                                      |  |
|                             | Avoid using the same signal for the tristate output enable and<br>the output latch enable. The design will fit, however the<br>Simulator may not output the expected vectors. Work around:<br>if check clashes occur on the programmer, modify the vectors,<br>not the design.                                                                                                                                                                                                                                      |  |
| Backannotating MACH designs | Signal names are limited to 14 characters; signals names<br>over 14 characters are truncated by PARSE. This limitation<br>will result in truncated signal names being ignored and lost<br>when they are backannotated from the .PLC file.                                                                                                                                                                                                                                                                           |  |
| Pinouts                     | The program which produces the pinout information does not<br>read the .PLC file; therefore pins that have not been placed<br>do not show on the pinout diagram. Work around: To show<br>these unplaced pins on the pinout diagram, back annotate the<br>signals using the .PLC file. Then change the Compilation run<br>mode to manual, and set all the choices but "Check syntax" to<br>"N". (Check syntax should be set to "Y".) Compile, then view<br>the pinout diagram.                                       |  |
| DALASA                      | A VEDSION 15 DELEASE NOTES                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |

# APPENDIX 3 - PALASM 4 .PDS FILE -MACH215 APPLICATION EXAMPLE

```
MACH215 Application Example - Flag Register
   TITLE Demo 215 Features Test
PATTERN Flg_Reg.PDS
REVISION 1.1
 AUTHOR Nick Schmitz
COMPANY ADVANCED MICRO DEVICES, INC.
   DATE 6/16/1992
CHIP Flg_Reg MACH215
   PIN ? P1 IPAIR B2
   NODE ? B1 OPAIR P1
   NODE ? B2
   PIN ? CLK1
                  PIN ? /CLK2
                                  PIN ?
                                         CLKS ; Clocks
   PIN ?
         R
                   PIN? P
                                  PIN ?
                                          ENA ; Control signals
   PIN ? X
                                                ; Display output for testing
   PIN ? I1 IPAIR BI1
                           NODE ?
                                   BI1
   PIN ? I2 IPAIR BI2
                           NODE ?
                                    BI2
   PIN ? I3 IPAIR BI3
                           NODE ?
                                    BI3
   PIN ? Y IPAIR BI4
                          NODE ?
                                   BI4
   GROUP MACH_SEG_A BI1 BI2 BI3 BI4 P1 B2 X Y
   GROUP MACH_PTS_8 P1
                                               ; Reserve Space for PT growth
EQUATIONS
   P1.T := /B1 * (B2 :+: P1)
   B1.T := \{P1.T\}
                                   ; Node equation identical to pin eq
    B2 *= P1
                                   ; Transfer function input latch
    X = B2
                                   ; Display output for testing
   P1.TRST = ENA
   P1.RSTF = R
   B1.RSTF = R
   P1.CLKF = CLK1
                                 ; Must minimize to 1 PT
   B1.CLKF = \{P1.CLKF\}
                                 ; Must be same as CLK for pin function
   B2.CLKF = CLK2
```

Y := BI1 + BI2 + BI3 + BI4Y.TRST = ENA $Y_{CIKF} = /CIK1$ BI1.CLKF = /CLK2 /BI2.CLKF = /CLK2 BI1 := I1BI1.SETF=P ; MACH215 macrocell BI2.RSTF=R ; Set/Rest on IPAIR BI2 := I2BI3 := I3 BI3.CLKF = /CLK1 BI4 := Y /BI4.CLKF = CLKS BI3.CLKF = /CLK1 + /CLK2; CLK PT use ; Excess CLK resources SIMULATION Trace\_on R P ENA Y X B1 P1 B2 CLK1 /CLK2 CLKS I1 I2 I3 BI1 BI2 BI3 BI4 Setf /CLK1 CLK2 /ENA /CLKS /I1 /I2 /I3 ; Initialize inputs : Rest state for active-low clocks Setf CLKS /CLK2 R Setf P1 /R ; Test out flag register Clockf CLK2 Setf /P1 Y I2 Setf CLK2 ; Make latch B2 transparent Setf P1 ; See data change on X Setf /P1 Setf P1 I3 ClockF CLK1 ; Load BI3 = 1Setf /CLK2 ; Close latch Clockf /CLKS ; Falling edge clock of BI4 Setf /P1 /Y /I2 Clockf /CLKS ClockF CLK1 ClockF CLK1 ; No more changes Setf ENA I3 ; Enable outputs P1 & Y Setf R P Setf /R /P /I3 ; Set/Reset secondary regs ClockF CLK2 ; Edge detect = 0Setf I1 /I2 /I3 ClockF CLK2 ; Load BI1 BI2 (Different edges) Setf /I1 I2 /I3 ; CLK to BI3 disabled ClockF CLK2 Setf CLK2 Setf CLK1 ; Enabled ClockF /CLK2 ; Load BI3 = 0Setf /ENA Trace\_off



### MACH215 Application Example - Flag Register Simulation Results



