# **CPLD Development/Programmer Kit**

.....

**User Guide** 





CPLD Development/Programmer Kit User Guide

-2

**Table of Contents** 



### Section 1

| Introducti | ion . |                                   | 1-1  |
|------------|-------|-----------------------------------|------|
| 1.1        | СР    | LD Development/Programmer Kit     | 1-1  |
| 1.3        | Kit   | Features                          | .1-2 |
| 1.3        | 3.1   | CPLD Development/Programmer Board | .1-2 |
| 1.3        | 3.2   | Logic Doubling CPLDs              | .1-2 |
| 1.3        | 3.3   | CPLD ISP Download Cable           | .1-2 |
| 1.3        | 8.4   | PLD Software CD-ROM               | .1-2 |
| 1.3        | 8.5   | Atmel CD-ROM Data Books           | .1-3 |
| 1.4        | De    | vice Support                      | .1-3 |
| 1.5        | Sys   | stem Requirements                 | .1-3 |
| 1.7        | Teo   | chnical Support                   | .1-4 |
| 1.8        | 8.1   | ProChip Designer                  | .1-5 |
| 1.8        | 8.2   | Atmel-WinCUPL                     | .1-5 |
| 1.8        | 3.3   | ATMISP                            | .1-5 |
| 1.8        | 3.4   | POF2JED                           | .1-5 |
|            |       |                                   |      |

### Section 2

| Hardware Description |                                       |     |  |  |  |
|----------------------|---------------------------------------|-----|--|--|--|
| 2.1 Atr              | mel CPLD Development/Programmer Board | 2-1 |  |  |  |
| 2.1.1                | 8-segment Display LEDs                | 2-2 |  |  |  |
| 2.1.2                | Push-button Switches                  | 2-6 |  |  |  |
| 2.1.3                | Clock Select Jumper                   | 2-6 |  |  |  |
| 2.1.4                | VCC Select Jumper                     | 2-7 |  |  |  |
| 2.1.5                | JTAG Port Header                      | 2-7 |  |  |  |
| 2.1.6                | Power Connectors                      | 2-8 |  |  |  |
| 2.2.1                | Expansion Terminal Holes              | 2-9 |  |  |  |
| 2.3 Atr              | mel CPLD ISP Cable                    | 2-9 |  |  |  |

### Section 3

| CPLD De | esign Flow Tutorial                             | 3-1 |
|---------|-------------------------------------------------|-----|
| 3.1     | Overview                                        | 3-1 |
| 3.2     | Create a Project Using the "New Project Wizard" | 3-1 |
| 3.3     | Add a Design File                               | 3-6 |
|         |                                                 |     |

### Section 4

| Schematic Diagrams. |   | -1 |
|---------------------|---|----|
| Schematic Diagrams. | 4 | -1 |

**CPLD Development/Programmer Kit User Guide** 

# www.BDTIC.com/ATMEL

i

Table of Contents



CPLD Development/Programmer Kit User Guide

ii



# Section 1

## Introduction

### 1.1 CPLD Development/ Programmer Kit

The Atmel CPLD Development/Programmer Kit (P/N: ATF15xx-DK2) is a complete development system and an In-System Programming (ISP) programmer for the ATF15xx family of industry-standard pin-compatible Complex Programmable Logic Devices (CPLDs) with Logic Doubling<sup>™</sup> features. This kit provides designers a very quick and easy way to develop, prototype and evaluate new designs with an ATF15xx CPLD. With the availability of the different Socket Adapter Boards to support all the package types offered in the ATF15xx family of ISP CPLDs, this CPLD Development/Programmer Board can be used as an ISP programmer to program the ATF15xx ISP CPLDs in all the available package types through the industry-standard JTAG interface (IEEE 1149.1a-1993).





**CPLD Development/Programmer Kit User Guide** 

# www.BDTIC.com/ATMEL

Rev. 3300A-PLD-08/02

#### **1.2 Kit Contents** CPLD Development/Programmer Board

- 84-lead PLCC Socket Adapter Board (P/N: ATF15xx-SAJ84)<sup>(1)</sup>
- Atmel CPLD ISP Download Cable
- Atmel PLD Software CD-ROM (includes ProChip Designer<sup>™</sup>, Atmel-WinCUPL<sup>™</sup> and other EPLD software)
- Atmel CD-ROM Data Books
- One ATF1508AS 5V 84-lead PLCC Sample Device
- One ATF1508ASVL 3.3V, low-power, 84-lead PLCC Sample Device
- Atmel CPLD Development/Programmer Kit User Guide
- Note: 1. Only the 84-lead PLCC Socket Adapter Board is included in this kit. Other Socket Adapter Boards are sold separately. Please refer to Section 1.6 for ordering information of the Socket Adapter Boards.

### 1.3 Kit Features

| 1.3.1 | CPLD Development/          | ■ 10-lead JTAG-ISP Port                                                                                       |  |  |  |  |
|-------|----------------------------|---------------------------------------------------------------------------------------------------------------|--|--|--|--|
|       | Programmer Board           | Regulated Power Supply Circuitry for 9V DC Power Source                                                       |  |  |  |  |
|       |                            | ■ 5V or 3.3V V <sub>CC</sub> Operation                                                                        |  |  |  |  |
|       |                            | 84-lead PLCC Socket Adapter Board                                                                             |  |  |  |  |
|       |                            | Socket Adapter Board Headers                                                                                  |  |  |  |  |
|       |                            | Expansion Terminal Holes for all Input and I/O pins of the ATF15xx Device                                     |  |  |  |  |
|       |                            | ■ 2 MHz Crystal Oscillator                                                                                    |  |  |  |  |
|       |                            | Eight 8-segment LED Displays                                                                                  |  |  |  |  |
|       |                            | Global Clear and Output Enable Push Button Switches                                                           |  |  |  |  |
| 1.3.2 | Logic Doubling<br>CPLDs    | ■ ATF1508AS-15JC84, 5V 128-Macrocell ISP CPLD with Logic Doubling Architecture                                |  |  |  |  |
|       |                            | ATF1508ASVL-20JC84, 3.3V Low-power 128-Macrocell ISP CPLD with Logic<br>Doubling Architecture                 |  |  |  |  |
| 1.3.3 | CPLD ISP Download<br>Cable | ■ 5V/3.3V ISP Download Cable for PC Parallel Printer (LPT) Port                                               |  |  |  |  |
| 1.3.4 | PLD Software               | ■ Free Atmel-WinCUPL <sup>™</sup> Design Software                                                             |  |  |  |  |
|       | CD-ROM                     | ■ 30-day Trial Version of Atmel ProChip Designer <sup>™</sup> Software                                        |  |  |  |  |
|       |                            | <ul> <li>Full Licensed Version of Atmel ProChip Designer Software (permanent license<br/>required)</li> </ul> |  |  |  |  |
|       |                            | Atmel CPLD ISP Software (ATMISP)                                                                              |  |  |  |  |
|       |                            | POF2JED Conversion Utility                                                                                    |  |  |  |  |
|       |                            | Logic Doubling Support and Documentation                                                                      |  |  |  |  |



CPLD Development/Programmer Kit User Guide

1-2

#### 1.3.5 Atmel CD-ROM Data Books

- Data Sheets
- Application Notes
- Manuals and User Guides

# **1.4 Device Support** The Atmel CPLD Development/Programmer Board supports the following devices in all speed grades and packages:

| ATF1502AS/ASL   | ATF1508AS/ASL          |
|-----------------|------------------------|
| ATF1502ASV      | ATF1508ASV/ASVL        |
| ATF1502SE/SEL   | ATF1508SE/SEL          |
| ATF1502AE/AEL   | ATF1508AE/AEL          |
| ATF1504AS/ASL   | ATF1516SE/SEL (Future) |
| ATF1504ASV/ASVL | ATF1516AE/AEL (Future) |
| ATF1504SE/SEL   | ATF1532AE/AEL (Future) |
| ATF1504AE/AEL   |                        |

#### 1.5 System Requirements The minimum hardware and software requirements to program an ATF15xx ISP CPLD on the CPLD Development/Programmer Board through the Atmel CPLD ISP Software (ATMISP) V4.0 or later are:

