Banning PRF programmer's manual by Kuelthau, R. L.
NASA CONTRACTOR
 
REPORT
 
NASA CR-149969
 
(WTSL-CF-149969) BANNING PRF PROGRIHER'S N76-36847 
MANUAL (W&S Computing, Inc., Huntsville, 
Ala.) 165 p HC $6.75 CSCL 09B 
Unclas
 
G3/61 50422
 
BANNING PRF PROGRAMMER'S MANUAL
 
By R. L. Kuelthau
 
M&S Computing, Inc.
 
Post Office Box 5183
 
Huntsville, Alabama 35804
 
December 30, 1970 A 
Prepared for 
NASA - GEORGE C. MARSHALL SPACE FLIGHT CENTER. 
Marshall Space Flight Center, Alabama- 35812 
https://ntrs.nasa.gov/search.jsp?R=19760023759 2020-03-22T13:14:21+00:00Z
TECHNICAL REPORT STANDARD TITLE PAGE 
REPORT NO. -2. GOVERNMENT ACCESSION NO. 3. RECIPIENT'S CATALOG NO. 
NASA CR-196 
4 TITLE AND SUBTITLE S. REPORT DATE 
BANNING PRF PROGRAMMERS MANUAL December 30, 19706. PERFORMING ORGANIZATION CODE 
7. AUTHOR(S) a.PERFORMING ORGANIZATION REPORr #
 
R I, Kuehlthau 70-0036 
9. PERFORMING ORGANIZATION NAME AND ADDRESS 10, WORK UNIT NO. 
M&S Computing, Inc. 
P.O. Box 5183 11. CONTRACT OR GRANT NO.
 
Huntsville, AL 35805 NAS8-Z56ZI
13. TYPE OF REPORT & PERIOD COVERED 
12. SPONSORING AGENCY NAME AND ADDRESS 
National Aeronautics and Space Administration Contractor Report
 
Marshall Space Flight Center, Alabama 35812
 
14. SPONSORING AGENCY CODE 
EC45 
15. SUPPLEMENTARY NOTES
 
Electronics Development Division, Electronics and Control Laboratory
 
Design Techniques Branch
 
16. ABSTRACT
 
This manual describes a modification of the Banning Placement-Routing-
Folding Program written by Radio Corporation of America and transmitted to the 
Marshall Space Flight Center in May 1970. The modifications to this program 
have been made by M&S Computing, Inc. to implement it on MSFC's Sigma 5 
computer and in support of their activities using the program. The input require­
ments of this program are detailed in the "Banning Placement-Routing-Folding 
User's Manual", while the required output, which is used as input for the Banning 
ARTWORK Generation Program, can be found described in detail in the "Banning 
ARTWORK Program User's Manual". This document presumes the reader is 
familiar with both of these documents and has a working knowledge of the FORTRAN 
IV language. 
Included in this manual are flowcharts of various levels, beginning with high 
level functional diagrams and working down to the level of detail deemed necessary 
to understand the operations of the various sections of the program. Along with 
the flowcharts of each subroutine is a narrative description of its functional
 
operation and definitions of its arrays and key variables. A section is also
 
included to assist the programmer in dimensioning the program's arrays. 
17. KEY WORDS 18. DISTRIBUTION STATEMENT 
Unclasified-Un ite d 
COR: I 
EC1 LIA___4.1406___ 
Director, E&G Cab 
19. SECURITY CLASSIF. (of this*repft) 120. SECURITY CLASSIF. (of this.Page) 121. NO. OF PAGES 122. PRICE 
Unclassified j Unclassified 164 NI 
MSFC- Form 3292 (Rev December 1972) For sale by National Technical information serNica, Springfield, Virginia 21ist 
TABLE OF CONTENTS 
Section age No. 
I INTRODUCTION I-I 
II PROGRAM EXECUTIVE MAIN It-I 
2.1 Functional Description II-i 
2.2 Program Structure 11-4 
2.3 Variables and Arrays 11-7
 
2.4 Debut Printout Ii-10 
III SUBROUTINE II- 1 
3.1 Subroutine INPUT 111- 1 
3.2 Subroutine PLACX IHl-17 
3.3 Subroutine CRCALC 111-27 
3.4 Subroutine ROUTE 111-30 
3.5 Subroutine SPACE 111-48 
3.6 Subroutine FOLD I-53 
3.7 Subroutine DIDDLE 111-65 
3.8 Subroutine REED 111-80
 
3.9 Subroutine LCRD IIH-84 
3.10 Subroutine LOOK IT1-87 
3.11 Subroutine SQUEEZ 111-89 
3. 12 Subroutine PADMVE 111-99 
iii 
TABLE OF CONTENTS (continued) 
Section Page No. 
3.13 Subroutine MOVE 111-104
 
3.14 Subroutine ASSIGN 111-116
 
3.15 Subroutine ARTWRK 111-123
 
3.16 Subroutine POWR III-133
 
IV PROGRAM SIZING IV- I
 
4.1 Program Overlays IV-1
 
4.2 Array Dimensions IV-1
 
V DEFINITIONS AND REFERENCES V-i
 
5. 1 Map Array Referencing Conventions V-I 
5.2 Abbreviations V-1
 
5.3 Term Definitions V-2
 
5.4 References V-4
 
iv 
SECTION I
 
INTRODUCTION
 
The Placement-Routing 
-Folding Program (PRF),is part of theBanning MOS large scale integrated circuit production system. The inputto this program is the logic design of in integrated circuit specifiedby a net list of required interconnections between Banning Standard Cells.The output of PRF is a magnetic tape of data defining the physicallocations of the Standard Cells and the interconnections between these cells,

which are utilized in implementing 
the logic design. This output is in aformat which may be used a's input for the Banning ARTWORK Program
which would normally be used to generate the plotter coding used to producethe integrated circuit's masks. The Banning Standard Cell EngineeringNotebook and the Placement-.Routing-Folding User's Manual contain detailedinformation on formulation of logic designs using the Banning Standard Cells
and on the translation of these designs into PRF program inputs. Details
of the output requirements for driving ARTWORK can be found in the BanningARTWORK Program User's Manual. 
This document describes the operations of the PRF program frominput of the logic design to output of ARTWORK data. Throughout the program,
control is maintained by the executive titled MAIN, which calls a sequencesubroutines to process data stored in COMMON memory 
of 
(COMMON memorybeing that portion of core memory which is saved for access by all subroutines
of the program). Section II of this manual discusses the function performedby each call in this sequence, and contains definitions of COMMON variables
and references to the COMMON arrays, as well as a flow diagram of MAIN. 
The subroutines called by MAIN are described individually inSection III, along with the secondary and tertiary subroutines which may be
called in turn. Following a brief functional description of each subroutineis a list of definitions of key variables and arrays which are constructed ormodified by the routine. Flowcharts provided are of the picture-on-a-page
format, allowing the programmer to reference the level of detail he may
require. The lowest level of detail for which flowcharts are provided
varies with the complexity of subroutine coding, as considerably greaterdetail is required to give complete and accurate pictures of the more 
difficult routines. 
I-1
 
Section IV describes the PRF Program's overlay scheme which
is used to reduce core 
memory requirements. It also contains a detailedanalysis of the relationship between the complexity of the logic designbeing run and the required dimensions of the individual arrays. This
analysis has been included since these arrays comprise the bulk of theprogram's core memory requirements, and it is anticipated their overflow
will be the cause of the majority of the programming problems encountered. 
The final section of this manual is a glossary of terms, abbrevia­tions, and conventions used throughout the manual. A list of references 
to other documents of the Banning System is also included. Familiarity
with the definitions of this section and with these references will save thereader from the necessity of making numerous later references while
studying Sections II, III, and IV of this manual. 
1-2
 
SECTION II 
PROGRAM EXECUTIVE MAIN 
The PRF program is constructed with a simple executive program
 
MAIN which maintains control at all times. Most of the program's operations
 
are performed by subroutines called sequentially by this executive. It will
 
be useful to reference the details of this calling sequence in the MAIN
 
flowchart (Figure 2-1) while reading the following discussion of its functions.
 
2.1 Functional Description 
The PRF program performs the translation from the logic designer's 
cell interconnection requirements to physical definition of the MOS chip by
 
manipulating data arrays which usually remain in COMMON core memory.
 
The user controls this translation by altering the values of those input
 
parameters which are recognized by the program as flags. The first data
 
card is read by MAIN and contains four such parameters (NPLC, NCTF, 
ISUP, and INFILE). The remaining 75 input parameters, the initial relative 
placement of logic cells, the list of required interconnections between logic 
pins of these cells, and the assignment of standard BANNING circuit numbers 
to these cells comprises the remainder of the user's normal input data. 
MAIN calls INPUT to read, check, and format all of this data into the COMMON 
arrays which are referenced throughout the translation process. Arrays 
describing the logic pins of the BANNING circuits are also formed by this 
subroutine with data read from the Circuit Type File. 
If the NPLC flag was set on the first data card, PLACX will be 
called to attempt to reduce the total length of interconnections by interchanging 
cell numbers in the array into which the user's initial placement has been 
mapped. The final placement of cells is printed before the program proceeds 
with the routing of connections between the cell pins. This final placement 
is in a form identical to that of the user's initial placement and consists of a 
list showing the order in which the logic cells would appear if they were to 
be connected together in a straight line. It is in this linear form that the 
cells will be interconnected and mapped during the preliminary phase of PRF. 
The chip is mapped in memory by letting each element of a large 
.two dimensional array represent a position on the chip relative to the other 
elements of the array. The number which is entered in an element indicates 
whether metal, P-material (tunnel), feedthrough (tunnel end) or some Banning 
cell occupies that position. The ROUTE subroutine is called to form such a 
11-1
 
MAIN A 
C CALL FOLD 
Fig. 3-25 
set array limits 
CALL ROUTE 
Fig 3-15 
Read: 
NPLC CALLFL 
NCTFISUP 151SF~~ Fg 3 
_ 
INFILE f] 
N 
CALL DIDDLE 
r=ig 3-32 
CALLS fUEEZ" 
3-43L PFig. 
AL NPUT CALL ASSIGN 
T 
FgFig. 3-6 
Fig. 3-61 
CALL ROUTE 
. |-'
 
YFig 3-95 CALL SQOWE 
set 1st Pass Flags: ORIGINAL PAGE 18IN 1 F POOR QUALITY NL 
IR -r 1 CALL ARTWRK 
NI 
Fig. 3-6 
Figure~ ~ ~ ig 3-64FEECTVEMI 
CALR6 
map of the final linear cell placement and enter the required interconnections 
between these cells. FOLD is then called to examine the widths of the 
interconnections in this map to determine the points at which this linear 
array should be folded upon itself to form a square chip. 
The folds, or sections of the linear map which are bounded by
these points, are then individually rerouted during a second pass through 
ROUTE. By routing a fold's wiring independent of the other folds, space is 
utilized more efficiently and the required number of wiring channels can 
usually be reduced. A second pass through FOLD follows this pass through
ROUTE during which the fold points are refined and the linear map is broken 
into maps of the individual folds which are then stored on s.cratch storage. 
The DIDDLE subroutine proceeds by reading the individual maps
into a large two dimensional map which is representative of the final chip. 
As each of the individual fold maps is read into this final map, the signal
connections required between it and the previously entered folds are routed. 
When this has been completed, MAIN proceeds by calling SQUEEZ to refine 
the mapped chip. This is accomplished by individually clearing and rerouting 
each fold's interconnections. Several wire channel widths may be saved in 
this process since the interconnections between adjacent folds are now
 
defined and can be integrated into the pin to pin wiring.
 
