## Introduce to

# Field Programmable Logic Device

Ref: 1. Michael Shyu, VLSI system lab, NCTU

- 2. Lattice datasheets
- 3. Xilinx datasheets

## Digital System Implementation

- Full Custom
- Semi-custom
  - Gate array
  - Standard cells
- Programmable Logic Device
  - Programmable read only memory (PROM)
  - Field programmable logic array (FPLA)
  - Programmable array logic (PAL)

## Structure of Programmable Logic Device



# Programmable Logic Notation

## A four-input AND gate





Fusible input connections to the AND gate



Notation.

# Programmable Logic Notation



Product line implements ACD

## Programmable Logic Notation



Portion of the programmable logic array programmed to implement  $f(A,B,C,D) = \overline{A}BC\overline{D} + A\overline{B}\overline{C}D$ 



Function is specified by the user after the device is manufactured.

FPLD families

SPLD (Simple Programmable Logic Device)

CPLD (Complex Programmable Logic Device)

: Xilinx XC9500

FPGA (Field Programmable Gate Arrays)

: Xilinx XC3000, VirtexE, VirtexII





ispGAL22V10 OUTPUT LOGIC MACROCELL (OLMC)

### Registered Mode



#### **Combinatorial Mode**



#### ispGAL22V10 Logic Diagram/JEDEC Fuse Map

#### PLCC & SSOP Package Pinout



| PARAMETER    | TEST<br>COND.1 | DESCRIPTION                                 |
|--------------|----------------|---------------------------------------------|
| <b>t</b> pd  | Α              | Input or I/O to Combinatorial Output        |
| t∞           | Α              | Clock to Output Delay                       |
| <b>t</b> cf² | _              | Clock to Feedback Delay                     |
| <b>t</b> su, |                | Setup Time, Input or Feedback before Clock↑ |
| <b>t</b> su, | _              | Setup Time, SP before Clock↑                |
| <b>t</b> h   | _              | Hold Time, Input or Feedback after Clock↑   |



Note: fmax with external feedback is calculated from measured tsu and tco.



fmax with No Feedback

Table 1. ispLSI 5000VE Family Attributes

|                           | 5128VE   | 5256VE                                       | 5384VE               | 5512VE                                       |
|---------------------------|----------|----------------------------------------------|----------------------|----------------------------------------------|
| Density (PLD Gates)       | 6,000    | 12,000                                       | 18,000               | 24,000                                       |
| Speed: <b>f</b> max (MHz) | 180      | 165                                          | 165                  | 155                                          |
| Speed: <b>t</b> pd (ns)   | 5.0      | 6.0                                          | 6.0                  | 6.5                                          |
| Macrocells                | 128      | 256                                          | 384                  | 512                                          |
| Registers                 | 128      | 256                                          | 384                  | 512                                          |
| I/O                       | 96       | 72/96/144                                    | 192                  | 192/256                                      |
| Pin/Package               | 128 TQFP | 100 TQFP<br>128 TQFP<br>256 fpBGA<br>272 BGA | 256 fpBGA<br>272 BGA | 256 fpBGA<br>272 BGA<br>388 fpBGA<br>388 BGA |

5KVE attributes





#### ispLSI 5000VE GLB





## Boundary Scan Register for Dedicated Input Pins



### ispLSI 5000VE Simplified Timing Model



Table 1: Spartan-IIE FPGA Family Members

| Device   | Logic<br>Cells | Typical<br>System Gate Range<br>(Logic and RAM) | CLB<br>Array<br>(R x C) | Total<br>CLBs | Maximum<br>Available<br>User I/O <sup>(1)</sup> | Maximum<br>Differential<br>I/O Pairs | Distributed<br>RAM Bits | Block<br>RAM Bits |
|----------|----------------|-------------------------------------------------|-------------------------|---------------|-------------------------------------------------|--------------------------------------|-------------------------|-------------------|
| XC2S50E  | 1,728          | 23,000 - 50,000                                 | 16 x 24                 | 384           | 182                                             | 83                                   | 24,576                  | 32K               |
| XC2S100E | 2,700          | 37,000 - 100,000                                | 20 x 30                 | 600           | 202                                             | 86                                   | 38,400                  | 40K               |
| XC2S150E | 3,888          | 52,000 - 150,000                                | 24 x 36                 | 864           | 265                                             | 114                                  | 55,296                  | 48K               |
| XC2S200E | 5,292          | 71,000 - 200,000                                | 28 x 42                 | 1,176         | 289                                             | 120                                  | 75,264                  | 56K               |
| XC2S300E | 6,912          | 93,000 - 300,000                                | 32 x 48                 | 1,536         | 329                                             | 120                                  | 98,304                  | 64K               |
| XC2S400E | 10,800         | 145,000 - 400,000                               | 40 x 60                 | 2,400         | 410                                             | 172                                  | 153,600                 | 160K              |
| XC2S600E | 15,552         | 210,000 - 600,000                               | 48 x 72                 | 3,456         | 514                                             | 205                                  | 221,184                 | 288K              |



FPGA Block Diagram

DS077\_01\_052102

### Spartan-IIE Input/Output Block (IOB)



For some I/O standards.

DS077-2\_01\_051501

## Spartan-IIE I/O Banks



| V <sub>CCO</sub> | Compatible Standards                                          |
|------------------|---------------------------------------------------------------|
| 3.3V             | PCI, LVTTL, SSTL3 I, SSTL3 II, CTT, AGP,<br>LVPECL, GTL, GTL+ |
| 2.5V             | SSTL2 I, SSTL2 II, LVCMOS2, LVDS, Bus<br>LVDS, GTL, GTL+      |
| 1.8V             | LVCMOS18, GTL, GTL+                                           |
| 1.5V             | HSTL I, HSTL III, HSTL IV, GTL, GTL+                          |