- Pentium<sup>®</sup> or Pentium-compatible microprocessor based computer
- Windows<sup>®</sup> 98, Windows NT<sup>®</sup> 4.0, Windows ME, or Windows 2000
- 16-MByte RAM
- 10-MByte free hard disk space
- Windows-supported mouse
- Available parallel printer (LPT) port
- 9V DC power supply with 500 mA of supply current
- SVGA monitor (800 x 600 resolution)



1-3

### 1.6 Ordering Information

| <b>_</b>        | <b>-</b>                              |  |  |  |  |
|-----------------|---------------------------------------|--|--|--|--|
| Part Number     | Description                           |  |  |  |  |
| ATF15xx-DK2     | Atmel CPLD Development/Programmer Kit |  |  |  |  |
| ATF15xx-SAA44   | 44-lead TQFP Socket Adapter Board     |  |  |  |  |
| ATF15xx-SAJ44   | 44-lead PLCC Socket Adapter Board     |  |  |  |  |
| ATF15xx-SAC49   | 49-lead BGA Socket Adapter Board      |  |  |  |  |
| ATF15xx-SAJ68   | 68-lead PLCC Socket Adapter Board     |  |  |  |  |
| ATF15xx-SAJ84   | 84-lead PLCC Socket Adapter Board     |  |  |  |  |
| ATF15xx-SAA100  | 100-lead TQFP Socket Adapter Board    |  |  |  |  |
| ATF15xx-SAQ100  | 100-lead PQFP Socket Adapter Board    |  |  |  |  |
| ATF15xx-SACT100 | 100-lead BGA Socket Adapter Board     |  |  |  |  |
| ATF15xx-SAA144  | 144-lead TQFP Socket Adapter Board    |  |  |  |  |
| ATF15xx-SAQ160  | 160-lead PQFP Socket Adapter Board    |  |  |  |  |
| ATF15xx-SAC169  | 169-lead BGA Socket Adapter Board     |  |  |  |  |
| ATF15xx-SAQ208  | 208-lead PQFP Socket Adapter Board    |  |  |  |  |
| ATF15xx-SACT256 | 256-lead BGA Socket Adapter Board     |  |  |  |  |

#### 1.7 Technical Support For technical support on any Atmel PLD related issues, please contact the Atmel PLD Applications Group at: Hotline: 1-408-436-4333

- Email: pld@atmel.com
- URL: www.atmel.com/atmel



CPLD Development/Programmer Kit User Guide

1-4

### 1.8 References

To help PLD designers use the different Atmel PLD software, documentation such as Help Files, Tutorials, Application Notes/Briefs, and User Guides are available.

#### 1.8.1 ProChip Designer

| ProChip Designer<br>Help Files | From the ProChip Designer main window, click on HELP and then select PROCHIP DESIGNER HELP. |
|--------------------------------|---------------------------------------------------------------------------------------------|
| Tutorials                      | From the ProChip Designer main window, click on HELP and then select TUTORIALS.             |
| Known Problems & Solutions     | From the ProChip Designer main window, click on HELP and then select REVIEW KPS.            |

#### 1.8.2 Atmel-WinCUPL

| Help Files                          | From the Atmel-WinCUPL main window, click on HELP and then select CONTENTS.                         |
|-------------------------------------|-----------------------------------------------------------------------------------------------------|
| CUPL Programmers<br>Reference Guide | From the Atmel-WinCUPL main window, click on HELP and then select CUPL PROGRAMMERS REFERENCE.       |
| Tutorial                            | From the Atmel-WinCUPL main window, click on HELP, select ATMEL INFO and then select TUTORIAL1.PDF. |
| Known Problems & Solutions          | From the Atmel-WinCUPL main window, click on HELP, select ATMEL INFO and then select CUPL_BUG.PDF.  |

#### 1.8.3 ATMISP

| Help Files                    | From the ATMISP main window, click on HELP and then select ISP HELP.                                                              |
|-------------------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| Tutorial                      | From the ATMISP main window, click on HELP, and then select ATMISP TUTORIAL.                                                      |
| Known Problems &<br>Solutions | Using Windows Explorer, go to the directory where ATMISP is installed and open the README.TXT file through any ASCII text editor. |

#### 1.8.4 POF2JED

| ATF15xx Conversion | From the POF2JED main window, click on HELP and then select |
|--------------------|-------------------------------------------------------------|
| Application Brief  | CONVERSION OPTIONS.                                         |



Introduction



CPLD Development/Programmer Kit User Guide

1-6



# **Section 2**

## **Hardware Description**

#### 2.1 Atmel CPLD Development/ Programmer Board The Atmel CPLD Development/Programmer Board, along with the Socket Adapter Board as shown in Figure 2-1, contains many features that designers will find very useful when developing, prototyping, or evaluating their ATF15xx CPLD design. Features such as push-button switches, 8-segment display LEDs, 2 MHz crystal oscillator, 5V/3.3V V<sub>CC</sub> selector, JTAG-ISP port, and expansion terminal holes make this a very versatile starter/development kit and an ISP programmer for the ATF15xx family of JTAG-ISP CPLDs.

Figure 2-1. CPLD Development/Programmer Board with 84-lead PLCC Socket Adapter Board



CPLD Development/Programmer Kit User Guide

# www.BDTIC.com/ATMEL

2-1

#### Hardware Description

#### 2.1.1 8-segment Display LEDs

The Atmel CPLD Development/Programmer Board contains eight 8-segment LEDs to allow the designer to observe the outputs of the ATF15xx. These eight LEDs are labeled **DSP1** to **DSP8** on the board. These eight display LEDs are common anode LEDs with the common anode lines connected to  $V_{CC}$  and the individual cathode lines connected to the I/O pins of the ATF15xx CPLD on the CPLD Development/Programmer Board. To turn on a particular segment of an LED, the corresponding ATF15xx I/O pin connected to this LED segment must be in a logical-0 state. Hence, the outputs of the ATF15xx need to be configured as active-low outputs in the design file.

Figure 2-2. 8-segment Display LED



Each segment of the display LED is hard-wired to one specific I/O pin of the ATF15xx. For the higher pin count devices (100-lead and larger), all eight segments of the eight LEDs are connected to the I/O pins of the ATF15xx. However, for the lower pin count devices (84-lead and smaller), only a subset of the LED segments are connected to the ATF15xx's I/O pins. Table 2-1 to Table 2-8 below show the connections of the LEDs to the ATF15xx in all the different package types.

| DSP/Sgt | PLD Pin # |   | DSP/Sgt | PLD Pin # |   | DSP/Sgt | PLD Pin # |   | DSP/Sgt | PLD Pin |
|---------|-----------|---|---------|-----------|---|---------|-----------|---|---------|---------|
| 1/A     | NC        |   | 3/A     | 28        |   | 5/A     | 6         |   | 7/A     | NC      |
| 1/B     | NC        |   | 3/B     | 26        |   | 5/B     | 4         |   | 7/B     | NC      |
| 1/C     | NC        |   | 3/C     | 24        |   | 5/C     | 5         |   | 7/C     | NC      |
| 1/D     | NC        |   | 3/D     | 25        |   | 5/D     | 8         |   | 7/D     | NC      |
| 1/E     | NC        |   | 3/E     | 27        |   | 5/E     | 11        |   | 7/E     | NC      |
| 1/F     | NC        |   | 3/F     | 29        |   | 5/F     | 9         |   | 7/F     | NC      |
| 1/G     | NC        |   | 3/G     | 31        |   | 5/G     | 12        |   | 7/G     | NC      |
| 1/DOT   | NC        |   | 3/DOT   | NC        |   | 5/DOT   | NC        |   | 7/DOT   | NC      |
| 2/A     | NC        |   | 4/A     | 36        |   | 6/A     | 18        |   | 8/A     | NC      |
| 2/B     | NC        |   | 4/B     | 33        |   | 6/B     | 16        |   | 8/B     | NC      |
| 2/C     | NC        |   | 4/C     | 34        |   | 6/C     | 14        |   | 8/C     | NC      |
| 2/D     | NC        |   | 4/D     | 40        |   | 6/D     | 17        |   | 8/D     | NC      |
| 2/E     | NC        |   | 4/E     | 37        |   | 6/E     | 19        |   | 8/E     | NC      |
| 2/F     | NC        |   | 4/F     | 39        |   | 6/F     | 20        |   | 8/F     | NC      |
| 2/G     | NC        | 1 | 4/G     | 41        |   | 6/G     | 21        | 1 | 8/G     | NC      |
| 2/DOT   | NC        | 1 | 4/DOT   | NC        | 1 | 6/DOT   | NC        | 1 | 8/DOT   | NC      |

