CMOS PLA Layout Generation by Bryant, Christopher D
CMOS PLA LAYOUT G~IERATION
Christopher D. Bryant
5th Year Microelectronic Engineering Student
Rochester Institute of Technology
ABSTRACT
A dynamic AND - dynamic OR type of PLA was designed using
a CMOS process and the layout was done on a CALMA system
using l.5um design rules. A PLA with 200 transistors was
completed and can be used to perform desired logic
functions.
INTRODUCTION
Programmable Logic Arrays have been used for many years as a
means of customizing logic design. PLA’s, as they are known,
provide a flexible and efficient way of synthesizing arbitrary
combinational functions in a regular structure. The circuit is
based on a representation of Boolean functions &S a set of sum—
of-products terms. The AND plane produces the distinct product
terms in the expressions; the OR plane collects these terms to
produce the desired outpUt5. PLA’s can be fabricated in either
bipolar7 using ECL gates or CMOS using both P and N type gates.
For certain types of logic networks, large CMOS arrays can
achieve overall system speeds that compare favorably with ECL
devices, yet don’t have the problems associated with those
devices. CMOS arrays are achieving a great deal of attention due
to their short path delays that are possible with high circuit
density (1).
There are three distinct types of PLA’s that can be implemented
and used for different designs, depending Ofl the size of the PLA,
the desired speed, and the timing sequence. They are the dynamic-
dynamic7 the dynamic-st&tiC~ and the static-dynamic. The two
terms are descriptive of the two separate planes~ AND-OR, that
provide the logic AND function or the logic OR function. Dynamic
means that the plane is always performing some type of function
while static means it performs a function only on specified clock
pulses.
Figure 1 shows the block diagram for a typical PLA. The
chart on the next page shows some typical uses, timing, sizes and
current consumptiOn comparison of the three types of PLA’S. The
timing diagrams are shown in Figure 2 (2). As can be seen the
uses of the PLA would be according to the design specifications
for the outputs being valid or the inputs being stable.
The ~in concept of a static plane is that the
inputs/outputs are sampled while the pull-up transistors are
•b? ‘.~
~thb~.C ‘4vb~ ~ CO” S:at~ ‘~J4 ~r~’
//1// /Z//~ //i ///// ~ / / ,7/’~ /
~ ~ .t ..~ ~ bflf~J’ e - e
U5&S Cioc1 e”°~ tt~duce ~
o~p~4~) -~ ~ ~,
ac~ CIoc~ C~CI( ~CLc~ ~ -
~ çL~r. jjc”~5 ~n ?,ot~- ~ ~ l’~. pb~t ~ I
~ ~ ~€ or ~‘. ~ ~- ‘4~ ~
Atr op~g~tII~G 3t$~( ~ ~ Q~’b~~t. ~ ~ j~. (
~ ••‘~ ~
~ u~fu4J ~.“• ~ ‘,.‘~. ~ ~ ~
S~( C1’ ~ ~ ~o~r4(~u ~, Lt~ç~, O’P~~ ~
~ ~“~R5~
Cv~rgM (.ni~o.~fofl sow, duo d. .~,‘e r~ f!4 L c~
~ ~ -
~ ~It ~ ~ b~c~,r~5c1~ l T~ Zn~tt
~ 5 ~ I~ ~ ~.~Lad CMOS ~t,~,cAu~o ~ ~
: ~ - ~
~4~)k~ (..ati~ ~‘~o) ct ~‘ c~s~~’
-~ ~ ~. ~, ( ~Lflt~ & L ~- bE e~ ‘O~ ~.‘ ~ L
f~Dr b~r bC ~ 4 ~f’







































FIGURE 3 : INPUT BUr~*( DCPLOS ION
disconnected. This means that every line that is a logic “1”
~jscharges and every line that is a logic Ho., is floating. The
main problem with this is the pull-ups try to charge all lines,
including the lines being pulled down. If the pull-down
transistors are not strong enough, noise margin degrades. If the
pull-ups are not strong enough then the charge of the output line
is slow and if the pull-ups are too strong the circuit wifl
consume a lot of power. One possible solution to this problem is
to make the pull-up transistor with a W/L ratio of 1.
A
FIGURE 1 : BLOCK DI~GRAN OF PLA
The focus of this project was on layout of the cells for the
PLA utilizing the CALMA system here at RIT. By making cells,
others can customize the PLA to perform a desired logic function.
The dynamic-dynamic PLA was chosen because of the ease of the
clocking scheme along with its interesting nature. Defining the
PLA, including the schematic of the cells used, the number of
inputs and outputs~ and also the clocking scheme was a part of
this project. Cell explosion schematics are shown in Figures 3
and 4 (3). Figure 3 is the cell explosion for the input buffer
and Figure 4 is the output buffer.
The PLA designed was for a CMOS double-metal process using
the ref ractory_POlYsilicon techniques. The ref ractorYPOlY
process uses metal placed on top of the polysilicofl to reduce the






used. The double-level metal was used because of its low power
consumption and short path delays.
The first step in the design process is developing the device
at the schematic level. The majority of schematic capture tools
available today require a designer to start with at least a
behavioral description of the circuit. The PL?~ description for
this design was arbitrary and was for demonstration purposes only.
This is true because the purpose of this project was to create the
standard cells necessary to help others redesign the PLA for a
specific function. Assuming the device to be fully custom, the
next step is to layout the physical geometries for each sking
level associated with the transistors in the schematic. Here is
where the CMOS, double level metal, polysiliCon gate process was
chosen.
DESIGN
PLA’s are essentially uncommitted logic gates where the user
determines the final logic configuration of the device. The basic
programmable array is the AND-OR logic in the familiar sum-of-
products (SOP) representation. A conventional schematic
representation is shown in Figure 5. Its programmable logic
equivalent is shown in Figure 6 (4).
FIGURE 5 : PLA SCI~MATIC REPRESENTATION
One reason for using the SOP expressions is their straightforward
conversion to very simple logic gate5. In their purest and
simplest form they go into two level networks which are networks
for which the longest path through which a signal must pass is two
gates long (5).
Today programmable logic typically implements from 4 to 20
SSI and MSI logic devic s. This allows a reduction of size for a
system as well as an increase in logic power. Also with the use
of programmable logic, the designer is not limited to standard off
the shelf parts and, therefore, can use non-standard structures.
Another reason for its use is that designer! can compress multiple
levels of logic into a two level AND-OR structure, thus




vI~ .6 a LOI~C ~QVWM~T
The PL~ for this project7 was designed for the ~4OS double
level metal process. The design rules used are for the l.5um
polysilicOn lines, and the masking steps for the process are
listed below in Table II. A cross section of th process ca.n be
seen in Figure v (7). The reason for using double level metal is
because if the PLA gets very large, to cut down on the resistance
of the poly gates, metal two can be tapped into the poly and it is
like having two resistors in parallel.






I (6) P+ regions










FIGURE 1 : CROSS SECTION OF CMOS
The schematics, shown in Figures 5 and 6, were drawn by hand
since logic simulation had been done already in November 1987
while on co-op at National Semiconductor in Santa Clara, the
program used for simulation was SPLA (8). The reason for
simulation was part of the work that was being done in studying
PLA’s in general. The ne t step in the design was layout. This
was done on the CALMA system in the CAD/CAM lab in the
microelectronics building at RIT. The library name used for this
project and where the cells can be found is called CMOSCDB.
RESULTS
25
All cells have been drawn, schematics have been constructed
and connection! to form the PLA has been completed. The PLA is
drawn such that it is rectangular. The pad arrangement has not
been set because of the way the PLA can be rotated to provide
extra space. The number of transistors is approximatelY 200.
CONCLUS I ONS
A dynamic - dynamic PLA has been done and the layout is
completed. It can now be programed to do any logic function that
is desired. The cells used can be modified to provide the best
implementation for that desired function.
p~ENCES
1. “Designing With Gate Arrays”, Robert J. Humphrey,
Semiconductor InternatiOflai, February 1986, pgs. 135 - 136.
2. “DescriptiOn of PLA Information”, Christopher D. Bryant,
AuguSt 1987, pgs. 1 - 7.
3. “SPLA User Guide”, ChristOpher 0. Bryant, November 1987,
pgs. 10, 12, 14.
136.
4. Programmable Logic Design Guide, National Semiconductor,
May 1986, pgs. 3 — 5.
5. IBID., pg. 22.
6. IBID., pgs. 3 - 5.
7. “5uM Poly Gate CMOS Gate Array”, Lisa A. Rogers, May 1987,
pg. 3.
8. “SPLA User Guide”, Christopher 0. Bryant, November 1987,
pgs. 1 - 14.
