An extended cell set of self-timed designs by Khoche, Ajay
An Extended Cell Set of Self-Timed Designs 
Ajay Khoche 
Department of Computer Science 
University of Utah 
Salt Lake City, UT 84112 
Abstract 
The high level synthesis approach described in [I} uses hopCP[2} language for behavioral 
descriptions. The behavioral specifications are then translated into Hop Flow Graphs 
(fIFGs). The actions in the graph are then refined such that refined actions can be 
directly mapped onto asynchronous circuit blocks. This report describes library of such 
blocks called action-blocks. The action blocks use two phase transition signalling protocol 
for control signals and bundled protocol for data signals. The blocks have been designed 
using ViewLogic Design tools. 
The high level synthesis approach described in [1] involves compilation of hopCP specifications 
into asynchronous circuits by deriving inplementation for every action in the corresponding Hop 
Flow Graphs(HFGs). There are three types of actions in a typical HFG. 
1. Control Actions: These actions denotes the synchronization. ' 
2. Data Actions: These actions involve value communication in addition to synchroniza-
tion. 
3. Expression Actions: These actions represent computations. 
All these actions are mapped onto a circuit abstraction called action block. These action blocks 
are classified into three categories 
1. Primitive Action Blocks - These blocks denote the leaf cells of the compiler e.g. C 
element, Merge, Register. 
2. Predicate Action Blocks - These blocks denote the conditional expressions. 
3. Function Action Blocks - These blocks implement various functions like ADD, SUB, 
SHIFT etc. 
All the action blocks are self timed blocks which use two phase signalling for the control signals 
and bundled protocol for data signals. Some of the primitive action blocks like C element, 
Merge, Call, Select, Toggle etc. have been described in [3] hence are not described here. 
The report is organized as follows. For each block its symbol is shown in the summary page. 
The schematics for all level of hierarchies are given with the textual information about its 
inputs, outputs and iyts function.This indicates no. of logic modules used by that schematic 
at all levels. The exact no. of Actel modules used can only be found using Action Logic 
System(ALS) but no. oflogic modules divided by three serves as good approximation for Actel 