#### Table 2-1. Connections of LEDs to ATF15xx 44-lead PLCC



**CPLD Development/Programmer Kit User Guide** 

2-2

| DSP/Sgt | PLD Pin # |
|---------|-----------|
| 1/A     | NC        |
| 1/B     | NC        |
| 1/C     | NC        |
| 1/D     | NC        |
| 1/E     | NC        |
| 1/F     | NC        |
| 1/G     | NC        |
| 1/DOT   | NC        |
| 2/A     | NC        |
| 2/B     | NC        |
| 2/C     | NC        |
| 2/D     | NC        |
| 2/E     | NC        |
| 2/F     | NC        |
| 2/G     | NC        |
| 2/DOT   | NC        |

| Table 2-2. | Connections   | of LEDs to | ATF15xx | 44-lead TQFF |
|------------|---------------|------------|---------|--------------|
|            | 0011100010110 |            | /       |              |

| DSP/Sgt | PLD Pin # |
|---------|-----------|
| 3/A     | 21        |
| 3/B     | 19        |
| 3/C     | 18        |
| 3/D     | 20        |
| 3/E     | 22        |
| 3/F     | 23        |
| 3/G     | 25        |
| 3/DOT   | NC        |
| 4/A     | 30        |
| 4/B     | 27        |
| 4/C     | 28        |
| 4/D     | 34        |
| 4/E     | 31        |
| 4/F     | 33        |
| 4/G     | 35        |
| 4/DOT   | NC        |

| DSP/Sgt | PLD Pin # |
|---------|-----------|
| 5/A     | 44        |
| 5/B     | 42        |
| 5/C     | 43        |
| 5/D     | 2         |
| 5/E     | 5         |
| 5/F     | 3         |
| 5/G     | 6         |
| 5/DOT   | NC        |
| 6/A     | 12        |
| 6/B     | 10        |
| 6/C     | 8         |
| 6/D     | 11        |
| 6/E     | 13        |
| 6/F     | 14        |
| 6/G     | 15        |
| 6/DOT   | NC        |

| DSP/Sgt | PLD Pin # |
|---------|-----------|
| 7/A     | NC        |
| 7/B     | NC        |
| 7/C     | NC        |
| 7/D     | NC        |
| 7/E     | NC        |
| 7/F     | NC        |
| 7/G     | NC        |
| 7/DOT   | NC        |
| 8/A     | NC        |
| 8/B     | NC        |
| 8/C     | NC        |
| 8/D     | NC        |
| 8/E     | NC        |
| 8/F     | NC        |
| 8/G     | NC        |
| 8/DOT   | NC        |

#### Table 2-3. Connections of LEDs to ATF15xx 68-lead PLCC

|         |           | 1 |    |
|---------|-----------|---|----|
| DSP/Sgt | PLD Pin # |   | DS |
| 1/A     | NC        |   |    |
| 1/B     | NC        |   |    |
| 1/C     | NC        |   |    |
| 1/D     | NC        |   |    |
| 1/E     | NC        |   |    |
| 1/F     | NC        |   |    |
| 1/G     | NC        |   | ;  |
| 1/DOT   | NC        |   | 3/ |
| 2/A     | 37        |   |    |
| 2/B     | 33        |   |    |
| 2/C     | 36        | • |    |
| 2/D     | 39        |   |    |
| 2/E     | 41        |   |    |
| 2/F     | 40        |   |    |
| 2/G     | 42        |   |    |
| 2/DOT   | NC        |   | 4/ |
|         |           |   |    |

| DSP/Sgt | PLD Pin # |
|---------|-----------|
| 3/A     | 47        |
| 3/B     | 45        |
| 3/C     | 44        |
| 3/D     | 46        |
| 3/E     | 49        |
| 3/F     | 51        |
| 3/G     | 52        |
| 3/DOT   | NC        |
| 4/A     | 56        |
| 4/B     | 54        |
| 4/C     | 55        |
| 4/D     | 61        |
| 4/E     | 59        |
| 4/F     | 60        |
| 4/G     | 64        |
| 4/DOT   | NC        |

| DSP/Sgt | PLD Pin # |
|---------|-----------|
| 5/A     | 5         |
| 5/B     | 4         |
| 5/C     | 7         |
| 5/D     | 9         |
| 5/E     | 13        |
| 5/F     | 8         |
| 5/G     | 10        |
| 5/DOT   | NC        |
| 6/A     | 17        |
| 6/B     | 14        |
| 6/C     | 15        |
| 6/D     | 18        |
| 6/E     | 22        |
| 6/F     | 20        |
| 6/G     | 23        |
| 6/DOT   | NC        |

| DSP/Sgt | PLD Pin # |
|---------|-----------|
| 7/A     | 25        |
| 7/B     | 24        |
| 7/C     | 27        |
| 7/D     | 29        |
| 7/E     | 32        |
| 7/F     | 28        |
| 7/G     | 30        |
| 7/DOT   | NC        |
| 8/A     | NC        |
| 8/B     | NC        |
| 8/C     | NC        |
| 8/D     | NC        |
| 8/E     | NC        |
| 8/F     | NC        |
| 8/G     | NC        |
| 8/DOT   | NC        |





2-3

#### Hardware Description

| DSP/Sgt | PLD Pin # |
|---------|-----------|
| 1/A     | 49        |
| 1/B     | 46        |
| 1/C     | 48        |
| 1/D     | 50        |
| 1/E     | 52        |
| 1/F     | 51        |
| 1/G     | 54        |
| 1/DOT   | NC        |
| 2/A     | 57        |
| 2/B     | 55        |
| 2/C     | 56        |
| 2/D     | 58        |
| 2/E     | 61        |
| 2/F     | 60        |
| 2/G     | 63        |
| 2/DOT   | NC        |

| DSP/Sgt | PLD Pin # |
|---------|-----------|
| 3/A     | 67        |
| 3/B     | 64        |
| 3/C     | 65        |
| 3/D     | 68        |
| 3/E     | 70        |
| 3/F     | 69        |
| 3/G     | 73        |
| 3/DOT   | NC        |
| 4/A     | 76        |
| 4/B     | 74        |
| 4/C     | 75        |
| 4/D     | 77        |
| 4/E     | 80        |
| 4/F     | 79        |
| 4/G     | 81        |
| 4/DOT   | NC        |

| DSP/Sgt | PLD Pin # |
|---------|-----------|
| 5/A     | 6         |
| 5/B     | 4         |
| 5/C     | 5         |
| 5/D     | 8         |
| 5/E     | 10        |
| 5/F     | 9         |
| 5/G     | 11        |
| 5/DOT   | 45        |
| 6/A     | 16        |
| 6/B     | 12        |
| 6/C     | 15        |
| 6/D     | 17        |
| 6/E     | 20        |
| 6/F     | 18        |
| 6/G     | 21        |
| 6/DOT   | 44        |

| DSP/Sgt | PLD Pin # |
|---------|-----------|
| 7/A     | 25        |
| 7/B     | 22        |
| 7/C     | 24        |
| 7/D     | 27        |
| 7/E     | 29        |
| 7/F     | 28        |
| 7/G     | 30        |
| 7/DOT   | 41        |
| 8/A     | 34        |
| 8/B     | 31        |
| 8/C     | 33        |
| 8/D     | 35        |
| 8/E     | 37        |
| 8/F     | 36        |
| 8/G     | 39        |
| 8/DOT   | 40        |

PLD Pin #

