



N O T I C E 
 
THIS DOCUMENT HAS BEEN REPRODUCED FROM 
MICROFICHE. ALTHOUGH IT IS RECOGNIZED THAT 
CERTAIN PORTIONS ARE ILLEGIBLE, IT IS BEING RELEASED 
IN THE INTEREST OF MAKING AVAILABLE AS MUCH 



















	LOGIC SYNTHESIS FROM DDL
	 N62-20905
DESCRIPTION
	 Quarterly Progress Report, 1
Oct, - 31 Dec. 1979 (Alabama Univ. in
If untsville.)	 18 p HC A02/M:F A01
	 CSCL 09b	 Unclas
G3/61	 16743
January 1980 a
Fifth Quarterly Progress Report y
October 1, 1979 - December 31, 1979
Contract	 NAS8-33096
"DESIGN SYNTHESIS OF DIGITAL SYSTEMS"








This is a technical summary of the progress made
since October 1, 1979 by The University of Alabama
in Huntsville towards the fulfillment of the con-
tract NAS8-33096, from the George C. Marshall Space
Flight Center, Alabama. The NASA Technical officer
for this contract is Mr. Robert E. Jones, Electronics














LOGIC SYNTHESIS FROM DDL DESCRIPTION
	
'i
The implementation of DDLT%N and DDLSIM programs on SZL-32 Computer 	 j
System is now complete. These programs were tested with DDL descriptions 	
C
of various complexity. Testing with newer system descriptions will
continue.
An algorithm to synthesize the combinational logic using the cells
available in the sL'andard IC cell library was formulated. This algorithm
is now being implemented as a FORTRAN program. A description of the
algorithm is given in the Appendix.
Some corrections were made to the MINICOMPUTER description (Example 5)
in the First Annual Technical Report. An updated version of the description
and the corresponding simulation results are shown in Figure 1.
The future work inciudes the completion of logic synthesis algorithm
implementation, extension of the algorithm to include the synthesis of
memory elements, registers and the register-transfer equations.








5: OE), M(25 6	 12
6: 410,08US(14).
7 9 4LA>S I AH I
9: <TI>Ho Figure 1
















26: HWN<- I	 -!),FE
27: FE(l):HUN:JP(l)JvAH -c-PC.,,) FU)J FC<-CNTUP4FCSf ,
2b:
29
t ,..	 ..	 3 0 s' . a»-w .s.. ».	 , . ».- .... ,
	
" ,^.) X 6 T Y l - > C E F -
	 .. , ; _
	 r»
3" 11	 EFC	 .`TFCI`)7,PA.F<, . AL"F; TP°C)"T"N6175=^ (AFAR')"; MSR<- NBUS.i
^..^,,....:...	




a E 	 CFO OD3 - >XAND"'k 103'->XAND-- 4203 - >XISZ




XAN( CW):]"i rl)) .kc-ACC` i)P(C))RAF<-ADR i:..
PMl P BUS=K(MAR)._NBR-4 -M,5.,
")-'077'7- CP (3)7')iZC"<"-`N 3R'^ 'ACG<-SUNSMHR `?Cl^: i"•" FE.





i.^^.»	 l P . (2)I ..NEiI;S=h'(iAR) ^NBR<•NB4S., 3.,<	 .........
41';
_^._^.».,_^..








