RouteChannel:
CEDAR
DEFINITIONS =
{
maxTrack: NAT = 600; -- MUST be even!!!
maxPinsOnCh: NAT = 2000;
ZMaxTracks: TYPE = NAT[0 .. maxTrack];
MaxTracks: TYPE = NAT[1 .. maxTrack];
MPinsOnCh: TYPE = NAT[1 .. maxPinsOnCh];
ZMPinsOnCh: TYPE = NAT[0 .. maxPinsOnCh];
ChanSideOrNone: TYPE = {none, chanBottom, chanTop, chanLeft, chanRight};
ChanSide: TYPE = ChanSideOrNone[chanBottom .. chanRight];
ChanSideName: ARRAY ChanSide OF Rope.ROPE;
ChanLRSide: TYPE = ChanSide[chanLeft .. chanRight];
ChanTBSide: TYPE = ChanSide[chanBottom .. chanTop];
AboveOrBelow: TYPE = {above, below};
AboveOrBelowName: ARRAY AboveOrBelow OF Rope.ROPE;
GoingDirection: TYPE = {leftToRight, rightToLeft};
GoingName: ARRAY GoingDirection OF Rope.ROPE;
RoutingChannelSides:
TYPE =
REF RoutingChannelSidesRec;
RoutingChannelSidesRec:
TYPE =
RECORD [
routeAreaCoord: DABasics.Number ← 0,
extSide: DABasics.Side,
barrierList: ARRAY RoutePrivate.RoutingLayer OF RTBasic.PQRectList ← ALL[NIL],
enclosingBarrier: RTBasic.PQRect ← [[0, 0], [0, 0]]
];
RoutingChannelPins:
TYPE =
REF RoutingChannelPinsRec;
RoutingChannelPinsRec:
TYPE =
RECORD [
cEnd1,
cEnd2: DABasics.Number ← 0,
count: ZMPinsOnCh ← 0,
size: ZMPinsOnCh ← maxPinsOnCh,
sides: ARRAY MPinsOnCh OF PinPosition ← ALL[NIL]
];
ChanParms:
TYPE =
REF ChanParmsRec;
ChanParmsRec:
TYPE =
RECORD [
maxToConvert,
emptyTrackLimit: DABasics.Number
];
RoutingChannelTracks:
TYPE =
REF RoutingChannelTracksRec;
RoutingChannelTracksRec:
TYPE =
RECORD [
count,
maxCount: ZMaxTracks ← 0,
size: ZMaxTracks ← maxTrack,
tracks: ARRAY MaxTracks OF Track
];
Track:
TYPE =
REF TrackRec;
TrackRec:
TYPE =
RECORD [
oldTrackNum,
trackNum: ZMaxTracks ← 0,
trackPos,
maxFeatureOnTrack: INT ← 0,
firstSeg: Segment ← NIL,
blocked: BOOLEAN ← FALSE,
keep: BOOLEAN ← FALSE
];
Segment:
TYPE =
REF SegmentRec;
SegmentRec:
TYPE =
RECORD [
exteriorPins: ARRAY ChanLRSide OF ChanPin ← ALL[NIL],
interiorPins: ChanPinList ← NIL,
routingLayer: RoutePrivate.RoutingLayer ← trunk,
qWidth: NAT ← 0,
constraintNode: RouteDiGraph.Node ← NIL,
trackNum,
trackConstraint,
secTrackConstraint: ZMaxTracks ← 0,
nextSeg: Segment ← NIL,
net: RoutePrivate.Net ← NIL,
part: INT ← 1,
failed,
exitBreak: BOOLEAN ← FALSE
];
SegmentList: TYPE = LIST OF Segment;
SegmentConstraint:
TYPE =
REF SegmentConstraintRec;
SegmentConstraintRec:
TYPE =
RECORD [
name: Rope.ROPE ← NIL,
segment: Segment
];
PinPosition:
TYPE =
REF PinPositionRec;
PinPositionRec:
TYPE =
RECORD [
pinIndex: ZMPinsOnCh,
pLoc: DABasics.Number ← 0,
blocked: BOOLEAN ← FALSE,
pins: ARRAY ChanTBSide OF ChanPin ← ALL[NIL],
innerPins: ChanPinList ← NIL
];
ChanPinType: TYPE = {noPin, chanConnect, dogLeg, compPin, exitPin};
ChanPin:
TYPE =
REF ChanPinRec;
ChanPinRec:
TYPE =
RECORD [
pinSide: ChanSideOrNone,
qLoc: DABasics.Number ← 0,
pWidth: NAT ← 0,
kindOfPin: ChanPinType,
pinPosition: PinPosition,
trackConstraint: ZMaxTracks ← 0, -- track Consdtraint of segment attached to pin
conctSeg: ARRAY ChanLRSide OF Segment ← ALL[NIL],
altConctSeg: ARRAY ChanLRSide OF Segment ← ALL[NIL], -- used only if non pin dog leg outside range
pin: InternPin ← NIL
];
ChanPinList: TYPE = LIST OF ChanPin;
ChannelData:
TYPE =
REF ChannelDataRec;
ChannelDataRec:
TYPE =
RECORD [
constraints: RouteDiGraph.Graph ← NIL,
chanSides: ARRAY ChanSide OF RoutingChannelSides ← ALL[NIL],
chanTracks: RoutingChannelTracks ← NIL,
chanPins: RoutingChannelPins ← NIL,
chanParms: ChanParms ← NIL
];
InternPin:
TYPE =
REF InternPinRec;
InternPinRec:
TYPE =
RECORD[
name: Rope.ROPE,
chanSide: ChanSide,
location: RTBasic.PQPos,
pWidth: NAT,
layer: RoutePrivate.RoutingLayer,
pin: Route.Pin ← NIL
];
InternPinList: TYPE = LIST OF InternPin;
Density:
TYPE =
REF DensityRec;
DensityRec:
TYPE =
RECORD [
maxDensity: DABasics.Number ← 0,
values: ARRAY MPinsOnCh OF DABasics.Number ← ALL[0]
];
channel routing method
TrackSequence: TYPE = {start, outsideInTop, outsideInBottom, botToTop, topToBot};
DirectionSequence: TYPE = {start, leftToRight, rightToLeft, alternateLeft, alternateRight};
Method:
TYPE =
REF MethodRec;
MethodRec:
TYPE =
RECORD[
trackSequence: TrackSequence ← start,
directionSequence: DirectionSequence ← start
];
trackSequenceName: ARRAY TrackSequence OF Rope.ROPE;
directionSequenceName: ARRAY DirectionSequence OF Rope.ROPE;
InitChannel:
PROC [extSidesData: RoutePrivate.RoutingAreaSides,
parms: RoutePrivate.RoutingAreaParms,
rules: Route.DesignRules,
netTab: RoutePrivate.NetTab,
signalSinglePinNets,
signalCoincidentPins: BOOLEAN ← TRUE,
okToDiddleLLPins,
okToDiddleURPins: BOOLEAN ← FALSE]
RETURNS [chanData: RouteChannel.ChannelData];
Initialize for channel routing
FindPinPos:
PROC [chanPins: RoutingChannelPins, thisPLoc: DABasics.Number]
RETURNS [index: ZMPinsOnCh];
build the PinPosition data structure for this pin at thisPLoc.
NOTE: NOT intended for general use !!!
GenerateConstraints:
PROC [chanData: ChannelData,
parms: RoutePrivate.RoutingAreaParms,
rules: Route.DesignRules,
routerUsed: RoutePrivate.RouterUsed]
RETURNS [anythingToDo: BOOLEAN];
run through the pins on the channel,
create segment constraints from the pin to pin relationships
TopoWiring:
PROC [chanData: RouteChannel.ChannelData,
parms: RoutePrivate.RoutingAreaParms,
rules: Route.DesignRules,
opt: Route.Optimization]
RETURNS [routingResult: Route.ResultData];
channel route the routing area
EnumTracks:
PROC [chanTracks: RoutingChannelTracks, eachAction: EachTrackActionProc]
RETURNS [quit:
BOOLEAN ←
FALSE];
EachTrackActionProc: TYPE = PROC [track: Track, trackIndex: MaxTracks] RETURNS [quit: BOOLEAN ← FALSE];
EnumPins:
PROC [pinPosition: PinPosition, eachAction: EachPinActionProc]
RETURNS [quit:
BOOLEAN ←
FALSE];
EnumPinsOnSeg:
PROC [seg: Segment, eachAction: EachPinActionProc]
RETURNS [quit:
BOOLEAN ←
FALSE];
EachPinActionProc: TYPE = PROC[pinPosition: PinPosition, pin: ChanPin] RETURNS [quit: BOOLEAN ← FALSE];
EnumPinPositions:
PROC [chanPins: RoutingChannelPins, eachAction: EachPinPositionActionProc]
RETURNS [quit:
BOOLEAN ←
FALSE];
EachPinPositionActionProc: TYPE = PROC[pinPosition: PinPosition, pinIndex: MPinsOnCh] RETURNS [quit: BOOLEAN ← FALSE];
EnumSegmentsProc:
TYPE =
PROC [
parms: RoutePrivate.RoutingAreaParms,
name: Rope.ROPE,
pos1, pos2: DABasics.Position,
width: DABasics.Number,
layer: CD.Layer]; -- Call back for wiring segments
EnumViasProc:
TYPE =
PROC [
parms: RoutePrivate.RoutingAreaParms,
name: Rope.ROPE,
pos, size: DABasics.Position, -- rectangle of size centered on pos
layer1, layer2: CD.Layer]; -- Call back for branch ends
EnumIncompletesProc:
TYPE =
PROC [
parms: RoutePrivate.RoutingAreaParms,
name: Rope.ROPE,
pos1, pos2: DABasics.Position]; -- Call back for incomplete connections
GetRouting:
PROC [chanData: RouteChannel.ChannelData,
parms: RoutePrivate.RoutingAreaParms,
rules: Route.DesignRules,
rect: DABasics.Rect,
brokenNetName: Route.BrokenNetProc,
channelData: REF ANY,
enumSegments: EnumSegmentsProc,
enumVias: EnumViasProc,
enumIncompletes: EnumIncompletesProc];
Enumerate routing results entities
RetrieveSegments: EnumSegmentsProc;
RetrieveVias: EnumViasProc;
RetrieveIncompletes: EnumIncompletesProc;
Destroy:
PROC [chanData: ChannelData];
Remove circular references so garbage collection can work
ClearChan:
PROCEDURE[chanData: ChannelData];
initialize for one channel routing
TrackLoc:
PROC [chanTracks: RoutingChannelTracks, parms: RoutePrivate.RoutingAreaParms, rules: Route.DesignRules, track: ZMaxTracks]
RETURNS [loc: DABasics.Number];
get location of the specified track
TrackSeg:
PROC [chanTracks: RoutingChannelTracks, track: MaxTracks]
RETURNS [Segment];
get first segment on the specified track
TrackSegAbs:
PROC [chanTracks: RoutingChannelTracks, track: MaxTracks]
RETURNS [Segment];
get first segment on the specified track without indirect reference
ChannelWidth:
PROC [chanTracks: RoutingChannelTracks, parms: RoutePrivate.RoutingAreaParms, rules: Route.DesignRules]
RETURNS [DABasics.Number];
returns the width of th channel
InfluenceTracks:
PROC [rules: Route.DesignRules, wireWidth:
NAT]
RETURNS [
NAT];
find how far a track can influence another track ( in tracks)
ExtSideToIntSide:
PROC [rules: Route.DesignRules, extSide: DABasics.Side]
RETURNS [intSide: ChanSide];
convert a position from x-y to p-q space.
IntSideToExtSide:
PROC [rules: Route.DesignRules, intSide: ChanSide]
RETURNS [extSide: DABasics.Side];
convert a position from p-q to x-y space.
WriteConstraints:
PROC [graph: RouteDiGraph.Graph];
write the constraint graph on the terminal
GetPinsOnSeg:
PROC [seg: Segment]
RETURNS [pinList: ChanPinList];
find all of the segments attached to a pin
GetSegsOnPin:
PROC [pin: ChanPin]
RETURNS [segList: SegmentList];
find all of the segments attached to a pin
DestroyOldConstraints:
PROC [chanData: ChannelData];
must explicitly destroy the old data
ComputeDensity:
PROC [chanPins: RoutingChannelPins, rules: Route.DesignRules]
RETURNS [density: Density];
compute the track density for the current channel
Length:
PROC [seg: Segment]
RETURNS [DABasics.Number];
return lenth of line segment from pos1 to pos2.
WriteResult:
PROC [result: Route.ResultData,
parms: RoutePrivate.RoutingAreaParms,
rules: Route.DesignRules,
method: Method];
write the results
FindConstraintLimits:
PROC [
chanPins: RoutingChannelPins,
parms: RoutePrivate.RoutingAreaParms,
rules: Route.DesignRules,
nextLower, nextHigher: MPinsOnCh,
pinAction: EachPinActionProc]
RETURNS [minLimit, maxLimit: MPinsOnCh];
find the limits for constraints
CheckPins:
PROCEDURE[seg: Segment, pin: ChanPin, sideOfSeg: ChanLRSide];
make sure a pin points back to segment
CheckSegs:
PROCEDURE[seg: Segment, pin: ChanPin];
make sure a segment points back to pin
AuditPins:
PROC [chanPins: RouteChannel.RoutingChannelPins];
make sure pin data is consistent
AuditSegs:
PROC [chanTracks: RoutingChannelTracks];
make sure seg data is consistent
Combine:
PROCEDURE [l1, l2, l3: ChanPinList]
RETURNS [l: ChanPinList ←
NIL];
MembRopeList:
PROCEDURE [ref: Rope.
ROPE, list:
LIST
OF Rope.
ROPE]
RETURNS [
BOOL];
GetRange:
PROC [pinList: ChanPinList]
RETURNS [range: RTBasic.Range];
get the range of the pins in the pinList
PinsOnSide: PROC [seg: Segment] RETURNS [left, top, right, bottom: BOOLEAN];