| Table 2-5. ( | Connections of | of LED | s to ATF15 | x 100-lead | IQFP |         |           | _ |         |
|--------------|----------------|--------|------------|------------|------|---------|-----------|---|---------|
| DSP/Sgt      | PLD Pin #      |        | DSP/Sgt    | PLD Pin #  |      | DSP/Sgt | PLD Pin # |   | DSP/Sgt |
| 1/A          | 47             |        | 3/A        | 67         |      | 5/A     | 96        |   | 7/A     |
| 1/B          | 52             |        | 3/B        | 64         |      | 5/B     | 93        |   | 7/B     |
| 1/C          | 48             |        | 3/C        | 63         |      | 5/C     | 94        |   | 7/C     |
| 1/D          | 46             |        | 3/D        | 65         |      | 5/D     | 97        |   | 7/D     |
| 1/E          | 44             |        | 3/E        | 68         |      | 5/E     | 99        |   | 7/E     |
| 1/F          | 45             |        | 3/F        | 69         |      | 5/F     | 98        |   | 7/F     |
| 1/G          | 42             |        | 3/G        | 71         |      | 5/G     | 100       |   | 7/G     |
| 1/DOT        | 49             |        | 3/DOT      | 61         |      | 5/DOT   | 92        |   | 7/DOT   |
| 2/A          | 54             |        | 4/A        | 80         |      | 6/A     | 12        |   | 8/A     |
| 2/B          | 41             |        | 4/B        | 76         |      | 6/B     | 9         |   | 8/B     |
| 2/C          | 40             |        | 4/C        | 78         |      | 6/C     | 8         |   | 8/C     |
| 2/D          | 56             |        | 4/D        | 84         |      | 6/D     | 10        |   | 8/D     |
| 2/E          | 58             |        | 4/E        | 81         |      | 6/E     | 13        |   | 8/E     |
| 2/F          | 57             |        | 4/F        | 83         |      | 6/F     | 14        |   | 8/F     |
| 2/G          | 60             |        | 4/G        | 85         |      | 6/G     | 16        |   | 8/G     |
| 2/DOT        | 55             |        | 4/DOT      | 75         |      | 6/DOT   | 6         |   | 8/DOT   |
|              |                |        |            |            |      |         |           |   |         |



CPLD Development/Programmer Kit User Guide

2-4

| DSP/Sgt | PLD Pin # |
|---------|-----------|
| 1/A     | 48        |
| 1/B     | 50        |
| 1/C     | 49        |
| 1/D     | 47        |
| 1/E     | 44        |
| 1/F     | 46        |
| 1/G     | 43        |
| 1/DOT   | 51        |
| 2/A     | 56        |
| 2/B     | 54        |
| 2/C     | 42        |
| 2/D     | 58        |
| 2/E     | 60        |
| 2/F     | 59        |
| 2/G     | 62        |
| 2/DOT   | 52        |

| Table 2-6. | Connections   | of LEDs to | ATF15xx | 100-lead | POFF |
|------------|---------------|------------|---------|----------|------|
|            | 0011100110110 |            |         | 100 1000 |      |

| DSP/Sgt | PLD Pin # |
|---------|-----------|
| 3/A     | 69        |
| 3/B     | 66        |
| 3/C     | 65        |
| 3/D     | 67        |
| 3/E     | 70        |
| 3/F     | 71        |
| 3/G     | 73        |
| 3/DOT   | 63        |
| 4/A     | 82        |
| 4/B     | 78        |
| 4/C     | 81        |
| 4/D     | 86        |
| 4/E     | 83        |
| 4/F     | 85        |
| 4/G     | 87        |
| 4/DOT   | 77        |

| DSP/Sgt | PLD Pin # |
|---------|-----------|
| 5/A     | 98        |
| 5/B     | 95        |
| 5/C     | 96        |
| 5/D     | 99        |
| 5/E     | 3         |
| 5/F     | 100       |
| 5/G     | 4         |
| 5/DOT   | 94        |
| 6/A     | 14        |
| 6/B     | 11        |
| 6/C     | 10        |
| 6/D     | 12        |
| 6/E     | 15        |
| 6/F     | 16        |
| 6/G     | 18        |
| 6/DOT   | 8         |

| D0D/0 1 | DI D D: # |
|---------|-----------|
| DSP/Sgt | PLD Pin # |
| 7/A     | 22        |
| 7/B     | 19        |
| 7/C     | 21        |
| 7/D     | 23        |
| 7/E     | 27        |
| 7/F     | 25        |
| 7/G     | 39        |
| 7/DOT   | 24        |
| 8/A     | 37        |
| 8/B     | 38        |
| 8/C     | 35        |
| 8/D     | 33        |
| 8/E     | 31        |
| 8/F     | 34        |
| 8/G     | 32        |
| 8/DOT   | 30        |

Table 2-7. Connections of LEDs to ATF15xx 144-lead TQFP

|         |           | <br>    | ot i i i ioda |   |         |           |   |  |
|---------|-----------|---------|---------------|---|---------|-----------|---|--|
| OSP/Sgt | PLD Pin # | DSP/Sgt | PLD Pin #     |   | DSP/Sgt | PLD Pin # |   |  |
| 1/A     | 79        | 3/A     | 100           |   | 5/A     | 134       |   |  |
| 1/B     | 78        | 3/B     | 98            | _ | 5/B     | 137       |   |  |
| 1/C     | 74        | 3/C     | 99            |   | 5/C     | 136       |   |  |
| 1/D     | 80        | 3/D     | 101           | - | 5/D     | 133       |   |  |
| 1/E     | 82        | 3/E     | 106           |   | 5/E     | 138       |   |  |
| 1/F     | 81        | 3/F     | 102           |   | 5/F     | 132       |   |  |
| 1/G     | 83        | 3/G     | 107           |   | 5/G     | 131       |   |  |
| 1/DOT   | 77        | 3/DOT   | 97            |   | 5/DOT   | 139       |   |  |
| 2/A     | 88        | 4/A     | 118           |   | 6/A     | 9         |   |  |
| 2/B     | 86        | 4/B     | 119           | _ | 6/B     | 7         |   |  |
| 2/C     | 87        | 4/C     | 117           |   | 6/C     | 6         |   |  |
| 2/D     | 91        | 4/D     | 114           |   | 6/D     | 8         |   |  |
| 2/E     | 93        | 4/E     | 112           |   | 6/E     | 10        |   |  |
| 2/F     | 92        | 4/F     | 116           | ] | 6/F     | 11        | ] |  |
| 2/G     | 94        | 4/G     | 113           |   | 6/G     | 15        |   |  |
| 2/DOT   | 84        | 4/DOT   | 111           | ] | 6/DOT   | 5         |   |  |





PLD Pin #



3300A-PLD-08/02

| DSP/Sgt | PLD Pin # | DSP/Sgt | PLD Pin # |
|---------|-----------|---------|-----------|
| 1/A     | 91        | 3/A     | 102       |
| 1/B     | 89        | 3/B     | 100       |
| 1/C     | 90        | 3/C     | 98        |
| 1/D     | 80        | 3/D     | 101       |
| 1/E     | 73        | 3/E     | 103       |
| 1/F     | 78        | 3/F     | 105       |
| 1/G     | 72        | 3/G     | 106       |
| 1/DOT   | 88        | 3/DOT   | 97        |
| 2/A     | 69        | 4/A     | 110       |
| 2/B     | 71        | 4/B     | 108       |
| 2/C     | 68        | 4/C     | 109       |
| 2/D     | 92        | 4/D     | 123       |
| 2/E     | 94        | 4/E     | 111       |
| 2/F     | 93        | 4/F     | 121       |
| 2/G     | 96        | 4/G     | 122       |
| 2/DOT   | 70        | 4/DOT   | 107       |

### Table 2-8. Connections of LEDs to ATF15xx 160-lead PQFP

| DSP/Sgt | PLD Pin # |
|---------|-----------|
| 5/A     | 11        |
| 5/B     | 159       |
| 5/C     | 160       |
| 5/D     | 10        |
| 5/E     | 12        |
| 5/F     | 13        |
| 5/G     | 14        |
| 5/DOT   | 158       |
| 6/A     | 20        |
| 6/B     | 18        |
| 6/C     | 16        |
| 6/D     | 19        |
| 6/E     | 21        |
| 6/F     | 23        |
| 6/G     | 24        |
| 6/DOT   | 15        |

| DSP/Sgt | PLD Pin # |
|---------|-----------|
| 7/A     | 29        |
| 7/B     | 27        |
| 7/C     | 28        |
| 7/D     | 52        |
| 7/E     | 50        |
| 7/F     | 53        |
| 7/G     | 51        |
| 7/DOT   | 25        |
| 8/A     | 43        |
| 8/B     | 49        |
| 8/C     | 30        |
| 8/D     | 31        |
| 8/E     | 32        |
| 8/F     | 41        |
| 8/G     | 33        |
| 8/DOT   | 48        |

#### 2.1.2 Push-button Switches

