Silicon Compilation - A Hierarchical Use of PLAs by Ayres, Ron
311 
Silicon Compilation- A Hierarchical Usc of PLAs 
Ron Ayres November 1978 
1.0 fntroduction 
This paper proposes a way to compile a silicon layout directly from synchronous logic 
specification. The motivation for introducing compilation into the silicon world comes from its 
extreme success in the software world. As we see silicon area increasing and circuit complexity 
increasing, we might feel much in common with the early day programmers who faced increasing 
memory availability along with increasing program complexity. 
Software and hardware revolve around the same basic concern: The software designer lays 
out a one dimensional array of memory whereas the integrated circuit designer lays out a two 
dimensional area of silicon. In each case, various constraints must be satisfied in order to obtain a 
working product. In addition, both efforts involve lots of modification. 
Compilers are around to reduce the amount of specification required to obtain a working 
program. Custom programs can be created economically and confidently with the aid of compilers 
and programs can be modified quickly even though the resulting memory layout has to change 
drammatically. Producing custom VLSI requires these same conveniences. Where a software 
compiler revises addresses which reference relocated blocks of memory, a silicon compiler rerou tes 
wires to relocated blocks of silicon. When changes are made to the logic specification for the chip, 
the compiler creates a new layout with all cells positioned and connected especially for the new 
logic specification. 
This paper is divided as follows: First, synchronous logic specification and a silicon 
imp.lementation for synchronous logic is described. Then, problems arising with large systems 
....... 
concerning both their specification and silicon implementation are cited and a solution is presented 
which both eases large synchronous logic specs and decreases silicon area. This particular solution 
introduces a flexible hierarchy into the specification of logic and accounts automatically for 
placement and wire routing. The ideas presented here a re implemented currently as programs 
written in the language ICL which runs on a PDP-10. 
2.0 Logic Specification for !Cs 
Synchronous logic is a language in which one specifies the function 
of an IC. In almost all IC designs, there exists at some time a synchronous 
logic specification. The synchronous logic spec provides means for simulating 
the IC before more detailed work proceeds. Synchronous logic is by no means 
CALTECH CONFERENCE ON VLSI, January 1979 
312 Ron Ayres 
the most convenient high level language in which to describe res but it does 
provide a solid starting point. Other high level specification languages can translate their input into 
synchronous logic. 
The language of synchronous logic admits any set of equations written in terms of boolean 
expressions and variables. [n addition, synchronous logic admits the specification of a unit delay in 
time. For example, figure l shows the synchronous logic for a single bit of a resetable counter. 
Any set of synchronous logic equations can be implemented in silicon via a PLA 
(Programmable Logic Array) coupled with some inverters and unit delay flipflops. Figure 2 shows 
a PLA which impleme.nts the coumer-bit. A PLA by itself implements any set of logic equations 
(without delays) which can be written in terms of an OR of AND terms devoid of logical NOTs. 
Attach inverters to the inputs of a PLA and one can implement any set of logic equations. Finally, 
by adding unit delay flipflops omo the outputs, one can implement any set of synchronous logic 
equations. The unit delay flipflops are placed on the outputs of those equations which were 
specified with the = next as opposed to the = by itself. 
3.0 Hierarchical or Functional Logic Specification 
Conceptual design of any lC involves partitioning lhe desired function into smaller 
functional units. The smaller functional units themselves may be partitioned etc. so that each of the 
smallest units can be implemented with confidence. For example, a frequency divider may be 
divided imo one counter + one register. The counter can be decomposed further by defining an 
individual bit position for the counter. 
Functional partitioning provides means to localize design concerns. Functional partitioning 
also alleviates the need to replicate equations for replicated components, e.g., the equations for one 
bit in a counter may be written once but referenced as a whole many times to form a full counter. 
Functional partitioning is old hat in software where programs are written in languages which 
support function definition and invocation. 
Logic specification can be partitioned by introducing the concept of a logic cell. A logic 
cell appears to the outside world as a block box + and interface. An interface is a set of named 
signals. Logic cells are related together by writing equations which involve signals. each of which is 
specified by naming both a particular logic cell and a particular signal in that logic cell's interface. 
For example, figure 3 presents a definition of an N-bit counter in terms of logic cells each of which 
represents a single counter bit. The notation \S (looks like apostrophy s) is used to retrieve a signal 
given a logic cell and a name. Figure 4 is a copy of figure 3 with explanations superimposed. 
COMPUTER-AIDED DESIGN SESSION 
Silicon Compilation - a Hierarchical Use of PLAs 313 
The notation used in figure 3 is working program text which has been used to generate the 
illustrations for this article. The program text uses the name LOGIC_LEVEL as a synonym for 
logic cell. (LOGIC_LEVEL was intended to mean one LEVEL of LOGIC in a hierarchy). 
A logic cell is a datastrucrure consisting of three fields: 
EXTERNALS: two sets of named pins (input and output) 
RELATIONS: A set of synchronous logic equations which relate the inputs and 
outputs of both this logic cell and all of the subcells (GUTS). 
GUTS: The set of subcells referenced by this cell. 
This hierarchical synchronous logic specification language has been used successfully to 
define an IC whose function is to drive an SCR to control the brightness of a lightbulb, 
parameterized by four kinds of instructions. The IC consists of two 6-bit registers, a 6-bit and a 2-
bit shift register, a 6-bit and a 3-bit counter, and a flipflop. The logic specification was easy to 
write and it has been simulated successfully. 
4.0 Hierarchical PLAs to Implement Hierarchical Logic Specification 
To simulate the hierarchical logic specification. a program smashes the hierarchy and creates 
one long list of equations. A standard synchronous logic simulator calces it from there. Likewise, a 
single, giant PLA can be constructed automatically from the long list of equations and therefore 
provide a silicon implementation. 
Unfortunately, a PLA can cake an inappropriately large amount of area; the area equals 
approximately the product of the number of input terms and the number of AND terms. PLA area 
can be saved when the designer notices that his PLA implements actually several independent sets of 
equations. He can substitute the one large PLA ·with several smaller PLAs. In the best case. the 
designer can cut PLA area by a factor of k by implementing k independent sets of equations as k 
small PLAs instead of one large PLA. 
Rather than removing the hierarchy from the logic specification prior to PLA generation, 
we can let the hierarchy work for us. Figure 5 shows a PLA which implements a 16-bit counter and 
figure 6 shows a hierarchical use of PLAs to implement the same. The subPLAs. the PLAs 
generated by each of the subcells, are lined up with all their inputs and outputs facing upwards. 
The RELATIONS of the current logic cell are themselves translated to a PLA and placed on the 
righthand side of the picture. Finally, wires are placed horizontally above the subcells. These wires 
transmit signals between the RELATIONS PLA and each of the subcells and the connection points 
(EXTERNALS) of this logic cell. 
CALTECH CONFERENCE ON VLSI, January 1979 
314 Ron Ayres 
This hierarchical use of PLAs as the following principle working in its favor: Local signals 
are represented locally in silicon. That is, signals relevant only to a subcell remain inside that 
subcell and do not enter PLAs of other subcells or enclosing cells. In addition, a good functional 
partitioning minimizes the number of input and output signals. (Notice that software functions 
generally take in and produce small numbers of parameters). Therefore, the RELATIONS PLA 
will have in general a minimal number of input and output lines, and therefore a nearly minimal 
area. With this setup, PLAs will always relate inputs and outputs of functional uni ts. 
The shape of a layout will depend not only upon the specific logic equations, but also upon 
the chosen hierachy. Figure 7 shows another layout for the 16-bit counter which differs only in its 
functional partitioning. The hierarchy for figure 7 is one level deeper; it consists of four subcells 
where each subcell itself is a four-bit counter generated by calling COUNTER(4). The 
RELATIONS for the new top level connect the four counters in series. Figure 8 shows still another 
16-bit counter; this hierarchy is five levels deep and each level relates exactly two instances of the 
level immediately underneith. Even though the different layouts have differing areas, a layout not 
having minimal area might be chosen merely because it has the right shape for a slot in a larger 
chip. This program makes no such choices, however. The user can modify his hierarchy to obtain 
the shape he wants. 
The layout for a logic cell always comes out with its interface on the lefthand edge. A cell 
is utilized as a subcell by rotating it 90 degrees so as to get its interface facing upwards. 
This program provides interconnect between the PLAs it generates. The interconnect 
generator accepts two sets of fixed pins among which it will provide interconnect. These two sets of 
fixed pins lie horizontally on the bottom and vertically on the right, e.g., the interface pins of the 
subcells on one hand and the pins of the RELATIONS PLA on the other. In addition, the 
interconnect generator accepts a set of movable pins which will reside on the left and which will be 
the interface for this level in the hierarchy. The interconnect generator ft.xes the positions of the 
movable pins as it creates horizontal and vertical wires between the two sets of fixed pins and the 
one set of movable pins. 
5.0 Some Optimizations 
The reader may notice that with the counter shown above, the RELATIONS PLA is trivial, 
i.e., it represents no logic computation. This RELATIONS PLA serves merely to route signals 
between the subcells and the counte r's interface. The equations in the RELATIONS component of 
the counter specification contain no logic in fact; they all have the form A = B. 
COMPUTER-AIDED DESIGN SESSION 
Silicon Compilation - a Hierarchical Use of PLAs 315 
Figures 9, 10, and 11 are copies of figures 6 thru 8 where the trivial equations are removed. 
That is, equations of the form A= 8 have been removed and the signal A has been indirected to the 
signal B so that whenever signal A shows up in a computation, signal B appears instead. 
6.0 Conclusions 
The continual increase in silicon area invites compilation because there is some space for 
overhead and because our bigger cimits are getting complex: enough to require computer assistance 
like that required by large software systems. Modifications will need to be made more readily and 
with confident results. In addition, even if silicon compilation is doomed to require too much area, 
there are still lots of smaller custom ICs which are needed in short order. 






























rcr;c!out = rc::etin 







va:uc c ( IF llip:n TH::.:-: -v<~lue ELSS 'l:liue ) & -re::;et!n 
next 
COUNT Eli- !3:T 
!:EFii!E COU-,TER_BiT= LCG!C_LEVEL: B E.GI~! IJJl.q ~ESET_H:,R~SET_OUT, FLI? _IN , FLIP _OUT , VALUE=P HI ; 
DO 
GIVE 
RES~T J:i := 
i< ~S ET- O:JT : = 
FLIP T:-1:= 








~: E'f·~ : ! T; 
'\F.[!JIT; 
:;c:·! -~ n ; 
r.;p{'}:r i; 
[ T'I PT'-'· ..... • "· r\::~ET ! ~ \t:t.~:~() I rl[SET IN' j 
' FL t P _).N \I.M:EC FL l? _:fN } 
OUT PHlS: ~ESET CUT \~AM:D ·~ESET OUT '; 
FLI i' OJT v:~:·:r.o 'rli r OUT ' ; 
'VALUE v:.tJ)ED VALU~' } ] 
RESET_,OUT \f.Q'J RESET_I~;; 
FLIP _C~JT \EGU (FLiP _HI \ft.:·:D VALUE) ; 














Silicon Compilation - a Hierarchical Use of PLAs 317 
fJGUf<E 2 




I, __ _ 
~­~,...-, ---,--.: 
v v 
1 ?. v n 
LET X • COUr\TER· OIT [ 1 .. N I 
rcsctln of X{ I) 
fiipin of X[ij 
• rosotout of X{ I +1 J 
• flo;J.out of X[ I +1 I 
rr r.ctln of X[ "II • resct.in 
flipin of X[ nJ • l!ipin 
rosclout • renc!out cf X[ 1] 
flip out • fiopout of X[ 1] 
V[ i] • vuluc of X(l] for I • 1 t' n 
~ 




CF;t"I~E C0\1:-'Tl.R(:<:IN>') • .LOCIC_LEVEL: B!Gil: VAR ClllTS•~AMED_LOCIC_!.EVELS; CBIT,LEFT,RIGl!T,L,R•LOCIC_LEVE!.; I•INT; 
DO C:liTS:- {COLLECT COUNTER_BlT '\l:A.'1ED ("!liT' '$1!! 1) FOR I FROM 1 TOll;}; 
LEFT:• CBITS(t); Ill GUT:- CBlTS D•J ; 
CIVE (r~_Pl~S: 
OUT_PlNS: 
RE!.ATIO~S: FOR {L;R} $C ClitTS; 
RlG!!T'-~ 'RZSET !~'; 
!liCIIN 'FLI?_IN ' 
LEr-1\S '!ltSF.7 Ot~·; 
LEF1''S ·ntP_OUT'; 
CBITS'SS 'VALUE' } ) 
COLLECT 
\EQU (~ 'r..!!SET_OUT'); 
'EGU (R\S 'FLIP_OUT')} 
GUTS: CBITS ) .:N!lOEnl 




























r·;~ct:io:l Header • W.!iiT!:~ 
uEFIXE C0c':\7I:C1. (~: 1:\T) = LO:;!C _ Lr:VEL: BEGI:-l VAR CBITS,.N/2-TD_LOGIC_LEVET-S; CBIT ,U:FT ,RIGHT ,L,R• LOGIC:_i:.!:'.'EL; I=!:\T; 
DO CB:7S:~ {COLLECT fcOUNTEl_ 'BIT'-.NAHJ:.:!) ( ' lilT' -.,.s_iiB I) ' 'FOR I FR0:1 1 70 N;); ~~.:t- .\~sign to CBITS, a:1 <'!:ray 
LFT·• Cil'Tsrt]- RICH~·=' ClilTS ~x). ) (:'or uJ:.~ing convenience , I of ~ coul~ ter_b::.ts, e.;c!·, 
• • 1 ~ • · l • l• • j } .!t Ll:!-T & RIGH1 refer to the ~a::~cd 'BIT' su~ I 




~ ... l..L.t....u"n.... • 'l •' "' I. .a."-"' .. ~~ · ·· ~-.: , 
The 1 - RlC.!ir S 'FLIP_IN' counter ) . bi~s. 
I~TErrFACE OUT_PIXS: { LSFT\~ 'RrSET_OJT'; 





RELATIONS : ( { 





·~:: r-'l ll CCrT(<J 1.-
1 
, 
-H_cntrr n . - , 




{L ;R) sc CR:TS; COLLECT 
L....S 'RESET_ I>I' 'EQU 





VALUi.( 1) VALVIEi2) VALUEjJ) VALiJ"!I,J 
9 FT\s 'R.osot·l'l' --F:'\s 'Ftip·!n 
( ~~\S 'RESET_OU'f '); 
(R\S 'FLIP_ OUT')) 
7his cc~r3ct cxpr_sr!c~l 
nraduce~ a Get of :l&=ed 
the ' \'all:c '-p;::l of e.;.ch 
ccunt~r bi~, narr.~d 
'V.\LU!:' ;;~.ob I 
pi:l 
} Connect t1:o: t l. o adjacent 
\....c..- co~~te::- Cits n.::.~~~ L!. !\ 
J 
Loop Ctce~arar : Set the 
v~ri~bl~s L & 1 to e~ch 
adj~cent pai~ v~ cccr.:er 
bits fnm the :1:-ray of 










































































l/ CD 0 












1 ~111 :1 !1 11~~~~~~~~~~~~~~~~~ I . 11·111! ,' ,. __.,---==' ::--7.::-: =-:,_ ~ =· .- -.-.- -:~ --~-- .. ~ -:: '-:--= :::::.~, -== ,_-_..,;_,_ ~-:..: :: _· . -:~:::.~--- -_. - __ : , -::· :_-.-_-=::-::::--::::~ _,-" -_ :=-~yi n!!k,,Jii i!~" 'l''i' 
II· , I,, :1 ,,~, ~~~~~~L ~ ~~:~t :~--:~-:i~~~~ ~ ~~~;~~;~:;;!;~: ~~ -=?-~~~)::~~;~:'7~~~~~=-~:~:if.1;-r1~-,~n::! ·i ''l': l!ii 1; 1!·1·il ili,!l:! 1:, 1·1 , 1 r·rrc=-.-~. ::-:--.:.::.·-::,:::':.:·.:.::.:: __ ::---::===-=--:-=-.~.::_~.::::.::=: :::.~-::.-7. ·::_= ·=,::.-:.-:::::-.. :-::~:.::::.=--:.:=:::.:-=.: :=.:::=·;,-·~!· ' ·-~~~ ~~'Ill 1;'...1111 1.:1. , .. , ' I I t '" '111- ::::-~ ::_:-_:- ?:.:::::.::=-:- := --:'-:'--:::-=-..:_-::.- :::::.::::.:::·:-~=-=---= ·: :.::::.: --~_::::::-::;';==--_:.:::·::=::.:.~~~~~~'! I i '!,', ,,,,.,' ill!l'i'h!i' 'i,,::! , 'I I 1.=--=-=-=.---:.---=- --- -==--:. -~-: . .:;=-: • .--.-=- -- =-.:.-.:.:.-.-.. -" _-__ --:-_-.:-_.:::_---~~=-·,:;-:tl' ij •t•! ,,, .. ,,•: ~·~ :: l'J' •, I, ,.: 1., ·' 
.:,11 111 ~~ r~=';c~={f.c:~~=-=-:::-:_-~~:::=:.i<.,:~-==-:j~_.,_::L;:~::.; -::_~:.-=~-~:~-~::~~~~-=-=-~fll ,·· ,d,,:~:l ,,, ,,!;idi:1:r; !'i'.'i::·;i.::!! ~~ :1)1 I . " ---·---- - .. ------ -- .. . ---- ------------- ----- '''''"' ' 'I I 1"·'·1•'1'' 1'1· 0 • I ,-;-=:..:.-.·:..=-.-:- --. ·--:._.-:--::· :..:;_-:.:-..:..==-. ·.-...:.:....· .• =--.:-_-;. __ :_ -·- - -·=--- ..:.~ '.1 . ,. 'I' II !, · ·:' ; , lt ,•i ·,!Ill 
III,,,.J l · l' ' l l' '''li' l r=-:;-=·:-:::-~ -~-;:.==-~=-_._._::. .. ~-~-=.:.?-==-- :==~·_;i_ ~-~-=:..:::: :-_-=-.::--,.:..-=:;~:- , ,~~~~ ~·; !l '·'i ' ''!::' ~ll'' ''i''''i ''''';ijt 'l;: .:,~·,·,i'';;, III II! I 1 j'l l 1 1rr .-:.:-=-~- ---:.:-: .. -:··--=--==.:·:~_ .. _. __ -:_--=----~----- ~ ~· 1 ''''11~11 111 1!,!11 I 1 ''l''ll'l 11 -. !~11, 1111,,,. II I . • " - --------- - - · - ----- --- ---- - ---- ·-- I ,I I I ' I IJ ' ' ''I' II' I I " I,,,,. ·I r;;:::; ___ ;::::_:_:-:_:__~-..:-. . -:.:.::=:-=----_.:_::-::=::-_::-.:-=:::::::-~-:::.... .~;;-n , .j: 'ltll ,~. ,; jl ,,,,, I I t 't''!i ,,;111'!•:1 ,,,,,1111! 
' I ' -- --- --- - - - - - ----. . - . ----- --. lijiJ . 'II I . q, ' I I ,,, I I HI , ,,, 1'1 
II I I l lk lj' 1 1 1jlj l rrr1~~-:::.:.:.--:: :::.--=--..::'=::-_·- ·::_----,-=--s.=:=::..=:.-- ::::.-::-=-:::;:.~~--~ :.j, ! P' ' '1 1'1 1 ,,,! 1 1 ~" 1 j'' l' ' l i~ li l 1jli i ! ·P· II:I I~~· 1·11 .. :·,,,11..,1,.:1 I II II I I II jl ------ - ------------ -- -. ----, jilu J "til Jli ~~~ J I JJU I lt,l I''[ ''J'j• ljl' 'II I 'I . . 'I ·I' 'ii---·-:..:-:=.=::.::::=-=---:-=.=::...:=,.::::-.:._=_.--.:;,-,:·: ~,~,,.,, ~ ', li ul' ' II' .,; i .,, ·:li: ·ill" I:.!.· ·! ,, :.,, 
Ill! '1 1, 1111 ''l'i!:,l·! ''I · ~ ~~~r~~Y-;f:~f~}~~:=z.~t£~~n·~·fiil1 !1' 1i: l ', lli:!, l l!l; ·, l'1 r1 '11 11 !'l !l~:: 1li:1i!:i i! l .!!i', li!lil'lil· ~~ ,,,li! 1 ! 1 l!i·,, !i;ihl , I 1 j l· 1. ::.:..:.·...:=:-=--• ...:=..:..::il!,lll '!t i l ·'1 .. 1,1 1''1' ''''· '' jl•' '.''· I, ''· ,1 ~ ,1,1ht 11 u.·, 
ll!, ~~ I ~~1~!!!! : tJ!,~J!!ili l! t~~~~/ 1;1.111:~[\l~~ i ~:~R~11(l~ ll1 ll!!l)i1J!!i~~l!]!!~i: ~~~~~~~~i(~i~:ll~ii~!~!~Ji i!~~~~~~!\~L 
!1· ·-·r ··,·j· .-,r·· l·· .,,,.:., .r< ,.,. ···t··· ··'· · .... .. " -"• 1: . ~t·-, "~l.·· ·1 · • .. . 1 .. . .. --··---- - 1 - 1-;~t J.~ : r,", • !Hr~~ftt t, -:;L'd 't)i!}i'; rr~ ~ ·,.r~} ,'i'-i~ ,r,· '~.:!·; ·_·!,., •. ~ I ·~,1H'1.;_! :.~,.t:_lj.!.:>. ,· ~j.· . , 'I' ,ril,.;li~·t.·· t · ~1;; , ..... 1!·!~;~-~~:..,·-·r-~--:~ 
• ._ .. .. ~ tt •. , ····~ 1 1 .,, · l• t ·· " '"" •' .•.. -· ·-•,.-... •.(.. t ,. ·- ·· . ~ ···- ... Jj t ' , ~· ;lllj': · .,., 11:t ,! ;n •, , ;. c:.:ff'[H-i,- ,1. ::,, ,1 .1·!' dJ .. 11, . i·. ,, • r,.l t .. '.' r:·t;l 1•" · 1 '",~-,,';• :,1 ·. · :;.l-!1•: .r.J-· , ,.~ tt 1::1' ., •' I.;, · ' .. •·-·• . _ I ~' ~ "-lq .. l'I ~''""''"J'l' ., t•-,;.r. · •i 1 l t • ···•·t~lrj···~··:t ... ,, •. ,,,,, 1-lJ•·L,.,• .. ,L ••. 1 .· ,···t · • ~-ffi, . •. n , .•... -~ ... r: -j' ~;· {,'{ll'' .. 'tlt', ·i:·"'tr!"+P"'"tl~--1- . 1 '~1~: ··i '"·' ·iji.t-:-· :~·-·' r ~ 1 j.; J~ -~c- t ' ·. '~r' ' .. t·· · ,·.:;. ,·,i·.~~~-. •1*.·: .. · .. · ,· . .-~ ;! il t '.,~ ! u • ij!t1·.!; ·:~, t• : :,•. -~ .. ft .::1r!~ ' ·J t;r-·.· ~ ,t'~·::ii·;--:iq ··t~;. - ~- -... !: · , ;l~ : ~ , ·:·j'r'·;~ ,~-- ~ -~!h.-.... ~~.;--::~:--t:~:: ·;: -~ .: ~-j:ii . .- .. ~ :.,.:: ·r , f-l rt· q ~f.f ·+~· t - ~--, . t_ : .. I 1 'l ' ~ .... 111.:.: , ···U· I 1 ,. l'lh •· : :ttli : ·,-f, .;.:: i' 1 . , • .:t-· . .... + ~ ·r ft ,~llJ• .. t • ['fJ l.d u!. ;. ~l. .. -·t·-a. fht :J ... _ ... ,., ~ .. - ... '\.,~,;..: ol I [}. r''• r'\ 1 ~ lft~ '' • .. ~,t~q ~~~ , • 1 •' • I:.,. 1 .,, . ~l-l• •1 ? 0 •'• • I r •••-t f t _. ,fj, I~ 't • f"' '1, •,.t,l. 'oiJ • J"" 1 H d·.- '·' ~ '- ,- · , .l-' .. ,· .. .~ :·· t ·•· ,, rt-~· ' q .:r··:· -i· 1l't'"-l· :•! .· .. ·~·~ -.-~l .,,.: : , ·" tf --·· . .;-. =, . . : t,~· I .. :-, ,, . . ,!: ~--, ' . ! -. 1 .. Hf· ~· . • .. ,, 1 1 14 .,1 1' .. t· ttl: •. , 11 .1,.,, • .. 1 _ ,~..,, 1 .,-..J, _, • • , ., ,-1 ~ ., 1 ''· lir···, .•. ,L ~ ... I Wl~l fl ' lt! j•' 1 ) '~ -~ • J . ... ,,l 1 •,! '• t- 1J 1·''' 1 ' '.l;tl-1 ~~~-,: !t,, , ot', -<. ' JJI '.'":,•. l•: g• ,_, ~l l _.- 1,{ 1 1 ... . ..:. 1 1'..,1-,1,, ~, ·,, I, ' ·,.:! ; I · ~ • '"' ' ' I I I 1 ' I ~· f • o ,,, • • 1 • .-' '• 1 • 1 • t -' , .. , • 't-& - · •' •.. ' , ,. • l ' -r j ·i ,.l 'II' - I --I , •• "l"t, .. ~.l "· .. ,, ... l'l' J.. .{_ ... · h--1 1·• I. ~·· -· ,, .... "'·-·~ •.. , , •. 1.L •• - I - t- ~ .~d q~· · J 1 ·t~'t l; ;:~~.! •·!i't :;J~ · ~~lH~.-~·:·,~_:ij~ ~i~ , ·~: ::~: .. ::_,>~~~ 1.:•!!~! :~~:;·t ·(:~,. =~~t ;':' !:·r ~! :.~i~G-:i· ,J·:/: · ./ .. ;,~_ ~~~ 
_pJ,i!j ..l-1.1- I }t~"-- r:.~• - • .•• , ".x!' ' "' I' I. •· .. ~·+·• ·-to • ... . "!'·•·•·' • r·~ ., . '··1·-- .,r•·'·' i1A·•"· . .1 ,, .- . - , •. ,. 
' •l'd ··.:.1,- .H ,'1 •1 !'~ ~,:,!;"" I · !...1tf.,t'=J~:.-;:·.tr·:1;._., ,: · .. ·, _·:...-: ~ . j, , .'i\.' ~-t.!-'~.,!;·,·.;l:r:~:of:.,t.t:-·_ rJ, : -~!' ... :·;~ .1 - ~ -. ·:.r : .... a I J> 
1111· l:;{•lf'H•"•It-·,· .. ,·f,J ,, .. ,, • .,,. ·- ·• '• l· ·1t·.h•·"'" ' •·r.·U· ·•· , ..•. ,,;: .· •i- ... · :ift· .. · · , •.• - ", , •~-· _ 'Ll'! w ua., if: ~1~r~ ~, ·r· ~rr'r I . , :- ; ~~i~·fh t: 'l, -;:~ ~ :; .. ; -{~.-,, .~· 1 ~;-~ :.r~! - I : :',. ~· :, • r~v· i ~:.·1 • ' .. ;, '; ~- ! 1~-~.,~ ,-::~ ~:t.~:.,'l: I.:'.";!-... ~.; ' I . !-~:-r~~:..: z 
t~~ ~ ti · i. .=-t.!:r! t,, !1:J.. C.·~ i't .tr I; ·~~-h~ ::t t j ;t I .. ! 'I ~-'·, :~~.1,·1 ~--- ftt .· .. .. ;.,:.: rt t'ii. ,.:.: : . . ·; ;rfl'' ~ ~1 ~ .. ',- ~=-l ~ ·CJ·n~ "'~ !_:.' :;/: ~J ~~ ~~ . ; :; ,' ·:'' ... -~=-·~: ... ~~ I ::J 
.. j'-'l·~-··J1:1f'l"1 1 11· f ·:l •. ,.:·. I! J.J,' ·.;w·- .. l:.!l>"j·:.-,.,:· .a. ... , r=: .... ··.,l c :'j'J.! "' -,-'1! .. 't:.:;1 ··- -·;•l ,:· .·,,·.·· .-- · ----:;: ~ I t-~H.i' ~ It,, · , .. !j ,r,1 ; :. I . p;f!J!'l·~ ~ ~. ~ :;:'. i ,!>:i: ;;! ':r"~--:.: ~;_1..1·1·' -:t:+H-:-:n;., !rY".t~~ ~!tt ~"-=-:-· _.•,·.:::..·· ! .. ;·. :. ~~ ··:. ':.:. ·:t I ;· .lH• · .· : ~·- !r-·q~,ll' lt ·!•·• l · '!, - ~rl.Jth" :.:·.~t .; ,.r"f ·~ ': •· .!. , • . ol:.f"tr,:r' i!J•:·f. ·.,.'J:il -'[-:·,! '- :- '·. ~~, - . ----- ... ' ,., t '-tl:-: ·:'~~•jtqT t• u,)t L'·l~ l~'! t•d·li~,_.i~.•;;• ,-.tt:•!!:;~f! ·.···J::-J t~. ;i ,,·!;f' !\:~:·-.:~;:~,f!~i~-:-:-:!.~J".:if_.;:,~· ' .. :~·_.·,.~. ~ .... o;. .. .. ,._: ·~ ~ i11 · •. ,. ~J · 1..1'1 ! ........ !.j· ~t, .1Q · "'· J, ·- • '· t .• . , .. L' J ••• I ---~ , ,~··t ·'''"t'l'• ·l , ... I ,.. i.i.,.. . q J ' > ' I :;) .~trl n-: ;li~~· :;-~ .. :!. '·'- , !'i:: .• f,f~i: ; t1tr''ir .. _:; · .. j·i · .. ·\J~ -~ . ·_. n;~!:;! -Ji.. : ___ ·-.~~ • . '; ,.L:i:-i.=: :: • .. ·i .. ti. 1 _; .=J~ ·!r- · :·~r. · .. -;-~·!··· ~ ·c..'"> ttwr+h'!J:~ ... '~,-j:~ . -::~J~' '''Lr:,: ,!Pp:-:~·h~- · ·"t~ : ~ ; 'r-11:· , 'i · ... -·}.:r'~-'" . .--! :.··i +~-;-.. ~~, .-·~;; . . -:"'.l ' ~~: ... ,r~: ~ · ' . -~,-~Iift .. r. :.~ .~:·,J- . -~:.:·-~~-~·~ ft.tt'tr , , .. 4' ~ •·.t !1, . .;:11 ·~I 1 •t:·· ~-'I. , .1 ... . ,11 ,.,.,rt . ..~ . . i .1., .J rt·· -. 1-f1 . ,, , '~ • .-4 .... ~lt,•t ... I +1-.-.1-1 , r:. ... , ,, . 1, 1 ,.. ~ r.~::~:;'-. . : .i i_i::-... :~;.~ .·n!-!• r.,1H .. ':~ .... f~!:i:!-:1: • ~!i:.'. ~;·,·;·J:._(: ,i-:1~_.:_: .. _ •• :-:..: j-:..;~:, .;.i!.iL~';.i:, .;..-.:,;w4. ~ 1";i- '.· · .. i~·~ ... : ::. ;L-~;,· .~ .. ~-~ .. --·hL i 
-i' ' l'•ll '" ll i.l)li1 C:'!'lHJ,'" .•. ,.!•-·,: .. n.,--ij] · . ' i ,,, .. ,,,,-;;'i'•-,····;t .. !-' •.•. ,;.;·.;;-,-ii···._~ •• i-.. -4! I'-~; 1~j;..., !··· : . ._· . · ··~·'· :::1'· - :,u • . " : .. ,.,; I 
·1-: ·l1+.r:~ ..... -n-t t.b t,t•1 'tt1·.-~·;; )::.;.;r:·,:;.!t :1.:.:;H~ :~ : ~ j; ·:! ·~t: !.~ 1-~!.:t··,;-!-i ,.r:v1!:~!!!,.:.~. ·;:·•1'·:-'f·_; r. ,. 1.· •i'!,~: ~~-~·r-· tf"L1i,;L:"L ~~~.·::t; .c -';n:!, ;:r:~ ~. : q:_::; I ~ ., l · t - ~ 'T ' 1 • · I I I 1 o • · • 1 1 · 1 I ". l; • 1 I· J -' •.t t-;1 • T • 1 0 · • ·. rl-• •· 1- 1-.1 · ' 1 • 1 'l ' •I 0 • ~, • •· I • ·• &/ , ·•• 'i • .. 1 .1~- ; ' ;J' ''!--l''!i ·lji:\1; <lfl o11 "~·; · j lt:,! .. ll•;_j,~l ' i • j I "; '1~:·· .·,..,_!-;l, . ;:-- •,:,c:;! .'';:t< ' · ~~:~- tr-1 . . ·. 'rl~ ' [i.ll~~-rttiH:i-- : .. .,,;:t1 .J'rii.;"H ..... : : ~ . 1: . f-r{~ ; _i_~f-!-t .. l1I '-. 't .. ;~~~i-· L~ ,1 P : ~ ~~ i f-l 1-.:~-, ~ - ~-:'l:.:~ .t J:,: -;·-:~· . . ~ f: ··;-i"• :: •'- · ,:-if-: tor ~,. .iT- ;; tl~~- ~ i;. !~:l--' ! ' "Jf•\•1-,J ;- .~.; t, ,-;~ ·;•-;~.---... -j 
: ~:-~:·1!t 11 ~ 1,ul~,:·\:·r . : 1~~-~·i t ;~-:;:: _~:~'l ·i -~· hl ~~ · ~~r=~:~~ ; ... ! .. ~-::l--rt .i· J ·-~! ,}ll'>i·~·~~:~· - :.: : :.~~-~~.:rL!:~ J ., .. :· ·.·:~:f1~:-t-r'·~: ;·:.iflf~f: · :;.~!.·~=-3 I 
.:·•J t·· ·""fl11-."r- ~ LJ! ... Jr·~u .. ~1 :- :!·r·:t·; _, i! ::·t:~ ' .'.l. r,: Jt ' i: · 'r, ... ~ ~,. -,.,._..._ ' -~!:o.J! .- ··: •• l--J, :; ·· ·r · ~- ,., .. . ;•-.:-.t- 1 l ·~, -.• 1lc.·.;:; m;;-.~ , ; : r'11 ~1,j,f1,: ~: ~ -:,~:~!. ht;;~·~.:.+11J}r +;:.t.;J_,~-!!:..:,. ·J·;~:!J•ct' ,· ;::.;;;r..;~1T;.~.:Jr,:~r~' · .,,!~,F'·~::r.1~"-. ,.-_· -~ .• -!:Ji',=:!; .;;:J:.:J:s:: · ,.:.~ ~..:.-•:;..~ I ~p '. "i . I: ~· t ~ t :. : ·/' !! ·{ ~-4 :~-~ -: 111! ,; ... ; •. --1 1 ~ ~- ' ••• ~-4-i:4.., :t: .... :P.; 1 · • \·~;~ ;,_~:· ' '"-:']it!' ":!{1; 1 :lt~ ;;•.· 1 .'!'I\"<,;··~ ;--! ~; ,.· . :.;..!· i1i~ ·~' '~- .:~-~ ~,-f.' . .:. "d: ':;: ~ 
.-,jr l. :-'t' f ,t-L; tll~ ·df · .. --*-L4Hl••f•l •h+•·, f! t-~ ilr'l.,.,,,·lltllfftt•J• ' •·1 1. .. -T't;._;h:t:} - - t :t !• • t.:.f,l_ ,. , ..... , . -.•~ - ~ : .: ·o•l (f !f;!~l:' ~~~•·•·•· ~ 












Silicon Compilation - a Hierarchical Use of PLAs 321 








COMPUTER-AIDED DESIGN SESSION 
Ron Ayres 
~1 11con comp11a~lon - a H1e r a r c n1 ca1 use of PLAs 323 
CALTECH CONFERENCE ON VLSI , January 1979 




COMPUTER-AIDED DESIGN SESSION 














D ·il-- ~~.-bt~·, ""fl~ r~rtFi · =tfffii , 
f-· 
- . 














'f ' l-it --l · e_rl n flti +-I TTf-r 
.,_ 
::l 
"" }c !z -,- O -o 1-.. .... '"0 I Q) ~ :~ 0.) c ;, ~ ~a ~ a U'l ...... 
fo.. 0:: Q) 
r.1:: 
CALTECH CONFERENCE ON VLSI, January 1979 
326 






· - 0 lL.. Q) 
0 