[7, ° 1 "~ 
ACK CRE""'r 
BR£QC[7:01r-. 








































{7: 0 J 







:IN [7: 0] is ~ 
AOUT[7:0) fsACK TOr-SH 


















Inputs: 1[7:0], WREQ, RREQ, CLR 
Ouput : 0[7:0], WACK, RACK 
Function: This is a read/write register. The 1[7:0] is bundled data .. When a request comes 
on WREQ line the data on I lines is latched in the register and an acknowledge is produced 
on WACK line. When a read request comes the data is available on 0[7:0] lines and a read 
acknowledge is produced on the RACK line. Upon clear the register is set to zero. The register 




c I J:) 
1 , 
r- -
WREQ n JO .. l.~:l UT RREQ 
rL 2 2 
r ~~98 0[7:0] 1[7: 0) ... ... 







Note: The regS is t~no 
4 
r/'V-J register 4 
no of ~ogic modul.es: 60 
S:HEET~ 100TE:: IDRAWN BY: avk 
.. I 
'" 
c I 0 
Boolean Register{Breg) 
Inputs : S, R, CLR 
Ouput : Q, SACK, RACK 
Function: This is a single bit storage element which can be set or reset by transitions. When 
A transition on S line occurs the register is set to high and an acknowledge is produced on 
SACK line. Similarly when a transition occurs on R line the register value is reset to low and 












2 T 2 level CLR toggle Q 
A....-. 
-BJ}'o~Y EQ 
~ A'" -- -
SELF."C 











" • BREG 
no of logic modules 63 
I DATE ~ 10/24/91 I AVK SHEET: DRAWN 8Y: 
A B I c D 
A. I B I e I D 
vee 
~ 











B IH" Y Q 
p 2 






level toggle . 
SHJ!:ETI I DAT1!:1 IOR.AWN lSYI 
~ 
Greater than or Equal to(GE) 
Inputs: A[7:0], B[7:0], REQ, CLR 
Ouput : T, F 
Function: This block tests for greater than or equal condition for bun.dled data inputs A and 
B. When A transition on REQ occurs the condtion is evaluated and depending on the result of 
condition check a transition is produced on either T or F. If the condition is true a transition 




I C I c 
1 1 
A[7:0] GE 
(7 : 0) OUT 
OUT 
B[7:0] 















\I d e 1 aye J Ir JC,.l~.a UT REQ 
-, 3 









no of logic modules 150 
I DAT!!:I I avk S'HEl!:T: DRAWN 8Y: 
A I B 1 c I 0 
A I e I c 1 D 
A[7: OJ B[7:0 B7 
A7 A,~" Y sJ)~:r 
B7 -
A7 A. sl~'O» y , , 
~ 
B6 
A6 A_"y B ))~/ 
B6 A 
A. T sl AN":" y A6 BlAND).) Y I I :l 
- A c1o~~ r-B5 -----;, ~c0-y 
A_ 
,-EJ A5 s ))-~ y 
B5 A 
"---A5 --;-J AN .. ' Y BJAND') Y ----./ 
2 2 
B4 
A4 A,~ '- " A B ))~>Q . ' 
Bl AND:" Y .~/ 0=,-" y B4 A A. I I Bl ~'.:" y sj-' y A4 , .. _/ Bl ..... C J 1 
~ OUT 
I- B3 A I-
A3 ~ JJ~'=)" S] AND',; Y 
B3 A 
A3 ;.. ~AND0Y A B 1-- U ) ( sl.-
B2 
-;, ~'D'\ Y c O")y-
-




A2 BlAND') '( SJAND,y:-~ 
Bl :1 AND'J Al : JJ~'~'" Y I-
Bl 
A. 
A_ Async Library Al Bl~cz) y Bl-QZ ) Y 
~AN00Y ~ BO 
A AO S ))~~Y 
.~ 
4 EO A a GE b 4 AO A. Bl 6V• OZ' Y sJ'"o,) y 
----./ 
A 
Bl~o~ y I DATE, 10RAWN "y, avk no of logic modules 102 SHE:E:T: 
A I a I c I 0 
Equal (EQ) 
Inputs: A[7:0], B[7:0], REQ, CLR 
Ouput : T, F 
Function: This module checks for the equality condition between bundled data inputs A and 
B. A transition on T is produced if the condition evaluates to true otherwise a transition is 
produced on F. When CLR is pulled low all the outputs are set to low. 
6 
... I B I c I 0 
A [7: 0 1 B [7 : 0 1 
1 , 
B7 A7 A_ 
B lJ--) Y 
,~ 
B6 
- A6 A A f-
B JJ~:'; Y B 
-----c y AND4 
B5 I ,.......E. AS A B ))~~ Y 
B4 
A O UT 
, A4 B ))x .. .).. Y A 2 ~ 'NO' Y 
-.-/ 
B3 .--: .-J 
A3 A~" y 
B ))XNO 
,-.-/ 
B 2 A 
A 2 
J.. _ ~~Y 
f- B JJ x .. .;'} y f-C "'NO" ~ ,~/ I r--" Bl ,.......E. F Al J.. S I!:t..EC 
B ))"'0' y XN 
B O OUTT T 
A O A ~r-






:I I' .ID. l ~4 UT X Dg~~l UT 
~ / EQ b 4 q. 4 
--=-
B u nd l ing de l a y s 
no of logi c m odule s 66 I DATE: I avk SHEET : DRAWN 2IY: 
.. j 
" 
J c I 0 
Less Than (LT) 
Inputs: A[7:0], B[7:0], REQ, eLR 
Ouput : T,F 
Function: This module checks for A Greater than B condition. When a transition on REQ 
input occurs the condition is tested and if it evaluates to true then a transition on T is produced 
otherwise a transition on F output is produced. Upon clear all the outputs are set to low. 
7 