Two push-button switches are provided to allow the user to control the logic states of the OE1 and GCLR inputs of the ATF15xx. These two switches are labeled GOE and GCLR on the board. The GCLR push-button switch is a momentary Single-Pole Single-Throw (SPST) normally open switch while the GOE push-button switch is a snap-acting momentary SPST normally open switch. As shown in the CPLD Development/Programmer Board schematic in Figure 4-1, these two switches are normally open and the GCLR and GOE signals are pulled-up to  $V_{CC}$  when they are not depressed. When the switches are depressed, the GCLR and GOE signals are connected to GND.

The output of the GCLR switch is connected to the GCLR dedicated input pin of the ATF15xx, and it is intended to be used as an active-low reset signal to reset the registers in the ATF15xx. The output of the GOE switch is connected to the OE1 dedicated input pin of the ATF15xx. It is intended to be used as an active-high or active-low output enable signal to control the enabling/disabling of the tri-state output buffers in the ATF15xx. However, these two switches can also be used to generate general logic input signals to the GCLR and OE1 input pins of the ATF15xx.

2.1.3 Clock Select Jumper The Clock Select Jumper, labeled JPCLK, on the CPLD Development/Programmer Board is a two-position jumper that allows the user to select which GCLK dedicated input pin (either GCLK1 or GCLK2) of the ATF15xx should be connected to the output of the 2 MHz crystal oscillator. In addition, the jumper can be removed to allow an external clock source to be connected to GCLK1 and/or GCLK2 of the ATF15xx.

Table 2-9 shows the pin numbers for the GCLR, OE1, GCLK1 and GCLK2 dedicated input pins of the ATF15xx in all the available package types.



**CPLD Development/Programmer Kit User Guide** 

| Signal | 44-lead<br>TQFP | 44-lead<br>PLCC | 68-lead<br>PLCC | 84-lead<br>PLCC | 100-lead<br>PQFP | 100-lead<br>TQFP | 144-lead<br>TQFP | 160-lead<br>PQFP |
|--------|-----------------|-----------------|-----------------|-----------------|------------------|------------------|------------------|------------------|
| GCLR   | 39              | 1               | 1               | 1               | 91               | 89               | 127              | 141              |
| OE1    | 38              | 44              | 68              | 84              | 90               | 88               | 126              | 140              |
| GCLK1  | 37              | 43              | 67              | 83              | 89               | 87               | 125              | 139              |
| GCLK2  | 40              | 2               | 2               | 2               | 92               | 90               | 128              | 142              |

#### Table 2-9. Pin Numbers of GCLR, OE1, GCLK1 and GCLK2

2.1.4 V<sub>cc</sub> Select Jumper The V<sub>cc</sub> Select Jumper, labeled VCC Select, on the CPLD Development/Programmer Board is a two-position jumper that allows the users to select the V<sub>cc</sub> voltage level (either 3.3V or 5.0V) used by various components on the CPLD Development/Programmer Board. This voltage generated by the on-board voltage regulation circuitry is applied to the V<sub>cc</sub> input pins (both VccINT and VccIO) of the ATF15xx, the common anode lines of the eight 8-segment LEDs, the V<sub>cc</sub> input of the 2 MHz crystal oscillator, the two push-button switches, and the V<sub>cc</sub> pin (Pin 4) of the 10-pin JTAG port header labeled JTAG.

Therefore, when a 3.3V device (ATF15xxASV/ASVL/AE/AEL) is used on this board, the V<sub>CC</sub> Select Jumper must be in the 3.3V position. On the other hand, when a 5V device (ATF15xxAS/ASL/SE/SEL) is used on this board, the V<sub>CC</sub> Select Jumper must be in the 5.0V position. This is also true when the ATF15xx is being programmed through ISP on this board.

#### 2.1.5 JTAG Port Header The JTAG Port Header, labeled JTAG, on the CPLD Development/Programmer Board is used to connect the ATF15xx's JTAG port pins (TCK, TDI, TMS and TDO) through the ISP download cable to the parallel printer (LPT) port of a PC for ISP programming of the ATF15xx. Table 2-10 shows the pin numbers for the four JTAG port pins of the ATF15xx in all the available package types.

| Signal | 44-lead<br>TQFP | 44-lead<br>PLCC | 68-lead<br>PLCC | 84-lead<br>PLCC | 100-lead<br>PQFP | 100-lead<br>TQFP | 144-lead<br>TQFP | 160-lead<br>PQFP |
|--------|-----------------|-----------------|-----------------|-----------------|------------------|------------------|------------------|------------------|
| TDI    | 1               | 7               | 12              | 14              | 6                | 4                | 4                | 9                |
| TDO    | 32              | 38              | 57              | 71              | 75               | 73               | 104              | 112              |
| TMS    | 7               | 13              | 19              | 23              | 17               | 15               | 20               | 22               |
| тск    | 26              | 32              | 50              | 62              | 64               | 62               | 89               | 99               |

Table 2-10. Pin Numbers of JTAG Port Signals

The ISP algorithm is controlled by the ATMISP software, which runs on the PC. The four JTAG signals are generated by the LPT port and they are buffered by the ISP download cable before going into the ATF15xx on the CPLD Development/Programmer Board. The pinout for the 10-pin JTAG Port Header on the CPLD Development/Programmer Board is shown in Figure 2-3 and the dimensions of this 10-pin male JTAG header are shown in Figure 2-4.

CPLD Development/Programmer Kit User Guide



Figure 2-3. Pinout Diagram of 10-pin JTAG Port Header (Top-view)

|   |                       | 1                                |
|---|-----------------------|----------------------------------|
| 1 | 2                     | GND                              |
| 3 | 4                     | vcc                              |
| 5 | 6                     | NC                               |
| 7 | 8                     | NC                               |
| 9 | 10                    | GND                              |
|   | 1<br>3<br>5<br>7<br>9 | 1 2<br>3 4<br>5 6<br>7 8<br>9 10 |





The pinout of this 10-pin JTAG Port Header is compatible with the Altera<sup>®</sup> ByteBlaster<sup>™</sup> and ByteBlasterMV<sup>™</sup> cables. In addition, the ATMISP software allows users to choose either the Atmel CPLD ISP Cable or the ByteBlaster/ByteBlasterMV cable to implement ISP.

2.1.6 Power Connectors The Atmel CPLD Development/Programmer Board contains two different types of power connectors, and either one can be used to connect to a 9V DC power source to power the board. The first power connector, labeled JPower, is a barrel power jack with a 2.1 mm diameter post and it mates to a 2.1 mm (inner diameter) x 5.5 mm (outer diameter) female plug. The second power connector, labeled JP Power, is a 4-pin male 0.1" header with 0.025" square posts. The availability of these two types of power connectors allows the users to choose the type of power supply equipment to use for the CPLD Development/Programmer Board.



2-8

