# Lecture 19 EE 421 / C\$ 425 Digital System Design

Fall 2023
Shahid Masud



# Topics

- PAL, PLA, Examples, Polarity Control Circuit in I/O
- Example of an I/O Block for SPLD
- Field Programming technology
- CPLD Architecture
- CPLD Examples from Xilinx and Altera
- Logic Expander Shareable and Parallel
- Output Block of PLD
- FPGA Architecture







**Embedded Systems Lab (EESL)** 

# **PLA = Programmable AND-OR Logic Array Logic Array Comprises Programmable AND-OR Gates** В Y output **LUMS** Digital System Design Lecture 19 Fall 2023

#### **Fuse Programmable Logic Array**





# PAL – Programmable Array Logic





#### PLA – Programmable Logic Array





#### For Exercise



#### **Example of PLA**



Implementation of Programmable Logic Array

Electronics Coach



# PAL – Programmable Array Logic





# PLA – Programmable Logic Array





#### For Exercise









# **Example of PLA**



Implementation of Programmable Logic Array

Electronics Coach



# PAL – Programmable Array Logic Example



- PAL Device is a PLD with fixed OR array and a programmable AND array
- As only AND gates are programmable, PAL is easier to program

but it is less flexible compared to PLA devices

#### **Example device:**

- This device has 4 inputs and 4 outputs.
- Each input has a buffer and inverter, output is from fixed OR gate
- The device has 4 sections: Each section comprises 3 wide AND-OR array, meaning three programmable AND arrays in each section
- Each AND gates has 10 programmable input connections
- One of the outputs (see F1) can be fed back to the inputs of AND gate through programmable connections



# Sequential Circuits with PLD – Mealy Machine





# Sequential Circuits with PLD - Moore Machine





# **Output Polarity Control**





# Programmable Logic Broad Classification





Simple and Complex Programmable Logic Devices Field Programmable Gate Array

Gemenic Array Logic (ออกาศาลง PAL by lattice semi), Programmable Logic Array

# Programmable Hardware Devices Comparison

|                               | SPLD -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | CPLD                                 | FPGA                                               |
|-------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------|----------------------------------------------------|
| Density                       | Low<br>Few hundred gates                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Low to Medium<br>500 to 12,000 gates | Medium to High 3,000<br>to 5,000,000 gates         |
| Timing                        | Predictable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | Predictable                          | Unpredictable                                      |
| Cost                          | Low                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | Low to Medium                        | Medium to High                                     |
| Major<br>Vendors              | Lattice Semiconductor<br>Cypress<br>AMD                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | Xilinx<br>Altera                     | Xilinx<br>Altera<br>Lattice Semiconductor<br>Actel |
| Example<br>Device<br>Families | Lattice Semiconductor<br>GAL16LV8<br>GAL22V10                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | Xilinx<br>CoolRunner<br>XC9500       | Xilinx<br>Virtex<br>Spartan                        |
|                               | Cypress<br>PALCE16V8                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | Altera<br>MAX                        | Altera<br>Stratix                                  |
|                               | AMD<br>22V10                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                      | Lattice<br>Mach<br>ECP                             |
|                               | The state of the s | THE RESERVE THE PARTY NAMED IN       | Actel<br>Accelerator                               |

Ref: Roth & John Book LUMS

# Interconnect Technology for Field Programming

**EEPROM / FLASH** 

**SRAM** 





SRAM Cell is connected to Gate terminal MOS Switch behaves as per stored value in SRAM



# Concept of a Programmable I/O Block





# Description of Basic (Registered) Macrocell

- Each section of an SPLD is called a macrocell that contains SOP combinational logic and an optional Flipflop
- A typical SPLD has from 8 to 10 macrocells within one chip
- All Flipflops are connected to common CLK input
- All three-state buffers at Flipflop output are controlled by a common OE input



# **Basic Macrocell Logic**

PAL that includes a DFF is called a Registered PAL





# **Generic CPLD Configuration**





# **Description of CPLD**

