nogrammable Logic Devices pesigning of Excess-3 to BCD Code using PAL Fig. 7.29. # 7.10 PPGA (FIELD PROGRAMMABLE GATE ARRAY) It is a type of logic chip that can be programmed. An FPGA is similar to a PLD, but where a PGAs support but whereas PLDs are generally limited to hundred of gates, FPGAs support thousands of gates. They are especially used for integrated circuit designs. Once thousands of gates. They are chips are produced for faster performance. design is set, hardwired chips are a semiconductor device containing A Field programmable gate array is a semiconductor device containing A Field programmable gate array is a semiconductor device containing A Field programmable gate array and programmable logic components called "logic blocks" and programmable programmable logic components called "logic blocks" and programmable programmable logic components called "logic blocks" and programmable programmable programmable programmable programmable logic components called "logic blocks" and programmable programmable programmable programmable logic blocks and programmable programmable logic components called "logic blocks" and programmable programmable logic components called "logic blocks" and programmable programmable logic components called "logic blocks" and blocks "lo programmable logic components and to perform the function of basic interconnects. Logic blocks can be programmed to perform the function of basic interconnects. Logic blocks can be programmed to perform the function of basic interconnects. interconnects. Logic blocks can be properly combinational function of basic logic gates such as AND, XOR or more complex combinational functions logic gates such as AND, xoR or more complex combinational functions basic logic gates such as AND, xoR or more complex combinational functions such logic gates such as AND, XOR of most FPGAs, the logic blocks such as decoders or mathematical functions. In most FPGAs, the logic blocks also decoders or mathematical functions which may be simple flip-flops or more corner which may be simple flip-flops or more corner to the such as decoders or mathematical functions. as decoders or mathematical lunes decoder blocks of memory. ks of memory. A hierarchy of programmable interconnects allows logic blocks to be A hierarchy of programmas system designer, somewhat like a one-chip interconnected as needed by the system designer, somewhat like a one-chip programmable breadboard. Logic blocks and interconnects can be programmed by the customer or designer, after the FPGA is manufactured, to implement any logical functions hence the name "field programmable". To configure (program) an FGPA you specify how you want the chip to work with a logic circuit diagram or a source code using a hardware description language (HDL). The HDL form might be easier to work with when handling large structures because its possible to just specify them numerically rather than having to draw every piece by hand. FPGAs are quite different from CPLDs (Complex Programmable Logic Device) because FPGAs do not contain AND or OR planes. Instead, FPGAs provide logic blocks for implementation of the required functions. FPGA contain three main types of resources: (1) Logic Blocks (2) Input/Output-Input/output blocks for connecting to the pins of the package. (3) Interconnection wires and switches. The logic blocks are arranged in a two-dimensional array, and the interconnection wires are organized as horizontal and vertical routing channels between rows and columns of logic blocks. The routing channels contain wires and programmable switches that allows the logic blocks to be interconnected in many ways. Figure 7.20 show two locations for programmable switches, the brown boxes adjacent to logic blocks holds switches that connect the logic block input and output terminals to the interconnection wires and the brown boxes that are diagonally between logic blocks connects one interonnection wire to another (such as a vertical wire to a horizontal wire). Programmable connections also exist between the Input/Output blocks and the interconnection wires. The actual programmable switches and wires in an FPGA varies in commercially available chips. FPGAs can be used to implement logic circuits of more than a few hundred thousand equivalent gates in size. Each logic block in an FPGA has a small number of inputs and one output. A number of FPGA products are on the market, featuring different types of logic blocks. The most commonly used logic block is a look up table (LUT), which contains storage cells that are used to implement a small logic function. Each cell is capable of holding a single logic value, either 0 or 1. The stored value is produced as the output of the storage cells. LUTs of various sizes may be created, where the size is defined by the number of inputs. Figure and one o two varia four stora table. Th multiple of one of by using $f_1$ from t 2nd MU correct programmable Log Block driv Each ue is ated, Fig. 7.30. FPGA Figure 7.21 shows the structure of a small LUT. It has two inputs $x_1$ and $x_2$ and one output function f. It is capable of implementing any logic function of two variables. Because a two-variable truth-table has four rows, this LUT has four storage cells. One cell corresponds to the output value in each row of truth table. The input variables $x_1$ and $x_2$ are used as the select input of three multiplexers, which, depending on the valuation of $x_1$ and $x_2$ , select two content of one of the four storage cells as the output of LUT. To realized a logic function by using the two-input LUT, consider the truth-table in fig. 7.22. The function $f_1$ from this table can be stored in LUT (as 1001 to first input to MUX 1 and 0 to 2<sup>nd</sup> MUX 1 input and so on). The arrangement of multiplexers in the LUT correctly realizes the functions $f_1$ when $x_1 = x_2 = 0$ , the output of the LUT is driven by the top storage which represents the entry in the truth table for $x_1x_2=00$ G. by the top storage which represents the charge in the $x_1x_2=00$ . Similarly, for all valuations of $x_1$ and $x_2$ , the logic value stored in the storage cell corresponding to the entry in the truth table chosen by the particular storage cell corresponding to the entry in the truth table chosen by the particular storage cell corresponding to the entry in the truth table chosen by the particular storage cell corresponding to the entry in the truth table chosen by the particular storage cell corresponding to the entry in the truth table chosen by the particular storage cell corresponding to the entry in the truth table chosen by the particular storage cell corresponding to the entry in the truth table chosen by the particular storage cell corresponding to the entry in the truth table chosen by the particular storage cell corresponding to the entry in the truth table chosen by the particular storage cell corresponding to the entry in the truth table chosen by the particular storage cell corresponding to the entry in the truth table chosen by the particular storage cell corresponding to the entry in the truth table chosen by the particular storage cell corresponding to the entry in the truth table chosen by the particular storage cell corresponding to the entry in the truth table chosen by the particular storage cell corresponding to the entry in the truth table chosen by the particular storage cell corresponding to the entry in the truth table chosen by the particular storage cell corresponding to the entry in the truth table chosen by the particular storage cell corresponding to the entry in the truth table chosen by the particular storage cell corresponding to the entry in the truth table chosen by the particular storage cell corresponding to the entry in the truth table chosen by the particular storage cell corresponding to the entry in the truth table chosen by the particular storage cell corresponding to the entry in the truth table chosen by the entry in e storage cell corresponding to the entry in the tradi-valuation appears on the LUT output. Providing access to the contents of storage valuation appears on the LUT output. Providing access to the contents of storage valuation appears on the LUT output. I Toylung to implement logic functionage cells is only way in which multiplexers can be used to implement logic functionage | $x_1$ | $x_2$ | y <sub>1</sub> | |-------|-------|----------------| | - | 0 | 1 | | 0 | 1 | 0 | | 1 1 | 0 | 0 | | 1 1 | 1 | 1 | | | | | Fig. 7.32. $f_1 = \overline{x_1} \cdot \overline{x_2} + x_1 x_2$ Fig. 7.33. Storage cell contents in the LUT Two-input LUT. The three input LUT is shown in fig. 7.23. It has eight storage cells because a three-variable truth-table has eight rows. Fig. 7.34. A 3-input LUT programmable Logic The storage co they lost their stor off. Hence FPGA Advantages of I (1) It is use (2) It is us thousar Demerits of FP The storage has to be program that holds its d (PROM), is incl cells in the FPGA to the chips. ### 7.11 COMPLEX PLAs and PAL circuits. Each d than the numb particular chip number of inpu that require n employed or programmable A CPLD wiring resource PLA or a PLA programmable Logic Devices The storage cells in the LUTs in an FPGA are volatile, which means that The stored contents whenever the power supply for the chip is turned they lost their stored contents whenever the power supply for the chip is turned they longer FPGA has to programmed event time and the chip is turned to t they lose FPGA has to programmed every time power is applied. Advantages of FPGA - (1) It is used to design large logic circuits. - (2) It is used to implement logic circuits of more than a few hundred thousand equivalent gates in size. ### pemerits of FPGA The storage cells in the LUTs in an FPGA are volatile. Due to this FPGA has to be programmed every time power is applied. Often a small memory chip has holds its data permanently, called a programmable read only memory (PROM), is included on the circuit board that houses the FPGA. The storage cells in the FPGA are loaded automatically from the PROM when power is applied to the chips. ## 7.11 COMPLEX PROGRAMMABLE LOGIC DEVICES (CPLDs) PLAs and PALs are useful for implementing a wide variety of small digital circuits. Each device can be used to implement circuits that do not require more than the number of inputs, product terms, and outputs that are provided in the particular chip. These chips are limited to modern sizes, supporting a combined number of inputs plus outputs of not more than 32. For implementation of circuits that require more inputs and outputs, either multiple PLAs or PALs can be employed or else a more sophisticated type of chip, called a complex programmable logic device (CPLD) can be used. A CPLD comprises multiple circuit blocks an a single chip, with internal wiring resources to connect the circuit blocks. Each circuit block is similar to a PLA or a PLA. The structure for CPLD is shown as follows: Fig. 7.35. ecause d Design rticular $\operatorname{stor}_{\operatorname{age}}$ nctions. Structure of CPLD It includes four PAL - like blocks that are connected to a set It includes four PAL – like block is also connected to a subcircuit interconnection wires. Each PAL – like block is also connected to a subcircuit interconnection wires. Each PAL – like block is also connected to a subcircuit interconnection wires. Each labeled Input/Output block which is attached to a number of chips input and output pins. The PAL like block includes 3 macro cells, each consisting of a four-input. The PAL like block includes between 5 and 20 inputs to each OR gate. OR gate (real CPLDs provides between 5 and 20 inputs to each OR gate). The OR-gate output is connected to another type of logic gate that we have not yet introduced. It is called an Exclusive—OR (XOR) gate. The behaviour of an XOR gate is the same as per an OR gate except that if both of the inputs are 1, the XOR gate produces a 0. One input to the XOR gate can be programmably connected to 1 or 0, if 1, then the XOR gate complements the OR-gate output and if 0, then the XOR gate has no effect. In some cases XOR gate is connected to macrocell. The macrocell also includes a flip-flop, a multiplexer and a tristate buffer. The flip-flop is used to store the output value produced by the OR gate. Each tri-state buffer is connected to a pin on the CPLD package. The tristate buffer acts as a switch that allows each pin to be used either as an output from the CPLD or as an input. To use a pin as an output, the corresponding tristate buffer is enabled, acting as a switch that is turned on. If the pin is to be used as an input, then the tri-state buffer is disabled, acting as a switch that is turned off. In this case an external source can drive a signal on to the pin. which can be connected to other macrocells using the interconnection wiring The interconnection wiring contains programmable switches that are used to connect the PAL-like blocks. Each of the horizontal wires can be connected to some of the vertical wires that is crosses, but not to all of them. The number of switches (for connection b/w wires) is chosen to provide sufficient flexibility for typical circuits without wasting many switches. Fig. 7.36. Internal Structure of CPLD. programmable Logi Commercial 100 PAL-like ble state permanent is known as non CPLDs are The exampl follows Manufact Atmel Cypers Altera The mostl macrocells, to t (1) Gate capa Compari (2) No. of Inp Outputs (3) Process Technolog (4) Performa ption (5) Power co (6) Speed (7) Intercon (8) Architec (9) Density (10) Area of (11) Type of (12) Flexibil compon (13) When p supply (14) Comple (15) Applica and Design o a set of subcircuit input and four-input gate). at we have haviour of inputs are rammably ate output connected and a triby the OR e. The trian output onding tribin is to be re used to inected to number of ibility for tch that is to the pin, on wiring. programmable Logic Devices Commercial CPLDs range is size from only 2 PAL-like blocks to more that PAL-like blocks. Once a CPLD is programmed, it retains the programmed permanently, even when the power supply for the chip is turned off. This known as non-volatile programming. CPLDs are used for the implementation of many types of digital circuits. The example of certain CPLD product company and its product are as follows-Manufacture **CPLD Product** Atmel ATF, ATV Cypers Altera FLASH 370, Ultra 37000 MAX 5000, 7000, 9000 The mostly used CPLD is MAX 7000 which range is size from 7032, has 32 macrocells, to the 7512 has 512 macrocells. Comparison between FPGA and CPLD