| 2.2   | Socket Adapter<br>Board     | Atmel CPLD Development/Programmer Socket Adapter Boards are circuit boards that interface with the Atmel CPLD Development/Programmer Board. They are used in conjunction with the CPLD Development/Programmer Board to evaluate/program Atmel ISP CPLDs in different package types. Currently, there are nine Socket Adapter Boards available covering all the package types offered in the ATF15xx family of CPLDs. They include 44-lead PLCC, 44-lead TQFP, 68-lead PLCC, 84-lead PLCC, 100-lead TQFP, 100-lead PQFP, 144-lead TQFP and 160-lead PQFP. New Socket Adapter Boards will become available when new packages are offered.        |
|-------|-----------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |                             | Each socket adapter board contains a socket for the Atmel ATF15xx device on the top side and male headers on the bottom side. The headers on the bottom side mate with the female headers, labeled <b>JPLEFT</b> and <b>JPRIGHT</b> , on the CPLD Development/Programmer Board. The eight 8-segment LEDs, push-button switches, JTAG port signals, crystal oscillator, $V_{CC}$ , and GND on the CPLD Development/Programmer Board are connected to the ATF15xx device on the Socket Adapter Board through these two rows of connectors.                                                                                                       |
| 2.2.1 | Expansion Terminal<br>Holes | Rows of expansion terminal holes suitable for 0.1" headers with 0.025" square posts are available on each of the Socket Adapter Boards to allow users to interface the ATF15xx to an external circuit board. All input and I/O pins except the four JTAG port pins of the ATF15xx are routed to these expansion terminal holes, and the corresponding pin numbers are marked next to the terminal holes. Please refer to the Socket Adapter Board schematics in Section 4 for the pinouts of the expansion terminal holes.                                                                                                                     |
|       |                             | On the bottom side of the Socket Adapter Boards, traces connecting the pairs of expan-<br>sion terminal holes can be cut to isolate the LEDs, push-button switches and crystal<br>oscillator from the ATF15xx on the Socket Adapter Board. This allows the users to gain<br>complete control and access to all input and I/O pins of the ATF15xx.                                                                                                                                                                                                                                                                                              |
| 2.3   | Atmel CPLD ISP<br>Cable     | The Atmel CPLD ISP Cable connects the parallel printer (LPT) port of the user's PC to the 10-pin JTAG header on the Atmel CPLD Development/Programmer Board or a custom circuit board. This is shown in Figure 2-5. This ISP cable acts as a buffer to buffer the JTAG signals between the PC's LPT port and the ATF15xx on the circuit board. The circuit schematic of the Atmel CPLD ISP Cable is shown in Figure 4-10 and Figure 4-11. The Power-On LED on the back of the 25-pin male connector housing indicates that the cable is connected properly. Make sure this LED is turned on before using the Atmel CPLD ISP Software (ATMISP). |
|       |                             | This ISP cable consists of a 25-pin (DB25) male connector, which is connected to the LPT port of a PC. The 10-pin female plug connects to the 10-pin male JTAG header on the ISP circuit board. The red color stripe on the ribbon cable indicates the orientation of Pin 1 of the female plug. The 10-pin male JTAG header on the CPLD Development/Programmer Board is polarized to prevent users from inserting the female plug in the wrong orientation.                                                                                                                                                                                    |
|       |                             | If the user is attempting to program low voltage (3.3V) devices, the user needs to use Rev. 4 or later of the Atmel CPLD ISP Cable. This and later revisions will support both the 3.3V and 5V ATF15xx ISP CPLDs. Earlier revisions of the cable only supported 5V devices.                                                                                                                                                                                                                                                                                                                                                                    |
|       |                             | When programming 3.3V devices, the $V_{CC}$ supplied to the ISP cable should also be 3.3V. Similarly, the $V_{CC}$ supplied to the ISP cable should be 5.0V when programming 5V devices.                                                                                                                                                                                                                                                                                                                                                                                                                                                       |



3300A-PLD-08/02



Figure 2-6 shows the pinout for the 10-pin Female header on the Atmel-ISP Cable. The pinout on the 10-pin male header on the PC board (if used for ISP) must match this pinout.





*Note:* The user's circuit board must supply VCC and GND to the Atmel CPLD ISP Cable through the 10-pin male header (See Figure 2-3).



**CPLD Development/Programmer Kit User Guide** 



# Section 3

## **CPLD Design Flow Tutorial**

**3.1 Overview** This tutorial will guide the user through a complete design cycle for the Atmel ATF15xx CPLD with Logic Doubling architecture. It will go through each phase of the design cycle step-by-step from design entry, logic synthesis, device fitting, in-system programming, and finally verifying the design on the Atmel CPLD Development/Programming Board. *Note:* To complete this tutorial, ProChip Designer V4.0 or later and Atmel-ISP Soft-

ware (ATMISP) V4.0 or later are required.

3.2 Create a Project Using the "New Project Wizard" Before starting the design process, a Project File must be created within ProChip Designer. ProChip Designer's New Project Wizard provides a very easy way to create a new Project File.

1. Click on the **START** .... **PROGRAMS** .... **PROCHIP** Icon to launch ProChip Designer. Or double-click on the **PROCHIP** icon on the desktop.



**CPLD Development/Programmer Kit User Guide** 

3-1

2. Click on **PROJECT** .... **NEW** or double-click on the **NEW PROJECT** shortcut button to launch the New Project Wizard.



3. Click on the **NEXT** button to start the project file creation process.

R

| lew Project Wizard - St | ep 1 of 6 🛛 🕅                                                                                  |                         |
|-------------------------|------------------------------------------------------------------------------------------------|-------------------------|
|                         | Welcome to the New Project wizard                                                              |                         |
| WILL PARTIE             | The New Project wizard will guide you in the creation of your<br>new ProChip Designer project. |                         |
| Bue                     | The steps that follow will include:                                                            |                         |
| Desi                    | 1. Creating a project file                                                                     |                         |
|                         | 2. Selecting the parts for use<br>with your project                                            |                         |
| °C                      | 3. Selecting the software tool sets<br>for use with each part                                  | (3) Click Next to Start |
| ž i                     |                                                                                                |                         |
|                         | Cancel Kesk Next > Finish                                                                      |                         |

- 4. Click on the BROWSE button to open the browser window.
- 5. Use C:\PROCHIP\DESIGNS\CUPL as the directory of the project.
- 6. Enter **DEV\_KIT.APJ** as the project filename. The extension of a project file must be .**APJ**.
- *Note:* The name and directory of the design project is specified in this window. All design, simulation and other project files must be placed in this project directory.





CPLD Development/Programmer Kit User Guide

## www.BDTIC.com/ATMEL

3300A-PLD-08/02

7. Choose **[ATF1508AS-10JC84]** as the target device type for the project. Also review the *Filters* that allow for selection of a specific *Speed Grade* or *Package Type*.



8. Select CUPL - ALTIUM as the software tool for this design flow.



With ProChip Designer V4.0 and later, the five possible design flows and their corresponding design entry types supported are listed in the table below:

| Design Flow                        | Design Entry Type                                                                 |
|------------------------------------|-----------------------------------------------------------------------------------|
| CUPL – Altium <sup>™</sup>         | CUPL design entry through Altium Protel <sup>™</sup> 99SE                         |
| Verilog – Exemplar <sup>™(1)</sup> | Verilog <sup>®</sup> design entry through Exemplar Leonardo Spectrum <sup>™</sup> |
| VHDL – Altium                      | VHDL design entry through the Altium PeakFPGA                                     |
| VHDL – Exemplar <sup>(1)</sup>     | VHDL design entry through Exemplar Leonardo Spectrum                              |
| Schematic – Altium                 | Schematic design entry through Altium Protel 99SE                                 |

Note: 1. Design flow require Mentor Graphics<sup>®</sup> Leonardo Spectrum software with Atmel CPLD support.



9. Select **DONE WITH PARTS** so that there will be only one device in this project.

On the other hand, users can select **ADD MORE PARTS** to include more parts to the current Project Directory.



10. Click the **FINISH** button to finish the New Project Wizard and the project creation process.

This closes the *New Project Wizard* and opens the *ProChip Designer* window. The *Sources* in the project are shown in the Left window.

| VA BOOM   | Congratulations!                                                                                                                                                                                             |                                                |
|-----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------|
|           | You have successfully completed the creation of your new<br>ProChip Designer project.                                                                                                                        |                                                |
| gne       | project tree shows the tools and design files included in your<br>project. Using the vertical toolbar on the side of the tree you can add or<br>delete parts, modify toolflows, or include new design files. |                                                |
| Chip Desi | To begin, click on a part in the project tree. This will display the design<br>flow in the part window. Then, click on any button in the design flow to<br>run the associated design tool.                   |                                                |
| ProG      | To close the New Project wizard and begin working with your<br>project, click the Finish' button.                                                                                                            |                                                |
|           | Cancel KBack                                                                                                                                                                                                 | (10) Click Finish to End<br>New Project Wizard |



CPLD Development/Programmer Kit User Guide

11. Click on the **Device Icon [ATF1508AS-10JC84]** to view the *Design Flow* window.



**CPLD Development/Programmer Kit User Guide** 



3-5

### 3.3 Add a Design Ond File user

Once the Project File is created, the next step is to add the design source file(s) into the user's project. For this tutorial, a single CUPL design file will be added into the project.

- Click on the ADD/EDIT button from Source Manager to open the Source Manager Window. The user can view the Source Manager Help File by clicking on the Help button within the Source Manager Window to view the description for the different processes.
- 2. In the *Source Manager Window*, click on the **ADD** button to add a CUPL design file to the project.
- 3. In the *File Manager Window*, select **LOGIC\_D8.PLD** from the *C:\PROCHIP\DESIGNS\CUPL* directory as the source design file for this project.