Q'C'A C6 ] :`)"P (T)) F"ER { -ACC:/ )`F (^') 7°N I^Fi c`^ A D R>'vx . 	 _^. ^..
,F x.44,_-	
._._....li'C3l','ACC<=Qt+1k3US=KBFirN(.P^.pF)<-NBUS./lP(4)a•aFF.
: - .'"`T'»^ ^ 5 't ^
	 ^.,.,a,........_^ d S K (?°





F° (s`) J`!'H°US'- K6'R°i




-AR.<-.0:'r)P'(2)YMBUS=M`(NAR)s.,.. 	 ... ...... _	 ..
r
^ 
	 Fi"c'^"N'2^i S : i l P`( ^i') `l^"C< -^Kli 6i'("4"i'D f `) i - ^ F t ;';.._..._.^».r ,
Figure l(a):. Continued
^a r<IN>M(0:3)/5,6,7/8





<DU>TN/C F(.r I 	 'PC # VAN T..t
<UU>FE/MAR,PHR/IN,PC/ACC/
%CU >E 	 ANo WR	 I'R /fit' PAM	 ,... 4w _...
<S I >
FPOOR QUALITY
^,,# TG IAL* UESIGN LANGUAGE 3MLATGR	 VFFSION- NSFC 1979 SIP'LLATION HUN	 1
' pooft
TIME U	 IH	 PC MA C PAR	 PON	 Ik	 PC	 ACL MAN MBR IN PC ACC





000a ^0 0 6 a F° a 0
	
To o c, 0 .. , x..,.,y. , ^,. -.,^rR,,_ ^r	 .. _.3,_^	 .	 ,	 .
' t	 16  8 0(.105 0005 009 0000i
,aoo g t.00 0 s., .ao9 TM0000 , . .	 ^.__.
48 0 06 ooaa 0768 01-0 ooua
'72 010 1030 1030 011 0005
_ ...^	 006 -000 , 1 - 1030- 0 1 V-000 5 a...... s^ _	 .,
96 011 1028 1028 012 0005
x"-11`2 -- '- 004-4093-1078-012 -0005
€	 120 012 2569 2569 013 0005 1
152 006 0001 0769 010 000b
°_..»..001..0006`"11769°,010"-0011 .,x,,.,.,, r.-,R1- 1 - ....,
176 01"0 1030 f, 030 Oil 0011
"-'192"'
`_.".	
--^-^---006' 0002 w, 103'0-"01 1"001 1-_`_.
=
200 Ol t 1028 '1028 012 0u1 10.0.0`" 
x1`0"9	 `10-,^ 
0. 1,2"0`0`11	 _ ..
224 012 2569 2569 013 0011 r=^,. ^,.._,... 012"2569 "2569' 009-001 1
256 Q06 0002 0770 U10 0031
 
0.02,,.,M0007-0770,r,0-10-0016_. . ....>	 ^,,.^..,_.....,.,... .. ..,....._
280 0110 1030 10S0 011 001 8 j
30 4 011 1028 1028 012 00.18 '}
0 Q04 "4095`.,1.028012_0018 _ .
	 p ,.	 , .__.	 {
° 	 328 012 2569 2569 U13 0018 
01Z E56"9°2569°°009-00.18- - --
360 006 00 0 3 0 771 010 00188
T 0-O 0'0 8"O7fii
384 01,0 1030 1030 011 0026
:.	 408 011 10 28 102b U12 0026
'2 4 H 	 0 0 4`_0'0'0.0""1"0.2 8	 0	 3	 0 0	 6 ,.. _,1.	 _	 2 ..^ _._ _. _ .. _ ^.^ .._._	 .^
432 013 1543 1545 014 0026 d
144 8 0 07-0'0^Z"1'5'43-^0` 1-q--O 0'0'0-
 b 0 0	 3584  	 015 014












The University of Alabr►ma in Huntsville
P.O. Box 1247
Huntsville, Alabama 35807(205) 895-6088
ABSTRACT
Hardware Description L.nguages are used to input
the details of a digital system into an automatic
design system, An algorithm to synthesize combinational
logic from the .description in one such language (DDL)
is discussed.
*Submitted to the 17th Design Automation Conference
Minneapolis, Minn. June 1980.
R1. INTRODUCTION
iiardwaoe Description Languages (IiDL) provide a convenient means of
:Uiputttng the digital system design details into a design automation
system. Although tiDLs were originally designed to be just description
media, they have been used in other functions such as simulation, fault
test generation, microcode generation, documentation, etc.. The use of
HDLs in LS1 design automation systems is not widespread because of the
difficulty in translating the HDL description into logic diagrams (or
connectivity lists or equivalent), non-familiarity of the hardware de-
4
signers with high-level language programming aspects, non-uniform design
}	 methodologies and the time and cost involved in transporting and tailor--
t
ing the HDL software developed at one design center to the other. How-
ever, the advent of VLSI forces that the design be thoroughly verified
at the earliest possible time in the design cycle to minimize the fabri-
cation costu brought about by the final changes in a design. Since a
suitable breadboard for a VLSI circuit is the VLSI circuit itself, a
thorough computer evaluation at the outset is mandatory. Figure 1 [1,2]
shows the complete schematic of-an IC design automation system. The
Computer Aided Design and Test System (CADAT) of the NASA Marshall Space
Flight Center [1] is organized as in Figure 1. Digital Systems Design
Language ('DDL) [3] has been selected [1] for the CADAT system. This
paper addresses the problem of hardware compilation from the DDL
description, i.e., the process of converting the output of the DDL
translator into logic diagrams (or connertivity list, net list, etc.).
2. DDL TRANSLATOR [3]
The DDL translator converts the DDL description of the digital
system into a facility table, a set of Boolean equations and a set of
I.
2
register transfer equations. Figure 2 shows an example description.
.,a Boolean equations generated by the translator are in Sum of Products
(SOP) form. The Boolean functions in the DDL description that were riot
in the SOP form are retained 4s they are by the translator. The de-
signer can thus generate all the Boolean equations in the SOP form only
if he desires. hence, the synthesis procedure: discusser] hare assumes a
SUP form for the Boolean functions.
3. THE STANDARD cnmi, lmmay
Table 1 shows a partial list of the standard cells available in the
CARAT system. Number of devices for each cell and the cell width (as a
measure of the silicon area needed) are a l.so shown. The last r_._► lumart
shows the literals in each product term of the fuor-ti.on realized by the
cell. Note that the patterns containing all is (11, 111, 1111) anu
those with one product term (1, 2, 3, G) correspond to a single gate
realization. Zt is desirable to realize a function by using larger
standard cells (if possible), as ahown by the implementations shown in
Figure 3 for an example Boolean function. The standard cell library
provides four cells that can realize a larger function than a gate
equivalent, i.e., 2222, 2112, 222, and 22. Also note that the maximum
number of inputs to a cell is 8 (2222). Hence, we limit the number of
literals in a Boolean function to be realized to 8. A function larger
than this needs to be redlined in several 8 literal units. For 'example,
Z- P+ Q	 where P and Q are 8-literal lin is
Ir	 r and Q are separately realized. A, NAND
cell is used to combine them to form Z
3i
4. THE SYNTIMSTS ALGORITHM
1) Scan the Booloanfunction to be implemented and count the number of
literals in each product term to generate the literals/product term
pattern for the function.
2) If the function pattern is that of a SUM term (patterns containing
onl ,  ls: 1, 11, 111, etc.):
	 implement using the NOR calls with
proper number of inputs followed by a NAND call; stop.
3) If the function pattern is that of 4 PRODUCT tarn (patterns 2, 3, 4,
etc.): implement using the NAND cells with proper number of inputs
followed by a NOR cell; stop.
4. Reduce the product terms with more than 2 lit(rals into a term with
1 literal	 Wie--e tarsus are kuplemented as in Step 3).
	
If' the
function pattern reduces to all ls go to Step 2, else proceed.
5. Scan the function pattern to identify the : ttandard patterns: 2222,
2211, 222 1, 22 in t1wit order.	 Eliminate the matching portion of the
function pat"Ierri if the patterns or partial patterns are found (A
partial pattern is one which matches the standard call pattern
everywhere except in one digit, for example:
2221 Is implemented as 2222
2111 is Implemented as 2211
21 is implemented as 22)
6)	 If the function pattern is exhausted, sLop- If not, go to Step 2,
Note that the algorithm does not minimize the Boolean function.
Only the literals are counted, not the actual number of input variables
needed. This might result in slightly higher cost implementations of




could be impleir.ented with two cells: 1880 and 1220. (14 devices, 20.7
mils). Ustag the algorithms
A+BE+OF
Stop 1)	 1 2
	