The map of the relative locations of the chip's components is now 
complete. ASSIGN is now called to assign absolute coordinates to each map 
array element in accordance with the specified spacing parameters and the 
spacing requirements of the standard cell components. This subroutine 
then uses the chip map and these coordinate assignments to produce the chip 
picture on the line printer. 
A normal PRF run proceeds from this point to the ARTWRK 
subroutine where output for use by the BANNING ARTWORK program is 
produced. Here pattern set data is generated to produce standard cells, 
tunnel ends, alignment marks, power pads, and test transistor. Line set 
data is generated to produce the'metal and tunnel interconnections and shape 
set data may also be generated to produce a chip border. The POWR sub­
routine follows to calculate the power bus requirements and generate line set 
data to produce them. This completes the PRF operation. 
There are two possible deviations from this normal PRF sequence 
which the user may select. By setting the LEN input parameter (see PRF 
I-3
 
User's Manual) non-zero, he may make insertions or deletions of metal 
or tunnel connection segments. When this option has been selected, the 
program will loop back to SQUEEZ after completing the first pass through 
ASSIGN. SQUEEZ then inputs and implements the change specifications 
before ASSIGN is called once again to revise coordinate assignments and 
restore control to the normal program sequence. It is necessary to complete 
the first pass through ASSIGN before entering the manual changes, since 
the change specifications are referenced by the absolute chip coordinates 
assigned.by the subroutine. Details of the manual change option can be 
found in Section VI of the PRF User's Manual. 
The other option which may be selected is that of simply bypassing 
generation of output for the ARTWORK program. If input parameter IBPA 
is set to zero, this option terminates the progran immediately after the 
ASSIGN subroutine has been completed. 
2.2 Program Structure 
Figures 2-2 and 2-3 contain a diagram showing the levels of the 
various subroutines and coding blocks of the PRF program. Distinct 
subroutines have underlined titles in this tree structure, while the 
remaining titles are merely blocks of coding which have been flowcharted 
on the pages having that title as the entry point. The number of the figure 
on which a subroutine or coding block is flowcharted appears directly 
below its title. All PRF coding may be referenced by this diagram with 
the exception of the LOOK subroutine. LOOK, described in Section 3. 10, 
is of such a low level that no specific calls are entered in the flowcharts, 
although it is referenced at numerous points in the DIDDLE, SQUEEZ, 
PADMVE, MOVE, ASSIGN, and ARTWRK subroutines. 
II-4
 
LEVEL 12 3 4 
RUN PARAM 
3-2 
CELL DATA 
3-3 
NET LIST 
3-4 
INPUT ARRAY 1 
.3-1 3-5 
ARRAY 2 
3-6 
ARRAY 3 
3-7 
PRINT NETS 
3-8 
RECONSTRUCT IP 
3-10 
SQUEEZ IP 
PLACX 
3-11 
INITIAL CALC CRCALC 
3 9 3-12 3-14 
,INTERCHANGE CRCALC 
SMAIN• :MAI " 3-13 3-14 
* -21 SET UP ARRAYS 
3-16 
CALCULATE LENGTHS 
3-17 
OPTIMIZE PADS. 
3-18 
ROUTE INVERT CELLS 
3-15 3-19 
REFORM ARRAYS 
3-20 
RUN WIRES HORIZONTAL 
3-21 3-23 
SPACE CELLS SPACE 
3-22 3-24 
SQUARE CHIP 
3-36 
BREAK 
3-27 
OPTIMIZE 
FOLD 3-28 
3-25 SET FOLDS 
3-29 
CLEAN VERTICAL 
3-30 
TAPE 
Figure 2-2 PRF CODING -LEVELS 
11-5 
LEVEL
 
2 3 4 5 
 6 
REED
 
3-40
 
END WIRE
 
3-33
 
DIDDLE PREPARE FOLDS
 
3-32 3-34
 
SPACE PADS CROSS MATCH
3-35 [ 3-37 
CROSSWIRE EXTEND LQRD
3.36 3-38 3-41 
[XRUN 
3-39 
SIDE ROUTE 
PADS PADMVE I 3- ET 
3-44 3-49 DELETE 
3-51 
SORT FLAGS
 
3-53 3-56 
WIRE LIST RIGHT CONNECTS UEEZ FOLD WORK - 3-48 3-57 
3-43 3-45 MOVE CHECK HOR. 
CORRECT 3-52 WIRE 3-58 
3-46 3-54 LEFT CONNECT 
SQUASH REFINE 3-592A 3-47 3-55 LOOSE ENDS 
2-1 3-60 
X-ASSIGN 
ASSIGN 3-62
 
3-61 Y-ASSIGN
 
3-63
 
TEND
 
PAT TERNS!_____ 3- 7
 
3-65 LET EDGEPOWR PAD 3-71 
3-66
 
AR TR TEST
 
3-64 -3-67
 
TUNNEL
 
3-68 
UPPER LEVEL
 
3-69
 
NC ,LIST
Lpo02_.R ["3-73
3-72. WRITE BS 
3-74 
Figure 2-3 .PRF CODING LEVELS 
11-6
 
2. 3 Variable's and Arrays 
As mentioned previously, most of the data describing the MOS 
chip being constructed passes between subroutines in COMMON variables 
and arrays. The following list defines usual use of COMMON variables 
as.well as the few local variables used by MAIN: 
COMMON Variables 
CAP - Array 
IAX - Maximum X-dimension of IFA (X, Y) 
IAY - Maximum Y-dimension of IFA (X, Y) 
IBF - FOLD bypass flag 
IBP - Not used 
IBPA - ARTWRK bypass flag 
IBPI - Not used 
IBR 
- ROUTE bypass flag 
IC Array 
ICK Array 
ICL Array 
ICN Array 
IDBG - Not used 
IDNEG - Not used 
IDP - Not used 
IEC - Array 
IEL - Element number used as argunent by CRCALC. 
IF - Array 
TT-7
 
IFA - Array 
IFX - Max. X-dimension of IF (X, Y); set to 10. 
IHF - Cell height. 
I - Number of folds. 
IN - During PLACX: value of new total pseudo wire length. 
During ROUTE - FOLD sequence: flag indicating Ist or 
2nd pass through sequence. 
INEQ - Not used. 
INT - Array 
10 - Total of old pseudo wire lengths calculated by CRCALC. 
IPAD - Pattern number of connection pads. 
IPTRN - Array 
IR - Flag set to 1 or 2 for Ist or 2nd pass through ROUTE. 
IRAMX - Index on last pin of IRA. 
IRX - Maximum X-dimension of IRA (X, Y). 
IRY - Maximum Y-dimension of IRA (X, Y). 
ISWC - Not used. 
IW - Net weight assigned to wire whose pseudo length is being 
evaluated by PLACX. 
IXW - Array 
IYW - Array 
JD - Array 
J3 - Number of logical unit on which the C. T. F. is to be read. 
11-8
 
LE - Length element used by PLACX 
LEN - Manual correction option flag 
LIMIT - Interchange limit used by PLACX 
LL - Number of the fold being rewired by MOVE 
MM - Vertical channel spacing; equal to ZxICN (73) 
MN - Pointer on vertical channel immediately to left of folds. 
Ml - Number of cells -on chip 
NAR - Not used 
NC - Array 
NCT - Number of circuit types 
NET - Array 
NNETS - Number of nets 
NP - Number of pins 
NWRK - Number of work tape 
NX - Array 
Ni - Set to 2 
PR - Array 
MAIN Local Variables 
INFILE - Contains the logical number of the input unit on which the 
Circuit Type File is to be read when cards are not used. 
ISUP - Flag which must be set to 1 if circuit pin parameters are 
to be printed from the C. T. F. 
11-9 
NCTF 	 Alphanumeric constant used to indicate which input
 
device is to be read for the C. T. F.
 
NCTF = "CARDS" for card input 
NCTF = "TAPE" or "ALTR" for input on device INFILE 
NPLC Alphanumeric constant indicating whether PLACX 
subroutine is to be run. 
NPLC = (Blank) for bypass of PLACX
 
The PRF 
COMMON arrays are often used for different purposes at
 
different points in the program. Every subroutine in which an array is
 
constructed or modified to perform a different function contains 
a description
of the new array format as a part of the subroutine's description in SectionIII. 
Figure 2-4 indicates which subroutines so alter the various arrays, as well 
as where each array is referenced. By using this table, the reader can 
reference the subroutine describing the format of any COMMON array at any 
point in the program. 
The following two arrays are referenced directly by MAIN: 
IP (I, J) - MAIN prints the placement from this array which has been 
set up by INPUT and modified by PLACX. 
MAP (I, J) - MAIN uses several discrete locations of this array to pass 
the three local variables INFILE, ISUP, NCTF on to the 
INPUT subroutine. 
2.4 Debug Printout 
The debug flags mentioned in the PRF User's Manual (page IV-ll)
produce output dumps from the routines listed below-
ICN (36) - PLACX 
ICN (37) - INPUT
 
ICN (38) - ROUTE
 
ICN (39) - FOLD
 
If-10 
SUBROUTINE 
U l 
ARRAY 0_____ ______ ______ 
CAP A B A 
IC AC BBAC C CC C C 
ICK A C C C 
ICN AC B C B 
IEC AC C C C C Ccc 
IF ACC B CBBC 
IPA AA BBBB CC 
INT AC 
IPR A A 
IPTRN A C C C 
IRA A A B 
IXW A AA 
IYW A A A C 
JD AA B BCBCBC 
NC A A B BACA 
NET A C C B C C 
NX A A BBBCC C 
PR A A 
A - ARRAY FORMED BY SUBROUTINE 
B - ARRAY MODIFIED BY SUBROUTINE 
C - ARRAY REFERENCED BY SUBROUTINE 
EQUIVALENT ARRAYS: 	 IFA e*IRA 
IPR PR 
COMMON ARRAY USAGE 	 MAP 
Figure 2-4 
II-il 
ION (40) - DIDDLE, SQUEEZ 
ICN (41) - REED, MOVE, LOOK 
ICN (42) - ASSIGN 
ICN (43) - ARTWRK 
ICN (44) - POWR 
None of these dumps are labeled and'some of the array dumps are 
not formatted, making interpretation difficult. Parameter dumps generally 
print many irrelevant variables along with the few whose values are critical 
at the particular point in the program. The programnier must use the 
listing to determine exactly which quantities of which dump are of interest. 
11-12
 
SECTION III 
SUBROUTINES 
3.1 Subroutine INPUT 
The INPUT routine reads most of the PRF input data, makes 
various checks on its validity, and formats it for storage in COMMON 
arrays.
 
3. 1. 1 INPUT Functional Description 
Since the formats of inputs are described in detail in the PRF 
User's Manual, as are input options and possible error messages for 
invalid data, this discussion is concerned primarily with the subrou­
tine's construction of arrays in COMMON memory. After the first 15 
control parameters (Ml, LEN, LIMINT, IHF, IBR, IBF, IRP, IBPI, 
IBPA, IDP, IDBG, NWRK, NAR, IPAD, I) have been read as COMMON 
discretes, the remaining control parameters are read sequentially into 
the first of these arrays, ICN. Following this, the assignment list is 
input directly into the IEC array, the initial placement directly into IP, 
and the net list is formatted and entered into NET. The entire Circuit 
Type File is input into arrays IPTRA, ICA, and ICB. After these 
arrays are searched for the data describing the cells to be used in the 
particular PRF run, and this data is transferred into IPTRN, ICL, and 
ICK for permanent reference, the original arrays IPTRA, ICA, and ICB 
have served their purpose and are no longer referenced. 
A number of cross-referencing arrays are constructed to enable 
easy access of cell type data, interconnection data, and placement data. 
These arrays, INF, LNAD, MAP, IC, and CAP are constructed at the 
same time that a number of validity checks are made on the data. If an 
error is detected, an error message, as indicated in the PRF User's 
Manual and the INPUT flowcharts (Section 3. 1. 3) is printed and local 
variable lIE is set to 2, causing an eventual recycle of the INPUT sub­
routine. The five arrays constructed in this section have a particularly 
interesting cross-reference structure which is shown in Table 3-1. 
The formats of arrays ICK, ICL, ICN, IEC, INF, IP, IPTRN, 
LNAD, MAP, and NET are significant since this is the form in which 
they will be referenced throughout the remainder of the program. Maps 
of all of these arrays are included in Tables 3-1 through 3-3. 
III- 1
 
INPUT NET CROSS-REFERENCE ARRAYS 
3rd element of each net group contains index 
t of the last cell in that net group
NET(M) "V . \ Format NET-Il 
M=1 2 3 4 5 6 7 8 9 10 11 1213 14 15 16 17 18 19 20 21 22 23 ?4 25 26 2IolUIUI '1w!1 l PllP C IP~ouUIUlP__T1cPIw ! PICll PICU 
Ml=7 t-M 2 =23 
C1 = Some specific cell number indexed by M 1 and M 2 .
 
U = Unknown number--these elements have not been set.
 
W 1 = Weighting factor assigned to Net 1.
 
C = Any cell number
 
P = Any pin number
 
LNAD(ND) Format LNAD-I1 
ND= 1 2 "3 4 5 6 7 8 9 13 [MMM
L MIMIM M M IMI M imiilM2iMIMI MIMI tM I MI MIMI MI MI MI M 
NDL=12..J 4NDu=l3
 
M I = Some index to cell C1 in NET 
M 2 = Some index to cell C1 in NET 
M = An index to any cell in NET 
NDu = Highest index in LNAD of a reference M to cell C1 
NDL = Lowest index in LNAD of a reference M to cell C1 
INF(C,L)
 
CL=l 1I 2I 3I 4I 5I 6 7 8 10 1 
11 12 13 14 
II- I I I I I I 
Format INF-IlT7III1I 
2 J J J J J J J J J J1 J J J J J J J J J J Y J 
3 T9U U UU 
4 = L LL Lr 
U 
L 
U NDL U U 
L NDuL L 
U I U 
Lr r r 
u U 
u 
UUUU 
rL 1 r UUI I 
(1,J) = Coordinates locating some cell C in IP 
U = -Highest index in LNAD of reference to cell C 
L = Lowest index in LNAD of reference to cell C 
(1, J) = Coordinates locating cell C1 in IP 
IP(I,J)
 
= I 

= - 1 2 3 4 5 6 7 8 9 10 il CI Il, Ti= Format IP-l 
JCC CCCCC C C C C I CC CC C I C C 
ZI P D PPD.DPD PD PD PD 0 00 OOOOOPDPDOPDP PD PD 
PD = Any pad number
 
MA
 
1--1 2 3 4 5 6 7 8 9 10 11 12 Format MAP-Il 
212121Z ~ ~ Z 2 0 0 O Oq!__ 0 10 10 10 10 22 2 
Table 3-1 INPUT NET CROSS REFERENCE ARRAYS 
III-2
 
MPE1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 ... 
IC(ME, MP) 
Format IC-Il 
2 1 11 
3 1 011111 
4 1 0- 0 
500001 
1 
I 
--
700000 
80000--------
-------­
900000 
0O 0 0 0 0 
1 
0 
= 
= 
Connected Pin 
Unused Pin 
K 3 
0 ! 0 2 0 o 4 0 5 o6 0 7 9 
0 300 201 301 200 ZOO 
SzZ 
O,300 
300 2 
330 
I(IJ,KX) -1- 30 
:TO300 
3504 
201 
250 
351 
0 
250 
2001 1 
200 
200 
Format 
0 
0" 
0 
(0 
O[0 
0 
0fa 
/ 
4i 
K 
Kl 
0 
0 
8 
0 
0 0 
Ideaim 
2In ex00 
0 
I0 0 
0 
0c 
0 
250 
0 
0 
0 
O-
0 / 0 
0 
10 
I0 0 0 0 
I Index is the Element Number 
J Index is the Pin Number 
K Index is the Paramneter Number 
K = I Indexes reassignment flags 
K = 2 Indexes pin capacitance 
K = 3 Indexes right to left pin spacing 
-K = 4 Indexes left to right pin spacing 
Table 3-2 INPUT ARRAYS 
.111-3 
IEC is indexed by the cell number tag assigned\ inthe assignment list. 
IEC(I) I= 1 2 3 4 5 ... 
PI P I P p P 
Format IEC-Il r-P4 is the Banning Cell Library Pattern Number 
which has been assigned to Element 4. 
IPTRN(I) I= 1 Z 3 4 5 6 7 ... 
jPj PI PI PI P PI P4 I 
Format IPTRN-I1 ' ,-IPTRN(I) is a list of all the patterns 
read in from the Circuit Type File in order in 
which they were read. Thus Pattern P4 is the 
7th pattern in the file. 
IC L(I, J) 
I= 1 2 3 4 5 6 7 8 9 
3= 1 CP 1 _/ 
2 CP 2 / 
3 CP3 
4 CP4 
5 CP5 
6 CP6 
Format ICL-Il CP I - CP 6 are the cell parameters of 
the 7th pattern in the Circuit Type File. 
,Table 3-3 INPUT ARRAY MAPS 
II-4 
3. 1. 2 INPUT Variables and Arrays 
Since most of the key variables of this subroutine are in COMMON, 
there are only a few significant local variables. These are: 
I - Dummy variable used as the number of the cell 
being processed. 
IIE- - Error indication flag which causes recycle of 
the INPUT subroutine. 
INFILE -	 Logical number of the alternate input file. 
ISUP - Pin data suppression flag; data will only be printed 
if ISUP = 1. 
ND 	 Dummy variable used as a pointer in forming 
LNAD and INF. 
NP 	 Dummy variable indicating the number of pins 
on the cell being processed. 
The following arrays are formed by the INPUT subroutine: 
A (I) 	 Temporary storage of alphaneumeric cell name 
data. 
CAP (I) 	 Contains the total capacitance of cell pins connected 
to net I. 
IC (ME, MP) -	 Map of pins referenced by net list; 
For: 	 IC(ME, MP) = 1 - Pin connected 
IC(ME, MP) = 0 - Pin not connected 
Where: 	 ME = Element number referenced 
MP = Pin number of element MP 
ICK (I, J, K) - Contains circuit type file pin parameters for cell 
types specified in the assignment list: 
IH-5 
I = 
J = 
K = 
Elemelt number in Circuit Type File 
Pin number 
Parameter type index 
For: K=l 
K=2 
K=3 
K=4 
- Reassignment flag 
- Pin Capacitance 
- Right to left pin spacing 
- Left to right pin spacing 
ICL (I, J) - Contains circuit type cell parameters. 
I 
J 
= 
= 
Element index number in 
Cell parameter number 
Circuit Type File 
ICN (I) - Program input parameter array. 
Note that only 75 parameters are utilized by PRF. 
Parameters 76-111 are reserved for use by SIGNAL 
TRACE. Some of the elements between 112 and 200 
are used as common data links between subroutines 
later in the program. 
IEC (I) Pattern assignment array. 
Element Number I is assigned the Banning 
Pattern Number entered in the location it 
indexes. 
INF (C, J) - Contains cross-reference information between array 
IP, which describes a cell's placement position, and 
array LNAD, which contains an ordered list of 
addresses of NET array elements containing the 
particular cell. See INPUT array maps, Table 3-1. 
INF (C, 1) = Contains the X-index locating cell C in IP 
INF (C, Z) = Contains the Y-index locating cell C in IP 
INF (C, 3) = Contains index to lowest element of LNAD 
referencing cell C. 
III- 6 
INP (C, 4) = Contains index-to highest element of LNAD 
which references cell C. 
IP (I, J) Element position placement array containing 
the element numbers in the relative positions 
specified by initial placement. Bonding pads 
are placed in a separate column. 
I = Index to relative position in linear array 
J=1 
J=2 
- Column containing logic elements 
- Column containing pad cells. See 
INPUT array maps. 
IPTRN (I) - List of pattern numbers read in 
File. 
from Circuit Type 
I = Index on position of pattern in 
Type File. 
Circuit 
ITITLE(I) - Array used to store the title of the PRF run and 
titles of input parameters. 
LNAD(ND) - Contains ordered list of address of NETS in NET 
array containing particular cells. This list is 
referenced by INF to provide a cell to net cross­
reference. See INPUT array maps, Table 3-1. 
ND = Index referenced by INF 
NET (M) - Linear array containing all net list data. Net lists 
are stored in NET in the order they are read from 
input data cards. Cells in INF may be referenced 
by utilizing the LNAD and INF arrays. The format 
of net list data stored in NET is shown by the 
INPUT array maps. 
M = Index referenced by LNAD 
III-7 
MAP (I, J) - Map of available cell position in IP (I, J) 
For: Map (I,l) = 1 - Logic cell position which may 
be utilized. 
= 0 - Logic cell position to be vacant. 
Map (I, 2) = 2 - Pad position which may be 
utilized. 
= 0 - Pad position to be vacant. 
Where: I = Relative position index 
J=l - Logic cell 
J=2 - Pad cell 
NETOT (150) - Used as temporary storage of pattern/element pairs 
during the print of the initial assignment list. 
ICA (I, J) - Temporary storage of Circuit Type File cell 
parameters. Format identical to ICL. 
ICB (I, J, K) - Temporary storage of Circuit Type File pin 
parameters. Format identical to ICK. 
3. 1. 3 INPUT Flowcharts 
Figures 3-1 through 3-8 contain flowcharts of the INPUT sub­
routine. 
111-8
 
o tLu o 

Y 

IIN
 
Figure 3-1 INPUT 
M1-9 
RUN PARAM
 
Read run
 
parameters
 
Fig. 3-Z
 
CELL DATA
 
Read Circuit Type 
File, Cell Place­
neryt, and Assign­
ment List 
Fi are 3-3 
NET LIST 
Read Net List 
Print Assignment 
and Placement 
ure -
ARRAY 1
 
Form INF and
 
LNAD arrays
 
Figure 3-5
 
ARRAY Z 
Form MAP array 
Figure 3-6 
ARRAY 3 
Form CAP array 
Figure 3-7 
PRINT NETS 
Print net data 
Figure 3-8 
Is Print Arrays: 
nput debug y MAoro
 LNADflag set 
NNINF
 
an error 
.detected
 
F1R 
RUNPARAM 
Set up 
alphanumeric 
constants 
Read and print 
run header
 
card
 
Initialize error 
IER x I 
Read and print 
run pararnete 
header car 
Clear IEC 
array
 
Read run 
parameter 
cards 
igure YA ICN (1) 
Print run 
Figure 3-2 RUN PARAM, 
CELL DATA 
Wri error 
rnsae:CTF
,ORASSIGN 
TTLE CAR 
TAR-IS AF 
FR col.5S 
'Read 
si 
S char, of into 
next crd Thmeft inointo EC array 
at 
cell par­
metrFrsptenaer card 
arrays A, 
IPIRA, ICA 
Print CTF 
header-
MAP(li.})"TAPE 
y 
First 
4 character 
"TAPE" or 
N 
cad n(.ISUP LI e fin 
pu 
Write celtheader 
feil parameters 
Nin header. ann param­
eters 
Set flag totreuseinput Y NAPdeviceright 
Form ICB: YICR, (1. 
4)=Left to right pin 
distance. lCB (1,J.3).ih .­ tpto left ptn 
distance 
ISUP.AP (2 1) 
Are 
NaRsig
-
r a:­
meet Flags of boh ijnt flags 
edge pins o0 arc no­
-ref pointY __J 
ccrcuit N 
Las t 
rcit 
typesy 
I -# of types in file 
J33# of original input 
device 
1Suppress-pLn data if 
option not properly 
specified ISUP'1Rr 
I 
Aead initial 
'placement 
jnto IP array 
-:o a 
l tZ 
ali topagte 
assignment been Y 
array 
REUN 
oF poor QUAI~fl 
Figure 3-3 CELl. DATA-
IRa- 11 
Read net list Print 
header, assignment 
read and list leader 
print NNE and assign­
of nes) ment list(A' ofnets)from lEG 
Read net list Print initial 
into placenent 
\/eader andNET array placement­
list fronm 
'P 
Error Msg: ETURN
_li t c LIST ISed"NET 

140?(aprac YOVER
 
N HIE z 2,Dis~card 
Axress ne data,
 
NNETS -IS of nets 
1ead in. 
IClear INF array 
ND z I 
assignment 
list 
headez
 
Address 1st cell
 
of C. T.F stored in
 
IPTRA, ICA, ICB
 
Srnethe cl' 
Nd inassgne r 
TCler the cell's 
parameters fro
 
IPTRA,, ICA,, IC]B
 
Figur NET LISTr-4 
ICA 7-ICPTRAyI-
Clear INF (200,4) 
ND= = 
Y inIP array K 
IP (1, 3), K0 
Illegal cell 
~K>200 _ 
H 
# 
= 2 
cell0as 
" I 
cillegal 
y 
Mulcplesinment 
error 
a ressge 
S INF (K, 1) 
INF (, 2)= 
INF (, 3): 
I 
D 
ND 
Store the Indce, of 
anachnet contliinn 
cell K n S-IceK vn 
NO = last indxofLNAD in ,ch an 
address Nas stored 
INF (K 4) iND 
[:ND = ND+ I 
ORIGINAL PAGE IS. 
N Lastdl 
• I 
II 
o s6, YH 
Error IMg: 
Internal 
-2 
-
Does NElenment X is 
s not in anyalyneCC] 
Figure 3 5 A RAY I 
HIE: 2 
K -IP (1!, 1) 
KA{II= 
L = IEC (K)E'C(K
(assigned pattern 9) 
pattern Error rsg:
L.le OK.assign
N ed as pad in 
S"Is HE, 21
 
EroMsg YI Ero 
Elem,. asig #l 
2zRA I-6 Figur 

MAP(1 2 
--
Clear arrays CAP, A 
ICAddress first 
netI 
C t 
Addres 
- first element 
ME r ele.H 
t (N
MP = pin. 
NN Y 
LastmN dlsement n 
EeElement 
N
tne 
plicerent Placapeita 
dElementin 
Y 
Netain pin# pont 
OF. QUIflI "mPOO N 
Pi.# Ne inai
 
has been been in
 
reviousl 
 r vou o
 
designate prvou "e 
HIE =2 Lat NAddress next 
N Elmn n elenmen t 
LIC (Mr. Ni)= 
S IER I 
Write: 
Sincluded in Addressnext net ne 
ORIGINAL PAGE JS CTF 
A A bort RutR E U R
 
Fig~e 3-7ttIRAY 3 
PRINT NETS 
Print net 
list lne 
e s frst nae. 
at NC 
Adrs next 
N N 
Neguro 3-S PRINT NE 2S 
III-I6 
3.2 Subroutine PLACX 
PLACX is used to reduce the length of cell interconnections 
by changing the relative positions of the cells in the placement array 
specified by the user. 
3.2. 1 Functional Description 
Since examination of all possible combinations of cell positions 
would require a prohibitive amount of computer time, the subroutine attempts 
to optimize placement by running the designer's initial placement through a 
complex iterative loop which makes desirable cell interchanges until it can 
detect no more possible improvements. Key variables controlling this 
iteration sequence are LE and KSW. They are initialized so as to route the 
first pass through the flow block labeled SQUEEZ IP before any calculations 
or cell interchanges are made. Here IPTMP, which has been loaded with 
the user's initial placement from IP, is formatted into a more nearly square 
array, having a Y-dimension of 6 (see Table 3-4). The array will be 
constructed so that there will be fewer non-zero elements in IPTMP than 
there are positions, and these will be blocked near the array's center. 
Following this initialization, the program enters a loop where the 
effect of each of a series of cell position interchanges is evaluated. This is 
accomplished by calling the CRCALC subroutine to calculate a rough 
approximation to cell interconnection lengths of each net, based on relative 
cell positions in the IPTMP array. The total of these lengths is termed the 
pseudo-wire length. 
The sequence in which different trial interchanges are evaluated is 
detailed on the INTERCHANGE flowchart, Figure 3-13. If one or more good 
interchanges were made in the interchange loop, it is recycled. This process 
continues until no more good interchanges can be found. Once this state has 
been reached, the key variables are tested and modified, and the complete 
interchange loop is recycled. Variables and switches of this complex 
optimization cycle, as listed in Table 3-5, sequence through the outer loop 
a total of 12 passes. On each of these passes, the short loop is recycled as 
many times as necessary to reach the no good interchange state. By tracing 
the variables of this table through the PLACX flowchart, the detailed path 
sequence of the loop can be determined. 
It should be noted that Nl, the Y-dimension of IFTMP, is decremented 
until it eventually returns to the original IP dimension of 2. When the loop 
111-17 
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 
IPTMP(I,J) 1 O OO C C C CIC C C C CC B B B 'O 0 
2 OOO B B BC CIC C C 0 OC0 
Format IPTMP-P 3000 C C CC C C C C B B B0 00 
4TO OO B BB 
s oooccccccc600'BBBCCC 
C C 
C 
C 
C 
C 
c 
C C C C C 
c B] B-BCC C C B 
O O0 0 00000000 0 0 
0 
o0 0 
B = Bonding Pad Number 
C = Cell Number 
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 
3=1 I 1 1 111 1 iF IfI 1 ,1 1 1 1 
MAPTMP(I,J) z I 1I 1 1 1 1 1 1 I 1 1 1 1 1 1 1. -1 
3 1 1 1 1 -1 1 1 1 1 11 1 1 T T 1+ 
Format MAPTMP-PI 	4 1 1 1 1 i 1 1 1 T 1 1 1 1 1 1 1 1 1 1 1 
5 1 1 1 1 1 1 1 1I 1 1 1 1 1 1 1 1 1 1 1 1 1 
6 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 _7_O_q_30 0 00 0 0	 0 1 0 0 01T A0ILO 

ABOVE ARRAY MAPS OF STATUS IMMEDIATELY AFTER RETURNING 
FROM SQUEEZ IP CODING BLOCK. 
i3rd element of each net group contains index of the last 
cell in thalt netoup. 
M= 1 2 3 4 5 6 7 8 81011 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 
NET(M)IOWliNWlll WICIPICiPtC IPIcCIPIoNW2 2WI zCIPIoIPIC IPCPIP 3 
Format NET-PI
 
owl1 = Old pseudo wire length of Net 1.
 
NW 1 = New pseudo wire length of Net 1.
 
W, = Weighting factor assigned to Net 1.
 
C =Any cell number.
 
P = Any pin number
 
Table 3-4 PLACX ARRAYS 
III- 18
 
PARAMETERS
 
0 1 P LE NOINT KSW ITOT INGG INEE M1 N, LIMINT 
1 2 6 361 2 0 0 361 7 6 3 
2 2 5 919 1 0. 0 819 7 7 4 
3 3 5 1241 2 0' 0 1028 7 5 4 
4 4 4 1745 1 0 0 1"357 7 6 6 
5 5 4 2096 2- 0 0 1503 9 4 6 
6 3 2562 1 100 3* 1642 7 4 9 
6 7 3 2793 1 0 3 1716 7 4 9 
8 3 3066 2 0 4* 1759 11 3 9 
7 9 3 3358 2 0 4 1805 11 3 9 
10 2 3740 1 300 7* 1838 11 3 13 
11 2 3937 1 400 8* 1870 11 3 13 
8 12 2 4208 1 200 10 1905 11 3 13 
9 13 2 4505 1 -100 10 1935 11 3 13 
14 2 4647 2 1100 11* 1940 13 2 13 
15 2 4783 2 1000 12* 1943 13 2 13 
10 16 2 4936 2 1000 12 1946 13 2 13 
17 1 5025 2 2900 17* 1963 9 2 13 
18 1 5124 2 2700 19* 1981 9 2 13 
11 19 1 5245 2 2700 19 1996 9 2 13 
12 20 0 5366 2 4700 19 -2012 9 2 13 
*Note that each pass in which a good interchange was made 
(indicated by an increment in the value of INGG), the loop 
took the short return path, causing the control variables to 
remain unchanged. 
The parameters of this table were printed by the debug print 
option near the end of the short loop while a small 18 cell 
test chip was being run. 
PLACX PARAMETERS PRINTED AT COMPLETION OF 
CELL INTERCHANGE LOOP 
Table 3-5 
111-19
 
has sequenced to this point and when KSW=I, the elements of IPTMP are 
again segregated into rows of logic cells and pad cells. The original 
MAP array is restored before the final passes through the interchange 
loop to maintain this segregation. When good interchanges can no longer 
be made and LE has sequenced down to zero, "PLACX prints the pseudo­
wire lengths of each net and returns with the new cell placement stored in 
IP.
 
3.2.2 PLACX Variables and Arrays 
The following key variables are referenced in PLACX: 
INEE - Equal interchange count 
INGG - Good interchange count 
IELL - Left cell of interchange used as argument in 
calling CRCALC. 
IELR - Right cell of interchange used as argument in 
calling CRCALC. 
INTE - Equal interchange flag 
INTG - Good interchange flag 
ITOT - Total of net pseudo-wiring lengths 
IX - X-Index on base cell 
IY - Y-Index on base cell 
KSW - Sequencing switch 
LE - Length element sequencing variable 
LIMINT Limit on the distance from base cell within which 
cells will be tested for interchange. 
M X-ndex on interchange candidate 
III-20
 
Ml X-Dimension of I.PTRN 
MIS - Number of logic cells 
N - Y-Index on interchange candidate 
Nl - Y-Dimension of IPTRN 
NOINT - Number of interchanges count 
The following arrays are either formed by PLACX or altered from 
their initial configuration in the INPUT subroutine: 
IC(I, J) - Rows 1, 2, and 3 are used for temporary storage 
of MAPTMP and IPTMP. 
IPTMP(I, J) - Array used to indicate relative positions of cells. 
IPTMP and MAPTMP are loaded from IP and MAP 
on entry to PLACX and their first two rows are 
restored in these arrays on return. 
MAPTMP(I, J) - Map denoting legal interchange positions. All 
rows corresponding to IPTMP rows which contain 
pads or cells are initially set to 1, enabling 
interchanges between pads and cells. After final 
reformation of IPTMP, the original map array (as 
shown in the INPUT array maps) is entered. Since 
interchanges between only those elements having 
equal non-zero MAPTMP references are allowed, 
the final format of IPTMP is preserved. 
NAT(I) - Used to temporarily store the elements of IPTMP. 
NET(M) - Identical to format formed by INPUT with the addition 
of OW and NW for each net as shown in Table 3-4. 
NETTOT(I) - Array containing the total pseudo-wire length of each 
net I. 
11[-21 
3.2.3 PLACX Flowcharts 
Figures 3-9 through 3-13 contain flowcharts of the PLACX sub­
routine. Flowcharts of the external subroutine CRCALC, which is 
referenced by PLACX, are presented in Section 3.3. 3. 
ll- 22 
PLACX B 
mi tiali, ation 
LE =6 LE'LE- 1 
IPTMP =P 
APTMP=
 
Ni=LE+±1I 
_ _ NTRUC TIP 
Restore IP with new 
placement to original 
dimensions and for­
mat Fig. 3-10N y 
I t Calculate the initial 
Nl- 2 t~lRestore original IPI 
pseudo vire lengthdimensions MIx 2 
of each net 
Fig. 3-12y 

LINUdT= LININTx 3/? 
Nl NI+l 
 I 
.. ...INTERCI-ANGE 
Make all favorable 
interchanges be txven 
cells 
KSW= 2Fig. 3-13 
debug 
N pri .nt_ 
Want Y 
N 
L ast, -
pass 
LELECN . -___ . -
Print net pseudoI 
~I,E, N lengths. Pr. t KSWo 
IN TO, 
AWas 
a good <a 
TE'.. IP ______change made - - agood cliange 
Reformat IPTMPZad 
with smialle r Y 
tnension and largeAclinensionIN 
Fig. 3-li 1 N 
Print pseuclo 
'wire length 
of ench net
-print IP 
y LE= 01 
NTFo r aotI nd 2± hA; _APTMI' 
IP=IPIaMP _ j 
Figure 3-9 PI.ACX 
TTT.- ? 
RECON-
Iniltialize, clear IC 
IZ = 1 
NIZ 2 
S nitale 
olumn 
8eareh
 
SPadLoku 
Cell neteeeto =0 
aloic 
Cek original map { Enter cell into new 
tlocate legal padI placement array. 
Pstion and enter 
pdinto corres. Update to INF 
pondng spotupdate 
elemnt of Nsearch 
tolni com~plete 
Adress next Row 
Replace old IP with 
:reconstructed a rray,
k-estorc original 
M',AP arra , restore 
originar IT dinmension 
Figure 3- 10 RECONSTRUCT IP 
HII-24 
IP 
ORIGINALa PAGE IS 
OF POOR QUALITY 
[ IEL -znext clem ent 
inIP 
ZSOUEEZRecalculate X 
dimension of IP 
MI = @pixa+s 
Beginning with col. 1 
row 1, and searchin' 
through cols., first 
store all el6ments in 
NAT (I) 
Clear IP. Clear row 
Ni of map array 
NI = LE 
= NN N1 
Beginning with ro, 
1, Col.4 fill in 'P 
dimensioned Ml x 
N'1. Fill clm 
first 
Figure 3-11 SQUEEZ LP 
[Address first 
element IEL of 
IP 
CAll-, CRCAI.C 
Calculate pseudo 
lengths of net 
contain*ing lEE 
Fi . 3-3 
LatMO e now r 
length in t ol ir 
Nclement inlength po tono 
each net, a c l t h 
sum ITOT 
Figure 3-1Z INIT IAL GALG 
111-25
 
Address IP (1,1) for 
interchange base 
element 
D~ fI 
ron,,'se 
. 
element.on rte 
Forfatechane 
Seet Y-index to 
SetSet 
c 
S Nfurthest 
can id tebou 
NI 2 
X-iidefon 
interchange 
candidate to arraynd M 1 
Fddress next 
inte rchange candL ­date in IP o'.ing
through cots. thenrolls 
Address Ist 
candidate for 
change 
Change Base and 
Candidate Elements 
coordinates in 
INF array 
Y 
I 
candidate N 
Calculate 
change in Pseudo 
Length of nets 
connected to BaseCelFlag
lEqual 
Store old and new 
lengths 
CALL CRCALG 
Calculate lengths -
of new connected net. 
to candidate cell 
Fig. 3-14 
" 
L0 
OCount 
Restore forer 
positions y restorin 
Set Eq Iand increment 
INT. Count 
S and Candidate 
Elements in IF 
. 
Replace Old Wire 
Length of affected 
et. ith N.% Wr6 
Set Good InterchangeFlag and inerecment 
Good Intercha 
Calculate totalLB 
change in pseudo-
length of nets 
C 
Ls 
'candidate 
Figure 3-13 INTERCHANGE 
111-26 
Cas 
n ba5e 
ted 
position 
3.3 Subroutine CRCALC 
PLACX calls, this subroutine to make the wire length calcilations 
on which cell interchanges are based. 
3. 3. 1 Functional Description 
Common variable IEL is set by PLACX to an element number 
which CRCALC is to use as its primary argument. The old pseudo-wire 
lengths, as set in NET (see Table 3-4) by PLACX, and the new pseudo­
wire lengths, as calculated by this routine, of each net containing cell IEL 
are added to form the total new pseudo-wire length, IN. These are the 
common variables passed back to PLACX for use in making the interchange 
decision. 
The hew'pseudo-wire length of'a net can be calculated by either of 
two subroutine branches, one using a fast and simple method for 2 pin nets, 
and another using a more general method for more than two pins. In either 
case, the calculation begins by determining the maximum index separation 
between the net's elements in array IP for both the X and Y dimensions. 
The variable-LE, which is varied by PLACX, is. then subtracted from both 
of these values. If either value is negative, it is set to zero before being 
added to the other value to form the new pseudo-wire length of the net, NW. 
If LE=0, NW is limited to'20. The only case in which NW is a true measure 
of a net's span in IP is when LE=O. 
3. 3.2 CRCALC Variables and Arrays 
The following list contains important local variables of the CRCALC 
subroutine: 
ID - Address of last net index in LNAD which references 
IEL. 
IEL - Argument element of IEL for which length is calculated. 
IMN - Net array index on the cell whose connection length 
is being added to the total net length. 
IN - New wire length for element IEL. 
10 - Old wire length for element IEL. 
111-27 
IW - -Net weight of current object net. 
JD - Address of first net index in LNAD which 
references IEL. 
KD - Index to LD in LNAD. 
LD - Variable which points to the net for which 
lengths are currently being calculated. 
LD24 - Index on new wire length of net in net array. 
.LE - Minimum segment of X or Y distance in IP 
which will be summed in calculation of wiring 
length. 
NEX - X-Span of wiring length in placement array. 
NEY - Y-Span of wiring length in placement array. 
All arrays referenced by CRCALC are in a format identical to that 
described for the PLACX subroutine in Section 3. 2. 2. 
3. 	 3. 3 CRCALC Flowcharts 
Figure 3-14 contains the CRCALC subroutine flowchart. 
II -Z8
 
CRCALC 
Inviali e old and l 
total pseudo uire 
sbrc Fdoes b et i'eletoents i20S& diffrencet. 0 if i 
[Find the Zc'span ". 
IP stlmteuact Lo
seO iff rence 
Add the differencestto form the ne, 
pseudo length for thi 
thsnet 
$-
_________di 
Venghsdo ir lengt

bewntahest to tns
soan p 
da vgumet 

nects to IEL beginnin
 
ith the first hpch
 
bccurs in NET array 
Find the net' oldp
-pseudo %ilrelength 
,and add it into tde
 
valuet of the old total
 
psed tireleneth
 
Ho 
l gn the net 
"have 
bythe 
ao n lat. 
Limit the nit p,,ud 
lengthi to ZOFigure..-...CRCAL 
Mu Itipy ps'udlo leipgth 
by Net Weight. Add 
the. result int. thetotal net, length valu 
c v al el t o 
S 
Find the tmmntum, x I 
array hicb ,~it. 'ust 
cover all leinents of 
netN nWiPh 
A.. . 
both the X and
 
Set negative
 
to form the n w
 
pse udo length fur thi
 
n et
 
-- _fren__c_ 
_____o 
QUALITYAL FigureR 
Was 2 
3.4 Subroutine ROUTE 
The primary function of the ROUTE subroutine is to form a map 
of the interconnections between cells specified by the NET array. These 
interconnections are made by "unfolding" the relative positions of the cells 
in the IP array and assigning each pin of each cell in this placement a 
position along an edge column of a linear chip map in array IRA (Table 3-8). 
Connections between the pins are then made by entering codes into the 
array elements which separate the pins, denoting the location of P-material, 
tunnel segment, wire segment, or both. 
3.4. 1 Functional Description 
Before the actual routing function takes place, several secondary 
tasks are performed by the subroutine. The first of these is the optimization 
of pad placement, occurring on the first pass through ROUTE. Flags are 
set during this first pass so that a large bias length is added to the estimated 
connection length of each net containing a pad. After these lengths have been 
calculated and sorted on length, control is switched to coding which clears 
the initial pad placement and shuffles pad positions so that on either end of 
the linear array, those pads having longer connections to logic pins are placed 
farther from the array's center. 
When this has been completed, the subroutine starts anew, calculating 
connection lengths for the end elements of each net and using these to determine 
which cells should be inserted by having the order of their pins in the linear 
array reversed. Each cell is also examined to reassign pins by interchanging 
the connections of functionally identical logic pins when the connection length 
can thereby be reduced. Upon completion of desirable pin iiterchanges, the 
NET array and others are updated to reflect these changes. 
The horizontal wire length required for each connection between pins 
is now calculated, and the NC array describing each connection is formed and 
sorted on increasing length. The actual running of connections between pins 
mapped in IRA is made from the list of connections in NC, shortest first for 
most efficient utilization of wiring area. Horizontal segments of the connection 
are run by searching into the wiring area from the connection's left pin until 
a clear channel is found to the right pin. Elements of this channel are then 
filled with the net number of the connection to indicate a horizontal wire has 
been run. The vertical connections between the-left and right pins and this 
horizontal channel are now entered by filling the intervening elements with 
either a 1, to indicate vertical metal, or a 999, indicating a P-material 
IH-30
 
tunnel under a previously run horizontal wire. Note that all horizontal 
connections will be metal, while vertical connections may be either 
P-material or metal. 
After every connection has been run another secondary function, 
that of determining the proper spacing between cells, is performed. This 
is done by adding the specified pad to pad spacing to the running length of 
pins following pad interfaces, and adding the spacing calculated by the SPACE 
subroutine to running lengths following all other interfaces. 
After a pass through FOLD, MAIN calls ROUTE for a second time. 
During this second pass, flags are set to bypass pad optimization and to 
reroute all wiring taking advantage of knowing the points at which the array 
is to be folded. The common variable IJ is referenced during this second 
pass to determine the number of folds, while array IF (Table 3-6) is 
referenced for the X-indexes in IRA at which the array is to be folded. By 
utilizing these indexes, each fold is now wired independently, resulting in 
a saving of horizontal channels over the wiring on the first pass. 
3.4.2 ROUTE 	 Variables and Arrays 
T.he following list 	contains key variables of the ROUTE subroutine: 
IAD 	 Running length of pins in linear array. 
IB 	 X-index on right pin of horizontal wire segment in IRA. 
ID 	 Number of pins of an element being considered 
for inversion. 
II 	 X-index on first logic pin of element in IRA. 
Ii 	 Number of folds. 
IK 	 Index on number of elements in IRA. 
IM 	 Number of net end point connections. 
IN 	 Flag which indicates whether FOLD subroutine has 
been run. 
For: 	 IN=l - FOLD has not been run 
IN=2 - FOLD has been run 
III-.31 
INC Inversion coding increment. 
For: INC=l 
INC=2 
-
-
Inverted cell 
Normal cell 
IPAD - Pattern number of a pad. 
IQ - Index on vertical wiring channel. 
IQ1 - Vertical channel wiring switch. 
IR - Flag denoting whether pad placement has been 
checked to put pads with longest connections on 
outside of linear array. 
For: IR= 
IR=2 
-
-
Check has not been completed 
Check completed and pads moved 
accordingly. 
IRAMX - X-index on last pin in IRA. 
IRX - Maximum X-dimension of IRA. 
IRY - Maximum Y-dimension of IRA. 
IRYY - Set to (IRY-1). 
IS - Space between adjacent cells 
Subroutine. 
calculated by SPACE 
ISW - Inversion coding flag. 
For: ISW=l 
ISW=2 
- Normal cell processing 
- Inverted cell processing 
IT - X-index on left pin of horizontal wire segment in IRA. 
I5 
- Y-index 
be run. 
on column in which horizontal wire is to 
JM Flag indicating status of interfold wiring. 
111-32 
KPK Number of elements in column I of NC array. 
K10 During routing - number of connections to route. 
K1I2 Location of true bottom pin number where connection 
wire terminates on fold edge. 
NN Net number of wire being run. 
NNETS - Number of nets specified by user. 
NSTRT - Index on first channel to be checked to run horizontal 
wiring. 
The following arrays are constructed or modified by the ROUTE 
subroutine. The more complex arrays are mapped in Tables 3-6 through 3-9. 
IRA(I, J) - Format IRA-R1: 
A linear list of all the pins. of all the elements in their proper 
sequence is constructed in the first four columns in format IRA-RI. 
The running length in column 1 contains the physical distance in
tenths of mils which would, separate a common origin at the top of 
the array and the associated pin. Except for the shuffling of pins
within cells during cell inversion and pin reassignment, this list 
remains unchanged through the ROUTE and FOLD routines. Fol­
lowing the first pass through FOLD, the fold points are flagged
during ROUTE wiring by setting the last element number of each 
fold negative. 
- Format IRA-R2: 
Columns 5 through 20 are used as temporary storage of various 
indexes, flags, and connection lengths during the ordering of 
connections, inversion of cells, and reassignment of pins. Table 3-8 
shows the details of this format. This storage area is cleared 
when the wiring nap, Format IRA-R3 is constructed. 
- Format IRA-R3: 
This map specifies the route to be followed and the types of 
conductors utilized by preliminary connections between cells. 
111-33 
- 1 2 3 4 5 6 30 31 32 33 34 
IP(I, J) 1 c l3 Il I 3[ Io 
Format IP-Il 2 O 2OP P34 
j= -1 2 	3 4 5 6 7 8 30 31 32 33 34 35 36 37 38 
NC( ) 1 2 C 1 C 3 C4 03 C7 CZ9 C30 C31 C37C33C341: 1 3  
Format NC-Ri 2 
3
 
4 
12 45 
1~ 2 3 4 5 6 
IC(I,J) J= 1 17 9 1- \ 
Format IC-Ri 	 2 21 13 5 
3 35 17 9 ­
5 53 
6
 
7
 
8
 
9
 
10
 
Pin# 	 IC(I,3) contains running length corresponding 
to Pin J of Element I. 
112 3 4 5 6 7 8 9 10 11 12 13 
2Format IRA-R1 O El El EZ EZ E3 E3 E3 E3 
3 0 1 2 3 1 2j3912 3 4 
4 0 03460 0 Ioo62 o0 
Pad Pad E 3=0 1 =2070P2P 
Table 3-6 ROUTE ARRAYS 
111-34 
IC(I,J) 
Format IC­
3= 1 
1 1 
R2 2 T 
2 3 4 
1 1 
2 22 
1 
5 6 7 8 9 10 11 
3 33 3 3 3 3 3 3 3 3 3 3 
4 4 
55 
42 4 
5 5 5 
4 4 
5 
4 
5 
4 
5 
4 
5 
4 
'5 
44 
5 5 
The pin sequence deviations show Pins 2 and 4 
of Element 3 have been reassigned to one another. 
I=
 
_ (, 1 2 3 4 5 6 7 8 9 10 11 12 
NXI5) 11 1 1 ~Vertical Length I 
Format NX,-R1 2 Horizontal Length 
3# of Crossovers 
XI Z 3 4 5 6 7
 
NC(I,5)* Jl 	 Net #J 	 j=I 
Format NC-R2 	 2 I Index to upper pin 
3 IIndex to lower pin 
4 I Connection length 
5 - iii X-Index of end of last fold containing net 
\1 2 3 4 5 6 
IC(I,J) J=l X X X X 
Format IC-R3 	 2 X X K X X 
3 XX X X ! 
4 KXXX X5 O X O O O1	 -t 
6 OX 0 OO 
7 0 0 0 0 
8 0 0 0 0 0 _[ 
9 0 0 0 0 0l 
100 0 00 0
 
Element IC(I, J) contains the X-Index to Element I, 
Pin J in IRA. 
*Final ROUTE output configuration. 
Table 3-7 ROUTE ARRAYS 
II-35 
ROUTE"'SUBROUTINE ARRAY MAP - IRA(I, J) 
3 
1 2 
1 1 0 
2 1 102 
3 5 102 
4 9 102 
"5 9 101 
6 13 101 
7 17 101 
8 17 46 
9 21 46 
10 35 46 
11 49 46 
12 53 46 
13 
14 
15 
16 
17 
3 4 
0 0 
1 0 
2 346 
3 0 
1 0 
2 346 
3 0 
1 0 
2 290 
3 296 
4 290 
5 0 
5 
0 
0 
0 
0 
0 
0 
0 
0 
4 
0 
2 
0 
6 
0 
0 
0­
0 
0 
0 
0 
0 
0 
0 
0 
0 
7 8 
146 
46 
9 
4 
2 
10 
1 
1 
11 
16 
36 
12 
2 
1 
13 
46 
46 
14 
2 
4 
15 
1 
1 
IRY 
Cdi 
,-4 O 4­
o 
. o. o 
W 60 0.e0 p 
0 . 0 
Id-I-
0 
3 
0 k 
Endpl'dn ~ ~ 4 do~ne 
#10 - 9034 PadCL 2 0 k k0 
#101- 9034 Pad 
Format of Columns 1 - 4 referenced as Format IRA-RI.
 
Format of Columns 5 - 20 referenced as Format IRA-RZ.
 
Table 3-8 ROUTE ARRAYS 
111-36 
IRA(X, Y) 
y= 
X 1 2 3 
1 1 0 0 
2 1102 10 
3 5 102 2 
4 9 1023 
5 
6 __ ' 7 ___ 
I 
4 5 
0 
_ 
346L 1 
0 
i 
6 7 8 9 
Metal 
Wiring Channels 
10 I1112 
i-_________ 
_____________•_ 
Maximum 
Y-Dimensic 
IRY 
9 
10 
_______,_________ 
__ 
_ _ _ __ _ _ 
_ _ _ 
o 0 
Ato ( Mta a 
-a)U 
So 
£ o " 
IRA(X, Y) = 
Crossover 
999 
.- e ;C) IRA(X, Y) = I 
Vertical Metal 
Maximum X-Dimcns ion = IRX 
Formnat TRA-R3 
Table 3-9 ROUTE ARRAYS 
71i-37 
For some element IRA(I, J): 
IRA(I, J) = 0 - Position (I, J) is not used.
 
IRA(I, J) = 1 - Position (I, J) contains a vertical metal wire.
 
IRA(I, J) = N - Position (I, I) contains a horizontal metal wire
 
of net number N, where l< N<998. 
IRA(I, J) = 999 - Position (I, J) contains a vertical P-material wire. 
JD(I) - JD(1) contains the total length of connections from a 
cell's pins to its edges for the cell in normal 
orientation. 
JD(2) contains the total length of connections from a 
cell's pins to its edges for the cell in inverted 
orientation. 
IP(I) 	 This array is not changed by ROUTE except for the 
interchanging of pads located on the same end of 
the array during pad optimization-
NET(I) 	 Pins which are reassigned are replaced by the new 
pin number. No other changes are made. 
ISR(I) - Array used to transfer input parameters to SPACE 
subroutine. 
ISR(I) = ICN(I+61) For I = 1, 2, 3. 
IEC(I) - On entry to ROUTE, IEG is reconstructed to contain 
in each element, IEC(I), the index to the Circuit 
Type File arrays ICK, ICL, and IPTRN for cell I. 
Before ROUTE returns to MAIN, the original format 
is restored, in which IEC(I) contains the pattern 
number of cell I. 
IC(I, J) -	 Format IC-RI: 
Each element of IC(I, J) contains the running length 
assigned to pin J of cell I in IRA. 
111-38 
Format IC-R2: 
Element IC(I, J) contains the new pin number to 
which connections formerly made to cell I, pin J 
have been assigned. Thus IC(I, J) = J except when 
pin J has been reassigned.
 
NC(I, J) Format NC-RI: 
Column 1 contains the placement array elements 
in a linear, "unfolded" order (see map, Table 3-6). 
Format NC-R2: 
Each row I contains information describing a con­
nection between two pins. 
For connection I: 
NC(I, 1) = Net number to which the connection belongs.
NC(I, 2) = X-index to the left pin of the connection 
in IRA. 
NC(I, 3) = X-index to the right pin of the connection 
in IRA. 
NC(I, 4) = The horizontal length of this connection in 
tenths of mils. Connections in NC are 
eventually ordered on ascending length.
NC(I, 5) = Flag used when running wires after FOLD 
has been run to determine fold points. If 
the connection runs down past the end of 
a fold, the X-index on the end of that fold 
is entered into this location. 
INT(I) Used to pass cell edge data describing adjacent cells 
to SPACE subroutine. It is equivalent to the array 
IDT(I) described in Section 3. 5. 2. 
NX(I, J) Array used to accumulate the horizontal and vertical 
length and the number of crossovers encountered by
each net. For net I: 
111-39 
NX(I, 1) = Length of horizontal wiring in mils XlO. 
NX(I, 2) = Number of vertical channels spanned by 
net's vertical wiring. 
NX(I 3) = Number of points at which this net has 
crossed over or under another net's 
connections. 
3.4. 3 ROUTE Flowcharts 
Figures 3-15 through 3-23 contain the ROUTE subroutine flowcharts. 
111-40
 
-V 
SET UP ARRAYS 
Pin list in IRA 
Elemuent C. T. F. 
in'dex in IEG 
Elene t list is NC 
Fi . 3-16 
CALCUL A'1 
LENG1) i, 
Sort net pins 
Calculate end lengt] 
List and sort Iength 
in IRA Fig. 3-17 
ShRffse Pans 
longest onnectonss 
to insidedof col. 
rry FFg 3-1. 
of 
a 
nith.sn 
ee 
rapl. idat 
Y 
C 
INVERT CELL'S 
Reassign pin andi 
invert cell. here 
drable. Update IC 
array Fig. 3-19 
_.pdateET 
3_29 
.r Fi iig it 
REyFORMN AR RAYS 1 
FSPCin IC.RS/r 
NC Update NET. 
Reform IC. Insert 
Snacer pins
Fi. 3-20 
RUN WIRFS 
Fill u~iring 
IRA 
into 
Fig. 3-2 1 
Space running length 
between.cells as 
necessary
Fig. 3-2Z 
GEUR 
Fiur[-15ROT 
SET UP ALCUL.A E 
ARRAYSLENCI 118 
Set IRA array rus is t 
limit: Indexc on end Point 
-list: I =1IRYYrIRy -I 
Set conductor
 
'ipacings to be used Sort pins of not into
 
by SPACE subrou- order of appearance
 
tine: for I= 1, 3 in IRA.
 
ISR (I)=ICN (It6l)
 
Store net's do.. end 
point conneclto,, pinClear IRA array and dowc flag In cot 
8, 9, 10 of IRA 
(format IRA-RZ) 
IEG in 
special ROUTE 
formatPid 
yetVN 
Reconstruct lEG so I 
lEC (I) indexes the 
Parameters of cell down end .4 
I in IPTRN, ICK. and point a Pad 
IEL 
y Calculate do,,n endp andPon 
point lengthan 
. - -. store in ILIA cot.Calculate doun end L itUnfold pads in IP point length, add 
­
to form linear large pad bias, store r.
 
placement in col. 1 in co Ii IRA (1, lZ=, TI­
of NC F Store net's up end 
(format NC-RI) point elenment.ptn. 
and up flag ii, cola. 
S8,9, 10, of IRA 
(format IRA - RI) 
Construct linear 
Pin list in cols. 
N opdntid1-4 of IRA dsPa 
(format IRA -Ri) Up yet 
< 
end point N __ y 
a pad ~7f­
in IRA 
running length J Calculate up end 11 
Construct pin toConstuct pn totore point length andcol. 
runingln-t dn s IR. 
cross reference Point length Add ____-­
p.d bias store *nin IC 
Cot. 11 of IRA­(format IC-RI) - Sot end point ind ex:, 
IRA (I, 12):l 
Lnr.?yint index' 
R ETURN 
____ 
Fur3-16 SET UP ARRAYSnt 
'- [ Address next net NLast 
and I? onascending 
length _of IRA (I, 11) 
RETURN 
Figure 3-17 CALCULATI; 
I.ENC.'I I1S 
OPTIMIZE INVZRT 
PADS CELLS 
Clear pad column of 
­
.ch CalL pdN
IP array at top. Add ress 1st Adesnin ddress next pin -
For top en poits

from length ordered
 
al
 
hesof pads in cotu.2cin nucof IP tusts orfrom bottom upt 
up end Point pads in
shortesto, firsten pito eCol. Z of IP from IsI 
bottom up,.hort.st
 
first
 
Set n dslasn g 
RETURN orientation, first end 
fs rassin-Figure 3-18 OPTIMIZE PADS atsbemndl in IRA co.length 
reassigne 5&6 (format IRA-I 
.R 2) 
b.Flar -a SD (2 [cl'
.. vgohi ,o .. 
s f n a inverted total... 
Lrrctin ltb ju
 
SD~~5- (1)fcel'mnoma 
Set flags and index 
for ell Nverted 
totaltcnctionpa-iR_nng nthS 
Smet rlas ai-n A. 1 
JD([clD( N 
rte
I,,ne 
snments. replace norma 
Invert cell's par-
Running Length in-
Address net cl,- N Ls 
E,. drn~xCall in NC 
~~ first pin 
Figure 3-19 I~;TCL. 
ARRAYA 
Net 
contain 
y 
Add bias length of 
+8000 to calculate 
crss e gt 
fag 
f d en 
1numbers into 
V/herreassigned pins ir e id on I 
n tcations 
de 
Aorrespond-
R= 410Ca 
error 
nsrint 
a 
c 
rinsbe locatefe 
cotIT'Fill unchanged pin through 
dumpN all or more 
eno s(Pi No. 
Aumbers int 
correspondingjlocatlos -n 
Cealcu latelgon 
"onnecconnioUse pin numbers 
in IC to update 
NET arrays 
N 
Yhi 
in NC it 
crs letege 
ofafold 
on 
NC 
foltd 
iC(<,foflnd 
-ide 
Print5 "egha 5 of +-3000to length 
array se 
Where t"o logic pinsart separated by 
[ xICN (73)] or more 
insert a spacer pin 
Addres next pi 
increment index onofnetconnection row of 
M; 
AR a s 
in 
/ 
Format NC 
Address next net, Ls t-edge 
Reform IC to index 
TX-coordinate of IRA 
Scontaining the 
corresponding pin 
t (Format IC - R3)}o 
_l 
I 
firs pinne 
Sort net conneto 
inN 
a~ ena Ing nt ln t 
Address first net, 
irst pin 
) 
[Clear all but first 
[4 columns of IRA. 
Calculate length of 
• the.horlzontal 
connection and enter 
| 
int NG. (Format NC - R2) Clear NX array 
•Figure 3-20 REFORM ARRAYS 
111- 44 
Address first con-
Address next con -
nection in NC.E 
nection in NC. 
Obtain connection 
info from XG 
NN=Net number 
IT z 
IB 
Top pin index 
Bottornpn inde: 
JM=I 
ConnectSet 
adjacent CStX 
to 
first wire 
rs r 
column 6 
colu 
o~r 
] 
pin 
N 
Set first tire column 
to coluiinn 8 
f Flag end ponts of 
etspan a fodlast. rY • all folds by 
setting
cell number in 
MO IZONTAL Set X-index of fold 
end into connection 
Run connection dlov~z 
dppropriate, column 
i 
-.....3-_j.0BLZ' nC nN 
IRA Fig. 3-23 .. .... 
0 3 Set IT to index Vold 
en3or top of next JM 
pin wire - JM ~ ._ __ 
JM-3 JM= > 
set IB fromTr NC index on bottom 
true b tto 
piinen 
flags for top pin L . 
2 of 
i 
old, store true 
S-Adjos t wire 
Se o NRt to fold 
end+l: 
-un vertcal it. o 
to connect in IRA. 
run metal if possible 
-t = 6 for adjacent pins 
-- 7 if no other vires 
cat fold 
ThIBD-I tunnel if necessary L other" is. 
Aidd vertical length]
and no. of crossovers 
In su in NX 
L(Iornmat NX -R I 
r 3-?ired 
- bottonm pin 
OF -Roo% 4 -_ _ 
LastLin Y 
F'gr 3-Z RUN WIRES 
TTA C 
PAGE CELLS 
Address first two 
cells in IRA. 
eCell 
a 
separation is 
ICN (3) 
S ,etuC. T. F. edge 
data of adjacent 
edges as arguments 
for SPACE 
CALL SPACE 
Determine proper 
cell separation from! 
edge data 
Fig. 3-24 
Add separatpp.inlto7Running Length of 
lower cell and sub­
sequent cells. 
I 
Set element numbers 
in IRA positive 
Last I ihE 
Adresex.p atter n eIRA 
Figure 3-22 SPACE CELLS 
111- 46 
OR! ZONTAL 
column out 
Address nnet 
sear-ch 'I re cqlurnn 
ITedo to emfrom 
either IB o lge 
fold. end in IRA,
wbhichever conics Istl 
Is 
in NX.no  
ror 
array calircof same" 
net 
Print orrorinIRA, eIT 
EXre 
Is 
Address nextTRA 
zmctol~slastentr elcarnt to nind t
 
IER=~~~ dd. iteemn 
rotto 9 If 
Entesorenu brI nout 
into 
~ el i Mm~ nN ~ dre n 
et
 
ru 
Add runninguntength 
st
 
NX nin hos vcrhc[ ] 
Add I ocunto 
a O~ QUA--I F a-aireHORZONTAL3o-

111-47
 
3. 5 Subroutine SPACE 
The SPACE subroutine is called by ROUTE to calculate the distance 
in tenths of a mil which must be added to the running length of a cell edge pin 
to separate it from the adjacent cell. 
3. 5. 1 Functional Description 
The process spacing requirements, as set by input parameters 
ICN(62), ICN(63), and ICN(64), are used as subroutine arguments through 
array ISR. The distances between the cell's edge and the metal and P-material 
within are specified by the edge parameters of the Circuit Type File, and are 
input via argument array IDT. The subroutine breaks down the data words of 
IDT so that the parameters may be referenced individually in array IC, as 
shown in Table 3-10. By using the ND array, sets of corresponding parameters 
are referenced and checked against the minimum- spacing requirements of the 
process and the current value of IS. IS contains the largest separation require­
ment which has been determined at any point during the checks, being immediately 
replaced by a larger requirement when one is found. Thus when all the 
parameter sets have been checked, we will return with IS being the required 
space between cell edge pins. 
A list of the edge parameter sets which are checked and the process 
parameters they are checked against is included in Table 3-11. These variables 
are defined in the description of the Circuit Type File in the Banning Engineering 
Notebook. 
3.5.2 SPACE Variables and Arrays 
The following key 	variables are referenced by SPACE: 
IS 	 Distance calculated by SPACE by which the edge 
pins of the two argument cells are to be separated 
in tenths of a mil. 
ISS 	 Temporary storage of space required by specific 
parameters. 
The following arrays are referenced by SPACE: 
IC(I, J) 	 Array constructed from IDT containing each of the 
24 decimal characters of the input word in individual 
elements of the array (see Table 3-10). Note this 
array is not in COMMON, and hence is not related to 
the COMMON IC array used elsewhere in the program. 
111-48
 
1= 1 2 3 4 5 6 
IDT(I) 1221611 In11210 Notused ')31013 101226 Not used 
Format IDT-SI 
IC(K) K= 
Format IC-S1 
1 2 3 4 5 6 7 8 90 i12 13 14 15 16 17 18 19 Z021 
2121116111o1 10 3 101 3 11 101 
Note this is not the same array as the array 
labeled IC in COMMON. 
22 
2 
23 24 
6 
ND(I) 
I 1 2 3 4 5 6 
1 411618 12012 114 
7 8 
618 
9 10 
12 
.11 
1 
12 13 
161 6 
14 
20 
15 
4 
16 
14 
17 
8 
18 
18 
Format ND-Si ND is an array referencing elements of IC. 
All elements are set by a data statement. 
Table 3-10 SPACE ARRAYS 
111-49
 
Parameter of Parmater of Process Spacing 
Cell #1 Cell #Z Checked 
DP DP ICN(62) 
DLP DLP ICN(62) 
DUP DUP ICN(62) 
DLM DLM ICN(63) 
DUM DUM ICN(63) 
DMB DMB ICN(63) 
DLM DPM ICN(64) 
DUM DUP ICN(64) 
DLP DLM ICN(64) 
fUp DUM ICN(64) 
TB TB N/A 
DB DB ICN(62) 
SPACE PARAMETER CHECKS
 
Table 3-11
 
IHI-50
 
IDT(I) 	 Argument array containing the edge parameters of 
the adjacent cells. IDT is equivalent to the INT 
array of the ROUTE subroutine. 
IDT(I) = INT(l) - Ist cell, edge parameter word 1 
IDT(2) = INT(2) - Ist cell, edge parameter word 2 
IDT(4) = INT(4) - Znd cell, edge parameter word I 
IDT(5) = INT(5) - 2nd cell, edge parameter word 2 
ISR(I) 	 Argument array containg the process spacing require­
ments. 
ISR(I) = ICN(I+61); for I=, 2,3 
ND(I) 	 Array which is set by a data statement and is used 
to sequentially reference parameter sets from IC. 
3. 5.3 SPACE Flowchart 
The SPACE subroutine flowchart is contained in Figure 3-24. 
111-51
 
P to P 

• 
Calculate the call 
spacing re toseparate P n'aterai 
ICN (62) 
u )(, D.11, DLSI) 
1)(DU1,DU 1 
PAGE lB 
nPtOR0 QUA|Lj' 
OIIXA L PAGE ISOr POOH QUALrly 
SPACE(ISR, IIIS) 
Transfer edge param
 
eter into IC array in
a single characterfornat. 
Set IS to spacing

required to
 
separate tunnel ends
 
y C I N (62). y
 
IntcI tera S a It 

0"ake ehck oa DLP
edge parameter fboth calls. 
Address tbials p ­
totne eetoaramelor 

[checked. in 
 IC arreay 
aci eretal P to 

Sbe checked 
,
 
Metl to ea 
lt------
-CIac...... ... ch Iei 

-- :-~t required t
spain elquired spaig rqired~ofpaa te "Irab to 
n(6by ab63m. 
than space Sspace calculated 
eu retunnt tyo 
MNREO
rigue - t 
/a type 6 [Add bias to ra-]tunnel nd r i­
across from a eter to allo tnnels 
Calcul~te main cell 
spacing to separate 
-bus tunnels by ICN 
(6?). if greater than 
IS replace IS. 
Figure 3-24 SPA*CE 
1Il- 5 z 
I 
3. 6 Subroutine FOLD 
FOLD subroutine is called to determine the points at which the 
linear collection of cells in IRA is to be broken into smaller fold s-egments. 
3. 6. 1 Functional Description 
As explained1 in the MAIN description, FOLD is called twice; the 
first time just to locate these fold points and the second to attempt to improve 
them and to put the folds in appropriate form on a scratch storage for latter 
reference. The number of folds to be made is calculated during the iirst pass 
and stored in ICN(67) to force the sanme number of fblds on the second pass. 
This calculation takes into account estimates of width of wiring located between 
trial folds, the width of wiring around the left edge of trial folds, and the 
actual widths of cells in the tentative folds. The algorithm determines the 
number of folds which form a chip with the smallest Y-dimension that is not 
less than its X-dimension. Thus if fold determination is left to the program, 
chips will always have greater height than width. 
The PRF User's-Manual describes options to force the number of 
folds to a specified number, or to specify the cells which terminate each fold. 
If the latter option is not selected, the program will attempt to locate the points 
at which the string of logic cells must be broken to give the required number of 
logic folds having the most uniform length. This is done b y breaking the array 
into tentative folds and then attempting to modify the number of cells in each 
of these to decrease the length of the array!s longest fold. Pads are always 
folded separately in end folds regardless of relative fold lengths. 
Once the breakpoints have been determined, they are flagged in the 
IRA array by setting the elements of the first and last column of each fold 
negative. Each fold is also described by a four element colunn entered into 
the IF array. All the information on folding required by ROUTE to run wires 
on an individual fold basis is now contained in these arrays, and the subroutine 
will return if flags indicate this is the first pass through. 
On the final pass through FOLD, several operations are performed 
on the IRA array to refine and reformat it.' All the array's wiring is searched 
for locations which will require a connection between meta.l and tunnel, and 
998 is entered into these locations to indicate tunnel end positions. The search 
also looks for tunnel segments having five or more elements which can be 
replaced by metal, and enters the necessary tunnel ends and metal for these 
connections. 
~ 111- 53 
&3O 
IRA is placed in the format utiliied by the remainder of PRF byidentifying those folds which must be inverted (folds which will have 
interconnections above their cells) and interchanging their elements
about both the X and Y axes of symmetry. Since the top pad fold must be
normal and the bottom pad fold inverted, an odd number of logic folds will 
cause a dummy fold having no cells to be inserted in the array. Each foldis finally transferred to the scratch storage from IRA, completing FOLD 
operations. 
3.6. 2 FOLD Variables and Arrays 
The following list defines key variables referenced by FOLD: 
IAH 
- Average height of cell interconnections of a fold. 
IARL 
- Length of logic elements of a fold. 
IB - Index on bottom logic element pin total running length. 
IFL - Nominal running length span of a fold. 
IIF 
- Current number of folds which have been determined. 
IN 
- ROUTE pass number flag; initialized to 1 by MAIN. 
IPH 
- An approximation to the height of pad folds and 
associated wiring. 
IR - ROUTE pass number flag; initialized to, I by MAIN. 
IRYY - Y-index of second last row in IRA. 
IT - Index on top logic element pin of fold. 
5l 
- Number of edge pins included in logic cells; hence also 
the number of columns in NC during fold optimization. 
J3 
- During fold point optimization: J3 = The total number 
of folds. 
KTOP 2 x (number of top pad fold pins) - (number of logic 
fold pins). 
111-54
 
LNGF Length of longest fold of a particular folding 
configuration. 
LNGL - Length of left fold being compared for length. 
LNGR - Length of right fold being compared for length. 
LNGST - Shortest of the longest folds found during optimization. 
NF - Number of folds for trial array layout. 
NFl - (Number of folds) - 1. 
TRH - Trial height of array. 
TRW - Trial width of array. 
The following arrays are constructed or modified by FOLD: 
IC(I, 3) - Format IC - FI: Element IC(I, 3) contains the net 
number of a wire which is to be connected to element I, 
pin J. 
IF(I, 3) - Format IF - Fl: See Table 3-12. For Fold I: 
IF(I, 1) = Index to pin in NC which is the last pin 
of fold I. 
IF(I, 4) =,Set to 0 initially; used as a modification to 
the index in IF(l, 1) during fold optimization. 
Format IF - F2: See Table 3-12. For Fold I: 
IF(I, 1) = Y - Index on last horizontal wire of fold 
in IRA. 
IF (I,2) = X - index on top pin of fold in IRA. 
IF (I, 3) = Y - Index on bottom pin of fold in IRA. 
IF(I, 4) = 1 - Indicates fold I inverted. 
INT(I) Linear array containing the X-index to the bottom pin 
of every other logic fold in IRA in normal sequence,
beginning with the first logic fold. 
III- 55
 
-1
j- 1 2 3 4 
NC(I, 3) 1 X-index to right edge pin of cell in IRA 
2 IRA running length at pin 
Format NC-Fi 	 3 Width of channels at pin 
4 - - 0 Poirpin laa 
5 Not used 
I=
 
1_ 2 . . 
IF(I, 3) J=1 Fold ref. pt. index to NC 
2 Not used 
Format IF-Fi 3 Not used 
4 Fold variation increment 
Where I = Fold number referenced 
1= 
1 2 ... 
IF(I, J) 1 - Fold width 
2 X-index on top of fold 
Format IF-FZ 3 X-index on bottom of fold4 1 T - Normal folidfla 
inverted ?oldf~ 
Where I= Fold number referenced 
I= 
j= 1 2 3 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 
IRA(I, J) 1 1 0 IRA is output 
2 in this format 
Format IRA-Fl 3 on the work tape 
4 after FOLD has 
5 been run the 
second time. 
Interconnect Format 
g 999 = Crossover 
"01 o * 998= Tap1 = Vertical metal 
+ . 2--O200 = Net # of metal 
0 2 0)0 = Open 
2- 0 0 
O1S t 
0 
; 
Data is 
which 
blocked by folds 
are alternately row 
Li and column inverted. 
Table 3-12 FOLD ARRAYS 
111-56 
IPR(I) Linear array used to store element numbers 
of breakpoints when the breakpoints are 
specified by user. 
IRA(I, J) Format IRA - FI: See Table 3-12. For 
column I of IRA: 
IRA(I, 1) = Running length (same as Format 
IRA-RI). 
IRA(I, 2) = [(100 x element number) + (pin 
number)]. 
All remaining rows of IRA contain the wiring 
date entered by ROUTE and shifted down two 
rows to utilize the rows formerly occupied by 
the pin number and reassignment flag. The 
wiring data is modified and tunnel ends are 
entered where required by setting elements to 
998. 
NC(I, J) 
- Reference 
See Table 
to right edge pins of cells in IRA. 
3-12. For edge pin I in IRA: 
NC(I, 1) 
NC(I, 2) 
NG(I,3) 
= X-index on edge pin I in IRA. 
= Running length of edge pin from IRA. 
= Width in mails x 10 of horizontal wire 
NC(I,4) = 
crossing edge pin. 
Fold pin flag: I = last pin of logic fold 
0 = normal pin 
3.6.3 FOLD Flowcharts 
Flowcharts of the FOLD subroutine are contained in Figure 3-25 
through 3-31. 
111-57
 
*-FOLD 
Initialize: clear 
IC~clear IF 
Determine i of folds 
requiredLFig- 3-26 
1st I
 
pass M'-rLons Fodg
 
Read input of folds as 
cards specify 
­ p ifding break- BpRcEiK
points into 
Print: ford IF 
Setbreak points in 
PutflTinFnDS n S n p 
inid.OnyN~~ ~ ~ PncIeapaFra IIAA FL) c 
Fig.3-30 _ j_

PIRA o m p t
 
n ro o
Lo at ruh horat e 
Wre RA n flFig. 3-328ETURNLD 
Figr 3-2 n ssfalo dedt
!rLFtcin o k a e  
n
uot on I-Q
 
1ig 3-30
 
TTTrm 

3F30uinto-I5 (67) 
1,PTT 

--
n--r---
N F F -
NF-NFtI 

Construct IC 
(format IC-Fl) 
Flag last pin column] 
of top pad'fold and is 
pin column of logic 
e. negative j 
Flag lstpinco of 
bottom pad fold and 
last logic pin column 
negative 
fCalculate total run in1!lcngth of logic cell, 
1IARL. " 
!Calculate height of 
v iring, tAF. 
Calculate approximate 
height of pad fold 1. 
wiring IPf 
Set trial of folds 
to NF-l 
Calculate trial 
chip height, 
TRII 
Calculate trial
 
chlp width, 
'RII
 
ffold lngth
 
y exceed lAY 
N
 
ORIGINAL PAGE IS 
N-: . , 
oF POOR QUALIT_ 
Figure 3-26 SOHAPIF CIlIP 
111-59 
Flag fold end inp 
(frat NC-Fl) 
V 
Enter fold in Il 
colas. I and 
decrementNFfornatcount fold 
Pt int, to Ilag Fl 
EtrfoldinI 
gfoing
 
on. last logic 
Icreme ninal 
length to ictie 
logicping el 
Figbrez'2n3REAI 
BREAK 
Deterinle nominal 
length of a logic 
fold 
Address first pin 
reassignleflleft 
Enter pin into NC]
.i
__El­
irray. Y-cols and2 
(Format NC - Fp) 
Determine amer1 
width of horiontal 
wiring above pin j 
iry oldonger.
tha nmial N 
OP '1IIZE 
Set last Y- co, 
IRA negative 
of 
loop. count-O Debug 
Print: 
NC array 
Using the trial 70old1 
points find the 
length of the longest 
fold including edge 
wiring 
Ha'c 
we gone through 
loop. 600 
Set these fold points 
in NC and IF. shortest longest 
old yet four 
Begin optimizing 
again v ih fold 
-
[ Try adding one cell 
to object fold I 
LNGST, 1N G,I 
LNGL. L,NGR /J1lJ3. LOON' 
J, II, NB ,-Debu, 
Debug 
N rnorQ than x 
2 cells been 
add(ed to thsPrint: 
Idy 
Restore fold and go 
on to next fold 
-
I LOOP1 
AAdd oo el 
fold 
N 
el to 
OF poog QUALMY 7 ) 0 i
 
'4 
[Address the 
fold 
first] 
Figure 3-2R l)" IMl.: 
111-61A 
. .. ----.­
-4 element and pin 
ho, at breakpoints 
negative in IRA 
Address first pin of 
first fold 
Locate and delete 
any empty horizontal 
channels in IRA. 
Determine width of 
fold wirin 
Addrespine firs 
Enter folds des­
cription into IF 
(Format IF -F2) 
Print: fold's 
description 
from IF 
A ddress first pin 
of next fold 
Ls 
fl 
Figure 3 - 29 SET FOLDS 
IH-62 
CLEAN 
;IRaCAL 
Address Ist pin in 
AddrtPin 
IRA 
SAddress 
REIGIIN 
' 
Last 
N 
/ 
next pin 
sese nw s b elo 
Search 
Iu 
pin-­" 
s 
Habeve 
t P 
tuneother 
-
l 
tunne 
pi 
hona-r 
NN 
-
l 
Y been:qunnelohat'"--
S egmsegmsnt 
rooo I 
etertunnel nt in lo o 
segment s t b e nd tunlhv 
e 
a Noth n 
nelf 
u n l Ngthuicro 
crossotar 
treretnt.n...e 
-­ : een%-o 
IER:34 
Net1t 
Put innupp tnl tunnel or 
enid aeve 
i 
lowe c 
enaidra 
d 
-
.... 
If the Znl scLg cz -­u/ei­
d. n.i .a 
_c-
plct1htne --
Set idcx to sMrceht 
next segnst U­
" ---.... 
JOF 
tunnel ed at upe 
Ei ientne~u 
IorNA PAGn " POOR QUA£rptS 
Figure 3-30 CLEAN 
11- 6I3 
VE:RTICAL 
TAPE 
Address first fold 
the second [old tipasfirst fold 
Set index to address 
next inverted fold 
Clear row 4 of IF 
Set IF (1, 4) to I for 
fold I to be inverted 
Determine fold size 
from IF 
Address first fold 
Write fold from IRA 
to scratch storage 
P rint: 12D 
J2, il, iJ 
Invcrt the positions 
of all elements of the 
fold in IRA withfol 
respect to both 
coordinates 
a1, e
y> 
N 
. 
8ins 
.
at a 
N invertedfol s Last 
y 'y 
i* hen las 
IsR 
Nol 
ml --
fetoidextoinvert ] 
-­ ,lrn 
Xh 
in 11-62 
last fold 
Figure 3d,31 TAPEt 
3. 7 Subroutine DIDDLE 
The DIDDLE subroutine forms a square mar of the chip in array

IFA from the previously formed fold segments and makes the 
required

interconnections between these segments.
 
3. 7.1 Functional Description 
DIDDLE calls REED to read individual folds into IFA and maintain
pointers on the locations of both the last fold and the 
second last fold readinto the array. If the last fold read was inverted, DIDDLE proceeds to make 
the cross-fold connections required between it and the normal fold read inpreviously. If it normal, connectedwas the fold is to the previous fold by

left end-around wires. Once it has been connected, the loop recycles 
to
 
read and connect the next fold in sequence.
 
Cross-fold wire routing begins by extending the right edge wires far
 
to the right of the longest fold of the pair 
 (the top fold of this pair is normal,
the lower fold is inverted). Beginning with the centermost wires and working
out, extensions of each wire broken by the folding are then matched and the
folds are searched 
to determine the rightmost and leftmost connection pins.The coding block headed CROSS WIRE determines the leftmost vertical channe 
through which the crosswire can be run. Since this channel may be to the
right of normal fold wiring, the EXTEND coding may be required to assign
running length values to these new vertical channels. 
Horizontal wiring which is no longer functional in the connection is
then deleted as the cross-fold wire is run by coding block XRUN. 
 Horizontal 
wires having no connection to pins of the fold pair are deleted entirely from
the folds. Cross wiring is completed when all of the extended right edge wires 
have been matched and either crosswired or deleted. 
The program branch which perfbrms cross-fold connections also 
performs bonding pad spacing calculations for pad folds. The space calculated 
is based on the total length of the adjacent logic fold minus the length required
for pads. The bottom fold also allows a space for the test transistor to beinserted on its extreme right. If the spacing calculated is not greater than the 
mininum set in the input parameters, it is forced to this minimum value. 
Left end-around wiring, performed by the other major branch ofDIDDLE, occurs immediately after normal fold isa read into IFA. Left edge
wires of the normal fold are matched with those of the inverted fold and both 
are extended left to be connected in the furthest available vertical channel. 
Each wire is also checked to determine if it has been deleted fro.n the previous 
111-65 
fold pair and must run up to folds above them. The required tunnel is 
entered if such a connection is indicated. 
DIDDLE is completed when the last fold has been entered into IFA 
and connected to the previous fold. A dump of IA in format 6012 in
Table 3-13 shows the interconnections of a small chip, consisting of a pad
fold, two logic folds, and another pad fold (note that the dump indexes are 
not in the same directions as generally referenced in this manual). Cross­
fold wires have been run between Folds 1 and 2, and left end-around wires 
are run between Folds 2 and 3, while the required cross-fold wires from 
Fold 3 to Fold 4 have yet to be run. 
3. 7. 2 DIDDLE 	 Variables and Arrays 
The following list defines variables referenced by DIDDLE. 
IMI 	 Right edge of right end wiring. Indexes channel 19 
columns to right of folds. 
IST 	 Starting vertical channel of left end-around wiring; 
set to ICN(8). 
ISW 	 Switch is normally set to 1. When the right edge of 
the normal fold is searched and no more wires can be 
found, ISW is set to 3, forcing the routine to make a 
second search after the folds have been extended as 
required.
 
IS1 	 Switch initialized at start of each crosswire pass to 3. 
Controls whether crosswire is to be run during the pass. 
IS2 	 Switch used to sequence normal fold, then inverted 
fold through reference pin removal coding. 
IS2 = 1 - Normal fold processing 
IS2 = 2 - Inverted fold processing 
IS3 	 Flag used to indicate one of the folds of a fold pair 
contains pads. 
IS3 = 1 - No pads 	in fold pair 
IS3 = 2 - Normal fold contains pad
193 = 3 - Inverted fold contains pad 
!I-66
 
J-l 5 10 15 20 25 
 30 35
So0u uoooouoooooo 0000000000 
 0 0u 0000000
 
n ) oc'r) n (I n o n..(I o ,n n o n n 0 0 u 0 n 0 0 0 0 00 0 pOO0o0ooooo0o00000000000o00000000000000
 
u-o- 0o0 _o u_ _ 0 0 _Q
-o-- -- -- 0 0I.I0I0!_0 0 0_I_11050 0 0 o0o__0 0__a____O_
5 aAAu 0u5 0i000  Q 
 . 101 50 00000 Q 0 0.
 
-- __0u_0 0_0r__0__o_ 51013 1 1 1 1 111 1 113 5000000000_0.
0 u u 0 a 0 00 0 5 o13 4 1 1 1 1 1 1 1 413 b 0 U 0 0 0 0 0 0 0'0 0 
n'i2[ ( "5 13 4 n ioO41 5 0u O s0nOO0 00oon0 0 0 0 0a0 0 0 5 013 4 U 0 0 0 0 0 0 413 
 5 0 U o 0 0 0 0 0 0 0 0 
-CX O-- 00-ID-Q.-00-OG 5 0i3400oaoao--3b. Th-U-rnfliarDhf()00 00 0 u 0 0 0 0 0 o 5 013 4 0 0 a 0 0 0 0 413 
 5 0 U 0 0 0 0 0 0 0 0 
-----0o- O 0 ___ -. -0 o - a -0-0--- . _00_ 0&. . o00 
0 0a0 0 0 0 0 0 5 013 4 a 0 0 0 0 0 0 413 5 0 U 0 0 0 0 0 0 0 0 0al(I0f050n4000 
 413 5 0nnnn000 0Q2000
15 0 0 0 0 0 10 0 0 u 5 013 4 0 0 0 0 0 0 0 413 5 0 U 0 0 0 0 0 0 0 0 0
 
0--0--0 -0 --0--O---0_5_-..-013--0-0.-0-0,0 
-0--0_413 .-5_D .uoOo-o_ 0o_ 0 0
*0 0 0 0 0 0 0 0 U 5 013 4 0 0 0 0 0 0 0 413 50 U 0 0 0 0 0 0 0 0 0W_-Juo o._ nO )nO c) 5 .13 4 o_0_0_0 
_0 OODOQ 0t__Co4_ _U 
00U0000U0005 01340000000413a 
_0000000 ­
o 0a o 0 0 0 013 4 0 0 0 413 u 0 0 0 00 0 5 0 0 0 0 50 0 0 0 0 0 
--- 000 -0-0-( --0C5 -0 1.32+.AL0.J0 0  413 50U00000QSQ .0 .0 
0 0 0 0 0 0 0 0 0 0 5 013 4 0 0 0 0 0) a 4350U 0 0 0 0CI 0 0 0 0 0 
- 0-r-o-00...00uo-., -0-Q0Q4130 b0134 b 0 U 0_ 0 0 0 0 000I=252801 U 0 0 0 0 0005o013 40o06Ud 034010413§b 0)U 0 0 0 0 0 0 00361 
2__211 1 1 19t 99998 1.5240o38a_1 413 5 0 n 0 51 1 1P0411003 00 0 0 0 0 4 5 013 1 10410 05203-9-7U--3' U 0 0-0 5 0 0 001p1J 
____9__0i0S._0 
 j 4989'.91 o66o49599999S 5 u 005o0003'98201 U 0 0 0 40 a 506 028208005 1 198999699' 0 0 513 1 10'271 
0.-0--__ 
_ 5_ . 51_306 -- _0 -A_.a__ _-_0- o t.bl _t __5130-_00 
5401 0 0 0 0 0 0 5 1 1 10454 09006 0 0 0 3 13 0 51300 0 0032' 
Afl£0IA__ WL,Io 1 1 1o0a 1 iQ3094fl5 1 1 3 5 13 0 n0051311 10C:2602 1 112 0 0 0 0 4 10 1 1 1 10226 00904-- s0SYT% 0 0 51311 oCI 
.2o3a o._oao .9998_1-1__1o21_0203_11i 1-5__5 o1-_O_ _ 0 0 00_ __0 
359801 0 012 0 0 U 0 0 10 0 0 8 i0396 03C-299999999 013 0 0 0 0 0 0 00 0 
7001 0(9Q 9 99 99 99 8 1 10370 04401 0 0 0 5 9 0 0 0 0 0 0 0 01 013 0 
- nL- (I :)") ') 0 n 0 0 0tCL00. 
1 1 01212 1 10232 05703 0 0 0 0 9
-----
.--- ._0_ 513 0 0 0 000 _00 00..0017-03uu--o--0-9-0;---- s- oa21_70 0_0Q_0_Q__513_'L0gO_0 0 0 
00 U 000000000000 
._..0__0 .,--. _,___.l _,__,_0_0.0_ 00005021 i139893D995 0 0 0 0 0 0 0 0.0_._0 0_ _07 9 O sl_71 l..0_5 00_ o _.O 0_0 0 0__0 0-0 00.-0o0000000O000 0083040713095 U00000000 0 
45 00 o000_0 
_0 00 9C21 _0_713. 09S5 000_ _00 'JfY U 0 00000 
00 0 
.0_.0 _.. - 01311 0 5 0 0 
0 0 0 0 U0 0 0 0 0 0 02104999999,399 5 U 0 0 0 0 0 0 0 : 
. 0 _.0. 0 0 0 Q 03405 0 Uo 0 o 0 0 0 -0 
.J54 3 . u uoi c0 u0 c_0 00 A 1713 5 U 0 0 0 0 0 0 40o oo 000o0u 0oo0 o -d-____oe_______-05102 0 -- C-l 0-- -- -0 " 
. .... .- 0._
0.. ..000.00. 
 C Q _ o0 0 0 0_0 0 0 o 0o0 OoJ 
-. -_ - - --- .. 
- --
Fold 1 Fold 2 Fold 3 Fold 4 
DIDDLE ARRAY DUMPIF j.1J_)_ _FORMLATIFA-UDI 
-
Table 3-13 
IT- iY7 
Ii - X-index on right edge of normal fold. 
16 - Pointer on candidate channel of normal fold for 
running cross-fold wire. 
16M - Conditional cross-fold wire's X-coordinate. 
17 - Pointer on candidate channel of inverted fold for 
running cross-fold wire. 
JNC - Net number of end wire. 
JNCM - Net number of trial crosswire. 
5l - Y-coordinate of top of normal fold's running length 
row. 
J2 - (Y-coordinate of bottom of normal fold) - 1. 
J3 - (Y-coordinate of top of inverted fold) - 1. 
J4 - Y-coordinate of bottom of inverted fold's running length 
row. 
J6 - Y-coordinate of normal fold's right edge wire. 
J6M - Y-coordinate of normal fold's trial crosswire 
end point. 
J7 - Y-coordinate of inverted fold's right edge wire. 
J7v - Y-coordinate of inverted fold's trial crosswire 
end point. 
KLI - Width of normal fold's right edge wires calculated 
at K by LCRD. 
KLZ - Width of normal foldis right edge wires calculatcd 
at K71 by LCRD. 
KRI - Width of inverted fold's right edge wires calculated 
at 1K7 by LCRD. 
iii- 68 
KR2 	 Width of inverted fold's right edge wires calculated
 
at K71 by LCRD.
 
KSK 	 Switch initialized to 1 after reading an inverted fold 
into IFA. When the crosswire search is to be 
recycled, KSK is set to 2, preventing more than 
two complete restarts 'on the same fold pair. 
K7 X-index on inverted fold's right edge channel 
containing the wire being run. 
K71 - K71 = (K7-1). 
LLI - Previous value of KLI. 
LRI - Previous value of KRl. 
MINSP - Minimum space between pads in mils x 10. 
MR - X-index on right edge of inverted fold. 
MST - X-index on first pad pin which is to remain in fold. 
NR - Count of the number of folds which have been read 
into IFA. 
NWAL - Minimum width of normal fold's right edge wires. 
NWAR - Minimum wid-th of inverted fold's right edge wires. 
The following arrays are constructed or modified by DIDDLE: 
IF 	 See REED arrays, Section 3. 8. 2. 
IFA 	 Contains the folded wiring run by ROUTE and broken 
into individual folds as specified by FOLD. The 
folds are read into the array by REED, stacked in 
the Y-dimension, and interconnected by DIDDLE as 
required to restore connections. See Format IFA-DI 
in Table 3-13. 
111-69 
NX 	 Contains reference to a net N associated with an 
element in IFA(I, J); where for array index K: 
(Table 3-14)
 
NX(K, 1) = I
 
NX(K, 2) = J
 
NX(K, 3) = N
 
3. 7. 3 DIDDLE 	Flowcharts 
Flowcharts of the FOLD subroutine are presented in Figures 3-32
 
through 3-39.
 
111-70
 
J=- 1 ... K4K 
NX(I, J) 
Format NC-D1 
1 
z 
3 
1 X-Coord. of Tunnel End 
Y-Coord. of Tunnel End 
Net Number of Tunnel End 
K4K indexes last entry made in array. 
Table 3-14 DIDDLE ARRAY 
111-71 
Increment 
countfold 
-CALL REED 
Read next fold 
as normal 
Fie. 3-40 

END WIRE
 
Run wire around 

left end of fold pair 
Fig. 3-33 
Inlttalze rewind 
work tape, clear 
IFA 
rAJ i 
Read first fold 
from ork tape 
Fig. 3-40 
N normal 
Increment fold 
CALL __ FIE.... 
Read next fold as 
inverted 
Fig. 3-40 
PREPARE FOLDS 
Extend wires right 
delete reference 
pins Fig. .3-34 
jS5PACE PADS _ 
A Adjust pad spacinc 
F~,3-35 
C ROSSWINE 
Run cross-fold 
wiring 
Fig. 3 36 
fold 
RETURN 
Figure 3-32 DIDDLE 
111-7Z 
Set indexes toaddrea 
*nvert. d fold above 
normal fold 
IST=ICN (8) ] 
-.Search for wire 
mnatch otn left edge 
Search for match 
with previous 
normal fold 
r wineth tnnldb 
Match 
with previousac Y onc 
fodaj 
to wire with tunnel 
fol 
Enter T.E. s on ends 
Make T.E. entry 
in NX array 
Run end around 
metal to connect 
&ire pair 
IST= IST-+1 
Index next w.ire pair 
in folds, index next 
vert. channel right 
N 1of fod wviring 
ORIGINAL PAGE IS-
END NVIREOF POOR QU .Figure 3-33 
111-73
 
PREPARE 
FOLDS 
Initialize 
r- indexes 
on 
Calculate width of 
wires at left edge 
of both folds -NWAL 
NWAR 
Extend hor. wirs 
19 elements beyond 
right edge of 
longest fold 
Initiali U flags, 
address normal 
fold 
a 
' n 
Does 
fole contain Y Set flag for normalpad f ld 
padLIP­
0N 
A rc ' ",,.Make error 
all le ments N 
__\___,_-- um 
in C. 1. F. 
EXIT_ 
Y 
Delete all reference 
pins except those on 
fold's ends 
Address inverted fold b o[ds 
ORIIGINAL PAGE IS 
OF POOP, QUALM 
Figure 3-34 PREPARE OLDS 
111-74 
Initialhze for bottom 
fold 
SPACE PADSold Y . " IInitialtec for top 
~ST-CMITo6X 
Searhor rightmost (6 
pin of previous logic N fold 
- fold 
MST=EAT+6X 
ICN (7) 
Search to etindex 
on rightmost pin of 
pad fold 
Calculate pad spacingl 
MINSP based on fold I 
length less test trans 
istor length j 
Calculate pad spacing 
based on available 
fold length MINSP 
ICN (3) 
'N 
N -MINSPICN 
4N 
INSPC(3)3) 
Y MNS? 
ICN (3) 
ICN (99)} ICH (99)NNS?PICNIS (98) = ItNSP 
there a dummiy N
• 
Is Is 
bottom fold 
iold .pty--.-.,o  N, 
Top 
fold Y 
< empty 
N Y 
Set running length of 
each pad fold column 
A 
Skip pads to be moved 
to side and 1st norma. 
pad r.. p randrs 
eqlual 
.... 
to that-o 
3 rd pin oi 
. 1st pad to right of 
Modify running 
lengths of remaining 
pads to allow DUNSP 
between them 
Lank at net p, 
right 
to N 
@ ------ / separation". 
from previous 
RETURN MINSPN 
y 
Is 
unntng 
length at 
either con­
nection =0 
' 
Fisure 3-35 SPACE PADS N 
OGUhIALJ1 
QF )O00 Q nt11I-75 PA GE 1$Shift 
-
th tscol. 
and all cots. on 
the right one col. 
further right 
Look at separation 
to net pin 
I 
- -
CRO7SSWIRE) 
nrmalifold for
 
ISW=I
 
IS4 - 1 
Set 2nd pass
 
any crospaamexterigh flag3Ii~i+'!.;:JKSK :-'°  =2 
o 
w.7' -F?-=- jW iresi~ aru 
e Ds offlsinort fold .r 
Sear_uiniSearch dxnit :+ ' , 
next wire, cl.Foundnd RETURN p s t 
wire b-EXIT gSli 
normal~ fold fJ :Ne poex~ et wircl U' S 
• entain tunnel no fold'sN *rmal 
r oun duiie 
Search for left2ost'CROSS MAHJ[,= 
Retur IS 
clear channel! 
Select channel and 
Fig. 3-39 
Figure 3-36 CROSSwi 
111-76 
Look at next column 
tleI&11 
_o 
Ft-0 
Wire 
aonect,to pin set 
below 
y 
N Wire 
conetcd to 
. 
y 
etError 
there a lndcx next column 
space pn to RT. 16=16+ 1 
N 
rcSameNm 
below 
y 
-,-
Go right one 
1 6=16 1 
Last 
column 
N 
Col. 
N have same 
v.1re 
,- Y 
Address cot. to 
right I 7 I 6+1 
dump 
IER -601 
ITvj~ -
chne 
cla-crs 
fold 
Last 
column 
-Error 
Y 4 
du:,' 
IER 57? 
EXII 
REI TRN 
Figure 3-37 CROSS MATCH 
ORIGINaE PAGE IS 
O)F POOR' QUALITY 
111-77 
ISW z 3 ] 
I 
CALL LCRD 
Calculate running 
lengths of fold 
e.xtensions 
Fig. 3-41 
Set s it o IS2ehto 
extend longest fold 
of pair 
e in e e et nd 
n' 
L 
n x ex 
Se n e eJ ~<-e ur" tp 
Tei t 
Set to e-tnd 
Bottom 
L cn Cturhs b tom fl 
extending top fod foId extenso/ \ ttopr bottom bottom fl fold 
A A 
N . 
AA 
• ,L "cross can l "vacated 
Shift channels right 
until cross channel 
is vacated 
3-38 EXTENI) 
II-78 
m bewire Setrahindexett 
onenect ertNcal 
Hae 
if chaneuint 
Indnnen ext chan 
RET UR'eeN both inodol 
fold badeleterign--
YN 
flbato riht - a Yeu T 
ever___ ocofoldfirst 
to .left Parameter of " 
aIsuchnet channel NR 
Figure 3w9 XRUN 
ORIGINAl PAGE IS 
OF POOR QUALIY 
3. 8 Subroutine REED 
DIDDLE calls REED to read individual folds from the scratch storageinto IFA. 
3.8. 1 Functional Description 
In addition to its function of simply transferring data into IFA, REED
maintains indexes on the locations of the currently inputed fold and the previously
inputed fold, and makes a row entry in IF for the previously inputed fold as a permanent reference to its location in IFA. Before reading a fold, REED incre­
ments the indexes so that it is placed immediately beneath the previous fold in 
IFA. 
3.8.2 REED Variables and Arrays 
Reed utilizes the following variables as either input or output arguments: 
Input Arguments 
33 - Y-index on top of previous fold in IFA. 
,4 - Y-index on bottom of previous fold in IFA. 
MT - X-index on the column in which the left edge of the 
fold is to be entered in IFA. 
NR - Number of the fold to be inputed.
 
Output Arguments
 
Ii 
- Right X-index of previous fold (previous value of MR).
 
31 - Y-index on top of second last inputed fold in IFA.
 
J2 - Y-index on bottom of second last inputed foldi in IFA.
 
J3 - Y-index of IFA on top of last inputed fold.
 
J4 - Y-index of IFA on bottom of last inputed fold.
 
MR - X-index to IFA on the last column of the last fold 
inputed to IPA. 
NR - Number of last inputed fold. 
111-80¢_,-SO 
The following array is constructed in Format IF-REl and is shown 
in an array map in Table 3-15: 
IF(I, J) - For Fold I: 
IF(I, 1) - Y-index on top of fold in IFA 
IF(I, 2) - Y-index on bottom of fold in IFA 
IF(I, 3) = 1 - Fold I is inverted 
= 0 - Fold I is normal 
3. 8. 3 REED Flowchart 
The REED subroutine is flowcharted in Figure 3-40. 
111-81
 
= 1 2 ... 10 
IF(I, J) 1 Fold Top Index 
Format IF-REl 
2 
3 
4 
Fold Bottom Index 
I FtgrYnaiY 
Not Used 
Where I = The number of the fold described. 
Table 3-15 REED ARRAY 
111-82 
REED 
IT- NWRK 
II AIR 
MRz 35-Croldlcngtfl 
+ N=J4+3t2 F 
J4fol3+dlold 
3 4dth -1 
Read from 
v orc tape: 
WFA (1, 3) 
IE MIT, M 
=J3 . 34 
Priol 
Debug y -
1old 
34-3441 
N 
F4J4 
orana 
N J =3- I 
First 
fold 
,ORIGINAL~ PAGE IS 
OF POOR QUALITYN 
N 
IF (Nl - 1,Z) :J2 
it­1,) 32t (N l- I.,. ...IF 
RETU RN 
Figure 3-10 RliED 
111-83 
3. 	 9 Subroutine LUaU 
called by DIDDLE to determine a X-direction runningLCRD is 
length value for a wiring column of IFA located to the right of fold columns 
which have previously been assigned such values. 
3.9.1 	 Functional Description 
The LCRD subroutine is entered with a X-index on the column in 
IPA whose running length value is to be determined, and a Y-index on the 
row of IFA which contains those running length values which have been 
It will return with 	the value K calculatedassigned for the fold of interest. 
as follows: 
K = [(Genter to center spacing) + (left edge wiring width) + (length 
of fold's previously assigned columns)]. 
3.9.2 	 LCRD Variables 
The following variables comprise the arguments of the LCORD 
subroutine: 
Input Arguments 
S - Y-index on IFA row containing running length 
as signment data. 
K7 " X-index on the column in IFA for which the running 
length value is to be determined. 
MM Spacing required between adjacent tunnel ends. 
MT X-index on left edge of folds in IrA., 
NW Value of left edge wiring to be added in IFA. 
Output Arguments 
K - Calculated for running length value for column K(7. 
K7 - X-index on rightmost running length value wlich has 
been assigned to this fold. 
111-84
 
3. 9. 3 LCRD Flowchart
 
The LCRD subroutine is flowcharted in Figure 3-41.
 
III-85
 
K4,~gNW.ILORD (3.K7. 
IERz299 
J)IFA (K, JIFA ( MT, J 
WFA (1(7, .J) 
K==K+NWM
 
IFA (7. 
 (RETURN 
7:K79991
-
EXIT 
,OF DOOR QUAuTr
 
Figure 3-41In -86LORD 
3.10 	 Subroutine LOOK 
LOOK is called to identify the net number associated with an 
element of array IFA. 
3. 10. 1 	 Functional Description 
is first searched toThe NX array, which will be in format NX-Dl 
of IFA.find an entry specifically identifying the net number of element (I, 5) 
assumed to belong to the net connectedIf no such entry is found, the element is 
to the logic cell pin having the same column and contained in the same fold as ­
the element. This net number is found by locating the proper pin in IFA and 
cannotthen finding this pin's reference in IC (format IC-Fl). If the element 
be located in NX and a fold pin cannot be associated with the element, the 
subroutine returns with a non-existent net number. 
3. 10. 2 	 LOOK Variables 
The following variables are used as arguments of the LOOK 
subroutine: 
Input Arguments 
I - X-coordinate of element whose net is to be identified. 
5 - Y-coordinate of element whose net is to be identified. 
K - Y-index to row in IFA containing cell/pin identity of 
pins in fold containing unknown element. 
L - Number of column entries which have been made 
in NIX. 
MR - Y-index on left edge of fold 1. 
Output Arguments 
N 	 Net number associated with element IFA(I, J). 
3.10.3 	 LOOK Flowchart 
The LOOK subroutine is flowcharted in Figure 3-42. 
111-87 
LOOK 
(I, j.,iS, N, 
I, M ") 
to 
1 NX(M, I)] 
-0 
s -NX (M.1 2)] 
N:NX (M, 3) MAL M=M-l 
I - -IA ECFZ FA l(1. l~OOtO 
___ 
N=NNETS + 2 NIC (E,
-1- IZP)-. . 
Figure 3-42 LOOK 
O/ 118O 0, z~0 Q4 
3. 11 Subroutine SQUEEZ 
SQUEEZ takes the wiring map formed in IFA by DIDDLE and attempts 
to compact it in the Y-dimension. 
3. 11. 1 Functional Description 
In addition to the primary function of reducing Y-channel require­
ments, SQUEEZ also performs the secondary functions of sequencing the 
calling of PADMVE to place side pads and making manual corrections if they 
are specified. Since the manual corrections reference wires in IFA by their 
absolute chip locations, the corrections can only be performed on a second 
pass through SQUEEZ after the ASSIGN subroutine has made absolute coordinate 
assignments to the wire channels in IFA. The LEN flag is switched by ASSIGN 
and checked by MAIN to control this sequence. 
The first call to SQUEEZ begins with tests for pad folds which are 
to be referenced by indexes as argument folds of a call to PADMVE. Although 
this subroutine is called for all pad folds, the fold is not altered unless the 
input parameters specify that pads 'are to be moved. The program proceeds 
to a loop through which each fold passes once. Here a list of all the pin 
connections contained in the fold is formed in the NC array (Table 3-16). 
Each point at which a wire connects to a pin or runs to an adjacent fold is 
designated a wire segment end point, and the appropriate array entry is made 
for each segment connecting such end points. Only those connections which 
are found within the fold are identified; left end connections, which are external 
to folds, are not altered by the routine. 
The loop proceeds to call the MOVE subroutine to clear and rewire 
all of the fold's connections from this list in NC. By sorting and individually 
running each segment of the fold's final wiring requirements, including those 
making cross-fold connections, MOVE reduces the number of horizontal wire 
channels required by the fold. This completes the rewire loop, which is then 
recycled until the last fold has been processed through. When this occurs, 
the program proceeds directly to the array refinement coding. 
SQUEEZ will be called a second time to insert manual changes, if 
this option has been selected, and flags direct execution directly to the coding 
performing this function. This coding individually reads and enters each 
change from the change cards (whose format is detailed in the PRF User's 
Manual). Only a limited check is made on the validity of these cards, but 
errors will show on the array picture output printed by the ASSIGN subroutine. 
After all change cards are read into IFA, the refinenent section of the 
subroutine is executed for a second time. 
111-89 
J= I=1 	 2 3 4 5 ... 
0 0 3011 0 Cross-Fold Tap FlagNC(I, J) 21 09 9 10 10 10 	 Index to row containing wire sement 
Format NC-SQl 3 4 7 16 3 3 	 Net number of segment 
Index to left end of segment4 7 32 6 29 40 
Index to right end of segment5 30 49 V 40 46 
0 	 crass-fold connectiona For noCross-Fold Tap Flag 
0 For connection to adjacent fold 
Typical values describing five fold connections have been 
entered in the above map. 
Table .3-16 SQUEEZ ARRAY 
111-90 
The refinement s'ection of this subroutine is primarily concerned 
with searching for empty channels which may have been cleared by PADMVE,
MOVE, or the manual changes, and deleting these channels from the IFA 
array. This search is also used to clear the wiring of redundant tunnel ends 
and other extraneous entries. When horizontal channels are deleted, the 
vertical wires running across them are restored and the IF and NX arrays
w;hich reference the folds are updated. 
3. 11. 2 SQUEEZ Variables and Arrays 
The following variables and arrays are referenced by SQUEEZ: 
- IB - Net number of right end of wire segment. 
IFPAD Although this variable is the argument of the 
SQUEEZ subroutine, it is not functional in the 
current program. 
IRET 
- Flag used to sequence through pad adjustments. 
IRET = 1 - Top pad fold 
IRET = Z - Bottom pad fold 
IT Net number of left end of wire segment. 
KTAP Flag indicating that a wire segment for which an 
entry is made in the NC array is connected at one 
end to the adjacent fold, and should be so flagged in 
NC(I, 1). 
KTAP = 0 - Wire has cross-fold connections 
KTAP = I - Wire has no cross-fold connections 
K12 - X-index to right end of wire segment in IPA. 
X(7 - X-index to left end of wire segment in IFA. 
K9 - Y-index on row of IFA containing wire segment. 
LEN - Flag controlling whether or not the subroutine is to 
be used to make manual changes on this pass. 
LEN ?z 0 - Put in manual corrections 
LEN < 0 - Bypass manual changes 
111-91 
LL4 Running count of the number of connections for 
which rows have been entered in the NC array, 
format NC-SQl. 
NOP Number of manual corrections to be executed. 
The following arrays are constructed or modified by SQUEEZ: 
IXW(I) 	 Array used in format IXW-Al to find X-coordinates 
in IFA of manual changes in the wiring to the left 
of the folds. The array is cleared after corrections 
have been made. 
IYW(I) 	 Array used in format IYW-Al to find Y-coordinate 
in IFA of manual correction channels. The array 
is cleared after the corrections have been completed. 
NC(I, 5) 	 Array used to store the description of each required 
horizontal wire of a fold for later use in rewiring by 
the MOVE subroutine. Each horizontal wire segment 
which connects any two vertical wires has a column 
of the array describing it (see array map, Table 3-16). 
The indexes contained in this column give the location 
of the original segment in IFA, 
3.11. 3 SQUEEZ Flowcharts 
Flowcharts of the SQUEEZ subroutine are presented in Figures 3-43 
through 3-48. 
II-92
 
XPADSN 
1st fold norma N 
Ify 
Set up indexes for 
1st fold of pads 
CALL PADIX F2
 
Move specified
 
pads to side
 
Fig. 3-49 
Set up indexes for 
last fold 
,CAll. I'ADMNV? 1 
Move specified pads 
to side
 
Fig. 3-49
 
Figure 3-44 'ADS 
I11- 94
 
SOUEEZ 
Manual 
set 
PADSiN
Move pads to 
side 
Fig. 3-44 
WORK 
FOLDRewire each 
L fold 
Ftg. 3-45 
or can nl 
Coe p 1a' fa 
WAFig. 3-47 
Fi g. 3-4 
_PAGCOREO RI~ nq~ TR 
- IF
 
Y IFA 
omomi Remove 
g y IFA 
IF I 9~g3-4 
FOL.D 
rotWOP,D1 
Initilhze, 
addres lst fold 
for Inverted normal for normal 
Put spacer column 
botvtoon each foldCOl. Set n.v Cot.' 
cell/pin 11) to 999991 
WIRE lIST 
Form fold ring 
list. 
Fig. 3-48S 
ast fceolum 
Ii 
fold or ?nd y f-. , 
_______ ~ ~n2nt fodN ~ ~ 
GALL MOVE 
Rex,..re all fold 
connections 
Fig. 3-52 
ol oddrsL s 
latfold 
___-A
-T R 
ORIGNAL PAGE .Is n oFigr OD 'ORt3-.S 
OF POOR QUALITY., M-95 
Read Manual 
pCORRECTehangc 
card 
Search IYW-aId 
running length row 
to find coord, of 
IF A ;search IXW if 
necessary 
Print: 
Are V-'11I% ABOVE 
CMAND -
T.. in INA atT. ipSet (1: 
cord,F Enter found­'T, refrence Set coord. 
botto 
to run 
. 
. 
--
S t T. Erra. 
a left to rlght,atop to 
found--int~a -_ord.TN Ei (13e
1 .ft totn-,-t NX 
llori, 
y,.,a r) 
En e.E r f r eSecified Irement 
rune 
ngsment 
1 
nvtica i Run horizontal v Ir­
* 
seomt[ 
segen 'I"t,e:n 
-coord.. of net g
Pecified j segmecnt as specified,j cpai? crossed verti­cal ,ires 
Increment change 
count 
Done-
Ix last change 
RETURN 
-
Figure 3-46 COIRE( 
0RFQo[ Aqj 111-96 
Address first fold 
" Y Set up for normalSot up for invertd	 N Fold 
foldal fold 
FSearcheach col. 
row to determinet 
ro can be deleted.Delete redundant 
T. E.sI 
Delete horilsontal1 
channel repairing 
broken vertical 
wivres 
Update NX and IF 
arrays 
Address nest row 
Address ne'xt fold lastfoldK I et 
• ~ , , 
OF POOR QUJAL[TY 
Rigure 3- 17 SQUASJIORIGINAL FAGE IS 	 I-97 
__ 
Se K9 to inde top 	 P04Qir
 
Set K7 to index leftE 
column 
I "runnel 
Find ele. and pin in End O ther 7 7+ Go t ne 
Col. K7.Set left (K7 K9) KTFTA 
point flag K14=1 "Col." 
@ ,t. 	 NT= Net 0 of Ma!ta.1 
YNi s t h r e E nd l e f p o i t y F i n d n e t N TA 
entryfo thconnected- to pin 
poin of irein column. 
N'S t t atH Fnd et 'T onn c-
from NX ted to 	pin I. this 
col." 
tan. end left " N 
p fo ni eS et B t o n e tF 
found
 
NiT= NB 
NB= 0 
N ~belov, 
A ~~Checkfor rossfold 
tonnection at N5. 
( 	 Set nlac if found. Set 
N KS~z ling: I SKz 
Set K7 to index on] I 
bottom -iC 'BP¢tconto 
• point to pin bc 1 
n t C in 
I 7 
las r-_ 	 N
 
Yinde 	 ­
tL s 
Col. 
Set NB= 0 Search 
or next Tunnel o
 
End, lior. *1 talo 
Ver tical Metal, 
M etal 
o n Me a C 
Tuneen
 
Index logic pin
 
set flag for
 
r,, on 
B
 
Enter decription of 
onnection in N 
rnray, (Format N-
SQI) 
- 3.12 Subroutine PADMVE 
called by SQUEEZ to movePADMVE is a short subroutine which is 
pads from the top or bottom of the chip to the left side. 
3. 12. 1 Functional Description 
or bottomThe PADMVE subroutine arguments specify whether the top 
while the number of pads to be moved are specified infold is to be altered, 
IFA contains negative numbers in column Ithe input parameter array ICN. 
These flags are used by PADMVE to locatewhich flag the end of each fold. 
the new pads. 
two types of pad networks which are considered. TheThere are 
first type, handled by the flowchart block SIDE DELETE, consists of a pad 
In this
which has no other connections in the fold adjacent to the pad fold, 
case the old pad is flagged as being disconifected by setting its former connection 
side pad location and pin to 1, and all the unnecessary wiring between the new 
the old pad is deleted. 
The second type of network contains connections between the old pad 
case flagged as beingand the adjacent logic fold. In this the old pad is 
disconnected as before, but only the short vertical wire between the old pad and 
A wire from the net connections in this foldthe adjacent fold can be deleted. 

out to the left edge and down to the new side pad location.
is then run 
3. 12. 2 PADMVE Variables 
The following variables are referenced by PADMVE: 
ID - Increment to J-index: 
ID = -1 for inverted fold
 
ID = +1 for normal fold
 
J - Y-index on first wiring row of pad fold. 
J2 - Y-index on horizontal connection of moved pad in 
pad fold. 
where the pad is connectedJ7 - Same as J2 in the case 

to th& adjacent fold.
 
U-1-99 
KEC 'Index to cell/pin ID of the adjacent logic fold. 
KM Y-index on new side pad position. 
KPC 	 - Index to cell/pin ID row of fold. 
- Index on the last cross-fold wire which has beenK4K 
entered in the NX array. 
MT Left edge of fold wiring in IFA. 
to which displaced pad is connected.Net number 
available fotr 
NA 
NER 	 X-index on vertical side channels 
side pad wiring. Initialized to 1CN(8). 
Count on the number of pads yet to be moved.NUM 
3. 12. 3 PADMVE Flowcharts 
Flowcharts of the PADMVE subroutine are presented in Figures 3-49 
through 3-51. 
Il- 100 
PADMIVE 
Initialization 
NER= ICN (8) 
Number of pads to be N Top be moved.ICN (6)
moved (7) movelC 
movod= ICN (7) 
Follow %ertica I Printindd 
connection into 
terlnination
fold inside vral 
Search left of REII-RN 
connections across 
to the adjacent fold 
ishc 
eqredRoutc 
connection to 
atjacent 
]SIDE ROUTE 
re to 
ne, pad on the 
side Fig. 3-51 
1 
S IDED-.I 
_. 
Deletemire.Yi n.-50. in top -5 
fold pair and "ire 
side pad 
ORIGINAL PAGE IS 
OF POOR QUALITy 
Figurc 3-49 PADMVE 
III- 101 
and sutfoldSecarcli 
57 to inlxthC hor. 
r, m pad 
Search into center 
of IA and locate
 
negativc eleinent in
 
col.. 1 ind xed b"
 
KM. Stop v hen IA 
(INER -1,J) cO0 
Set error flag 
6IetIF,1=r = 69 J Index,4AY Y 
-
1>-
No 
Neg. thugs 
<found 
> 
print ind.-csN 
andSet old pad pin to 

I to flag as di- vrtable;
 
connected
 
Delete vertical wire R E T U InC

scgnent from old -,..
pa~d owiein 
,3 7channel 
Run horiaontal "ire
 
from col. (NFR-I)
 
to ol pad col. in
 
ch,anc.l J7
A. 
,*NRr.-(iNER- 1)
 
put in a tunnel end if
 
necessar. 
 to connect
 
with adjacent fold
 
Update NYC array 
Rut, vertica'l "ire in
 
Col. \11,11 Lion, flag,
 
KIM to clannel J7
 
Flag new pad: force
 
negative flag at ro
 
KM, col. I to be
 
Roin short wit o from to %'irC inlDew. pa:d j
.E-
Column 
P--
xu;--.'ruRND 
Figure 3-50 SIDE ROUI r 
i- 102 
SIDE 
Bogining vith the 
hor coenection row 
search for a neg. RLg 
in col. 1. Index with 
J5
 
IA (NER,.
 
15) a "irem ~ --.
 
elen.c ot of tb
 
,ad's not
 
t old pad pin to I
 
to flag as discon­
nected _ 
DeleteSWiring vrital fronm old 
pact 
Delete horizontal,
 
to old pad'col.
 
Delete vertical vir]
 
from nep to
 
end fold 
Run "ire from
 
re, pad to cot.
 
NER
 
Set left edge flag
 
Lot. I po'itve
 
N E R N E R I - -

RET URN 
ORIGINAL P4GE IS 11-103 OF POOR QUALiTY 
3. 13 Subroutine MOVE 
MOVE is called by SQUEEZ to rewire for each fold of logic cells. 
3. 13.1 Functional Description 
MOVE's function is to clear and rewire the connections within the 
argument fold from a connection list which has been set up in the NC array. 
Each column entry in this array represents a horizontal wire segment running 
or between two verticalbetween either the left fold edge and a vertical channel, 
channels. Before the actual wiring is begun, the entries are flagged to indicate 
which type of wire segment (pad on left end, cross-fold connections, etc.) is 
described and then ordered in NC by type and increasing length among types. 
IFA elements within the fold boundaries are now cleared. In the case 
of a logic fold adjacent to a pad fold, these boundaries are specially defined 
to include all pad wiring. The connections of a particular type wire are always 
run from their order of appearance in the NC array, hence the shortest are 
The wiring loop first runs all those wires which connect to leftentered first. 
end wiring before going on to the pin to pin wires. If a connection is flagged 
a connection toas a cross-fold type in NC, the routine searches for and runs 
the adjacent fold before searching for and running a possible connection to the 
fold's own cells. The search and run procedure is done first for the right wire 
segment termination, and then for the left. 
If at some time during this process the routine finds it does not have 
sufficient horizontal channels to make the required connections within the fold, 
another channel is added and the fold is recycled back to the beginning of the 
subroutine. Normally, however, MOVE can make the required connections in 
arefewer horizontal channels than previously required. Once all entries in NC 
run, the adjoining fold is searched to determine if all required cross-fold 
connections have been completed. The adjacent fold is searched for connections 
which are to run directly to the object fold's pins and such wires are run where 
required.
 
After all wires have been run, each vertical wiring channel of the 
fold is examined and cleared of very short metal or tunnel segments and 
unnecessary tunnel ends. The channel between folds is also cleaned of un­
necessary entries and proper cross-fold connections entered before MOVE 
returns to SQUEEZ. 
I- 104 
3. 13. 2 MOVE Variables and Arrays 
The following variables are referenced by MOVE: 
iE 	 Channel increment element which is to be added to 
the Y-index of a channel in IFA to index channels 
above or below the base channel. 
IE = +1 or IE = -1 
IJRL -	 Number of folds in chip. 
INC 	 Unit increment by which Y-index on fold channels 
must be increased to look at wires further from 
fold's cells. 
INC = +1 - for normal folds 
INC = -1 - inverted folds 
ISFE 	 Switch used to sequence every sixth search of the 
column into the NX reference deletion coding and 
back again. 
KG 	 Flag used to indicate whether the last column of IFA 
has been processed through the tunnel checking loop. 
KINSW 	 Switch indicating whether a recycle pass has been 
executed. 
KINSW = 1 - No recycle 
KINSW = 0 - Have done a recycle 
KSW 	 Switch used to indicate whether the wire coming in from 
the fold's left end, or cap wires, have been completed 
yet. 
KSIV = 1 - Cap wires are being run 
KSW = 2 - Cap wires have all been run 
K4K 	 Number of entries in the NX array. 
K4L 	 Number of tunnel end references in NX array at start 
of tunnel checking loop. 
Ir-105
 
LL Number of the fold being worked upon. 
LL4 Number of entries in the NC array. 
MT X-index on left edge of folds in IFA.
 
NB X-'index on right end of wire being connected in IFA.
 
NNO Number of the net containing the wire being connected 
in IFA. 
NT X-index on left end of wire being connected in IFA. 
The only array format changes made by MOVE are the length/connection 
type entries made in row one of the NC array: 
For connection I: 
NC(I, 1) = [NC(, 5) - NC(I, 4) - Connection I is a normal 
wire segment having a horizontal length i! 6. 
NC(I, 1) = [NC(I, 4) - Connection I is a normal wire segment 
having a horizontal length - 6. 
NC(I, 1) = [10, 000 - NC(I, 4) - Left end of connection I runs 
to a pad. 
NC(I, 1) = [3, 000 + NC(I, 5) - NC(I, 4)] - Connection I has a 
cross-fold wire tap, 
3. 13. 3 MOVE Flowcharts 
Flowcharts of the MOVE subroutine are presented in Figures 3-5Z 
through 3-60. 
111-106
 
Initial.iation 
KINSW = 1 
Set up for normalSet up for invertedod 
fold < nralfold
 
connection 
N 
Ordei connection 
list, clear old. 
Vxir s
 
Fig. 3-53 
WIlRE 
Run nev, 
wiring 
- Fg-3-54 
R"ecy'cle
 
Print: IFA 
tarnictesDebug 
NX 
Rrl-'INE 
Clean, up newv 
vi ring 
3-55
;T-1QN44Fig.. 
O - _UPrint: IFA 
parametersRE URN >----r-- Debug >_ 
NX 
Figure 3-52 MOVE 
III-107 
SORT 
FLAGS 
Set vire t,'pe flags 
for each connection 
in NC (I, 1) 
Fie. 3-56 
Sort NC list on­
tscending magnitud 
of NC ( I, 1) 
Clear previous 
wiring x.ithin fold 
boundaries 
Delete all NX 
entries referrin 
to deleted viring 
R TU
RN 
. aramete 
Figure 3-53 SORT 
QUP4 1-108
 
pas 
Initialize; 
SW =}:SW 
Initialize, 
= 2 
Search for next 
Cap Wre 
Search NC for 
next wire to be 
run 
LER z 12inIF RGCap Wiref rentry 
in 
Y Ca i e N " Ctrecs inN u 
u do 
Run horizontal 
paa et r 
RIre seCment 
Cnni.t r 
341N1 Fol 
. 
Delete 
paD (1) 
dtscotifectcd 5000. 
c NK4K L =-
Ihleto 
JNnd 
C 
300CHECKadHOR 
run 
-W 
1 
d 
n 
,,re 
=1 =2 NCgure(1-2 =58sJ -
CSec 
Upiesegeen 
hif and ai 
j~~~~~NeFl 
J3 J3 1norm.1 
frr her 
chaneo rier 
-
-+1N HC O 
S an oher . 
rowpas 
S 
bloweon 
and l 
1.'Ero 
l 73-5 
OF100 
Cepar rok e 
vertical. wiring in 
cleard channel 
o-RGINL 'ZI yec faj:LEFT 
RETURlN 
E 
i rh 
r!" 
CONNTr 
Connect left Lnd of 
wire segment 
Figuze 3-5 
1-19 Figure 3= WIRE -
RF 
INE 
Addresa 1st colun 
of fold In IFA 
Fold 
y 
o Enter Ve tical 
Metal and T., at 
fold edge for w'ire. 
Set Re. in NX 
Search col. xtithn 
gold fcor 'I.E. or tun. 
Put metal where tun. 
is longer then S 
elme t.rmova 
eces s T. E.'S 
Search column for 
vertical metal 
segment of loss than 
3 cle,.qents and 
chanoge to tunnel 
C_--JhtJlt 
Indox next 
ditofcl 
Delete unnecessary 
T.E. reference to 
column in NX 
c1 in IFA [djoitning last fold 
H.5 
in NX clian ed 
Ikemve I.E.' S 
Ion, canl 
ad jacent :o pad 
Delete mtf...cL~ssary 
'I.. ref.i'erence to 
array 
-
Done 
ast ccl.. 
Figure 3-55 fl~'INE 
.ii-110 
"C 
Address Ist entry 
(I= 1) in NC array 
(1,4 
reAinng 
t 
[N NC (1, 
Use Cell/inn code 
in N C (1,5) to fInd 
net H of aire 
/ (1, 3)-N ._NC ( 
NCC (1 1,4 
onn ct 
pad 
onN 1.4 
@Y
 
XFigure 3-56 FLAGSORIGINAL PAGE IS 
oF POOR QUALrTY 
RlGIlT 
CONNECT 
Set up loop 
IE a ID 
K=J3 
Set ind"' to run 
0 (irearray from fold 
10000cells IE -- IE" 
Put tunnel end in lEA -it, J) 7 
last elen 'cntof 
;vire 
Pad wire 
Gotonet channel 
Enter refonce to K : F I 
element in NX--
Ise e Do s NEnter T. E. adjacert 1 
within fold N cro s folld ill­
r 
bounds out F , - 1 
)Trl V1 
Run horirontal metal 
across op~i, aicas 
for "ire 
connection nlag Is 
clnptod NC(, I) 
ar 
- Figure 3-57 RIGwT CONNECT 
III - 11 
CHECK HOR. 
lnitialiC 
pararieters 
NT,NB, NNO 
N 
boundary of Idxnext channelle 
Shoult 
th 
St to tae recycle t.does 
OF_ fN 
y 
-ooR RUA N 
foa 
LOOK reeene 
same pnj 
d f 
Srhouldtt~(' 
A N tal RFhR 
Figure 3-5ir CEuK tio 
111[-113 
LEF'I 
CON'NECT 
Initialie indexes 
K'S 
IE- ID 
fold adjacent 
Is Souldpad: 
left end connect 
Sot index for run to 
IE'-ID, set 
flag NC (I,' 1)I 
Put T. E at left end 
if there is none 
ZEnter reference to 
Y T.E. in NX array 
Index next channel: 
K = K- I 
bounds 
N 
Enter T. E. in 
last cli-ment 
Cros. 
fold 
connetion 
N 
Y 
Enter reference to 
vce" T. E. in NX 
array 
to 
Setinexet ru 
pin of same fold: 
I K=DKJ 
IY ia also run 
oflpi 
to' fod ibe low 
Figure 3-59 LEY-T CONNECT 
111-114 
=,CCSEENI)S 
Adldress l,ft edge 
colu l. of r'icis in 
IFA 
Search coltlin for 
disco.nnected pad in 
fold 
Find 
Y [- -
Delete tunnel 
-which made old 
o 
ny disconnect-
N 
First 
,irece. in 
tiont.I ,fu( 
Determine net 
number of connec­
tion 
Ente'I.. atstart 
of Connection Im' 
IFA*,enter rot. lo 
Run tunnel accross 
fold pair until 'I.E., 
mnetal of sa.-e net,or 
tun. is found 
Fo ud y ner 
of 
T.FE n end1 
iCi. pot ref. 
metal / m NX 
Las 
Index next Col. to " 
ln 
rght 
V 
IF19URN 
Figure 3-60 LOOSE ENI­
111-115 
oRICINAL 0AGE IB 
op BOOR QUALM 
3. 14 Subroutine ASSIGN 
The ASSIGN subroutine assigns absolute coordinates to the various 
wiring and pattern components of the chip. 
3. 14. 1 Functional Description 
Previous PRF routines have rnapped the wiring components into 
relative locations in the IFA array. All that remains to be done to fully 
define them on the chip is to utilize the input parameters which specify 
spacings and wire widths to make coordinate assignments relative to the 
physical origin of the chip. X-dimension coordinates are first assigned to 
the left side pads and wiring channels in the IYW array. Fold assignments 
follow with the translation of running length values into the chip X-coordinates. 
During this translation, the wiring is examined to insure that no violations of 
process spacing requirements are made. Wire channels which are to the 
right of folds proper are assigned coordinates in extensions of fold running 
length rows. 
The IYW array is used to store the Y-coordinates assigned to the 
rows of the IFA array. An entry is made for each row of the chip picture 
printout which is assigned a coordinate. The assignments are made by begin­
ning at the top of IFA and utilizing cell size and channel spacing parameters to 
make assignments to the rows of successive pairs of folds, If crosswires run 
between the folds of a pair, entries are made in the NC array at this time to 
describe the wiring of any horizontal adjustment which must be made to compen­
sate for assignment of different X-coordinates in different folds to the same 
array column. If such a horizontal adjustment wire must be run, Y-coordinates 
are assigned to allow space for these channels. 
After absolute coordinates have been assigned, ASSIGN prints the 
contents of the IFA array as the chip picture to clearly-show the relative location! 
of wiring and cells. The absolute coordinates assigned to the various channels 
are also printed, and these must be used if one is to determine the true locations 
of components on the chip. 
3. 14. Z ASSIGN Variables and Arrays 
The following variables are referenced by the ASSIGN subroutine. 
ICH Cell height; set to I-IF. 
IFFP Set to 1. 
111-116 
IFMX .	 Set to the total number of folds. 
ILFP -	 Set to 1. 
IPH -	 Pad edge to metal wire spacing. 
IPWR -	 Width of channel reserved for power lines. 
IWVDD -	 Distance by which folds are overlapped. 
liSp - Correction distance by which space MMSP is 
reduced in spacing the first horizontal wire above 
cells. 
MAXX -	 Maximum X-coordinate assigned to a fold. 
MMSP -	 Center to center spacing of horizontal metal lines. 
MSLSP -	 Distance from metal to scribe lines. 
MT -	 X-index to left edge of fold cells. 
NMPA -	 Pass number. 
The following arrays arc constructed by ASSIGN: 
IF(I, J) -	 For Fold Nunber I: 
IF(I, 1) - Y-index on top of fold in IFA. 
IF(I, 2) - Y-index on bottom of fold in IFA. 
IF(I, 3) = 0 - Fold I is normal. 
= 1 - Fold I is inverted. 
IF(1, 4) - Index to first crosswire entry in ?NC which 
connects to Fold I (for inverted folds only). 
IXW(I) 	 Array in which the X-coordinate of each vertical 
channel left of the fold is stored. 
IYW(I) 	 Array in which the Y-coordinate of each row I of the 
printed chip picture is assigned. IFA rovs containing 
running length values are assigned the Y-coordinate 
of the top of the cells of a normal fold (bottom if fold 
is inverted). Cell/pin ID rowjs have the bottom cell 
coordinate for normal folds (top for inverted folds). 
111-117 
NC(I, J) 	 Array containing a column entry to describe each 
crosswire running between folds. See array map, 
Table 3-17. 
For wire I: 
NC(I, 1) - X-coordinate of channel of normal fold 
containing crosswire. 
NC(I, 2) - X-coordinate of channel of inverted fold 
containing crosswire. 
NC(I, 3) - The number of channels which must be 
used to run wire horizontally to correct 
for the length displacement between folds. 
NC(I, 4) - Direction flag 
1 - For NC(I, 1) c NC(I, 2) 
= 2 - For NC(I, 1) NC(I, 2) 
NC(U, 5) = 000 x crosswire (fold number) + 
(X-index to channel in IFA)J 
PR(I) 	 Linear array used as buffer storage of one line of 
data during I/0 operations in the generation of the 
chip picture. 
3. 14. 3 ASSIGN 	 Flowcharts 
Flowcharts of the ASSIGN subroutine are presented in Figures 3-61 
through 3-63. 
1I1-118
 
-1=2 3 4 5 6 
NC(I,J) I X-coord. of channel in top fold of pair ( 
2 X-coord. of channel in bottom fold of pair 
Format NC-Al 3 Number of horizontal channels displaced 
4 Direction flag 
5 Fold/Channel I. D. 
Where: Fold/Channel I.D. = i000 x (fold number) + (X-index to 
channel in IFA)J 
Direction Flag = Q for NC(I, l),lNC(I, 2) 
(2for NC(T, l)>NC(I, 2) 
IF(I, 5) 
Format IF-RE1 
J= I 
2 
3 
2I= 
Fold top index 
Fold bottom index 
= i nal 11ag 
in 
4 Crosswire index 
Where I = The number of the fold described. 
Table 3-17 ASSIGN ARRAYS 
111-119 
ASS IGCN 
Itiltilzation : " 
Aet-up constants 
X-ASSIGN 
Assign X coordinates 
to vertical channels 
Fig. 3-62 
Y-AsSI 
Fort NC end IYW 
arrays 
Fig. 3-63 
Debug Debug 
printout; 
flagrathA 
sciatch storage 
Print chip2 LE1 
ENLEN LEN 
Figrre 3-61 ASSIGNQt34 li s-tira0 
X- ASSIGN 
Set normal coerd. of 
left channel in 
Ixw 1) 
I Sea rch for left edge] 
pad, put space in1 
IXW 1) if found 
I
 
Assign a coord.
 
IXW (1) to each
 
channel I left of
 
folds. Use min. 
allo%,abie spacing 
Add space for
 
pover v.iring
 
IPWR
 
Address s 
fold pair 
Set coord. of left ] 
edge in fold's left 
R ..nni.nd Length 
loca'ion 
Set Running Length 
Values to space 
kach fold channel 
Set MAXX = Max. 
fold "idth 
Address next Last 
fold pair 
FSet Running Length 
Values spacing 
channels to right 
of fold's cells 
ORIGNAL PAGE IS 
RURNOF POOR QUALITY ) 
Figure 3-62 X-ASSIGN 
111-121 ­
Y- ASSIGN 
AAddress Ist 
fold 
lmctd 
set 
fold 
Enter each cross-
fold v ire in NC, 
(format N.C-Al) 
Enter space bctveon 
folds in IW.I
Adjust space 1 
bet,en folds if 
cross-fold wire is 
tunnel]rustIY 
odNsodlt 
up nrmalFold 
N 
Make entries in 
lyw arr..y forI 
Cell/Pin 11) and 
Runmng Length ros 
of folds 
I-
Space fold's hor. 
"ire channel and 
6nter Y-coords. 
in tYW 
Fold s 
normal 
A.Y 
Address newt 
Y 
N 
SOL coot. for 
Ist fol-d in lYV, 
array 
______-___ 
Enter Y-c,ord;s. of 
Cell/pt,, Ili 
Runnit.g l.cngth 
r 
I 
Donet old 
-
3 ---" 
N 
-­
fold cota ". X into l for pad,­
an- aefdrs pd 
inocot. I of JI'A 
Figure 3-63 Y-ASSIGN 
111-122 
3.15 Subroutine ARTWRK 
The ARTWRK subroutine performs the translation from.the 
representation of the chip in PRF arrays into pattern set, line set, and shape 
set data which can be used by the Banning ARTWORK program to produce 
plotter commands. 
3. 15. 1 Functional Description 
ARTWRK is a relatively straightforward routine which operates 
sequentially to produce pattern set data and line and shape set commands 
for each of the four levels of MOS masks. The details of these commands 
for ARTWORK can be found in the ARTWORK User's Manual. Since the 
absolute coordinates of all points in IFA have previously been calculated and 
stored in arrays IXW and IYW, ARTWRK merely searches the array for the 
various components and uses these arrays to formulate the proper output data 
in the proper sequence. 
The only calculations performed by the routine are those required 
to determine the position of the test transistor, the power pads,- and the chip 
border, and those which compute the total capacitance of each net. The net 
capacitances are calculated by determining the net number of each metal 
segment, tunnel segment, and tunnel end, and adding the associated capacitances 
to that net's running total stored in the CAP array. This array is printed along" 
with the net list at the end of the subroutine, and can be used as the input for 
the Banning SIGNAL TRACE program. 
3. 15. 2 ARTWRK Variables 
The following variables are referenced by the ARTWRK subroutine: 
ICNT -	 Running count of line set number. 
IFMX -	 Set to IJ = Number of folds. 
IG 	 Flag indicating whether an ARTWORK tape is to be 
made: 
IG 1 0 - Produce tape on logical unit IG 
IG = 0 - Printer output only 
ILH 	 Y-coordinate of lower end of vertical wire. 
111-123 
IRH _ Y-coordihate of upper end of vertical wire. 
search for vertical metal to indicateISW - Switch used in 

being sought.
which end of a wire is 
0 - Lower end 
1 - Upper end 
Set to JD(2) = Number of cross wire entries in NC.KZK 
of tunnel end entries in NX.Set to JD(1) = NumberK4K 
LEVEL Flag designating the inask level of the ARTWORK 
input being. generated. 
- 15 or 35.NMPA 	 Set to ICN(190) - Specify left edge 
Net number of wire currently being run.NNO ­
3.15. 3 ARTWRK Flowcharts 
are presented in Figures 3-64 Flowcharts of the ARTWRK subroutine 
through 3-71. 
111-124
 
]Initialization 
Calculate Net
 
Capacitances froln
 
Pil Capac.
 
_INS 
Write cell and
 
end pattern
tunnel 

set data
 
rig. 3-65
 
I 
POWVR PAD 
Write pov Cr pad
 
data
 
Fig. 3-66
 
LTEST-
Write test trans­
istor data 
Fig. 3-67 
Calculate
 
coordinates of
 
borders
 
\Write ahgn­
ti rns 
rite level 
4 bordet 
1 lineWrite level 
set data 
Fig. 3-68 ! 
Write level 4 line
 
set data
 
Fig. 3-69 
r rint Net 
List 
f----I--­
3-6 ARTWRKORIGINAL PAGE IS Fgur. 

OF POOR QUALITY 111-125
 
'III EItIN 
arra 
Ini tialirati nn, 
first fold 
Set indexes forSet Indexes for 
N Fold X tiurinal foldinverted fold 
norm.al1 
Dote rmne cell 
orientation 
CGalculate X­
coordinate of 
ell
 
p atr 
.I .st 
ofl stdata 
foldo 
y 
Put out tunnel end 
data 
Fig. 3-70 
Addrss oldLastext 
fold 
LF,1 l"1 EDGI: 
'ls 
and pad on left 
edge 
F:ig ._3-71 
Put out 7"'.
I 
Figure 3-65 i'A' JRNS 
In - 1 6Z 
ORIGINAL PAGE IS 
soE pooR QUALITY 
Find outside fold 
centers to be
 
connected
 
Y-Determine 
coordinates of 01 
andft 2 pad patterns 
Determine X­
coord. from spacin 
to folds 
Write j1 
pad set
 
data
 
Write 02 
pad set 
data 
tETU1 RN 
Figurc 3-66 POWR PAD 
1[1-127
 
TS 
Initialiation. Set 
transistor in pad 
fold 
Trans. Y Move trans. above 
ver pad power pads 
N 
Trans. Pat trans, in vcrtical 
stil overpstin 
pads paver 
N 
Trana- Trans. 
N to close to -still near 
ower N pads> 
y y 
Move trans. up to 
clear power pad 
Msg:
close 
pds 
trans. 
to / 
----.-.... 
Find limits of wire 
area covered b, 
tran1s. 
edeu of 
'ovc-hannel width 1 tate._Y~urin chp Y 
area> 
__ N 
IIIY-Y 

Icigtoo 3-67 TEST 
Search left edge of 
I FA for 'I.. s 
Contruct line set 
for connecterd tunnel 
Write line 
set dlata, 
Add tunnel 
capacitance 
to net 
complete 
y 
Address first fold 
~Writt line set 
S -________ Sot up Indc... Vy - Fold norn, N dlata from - \I Array 
Search fold 
-d fjtAdd capacitance 
net 
to 
for 
tunneli 
Address fold write itrextset d natfor 
LAdd n t capcitrec 
•RWIURN it r 
ORIQAJLJIPA~l ISFigure 3-Cs IUWNF.L 
OF POORPAGE M-OF POOR QUALITY 
LEV EL 
Wite shape 
levul I and
 
set data for
2 bordersLSearch
left of fold 
and put out line sets 
for vertical ictar 
Updte net cap. 
Address 1st fold 
Write line set 
data from NC 
Setup Indexes -- I array 
_ .... p Ik . 
t ll arra 
Setlc fotlfor[ aa~ac 
etal er 
Wrtc inet
----
Updlate net 
capacit.lCO. 
AddrNss t foldSar, ell . 
Attrusex fldfold complte 
-, 
Search, IFA fox 
horizontal n', tat 
write itne sets 
Update net cap. 
Wvrite lr Ql4 
set 
ligure 3-69 UPI'R I.F:VEL 
Ili- 130 
1InitLialzC search 
Search fold for 
tunnelI ends 
Determine net of1 
T. E. foui,d and add 
caacitanceJ 
Inrment search
 
a rca
 
-- q 
RE'1URN 
,ORIGIAAW i PAGE Y Figuic 3-70 TEND 
OF POOR QUTALI1 
111-131 
Initialize search 
-4 
Search left edge of 
IRA for T.E. s 
Determine net of 
T.E. found and add 
capacitance 
'WriteT. E. 
pattern set 
Incremnt 
area 
sea ch Search 
complete 
Search dovn left 
edge. of IFA for pad 
flag, 
Writ. pad 
pattern st 
1RETUR~ 
Figure 3-71 LEFT EI)GE 
111-132 
3.16 Subroutine POWR 
The ARTWORK program inputs required to produce the chip's power 
busses are generated by the POWR subroutine. 
3.16.1 Functional Description. 
POWR utilizes coordinate information in array IFA, fold information 
in array IF, power pad location data passed from ARTWIRK in the IGN array, 
and input parameters stored in ICN to produce the metal line set data for the 
power busses. Connections to the power pads and between folds are run, as 
well as the lines running through the fold centers, The basic wiring structure 
is outlined in the NC array (format NC-PI) prior to wiring. During the 
formation of this array, nearly all horizontal components of the power system 
are defined, taking into account the extensions required on both fold ends for 
inter connection. 
The output of line set data then begins with the short connection 
required to connect power pads to the position where busses will be drawn. 
A loop producing line set data for each type bus (0i, 0?, VDDl or GND) is 
now entered. The operature specified by the associated input parameter is 
selected, the horizontal lines are drawn from the NC array, and the'vertical 
connection to the previous fold is made, if required. When all busses have 
been run, the ARTWORK output tape is rewound and control is returned to 
MAIN to terminate the PRF program. 
3.16. 2 POWR Variables and Arrays 
The following variables are referenced by POWR: 
ICN(178) - Flag set during positioning of power pads by 
ART WRK. 
ICN(178) = 0 - Not enough room for 02 protection 
device. 
ICN(l78) = 1 - Sufficient room for device available, 
ICN(179) - Set to NTr in ARTWRK. 
NTF = 0 - More than one fold pair. 
NTF = I - Only one fold pair. 
ICN(l80) - X-coordinato of origin of 01 power pad pattern. 
111-133 
ICN(181) - .Xcoordinate of origin 0? power pad pattern. 
ISW Switch used to sequence normal or inverted folds 
through formation of NC array. 
ISW = 1 - For first fold inverted 
ISW = 2 - For other inverted folds 
ISW = 3 - For normal folds 
of left edge of fold to which bussesITX _ 	 X-coordinate 

are to be run.
 
_ 
Running X-index on entries to NC array.N 
The following arrays are constructed by POWR: 
IAP(I) 	 Equivalent to input parameters ICN(32), ICN(33), 
ICN(34), ICN(35). 
ICN(29),IBI(I) 	 Equivalent to input parameters ICN(28), 
ICN(30), ICN(31) for I - 1, 2, 3, 4. 
ITI(I) 	 Equivalent to input parameters ICN(24), ICN(25), 
ICN(26), ICN(27) for I - 1, 2, 3, 4. 
to list the coordinates of the power bussesNG(I, J) 	 Array used 
of each fold. Each logic fold will have three columns 
e ntered in format NC-Pl, illustrated in the array map, 
Table 3-18. 
3. 16. 3 POWR Flowcharts 
Flowcharts of the POAWR subroutine arc presented in Figures 3-72 
through 3-74. 
III- 134 
1 2 3 4 5 6 .,.
 
NC(I,J) 
Format NC-P1 
I 
2 
3 
4 
5 
X1 I X 2 
XY 
X1 X 2 
X1 X 2 
_ 
YjXz X1 iY 
X Y 
Y X2 X! Y 
Y X2 X1 YI-. 
I VDD1 Line Coord. 
01 Line Coord 
(,02 Line Coord. 
GND Line Coord. 
N. Not Used 
w X 1 = Left X-coordinate of power line. 
0 ,-0 
.k 0 
0 
Oo 
X 2 
Y 
= Right X-coordinate of power line. 
=Y-coordinate of power line. 
0 
O o 
0 
Table 3-18 POWR ARRAYS 
111-135 
Go to next bas 
POWR 
Initialization 
NC LIST 
List poV.er bus 
coordinates in NC 
array 
Fin 3-73 ____ 
Initialize I-CoT) 
To run buses into 
Or,' r- DD,er 
GNDVDD 
.______ 
Put out po,,or bus 
line set data 
Fig. 3-74 
Last 
buy 
WVrite "END 
LEVEL 4" 
R~ewind 
Tape -
RE']URN 
Figuic 3-72 P) IVR 
oR RAL pu
 
I 
136 
Set-up for inverted ]Fold 
fold 
NC LIST 
Initialh-aton 
Set-up Ist fold 
--7-

L Set-up for normal fold ISW = 3 
Find lngth of fold
 
pair. Enter fold's
 
VDJDJII i. NC 
15W [intor V'DD edge 
ISW =extension to 
IT X in INC 
t-3 
Enter remaining Enter fold bus 
bus line coordinate line coordin.tes 
in NC for fold in NC 
Address next fold 
.Last 
N 
fold 
done> 
y 
Ex~tend busos to 
poltr pad, 
RlETURN 
Figure 3-73 NC LIST 
111-137 
Initialire to do for 
VDD 1st 
-'or 
apa~rti re 
scooted for 
¥DDI 
Address 1st fold 
entry in NC 
Write hor, and 
vert. line set 
for fold b~is 
Address nex.t fold ,. Last 
data in NC fold 
touclkRoom 
-tp lcit
-
for protection 

vDD~~~ dVice.dvc
 
VuniDD 
in YN N 
N Last bosC to ext. bus 
t-pI . Ordr i M - -- - typeflD, V2.01, CND 
RJ -'1U 1, ' 
"i",,e 3-74 WRj'I:: BUS 
If!-138 
SECTION IV 
PROGRAM SIZING 
4.1 Program Overlays 
Since the PRF program is relatively large, 'a series of program 
overlays has been devised to reduce the core storage which must be 
dedicated to program instructions. The sequential nature of the program allows 
each of the bracketed segments of Figure 4-1 to overlay the preceding seg­
ment when its execution has been completed. The only instructions which 
must remain resident in core throughout the program are those of the 
executive MAIN and those of the small utility routine LOOK. The core 
required for program instruction is thus the sum of that required by MAIN 
and LOOK and that required by the largest overlay block. The largest 
block of the current PRF configuration is SQUEEZ-PADMVE-MOVE, 
requiring roughly 5. 6K. The total core which must be reserved for instructions 
is thus a bit less than 6K, while the total without overlays is more than 20K. 
4.2 Array Dimensions 
The bulk of the core memory required by PRF is used for array 
storage. These arrays are used as chip maps, component lists, cross­
referencing data tables, and input data tables, and, generally, their size 
requirements are directly dependent upon the complexity of the chip designs 
being run. Optimal use of core can be obtained by carefully scaling each 
individual array to the complexity of the circuit being run. Although the 
program makes a few checks for array overflows, generally there will not be 
an.error message when an array dimension has been exceeded, and such an 
error must be traced back from seemingly unrelated problems using core 
memory dumps and debug printout. 
Table 4-1 lists the dimensions of the major chip dependent arrays 
in both the Z00 cell program used for system test and the 129 cell version 
implemented by M&S Computing.. Complete descriptions of the formats of 
these arrays may be foind in Section III in the descriptions of the subroutines 
which form them. These subroutines can be referenced from Figure 2-4 
for common arrays- or from Table 4-2 for local arrays. The latter figure 
also indicates those local arrays which are equivalent or sectionally equivalent 
to common arrays, and where these equivalent statements must be adjusted 
if the dimensions of either array are altered. 
The following lists attempt to define the relationship between chip 
complexity and minimum array dimensions. 
IV-I 
MAIN 
-
I CALL FOLD 
Clear array ICN, 1Fig. 3-25 
set array limits 
r_ CALL ROUTFE 
Overlay 3 Fig 3-15 
NPLC 
Overlay 4 F~ig3-32 
ISUPISU 
. D 
O. 

O ve la 
3-61Fig.6 
NPLCE Overlay 
(-- ...i
OlavyeIr ITblank- -O l 5.r F-7 343A 
N 
CLL LACX" S 
Overlay 2 Fig 3-9rli 
L- Overlay F-, 
PrintI F ' L Fi.-s 
ar ray rA..ASG 
Overlay 6 Fig 3-61 
op IOBPA= 
UpN 
1st P's Fas< 

IN 1( 
 Cl..ATW_ 
Overlay 7 Fig. 3-6-
Overlay 3RUT 7rLIOver1Jay 8 < i.37 
ID? z 2 
- - ~ ~ - -~ 
Figure -4-1 STOP 
N PRF PDROGR AM OVEPULAYS
 
A IV-2
 
Subroutine 
Array Forming Array 
ICA INPUT 
ICB INPUT 
ICL INPUT 
INF INPUT 
IP INPUT 
IPTMP PLACX 
IPTRA INPUT 
LNAD INPUT 
MAP INPUT 
MAPTMP PLACX 
NAT PLACX 
NETTOT PLACX 
Table 4-1 
Equivalent Subroutines Which
 
to Array Reference Array
 
IRA INPUT 
IRA INPUT 
IRA INPUT, ROUTE-
IRA INPUT, PLACX, CRCALC, FOLD 
IRA INPUT, PLACX, ROUTE
 
--- PLACX
 
IRA INPUT
 
IRA INPUT, PLACX, CRCALC
 
IRA INPUT, PLACX, FOLD
 
--- PLACX
 
--- PLACX
 
--- PLACX
 
MAJOR LOCAL ARRAYS 
IV-3
 
Report No. 70-0036 
ZOO Cells 
Dimensions 
CAP (200) 

IC' (200,10) 

ICK (120,10,13) 
ICN (200) 
IEC 	 (200) 
IF 	 (10,4) 
IFA (200, 200) 
rn INT (6) 
>' IPR (250) 
IPTRN (120) 
r IRA (800,50)14 	 IXW (35) 
IYW (200) 

JD (2) 

NC (600, 5) 
0 
o 	 NET (Z00) 
NX (200,3) 
PR (Z50) 
ICA (200,6) 

ICB (200,10, 13) 

ICL (120,6) 

INF (200,4) 

> IP (200,2) 
< IPTMP (200,7) 
z IPTRA (200,2) 
LNAD (1000) 
MAP (Z00, 2) 
o MAPTMP (200,7) 
O NAT (2000)NETTOT 	 (200) 
Revision 1 
February 21, 197Z 
2ZO 
Core Dimensions Core 
200 (220) 220 
Z, 000 (220,11) 2,420 
15,600 (50, 11, 4) 2,200 
200 (200) 200 
ZOO (200) 200 
40 (Z0, 4) 80 
40,000 (Z18, ZZ0) Z3, 980** 
6 (6) 6 
250 (250) 250 
1Z0 (50) 50 
40,000 (800, 51) Z0,400* 
35 (45) 45 
200 (235) 235 
Z (2) Z 
3,000 (850, 5) 4, Z50 
Z, 000 (2250) Z, Z50 
600 (400, 3) 1, Z00 
250 (250) Z50 
1,200 (50, 6) 300 
26,000 (50, 11, 13) 7,150 
720 (50, 6) 300 
800 (220, 4) 880 
400 (220, 2) 440 
1,400 (220, 7) 1,540 
400 (150) 150 
1,000 (1300) 1,300 
400 (220, 2) 440 
1,400 
2,000 
200 
(220, 7) 
(1540)
(ZZ0) 
1,540 
1, 540 
ZZ0 
*Although it may be possible to run up to ZZ0 cells with these 
dimensions, chips of this size have not yet been attemped. 
**Half word arrays 
EFFECTIVE ARRAY DIMENSIONS VS. NUMBER OF CELLS 
Table 4-Z 
IV-4 
- Fixed Dimension Arrays: 
ICN(200)
 
IF(I 0, 4)
 
INT(6)
 
IPR(250) 
IXW(35) 
JD(2) 
Arrays directly dependent on the number of cells (including bonding 
pads) of the logic design. Where C = (number of logic cells + bonding 
pads), these arrays are dimensioned as: 
IC(C, 10)
 
IEC(C)
 
INF(C, 4)
 
on the number of logic cells of the design.Arrays directly dependent 
the number of logic cells, these arrays are dimensionalWhere C is 
as: 
IP(G, 2)
 
MAP(C, Z)
 
IPTMP(C, 7)
 
MAPTMP(C, 7)
 
INAT(7xC) 
Arrays directly dependent on the number of different cells in the
 
Circuit Type File. They are dimensioned as follows, where F is
 
the nuinber of file cells:
 
IPTRA(F)
 
ICA(F, 6)
 
ICB(F, 10, 13)
 
Arrays directly dependent on D, the number of different circuit 
types utilized by the logic design being run: 
ICK(D, 10, 13)
 
ICL(D, 6)
 
IPTRN(D)
 
IV-5 
Arrays directly dependent on N, the number of independent 
interconnection nets in the logic design being run: 
CAP(N)
 
NETTOT(N)
 
The following arrays have the unique dimension requirements 
described: 
IFA(X, Y) 	 The minimum X-dimcnsion is roughly twice the 
maximum number of pins in any fold plus 45. 
The minimum Y-dimension is the total number of 
horizontal wiring channels plus 4x(the numbcr of folds). 
IRA(X, Y) 	 The required X-dimension equals the total number 
of cell pins, including cell edge reference pins, plus 
one. The Y-dimension must be 7 plus the maximum. 
number of horizontal wire channels required at any 
one point in the linear wiring array, not to be less 
than 20. 
IYW(Y) - Dimensions should be the same as the Y-dimensions 
of IFA. 
LNAD(I) - Dimension must equal the number of pins connected 
in the design being run. 
NC(I, 5) - Dimension I must equal the number of connected 
pins minus the num-nber of nets. 
NET(l) - Dimension I [4x(number of nets) + Zx(nnmber of 
connected pinsf . 
- Dimension 	I must equal whichever is greater, theNX(l, 3) 
number of nets, the nunber of cross-fold wires, or 
the number of t-unnel ends in the PRF output. 
iv- 6 
SECTION V 
DEFINITIONS AND REFERENCES 
5. 	 1 Map Array Referencing Conventions 
The following convention corresponds to the orientation printed 
in the chip picture by the PRF program: 
Linear Chip Array Map IRA(X, Y) 
Up Increasing Y 
Right Increasing X 
Square Chip Array Map IFA(X, Y) 
Up Decreasing Y 
Right Increasing X 
Although this convention is used consistently throughout this manual, 
debug dumps and many of the listing comments use the following convention 
for both IRA(X, Y) and IFA(X, Y): 
Up - Decreasing X 
Right - Increasing Y 
All output data coordinates follow yet another convention -whore the 
origin is located at the lower left of a plot, resulting in these axis directions: 
Up - Increasing Y 
Right - Increasing X 
Some of the listing comments in ASSIGN, ARTWRK, and POWR 
referehce IFA using this last convention, 
5. 2 	 Abbreviations 
C. T. F - Circuit Type File
 
Cap. Capacitance
 
Coord. - Coordinate 
Ho r. 	 Horizontal 
V-I
 
I. -	 Inverted 
L. - Left
 
Msg. - Message
 
N. -	 Normal 
P. R. F. - Placement-Routing-Folding Program 
Ref. - Reference 
Rt. - Right 
Seg. - Segment 
T. E. - Tunnel End
 
Trans. - Transistor
 
Tun. - Tunnel
 
Vert. - Vertical
 
5.3 Term Definitions 
CAP WIRES -	 Same as LEFT END-APOUND WIRES. 
CELL/PIN ID - A number which identifies both the cell number 
and the pin number of a pin position in IRA or 
IFA. Set to Ci00 x (cell numnber) 4 (pin numberg. 
CROSS-FOLD WIRES - Wire interconnections between a pair of adjacent 
folds whose cells are connected to different power 
bus branches. 
CROSSWIRE 	 Sane as CROSS-FOLD WIRE. 
DUM'MY 	 FOLD A fold containing no calls which is inserted 
above the bottom pad fold to make the pad fold 
inverted. 
V-2 
EDGE PIN -
FOLD 
HORIZONTAL WIRE -
INVERTED CELL -
INVERTED FOLD 
LEFT END-AROUND 
LOGIC FOLD 
NORMAL CELL -
NORMAL FOLD -
Either the- first or last pin of a cell which is 
used to provide a reference to the location of 
the cell edge, and may not be used as a 
connection point. 
A row of Banning standard cells to be placed 
side by side on the chip, and the wire intercon­
nections associated with these cells. 
An interconnection segment which runs parallel 
to the fold axes of the chip. Such a segment 
will be represented in chip map IRA and IFA by 
elements having the same Y-coordinate and 
containing either a number N,ClI N 998 (metal
 
of net N), or 998 (tunnel end).
 
A cell which was oriented in the linear chip 
map IRA so that its first pin was referenced by 
a larger X-coordinate than its last pin. 
A fold whose cells are oriented with their
 
connection pins above.
 
WIRES - Wire interconnections between a pair 
a commonof adjacent folds whose cells share 

power bus branch.
 
A fold containing at least one cell, but no
 
bonding pad cells.
 
A cell which was oriented in the linear chip rnap 
IRA so that its first pin -\,as. referenced by a 
smaller X-coordinate than its last pin. Cells 
are drawn in normal orientation in the Banning 
Engineering Notebook. 
A fold whose cells are oriented with their
 
connection pins belovw, as they are drawn in
 
the Banning Engineering Noiebook.
 
V-3
 
PAD FOLD 	 A fold which contains one or more bonding 
pad cells. 
- A pin whose specified 	connection has beenREASSIGNED PIN 
interchanged with an equivalent pin of the 
same cell to reduce total connection length. 
as EDGE PIN.REFERENCE PIN -	 Same 
LENGTH - A value wbicb specifies the distance inRUNNING 
tenths of a mil between a particular cell 
pin or wiring column and sone reference 
point. This reference point may be either 
the left end of the linear chip map, the 
right or left end of a fold, or the origin 
of the chip coordinates. 
of 10 added to a cell by theSPACER PIN 	 A pin number 
PRF programn where the cell has space 
for a wuiring channel but does not have a 
connection pin. 
TAP 	 An intermediate connection between the 
end points of a horizontal wire segment. 
TUNNEL END 	 A point at wh'cb pattern set data is to be 
used to create a connection between metal 
and P-material. 
runsVERTICAL WIRE An interconnection segment which 
perpendicular to ihe fold axes of the chip. 
The representation of such a segment in 
chip m-aps IRA and IFA will consist of 
elements having the same X-coordinate 
and containing either a 1 (vertical metal), 
999 (tunnel) or 998 (tunnel end). 
5.4 References 
(M&S ComrputingBanning Iliacement-Routing - Foldin" User's lannwil 

Report No. 70-0021).
 
V-4 
Banning ARTWORK Program User's Manual (M&S Computing 
Report No. 70-0012). 
V-5
 
4L U.S. GOVERNMENT PRINTING OFFICE 1976-641.255/555 REGION NO. 4 