This "LOGIC\_D8.PLD" is a CUPL design that uses the eight 8-segment LED displays and the 2 MHz oscillator on the Atmel CPLD Development/Programmer Board to generate a scrolling message that displays the words "logic doubling" on the LEDs. The GOE push-button switch is used to control the direction that the message scrolls in (left or right). The GCLR push-button switch is used to reset the counter registers. When the GCLR push-button switch is depressed, the message will stop scrolling. This CUPL design can be compiled using either the ProChip Designer or the Atmel-WinCUPL software.

The first section of the LOGIC\_D8.PLD as shown below pre-defines which segments of the LED should be asserted in order to display the desired letter or number. For example, to display the upper case letter "C", segments A, D, E, and F need to be set to low (active low) and the remaining segments need to be set to high.

| \$define | Font0      | 'b'1000000 | /* = ( _f_e_d_c_b_a ); | 0 */ |
|----------|------------|------------|------------------------|------|
| \$define | Font1      | 'b'1111001 | /* = ( _c_b );         | 1 */ |
| \$define | :<br>FontA | 'b'0001000 | /* = (_g_f_e _c_b_a ); | A */ |



CPLD Development/Programmer Kit User Guide

3300A-PLD-08/02

#### **CPLD Design Flow Tutorial**

The next section of this CPLD design as shown below illustrates how to declare and assign pin numbers in the CUPL language to the input and output signals. The input and output pin assignments are assigned according to the connections between the CPLD and the eight 8-segment LED's as shown in the connection tables (Table 2-1 to Table 2-8) in Section 2.

```
/* Inputs */
pin 1 = GCLR; /* Global Clear input */
pin 83 = MCLK; /* Global Clock input */
pin 84 = GOE; /* GOE1 button used as direction control */
/* Outputs */
/* DSP1 */
pin 49 = LED1A;
                     /* LED1 segment A */
pin 46 = LED1B;
pin 48 = LED1C;
                       /* LED1 segment B */
                       /* LED1 segment C */
pin 50 = LED1D;
                       /* LED1 segment D */
pin 52 = LED1E;
                       /* LED1 segment E */
pin 51 = LED1F;
                       /* LED1 segment F */
                       /* LED1 segment G */
pin 54 = LED1G;
```

Next, the buried signals for the counter and state machine are declared as PINNODE's as shown below. The feedback and/or the foldback paths available in each macrocell implement these buried signals. For the listing of the pinnode numbers, please refer to the "ATF15xx Device Help" section of the ProChip Designer Help File.

```
pinnode [618,634,650,687]= [CA20..CA17];
pinnode = [CA16..CA0];
pinnode = [SM7..SM0];
```

After assigning the input, output and buried signals, the related signals (i.e. the LED segments and buried counter) are grouped together as shown below to make the design source code more readable and manageable. In CUPL, the "Field" declaration can be used to group a specific set of signals.

Next, a 21-bit buried up-counter implemented using D-type Flip-flops is shown below and it is used to divide the 2.0 MHz clock into a 0.954 Hz (2 MHz  $\div 2^{21} = 0.954$  Hz) signal that can be used to display the text messages. The last bit of this counter is used as the clock for the state machine that controls the display sequence of the messages on the LEDs.

```
CA0.d = !CA0;
CA1.d = CA0 $ CA1;
:
CA7.d = (CA6 & CA5 & CA4 & CA3 & CA2 & CA1 & CA0) $ CA7;
:
CNT_A.ck = MCLK;
CNT_A.ar = !GCLR;
```



The next section of this PLD design is a state machine with 15 states to control the display sequence of the text messages on the LEDs. The GOE push-button switch on the CPLD Development/Programmer Board controls the flow of this state machine. When this switch is in the "up" position, the state machine will go from RESET to State-0 to State-1 to State-2 and so on until it reaches State-14 and then it will go back to State-0. On the other hand, if the GOE switch is in the "down" position, the state machine will go in the opposite direction (i.e. State-14 to State13 .. etc).

Finally, the last section of the PLD design will assign the appropriate letters or numbers to the eight 8-segment LEDs to be displayed during the different states of the state machine. The user can easily change the letters/numbers to be displayed by changing this section of the code to the appropriate pre-defined letters/numbers.

| LED1 = |   | FontBK | &  | SM:[RESET] |
|--------|---|--------|----|------------|
|        | # | FontBK | δc | SM:[S0]    |
|        | # | FontLl | &  | SM:[S1]    |
|        | # | FontLo | &  | SM:[S2]    |
|        | # | FontLg | &  | SM:[S3]    |
|        | # | FontLi | &  | SM:[S4]    |
|        | # | FontLc | δ. | SM:[S5]    |
|        | # | FontBK | &  | SM:[S6]    |
|        | # | FontLd | δ. | SM:[S7]    |
|        | # | FontLo | δc | SM:[S8]    |
|        | # | FontLu | δc | SM:[S9]    |
|        | # | FontLb | &  | SM:[S10]   |
|        | # | FontLl | &  | SM:[S11]   |
|        | # | FontLi | &  | SM:[S12]   |
|        | # | FontLn | &  | SM:[S13]   |
|        | # | FontLg | &  | SM:[S14];  |



CPLD Development/Programmer Kit User Guide

3300A-PLD-08/02

### 3.4 Compile the CUPL Design

In this part of the tutorial, the CUPL design will be compiled through the Logic Synthesis process into a set of optimized/minimized logic equations.

1. Click on the **CUPL – Design Ex**. button in the Design Flow Window to open the Logic Synthesis Window.



- 2. Make sure all of the options in the Optimization section are unchecked.
- 3. Make sure the *Minimization* setting is set to **Quick**.
- 4. Click on the **Compile** button to start the CUPL compile process.



The user can click on the **Set Defaults** button and it will automatically specify the Synthesis tool in the Tool Text box.

If the user clicks on the CUPL Tab, it shows the various Synthesis options. Please refer to the HELP file for further description.



3-9

### 3.5 Fit the Synthesized Design File

In Section 3.4, the Logic Synthesis portion of the CPLD Design Flow was completed. On successful compilation, the CUPL compiler tool produces a PLA output file (with extension .pla). A PLA file contains the netlist of the optimized and minimized logic equations. It is now necessary to map this netlist into a specific Atmel PLD architecture using the **Atmel Fitter**.

1. The user can now proceed to the Device Fitter portion of the Design Flow by clicking on the **Atmel Fitter** button.



The user can either use the Default options or specify Fitter properties. ProChip Designer will automatically select the PLA file associated to the current design project and the tool type. In this example, since the target device is an ATF1508AS, the fit1508.exe device fitter will be selected.

The fitter creates the important JEDEC and FIT REPORT output files. They contain the data for programming the Device (using In-System Programming or on a third party device programmer) and the pin assignments required for board layout respectively.

Please review the Global Device Parameters and Pin/Node Options as well. The Help Files also show the Device Pin\_Node lists for each of the ATMEL CPLDs.

- 2. Make sure the **JTAG** box is checked. This enables the JTAG port for ISP programming.
- 3. Make sure the *PIN FIT CONTROL* setting is set to **Keep**. This will ensure that the pin assignments in the PLD file will be kept during the Place-and-Route process.
- 4. When all the fitter options are set, click on the **Run Fitter** button to fit the design.





**CPLD Development/Programmer Kit User Guide** 

The Fitter Report (.FIT) File generated for this design is shown below.

