# **SmartTime Static Timing Analyzer User Guide** Libero SoC v2025.1 #### Introduction (Ask a Question) SmartTime is a Libero SoC interactive gate-level static timing analysis tool that allows you to visualize and identify timing issues in your designs. Using this tool, you can evaluate how close you are to meeting your timing requirements, create custom sets to track, set timing exceptions to obtain timing closure, and define cross-probe paths with other tools. Key SmartTime features allow you to: - Perform complete timing analysis of your design to ensure that your designs meet all timing constraints and operate at the desired speed, with the appropriate amount of margin across all operating conditions. - Browse through your design's various clock domains to examine the timing paths and identify those that violate your timing requirements. - · Create customizable timing reports. - Navigate directly to the paths responsible for violating your timing requirements. **Note:** Creating and editing timing constraints are handled in a separate Timing Constraints Editor. For more information, see the Timing Constraints Editor User Guide. #### **Supported Device Families** The following table lists the family of devices that Libero SoC supports. This guide covers all these device families. However, some information in this guide might apply to certain device families only. In this case, such information is clearly identified. **Table 1.** Device Families Supported by Libero SoC | Device Family | Description | |----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | PolarFire® | PolarFire FPGAs deliver the industry's lowest power at mid-range densities with exceptional security and reliability. | | PolarFire SoC | PolarFire SoC is the first SoC FPGA with a deterministic, coherent RISC-V® CPU cluster, and a deterministic L2 memory subsystem enabling Linux® and real-time applications. | | SmartFusion® 2 | SmartFusion 2 addresses fundamental requirements for advanced security, high reliability, and low power in critical industrial, military, aviation, communications, and medical applications. | | IGLOO® 2 | IGLOO 2 is a low-power mixed-signal programmable solution. | | RTG4™ | RTG4 is Microchip's family of radiation-tolerant FPGAs. | **Important:** This document is updated frequently. The latest version of this document is available at this location: Libero SoC Design Suite Documentation. # **Table of Contents** | Int | roduct | ion | 1 | | |----------------------|--------|------------------------------------------------------------------------------|----|--| | 1. | Abou | About SmartTime | | | | | 1.1. | Static Timing Analysis (STA) | 2 | | | | 1.2. | Timing Constraints | 2 | | | | 1.3. | Timing Analysis | 2 | | | | 1.4. | SmartTime and Place and Route | ∠ | | | | 1.5. | Timing Reports | | | | | 1.6. | Cross-probing into Chip Planner | | | | | 1.7. | Cross-probing into Constraints Editor | | | | 2. | Desig | n Flows with SmartTime | 6 | | | 3. | Starti | ng and Closing SmartTime | | | | 4. | Confi | guring SmartTime Settings | 8 | | | | 4.1. | Configuring SmartTime General Settings | 8 | | | | 4.2. | Configuring SmartTime Analysis Settings | | | | | 4.3. | Configuring SmartTime Advanced Settings | 10 | | | 5. SmartTime Toolbar | | 12 | | | | 6. | Smar | tTime Timing Analyzer | 13 | | | | 6.1. | SmartTime Analyzer Components | 13 | | | | 6.2. | Analyzing Your Design | 13 | | | | 6.3. | Maximum Delay Analysis View | 14 | | | | 6.4. | Managing Clock Domains | 14 | | | | 6.5. | Managing Path Sets | | | | | 6.6. | Displaying Path List Timing Information | | | | | 6.7. | Displaying Expanded Path Timing Information | | | | | 6.8. | Using Filters | 20 | | | 7. | Adva | nced Timing Analysis | 22 | | | | 7.1. | Understanding Inter-Clock Domain Analysis | 22 | | | | 7.2. | Activating Inter-Clock Domain Analysis | | | | | 7.3. | Displaying Inter-Clock Domain Paths | | | | | 7.4. | Deactivating a Specific Inter-Clock Domain | | | | | 7.5. | Changing Output Port Capacitance | 25 | | | 8. | Gene | rating Timing Reports | | | | | 8.1. | Types of Reports | 27 | | | | 8.2. | Generating a Timing Report | | | | | 8.3. | Understanding Timing Reports | | | | | 8.4. | Generating a Timing Violation Report | | | | | 8.5. | Understanding Timing Violation Reports | | | | | 8.6. | Generating a Constraints Coverage Report | | | | | 8.7. | Understanding Constraints Coverage Reports | | | | | 8.8. | Generating a Bottleneck Report. | | | | | 8.9. | Understanding Bottleneck Reports—SmartFusion 2, IGLOO 2, RTG4, and PolarFire | 33 | | | 9.10 Congrating a Datashoot Depart | | |----------------------------------------------------------|-----| | 8.10. Generating a Datasheet Report | 34 | | 8.11. Understanding Datasheet Reports | 34 | | 8.12. Generating a Combinational Loop Report | 36 | | 8.13. Understanding Combinational Loop Reports | 36 | | 8.14. Generating a Clock Domain Crossing (CDC) Report | 37 | | 9. Timing Concepts | 47 | | 9.1. Static Timing Analysis Versus Dynamic Simulation | 47 | | 9.2. Delay Models | | | 9.3. Timing Path Types | 47 | | 9.4. Maximum Clock Frequency | 47 | | 9.5. Setup Check | | | 9.6. Arrival Time, Required Time, and Slack | | | 9.7. Timing Exceptions Overview | | | 9.8. Clock Skew | | | 9.9. Cross Probing | 49 | | 10. SmartTime Tutorials | 56 | | 10.1. Tutorial 1—32-Bit Shift Register with Clock Enable | | | 10.2. Tutorial 2—False Path Constraints | 70 | | 11. SmartTime Dialog Boxes | 80 | | 11.1. Add Path Analysis Set Dialog Box | 80 | | 11.2. Analysis Set Properties Dialog Box | 81 | | 11.3. Edit Filter Set Dialog Box | 82 | | 11.4. Customize Analysis View Dialog Box | 82 | | 11.5. Manage Clock Domains Dialog Box | | | 11.6. Set False Path Constraint Dialog Box | | | 11.7. SmartTime Options Dialog Box | | | 11.8. Create Filter Set Dialog Box | | | 11.9. Timing Bottleneck Analysis Options Dialog Box | | | 11.10. Timing Datasheet Report Options Dialog Box | | | 11.11. Timing Report Options Dialog Box | | | 11.12. Timing Violations Report Options Dialog Box | | | 11.13. Data Change History—SmartTime | 98 | | 12. Tcl Commands | 100 | | 13. Glossary | 101 | | 14. Revision History | 103 | | Microchip FPGA Support | 104 | | Microchip Information | 104 | | Trademarks | 104 | | Legal Notice | | | Microchip Devices Code Protection Feature | | #### 1. About SmartTime (Ask a Question) The following sections describe SmartTime functions. ## 1.1. Static Timing Analysis (STA) (Ask a Question) Static Timing Analysis (STA) offers an efficient technique for identifying timing violations in your design and ensuring that it meets all your timing requirements. You can communicate timing requirements and timing exceptions to the system by setting timing constraints. Then a static timing analysis tool checks and reports setup, and holds violations and violations on specific path requirements. STA is particularly well suited for traditional synchronous designs. The main advantage of STA is that unlike dynamic simulation, it does not require input vectors. It covers all possible paths in the design and does all the above with relatively low run-time requirements. A major disadvantage of STA is that the STA tools do not automatically detect false paths in their algorithms as it reports all possible paths, including false paths, in the design. False paths are timing paths in the design that do not propagate a signal. To get a true and useful timing analysis, identify any false paths as false path constraints to the STA tool and exclude them from timing considerations. The SmartTime user interface provides efficient, user-friendly ways to define these critical false paths. # 1.2. Timing Constraints (Ask a Question) SmartTime supports a range of timing constraints to provide useful analysis and efficient timing-driven layout. #### 1.3. Timing Analysis (Ask a Question) SmartTime provides a selection of analysis types that allow you to: - Find the minimum clock period/highest frequency that does not result in a timing violations - Identify paths with timing violations - Analyze delays of paths that have no timing constraints - Perform inter-clock domain timing verification - Perform maximum and minimum delay analysis for setup and hold checks To improve the accuracy of the results, SmartTime evaluates clock skew during timing analysis by computing individual clock insertion delays for each register. SmartTime checks the timing requirements for violations while evaluating timing exceptions such as multicycle or false paths. #### 1.4. SmartTime and Place and Route (Ask a Question) Libero SoC Place and Route uses SmartTime STA during timing-driven place-and-route operations run in the background. As a result, your analysis and place and route constraints are always consistent. #### 1.5. Timing Reports (Ask a Question) SmartTime provides robust reporting capabilities that allow you to generate the following report files: - Timing Report for Max and Min Delay Analysis - Timing Violations Report for Max and Min Delay Analysis - Bottleneck Report - Constraints Coverage Report - Combinational Loop Report #### 1.6. Cross-probing into Chip Planner (Ask a Question) From SmartTime, you can select a design object and cross-probe the same design object in Chip Planner. Design objects that can be cross-probed from SmartTime to Chip Planner include: - Ports - Macros - Timing paths # 1.7. Cross-probing into Constraints Editor (Ask a Question) From SmartTime, you can cross-probe into the Constraints Editor. The Constraints Editor must be running for cross-probing to work. For more information, see section Cross-Probing from SmartTime to Chip Planner. # 2. Design Flows with SmartTime (Ask a Question) You can access SmartTime in Libero SoC during the following design implementation phases: - During Place and Route—when you select timing-driven place-and-route, SmartTime runs in the background to provide accurate timing information. - After Place and Route—run SmartTime to perform post-layout timing analysis and adjust timing constraints. In the Libero SoC Design Flow window, expand Implement Design > Verify Post-Layout Implementation and then either: - Double-click **Verify Timing** to generate Timing Reports. - Right-click **Open SmartTime > Open Interactively** to run SmartTime. - During Back-Annotation—SmartTime runs in the background to generate the SDF file for timing simulation. You can also run SmartTime to generate Timing Reports, regardless of which design implementation phase you are in. For more information about Place and Route and Back-Annotation, see the Libero SoC Design Flow User Guide. # 3. Starting and Closing SmartTime (Ask a Question) You must complete Place and Route for your design before using SmartTime interactively. Otherwise, Libero SoC completes that phase before starting SmartTime. To open SmartTime interactively: - 1. Select Implement Design > Verify Post Layout Implementation. - 2. Right-click **Open SmartTime** and select **Open Interactively**. SmartTime reads your design and displays post- or pre-layout timing information. To close SmartTime, choose **Exit** from the **File** menu. # 4. Configuring SmartTime Settings (Ask a Question) The SmartTime Options dialog box allows you to change general, analysis, and advanced settings. # 4.1. Configuring SmartTime General Settings (Ask a Question) To configure **General** settings in the SmartTime Options dialog box: 1. From the SmartTime Maximum/Minimum Delay Analysis View window, choose **Tools > Options**. The SmartTime Options dialog box appears. Figure 4-1. SmartTime Options Dialog Box—General Settings for SmartFusion <sup>®</sup> 2, IGLOO <sup>®</sup> 2, and RTG4 <sup>TM</sup> **Figure 4-2.** SmartTime Options Dialog Box—General Settings for PolarFire ® - 2. In the **General** category, select the settings for the operating conditions. SmartTime performs maximum or minimum delay analysis based on the best, typical, or worst case. - 3. Specify whether you want SmartTime to use inter-clock domains in calculations for timing analysis. - 4. To revert the **General** settings to their default value, click **Restore Defaults**. - 5. Change **Analysis** and **Advanced** settings as necessary. - 6. When finished, click **OK**. #### 4.2. Configuring SmartTime Analysis Settings (Ask a Question) To configure **Analysis** settings in the SmartTime Options dialog box: - 1. From the SmartTime Maximum/Minimum Delay Analysis View window, choose **Tools > Options**. The SmartTime Options dialog box appears. - 2. In the left pane, click Analysis. Figure 4-3. SmartTime Options Dialog Box—Analysis Settings - 3. Enter a number greater than 1 to specify the maximum number of paths to include in a path set during timing analysis. - 4. Check or uncheck whether to filter the paths by slack value. If you check this box, specify the slack range between the minimum slack and maximum slack. - 5. Check or uncheck whether to include clock network details. - 6. To specify the number of parallel paths in the expanded path, enter a number greater than 1. - 7. To revert the **Analysis** settings to their default value, click **Restore Defaults**. - 8. Change **General** and **Advanced** settings as necessary. - 9. When finished, click OK. # 4.3. Configuring SmartTime Advanced Settings (Ask a Question) To configure **Advanced** settings in the SmartTime Options dialog box: - 1. From the SmartTime Maximum/Minimum Delay Analysis View window, choose **Tools > Options**. The SmartTime Options dialog box appears. - 2. In the left pane, click **Advanced**. Figure 4-4. SmartTime Options Dialog Box—Advanced Settings - 3. Specify whether to use loopback in bidirectional buffers (bibufs) and/or break paths at asynchronous pins. Then specify whether to disable non-unate arcs in the clockpath. - 4. To revert the **Advanced** settings to their default value, click **Restore Defaults**. - 5. Change **General** and **Analysis** settings as necessary. - 6. When finished, click **OK**. # 5. SmartTime Toolbar (Ask a Question) The SmartTime toolbar contains icons for constraining or analyzing designs. Tool tips are available for each icon. Table 5-1. SmartTime Toolbar Icons | Icon | Description | |----------|-----------------------------------------| | | Saves the changes. | | <u>의</u> | Undoes previous changes. | | | Redoes previous changes. | | <u> </u> | Opens the maximum delay analysis view. | | <u></u> | Opens the minimum delay analysis view. | | <u>@</u> | Opens the manage clock domains manager. | | X | Opens the path set manager. | | <b>⊘</b> | Recalculates all analyses. | # 6. SmartTime Timing Analyzer (Ask a Question) The following sections describe the SmartTime Timing Analyzer functions. #### **6.1.** SmartTime Analyzer Components (Ask a Question) SmartTime Timing Analyzer consists of the following components: - Domain Browser: Alows you to perform your timing analysis on a per domain basis. - Path List: Shows paths in a specific set within a given domain sorted by slack. - Path Details: Shows detailed timing analysis of a selected path in the paths list. - Analysis View Filter: Allows you to filter the content of the paths list. - Path Slack Histogram: When a set is selected in the Domain Browser, Path Slack Histogram shows a distribution of the path slacks for that set. Selecting one or multiple bars in the Path Slack Histogram filters the paths shown in the Path List. The following figure shows the SmartTime Timing Analyzer Components. You can copy and change the resolution and number of bars of the chart from the right-click menu. Figure 6-1. SmartTime Timing Analyzer Components #### 6.2. Analyzing Your Design (Ask a Question) The timing engine uses the following priorities when analyzing paths and calculating slack: - 1. False path - 2. Max/Min delay - 3. Multi-cycle path - 4. Clock If multiple constraints of the same priority apply to a path, the timing engine uses the tightest constraint. You can perform two types of timing analysis: Maximum Delay Analysis Minimum Delay Analysis To perform the basic timing analysis, use one of the following methods to open the Timing Analysis View: - From the SmartTime **Tools** menu, choose **Timing Maximum Delay Analysis** or **Minimum Delay Analysis**. - From the SmartTime window, click the icon for Maximum Delay Analysis or the icon for Minimum Delay Analysis. **Note:** When you open the Timing Analyzer from Designer, the Maximum Delay Analysis window appears by default. #### 6.3. Maximum Delay Analysis View (Ask a Question) To enter Maximum Delay Analysis View: - 1. In the Domain Browser, select the clock domain. Clock domains with a → indicate that the timing requirements in these domains were met. Clock domains with an x indicate that there are violations within these domains. **Paths List** shows the timing paths sorted by slack. The path with the lowest slack (biggest violation) is at the top of the list. - 2. Select the path you want to view. **Path Details** below the **Paths List** shows detailed information about how the slack was computed by detailing the arrival time and required time calculation. If a path is violated, the slack is negative and shown in red. - 3. To display a separate view that includes the path details and schematic, double-click the path. - 4. Repeat this procedure as necessary. **Note:** If the minimum pulse width of one element on the critical path limits the maximum frequency for the clock, an icon for the clock name appears in the **Summary List**. Clicking the icon displays the name of the pin that limits the clock frequency. # 6.4. Managing Clock Domains (Ask a Question) In SmartTime, timing paths are organized by clock domains. By default, SmartTime displays domains with explicit clocks. Each clock domain includes at least three path sets: - Register to Register - External Setup (in the Maximum Analysis View) or External Hold (in the Minimum Analysis View) - Clock to Out You must select a path set to display a list of paths in that specific set. To manage the clock domains: 1. Right-click anywhere in the Domain Browser and choose **Manage Clock Domains**. The Manage Clock Domains dialog box appears. **Tip:** You can click the icon in the SmartTime window bar to display the Manage Clock Domains dialog box. 2. To add a new domain, select a clock domain from the **Available clock domains** list and click **Add**. To add a non-explicit clock domain, click **New Clock**. The Choose the Clock Source Pin dialog box appears, and you can select the clock source pin. You can choose to filter the available pins and search. Figure 6-2. Choose the Clock Source Pin Dialog Box - 3. To remove a displayed domain, select a clock domain from the **Show the clock domains in this order** list and click **Remove**. - 4. To change the display order in the Domain Browser, select a clock domain from the **Show the clock domains in this order** list, and then use **Move Up** or **Move Down** to change the order in the list. - 5. Click **OK**. SmartTime updates the Domain Browser based on your specifications. If you added a new clock domain, it includes at least three path sets, as mentioned in the preceding step. ## 6.5. Managing Path Sets (Ask a Question) You can create and manage custom path sets for timing analysis and tracking purposes. Path sets appear below **Custom Path Sets** at the bottom of the Domain Browser. To manage path sets: 1. Right-click anywhere in the Domain Browser and choose **Add Set**. The Add Path Analysis Set dialog box appears. **Tip:** You can click the icon in the SmartTime window bar to display the Add Path Analysis Set dialog box. Figure 6-3. Add Path Analysis Set Dialog Box - 2. Enter a name for the path set. - 3. Select the source and sink pins. You can use the Using Filters to control the type of pins displayed. - 4. Click **OK**. The new path set appears below **User Sets** in the Domain Browser. Figure 6-4. Updated Domain Browser with User Sets #### 5. To rename a path: - a) Select the path set from **User Sets** in the Domain Browser. - b) Right-click the set you want to rename, and then choose **Rename Set** from the right click menu. - c) Edit the name directly in the Domain Browser. - 6. To remove a path: - a) Select the path set from **User Sets** in the Domain Browser. - b) Right-click the set you want to delete, and then choose **Delete Set** from the right click menu. #### 6.6. Displaying Path List Timing Information (Ask a Question) Path List in the Timing Analysis View shows the timing information required to verify the timing requirements and identify violating paths. The Path List is organized in a grid where each row represents a timing path with the corresponding timing information displayed in columns. Timing information is customizable, allowing you to add or remove columns for each type of set. By default, each type of set displays the following subset of columns: - Register to Register: Source Pin, Sink Pin, Delay, Slack, Arrival, Required, Setup, Minimum Period, and Skew. - External Setup: Source Pin, Sink Pin, Delay, Slack, Arrival, Required, Setup, and External Setup. - Clock to Out: Source Pin, Sink Pin, Delay, Slack, Arrival, Required, and Clock to Out. - Input to Output: Source Pin, Sink Pin, Delay, and Slack. - Custom Path Sets: Source Pin, Sink Pin, Delay, and Slack. You can add the following columns for each type of set: - Register to Register: Clock, Source Clock Edge, Destination Clock Edge, Logic Stage Count, Max Fanout, Clock Constraint, Maximum Delay Constraint, and Multicycle Constraint. - External Setup: Clock, Destination Clock Edge, Logic Stage Count, Max Fanout, Clock Constraint, Input Delay Constraint, Required External Setup, Maximum Delay Constraint, and Multicycle Constraint. - Clock to Out: Clock, Source Clock Edge, Logic Stage Count, Max Fanout, Clock Constraint, Output Delay Constraint, Required Maximum Clock to Out, Maximum Delay Constraint, and Multicycle Constraint. - Input to Output: Arrival, Required, Setup, Hold, Logic Stage Count, and Max Fanout. - Custom Path Sets To customize the set of timing information in the Path List: 1. Choose **Customize table** on the top-left corner of path list to open the Customize Paths List Table dialog box. Figure 6-5. Customize Paths List Table Dialog Box - 2. To add one or more columns, select the fields to add from the Available fields list and click Add. - 3. To remove one or more columns, select the fields to remove from the **Show these fields in this order** list, and click **Remove**. - 4. To change the order in which the fields appear, select fields in the **Show these fields in this order** list and click **Move Up** or **Move Down**. - 5. Click **OK** to add or remove the selected columns. SmartTime updates the Timing Analysis View. # 6.7. Displaying Expanded Path Timing Information (Ask a Question) SmartTime displays the list of paths and path details for all parallel paths. The Path Details grid displays the path details for all parallel paths. The Path List displays all parallel paths in your design. Figure 6-6. Path List View To display the Expanded Path View: - 1. From the Path List, double-click the path, or right-click a path and select **expand selected paths**. - 2. From the Expanded Path View, double-click the path, or right-click the path and select **expand path**. Figure 6-7. Expanded Path View The Expanded Path Summary provides a summary of all parallel paths for the selected path. The Path Profile chart shows the percentage of time taken by cells and nets for the selected path. If no parallel path is selected in this view, the Path Profile shows the percentage for all paths. By default, SmartTime shows only one path for each Expanded Path. To change this default, use the SmartTime Options dialog box. The Expanded Path View includes a schematic of the path and a path profile chart for the paths selected in the Expanded Path Summary. #### 6.8. Using Filters (Ask a Question) You can use filters in SmartTime to limit the Path List content (that is, create a filtered list on the source and sink pin names). Filtering options appear at the top of the Timing Analysis View. You can save these filters one level below the set under which they have been created. To use the filter: - 1. Select a set in the Domain Browser to display a given number of paths, depending on your SmartTime Options settings (100 paths by default). - 2. Enter the filter criteria in both the From and To fields, and then click **Apply Filter**. The display limits the paths to those that match your filter criteria. Figure 6-8. Maximum Delay Analysis View 3. Click **Store Filter** to save your filter criteria with a special name. The Create Filter Set dialog box appears. Figure 6-9. Create Filter Set Dialog Box 4. Enter a name for the filter, such as myfilter01, and click **OK**. Your new filter name appears below the set under which it was created. Figure 6-10. Specifying the Filter my\_filter01 - 5. Repeat this procedure to cascade as many sets as you need using the filtering mechanism. - 6. To edit a filter in the set: - a) Select the filter you want to edit. - b) Right-click the filter and choose **Edit Set** from the shortcut menu. - 7. To rename a set created with filters: - a) Select the set that uses filters. - b) Right-click the set, and choose **Rename Set** from the shortcut menu. - c) Edit the name directly in the Domain Browser. # 7. Advanced Timing Analysis (Ask a Question) The following sections describe advanced timing analysis. #### 7.1. Understanding Inter-Clock Domain Analysis (Ask a Question) When functional paths exist across two clock domains (the register launching the data and the one capturing it are clocked by two different clock sources), you must provide accurate specification of both clocks to allow a valid inter-clock domain timing check. This is important especially when the clocks are specified with different waveforms and frequencies. When inter-clock domain paths exist in your design, consider whether setup and hold analysis needs to be performed. Inter-clock domain analysis is controlled from the SmartTime options, as shown in Activating Inter-Clock Domain Analysis section, and is enabled by default. When enabled, SmartTime performs setup and hold checks between the clock domains unless a false path or asynchronous clock group constraint has been applied. When disabled, the tool does not perform the setup and hold checks. If you have several clock domains that are subset of a single clock (for example, if you want to measure clock tree delay from an input clock to a generated clock), you must configure Generated Clock Constraints for each of the clock domains in order for SmartTime to execute the calculation, and show timing for each of the inter-clock domain paths. Once you include the inter-clock domains for timing analysis, SmartTime analyzes, for each inter-clock domain, the relationship between all the active clock edges over a common period equal to the least common multiple of the two clock periods. The new common period represents a full repeating cycle (or pattern) of the two clock waveforms, as shown in the following figure. Figure 7-1. New Common Period For setup check, SmartTime considers the tightest relation launch-capture to ensure that the data arrives before the capture edge. The hold check verifies that a setup relationship is not overwritten by a following data launch. # 7.2. Activating Inter-Clock Domain Analysis (Ask a Question) To activate the inter-clock domain checking: - From the SmartTime Tools menu, choose Options. The SmartTime Options dialog box appears, as shown in the following figure. - 2. In the **General** category, check **Include inter-clock domains in calculations for timing analysis**. Figure 7-2. SmartTime Options Dialog Box for SmartFusion 2, RTG4 , and IGLOO 2 **Figure 7-3.** SmartTime Options Dialog Box for PolarFire ® 3. Click **OK** to save the dialog box settings. #### 7.3. Displaying Inter-Clock Domain Paths (Ask a Question) After you activate the inter-clock domain checking for a given clock domain CK1, SmartTime detects automatically all other domains CKn with paths ending at CK1. SmartTime creates inter-clock domain sets CKn to CK1 under the domain CK1. Each set allows you to display the inter-clock domain paths between a given clock domain and CK1. To display an inter-clock domain set: 1. Expand the receiving clock domain of the inter-clock domain in the Domain Browser to display its related sets. For the inter-clock domain CK1 to CK2, expand clock domain CK2. Figure 7-4. Expanding the Inter-Clock Domain Select the inter-clock domain you want to expand from these sets. All paths between the related two domains are displayed in Paths List in the same way as any register to register set. # 7.4. Deactivating a Specific Inter-Clock Domain (Ask a Question) To deactivate the inter-clock domain checking for the specific clock domains clk2->clk1, without disabling this option for the other clock domains: - 1. From the **Tools** menu, choose **Constraints Editor > Primary Scenario** to open the Constraints Editor View. - 2. In the Constraints Browser, double-click **False Path** under **Exceptions**. The Set False Path Constraint dialog box appears. - 3. Click the **Browse** button to the right of the **From** text box. The Select Source Pins for False Path Constraint dialog box appears. - 4. For Specify pins, select by keyword and wildcard. - 5. For **Pin Type**, select **Registers by clock names** from the **Pin Type** drop-down list. - 6. In the filter box, type the inter-clock domain name (for example, Clk2), and then click **Filter**. - 7. Click **OK** to begin filtering the pins by your criteria. - In this example, [get\_clocks {Clk2}] appears in the **From** text box in the Set False Path Constraint dialog box. - 8. Repeat steps 3 to 7 for the **TO** option in the Set False Path Constraint dialog box and type Clkl in the filter box. - 9. Click **OK** to validate the new false path and display it in the Paths List of the Constraints Editor. - 10. Click the Recalculate All icon in the toolbar. - 11. Select the inter-clock domain set clk2 -> clk1 in the Domain Browser. - 12. Verify that the set does not contain any paths. #### 7.5. Changing Output Port Capacitance (Ask a Question) Output propagation delay is affected by both the capacitive loading on the board and the I/O standard. The I/O Attribute Editor in Chip Planner provides a way to set the expected capacitance to improve the propagation delay model. SmartTime uses the modified delay model automatically for delay calculations. To change the output port capacitance and view the effect of this change in SmartTime Timing Analyzer, see the following example. The following figure shows a delay of 6.603 ns from DFN1 to output port Q based on the default loading of 5 pF. Figure 7-5. Maximum Delay Analysis View If your board has an output capacitance of 15 pf on Q, perform the following steps to update the timing number. 1. Open the I/O Attribute Editor and change the output load to 15 pf. Figure 7-6. I/O Attribute Editor - 2. Select File > Save. - 3. Select File > Close. - 4. Open the SmartTime Timing Analyzer and confirm that the **Clock to Output** delay changed to 5.952 ns. # 8. Generating Timing Reports (Ask a Question) The following sections describe how to generate timing reports. # 8.1. Types of Reports (Ask a Question) The following table lists the types of timing reports you can generate using SmartTime. Table 8-1. Types of Timing Reports | Report | Description | |------------------------------|----------------------------------------------------------------------------------------------------------------------------| | Timer Report | Displays the timing information organized by clock domain. | | Timing Violations Report | Provides information about constraint violations. | | Bottleneck Report | Displays points in the design that contribute to the most timing violations. | | Datasheet Report | Describes the characteristics of the pins, I/O technologies, and timing properties in the design. | | Constraints Coverage Report | Displays the overall coverage of the timing constraints set on the current design. | | Combinational Loop Report | Displays loops found during initialization. | | Clock Domain Crossing Report | Analyzes timing paths that cross from one clock domain (the source clock) to another clock domain (the destination clock). | ## 8.2. Generating a Timing Report (Ask a Question) The Timing Report allows you to determine whether timing problems exist in your design. The Maximum Delay Analysis Timing Report lists the following information about your design: - Maximum delay from input I/O to output I/O - Maximum delay from input I/O to internal registers - Maximum delay from internal registers to output I/O - Maximum delays for each clock network - Maximum delays for interactions between clock networks To generate a Timing Report: - From the SmartTime Max/Min Delay Analysis View, choose Tools > Reports > Timer. The Timing Report Options dialog box appears. - 2. Select the options you want to include in the report, and then click **OK**. The Timing Report appears in a separate window. #### 8.3. Understanding Timing Reports (Ask a Question) The following table lists the sections in the Timing Report. Table 8-2. Timing Report Sections | Section | Description | | |---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | Header | Lists the: | | | | Report type | | | | Version of Designer used to generate the report | | | | Date and time the report was generated | | | | General design information (name, family, and so on) | | | Summary | Reports the timing information for each clock domain. By default, the clock domains reported are the explicit clock domains that are shown in SmartTime. To filter the domains and show only specific sections in the report, use the Timing Report Options dialog box. | | | Table 8-2. Timing Report Sections (continued) | | | |-----------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | Section | Description | | | Path | Lists the timing information for different types of paths in the design. This section is reported by default. You can deselect this option in the Timing Report Options dialog box. By default, the number of paths displayed per set is 5. You can filter the domains using the Timing Report Options dialog box. You can also view the stored filter sets in the generated report using the Timing Report options. The filter sets are listed by name in their appropriate section. The number of paths reported for the filter set is the same as for the main sets. By default, the filter sets are not reported. | | #### 8.3.1. Clock Domains (Ask a Question) Paths are organized by clock domain. #### 8.3.2. Register to Register Set (Ask a Question) This set reports the paths from the registers clock pins to the registers data pins in the current clock domain. #### 8.3.3. External Setup Set (Ask a Question) This set reports the paths from the top-level design input ports to the registers in the current clock domain. #### 8.3.4. Clock to Output Set (Ask a Question) This set reports the paths from the registers clock pins to the top-level design output ports in the current clock domain. #### 8.3.5. Register to Asynchronous Set (Ask a Question) This set reports the paths from registers to asynchronous control signals, such as asynchronous set/reset. #### 8.3.6. External Recovery Set (Ask a Question) This set reports the external recovery check timing for asynchronous control signals, such as asynchronous set/reset. #### 8.3.7. Asynchronous to Register Set (Ask a Question) This set reports the paths from asynchronous control signals, such as asynchronous set/reset, to registers. #### 8.3.8. Inter-clock Domain (Ask a Question) This set reports the paths from the registers clock pins of the specified clock domain to the registers data pins in the current clock domain. Inter-domain paths are reported by default. #### 8.3.9. Pin to Pin (Ask a Question) This set lists input to output paths and user sets. Input-to-output paths are reported by default. To see the user- defined sets, use the Timing Report Options dialog box. #### 8.3.10. Input to Output Set (Ask a Question) This set reports the paths from the top-level design input ports to the top-level design output ports. #### 8.3.11. Expanded Paths (Ask a Question) Expanded paths can be reported for each set. By default, the number of expanded paths to report is set to 1. You can select and change the number when you specify Timing Report options. Figure 8-1. Timing Report ## 8.4. Generating a Timing Violation Report (Ask a Question) The Timing Violations Report provides a Flat Slack Report centered around constraint violations. To generate Timing Violations Report: 1. From the SmartTime Max/Min Delay Analysis View window, choose **Tools > Reports > Timing Violations**. The Timing Violations Report Options dialog box appears. 2. Select the options you want to include in the report, and then click **OK**. The Timing Violations Report appears in a separate window. #### 8.5. Understanding Timing Violation Reports (Ask a Question) The following figure shows an example of a Timing Violations Report. Figure 8-2. Sample Timing Violation Report The following table lists the sections in the Timing Violation Report. Table 8-3. Timing Violation Report Sections | Section | Description | |---------|------------------------------------------------------| | Header | This section lists the: | | | Report type | | | Version of Designer used to generate the report | | | Date and time the report was generated | | | General design information (name, family, and so on) | | Table 8-3. Timing Violation Report Sections (continued) | | | |---------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | Section | Description | | | Paths | This section lists the timing information for different types of paths in the design. The number of paths displayed is controlled by the following parameters: • A maximum slack threshold to report | | | | · | | | | A maximum number or path to report | | | | By default, the slack threshold is 0 and the number of paths is limited. The default maximum number of paths reported is 100. All clocks domains are mixed in this report. The paths are listed by decreasing slack. | | | | You can also choose to expand one or more paths. By default, no paths are expanded. For details, see the Timing Violation Report options. | | #### 8.6. Generating a Constraints Coverage Report (Ask a Question) The Constraints Coverage Report contains information about the constraints in the design. To generate a Constraints Coverage Report: - 1. From the SmartTime Max/Min Delay Analysis View, choose **Tools > Reports > Constraints Coverage**. - 2. Select the text format and number of unconstrained instances and click **OK**. The report appears in a separate window. ## 8.7. Understanding Constraints Coverage Reports (Ask a Question) The Constraints Coverage Report shows the overall coverage of the timing constraints set on the current design. You can generate this report either from within Designer or within SmartTime Analyzer. Figure 8-3. Sample Constraints Coverage Report The following table lists the sections in the Constraints Coverage Report. Table 8-4. Constraints Coverage Report Sections | Section | Description | |-------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Coverage Summary | Shows statistical information about the timing constraint in the design. For each type of timing checks (Setup, Recovery, Output, Hold, and Removal), it specifies how many are Met (there is a constraint and it is satisfied), Violated (there is a constraint and it is not satisfied), or Untested (no constraint was found). | | Results by Clock Domain | This section provides a coverage summary for each clock domain. | | Enhancement Suggestions | Reports, per clock domain, a list of constraints that can be added to<br>the design to improve the coverage. It also reports if some options<br>impacting the coverage can be changed. | | Table 8-4. Constraints Coverage Report Sections (continued) | | |-------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------| | Section | Description | | Detailed Stats | Provides detailed suggestions about specific clocks or I/O ports that may require to be constrained for every pin/port that requires checks. | #### 8.8. Generating a Bottleneck Report (Ask a Question) To generate a Bottleneck Report: From the SmartTime Max/Min Delay Analysis View, choose **Tools > Reports > Bottleneck**. The report appears in a separate window. # 8.9. Understanding Bottleneck Reports—SmartFusion 2, IGLOO 2, RTG4, and PolarFire (Ask a Question) A bottleneck is a point in the design that contributes to multiple timing violations. The Bottleneck Report lists the bottlenecks in the design. You can generate this report from SmartTime Analyzer. **Notes:** The bottleneck can be computed only when a cost type is defined. There are two cost type options available: - **Path count**: Associates the severity of the bottleneck to the count of violating/critical paths that traverse the instance. - **Path cost**: Associates the severity of the bottleneck to the sum of the timing violations for the violating/critical paths that traverse the instance. Figure 8-4. Sample Bottleneck Report The following table lists the sections in the Bottleneck Report. Table 8-5. Bottleneck Report Sections | Part | Description | |------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------| | Device Description | Contains general information about the design, including: | | | Design name | | | • Family | | | • Die | | | • Package | | | Software version | | Bottleneck Analysis Lists the core of the bottleneck information. It is organized int columns: | | | | Instance Name: Refers to the output pin name of the instance. | | | Path Count: Shows the number of violating paths that include the instance pin. | #### 8.10. Generating a Datasheet Report (Ask a Question) The Datasheet Report shows information about a design's external characteristics. To generate a Datasheet Report: 1. From the SmartTime Max/Min Delay Analysis View, choose **Tools > Reports > Datasheet**. The report appears in a separate window. # 8.11. Understanding Datasheet Reports (Ask a Question) The Datasheet Report displays the external characteristics of the design. You can generate this report from SmartTime Max/Min Delay Analysis View. Figure 8-5. Sample Datasheet Report The following table lists the tables in the Datasheet Report. Table 8-6. Datasheet Report Tables | Table | Description | |-------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Pin Description | Provides the port name in the netlist, location on the package, type of port, and I/O technology assigned to it. Types can be input, output, or clock. Clock ports are ports shown as "clock" in the Clock domain browser. | | DC Electrical Characteristics | Provides the parameters of the different I/O technologies used in the design. The number of parameters displayed depends on the family for which you have created the design. | | AC Electrical Characteristics | Provides the timing properties of the design ports For each clock, this section includes the maximum frequency. For each input, it includes the external setup, external hold, external recovery, and external removal for every clock where it applies. For each output, it includes the clock-to-out propagation time. This section also displays the input-to-output propagation time for combinational paths. | #### 8.12. Generating a Combinational Loop Report (Ask a Question) The Combinational Loop Report shows all loops found during initialization and reports pins associated with the loop(s) and the location where a loop is broken. To generate a Combinational Loop Report: - 1. From the **Tools** menu, choose **Reports > Combinational Loops**. The Combinational\_Loops Report Options dialog box appears. - 2. Select either Plain Text or Comma Separated Values. - 3. Click OK. #### 8.13. Understanding Combinational Loop Reports (Ask a Question) The Combinational Loop Report shows all loops found during initialization, reports the pins associated with the loops, and identifies the locations where loops are broken. Figure 8-6. Sample Combinational Loop Report ## 8.14. Generating a Clock Domain Crossing (CDC) Report (Ask a Question) The Clock Domain Crossing (CDC) Report analyzes timing paths that cross from one clock domain (the source clock) to another clock domain (the destination clock). The CDC Report helps identify instances where there may be data loss or metastability issues. To generate the CDC Report: - From the Tools menu, choose Reports > Clock Domain Crossing (CDC).. The Clock Domain Crossing Report Options dialog box appears. - 2. Select either CDC Table or Comma Separated Values. - 3. Click OK. Selecting **CDC Table** displays a graphical table with color-coded cells. Each cell represents a CDC type between the source clock and the destination clock domains that have constraints. Clocks without constraints do not appear in the CDC table. Figure 8-7. Graphical Table of CDC Types The attributes present in the path table are as follows: - Source Clock: Source of the clock - Destination Clock: Destination of the clock - Worst Slack (ns): Worst slack of the CDC path in nanoseconds - Worst Slack Edge: Source/sink edge for the worst path of CDC - Max Delay Cstr: See the following table. | Value | Description | |---------|----------------------------------------------| | Yes | All paths in CDC have set_max_delay applied | | No | No paths in CDC have the constraints applied | | Partial | Any path in CDC has the constraint applied | Multicycle Path Cstr: see the following table. | Value | Description | |-------|---------------------------------------------------| | Yes | All paths in CDC have set_multicycle_path applied | | No | Value | Description | |----|---------|----------------------------------------------| | | No | No paths in CDC have the constraints applied | | | Partial | Any path in CDC has the constraint applied | Clock Group Cstr: See the following table. | Value | Description | |-------|-------------------------------------------| | Yes | CDC has set_clock_group applied | | No | CDC does not have set_clock_group applied | - Clock Uncertainty Cstr: Uncertainty value for the worst path in CDC; otherwise, the clock uncertainty field is left empty. - Num of Paths: Number of paths in CDC. For User Ignored paths, the value is 0. - Clock Pair Status: Status can be Timed Safe, Timed Unsafe or User Ignored. In the CDC Report dialog box, you can select the clocks to view or hide. Clicking the **Clock Selection** button at the top left of the dialog box lists all clocks that can be viewed or hidden. By default, all clocks are checked and visible. To hide a clock, clear its check box. Figure 8-8. Showing or Hiding Clocks The following table describes the colors in the CDC Report shown in the preceding figure. Table 8-7. Definition of Colors in the CDC Report | Pattern | Status | Color | |----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------|------------| | Paths from the source clock domain to the destination clock domain have all been disabled by false path or clock group constraints. | User-Ignored Paths | Light blue | | No Paths found from the source clock domain to the destination clock domain. | No Paths | Gray | | The source and destination clocks are synchronous: Both the clocks have a common primary clock and paths are found from the source clock domain to the destination clock domain. | Timed | Dark Blue | | Synchronizers have been identified on all paths between source and destination clocks. | Synchronized | Orange | There are certain scenarios related to the path table as explained in the following: 1. When CDC Report is generated, path table is shown by default for all CDC having paths. Each row shows the worst slack for a clock crossing. Similarly, when clicking on a particular CDC crossing in CDC Report, you can have a single row showing the worst slack for CDC crossing. Example: The path table shown in the following figure, the worst path for reg\_com\_clk\_10mhz to reg\_com\_clk\_5mhz has the worst slack of 93.541. The same path is displayed by default, when the CDC crossing is selected. Figure 8-9. Worst Path with Slack 93.541 ns Figure 8-10. Smarttime Showing the Worst Path with Slack 93.541 ns 2. Clicking on the CDC box shows the worst slack for a clock crossing as in path table in the following figure. Figure 8-11. Highlighted CDC Box Showing the Worst Slack in Path Table Clicking on the same CDC box again shows details for all the clocks selected in the CDC Report. > Clock Selection en\_clk\_12p5ml \_/pll\_inst\_0/OUTc \_/pll\_inst\_0/OUTc | \_/pll\_inst\_0/O gen\_clk\_12p5mhz .../pll\_inst\_0/OUT0 .../pll\_inst\_0/OUT1 asyn\_reg\_clk clk\_input\_100mhz clk\_input\_25mhz No Path Timed (Unsafe) Worst Slack Edge Multicycle Path Cstr Clock Group Cstr Clock Uncertainty Cstr Source Clock Destination clock PF\_CCC\_CO\_0/PF\_CCC... PF\_CCC\_CO\_0/PF\_CCC. 23.459 RR No 0.500 1 Timed safe PF\_CCC\_CO\_0/PF\_CCC... PF\_CCC\_CO\_0/PF\_CCC. 1 Timed safe 3.928 clk\_input\_100mhz clk\_input\_25mhz Yes 0 User Ignored clk\_input\_100mhz clk\_input\_50mhz Yes 0 User Ignored Figure 8-12. CDC Path Table Showing All Clocks on Deselecting the Selected CDC Box For all clocks having large names, tool-tips for columns have been added. Figure 8-13. CDC Path Table Showing Tool-Tip for a Source Clock Name | Source Clock | Destination clock | Worst Slack<br>(ns) | | | |--------------------|---------------------------|---------------------|--|--| | PF_CCC_C0_0/PF_CCC | . PF_CCC_C0_0/PF_CCC | 23.459 | | | | PF_CCC_PF_CCC_CO_0 | PF_CCC_C0_0/pll_inst_0/OU | 3.928 | | | | clk_input_100mhz | clk_input_25mhz | | | | 3. Selecting/deselecting clocks in clock selection dynamically changes the path table along with the CDC table. Both the tables are in sync. Example: Here, clk\_input\_100mhz is selected, therefore, the clock is displayed in CDC table and path table. Figure 8-14. CDC Table in Sync with Clock Selection Section When the clock clk\_input\_100mhz is unselected, then the same clock is removed from the CDC table. The crossings related to the clock are also removed from the path table as shown in the following figure. Destination Clocks < Clock Selection i\_clk\_12p5r | sll\_inst\_0/OU | sll\_inst\_0/OU | isyn\_reg\_cli |:\_input\_25m | com\_clk\_10 |:\_input\_50m | com\_clk\_5r | gen clk 12p5mhz \_/pll\_inst\_0/OUT0 \_/pll\_inst\_0/OUT1 asyn\_reg\_clk clk\_input\_25mhz reg\_com\_clk\_10mhz Legend No Path User Ignored Paths Timed (Unsafe) Clock Group Cstr Clock Uncertainty Cstr Source Clock Destination clock PF\_CCC\_CO\_0/PF\_CCC... PF\_CCC\_CO\_0/PF\_CCC... 23.459 RR No No 0.500 1 Timed safe PF CCC CO O/PF CCC ... PF CCC CO O/PF CCC. 3.928 RR No No 1 Timed safe clk\_input\_25mhz clk\_input\_50mhz Yes clk\_input\_50mhz clk\_input\_25mhz Yes 0 User Ignored Figure 8-15. Deselecting a Clock in Clock Selection Section Syncs the Path Table Accordingly After clicking any one of the four options in the CDC category, the clock table is filtered according to the CDC category selected. In the following scenario, the Timed button has been selected and Timed safe CDC is displayed only in the clock table. Figure 8-16. CDC Report When Timed Button is Selected in CDC Category Clicking on the same CDC category shows the details for all the clocks selected in CDC Report. Selecting/unselecting clocks in clock selection does dynamically change the clock table along with the CDC table. In the following figure, the User Ignored CDC category button is chosen and clk\_input\_100mhz is selected. Therefore, the clock is displayed in CDC table and clock table. Now, when clock clk\_input\_100mhz is unselected, the same clock is moved from CDC table and the crossings related to that clock are also removed from clock table. Therefore, when the User Ignored CDC category is selected, entries related to clk\_input\_100mhz are not visible. After right-clicking a CDC box, you can choose to **Copy**, **Add a Clock Group Constraint** or **Go to Timing Explorer**. Figure 8-17. CDC Report with Go to Timing Explorer Option Selecting the **Go to Timing Explorer** option opens the Timing Explorer dialog box. Figure 8-18. Timing Report Explorer There are corner scenarios when cross probing between CDC and Timing Explorer: #### Scenario 1: This is a scenario where difference is seen between SmartTime and Verify timing, when two clocks are defined on same port and when cross probing for CDC reg\_com\_clk\_10mhz and reg\_com\_clk\_5mhz is unable to find the same in Timing Report Explorer. The constraints are as follows: ``` create_clock -name {reg_com_clk_10mhz} -period 100 -waveform {0 50 } [ get_ports { reg_com_clk_10mhz } ] create_clock -name {reg_com_clk_5mhz} -period 200 -waveform {0 100 } -add [ get_ports { reg_com_clk_10mhz } ] ``` The Timing Report Explorer does not pick reg\_com\_clk\_5mhz as destination clock, and Smart time does pick the reg\_com\_clk\_10mhz and reg\_com\_clk\_5mhz pair as CDC, as shown in the following figure. Figure 8-19. Timing Report Explorer Snapshot - 1 Figure 8-20. Timing Report Explorer Snapshot - 2 Figure 8-21. SmartTime Snapshot Timing Explorer is picking the worst slack path for a pair of start and end point. Therefore, you can miss CDC and other reg to reg paths with lower slack values. #### Scenario 2: This is a scenario where due to different operating conditions set in Smart Time, you can have different results, when cross probing between CDC and Timing Report Explorer. SmartTime and CDC are in sync. Figure 8-22. Worst Slack of 97.958 ns in Timing Report Explorer Figure 8-23. Worst Slack of 98.154 ns in SmartTime Figure 8-24. Operating Conditions The Timing Report Explorer reports the path from slow\_lv\_lt, and SmartTime reports using the operating condition fast\_hv\_lt. When the operating condition in SmartTime is changed to slow\_lv\_lt, the worst slack becomes the same as in the Timing Report Explorer. Figure 8-25. Slack After Changing the Operating Condition to slow\_lv\_lt CDC Reports worst path for a particular corner selected in SmartTime, and Timing Report Explorer reports the worst path across all the corners. In such cases, you can see changes in values when navigating from CDC to Timing Report Explorer. To make you aware of such situations, Corner Info column is added to display the operating conditions. #### Note: - The path details for the same clock crossing (C1 to C1) are not shown in the path tale as they are not valid clock crossings and are currently shown as timed safe by default in CDC Report. - The clock table has CDC details only related to clocks checked in clock selection from CDC Report. - Path table will not show any CDC having no paths. - For User Ignored CDC columns, "Worst Slack (ns)", "Worst Slack Edge", "Max Delay Cstr", "Multicycle Path Cstr", and "Clock Uncertainty Cstr" are empty. - Cross probing is allowed to Timing Report Explorer for the same clock crossing (C1 to C1). - For User Ignored CDC category, Corner Info column is empty. Selecting **Comma Separated Value** exports the CDC Report to a CSV file. If you select this option, a window appears in which you assign a name to the CSV file and specify the location where it will be exported. The CSV file shows details about the CDC between each clock domain in numeric format. Each CDC type is represented as a number similar to colors in the table. The CSV file includes an explanation of each number type and CDC type. ## Figure 8-26. Sample CSV Report | A COLUMN TO COLU | | | 9 | | | 9. | H | | - 1 | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------|----------------------------------------|----------------------------------------|-------------|----------------|-------------------|------------------|----------------|----------------| | SmartTime Version v12.4 | | | | | | | | | | | Microsemi Corporation - Microsomi Libero Software Release v12.4 (Version 12.900.8.1) | | | | | | | | | | | Date: Wed Mar 21 23:48:02 2020 | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Design: | test | | | | | | | | | | Family | PolarFire | | | | | | | | | | Die | MOYDOOT | | | | | | | | | | Package | PCG484 | | | | | | | | | | Tomperature Kange | 0 - 100 C | | | | | | | | | | Vollage Range | 0.97-1.03 V | | | | | | | | | | Speed Grade | | | | | | | | | | | Design State | Post-Cayout | | | | | | | | | | Cata source | Production | | | | | | | | | | Operating Conditions | slow_br_ht | | | | | | | | | | Scenario for Tening Analysis | Clock Domain Crossings | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Source Clocks / Destination Clocks | gen ck 12stmic | PF CCC CO GIFF CCC CO G/o/I Hub G/DUTO | PF GOC CD G/PF CCC CD G/s/R HIS G/GUTS | may reg clk | sk rout 200m/s | clk input. 25mly. | reg com dk 10mhs | ck input 50mhs | reg com ck 5rd | | gen, ck. 12p6enhz | Timed | No Path | No Path | | | Timed | No Peth | User Ignored | No Peth | | of ccc co gipt ccc co gips wat groute | No Path | Tirsed | User ignored | No Futh | No Path | No Path | No Path | No Path | No Path | | OF CCC CO SIPP CCC CO CIDE INC SIGNETS | No Path | User Ignored | Timed | No Futh | No Purh | No Path | No Path | No Path | No Path | | anya_rag_clk | No Path | No Path | No Path | Tiened | No Purb | No Path | No Park | No Park | No Fath | | clic_input_100mAs | Tirned (uncafe) | No Fath | No Path | No Fush | Timed | Timed (uncafe) | No Path | User Ignored | No Fath | | cli_max_25mla | User Ignored | No Path | No Path | No Fush | (Imed (unsafe) | Timed | No Path | User ignored | No Path | | reg_com_ck_10mhe | No Path | No Path | No Path | No Path | No Path | No Poth | Timed | Ne Path | Temed (unsefe) | | clk input 50mly | No Path | No Pach | Nu Path | No Peth | Asp Path | User Ignored | No Path | Timed | No Path | | reg com cik 5mbc | No Path | No Path | No Path | No Path | No Path | No Path | Timed (unsafe) | No Pach | Timed | # 9. Timing Concepts (Ask a Question) The following sections describe timing concepts associated with the RTG4 FPGA Clock Conditioning Circuit with PLL configuration. ## 9.1. Static Timing Analysis Versus Dynamic Simulation (Ask a Question) Static Timing Analysis (STA) offers an efficient technique for identifying timing violations in your design and ensuring that it meets all your timing requirements. You can communicate timing requirements and timing exceptions to the system by setting timing constraints. Then a static timing analysis tool checks and reports setup, and holds violations and violations on specific path requirements. STA is well suited for traditional synchronous designs. The main advantage of STA is that, unlike dynamic simulation, it does not require input vectors. It covers all possible paths in the design and does all the above with relatively low run-time requirements. The major disadvantage of STA is that the STA tools do not automatically detect false paths in their algorithms. ## 9.2. Delay Models (Ask a Question) The first step in timing analysis is the computation of single component delays. These components can be either a combinational gate or block or a single interconnect connecting two components. Gates that are part of the library are pre-characterized with delays under different parameters, such as input-slew rates or capacitive loads. Traditional models provide delays between each pair of I/Os of the gate and between rising and falling edges. The accuracy with which interconnect delays are computed depends on the design phase. These can be estimated using a simple Wire Load Model (WLM) at the pre-layout phase or a more complex Resistor and Capacitor (RC) tree solver at the post-layout phase. # 9.3. Timing Path Types (Ask a Question) Path delays are computed by adding delay values across a chain of gates and interconnects. SmartTime uses this information to check for timing violations. Traditionally, timing paths are presented by static timing analysis tools in four categories or "sets." - Paths between sequential components internal to the design: SmartTime displays this category under the Register to Register set of each displayed clock domain. - Paths that start at input ports and end at sequential components internal to the design: SmartTime displays this category under the External Setup and External Hold sets of each displayed clock domain. - Paths that start at sequential components internal to the design and end at output ports: SmartTime displays this category under the Clock to Out set of each displayed clock domain. - Paths that start at input ports and end at output ports: SmartTime displays this category under the Input to Output set. ## 9.4. Maximum Clock Frequency (Ask a Question) Generally, you set clock constraints on clocks for which you have a specified requirement. The absence of violations indicates that this clock can run at least at the specified frequency. However, in the absence of such requirements, you may still be interested in computing the maximum frequency of a specific clock domain. To obtain the maximum clock frequency, a static timing analysis tool computes the minimum period for each path between two sequential elements. To compute the maximum period, the tool evaluates the maximum data path delay and the minimum skew between the two elements and the setup on the receiving sequential element. It also considers the polarity of each sequential element. The maximum frequency is the inverse of the largest value among the maximum period of all the paths in the clock domain. The path responsible for limiting the frequency of a given clock is called the "critical path." ## 9.5. Setup Check (Ask a Question) The setup and hold check ensures that the design works as specified at the required clock frequency. Setup check specifies when data is required to be present at the input of a sequential component so that the clock can capture the data effectively into the component. Timing analyzers evaluate the setup check as a maximum timing budget allowed between adjacent sequential elements. For more information about how setup check is processed, see section Arrival Time, Required Time, and Slack. ### 9.6. Arrival Time, Required Time, and Slack (Ask a Question) You can use arrival time and required time to verify timing requirements in the presence of constraints. The following simple example is applied to verify the clock requirement for setup between sequential elements in the design. The arrival time represents the time at which the data arrives at the input of the receiving sequential element. In this example, the arrival time is considered from the setup launch edge at CK, taken as a time reference (instant zero). It follows the clock network along the blue line until the clock pin on FF1 (delay d1). Then it continues along the data path always following the blue line until the data pin D on FF2. Therefore: Arrival\_TimeFF2:D = d1 + d2 The required time represents when the data is required to be present at the same pin FF2:D. Consider in this example, in the presence of an FF with the same polarity, the capturing edge is simply one cycle following the launch edge. Using the period T provided to the tool through the clock constraint, the event gets propagated through the clock network along the red line until the clock pin of FF2 (delay d3), taking FF2 setup (delay d4) into account. This means the clock constraint requires the data to be present d4 time before the capturing clock edge on FF2. Therefore, the required time is: Required\_TimeFF2:D = T + d3 - d4 If the slack is negative, the path is violating the setup relationship between the two sequential elements. The slack is simply the difference between the required time and arrival time: SlackFF2:D = Required\_TimeFF2:D - Arrival\_TimeFF2:D Figure 9-1. Arrival Time and Required Time for Setup Check ## 9.7. Timing Exceptions Overview (Ask a Question) Use timing exceptions to overwrite the default behavior of the design path. Timing exceptions include: - Setting multicycle constraint to specify paths that (by design) will take more than one cycle. - Setting a false path constraint to identify paths that must not be included in the timing analysis or the optimization flow. - Setting a maximum/minimum delay constraint on specific paths to relax or to tighten the original clock constraint requirement. #### 9.8. Clock Skew (Ask a Question) The clock skew between two sequential components is the difference between the insertion delays from the clock source to the clock pins of these components. SmartTime calculates the arrival time at the clock pin of each sequential component. Then it subtracts the arrival time at the receiving component from the arrival time at the launching component to obtain an accurate clock skew. Both setup and hold checks must account for clock skew. However, for setup check, SmartTime looks for the smallest skew. This skew is computed by using the maximum insertion delay to the launching sequential component and the shortest insertion delay to the receiving component. For hold check, SmartTime looks for the largest skew. This skew is computed by using the shortest insertion delay to the launching sequential component and the largest insertion delay to the receiving component. SmartTime makes the distinction between setup and hold checks and hold checks automatically. ## 9.9. Cross Probing (Ask a Question) Design objects displayed in SmartTime can be cross-probed into other Libero SoC tools. Libero SoC allows cross-probing from SmartTime to the Constraints Editor (but not vice versa) and from SmartTime to Chip Planner (but not vice versa). When cross-probing from SmartTime to one of the other tools, both SmartTime and the other tool must first be opened. ### 9.9.1. Cross-Probing from SmartTime into the Constraints Editor (Ask a Question) To add a timing exception constraint from SmartTime and have the Constraints Editor display the constraint: - 1. From the SmartTime Maximum or Minimum Delay Analysis view, click a timing path to add a timing exception constraint. - 2. When the Constraints Editor's Add Constraint dialog box appears, the fields for source (from) pin and destination (to) pin are populated with the correct names from the timing path you selected. ### 9.9.2. Adding a Timing Exception Constraint from a Timing Path (Ask a Question) To add a timing exception constraint from a timing path in SmartTime Max/Min Delay Analysis View: - 1. Open SmartTime (**Design Flow Window > Verify Timing > Open interactively**). - 2. Open the Constraints Editor (Constraint Manager > Timing Tab > Edit with Constraints Editor). - 3. Select Max/Min Delay Analysis View, and then right-click a timing path in the table. - 4. Select a timing exception constraint to add: - False Path Constraint - · Maximum Delay Constraint - Minimum Delay Constraint - Multicycle Path Constraint From \* TO \* Customize table Apply Filter Store Filter Reset Filter Delay Sink Pin Source Pin Slack (ns) Arrival (ns) (ns) Q[6]:CLK Q[6]3.990 7.592 2 Q[4]:CLK Q[4] 3.899 7,499 Q[3] Copy Q[2]:CLK Q[2] 7.463 Print Q[1]:CLK 5 Q[1] 6.640 Add False Path Constraint Add Max Delay Constraint Q[0]:CLK 6 Q[0]6.633 Add Min Delay Constraint Add Multicycle Path Constraint Name Type Macro ■ Summary Show Path in Chip Planner data required time data arrival time Expand selected paths slack ■ Data\_arrival\_time\_calculation Figure 9-2. Add Timing Constraint from SmartTime's Reported Timing Path **Note:** If the Constraint Editor is not open, the **Add Max/Min Delay**, **False Path**, and **Multicycle Path Constraint** menu items are grayed out. - 5. Add the Constraint in the Add Constraint dialog box. The **source/from pin** and **destination/to pin** fields are populated with the appropriate pin names captured from the SmartTime reported path (Source Pin and Sink Pin) you clicked. - a) Click **OK** to exit the Add Constraint dialog box. - b) Click Save in the Constraints Editor. - c) Exit the Constraints Editor. - d) Exit SmartTime. - e) If the newly added constraint that is added to a file (the Target file) is used for Place and Route and Verify Timing, rerun Place and Route. - f) Open SmartTime Maximum/Minimum Delay Analysis View. Figure 9-3. Add Maximum Delay Constraint #### 9.9.3. Cross-Probing from SmartTime to Chip Planner (Ask a Question) Cross-probing of design objects is available from SmartTime to Chip Planner, but not vice versa. Cross-probing allows you to select a design object in one application and display the selected object in another application. Complete the Place and Route step on the design, and then open both SmartTime and Chip Planner. Because Libero SoC allows you to cross-probe design objects from SmartTime to Chip Planner, you can better understand how the two applications interact with each other. With cross-probing, a timing path not meeting timing requirements can be fixed with relative ease when you see the less-than-optimal placement of the design object (in terms of timing requirements) in Chip Planner. Cross-probing from SmartTime to Chip Planner is available for the following design objects: - Macros - Ports - · Nets/Paths To cross-probe from SmartTime to Chip Planner, use a design macro in SmartTime. ## 9.9.4. Design Macro Example (Ask a Question) - 1. Make sure the design completed the Place and Route step successfully. - 2. Open SmartTime Maximum/Minimum Analysis View. - 3. Open Chip Planner. 4. In the SmartTime Maximum Analysis View, right-click the instance Q[2] in the Timing Path Graph and choose **Show in Chip Planner**. The Properties window in Chip Planner displays the properties of Q[2]. With cross-probing, the Q[2] macro is selected in Chip Planner's Logical View and highlighted (white) in the Chip Canvas. **Note:** If Chip Planner is not open, **Show in Chip Planner** is gray and unavailable. Figure 9-4. Cross-Probing—Macro 5. If necessary, zoom in to view the highlighted Q2 Macro in the Chip Canvas. ### 9.9.5. Timing Path Example (Ask a Question) The following procedure provides an example of working with timing paths. - 1. Make sure the design completed the Place and Route step successfully. - 2. Open SmartTime Maximum/Minimum Analysis View. - 3. Open Chip Planner. - 4. In the SmartTime Maximum/Minimum Analysis View, right-click the net CLK\_ibuf/U0/U\_IOPAD:PAD in the table and choose **Show Path in Chip Planner**. The net is selected (highlighted in red) in the Chip Canvas view and the three macros connected to the net are highlighted in white in the Chip Canvas view. **Note:** If Chip Planner is not open, **Show Path** in Chip Planner is gray and unavailable. Figure 9-5. Cross-Probing—Timing Path Figure 9-6. Cross-Probing Path from Max/Min Delay Analysis View Table Instead of performing step 4, you can right-click a path in the Max/Min Delay Analysis View and choose **Show Path in Chip Planner** to cross-probe the path. #### 9.9.6. Port Example (Ask a Question) - 1. Make sure the design completed the Place and Route step successfully. - 2. Open SmartTime Maximum/Minimum Analysis View. - 3. Open Chip Planner. - 4. In the SmartTime Maximum/Minimum Analysis View, right-click the Port "CLK" in the Path and choose **Show in Chip Planner**. - The Port "CLK" is selected and highlighted in the Chip Planner Port View. **Note:** If Chip Planner is not open, **Show in Chip Planner** is gray and unavailable. Figure 9-7. Cross-Probing—Port From the Properties View inside Chip Planner, you will find useful information about the Port "CLK" you are cross- probing: - Port Type - Port Placement Location (X-Y coordinates) - I/O Bank Number - I/O Standard - Pin Assignment Figure 9-8. Properties View of Port "CLK" # 10. SmartTime Tutorials (Ask a Question) The following sections describe SmartTime tutorials. ## 10.1. Tutorial 1—32-Bit Shift Register with Clock Enable (Ask a Question) This tutorial describes how to enter a clock constraint for the 32-bit shift register on SmartFusion 2 device. You use the SmartTime Constraints Editor and perform post-layout timing analysis using the SmartTime Timing Analyzer. Figure 10-1. 32-Bit Shift Register To set up your project: - 1. Invoke Libero SoC. From the **Project** menu, choose **New Project**. - 2. Type sf2\_shift32 for your new project name and browse to a folder for your project location. - 3. Select **Verilog** as the Preferred HDL Type. - 4. Leave all other settings at their default values. Figure 10-2. New Project Creation—32-Bit Shift Register 5. Click **Next** to go to Device Selection page. Make the following selection from the pull-down menus: • **Family**: SmartFusion 2 Die: M2S090TS • Package: 484 FBGA Speed: STD Core Voltage: 1.2V • Range: COM Figure 10-3. Selections from Pull-down Menus 6. Click the M2S090TS-1FG484 part number and click. - 7. Accept the default settings in the Device Settings page and click **Next**. - 8. Accept the default settings in the Design Template page and click **Next**. - 9. Click **Next** to go to the Add Constraints page. - 10. Because you are not adding any constraints, click **Finish** to exit the New Project Creation wizard. - 11. To add a new HDL file, select **File> New> HDL**. The Create a new HDL file dialog box appears. - 12. Name the HDL file shift req32 as shown in the following figure, and click **OK**. Figure 10-4. Create a New HDL File Dialog Box 13. Copy the following code and paste it into the Verilog file: ``` module shift32 ( Q,CLK,D,EN,RESET); input D,EN,CLK,RESET; output[31:0] Q; reg [31:0] Q_int; assign Q=Q_int; always@ (posedge CLK) begin if(RESET) Q_int<=0; else begin if(EN) Q_int<={Q_int[30:0],D}; end end endmodule</pre> ``` - 14. Check the HDL file to confirm there are no syntax errors. - 15. Confirm that the shift\_reg32 design appears in the Design Hierarchy window, as shown in the following figure. Figure 10-5. shift reg32 in the Design Hierarchy Window 16. In the Design Flow window, double-click **Synthesize** to run Synplify Pro with default settings. A green check mark appears next to **Synthesize** when Synthesis is successful, as shown in the following figure. Figure 10-6. Synthesis and Compile Complete—32-Bit Shift Register with Clock Enable ### 10.1.1. Add a Clock Constraint—32-Bit Shift Register (Ask a Question) To add a clock constraint to your design: 1. In the Design Flow window, double-click **Manage Constraints**. The Constraint Manager appears. Figure 10-7. Constraint Manager - 2. Click the **Timing** tab. - 3. Click Edit with Constraints Editor > Edit Place and Route Constraints. Figure 10-8. Constraints Editor—Add Clock Constraint The Constraints Editor appears. 4. In the Constraints Editor, right-click **Clock** under **Requirement** and select **Add Clock Constraint**. The Create Clock Constraint dialog box appears. Figure 10-9. Create Clock Constraint Dialog Box - 5. From the **Clock Source** drop-down menu, choose the **CLK** pin. - 6. In the **Clock Name** field, type my\_clk. - 7. Set the **Frequency** to 250 MHz (as shown in the following figure) and accept all other default values. Figure 10-10. Add a 250 MHz Clock Constraint 8. Click **OK** to continue. The clock constraint appears in the SmartTime Constraints Editor. - P X ConstraintsEditor - [Constraints Editor] E File Constraints Tools Edit Help \_ B × Constraints Editor Dutycycle Clock Name Waveform Syntax Clock Source Requirements (ns) (MHz) (%) Edge (ns) Clock Generated Clock 1 Click within 50% 0.000 0.00 0.00 0.000 rising [ get\_ports { CL... 4.000 2 250.000 50.000000 rising 0.000 0.00 2.00 my\_clk Input Delay Output Delay External Check Clock To Out Exceptions Max Delay Min Delay Multicycle False Path ☐ Advanced Disable Timing Clock Source Latency Clock Uncertainity Clock Groups Figure 10-11. 250 MHz Clock Constraint in the Constraint Editor - 9. From the **File** menu, choose **Save** to save the constraints. - 10. From the SmartTime **File** menu, choose **Exit** to exit SmartTime. Libero creates a constraint file to store the clock constraint. This file appears in the Constraint Manager. It is named **user.sdc** and designated as **Target**. **Note:** A target file is used to store newly added constraints from the Constraint Editor. If you invoke the Constraint Editor with no SDC timing constraint file present, Libero SoC creates the user.sdc file and marks it as **Target** to store the timing constraints you create in the Constraint Editor. 11. In the Constraint Manager, check the check boxes under **Place and Route** and **Timing Verification** to associate the constraint file to the tools. The constraint file is used for both Place and Route and Timing verification. Figure 10-12. SDC Constraint File and Tool Association ### 10.1.2. Run Place and Route (Ask a Question) To run Place and Route: - 1. Right-click **Place and Route** and choose **Configure Options**. The Layout Options dialog box appears. - 2. Click the check box to enable **Timing-driven** layout and accept the other default values shown in the following figure. Figure 10-13. Layout Options Dialog Box - 3. Click **OK** to continue. - 4. In the Design Flow window, double-click **Place and Route** to start the Place and Route. ### 10.1.3. Maximum Delay Analysis with Timing Analyzer—32-Bit Shift Register Example (Ask a Question) The SmartTime Maximum Delay Analysis window shows the design maximum operating frequency along with any setup violations. To perform maximum delay analysis: 1. Right-click **Open SmartTime** in the Design Flow window and choose **Open Interactively** to open SmartTime. The Maximum Delay analysis window appears. A green check next to the clock name indicates there are no timing violations for that clock domain. The Summary page displays a summary of the clock domain timing performance. The Maximum Delay Analysis Summary appears with the following information shown: - Maximum operating frequency for the design - · External setup and hold requirements - Maximum and minimum clock-to-out times. In this example, the maximum clock frequency for CLK is 609.75 MHz. Figure 10-14. Maximum Delay Analysis—Summary 2. Expand my\_clk to display the Register to Register, External Setup, and Clock to Output path sets. Figure 10-15. SmartTime Register-to-Register Delay - 3. Select **Register to Register** to display the register-to-register paths. The window displays a list of register- to-register paths and detailed timing analysis for the selected path. All the slack values are positive, indicating that there are no setup time violations - 4. Double-click a path row to open the Expanded Path window. The window shows a calculation of the data arrival and required times, along with a schematic of the path. **Note:** Timing numbers in the reports may vary slightly with different versions of the Libero software, and may not be what you see when you run the tutorial. Figure 10-16. Register-to-Register Expanded Path View - 5. Select **External Setup** to display the Input to Register timing. - 6. Select **Path 3**. The Input Arrival time from the EN pin to Q\_int[27]:EN is 4.547 ns. Figure 10-17. SmartTime—Input to Register Path Analysis 7. Select **Clock to Output** to display the register to output timing. ### 8. Select Path 1. The maximum clock to output time from Q\_int[16]:CLK to Q[16] is 9.486 ns. Figure 10-18. SmartTime Clock to Output Path Analysis ### 10.1.4. Minimum Delay Analysis with Timing Analyzer—32-Bit Shift Register Example (Ask a Question) The SmartTime Minimum Delay Analysis window identifies any hold violations that exist in the design. To perform minimum delay analysis: 1. From the SmartTime Analysis window, choose **Tools > Minimum Delay Analysis**. The Minimum Delay Analysis View appears, as shown in the following figure. 0 0 X SmartTime - [Minimum Delay Analysis View] File Edit View Tools Help finimum Delay Analysis View Design shift\_reg32 Family SmartFusion2 M2S090TS ✓ my\_clk ✓ Register to Register External Hold Die Package 484 FBGA Temperature Range 0 - 85 C Clock to Output Register to Asynchronous External Removal Voltage Range 1.14 - 1.26 V Speed Grade STD Asynchronous to Register 4 35 Pin to Pin Design State Post-Layout Production Data source Min Operating Conditions BEST - 1.26 V - 0 C Max Operating Conditions WORST - 1.14 V - 85 C Scenario for Timing Analysis timing\_analysis Summary Clock Domain (ns) Frequency Required Period (ns) Required Period (ns) (MHz) Required (MHz) External External Min Clock-Setup (ns) Hold (ns) To-Out (ns) Max Clock To-Out (ns) my\_clk 1.640 609.756 4.000 1.297 0.510 250.000 3.781 9.880 Min Delay (ns) Max Delay (ns) Input to Output N/A N/A Temp: 0 - 85 C | Volt: 1.14 - 1.26 V | Speed: STD Figure 10-19. SmartTime Minimum Delay Analysis View—Summary - 2. Expand **my\_clk** to display Register to Register, External Hold, Clock to Output, Register to Asynchronous, External Removal, and Asynchronous to Register path sets. - 3. Click **Register to Register** to display the reg to reg paths. The window displays a list of register to register paths and detailed timing analysis for the selected path. All the slack value are positive, indicating that there are no hold time violations. - 4. Click to select the first path and observe the hold analysis calculation details, as shown in the following figure. Analysis for scenario Apply Filter Store Filter Reset Filter Customize table Q\_int[29]:0 Input to Output User Sets 0.293 0.257 O intf161:OUK O int[17]:D 0.206 0.260 2 440 2,189 0,000 0.297 0.261 2.450 2 189 0 000 0.036 O MIDZING K O INFORT-O Q\_int[10]:O.K Q\_M[11]:0 0.307 0.262 2.467 2.205 0.000 0.045 Summary dota arrival time data required time slack eta\_arrival\_time\_calculation my\_clk CLK CLK CLK ibut/U0/U JOPAD PAD 1.109 1.109 CLKjbuf CLK\_ibuf\_RNIVQ64:An 0.104 1.213 CLK, ibuf, RNNVQ04-VWn CLK, ibuf, RNNVQ04-VWn CLK, ibuf, RNNVQ04-VWn CLK, ibuf, RNNVQ04-VWn GB1, RGB3-VL cell Q\_int(29)-CLK cell cell ADLIB:GBM CLK\_ibuf\_RNIVQ04/U0\_YWn Temp: 0 - 85 C | Volt: 1.14 - 1.26 V | Speed: STD Figure 10-20. SmartTime Minimum Delay Analysis ## 10.1.5. Changing Constraints and Observing Results—32-Bit Shift Register Example (Ask a Question) You can use the Constraints Editor to change your constraints and view the results in your design. The following procedure describes how. Open the Constraints Editor (Constraints Manager > Timing Tab > Edit Constraints with Constraint Editor > Edit Timing Verifications Constraints). The Constraints Editor shows the clock constraint at 250 MHz you entered earlier. Figure 10-21. Clock Constraint Set to 250 MHz - 2. Select the second row. Right-click and choose **Edit Clock Constraint**. The Edit Clock Constraint dialog box appears. - 3. Change the clock constraint from 250 MHz to 800 MHz, and then click the green check mark to continue. - 4. Click Open SmartTime > Open Interactively. - 5. Choose **Maximum Delay Analysis View** to view the max delay analysis. - 6. In the Maximum Delay Analysis window, expand **my\_clk**. - 7. Click **Register to Register** to observe the timing information. The slacks decrease after you increase the frequency. You may see the slacks go negative, which indicates Timing Violations. Negative slacks are shown in red. **Note:** The actual timing numbers you see may be slightly different. Figure 10-22. Maximum Delay Analysis After Setting Clock Constraint to 800 MHz 8. Close SmartTime. When prompted to save changes, click **No**. ## 10.2. Tutorial 2—False Path Constraints (Ask a Question) This section describes how to enter false path constraints in SmartTime. Import an RTL source file from the following design. After routing the design, you analyze the timing, set false path constraints, and observe the maximum operating frequency in the SmartTime Timing Analysis window. Figure 10-23. Example Design with False Paths ### 10.2.1. Set Up Your False Path Example Design Project (Ask a Question) To set up your false path example design project: 1. Open Libero. - 2. From the **Project** menu, choose **New Project** to create a new project. - 3. Name the project false path and set the project location according to your preferences. - 4. Click Next. - 5. Enter the following values for your **Device Selection** settings: • **Family**: SmartFusion 2 • **Die**: M2S050 Package: 484 FBGA Speed: STD Die Voltage: 1.2 V Range: COM 6. Click **Finish** to create the new project. #### 10.2.2. Import the false path Verilog File and Add Constraints (Ask a Question) For this tutorial, you import the false\_path.v Verilog source file into your design, and then run Libero SoC. To import the Verilog source file: - 1. From the **File** menu, choose **Import > HDL Source Files**. - 2. Browse to the location of the false\_path.v you saved and select it. Click **Open** to import the file. - 3. Verify that the file appears in Design Hierarchy. - 4. In the Design Flow window, double-click **Synthesize** to run synthesis. A green check mark appears when the Synthesis step completes successfully. - 5. Expand **Edit Constraints**. - 6. Right-click **Timing Constraints** and choose **Open Interactively**. - 7. Double-click Manage Constraints. - 8. Select the **Timing** tab. - 9. Expand the **Edit with Constraint Editor** sub-menu, and select **Edit Place and Route Constraints**. The Constraints Editor appears. 10. Double-click **Requirements: Clock**. The Create Clock Constraint dialog box appears. - 11. Double click the **Browse** button for **Clock Source**, select **CLK**, and assign it a name (for example, clk). - 12. Set the frequency to 100 MHz. Figure 10-24. Clock Constraint of 100 MHz 13. Click **OK** to return to the Constraints Editor and observe that the clock information has been filled in, as shown in the following figure. Figure 10-25. Clock Constraint of 100 MHz in false\_path Design - 14. Save your changes (File > Save) and close the Constraints Editor (File > Close). - 15. In the Constraint Manager, check the check boxes under **Place and Route** and **Timing Verification** to associate the constraint file to both tools. The constraint file is used for both Place and Route and Timing verification. #### 10.2.3. Place and Route Your FALSE PATH Design (Ask a Question) To run Place and Route on false\_path design: 1. In Libero SoC, right-click **Place and Route** and choose **Configure Options**. The Layout Options dialog box appears. Figure 10-26. Layout Options Dialog Box - 2. Click the check box to enable **Timing-Driven** layout and leave all other values unchecked. - 3. Click **OK** to close the Layout Options dialog box. - Right-click Place and Route and choose Run. A green check mark appears next to Place and Route in the Design Flow window when Place and Route completes successfully. ₽× Design Flow Top Module(root): false\_path Active Synthesis Implementation: synthesis Tool □ ► Create Design System Builder Configure MSS SD Create SmartDesign Create HDL Create SmartDesign Testbench Create HDL Testbench ◆☐ Generate Memory Map Verify Pre-Synthesized Design Simulate ☐ ► Constraints Manage Constraints **□** Implement Design Netlist Viewer Synthesize ■ Verify Post-Synthesized Design ◆□ Generate Simulation File Simulate ◆☐ Configure Flash\*Freeze ◆☐ Configure Register Lock Bits Place and Route Verify Post Layout Implementation ◆☐ Generate Back Annotated Files Simulate Verify Timing Open SmartTime Verify Power 10 Analyzer CCNI Analyzor Figure 10-27. Synthesize and Place and Route Successful Completion #### 10.2.4. Timing Analysis—Maximum Clock Frequency (Ask a Question) The SmartTime Maximum Delay Analysis View displays the design maximum operating frequency and lists any setup violations. To perform maximum delay analysis: - 1. Expand Verify Post Layout Implementation. - 2. Right-click **Open SmartTime** and choose **Open Interactively** to open SmartTime. The Maximum Delay Analysis View appears. The Maximum Delay Analysis View summarizes design performance and indicates that the design will operate at a maximum frequency of 442.48 MHz. **Note:** You may see a slightly different maximum frequency with a different version of Libero SoC. Figure 10-28. Maximum Delay Analysis Summary - 3. Expand clk to expand the display and show the Register to Register path sets. - 4. Select **Register to Register** to display the register-to-register paths. Notice that the slack values are positive. Figure 10-29. Expanded Path - 5. Double-click to select and expand the row in the path list with the path is from the CLK pin of flip-flop D0\_reg to the D input of flip flop Q\_reg. Note that the path goes through the S input of multiplexer un1\_MUX2. - Looking at the code in false\_path.v, you can see on lines 51 and 52, that D0\_reg and D)\_inv\_reg are always the inverse of each other in "operational" mode (except when RST is active). Line 56 says that XOR2 is the XOR of these two signals, and hence always 1 (except when RST is active). Line 59 says that XOR2 is the select of MUX2. - We might reasonably decide that we are not interested in the reset mode delay for this design; therefore, this path is a false path for our timing analysis purposes. Figure 10-30. Analyzing the False Paths ``` 43 if (RST) 44 begin 45 D0 reg <= 1'b0; 46 D0 inv reg <= 1'b0; 47 end 48 49 else 50 begin 51 D0 reg <= D0; D0 inv_reg 52 <= ~D0: 53 end 54 end 55 assign XOR2 = D0 reg ^ D0 inv reg; 56 57 assign OR2 = D0 inv reg || D1 reg; 58 assign AND2 = OR2 && D2 reg; 59 assign MUX2 = (XOR2) ? (D2 reg) : (AND2); 60 61 ``` Similar analysis shows that the path from D0\_inv\_reg:CLK to Q\_reg:D shares exactly the same false-path characteristic. Disable both paths. - 6. Restart the Libero Constraints Editor. The Constraints Editor must be running to use SmartTime's back-annotation feature. Go to the **Constraint Manager** tab, then go to the **Timing** sub-tab, pull down **Edit with Constraint Editor**, and choose **Edit Timing Verification Constraints**. - 7. Leave this running and return to SmartTime. - 8. From the **Tools** menu, select **Max Delay Analysis**. - 9. To set the path from D0\_inv\_reg:CLK to Q\_reg :D as false, select the row containing this path in the Register to Register path set, right-click and choose **Add False Path Constraint**. The Set False Path Constraint dialog box appears. It might pop behind the current dialog box, so check other Constraint Manager windows. Figure 10-31. Right-Clicking Add False Path Constraint - 10. Click **OK** to close the Set False Path Constraint dialog box. - 11. In the Constraints Editor window, check for an entry below Exceptions > False Path. - 12. Return to the SmartTime window and repeat for the D0\_reg;CLK -> Q\_reg;D path. 13. Because we are interested only in timing analysis through the MUX when select = 1, we can ignore the MUX "0" path from D1\_reg:D through the AND2. We make this a false path. At this point the Constraints Editor should now look as follows. Save the file and exit the Constraints Editor and SmartTime. Figure 10-32. False Path Constraints in the SmartTime Constraint Editor Place and Route is now invalidated and must be re-run before we can perform timing analysis again. This is because we changed the constraint file we are using for both Place and Route and for Timing Analysis. We can use different constraint files, in which case we would not need to re-run Place and Route. - 14. Right-click **Open SmartTime** and choose **Update and Open Interactively**. You will see that Place and Route is run automatically before SmartTime is restarted. - 15. View the summary in the Maximum Delay Analysis View (**Tools > Max Delay Analysis**). SmartTime now reports the maximum operating frequency as 586.17 MHz, as shown in the following figure. **Note:** The maximum operating frequency may vary slightly with a different version of the Libero software. Figure 10-33. Maximum Delay Analysis View—Summary 16. Select the Register to Register set for my\_clk. Observe that only one path is visible, from D2\_reg: CLK to Q\_reg:D. This is the only path that propagates a signal, as shown in the following figure. Figure 10-34. Maximum Delay Analysis View—Register to Register - 17. Close SmartTime. - 18. Close Libero SoC. #### 10.2.5. false\_path.v (Ask a Question) ``` // Package::484 FBGA; // Author: Joe X // // .. ....... module false path (D0, D1, D2, RST, CLK, Q); input D0; input D1; D2: input input RST; input CLK; output Q; reg D0 req; reg D0_inv_reg; D1_reg; D2_reg; reg req reg Q_reg; wire XOR2 /*synthesis syn keep=1*/; /*synthesis syn keep=1*/; wire AND2 /*synthesis syn_keep=1*/; wire OR2 /*synthesis syn_keep=1*/; wire MUX2 /*synthesis syn_keep=1*/; wire NOT1 wire NOT2 /*synthesis syn_keep=1*/; assign Q = Q_reg /*synthesis syn_keep=1*/; always @(posedge CLK or posedge RST) begin if (RST) begin D0_reg <= 1'b0; D0_inv_reg <= 1'b0; D0 reg end else begin <= D0; D0 reg D0_inv_reg <= ~D0; end end assign XOR2 = D0 reg ^ D0 inv reg; assign OR2 = D0 inv reg | D1 reg; assign AND2 = OR2 && D2_reg; assign MUX2 = (XOR2) ? (D2_reg) : (AND2); always @ (posedge CLK) begin <= D1; <= D2; D1 reg D2_reg Q_reg <= NOT2;</pre> end not u1 (NOT1, MUX2); not u2 (NOT2, NOT1); endmodule ``` # 11. SmartTime Dialog Boxes (Ask a Question) The following sections describe the SmartTime dialog boxes. # 11.1. Add Path Analysis Set Dialog Box (Ask a Question) Use the Add Path Analysis Set dialog box to specify a custom path analysis set. To open the Add Path Analysis Set dialog box from the SmartTime Timing Analyzer, choose any path and right-click to select **Add Set**. Note: The Analysis menu is available only in Maximum or Minimum Delay Analysis view. Figure 11-1. Add Path Analysis Set Dialog Box ## 11.1.1. Name (Ask a Question) Enter the name of your path set. #### 11.1.2. Trace from (Ask a Question) Select whether you want to trace connected pins from **Source to sink** or from **Sink to source**. By default, the pins are traced Source to sink. #### 11.1.3. Source Pins (Ask a Question) Displays a list of available and valid source pins. You can select multiple pins. To select all source pins, click the **Select All** button below the **Source Pins** list. ## 11.1.4. Select All (Ask a Question) Selects all the pins in the **Source Pins** list to include in the path analysis set. #### 11.1.5. Filter Source Pins (Ask a Question) Allows you to specify the source **Pin Type** and the **Filter**. The default pin type is Registers by pin name. You can specify any string value for the **Filter**. If you change the pin type, the **Source Pins** shows the updated list of available source pins. #### 11.1.6. Sink Pins (Ask a Question) Displays list of available and valid pins. You can select multiple pins. To select all source pins, click the **Select All** button below the **Sink Pins** list. #### 11.1.7. Select All (Ask a Question) Selects all the pins in the Sink Pins list to include in the path analysis set. #### 11.1.8. Filter Sink Pins (Ask a Question) Allows you to specify the sink **Pin Type** and the **Filter**. The default pin type is **Registers (by pin)**. You can specify any string value for the **Filter**. If you change the pin type, the **Sink Pins** shows the updated list of available sink pins. ## 11.2. Analysis Set Properties Dialog Box (Ask a Question) Use the Analysis Set Properties dialog box to view information about a user-created set. To open the Analysis Set Properties dialog box from the Timing Analysis View, right-click a user-created set in the Domain Browser, and then choose **Properties** from the shortcut menu. Figure 11-2. Analysis Set Properties Dialog Box # 11.2.1. Name (Ask a Question) Specifies the name of the user-created path set. # 11.2.2. Parent Set (Ask a Question) Specifies the name of the parent path set to which the user-created path set belongs. #### 11.2.3. Creation Filter (Ask a Question) Specifies a list of source pins in the user-created path set. #### 11.2.4. To (Ask a Question) Specifies a list of sink pins in the user-created path set. # 11.3. Edit Filter Set Dialog Box (Ask a Question) Use the Edit Filter Set dialog box to specify a filter. To open the Edit Filter Set dialog box from the SmartTime Max/Min Delay Analysis view, right-click a filter set in the clock domain browser, and then choose **Edit Set** from the shortcut menu. Figure 11-3. Edit Path Analysis Set Dialog Box #### 11.3.1. Name (Ask a Question) Specifies the name of the path you want to edit. ## 11.3.2. Creation filter (Ask a Question) **Source Pins**: Displays a list of source pins in the user-created path set. **Sink Pins**: Displays a list of sink pins in the user-created path set. ## 11.4. Customize Analysis View Dialog Box (Ask a Question) Use the Customize Analysis View dialog box to customize the timing analysis grid. To open the Customize Analysis View dialog box from the SmartTime Max/Min Delay Analysis View, click the **Customize table** button (circled in red in the following figure) in the Max/Min Delay Analysis View. The Customize Paths List Table dialog box appears. Figure 11-4. Customize Table Button Figure 11-5. Customize Paths List Dialog Box #### 11.4.1. Available Fields (Ask a Question) Displays a list of all the available fields in the timing analysis grid. #### 11.4.2. Show These Fields in This Order (Ask a Question) Shows the list of fields you want to see in the timing analysis grid. Use **Add** or **Remove** to move selected items from **Available fields** to **Show these fields in this order** or vice versa. You can change the order in which these fields are displayed by using **Move Up** or **Move Down**. # 11.4.3. Restore Defaults (Ask a Question) Resets all the options in the **General** panel to their default values. # 11.5. Manage Clock Domains Dialog Box (Ask a Question) Use the Manage Clock Domains dialog box to specify the clock pins you want to see in the Expanded Path view. To open the Manage Clock Domain dialog box from the SmartTime Max/Min Delay Analysis view, click the icon. Figure 11-6. Manage Clock Domains Dialog Box #### 11.5.1. Available Clock Domains (Ask a Question) Displays alphanumerically sorted list of available clock pins. The first clock pin is selected by default. #### 11.5.2. Show the Clock Domains in This Order (Ask a Question) Shows the clock pins you want to see in the Expanded Path view. Use **Add** or **Remove** to move selected items from **Available clock domains** to **Show the clock domains in this order** or vice versa. You can change the order in which these clock pins are displayed by using **Move Up** or **Move Down**. # 11.5.3. New Clock (Ask a Question) Allows you to add a non-explicit clock domain. Clicking this option opens the Choose the Clock Source Pin dialog box, where you can select the clock source pin. # 11.6. Set False Path Constraint Dialog Box (Ask a Question) Use the Set False Path Constraint dialog box to define specific timing paths as being false. This constraint removes timing requirements on these false paths so that they are not considered during the timing analysis. The path starting points are the input ports or register clock pins and path ending points are the register data pins or output ports. This constraint disables setup and hold checking for the specified paths. **Note:** The false path information always takes precedence over multiple cycle path information and overrides maximum delay constraints. To open the Set False Path Constraint dialog box from the SmartTime Constraints Editor, choose **Constraints > Exceptions False Path > Add False Path Constraint**. Figure 11-7. Set False Path Constraint Dialog Box # 11.6.1. From (Ask a Question) Specifies the starting points for false path. A valid timing starting point is a clock, a primary input, an input port, or a clock pin of a sequential cell. # 11.6.2. Through (Ask a Question) Specifies a list of pins, ports, cells, or nets through which the disabled paths must pass. #### **11.6.3.** To (Ask a Question) Specifies the ending points for false path. A valid timing ending point is a clock, a primary output, an input port, or a data pin of a sequential cell. # 11.6.4. Comment (Ask a Question) Allows you to provide comments for this constraint. # 11.7. SmartTime Options Dialog Box (Ask a Question) Use the SmartTime Options dialog box to specify the SmartTime options to perform timing analysis. This interface includes the following categories: General - Analysis - Advanced To open the SmartTime Options dialog box from the SmartTime tool, choose **Tools > Options**. Figure 11-8. SmartTime Options—General Dialog Box for SmartFusion <sup>®</sup> 2, IGLOO <sup>®</sup> 2, and RTG4 <sup>®</sup> **Figure 11-9.** SmartTime Options—General Dialog Box for PolarFire ® #### 11.7.1. Operating Conditions (Ask a Question) Allows you to perform maximum or minimum delay analysis based on the Best, Typical, or Worst case. By default, maximum delay analysis is based on WORST case and minimum delay analysis is based on BEST case. #### 11.7.2. Clock Domains (Ask a Question) - Include inter-clock domains in calculations for timing analysis: Allows you to specify whether SmartTime must use inter-clock domains in calculations for timing analysis. By default, this option is checked. - **Enable recovery and removal checks**: Allows SmartTime to check removal and recovery time on asynchronous signals. Additional sets are created in each clock domain in Analysis View to report the corresponding paths. #### 11.7.3. Restore Defaults (Ask a Question) Resets all the options in the **General** panel to their default values. ## 11.7.4. Analysis (Ask a Question) The following figure shows the SmartTime Options—Analysis View dialog box. Figure 11-10. SmartTime Options—Analysis View Dialog Box #### 11.7.5. Display of Paths (Ask a Question) Limits the number of paths shown in a path set for timing analysis. The default value is 100. You must specify a number greater than 1. ## 11.7.5.1. Filter the Paths by Slack Value (Ask a Question) Specifies the slack range between minimum slack and maximum slack. This option is unchecked by default. ## 11.7.6. Show Clock Network Details in Expanded Path (Ask a Question) Displays the clock network details as well as the data path details in the Expanded Path views. **Limit the number of parallel paths in expanded path to**: For each expanded path, specify the maximum number of parallel paths that SmartTime displays. The default number of parallel paths is 1 #### 11.7.7. Restore Defaults (Ask a Question) Resets all the options in the **Analysis View** panel to their default values. #### 11.7.8. Advanced Dialog Box (Ask a Question) The following figure shows the SmartTime Options—Advanced dialog box. Figure 11-11. SmartTime Options—Advanced Dialog Box ## 11.7.9. Special Situations (Ask a Question) Allows you to specify whether you need to use loopback in bi-directional buffers (bibufs) and/or break paths at asynchronous pins. #### 11.7.10. Scenarios (Ask a Question) Allows you to select the scenario to use for timing analysis and for timing-driven place-and-route. #### 11.7.11. Restore Defaults (Ask a Question) Resets all the options in the **Analysis View** panel to their default values. # 11.8. Create Filter Set Dialog Box (Ask a Question) Use the Create Filter Set dialog box to specify a filter. To open the Create Filter Set dialog box from the SmartTime Timing Analyzer, select a path, and click the **Store Filter** button in the Analysis View Filter. Figure 11-12. Create Filter Set Dialog Box # 11.8.1. Name (Ask a Question) Specifies the name of the filtered set. # 11.9. Timing Bottleneck Analysis Options Dialog Box (Ask a Question) Use the Timing Bottleneck Analysis Options dialog box to customize the Timing Bottleneck Report. You can set report options for the following categories: - · General pane - · Bottleneck pane - Sets pane To open the Timing Bottleneck Analysis Options dialog box from the SmartTime tool, choose **Tools > Bottleneck Analysis**. #### 11.9.1. General Pane (Ask a Question) The following figure shows the Timing Bottleneck Options—General Pane dialog box. Figure 11-13. Timing Bottleneck Options—General Pane Dialog Box #### 11.9.2. Slack (Ask a Question) Allows you to specify whether the reported paths is filtered by threshold and, if so, what maximum slack to report. By default, the paths are filtered by slack and the slack threshold is 0. #### 11.9.3. Restore Defaults (Ask a Question) Resets all the options in the **General** pane to their default values. #### 11.9.4. Bottleneck Pane (Ask a Question) The following figure shows the Timing Bottleneck Options—Bottleneck Pane dialog box. Figure 11-14. Timing Bottleneck Options—Bottleneck Pane Dialog Box ## 11.9.5. Bottleneck Options (Ask a Question) **Cost Type**: Select the cost type that SmartTime will include in the Bottleneck Report. By default, path count is selected. You can select one of the following two items from the drop-down list: - **Path Count**: This cost type associates the severity of the bottleneck to the count of violating/ critical paths that traverse the instance. This is the default. - **Path Cost**: This cost type associates the severity of the bottleneck to the sum of the timing violations for the violating/critical paths that traverse the instance. **Limit the number of paths per section to**: Specify the maximum number of paths per set type that SmartTime will include per section in the report. The default maximum number of paths reported is 100. **Limit the number of parallel paths per section to**: For each expanded path, specify the maximum number of parallel paths that SmartTime will include in the report. Only cells that lie on these violating paths are reported. The default number of parallel paths is 1. **Limit the number of reported instances**: Specify the maximum number of cells that SmartTime will include per section in the report. The default number of cells is 10. #### 11.9.6. Restore Defaults (Ask a Question) Resets all the options in the **Bottleneck** panel to their default values. #### 11.9.7. Sets Pane (Ask a Question) The **Sets** pane has four mutually exclusive options: - Entire design - Clock Domain - Use existing user set - Use Input to Output Set Figure 11-15. Timing Bottleneck Report—Sets Pane Dialog Box **Entire design**: Displays bottleneck information for the entire design. **Clock Domain**: Displays bottleneck information for the selected clock domain. You can specify the following options: - **Clock**: Allows pruning based on a given clock domains. Only cells that lie on these violating paths are reported. - **Type**: This option can only be used with clock. The following table shows the acceptable values. Table 11-1. Acceptable Type Values | Value | Description | |--------------------------|----------------------------------------------------| | Register to Register | Paths between registers in the design. | | Asynchronous to Register | Paths from asynchronous pins to registers. | | Register to Asynchronous | Paths from registers to asynchronous pins. | | External Recovery | The set of paths from inputs to asynchronous pins. | | External Setup | Paths from input ports to register. | | Table 11-1. Acceptable Type Values (continued) | | | | |------------------------------------------------|---------------------------------------|--|--| | Value | Description | | | | Clock to Output | Paths from registers to output ports. | | | **Use existing user set**: Displays bottleneck information for the existing user set selected. Only paths that lie within the name set will be considered towards the Bottleneck Report. **Filter**: Allows you to filter the Bottleneck Report by the following options: - **From**: Reports only cells that lie on violating paths that start at locations specified by this option. - **To**: Reports only cells that lie on violating paths that end at locations specified by this option. Filter defaults to all outputs. #### 11.9.8. Restore Defaults (Ask a Question) Resets all the options in the **Paths** panel to their default values. # 11.10. Timing Datasheet Report Options Dialog Box (Ask a Question) Use the Timing Datasheet Report Options dialog box to select the output format for the Timing Datasheet Report. To open the Timing Datasheet Report Options dialog box from the SmartTime Max/Min Delay Analysis view, choose **Tools > Reports > Datasheet**. You can generate your report in one of two formats: - Plain Text: Saves your report to disk in plain ASCII text format. - Comma Separated Values: Saves your report to disk in comma-separated value format (.CSV) format, which you can import into a spreadsheet **Note:** This Datasheet Report feature is not supported for PolarFire. Figure 11-16. Report Options Dialog Box # 11.11. Timing Report Options Dialog Box (Ask a Question) Use the Timing Report Options dialog box to customize the Timing Report. You can set report options for the following categories: - General - Paths - Sets - Clock Domains To open the Timing Report Options dialog box from the SmartTime Max/Min Delay Analysis View, choose **Tools > Reports > Timer**. #### 11.11.1. General (Ask a Question) The following figure shows the Timing Report Options—General dialog box. Figure 11-17. Timing Report Options—General Dialog Box #### 11.11.1.1. Format (Ask a Question) Specifies whether the report exports as a Comma Separated Value (CSV) file or a plain text file. By default, the **Plain Text** option is selected. #### 11.11.1.2. Summary (Ask a Question) Specifies whether the summary section is included in the report. By default, this option is selected. #### 11.11.1.3. Analysis (Ask a Question) Specifies the type of analysis to be included in the Timing Report is a Maximum Delay Analysis Report or a Minimum Delay Analysis Report. By default, the Maximum Delay Analysis Report is included in the Timing Report. #### 11.11.1.4. Slack (Ask a Question) Allows you to specify whether the reported path is filtered by threshold and, if so, what maximum slack to report. By default, the paths are not filtered by slack. #### 11.11.2. Paths (Ask a Question) The following figure shows the Timing Report Options—Paths dialog box. Figure 11-18. Timing Report Options—Paths Dialog Box #### 11.11.3. Display of Paths (Ask a Question) **Include detailed path information in this report**: Check this box to include the detailed path information in the Timing Report. **Limit the number of reported paths per section to**: Specify the maximum number of paths that SmartTime will include per section in the report. **Limit the number of expanded paths per section to**: Specify the maximum number of expanded paths that SmartTime will include per section in the report. **Limit the number of parallel paths in expanded path to**: For each expanded path, specify the maximum number of parallel paths that SmartTime will include in the report. The default number of parallel paths is 1. #### 11.11.4. Sets (Ask a Question) The following figure shows the Timing Report Options—Sets dialog box. Figure 11-19. Timing Report Options—Sets Dialog Box # 11.11.4.1. Display of Sets (Ask a Question) Specifies whether user sets are included in the Timing Report. User sets are either filters you created and stored on the default paths sets (Register to Register, Inputs to Register, and so on) or Pin-to-Pin user sets. By default, the paths for these sets are not reported. You can also specify whether the Inputs to Output sets are included in the report. By default, the Input to Output sets are reported. #### 11.11.5. Clock Domains (Ask a Question) The following figure shows the Timing Report Options—Clock Domains dialog box. Figure 11-20. Timing Report Options—Clock Domains Dialog Box #### 11.11.5.1. Display of Clock Domains (Ask a Question) Allows you to specify the clock domains included in the report. By default, the current clock domains used by the timing engine is reported. # 11.11.5.2. Include Clock Domains (Ask a Question) Allows you to include or exclude clock domains in the report. Click the check box to include clock domains. ### 11.11.5.3. Limit Reporting on Clock Domains to Specified Domains (Ask a Question) Allows you to include clock domain names in the box, or include additional clock domain names using **Select Domains**. # 11.12. Timing Violations Report Options Dialog Box (Ask a Question) Use the Timing Violations Report Options dialog box to customize the Timing Violation Report. You can set report violation options for the following categories: - General - Paths To open the Timing Report Options dialog box from the SmartTime tool, choose **Tools > Reports > Timing Violations**. # 11.12.1. General (Ask a Question) The following figure shows the Timing Violations Report Options—General dialog box. Figure 11-21. Timing Violations Report Options—General Dialog Box # 11.12.1.1. Format (Ask a Question) Specifies whether the report exports as a Comma Separated Value (CSV) file or a plain text file. By default, the **Plain Text** option is selected. ## 11.12.1.2. Analysis (Ask a Question) Allows you to specify what type of analysis is reported in the report. By default, the report includes Maximum Delay Analysis. ## 11.12.1.3. Slack (Ask a Question) Allows you to specify whether the reported paths is filtered by threshold and, if so, what maximum slack to report. By default, the paths are filtered by slack and the slack threshold is 0. #### 11.12.1.4. Restore Defaults (Ask a Question) Resets all the options in the **General** panel to their default values. # 11.12.2. Paths (Ask a Question) The following figure shows the Timing Violations Report Options—Paths dialog box. Figure 11-22. Timing Violations Report Options—Paths Dialog Box ## 11.12.2.1. Display of Paths (Ask a Question) **Limit the number of reported paths**: Check this box to limit the number of paths in the report. By default, the number of paths is limited. **Limit the number of paths per section to**: Specify the maximum number of paths that SmartTime will include per section in the report. The default maximum number of paths reported is 100. **Limit the number of expanded paths per section to**: Specify the maximum number of expanded paths that SmartTime will include per section in the report. The default number of expanded paths is 0. **Limit the number of parallel paths in expanded path to**: For each expanded path, specify the maximum number of parallel paths that SmartTime will include in the report. The default number of parallel paths is 1. #### 11.12.2.2. Restore Defaults (Ask a Question) Resets all the options in the **Paths** panel to their default values. # 11.13. Data Change History—SmartTime (Ask a Question) The data change history lists features, enhancements, and bug fixes for the current software release that may impact timing data of the current design. To generate a data change history, choose **Data Change History** from the **Help** menu to display a data change history in text format. Figure 11-23. SmartTime Data Change History Report # 12. Tcl Commands (Ask a Question) For details about the Tcl commands supported by SmartTime, see the Tcl Commands Reference Guide. # 13. Glossary (Ask a Question) The following glossary defines terms in this user guide. Table 13-1. Glossary | Table 13-1. Glossary | _ | | |-------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | Term | Definition | | | Arrival time | Actual time in nanoseconds when data arrives at a sink pin when considering the propagation delays across the path. | | | Asynchronous | Two signals that are not related to each other. Signals not related to the clock are usually asynchronous. | | | Capture edge | The clock edge that triggers the capture of data at the end point of a path. | | | Clock | A periodic signal that captures data into sequential elements. | | | Critical path | A path with the maximum delay between a starting point and an end point. In the presence of a clock constraint, the worst critical path between registers in this clock domain is the path with the worst slack. | | | Data timing analysis | The standard method for verifying design functionality and performance. Both pre-layout and post-layout timing analysis can be performed via the SDF interface. | | | Exception | See timing exception. | | | Explicit clock | Clock sources that can be traced back unambiguously from the clock pin of the registers they deserve, including the output of a DLL or PLL. | | | Filter | A set of limitations applied to object names in timing analysis to generate target specific sets. | | | Launch edge | The clock edge that triggers the release of data from a starting point to be captured by another clock edge at an end point. | | | Minimum period | Timing characteristic of a path between two registers. It indicates how fast the clock runs when this path is the most critical one. The minimum period value takes into consideration both the skew and the setup on the receiving register. | | | Parallel paths | Paths that run in parallel between a given source and sink pair. | | | Path | A sequence of elements in the design that identifies a logical flow starting at a source pin and ending at a sink pin. | | | Path details | An expansion of the path that shows all the nets and cells between the source pin and the sink pin. | | | Path set | A collection of paths. | | | Paths list | Same as path set. | | | Post-layout Post-layout | The state of the design after you run Layout. In post-layout, the placement and routing information are available for the whole design. | | | Potential clock | Pins or ports connected to the clock pins of sequential elements that the STA tool cannot determine whether they are is enabled sources or clock sources. This type of clock is generally associated with the use of gated clocks. | | | Pre-layout | The state of the design before you run Layout. In pre-layout, the placement and routing information are not available. | | | Recovery time | The amount of time before the active clock edge when the de-activation of asynchronous signals is not allowed. | | | Removal time | The amount of time after the active clock edge when the de-activation of asynchronous signals is not allowed. | | | Table 13-1. Glossary (continued) | | |----------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Term | Definition | | Required time | The time when data must be at a sink pin to avoid being in violation. | | Requirement | See timing requirement. | | Scenario (timing constraints scenario) | Set of timing constraints defined by the user. | | Setup time | The time in nanoseconds relative to a clock edge during which the data at the input to a sequential element must remain stable. | | Sink pin | The pin located at the end of the timing path. This pin is usually the one where arrival time and required time are evaluated for path violation. | | Skew | The difference between the clock insertion delay to the clock pin of a sink register and the insertion delay to the clock pin of a source register. | | Slack | The difference between the arrival time and the required time at a specific pin, generally at the data pin of a sequential component. | | Slew rate | The time needed for a signal to transition from one logic level to another. | | Source pin | The pin located at the beginning of a timing path. | | STA | See static timing analysis. | | Standard delay format (SDF) | A standard file format used to store design data suited for back-annotation. | | Static timing analysis | An efficient technique to identify timing violations in a design and to ensure that all timing requirements are met. It is well suited for traditional synchronous designs. The main advantages are that it does not require input vectors, and it exclusively covers all possible paths in the design in a relatively short run-time. | | Synopsys design constraint (SDC) | A standard file format for timing constraints. SDC is a Tcl-based format used by Synopsys tools to specify the design intent, including the timing and area constraints for a design. Micrchip SoC tools use a subset of the SDC format to capture supported timing constraints. You can import or export an SDC file from the Designer software. Any timing constraint that you can enter using Designer tools, can also be specified in an SDC file. | | Timing constraint | A requirement or limitation on the design to be satisfied during the design implementation. | | Timing exception | An exception to a general requirement usually applied on a subset of the objects on which the requirement is applied. | | Timing requirement | A constraint on the design usually determined by the specifications at the system level. | | Virtual clock | A virtual clock is a clock with no source associated to it. It is used to describe clocks outside the FPGA that have an impact on the timing analysis inside the FPGA. For example, if the I/Os are synchronous to an external clock. | | Wire Load Model (WLM) | A timing model used in pre-layout to estimate a net delay based on the fan-out. | # 14. Revision History (Ask a Question) The revision history describes the changes that were implemented in the document. The changes are listed by revision, starting with the most current publication. Table 14-1. Revision History | | | on mistory | |----------|---------|-----------------------------------------------------------------------------------------------------------------------------------| | Revision | Date | Description | | M | 05/2025 | The following is a summary of the changes made in this revision: | | | | • In the section Generating a Clock Domain Crossing (CDC) Report, updated Figure 8-7 and the last row in Table 8-7. | | L | 07/2024 | The following is a summary of the changes made in this revision: | | | | Updated content in the Understanding Inter-Clock Domain Analysis section. | | | | Updated content in the Inter-clock Domain section. | | | | Updated content in the Clock Domains section. | | K | 02/2024 | This document is released with Libero SoC Design Suite v2024.1 without changes from v2023.2. | | J | 08/2023 | This document is released with Libero SoC Design Suite v2023.2 without changes from v2023.1. | | Н | 04/2023 | This document is released with Libero SoC Design Suite v2023.1 without changes from v2022.3. | | G | 12/2022 | This document is released with Libero SoC Design Suite v2022.3 without changes from v2022.2. | | F | 08/2022 | This document is released with Libero SoC Design Suite v2022.2 without changes from v2022.1. | | E | 04/2022 | This document is released with Libero SoC Design Suite v2022.1 without changes from v2021.3. | | D | 12/2021 | This document is released with Libero SoC Design Suite v2021.3 without changes from v2021.2. | | С | 08/2021 | Changed clk2 to clk1 in point 8 of Deactivating a Specific Inter-Clock Domain. | | В | 04/2021 | <ul> <li>Generating a CDC Report: Added information related to cross probing, corner scenarios, and<br/>updated notes.</li> </ul> | | Α | 11/2020 | Document converted to Microchip template. Initial Revision. | # Microchip FPGA Support Microchip FPGA products group backs its products with various support services, including Customer Service, Customer Technical Support Center, a website, and worldwide sales offices. Customers are suggested to visit Microchip online resources prior to contacting support as it is very likely that their queries have been already answered. Contact Technical Support Center through the website at <a href="https://www.microchip.com/support">www.microchip.com/support</a>. Mention the FPGA Device Part number, select appropriate case category, and upload design files while creating a technical support case. Contact Customer Service for non-technical product support, such as product pricing, product upgrades, update information, order status, and authorization. - From North America, call 800.262.1060 - From the rest of the world, call 650.318.4460 - Fax, from anywhere in the world, 650.318.8044 # **Microchip Information** ### **Trademarks** The "Microchip" name and logo, the "M" logo, and other names, logos, and brands are registered and unregistered trademarks of Microchip Technology Incorporated or its affiliates and/or subsidiaries in the United States and/or other countries ("Microchip Trademarks"). Information regarding Microchip Trademarks can be found at https://www.microchip.com/en-us/about/legal-information/microchip-trademarks. ISBN: 979-8-3371-1242-8 # **Legal Notice** This publication and the information herein may be used only with Microchip products, including to design, test, and integrate Microchip products with your application. Use of this information in any other manner violates these terms. Information regarding device applications is provided only for your convenience and may be superseded by updates. It is your responsibility to ensure that your application meets with your specifications. Contact your local Microchip sales office for additional support or, obtain additional support at <a href="https://www.microchip.com/en-us/support/design-help/client-support-services">www.microchip.com/en-us/support/design-help/client-support-services</a>. THIS INFORMATION IS PROVIDED BY MICROCHIP "AS IS". MICROCHIP MAKES NO REPRESENTATIONS OR WARRANTIES OF ANY KIND WHETHER EXPRESS OR IMPLIED, WRITTEN OR ORAL, STATUTORY OR OTHERWISE, RELATED TO THE INFORMATION INCLUDING BUT NOT LIMITED TO ANY IMPLIED WARRANTIES OF NON-INFRINGEMENT, MERCHANTABILITY, AND FITNESS FOR A PARTICULAR PURPOSE, OR WARRANTIES RELATED TO ITS CONDITION, QUALITY, OR PERFORMANCE. IN NO EVENT WILL MICROCHIP BE LIABLE FOR ANY INDIRECT, SPECIAL, PUNITIVE, INCIDENTAL, OR CONSEQUENTIAL LOSS, DAMAGE, COST, OR EXPENSE OF ANY KIND WHATSOEVER RELATED TO THE INFORMATION OR ITS USE, HOWEVER CAUSED, EVEN IF MICROCHIP HAS BEEN ADVISED OF THE POSSIBILITY OR THE DAMAGES ARE FORESEEABLE. TO THE FULLEST EXTENT ALLOWED BY LAW, MICROCHIP'S TOTAL LIABILITY ON ALL CLAIMS IN ANY WAY RELATED TO THE INFORMATION OR ITS USE WILL NOT EXCEED THE AMOUNT OF FEES, IF ANY, THAT YOU HAVE PAID DIRECTLY TO MICROCHIP FOR THE INFORMATION. Use of Microchip devices in life support and/or safety applications is entirely at the buyer's risk, and the buyer agrees to defend, indemnify and hold harmless Microchip from any and all damages, claims, suits, or expenses resulting from such use. No licenses are conveyed, implicitly or otherwise, under any Microchip intellectual property rights unless otherwise stated. # **Microchip Devices Code Protection Feature** Note the following details of the code protection feature on Microchip products: - Microchip products meet the specifications contained in their particular Microchip Data Sheet. - Microchip believes that its family of products is secure when used in the intended manner, within operating specifications, and under normal conditions. - Microchip values and aggressively protects its intellectual property rights. Attempts to breach the code protection features of Microchip products are strictly prohibited and may violate the Digital Millennium Copyright Act. - Neither Microchip nor any other semiconductor manufacturer can guarantee the security of its code. Code protection does not mean that we are guaranteeing the product is "unbreakable". Code protection is constantly evolving. Microchip is committed to continuously improving the code protection features of our products.