A(7,0) ( 7 ,0 J 
2 OU 2 
8(7,0) 17: 0 J 














. a LT b • 
no of modu~ es 1.38 
I OAT!!:: I DRAWN avk SH~~T: BY, 
A I B I c I D 
A I B I c I 0 
A[7: 0] B[ 7:0 B7 
A7 A B 1I-~ y 
B7 
A7 bJ~O') 1 1 
B6 





T BJ~o, Y A6 bJ~O') I~ I ~ f- A ~C1OR~ f-
B5 Bl'No~ Y ~ A5 A ""'- -B 1I~'/ Y 
B5 A~ 
A5 Bj~.o,") • BJ ~o'./ Y 
2 h 2 
B4 
A4 A 
B 11-:7 Y A Bl'No, Y 
0='Y 
B4 ~ A O UT 
~ I -;'_Ol"\ Y ~/ A4 >OJ .. o,. 
~ 
I- B3 A f-
A3 A Bl'No,' Y B ll~'~ '{ 
7---'/ 
B3 A 
~, Bl-c::a y A A3 B\. Bj .. o,,) • 
~~ OM Y A c B2 Bl·No,) Y Dr ) 
" 
I A 
) A2 B 1I~'~ Y 
B2 





A A1 B 11-,/ ~ Y 
Bl·No, Y 
---/ 
B1 I A Async Library A1 ~ ;J .. 00 y Bj .. o,") . 
I A h 
Bl .. o,' Y 
---/ 
4 90 A a · LT b 4 Bl,,00 Y AO BjANO'") y 
no of logi c modules 93 SHEET : 1 DATI!: , I DRAWN BY , avk 
A I B I c I 0 
Greater Than (GT) 
Inputs: A[7:0], B[7:0], REQ, eLR 
Ouput : T, F 
Function: This module checks for A less than B condition. When a t·ransition on REQ input 
occurs the condition is tested and if it evaluates to true then a transition on T is produced 









Al7:0) {" ~ OJ 
2 ou 2 













4 a GT b • 
no of modul.es 138 
SHEET: I DATE:: lr::rJ:t.AJ".n'~ BY: avk 
A I 
'" 
I c I 
" 
A I B I c I D 
1'.(7,0] B[7,0 B7 
1'.7 A '" a 11-0 /, y 
B7 
A. A7 al~D>3 y 1 1 
B6 
1'.6 A ,"y 
a ~/ 
B6 A 
A.-. T aI ANo ') y A6 al~o, y I ~ I f- ~ A~ clo~¥- -al ANo."\ y B5 ~ 1'.5 A,_ ----.../ B ll-;," Y ,~/ 
B5 




A4 A B ))-~ Y A al ANo ,'\ y 
A B4 ~ A ~o.»Y OUT ~~o,'\Y 
--1'.4 al~O') Y ----.../ 
f- B3 A f-





Bl ~o,' y A 1'.3 
al AA.,) y BL ~j 
A C o,,:y:-B2 91 ... ",0 1 Y 01 , h~ 3 1'.2 B ))~,:,> Y ~ ,~/ 
B2 A 




A '---;1. NO,'\ Y 
-
A1 
a ll~':'> Y f- ,~/ 
B1 
A "'\ I A Async Library A1 al~00 Y Bl-C1) Y I A 
slJt.NDl Y 
~ 
< BO A a GT b • A. '::ijAAO') Y AO al~D,j Y 
no of 10gic modu1es 93 SO:Hl!!:E:T: -r DATE, I DRAWN B Y, a vk 
A I B I c I D 
ZERO 
Inputs: A[7:0], B[7:0], REQ, CLR 
Ouput: T, F 
Function : This module tests for its operand to be zero. When as transition on REQ input 
occurs the condition is tested and if it evaluates to true then a transition on T output is 
produced otherwise a transition on F output is produced. 
9 





I- A6 el l-
e )"O"~ y A5 I A A4 of ./ i-'i' A3 A,. 
A2 sl 
A1 NO.;" Y 

