| Logic Array Block<br>Cascades                                                                                                                     | Logic C            | ells                                                   | I/O Pins                                             | Foldbacks | TotalPT    | FanIN |   |
|---------------------------------------------------------------------------------------------------------------------------------------------------|--------------------|--------------------------------------------------------|------------------------------------------------------|-----------|------------|-------|---|
| A: LC1 - LC16                                                                                                                                     | 16/16(1            | 00%)                                                   | 8/16(50%)                                            | 5/16(31%) | 46/80(57%) | (19)  | 0 |
| B: LC17 - LC32                                                                                                                                    | 16/16(1            | 00%)                                                   | 8/16(50%)                                            | 3/16(18%) | 51/80(63%) | (38)  | 0 |
| C: LC33 - LC48                                                                                                                                    | 16/16(1            | 00%)                                                   | 8/16(50%)                                            | 2/16(12%) | 48/80(60%) | (38)  | 0 |
| D: LC49 - LC64                                                                                                                                    | 16/16(1            | 00%)                                                   | 6/16(37%)                                            | 2/16(12%) | 40/80(50%) | (38)  | 0 |
| E: LC65 - LC80                                                                                                                                    | 16/16(1            | 00%)                                                   | 6/16(37%)                                            | 6/16(37%) | 55/80(68%) | (32)  | 0 |
| F: LC81 - LC96                                                                                                                                    | 16/16(1            | 00%)                                                   | 8/16(50%)                                            | 2/16(12%) | 47/80(58%) | (38)  | 0 |
| G: LC97 - LC112                                                                                                                                   | 16/16(1            | 00%)                                                   | 8/16(50%)                                            | 3/16(18%) | 43/80(53%) | (25)  | 0 |
| H: LC113- LC128                                                                                                                                   | 16/16(1            | 00%)                                                   | 8/16(50%)                                            | 2/16(12%) | 42/80(52%) | (34)  | 0 |
| Total dedicated input<br>Total I/O pins used<br>Total Logic cells used<br>Total Flip-Flop used<br>Total Foldback logic u<br>Total Nodes+FB/MCells | used:<br>1<br>1sed | 3/4<br>60/64<br>128/128<br>31/128<br>25/128<br>153/128 | (75%)<br>(93%)<br>(100%)<br>(24%)<br>(19%)<br>(119%) |           |            |       |   |
| Total cascade used                                                                                                                                |                    | 0                                                      |                                                      |           |            |       |   |
| Total input pins                                                                                                                                  |                    | 7                                                      |                                                      |           |            |       |   |
| Total output pins                                                                                                                                 |                    | 20                                                     |                                                      |           |            |       |   |
| iolai ris                                                                                                                                         |                    | 514                                                    |                                                      |           |            |       |   |

The ATF15xx Family devices Logic Doubling features provide extra I/O connectivity and logic reusability. Some of the Logic Doubling features available in the ATF15xx family of CPLDs are:

- Bury either Register or Combinatorial signal while using the other for output
- Dual independent feedback allows multiple latch functions per macrocell
- 5 product terms per macrocell, expandable to 40 per macrocell with cascade logic, plus 15 more with foldback logic
- D/T/Latch configurable flip-flops plus transparent latches
- Global and/or per macrocell Output Enable
- Single level Switch Matrix
- Up to 40 inputs per Logic Block

In the LOGIC\_D8.PLD example given in this tutorial, Logic Blocks B, C D, and F have 37 or more signal inputs (Fan-In's) as shown in the Universal-Interconnect-Multiplexer assignments section of the .FIT file. The availability of wide Fan-In's to the Logic Blocks is one of the many Logic Doubling features. This feature improves the possibility of routing all the necessary signals from the Global Bus to the Logic Blocks.

In addition, macrocells 37 and 59 of the ATF1508 are able to implement both combinatorial outputs (LED1G and LED8D) and buried registered signals (CA0 and RST) within the same macrocells. This is shown in the Resource Usage section of the .FIT file.

For more examples of design techniques that utilize the Logic Doubling features of the ATF15xx Family, refer to Atmel's Logic Doubling White Paper and Reference Designs available on the Atmel website. These examples show how to apply Logic Doubling techniques to new product designs, to obtain the benefits of more features in a smaller and possibly less expensive chip, or spare logic resources for future revisions and reduce the risk of PCB re-spin.



### 3.6 Program and Verify Design

In this step of the tutorial, the user will program an ATF1508AS 84-pin PLCC device on the Atmel CPLD Development/Programmer Board through ISP and then verify the design by observing the text messages displayed on the eight 8-segment LED displays of the CPLD Development/Programmer Board.

The user will need to follow the steps below to setup the ATMISP software in order to program the ATF1508AS 84-pin PLCC on the CPLD Development/Programmer Board.

1. To create a new chain file, the **ATMISP Software** first needs to be launched either through the **PROGRAM CHIP** button in the ProChip Designer window, the ATMISP desktop icon or the *Start ... Programs .. Atmel ISP* menu.



If ATMISP is launched through ProChip Designer, steps 2 to 6 below can be skipped since ProChip Designer will automatically setup the appropriate chain file for the ISP operation.

2. To create a new chain file, select the **New** command under the **File** menu or click on the **New Shortcut Button**.



3. The first piece of information that the software asks for when creating a new chain is the number of devices in the JTAG chain. Therefore, enter **1** and then click **OK** since a 1-device JTAG chain will be programmed.



- 4. Next the user will need to specify the properties of each JTAG device in the Device Properties window. First, select the target device type of the first device in the JTAG chain. For this tutorial, please select **ATF1508AS** as the target device type.
- 5. In the JTAG Instruction field, the user can specify the appropriate JTAG instruction to be executed on this device in the chain. Please select **Program/Verify** to program and verify the ATF1508AS.



CPLD Development/Programmer Kit User Guide

 The next step is to specify the JEDEC file to be programmed into the target device in the JEDEC File field. Click on the Browse button, change the directory to [..\PROCHIP\DESIGNS\CUPL"] and then select LOGIC\_D8.JED as the target JEDEC file. Click OK to close the JTAG Device Properties window when all properties are specified.



The next few steps require the user to setup the Atmel CPLD Development/Programmer Board to program the ATF1508AS through ISP.

- Connect the 25-DB side of the Atmel-ISP Cable to the PC's parallel port and the 10-pin header side of the Atmel-ISP Cable to the Atmel CPLD Development Board as shown Figure 2-5.
- 8. Connect a **9V** AC/DC power adapter to the power connector (JPower) of the Atmel CPLD Development/Programmer Board.
- 9. Set the 5V/3.3V jumper to 5V. This will set the system board  $V_{CC}$  to 5V.
- 10. Set the JPCLK jumper to **GCLK1** so that the output of the crystal oscillator will be connected to Pin 83 of the ATF1508AS.
- 11. Connect the 84-pin PLCC Socket Adapter Board onto the main Development/Programmer Board.
- Note: If a device in a different package type is to be programmed, then the appropriate Socket Adapter Board must be used.
- 12. Switch the Power Switch to the ON position.
- 13. Select the appropriate LPT port in the *Port Setting* field. LPT 1 is the default port.
- 14. Select the **ISP** download cable type in the *Cable Types* field. The default cable type is the Atmel ISP Cable but it can be changed to the Altera ByteBlaster cable if the ByteBlaster cable is being used.

Now both the user's software and hardware are setup for ISP programming, and the user can execute the **PROGRAM/VERIFY** instruction to program the ATF1508AS on the Atmel CPLD Development/Programmer Board.



 Click on the **Run** button in the ATMISP main window to execute the JTAG instruction to program the ATF1508AS on the CPLD Development/Programmer Board.



After successfully programming the ATF1508AS with the LOGIC\_D8.JED file, the eight 8-segment LED's will display the words "Logic Doubling".

If these two text messages are correctly displayed on the CPLD Development/Programmer Board, then the user has successfully completed this tutorial.



CPLD Development/Programmer Kit User Guide



**Section 4** 

# **Schematic Diagrams**

**CPLD Development/Programmer Kit User Guide** 

4-1

#### Schematic Diagrams





CPLD Development/Programmer Kit User Guide

4-2



Schematic Diagram of 44-pin PLCC Socket Adapter Board Figure 4-2.

## www.BDTIC.com/ATMEL

4-3

CPLD Development/Programmer Kit User Guide



Schematic Diagram of 44-pin TQFP Socket Adapter Board Figure 4-3.



## www.BDTIC.com/ATMEL

4-4

CPLD Development/Programmer Kit User Guide

4-5



Schematic Diagram of 68-pin PLCC Socket Adapter Board Figure 4-4.





www.BDTIC.com/ATMEL

3300A--PLD--08/02

4-6



Schematic Diagram of 100-pin PQFP Socket Adapter Board

Figure 4-6.



AIMEL

Schematic Diagrams



4-8







4-9

Figure 4-9. Schematic Diagram of 160-pin PQFP Socket Adapter Board



**CPLD Development/Programmer Kit User Guide** 

4-10



GNI

**4-11** 3300A-PLD-08/02



4-12





# www.BDTIC.com/ATMEL

Schematic Diagrams

Figure 4-11. Schematic Diagram of Atmel CPLD ISP Cable, Continued