3




Step 2)	 0 2	 1 <---From Stop 5
The implementation needs three cells: 1870 and 3, 1220a assuming
that A is not available. The cost is (20 devices, 27 mils).
CONCLUSIONS
An algorithm for selec tag standard cells for implementing the
combinational logic is presented. The algori.tivii is ouitable for imple-
mentation as a computer progtam. The Complete synthesis algorithms for
the CADAT system are now being investigated. These. algorithms extend
the algorithm presented here to include the memory cells (flip-flops)
and corresponding register-transfers. But the algorithm presented here
is suitable for any LST design environment.
ACKNOWLEDGEMENTS
This work is supported by the NASA-Marshall Space Flight Center
under the contract NAS8-33096.
REFERENCES
[11 S. G. Shiva, "Use of DDL in an Automatic LST Design System,"
Prod ^ lnternati.onal S}nn. CIIDLs, Palo Alto, CA, October 1979,
pp. 28-32.
"Hardware Description Languages - A Tutorial," Pro_c. TFBF,
D(,c. 1979.
t
5(31 D. L. Dietmover and J. R. Dulay, "Register Transfer Languages and
Their Translation," in Digital $Xotems DasiSnAutomation: Languages,
Shitulation and Data Baca, M. A. Brauer (ad), Computer Sciences press)
Woodland Ilillo f CA  1975.
t
Table 1« CARAT Standard Call Library (Partial)





1120 2 input	 A CiR 4 5 . 8 A I3 1,1
1130 3 input	 N lit 6 7.7 A + B + C 1,1,1
1140 4 input
	 NOR 8 9.6 A +i 'B+  C f= b I,I,I,1
1220 2 input	 NAND 4 5.8 '94 2
1230 3 input	 HAND 6 7.7 A-,B•C 3
1240 4 input
	
NAND 8 9.6 AA	 D 4
1310 Buffer Inverter 2 3.9 A 1
1620 2 input	 AND 6 5.8 7--i 2
1630 3 input	 AND 8 7.7 A#BBC 3
1640 4 input	 AND 10 9.6 A•B-C•D 4
1720 2 input
	
OR 6 5.8 A + B 10 1
17301 3 input	 OF. 8 7. 7 A + n + C l,l, l
1740 4 input	 OR 10 9.6 A + B + C + D 1,1,1,1
1800 4 x 2 input AND + 16 17.2 2,2,2,2(9B	 UP+tit)
4 x NOR
1840 3 x 2^ input AND + 10 11.6 C (AB ++ DE) *
2	 input 'NOR
1960 2 x 2 input AND + 12 13.7 AB+B+F+CD 2,101,2
4	 input NOR
1870 2 x 2 input AND + 8 9.6 (AB +CD) 2,2
2 inpu t NOR
1880 2 bit carry 10 14.9 (CDE) +BE+ D*
Anticipate
1890 3 x 2 input AND + 12 16.9 99 + CD + BF 2,2,2
3 input NOR







i`	 *	 f 	 s
W 0!.	 Z V
Z ^'	 (L C9V
WW	 O	 fL'OJ
^O	 W	 p









1	 Q	 U)	 O N
	





t	 Oa	 v)o 	 a
Za
9'
Jz 	 ^nQ.	 0Z	 Z	 ^^^z	 o	 0	 J1
p	 H	 W
^t	 Q	 cr Q
it	 w	 z	 0a	 X	 0Z	
,^
k0J	 Q	 W	 a: a 	Q	 h, Z	 (1) :1
W=	 kZ-	 Q	 =V	 „'0O	 AO	 m	 q	 Q x F- to 0i;	 J C7
f.	 W Z	 H	
G	 yN fr.
	 J
••a	 cD	 a 0 ^
 Cr.	 W
c^ s	 CL u)
=	 O W Z	 A




































4^N` V7	 • i
^ • O
r^' Ut	 •













































































































V ^ ^^ d0
< > - U t	 t1 *^	 fl J W
4 v V	 v v	 v v V







G +^ N In 1/1 4	 Q :1 lJ' (! LL ^	 . ^ 7 0 0 1 f- ';'' 7 ^^ 4 m — f- — 'J !X,
O N
	
lr ..	 to	 to +;a	 O fU -+ 0	 — to U — In h
'r1(V M
	 'V	 NMiNN	 NNfnM	 tnlr in l!17 it
U'1 U •




8cr y f- U, + 0	 C; C	 -• on i s 'V I	 n M co a to n 3 A.	 a •tM	 fV rn ...	 7' -+	 It	 7 J	 ^,	 v 	 is v 1+1	 -, IV 10 O	 if) 'Y,M	 (MNN	 N	 tV'V..frV	 N'V "^M	 tr. to: q :1 a ON
tfJ




