IC Compiler User Guide
Contents
WhatsNewinThisrelease
Aboutthisguide
XXVIll
CustomerSupport
1■口
PartI:ICCompilerImplementationFlow
IntroductiontoICCompiler
Supportedplatforms
1-2
ICCompilerPackages
1-2
UserInterfaces
-5
MethodologyOverview
■■■1
1-5
SpeedingUptheBasicFlow
1-8
2.WorkingWithICCompiler
GettingStarted
22
StartingICCompiler
22
Enteringicc_shellCommands
2-4
ChoosingmenuCommandsinguiwindows
InterruptingorTerminatingcommandprocessing
OpeningandClosingthegUI
2-7
UsingTclScripts
28
UsingSetupFiles
2-9
ExitingICCompiler
■■■■■着日■1
2-10
ICCompilerImplementationUserGuide
Versiond-201003
GettingHelpinICCompiler
2-11
GettingHelpontheCommandLine
2-11
FindingMenuCommandsandDialogBoxes
212
ViewingManPages
2-14
DisplayingtheListofKeyboardShortcuts
2-14
UsingOnlineHelp
2-15
SearchingforText
2-16
ConfiguringtheHelpBrowser
2-17
WorkingWiththeguI
2-18
UsingGUIWindows
2-18
Menubar
重1
2-19
Toolbars
2-20
Statusbar
2-20
ViewWindows
2-21
Panels
1重
2-22
WorkingintheMainWindow
■■面
2-23
WorkingWiththeConsole
2-24
ViewingtheSessionLog
2-25
ViewingtheHistoryView
2-27
Previewingicc_shellCommandsinDialogBoxes
2-28
ViewingthePhysicalLayout
2-29
SettingthecurrentTask
2-30
SettingthePrimaryDesign
2-31
SettingGUIPreferences
2-31
ReadingandSavingDesigns
2-32
ReadingaDesign
2-33
SettingtheCurrentDesigr
2-34
Savingdesigns
2-34
SavingdesignSettings
2-35
Closingdesigns
2-36
SavingorDiscardingDesignChanges
2-37
Archivingdesigns
■■■■■着日■1
2-39
UsingICCompilerCommand-LineInterfaces
2-41
UsingWildcardCharacters
■
2-43
UsingAliases
2-43
istingandRerunningPreviouslyEnteredCommands
2-44
ReportingMemoryUsageandRuntime
2-44
Contents
ICCompilerImplementationUserGuide
Versiond-201003
RedirectingandAppendingcommandoutput
2-44
CheckingtheSyntaxandSemanticsofYourScripts
2-45
InstallationRequiremen
2-46
RunningtheSynopsysSyntaxChecker
2-46
LimitationsoftheSynopsysSyntaxChecker
2-48
Bytecode-CompiledFiles
2-49
TclProLimitations
2-49
WorkingWithLicenses
2-49
ListingtheLicensesinUse
2-50
GettingLicenses
2-50
EnablingLicenseQueuing
2-51
Releasinglicenses
2-52
GettingandReleasingLicensesintheGUI
2-52
EnablingMulticoreProcessing
2-53
ConfiguringMultithreading
2-53
ConfiguringDistributedProcessing
2-54
3.Preparingthedesign
SettingUptheLibraries
3-2
SettingUptheLogicLibraries
32
SettingUpthePhysicalLibraries
3-3
CreatingaMilkywayDesignLibrary
3-4
ManagingMilkywayReferenceLibrariesUsing
Referencecontrolfiles
3-5
UpdatingMilkywayLibrariestotheLatestSchema
3-10
OpeningaMilkywayDesignLibrary
3-12
ReportingonaMilkywayDesignLibrary
3-12
ChangingPhysicalLibraryInformation
3-13
SavingPhysicalLibraryInformation
3-14
VerifyingLibraryConsistency
3-15
ReadingtheDesign
3-15
ReadingaDesigninMilkywayFormat
3-16
ReadingaDesigninASCllFormat
3-17
AnnotatingthePhysicalData
3-18
ReadingDEFFiles
3-18
ReadingFloorplanFiles
3-19
Contents
ICCompilerImplementationUserGuide
Versiond-201003
CopyingPhysicalData
3-19
ValidatingPhysicalData
3-21
CheckingtheDesignDatabase
3-21
UsingtheGUIPartitionEditor
■■■■■
3-22
PreparingforTimingAnalysisandRCCalculation
3-27
SettingUpthetlUPlusFiles
3-27
Back-AnnotatingDelayorParasiticData
重1
3-29
SettingtimingConstraints
3-29
SpecifyingtheOperatingConditionAnalysisMode
3-30
SettingVoltageandTemperatureScalingBetweenLibraries
3-31
SettingtheDeratingFactors
3-32
SelectingtheDelaycalculationMethod
3-33
Savingthedesign
3-34
SavingthedesigninmilkywayFormat
3-34
SavingthedesigninASCllFormat
3-34
WritingGDSIIandOASISLayoutDataFiles
3-35
4.DesignforTest
Overviewofthedftflow
4-2
PreparingforPhysicalDFTUsingtheread_defFlow
4-3
PerformingScanSynthesisandGeneratingaSCANDEFFile
4-4
Hierarchicalflov
LoadingtheSCANDEFFile
4-5
GeneratingSCANDEFDataUsingthetrace_scan_chainFlow
4-6
ScanChainConsistencyChecking
4-7
RemovingSCANDEFData
4-8
OptimizingScanChains
4-8
Placement-AwareScanChainReordering
4-9
Clock-AwareScanReordering
4-11
ExampleoptimizationFlow
iewingScanChains
4-12
Contents
ICCompilerImplementationUserGuide
Versiond-201003
5.PowerOptimization
TypesofPowerOptimization
52
StrategiesToReduceLeakagePower
5-2
UsingMultipleThreshold-VoltageCells
5-3
MultipleThreshold-VoltageLibraries
5-4
DefiningMultipleThreshold-VoltageCellsUsingAttributes
ConstrainingtheLeakagePowerOptimization
::
5-5
AdaptiveLeakagePowerOptimization
5-7
AnnotatingSwitchingActivity
.·
SettingtheOptionsforPowerOptimization
5-8
Performingpoweroptimization
5-9
LoW-PowerPlacement
5-9
LOW-PowerClockTreeSynthesis
5-10
LOW-PowerRouting
1■■■■
5-10
PowerOptimizationFlowExample
5-11
6.Placement
DefiningPlacementBlockages
6-2
DefiningKeepoutMargins
重■重
6-2
DefiningGlobalKeepoutMargi
6-3
DefiningCell-SpecificKeepoutMargins
6-4
DefiningArea-BasedPlacementBlockages
6-5
lacementOpti
CongestionOptions
6-7
Movebounds
68
IntercellandBoundarySpacingRules
6-9
ButterStrategyforOptimization
6-11
SettingthePreferredBuffersforHoldFⅸXing...…,
6-11
TieCellInsertion
6-12
MagnetPlacement.
1■
1■
6-12
PlacementandOptimizationAttributes
6-14
InsertingPortProtectionDiodes
6-15
PreparingforHigh-FanoutNetsynthesis
6-15
AnalyzingPlacementandOptimizationFeasibility
6-16
Contents
ICCompilerImplementationUserGuide
Versiond-201003
AnalyzingCellDisplacementDuringLegalization
6-17
PerformingClockTreeSynthesisDuringPlacement
6-19
Performingplacementandoptimization
6-20
UsingPhysicalGuidanceFromDesignCompiler
6-22
SavingIntermediateResultsDuringRerouteOptimization
6-22
SettingUpforCongestion-DrivenPlacement
6-23
UsingPhysicalOptimization
6-24
RerouteRCEstimation
■m
6-26
ModifyingtheRCCoefficients
6-27
DefiningNet-BasedLayerConstraints
6-27
IntroducingPessimism
6-28
EnablingviaResistanceEstimation
6-29
ScalingtheviaResistancevalues
6-29
ManuallySpecifyingViaResistanceValues
6-29
AnalyzingPlacement
6-30
PlacementAreautilization
6-30
TimingAnalysis
6-32
PowerAnalysis
6-37
Quality-of-ResultsReporting
6-39
creategorsnapshot
1■■
6-40
query_gor_snapshot
6-41
PlacementAnalysisToolsinthegUI
6-43
CellDensityMe
6-44
CongestionMaps
6-46
HierarchyVisualMode
6-47
ClockTreeVisualmode
6-48
NetConnectionsinAreavisualmode
::·:
6-48
RefiningPlacement
6-52
7.ClockTreeSynthesis
PrerequisitesforClockTreeSynthesis
DesignPrerequIsites…
7-3
LibraryPrerequisites............
AnalyzingtheClockTrees
1■
7-4
DefiningtheClockTrees
7-5
Contents
ICCompilerImplementationUserGuide
Versiond-201003
Cascadedclocks
7-6
CascadedGeneratedClocks
1■■■■■
7-6
IdentifyingtheClockTreeEndpoint
7-7
DefiningtheclockRootAttributes
7-9
SpecifyingclockTreeEXceptions
SpecifyingNonstopPins
7-13
SpecifyingEXcludePins
7-13
SpecifyingFloatPin
7-14
SpecifyingStopPins
7-17
SpecifyingDon'tTouchSubtrees
7-17
SpecifyingDon'tBufferNets
pecifyingDontsizecells
7-18
SpecifyingSize-OnlyCells
7-19
PreservingtheClockPinsofExistingHierarchies
7-19
SpecifyingtheClockTreeReferences
7-20
DefiningClockCellSpacingRules
■■■
7-22
SpecifyingClockTreeSynthesisOptions
7-23
SpecifyingtheClockTreeSynthesisGoals
7-27
SettingClockTreeDesignRuleConstraints
7-27
SettingClockTreeTimingGoals
7-29
SettingLevelRestrictions
7-30
SettingClockTreeRoutingOptions
7-30
SpecifyingRoutingRules
■■■
7-31
ShieldingClockNets
7-32
SpecifyingroutingLayers
7-34
AssociationofNondefaultroutingruleswithreferencecells
7-35
InsertingBoundaryCells
7-36
SelectingtheClockTreeClustering
7-37
EnablingOn-Chip-Variation-AwareClustering
7-38
EnablingLogic-LevelBalancing
7-38
EnablingRegion-AwareClockTreeSynthesis
7-41
SpecifyingClockTreeOptimizationOptions
7-42
ControllingEmbeddedClockTreeOptimization
7-42
ControllingRerouteClockTreeOptimization
7-43
ControllingPostrouteClockTreeOptimization
7-44
SavingIntermediateResultsDuringPrerouteOptimization
44
Contents
ICCompilerImplementationUserGuide
Versiond-201003
InsertingUser-SpecifiedClockTrees
7-45
ReadingaClockConfigurationFile
7-45
ReducingSkewVariationbyUsingRCConstraint-BasedClustering
7-45
Savingaclockconfigurationfile
7-46
Definingtheclocktreestructure
7-46
HandlingSpecificDesignCharacteristics
7-50
HandlingHardMacroCells
■m■
7-50
andlingExistingClockTrees
7-51
IdentifyingExistingClockTrees
7-51
PreservingPortionsofanEXistingClockTree
7-52
RemovingClockTrees
7-52
HandlingNon-UnateGatedClocks
7-54
HandlingIntegratedClock-GatingCells
7-54
OptimizingforClockTreeQoR
7-54
OptimizingforPower
7-56
otimizingforTimingonEnableSignals
7-58
BalancingMultipleClocks
7-60
DefiningtheDelayBalancingBuffers
7-60
DefiningaClockBalanceGroup
■1
7-60
DefiningtheInterclockDelayRequirements
7-61
RemovingtheInterlockdelaysettings
7-63
HierarchicalDesignsUsingInterfaceLogicModels
7-64
Multivoltagedesigns
7-64
Multicorner-Multimodedesigns
7-65
/erifyingtheClockTrees
7-65
ImplementingtheClockTrees
7-67
AnalyzingOptimizationFeasibilityAfterClockTreeSynthesis
7-72
StandaloneClockTreeSynthesisCapabilities
7-73
PerformingClockTreePowerOptimization
7-74
PerformingClockTreeSynthesis
7-74
PerformingClockvτerOPimization….…
High-FanoutNetSynthesis
7-75
7-76
ImplementingclockMeshes
7-80
PrerequisitesforcreatingclockMeshes
7-81
Theclockmeshflow
7-82
FlatteningtheLogicofIntegratedClock-GatingCells
重1重
7-83
SplittingClockNets
7-84
Contents
暂无评论