4 a ' - 0 4 -
no of l.ogic modules 39 I DATE, I DRAWN avk SHEETI BY, 
A I B I c I D 
Left fRight Shifter 
Inputs: LSH, RSH, AIN[7:0], CLR 
Ouput : AOUT[7:0]. ACK 
Function: This module shifts the data left or right by one bit depending on which input gets 
the transition. When a transition occurs on LSH line the bundled data AIN is left shifted by 
one bit and an acknowldge is produced on ACK line. Similarly when a transition occurs on 
RSH line the bundled data AIN is right shifted one bit and an acknowledge is produced on ack 
line.The shifted output occurs on the AOUT lines in both the cases. A low on CLR lines reset 












r~ AOUT(7:0] 2 INf;' ) 1[7,0) fr eg8 
HI p~;J ,~,~ . .. , .. 





















• l / r shi ter 4 
no of logic: modules l47 
SHf;;';;T: I DATE, I DRAWN :BY': 
.t-




































OU'I' [7 0] 
OUTO 










Asynchronous Multiplexer( AMUX) 
Inputs: AREQ, A[7:0], BREQ, B[7:0], CACK 
Ouput : AACK, BACK, CREQ, C[7:0] 
Function : This is a transition multiplexer. The inputs are multiplexed on the output when 
corresponding requests arrive. When a transition on AREQ occurs the bundled data A is put 
on the output C and a transition is produced on CREQ. When this request is acknowledged on 
CACK an acknowledge is produced on AACK. Similarly when a transition occurs on BREQ the 
B input is put onn the output and a transition on CREQ is generated and when an acknowledge 
signal occurs on CACK an acknowldge is produced on BACK. The input request should be 
mutually exclusive. 
11 






~r7 :0) C[7:0) 













BREQ ItJ::'Ql.~"~ UT R2 
-7 - CACK A2 
3 '---- 3 
BACK: 
Note : The delay 1 element has been used to 
-
-
compensate for the delay of XOR gate_ 
Async ib ary 
4 AMUX 4 
no of ~ogic:: module 45 . 
SHEET: I DATE' I DRA>rn BY, avk I 
A I B I c I D 






A7 A6 AS A4 A3 A2 Al AO 
-i-
-
87 86 85 84 83 B2 8J BO 
1)1 » OJ » ~ III » TL IJ:J » T~ IJ:J > , 1J- 1J- '1r- !J- 1t- 2 ., 
': .; -: 
" 
-< >< -< 









!< 8 Bit Mu::x: 4 
SHEET, I PATE: I r:;;RAWl-~ BY: avl< 
~ , ~ I 
Test and Set 
Inputs: 5, R, T, CLR 
Ouput SACK,RACK,TO,T1 
Function : This module is a single bit flag register which can be set or reset and later can be 
probed for the stored value. When a transition on S input occurs the flag is set to high and 
when a transition on R occurs it is reset to low. When a transition on T occurs depending 
on the value of the flag a transition on TO or T1 is generated. If the flag value is high then 
a transition occurs on T1 otherwise on TO. At clear the flag and all outputs are reset to low. 














T 2 level " CLR toggle 
A 
R II"":) Y EQ 










?UTT OUTT T~ OUT'T' 
-~,.- ~,.- ~r 
, 3 




4 TS 4 