- Structured Array of PLD blocks
- Programmable On-Chip Interconnection Fabric
- Have higher number of inputs without much increase in area
- 100% connectivity between macrocells, BUT not all outputs of macrocells are connected to OUTPUT
- Wide Fan-In AND gates are used at INPUTS
- Outputs of macrocells can be routed within the chip to form more complex logic blocks
- The Interconnect Array selects signals from I/O blocks or macrocell outputs and connects them back to function block inputs
- The I/O blocks provide an interface between bidirectional physical I/O pins and the interior of the CPLD



#### **Details of Generic CPLD Configuration**

- Collection of individual PLD gate arrays on a single integrated circuit
- Each I/O pin is driven by a 3-state buffer and can be programmed to act as Input or Output pin
- Each PLD typically contains 8 to 16 macrocells
- If a macrocell has unused product terms, they can be used by nearby macrocells
- The outputs of macrocells can be routed to inputs of other macrocells to form complex multi-level logic functions
- Different manufactures offer variations in PLD design, programmable switching matrix and different types of I/O blocks



**Embedded Systems Lab (EESL)** Altera 7000 Series CPLD Architecture Input/GClk \_ Input/GClkn\_ Input/OE1 Input/OE2 LAB A LAB B Macrocells Macrocells 8 to 8 to 36 36 1 to 8 17 to 24 16 16 1/0 1/0 8 to 16 8 to 16. Control Control Macrocells Macrocells I/O Pins I/O Pins Block Block 9 to 16 16 25 to 32 16 8 to 16/ PIA 8 to 16 Programmable LAB C LAB D Interconnect Array Macrocells Macrocells 8 to 8 to 33 to 40 36 49 to 56 36 16 1/0 16 1/0 8 to 16. 8 to 16 Control Control Macrocells I/O Pins. Macrocells I/O Pins Block Block 41 to 48 16 57 to 64 16 8 to 16 / 8 to 16 Digital System Design Lecture 19 Fall 2023 26

#### **Details of Altera 7000 CPLD**

- Floating gate EEPROM Configuration memory cells
- Architecture consists of an array of logic array blocks (LAB), programmable interconnect array (PIA) and an array of programmable I/O blocks
- Each LAB has 36 inputs and 16 outputs
- Each LAB consists of 16 macrocells providing both combinational and sequential logic
- PIA provides full connectivity between LAB and I/O Cells
- I/O Control block connects I/O Pins and PIA and LAB
- Global input clk (GCLK) and Global Clear (GCLR) connect to all macrocells
- Each macrocell can provide five product terms to its product-termselect matrix



#### PIA and I/O

- The PIA provides full connectivity with predictable timing between LAB, dedicated inputs and I/O Pins
- The I/O Control block establishes connectivity between I/O Pins and PIA and LABs
- From 8 to 16 LAB outputs can be programmed to route through I/O Pins; and from 8 to 16 I/O Pins can be programmed to route through the I/O Control block to the PIA
- Altera architecture uses a PIA to connect LABs and I/O Pins. All signals are available throughout the device. The timing is thus predictable. The alternative is 'Channel-Routed Architecture' that is more denser but the timing is un-predictable as delays are routing-dependent



# Shareable Expander in Altera 7000 CPLD









# Altera 7000 Series Macrocell Architecture





**Product Terms** 

#### Altera 7000 Series I/O Control Block





#### Xilinx XC9500 CPLD Architecture





#### **Details of Xilinx 9500 CPLD**

- Flash based EEPROM Technology
- Comprises Few (4) Functional Blocks
- Each functional block contains 18 independent macrocells
- Each functional block has 54 inputs and 18 outputs
- Product-term-allocator allocates upto 90 product terms in each macrocell in a functional block to form SOP expressions
- Each macrocell can receive five direct product terms from the AND array and up to 10 more product terms can be made available from other uncommitted product terms in other macrocells from same functional block
- Partial SOP terms can be combined from several macrocells
- Each macrocell can be independently configured for combinational or sequential functionality



#### Xilinx XC9500 Macrocell Architecture