r+ -ALt L L 11 u, in c1 tT O cr U	 •G Pool M s` N tr J CI O 0 ^a ^+ r Z u, ry N




.+ b v .^ .n .^ r+ M M v-r f-I .- .- I -4 a-' C r. .r 	 .r C cl o1 f\ f on fV L -
.p
^ M
r fx u co r- -. a r-:o K	 v ti i,-I,	 t:. M =s .n	 c3 (, tic rr
Ili




















































	 - •	 r
ORIGINAL PAGE f5
OF K"On QUALITY
..... x..^..^.-.... ^	 w...












C	 .	 • : _
u i r.;,	 G	 + + in




«	 -+ .^	 ^,	 1	 1	 r nl
U j U IX	 Ix
..v0..,	 %.. f + t t * +
.VJ..— ..)t ..^.
lV t t	 : r iq a Li •- .•. 11 .-. 11	 +	 +	 +	 + +
s. V \ i ^ V N rV ( Vi r+ M C M	 ••. .•+ .•, NI N ?	 Ir
2	 k	 It	 11 11	 11	 It	 11	 11	 u	 <t !'t	 it	 if	 'o	 « M	 « s
1L	 It	 •• •-• iVfr ^ US 4J 	 .. 'L ,L ,l tit il. LL	 11




























N 4 W	 I
z 1  IA rd



















	AB + CA + EC + G	 -	 Function to be implemented
2	 2	 2 1	 -	 Pattern
Implementation Cells Needed	 _No. of Devices Area (Mils)
1 2221	 2222 1800 16 17.2
1220 4 5.8
*Total Cost 20 23.0
2 L::K2	 E2 i
^22^	 ti 22-J 1870 $ 9.6
1870 8 9.6
1220 4 5.8
Total Cost 20 25.0
3 [j2 U U Li__^ 4 x 1220 16 23.2
1240 8 9.6
24 32.8Total Cost
* Least Cost Implementation