Boolean Call (BCall) 
Inputs : RA, RB, T, F, CLR 
Ouput A, B, TA, FA, TB, FB 
Function : This module is modified Call module. It allows one to call one of the two modules 
to be called. The called module is a Predicate Action Block(PAB) in this case, which returns 
true or false transition. the returned value of the call is then routed to the appropriate caller. 
If a transition on request line RA occurs then PAB A is called by generating a transition on 
output A. The called module produces a transition on T or F inputs depending on the predicate 
evaluates to true or false. This returned value produced on the TA or FA outputs depending 
on which input Tor F get a transition. Similarly when a request occurs on RB input the PAB 
B is called and the result are routed to TB or FB. 
13 
A I B C I 1:> 
T RB F CLR RA 
~ I ~ 
1 ,. 
t-- wI? 11l11:t' ~ I?I> I-
", H ;.t \:.- \~ \~ 
~ ~ ~ ~ 
2 2 
kH '" " ... ~ '''' o. ''"' 





::: H 3 H H 
;. ro ft, f-ij ft, ~ t 
~t7 » • I~ ~ • H -: ~i7 ~ I"~ >< ~ V 
C C 




I II II 
• ,BeALL • A TA FA B TB FB 
no of logic modules. 66 I OAT!!:, I DRAWN 'BY: SHEET: avl< 
A I B I c I D 
CAL 
Inputs: AREQ, BREQ, EN, CLR 
Ouput : A, B 
Function : This module is a generalized C element. When a transition on AREQ and EN 
occurs a transition is produced on output A, similarly When a transition on BREQ and EN 
occurs, a transition is produced on output B. The input request AREQ and BREQ should not 
occur at the same time. The request and EN transitions may come in any order. Upon clear 
all the outputs and internal stateis set to low. To observe the above behavior all the inputs 
must be in same state. 
14 
" 
I ,. I c I D 
, , , 
AREQ _ 
/ I A 
-
A..r-







- A, A 
-
C"'UT B 






" CAL " 
no of ~ogic: modu~es ~8 
SH:e::E:T: I DATE, loR.A.!.oI'N BY t a vl< 
A I B I c I D 
OR 
Inputs: A[7:0], B[7:0], R~Q 
Ouput : Y[7:0J, ACK 
Function: This module performs logical OR of the operands upon getting a transition on the 
REQ input and produces an acknowledge transition on ACK output. 
• 15 




> A7 1 
B7 ~y Y7 B)~' 
--'" 
A6 




B5 A, Y5 Blc~~ y 
A4 
:-JQ~~ y Y4 B4 
2 
A3 
A, Y3 :z B3 B)~:) Y 
A2 
;.. Y2 B2 ,,. RJ~' 
_/ 
Al 








- REQ. Il'tln • 1 -r2 j=UT • ACK 
A ync Library 
4 B bit OR • 
logic no of modules 30 I DATE: I SHE!!.:T; 
A I B I c I 
" 
AND 
Inputs: A[7:01, B[7:0], REQ 
Ouput : Y[7:0], ACK 
Function : This module performs logical AND of the operands upon getting a transition on 




I c I 0 
8 [7: 0] A [7: 0] Y[7,0] 
, A7 1 
A Y7 87 81""'" y 
A6 Y6 A B6 BI~' Y 
-/ 
r- r-A5 
A..--,y Y5 B5 
B I--NO'.! 
A4 Y4 
B4 A~y BI~' 
-/ 
2 
A3 Y3 2 A 83 BI~"Y 
A2 Y2 A 82 
B I "-"'j y 
Al. Yl -r- A Bl. BI~')Y 
AO YO A 80 BI'~" y 
-/ 
:> 3 
REQ :JD::':!C ACK . 
'--
Async Libra.ry 
• B bit AND 4 
no of logic modules 30 
SHEET: I DATE, 1:cR..AWN .MY: avk 
A I D I c I D 
NOT 
Inputs: A[7:0], REQ 
Ouput : Y[7:0], ACK 
Function: This module inverts the input upon transition on REQ. input and produces ac-
knowledge transition on ACK output. 
17 
A I B I c I t> 
1 
Y(7:0] 
A [7: 0] A7 Y7 










A ....... Y 
V 
A3 Y3 







A ....... Y 
V 
AO YO 
Ar-,., y [, V 3 
-
REQ • Htlo • 1ar2 YUT • ACK 
Async Library 
;" 8 bit inveter 4 
no of logic ITlodules 30 
SHr:r:T; I DATE: loR.A"WN :ev: avk 
= ~ 
References 
1. Venkatesh Akella and Ganesh GopalKrishnan.F1'Om P1'OCeS8 Oriented Specifications to 
Efficient Asynchronous Circuits Tech Report UUCS-91-XX, Dept. of Computer Science, 
University of Utah. 
2. Venkatesh Akella. hopCP: Language Definition, Semantics and Examples. Tech Report 
UUCS-91-XX, Dept of Computer Science, University of Utah. 
3. Erik Brunvand. A cell Set for Self-Timed Design using Actel FPGAs. Tech report UUCS-
91-013, Dept. of Computer Science, University of Utah. 
18 
