

## Centre of Excellence in VLSI

# Static Timing Analysis using PrimeTime Lab Manual

www.maven-silicon.com



## **Maven Silicon Confidential**

All the presentations, books, documents [hard copies and soft copies] labs and projects [source code] that you are using and developing as part of the training course are the proprietary work of Maven Silicon and it is fully protected under copyright and trade secret laws. You may not view, use, disclose, copy, or distribute the materials or any information except pursuant to a valid written license from Maven Silicon



## **Table of Contents**

| 1. L | ab 01 - PrimeTime Flow                                    | 4  |
|------|-----------------------------------------------------------|----|
| 1.1  | Task 1 : Restore a PrimeTime Session                      | 4  |
| 1.2  | Task 2 : Explore some helpful commands                    | 5  |
| 1.3  | Task 3: Validate an Existing PrimeTime Session            | 7  |
| 1.4  | Task 4: Execute the Run Script and Analyze the run        | 8  |
| 1.5  | Task 5 : Analyze STA Reports                              | 9  |
| 2. L | ab 02 - writing constraints and validating them           | 12 |
| 2.1  | Task 1 : Validate Constraints                             | 12 |
| 2.2  | Task 2: Analyse Timing Report for Input Delay Constraint  | 13 |
| 2.3  | Task 3: Analyse Timing Report for Output Delay Constraint | 15 |
| 3. L | ab 03 – Generating Timing Reports and analysing them      | 17 |
| 3.1  | Task 1 : Setup PrimeTime for Lab3                         | 17 |
| 3.2  | Task 2 : Generate Summary Reports                         | 18 |
| 3.3  | Task 3: Analyse Timing Reports for Setup and Hold         | 19 |
| 3.4  | Task 4 : Apply the Correct Timing Report Switches         | 20 |
| 3.5  | Task 5 : Identify Half-Clock Cycle Paths                  | 21 |
| 4. L | ab 04 - Constraining multiple clocks                      | 23 |
| 4.1  | Task 1 : Get to Know the Design Clocks                    | 23 |
| 4.2  | Task 2: Use the GUI to Report Clock Relationships         | 24 |
| 4.3  | Task 3: Use the GUI to explore detail of timing paths     | 27 |
| 4.4  | Task 4 : Report a False Violation                         | 32 |
| 4.5  | Task 5: Re-Execute the Run Script to reduce violation     | 34 |
| 5. L | ab 05 – Additional Constraints                            | 35 |
| 5.1  | Task 1 : Debug PTE-070 Information Messages               | 35 |
| 5.2  | Task 2 : Explore Time Borrow and Latches                  | 36 |



#### 1. Lab 01 - PrimeTime Flow

**Objective :** To be familiar with Prime Time and understand how to read and analyze setup/hold reports

Working Directory :/home/<user name>/PD Labs/PT/Lab01

**Relevant Files & Directories :** 

Lab01 : current working directory common\_setup.tcl : multi tool shared setup file

pt\_shell.tcl : tool specific PrimeTime setup file.

pt\_scripts : Run file directory

pt.tcl : Run file

**.synopys pt.setup** : Automatically read PT setup file

orca savesession : Saved Session directory

RUN.tcl : Run script for orca\_savesession

#### **Learning outcomes:**

- ✓ How to create a session for later usage
- ✓ How to restore a saved session
- ✓ How to validate a restored session
- ✓ Understanding the basic PrimeTime flow
- ✓ To understand how to read and understand the timing reports.

#### 1.1 Task 1: Restore a PrimeTime Session

**Instructions**: Follow the below instructions and answer the given questions based on your observations after the execution of the relevant instructions.

✓ Invoke PrimeTime from the lab1 directory.

PT\_Labs]\$ cd Lab01/ Lab01]\$ pt\_shell

- ✓ Restore a previously saved PrimeTime session. This step will read in the design netlist, libraries, and constraints. The design is now ready for analysis.
  - Note: The orca savesession below is a Unix directory.
  - Note: The orca savesession can be recreated, if needed, using:

pt shell -f RUN.tcl | tee -i run.log

- Note: Any PARA-124 Errors during the execution of RUN.tcl (within the parasitics\_command.log file) can be safely ignored for the purpose of our labs.
- Note: Prime Time supports command, option, variable and file completion. Type a few letters and then hit the tab key.

pt\_shell> restore\_session orca\_savesession



✓ Generate coverage analysis report

|   |      | pt_shell> report_analyis_coverage                                 |
|---|------|-------------------------------------------------------------------|
|   | •    | Question 1: What is the name of the design under analysis?        |
|   |      |                                                                   |
|   |      |                                                                   |
|   | •    | Question 2: How many setup and hold violations does ORCA have?    |
|   |      | •••••                                                             |
|   |      | ••••••                                                            |
| / | Gene | rate global timing report                                         |
|   |      | pt_shell> report_global_timing                                    |
|   | •    | Question 3: How many reg-reg setup and hold violations are there? |
|   |      | •••••                                                             |
|   |      |                                                                   |
|   |      |                                                                   |
|   |      |                                                                   |

#### 1.2 Task 2: Explore some helpful commands

**Instructions**: Follow the below instructions and answer the given questions based on your observations after the execution of the relevant instructions.

✓ Execute the following three history short cut commands:



✓ Use up and down arrows to scroll through the history event list as an alternative to the previous step. Type the following to see all the available key bindings (in the default emacs editing mode).



✓ Explore the page mode alias; execute the following command, which will generate a report that scrolls off the screen.

```
pt_shell> report_timing -group [get_path_group *]
```

✓ Turn on the page mode

```
pt_shell> page_on
pt_shell> !rep
```

- ✓ Use the space bar and Enter keys to page through a long report. Quit from a long report in page mode by typing "g\*. If you want to turn off page mode, use the command alias page off.
- ✓ Find the command to restore a PrimeTime session and then display help information on this command.

```
pt_shell> help restore*
pt_shell> view man restore_session
pt_shell> restore_session -help
```

• **Note :** The following is an alternative way to display syntax help

```
pt_shell> help -v restore_session
```

- Question 5: From the last command above, does the command restore session accent switches?.
- ✓ The time unit in PrimeTime is determined by the main technology library. To find the time unit for ORCA, first list all libraries in memory.
  - **Note :** The \* in the following report indicates the main library.

- ✓ Generate a report for the main library which will state the time unit.
  - **Note:** Use copy and paste to avoid mistyping the lib name. The time unit is at the very top of the report.

| • | <b>Question 6:</b> What is the time unit used for timing reports (as well as all other reports) for the ORCA design? |
|---|----------------------------------------------------------------------------------------------------------------------|
|   |                                                                                                                      |
|   |                                                                                                                      |
|   |                                                                                                                      |



- **Note**: Do not forget to use "q" to quit from a long report in page mode and return to the pt shell prompt without reading the entire report.
- ✓ Display units used by the current design.

```
pt_shell> report_units
```

#### 1.3 Task 3: Validate an Existing PrimeTime Session

**Instructions**: Follow the below instructions and answer the given questions based on your observations after the execution of the relevant instructions. In this task, you will validate the inputs that have been read into Prime Time: the current design and libraries, the back annotation and constraints.

✓ Verify that the current design is your top-level module: ORCA.

```
pt_shell> current_design
```

✓ Compare the unix paths of the libraries to what has been read into Prime Time.

```
pt_shell> printvar search_path
pt shell> printvar link_path
pt shell> list_libraries
```

| <b>Question 7:</b> Have the 4 libraries in the link_path been successfully read into PrimeTime?                               |
|-------------------------------------------------------------------------------------------------------------------------------|
|                                                                                                                               |
| Question 8: Which library defines the defaults for time units, operating conditions, and other delay calculation information? |
|                                                                                                                               |
| Question 9: What time unit is used?                                                                                           |
|                                                                                                                               |
| •••••••••••••••••••••••••••••••••••••••                                                                                       |

✓ Verify that the nets are completely annotated..

pt shell> report annotated parasitics





|   | •      | Question 10: Are there any nets that are not annotated?                                                                      |
|---|--------|------------------------------------------------------------------------------------------------------------------------------|
|   |        |                                                                                                                              |
|   | •      | Question 11: What option to report_annotated_parasitics would be good to use as a 'next step' in debugging the missing nets? |
|   |        |                                                                                                                              |
| ✓ | Verify | that the design is completely constrained.                                                                                   |
|   |        | pt_shell> check_timing                                                                                                       |
|   | •      | Question 12: What option to check_timing would be good to use as a 'next step' in debugging the missing constraints?         |
|   |        |                                                                                                                              |
| ✓ | -      | that the checks in your cells are completely exercised; look at possible for your findings.                                  |
|   |        | <pre>pt_shell&gt; report_analysis_coverage pt_shell&gt; report_case_analysis</pre>                                           |
|   | •      | Question 13: Is it logical that many of your timing checks are untested?                                                     |
|   |        |                                                                                                                              |
| ✓ | Quit P | rimeTime.                                                                                                                    |
|   |        | pt_shell> quit                                                                                                               |

## 1.4 Task 4: Execute the Run Script and Analyze the run

**Instructions**: Follow the below instructions and answer the given questions based on your observations after the execution of the relevant instructions.

 $\checkmark$  Execute the run script logging the results to the log file run. log.



Lab01]\$ pt\_shell -f ./pt\_scripts/pt.tcl | tee -i run.log

| • Question 14: Were there any errors during the execution of the run script?                                                                                                                                                                        |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                                                                                                                                                                                                                                     |
| If there are any errors, address these first before moving on to the next step.                                                                                                                                                                     |
| Evaluate your log file. With a text editor, open your log file. Search for the update timing messages (UITE-214), print_message_info output, and the exit output. Then, in your profile directory, examine the file tcl_profile_sorted_by_cpu_time. |
| • Question 15: What step required the most CPU time?                                                                                                                                                                                                |
|                                                                                                                                                                                                                                                     |
| • Question 16: What commands were causing UITE-214 messages?                                                                                                                                                                                        |
|                                                                                                                                                                                                                                                     |
| • Question 17: Can any of the timing updates be avoided?                                                                                                                                                                                            |
|                                                                                                                                                                                                                                                     |
| • Question 18: Why might the exit command output be a good place to start before reviewing your log file?                                                                                                                                           |
|                                                                                                                                                                                                                                                     |
|                                                                                                                                                                                                                                                     |

### 1.5 Task 5 : Analyze STA Reports

**Instructions**: Follow the below instructions and answer the given questions based on your observations after the execution of the relevant instructions. Generate and interpret two STA reports for setup and hold for SYS CLK.

✓ Invoke PrimeTime and restore the session that you saved in the previous task.

#### **VLSI Training Services**

Setting standards in VLSI Design

Lab01]\$ pt\_shell
pt\_shell> restore\_session my\_savesession

| ✓ | Execute | the following to display the clocks in ORCA:.                                                                                                             |
|---|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|
|   |         | pt_shell> report_clock                                                                                                                                    |
|   | •       | Question 19: How many clocks are in ORCA?                                                                                                                 |
|   |         |                                                                                                                                                           |
| ✓ | comma   | a single, "short" timing report for setup for the clock SYS_CLK. Use nd-line expansion (the tab key) to expand both the command AND the -group and -path. |
|   | pt_     | shell> report_timing -group SYS_CLK -path shor                                                                                                            |
|   | •       | <b>Note:</b> The lines containing the data path cells and their delays are removed from the data arrival section making this report.                      |
|   | •       | <b>Note :</b> The above command generates a report for setup by default.                                                                                  |
|   | •       | <b>Question 20:</b> There are at least 4 clues that this report is for setup and not for hold. How many can you identify?                                 |
|   |         |                                                                                                                                                           |
|   | •       | <b>Question 21:</b> Identify the instance names of the start and end point flip-flops.                                                                    |
|   |         |                                                                                                                                                           |
|   | •       | <b>Question 22:</b> The clock skew for this timing path is 0.511ns; which two lines in the report can you use to calculate this?                          |
|   |         |                                                                                                                                                           |
|   | •       | Question 23: How does this clock skew affect slack (i.e. does the clock skew help or hurt slack)?                                                         |
|   |         |                                                                                                                                                           |



**VLSI Training Services**Setting standards in VLSI Design

| <ul> <li>Question 24: How large is the violation in comparison to the clock<br/>period?</li> </ul>                                                                                                                              |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                                                                                                                                                                                                                 |
|                                                                                                                                                                                                                                 |
|                                                                                                                                                                                                                                 |
| Generate a timing report for hold time.  The following is a short cut that will execute the last command in history starting with the letters "rep" and add the switch -delay min (which will generate a report for hold time). |
| pt_shell> !rep -delay min                                                                                                                                                                                                       |
| • Question 25: There are at least 4 clues that indicate this is a hold report and not a setup report. How many can you find?                                                                                                    |
|                                                                                                                                                                                                                                 |
| • Question 26: How does the clock skew in this hold report affect slack (i.e. does the clock skew help or hurt slack)?                                                                                                          |
|                                                                                                                                                                                                                                 |
|                                                                                                                                                                                                                                 |
|                                                                                                                                                                                                                                 |
| Quit PrimeTime.                                                                                                                                                                                                                 |
| pt_shell> quit                                                                                                                                                                                                                  |



## 2. Lab 02 - writing constraints and validating them

**Objective :** To understand how to validate the constraints and how to interpret constraints in a timing report

Working Directory :/home/<user\_name>/PD\_Labs/PT/Lab02

**Relevant Files & Directories :** 

Lab02 : current working directory

**.synopys\_pt.setup** : Automatically read PT setup file

orca\_savesession : Saved Session directory

RUN.tcl : Run script for orca\_savesession

#### **Learning outcomes:**

- ✓ How to validate the constraints for constraint completeness
- ✓ How to validate the constraints for untested timing checks
- ✓ How to interpret the timing constraints

#### 2.1 Task 1 : Validate Constraints

**Instructions**: Follow the below instructions and answer the given questions based on your observations after the execution of the relevant instructions.

- ✓ Invoke PrimeTime from the lab2 directory and restore a previously saved PrimeTime session using the orca\_savesession directory.
  - Note: The orca\_savesession can be recreated, if needed, using:

- Note: Any PARA-124 Errors during the execution of RUN.tcl can be safely ignored for the purpose of our labs.
- ✓ Check for constraint completeness.

| <pre>pt_shell&gt; check_timing -verbose</pre>                   |
|-----------------------------------------------------------------|
| Question 1: Are all registers in the design clocked?            |
|                                                                 |
|                                                                 |
| Question 2: Are there any missing constraints? Can you explain? |
|                                                                 |
|                                                                 |
|                                                                 |



2.2 Task 2 : Analyse

✓ Check for the untested timing checks in the design

| •    | <b>Question 3 :</b> Nearly two thirds of the setup/hold checks are untested! What are the 2 causes?                               |
|------|-----------------------------------------------------------------------------------------------------------------------------------|
|      |                                                                                                                                   |
| •    | Question 4: Why are there unexercised min_pulse_width checks?                                                                     |
|      |                                                                                                                                   |
| •    | <b>Question 5 :</b> How many output delay constraints are there for setup and for hold and are these constraints met or violated? |
|      |                                                                                                                                   |
| Ti   | ming Report for Input Delay Constraint                                                                                            |
| Foll | ow the below instructions and answer the given questions                                                                          |

pt\_shell> report\_analysis\_coverage

**Instructions**: Follow the below instructions and answer the given questions based on your observations after the execution of the relevant instructions.

✓ Generate a report for the input delay constraints applied to the port pad[0].

| <b>Question 6:</b> What are the min and max arrival times to pad [0]?                |
|--------------------------------------------------------------------------------------|
|                                                                                      |
| Question 7: What is the name of the external start point clock constraining pad [0]? |
|                                                                                      |

✓ Generate a timing report for setup starting at the port pad[0]. Answer the following questions using this report. Use your job aid labelled "timing reports" for help recalling the appropriate switch for report timing.



## **VLSI Training Services**

Setting standards in VLSI Design

| •                | <b>Question 8:</b> Which lines in the timing report did you use to ensure the reported path starts at the port pad [01 and is for setup?                                                                                                                 |
|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                  |                                                                                                                                                                                                                                                          |
| •                | Question 9: List all user specified constraints in this timing report.                                                                                                                                                                                   |
|                  |                                                                                                                                                                                                                                                          |
| •                | Question 10: Where must the clock latency be included for the start point clock PCI_CLK?                                                                                                                                                                 |
|                  |                                                                                                                                                                                                                                                          |
| •                | Question 11: Describe the direction of the port pad [0] (i.e. is it an input, output or inout port)                                                                                                                                                      |
|                  |                                                                                                                                                                                                                                                          |
| •                | Question 12: Describe the end point of this timing path (i.e. is it an output port or an internal flip-flop).                                                                                                                                            |
|                  |                                                                                                                                                                                                                                                          |
| details reports' | te a new report from the same port pad [0] for setup, which also shows the of the calculated clock network delay. Use the job aid labelled "timing for help recalling the appropriate switch for report timing. Remember to vantage of history commands. |
| •                | Question 13: How large is the clock source latency versus the clock network latency for the end point clock PCI CLK?                                                                                                                                     |
|                  |                                                                                                                                                                                                                                                          |
| •                | Question 14: Where has the clock PCI CLK been defined (the clock definition point)?                                                                                                                                                                      |
|                  |                                                                                                                                                                                                                                                          |
|                  |                                                                                                                                                                                                                                                          |

 $\checkmark$  Generate a report starting at the port pad [0) for hold time.





| •                  | <b>Question 15:</b> Does the value of the input external delay constraint match your expectations?                                                    |
|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|
|                    |                                                                                                                                                       |
| ask 3 : Analyse Ti | ming Report for Output Delay Constraint                                                                                                               |
|                    | low the below instructions and answer the given questions vations after the execution of the relevant instructions.                                   |
| ✓ Gener            | ate a report for the output delay constraints applied to the port pad[0].                                                                             |
| •                  | <b>Question 16:</b> What are the min and max output delay constraints for this port?                                                                  |
|                    |                                                                                                                                                       |
| •                  | Question 17: How will the negative min output delay constraint be applied to this port (i.e. will it impose a positive or negative hold requirement)? |
|                    |                                                                                                                                                       |
| •                  | Question 18: What is the name of the external end point clock constraining this port?                                                                 |
|                    |                                                                                                                                                       |
| ✓ Genera           | te a "short timing report ending at the port pad [0] for hold time.                                                                                   |
| •                  | Question 19: Describe the start point of this timing path (i.e. is it an input port or an internal flip-flop).                                        |
|                    |                                                                                                                                                       |
| •                  | Question 20: Does the path group for this timing path match your expectations?                                                                        |
|                    |                                                                                                                                                       |



#### **VLSI Training Services**

Setting standards in VLSI Design

| • | Question 21: Does the "data required time" match your expectations? |
|---|---------------------------------------------------------------------|
|   |                                                                     |
|   |                                                                     |
|   |                                                                     |

✓ Optionally, apply the following constraint which will impose a positive output delay constraint for hold on pad [0] and then re-execute the steps in this task to see the affect.

pt\_shell> set\_output\_delay -min 1.0 -clock PCI\_CLK pad[0]

✓ Quit PrimeTime.

.



## 3. Lab 03 – Generating Timing Reports and analysing them

**Objective:** To understand how to generate timing reports and how to understand how to analyzing them.

Working Directory :/home/<user name> PD Labs/PT/Lab03

**Relevant Files & Directories :** 

Lab03 : current working directory

.synopys\_pt.setup : Automatically read PT setup file

orca\_savesession : Saved Session directory

RUN.tcl : Run script for orca savesession

#### **Learning outcomes:**

- ✓ How to generate summary report for the violations
- ✓ How to analyze the timing reports for setup and hold
- ✓ How to apply the switches to timing report commands
- ✓ How to identify the clock cycle paths

#### 3.1 Task 1 : Setup PrimeTime for Lab3

**Instructions**: Follow the below instructions and answer the given questions based on your observations after the execution of the relevant instructions.

- ✓ Invoke Prime Time from the lab3 reports workshop lab directory. Restore the PrimeTime session using the orca savesession directory.
  - Note: The orca\_savesession can be recreated, if needed, using:

- Note: Any PARA-124 Errors during the execution of RUN.tcl can be safely ignored for the purpose of our labs.
- ✓ Find the variable that controls the significant digits for many reports and set it to 4 significant digits. (Hint: aa significant].

| • | Question 1: What is this variable's default value? [Hint: man page] |
|---|---------------------------------------------------------------------|
|   |                                                                     |
|   |                                                                     |
|   |                                                                     |
|   |                                                                     |



## 3.2 Task 2 : Generate Summary Reports

**Instructions**: Follow the below instructions.

| ✓ | Answe    | r the following questions by generating the appropriate summary reports:                                                                                                               |
|---|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|   | •        | <b>Question 2 :</b> Identify the top five setup violations with the worst slack The required details are me endpoint names and the slack.                                              |
|   |          |                                                                                                                                                                                        |
|   | •        | <b>Question 3:</b> List the 2 clock domains that have violating setup timing paths, and the 5 clock domains that have violating hold timing paths (ORCA has 6 clock domains in total). |
|   |          |                                                                                                                                                                                        |
|   | •        | <b>Question 4 :</b> Identify how many hold violations are on input paths, how many on output paths, and how many are register-to-register violations.                                  |
|   |          |                                                                                                                                                                                        |
| ✓ | the outp | te a report for the worst slack for setup to each bit of a 16-bit bus ending a put ports sd_DQ (0] to sd_DQ [15] (the output ports are all constrained by clock, SD DDR CLK).          |
|   | •        | Question 5: List the end point with the largest margin (the best slack).                                                                                                               |
|   |          |                                                                                                                                                                                        |
| ✓ | Generat  | te a high-level overview of the quality of the design.                                                                                                                                 |
|   | •        | <b>Question 6:</b> Which clock group has the highest number of violating paths?                                                                                                        |
|   |          |                                                                                                                                                                                        |



## 3.3 Task 3: Analyse Timing Reports for Setup and Hold

| ✓ | Turn Page Mode on.                                                                                               |
|---|------------------------------------------------------------------------------------------------------------------|
| ✓ | Execute the following command to generate a timing report for PCI CLK:                                           |
|   | <pre>pt_shell&gt; report_timing -group PCI_CLK</pre>                                                             |
|   | • Question 7: Does this timing path meet or violate timing?                                                      |
|   |                                                                                                                  |
|   | • Question 8: What type of timing path is this - internal flip-flop to flip flop, input, or output timing path?. |
|   |                                                                                                                  |
| ✓ | Generate a timing report for hold time for the same clock group PCI_CLK.                                         |
| р | t_shell> report_timing -group PCI_CLK -delay min                                                                 |
|   | • Question 9: What type of timing path is this - internal flip-flop to flip flop, input, or output timing path?  |
|   |                                                                                                                  |
|   |                                                                                                                  |
|   |                                                                                                                  |
|   |                                                                                                                  |
|   |                                                                                                                  |

above question.

In the next step, you will continue to explore and confirm your answer for the



## **VLSI Training Services**

Setting standards in VLSI Design

| answer for the above question?                                                                                                                                                                                                                                                                                                            | ur                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                                                                                                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|                                                                                                                                                                                                                                                                                                                                           | ••                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| fall transition at the end point (instead of a rise transition). Use copy and paste                                                                                                                                                                                                                                                       | to                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| • Question 13: Which lines in this report did you use to confirm that t correct path has been reported?                                                                                                                                                                                                                                   | he                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|                                                                                                                                                                                                                                                                                                                                           | ••                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| · · · · · · · · · · · · · · · · · · ·                                                                                                                                                                                                                                                                                                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|                                                                                                                                                                                                                                                                                                                                           | ••                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|                                                                                                                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| the Correct Timing Report Switches                                                                                                                                                                                                                                                                                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| : Follow the below instructions.                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|                                                                                                                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| : Follow the below instructions.  Answer the following questions by experimenting and exploring in Prime Tim Use the job aid labelled "timing reports" for help identifying the appropria                                                                                                                                                 | ate                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| : Follow the below instructions.  Answer the following questions by experimenting and exploring in Prime Tim Use the job aid labelled "timing reports" for help identifying the appropria commands and switches.:  • Question 15: Write the command to generate a single timing report for the prime Time Time Time Time Time Time Time T | ate                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| : Follow the below instructions.  Answer the following questions by experimenting and exploring in Prime Tim Use the job aid labelled "timing reports" for help identifying the appropria commands and switches.:  • Question 15: Write the command to generate a single timing report for each path group for setup.                     | for                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|                                                                                                                                                                                                                                                                                                                                           | Generate another timing report for the same timing path for hold time but with fall transition at the end point (instead of a rise transition). Use copy and paste avoid mistyping the end point and start point pin names. Use the job aid labell "timing reports" to find the appropriate switches for report_timing.  • Question 13: Which lines in this report did you use to confirm that the correct path has been reported?  • Question 14: Was the guess correct - the faster fall delays results in faster data arrival time but a smaller hold time requirement and thus better slack? |



## Setting standards in VLSI Design

| •                                          | <b>Question 17:</b> What are the names of the two path groups that have violating timing paths in ORCA (the answer will come from the result of the previous question)?                                                                                     |
|--------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                            |                                                                                                                                                                                                                                                             |
| •                                          | <b>Question 18:</b> Write the command to generate a timing report with the worst slack for setup to any output port constrained by the clock PCI_CLK.                                                                                                       |
|                                            |                                                                                                                                                                                                                                                             |
| •                                          | Question 19: There are a few latches in ORCA; write the command to identify the data pins of these latches.                                                                                                                                                 |
|                                            |                                                                                                                                                                                                                                                             |
| •                                          | Question 20: Write the command to generate a timing report for hold to the D pin of the latched_cik_en_reg latches.                                                                                                                                         |
|                                            |                                                                                                                                                                                                                                                             |
| 3.5 Task 5 : Identify Ha                   | alf-Clock Cycle Paths                                                                                                                                                                                                                                       |
| in ORCA (i.e. it con edge triggered flip-f | clock SDRAM_CLK constrains many half clock cycle paths strains paths from a falling edge triggered flip-flop to a rising lop and vice versa). These paths must be carefully monitored e.g. the duty cycle of SDRAM_CLK is not yet well defined or ock skew) |
|                                            | e the following command to report the clock period for SDRAM CLK and information to answer the following questions:                                                                                                                                         |
|                                            | pt_shell> report_clock SDRAM_CLK                                                                                                                                                                                                                            |
| •                                          | Question 21: Given that the first number under the waveform column is the first rising edge for the clock SDRAM CLK and the second number is the falling edge - what duty cycle has been defined for this clock?                                            |
|                                            |                                                                                                                                                                                                                                                             |

.....





Launch Clock Edge

Rise 0ns
Fall 3.75ns

| •                  | timing report for                           | escribe the specific<br>setup for a timing po<br>the falling edge of | ath constrained by t |                     |
|--------------------|---------------------------------------------|----------------------------------------------------------------------|----------------------|---------------------|
|                    |                                             |                                                                      |                      |                     |
| •                  | -                                           | or this same timing used in a timing re                              | <b>U</b> 1           | •                   |
|                    |                                             |                                                                      |                      |                     |
| timing             | m the information reports for the ha M_CLK. | _                                                                    |                      |                     |
| Capture clock edge | Worst Setup<br>Slack                        | Launch clock edge                                                    | Capture clock edge   | Worst Hold<br>Slack |
| Fall 3.75ns        | 0.680ns                                     | Rise 7.5ns                                                           | Fall 3.75ns          | 3.558ns             |
| Rise 7.50ns        | 0.635ns                                     | Fall 3.75ns                                                          | Rise 0ns             | 3.514ns             |
| •                  |                                             | hich switch is usefu                                                 |                      | worst 10 timing     |
|                    |                                             |                                                                      |                      |                     |
| •                  | -                                           | ny does PrimeTime<br>eTime is using are<br>nmand).                   | •                    |                     |
|                    |                                             |                                                                      |                      |                     |
| •                  | <b>Question 23 :</b> W 10 timing paths?     | hat additional option                                                | on must you use to   | report the worst    |
|                    |                                             |                                                                      |                      |                     |
| ✓ Ouit Pı          | rimeTime.                                   |                                                                      |                      |                     |



## 4. Lab 04 - Constraining multiple clocks

**Objective:** To understand how to PrimeTime commands to gather information about the design clocks and use the GUI for another view of the design clocks.

Working Directory :/home/<user\_name> PD\_Labs/PT/Lab04
Relevant Files & Directories :
Lab04 : current working directory : Automatically read PT setup file orca\_savesession : Saved Session directory

orca\_savesession\_violations : Saved ORCA Session with an issue

RUN.tcl : Run script for ORCA scripts/orca\_pt\_variables.tcl : Run script for ORCA

#### **Learning outcomes:**

- ✓ How to use PT commands to get the information of clocks
- ✓ How to use GUI to view the design clocks

#### 4.1 Task 1 : Get to Know the Design Clocks

**Instructions**: Follow the below instructions and answer the given questions based on your observations after the execution of the relevant instructions.

- ✓ Make sure your current directory is Lab04.
- ✓ Invoke PrimeTime (pt shell) and restore the session saved in orca savesession.

| <b>Question 1 :</b> How many clocks are in this design and how many of these are generated? |
|---------------------------------------------------------------------------------------------|
|                                                                                             |
|                                                                                             |
| Question 2: Which input ports have defined, master clocks?                                  |
|                                                                                             |
| Question 3: Which output ports have defined, outgoing clocks?                               |
|                                                                                             |





| Question 5: Which 3 clock pairs have constrained timing paths?  4.2 Task 2: Use the GUI to Report Clock Relationships  Instructions: Follow the below instructions and answer the given questions based on your observations after the execution of the relevant instructions.  ✓ Start the GUI by executing the following command.                                                                                            |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <ul> <li>Instructions: Follow the below instructions and answer the given questions based on your observations after the execution of the relevant instructions.</li> <li>✓ Start the GUI by executing the following command.</li> </ul>                                                                                                                                                                                       |
| based on your observations after the execution of the relevant instructions.  ✓ Start the GUI by executing the following command.                                                                                                                                                                                                                                                                                              |
|                                                                                                                                                                                                                                                                                                                                                                                                                                |
| <pre>pt_shell&gt; start_gui</pre>                                                                                                                                                                                                                                                                                                                                                                                              |
| <ul> <li>Note: The original pt_shell session is still running in the terminal window. You can keep the GUI open and use either the shell or the GUI interface as appropriate to the desired tasks.</li> </ul>                                                                                                                                                                                                                  |
| ✓ Look at clock domain crossings: Open the "clock domain matrix" from the pull-down menu: Clock → Clock Analyzer.                                                                                                                                                                                                                                                                                                              |
| The ClockAnalyzer window that opens (expand if needed by clicking on the plus signs to the left of the clocks) should match the information from check timing when reporting the clock crossings in the design. Mouse over the blocks in the matrix to see information on what type of false paths exist. It is sometimes easier to digest this information as a graphical matrix table in comparison to the text output from. |
| <pre>pt_shell&gt; check_timing -override clock_crossing -verbose</pre>                                                                                                                                                                                                                                                                                                                                                         |
| The left part of the window lists each master clock and any generated clocks that are created from each master clock                                                                                                                                                                                                                                                                                                           |
| • Question 6: What is the master clock for SYS_2x_CLK?                                                                                                                                                                                                                                                                                                                                                                         |
|                                                                                                                                                                                                                                                                                                                                                                                                                                |



| • | Question 7: SYS_2x_CLK is defined on which pin/port (its "source")? (note: you may have to drag the clock matrix out of the way, exposing more columns of information about the clocks) |
|---|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|   |                                                                                                                                                                                         |
| • | Question 8: The master clock for SYS 2x CLK is defined on which pin/port?                                                                                                               |
|   |                                                                                                                                                                                         |

- ✓ Explore in more detail by displaying the clock schematic for SYS\_2x\_CLK: select the clock, then right mouse button + Schematic of Selected Clocks.

  Expand the fan-in for the schematic for the MUX called I\_CLOCK\_GEN/U20

  [Hint: To locate/highlight U20, use Select → By Name] by double-clicking the input stubs, as shown in the following screen captures.
- ✓ Continue the double clicks until the fain is exhausted [Example: an input port has been reached]





Double click the input pin stubs





|          | •                  | Question 9: What port is connected to the select pin of the MUX I_CLOCK_GEN/U20?                                                                                                                                                                                                    |
|----------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|          |                    |                                                                                                                                                                                                                                                                                     |
|          | •                  | Question 10: Does seeing the schematic give you insight into the clocking scheme for test?                                                                                                                                                                                          |
|          |                    |                                                                                                                                                                                                                                                                                     |
| <b>✓</b> | window,<br>Clocks. | clock relationships with the abstract clock graph: Close the schematic then, on the Top Level window, select Clock → Clock Graph for All If necessary, display a toolbar next to the schematic by pressing the F8 play various elements by checking the toolbar and pressing Apply. |
| <b>✓</b> | Find a pa          | air of muxed clocks: In the Abstract Clock Graph toolbar, select Mux c Apply.                                                                                                                                                                                                       |
| <b>\</b> |                    | bstract Clock Graph, find instance I_CLOCK_GEN/U10 of mx02d1. o locate/highlight U10, use Select → By Name].                                                                                                                                                                        |
|          | •                  | Question 11 : What clocks drive I_CLOCK_GEN/U10?                                                                                                                                                                                                                                    |
|          |                    |                                                                                                                                                                                                                                                                                     |
| <b>√</b> |                    | the clock graph window, 'zoom into' an interesting object by displaying atic for it: Select I_CLOCK_GEN/U10, then Schematic → Schematic                                                                                                                                             |
|          | •                  | <b>Question 12 :</b> What port drives the select line to I_CLOCK_GEN/U10?                                                                                                                                                                                                           |
|          |                    |                                                                                                                                                                                                                                                                                     |
| <b>\</b> | Go back            | to the Abstract Clock Graph.                                                                                                                                                                                                                                                        |
|          | •                  | <b>Question 13:</b> From the abstract clock graph window, is it possible to open and display the same clock schematic for SYS_2x_CLK you displayed in the clock analyzer [Right Click on SYS_2X_CLK and find the option?                                                            |
|          |                    |                                                                                                                                                                                                                                                                                     |



- Close the Clock Analyzer window by clicking on the small "X" in its upper right corner.
- ✓ Close the Clock Schematic and Clock Analyzer windows by clicking on the small "X" in the upper right corner.

#### 4.3 Task 3: Use the GUI to explore detail of timing paths

**Instructions**: Investigate paths between launch and capture clocks - in this case. you will look at network latency for the launch and capture paths clocked by SYS CLK.

✓ Propagate all the clocks to have the clock network delays calculated by Primetime before examining paths, by executing these commands in the shell, which remains open behind the GUI (this will take a minute or so to complete). Tell PrimeTime to save the arrival times for all pins (this is what you will examine. Then, define a collection of timing paths to examine.

✓ Enter your collection of violating paths from the pull-down menu Timing → Path Analyzer.



Enter your collection of timing paths and click on apply



✓ Bring up a histogram of your ten timing paths.



✓ From the histogram, bring up the Path Inspector on a selected path.



Select the set of paths with the worst slack by left clicking the leftmost bar



#### Get pins PrimeTime - MainWindow. Get cells File View Select Highlight Re er Clock Schematic ECO Wind Get nets 2223 5 C 🛂 🛣 📝 Find related timing paths TimingStatus.1 × 🛅 Cloc PathAnalyzer.1 × **ii** Path Get timing points ningPaths Histogram Get startpoints 2 Get endpoints **FimingPaths** Get launch clock paths Get capture clock paths 1 Create Collection ... Trim Collection ... Report -0.96 I-0.9 -0.68 I-0.64 I-0.6 -0.56 -1.04 1-1 Schematic slack Inspector Enter filter expression 🔚 Cross Prob slack startpoint -0.987 I ORCA TOP/I DER/s4 op2 reg[31]/D Select the worst path, then click on inspector Export

✓ In the Path Inspector, examine clock reconvergence pessimism: In the data required and data arrival section, scroll down until you find CRP. Then, scroll across until you find the percent of delay for the CRP.







| • | <b>Question 14:</b> What percent of the capture delay comes from CRP? |
|---|-----------------------------------------------------------------------|
|   |                                                                       |
|   |                                                                       |
| • | Question 15: Is this percent representative of all designs?           |
|   |                                                                       |
|   |                                                                       |
|   |                                                                       |

✓ Look at a schematic of the path by clicking on the Path Schematic tab on the bottom of the path inspector window.



- ✓ In the schematic window, find the CRP (clock reconvergence pessimism) point. This is the last pin before the launch and capture paths diverge.
  - Note: Mouse "gestures" or "strokes" are available for easier zooming: While pressing the middle mouse button drag the cursor vertically for 'zoom full'; Drag diagonally up across an object to zoom in, and down across an object to zoom out.
- ✓ To see arrival times on this pin, if necessary, you may have to first 'expand the pin's buffer. (PrimeTime may 'collapse' buffer trees into a single buffer).





| ✓ | View the arrival times (and any other attributes of interest) by selecting the          |
|---|-----------------------------------------------------------------------------------------|
|   | output pin of the buffer just before the register, then by selecting View $\rightarrow$ |
|   | Property [and by changing the list from being the default "Basic" to the                |
|   | "Application"].                                                                         |
|   |                                                                                         |

| • | <b>Question 16:</b> How wide is the arrival window for thee buffer output pin?                                    |
|---|-------------------------------------------------------------------------------------------------------------------|
|   |                                                                                                                   |
| • | Question 17: Does this match what we saw earlier in the data arrival data required section of the path inspector? |
|   |                                                                                                                   |
|   | e the path waveform: Click on the Waveform tab at the bottom of the pector window.                                |
| • | <b>Question 18:</b> What can you add to the waveforms by clicking the right mouse button in the waveform window?  |
|   |                                                                                                                   |
|   |                                                                                                                   |

Close the GUI while keeping the original pt\_shell session going in the terminal

window.



pt\_shell> stop\_gui (In the pt\_shell window)
or
File -> Close GUI (in the main GUI window)

✓ Exit PrimeTime

#### 4.4 Task 4: Report a False Violation

**Instructions**: Follow the below instructions and answer the given questions based on your observations after the execution of the relevant instructions.

- ✓ Bring up PrimeTime and restore the saved session orca\_savesession\_violations
- ✓ Determine the number and type of timing violations in ORCA:

- Question 19: How many, and what kind of violations does ORCA have?
   Generate a "short" timing report for the worst slack for an out\_setup timing checks
   Question 20: How will you identify the endpoint port which has the worst slack for out\_setup (use the job aid labeled "Timing Reports" for help recalling the two appropriate switches)?
   Question 21: Which clocks (launch and capture are involved in this
  - **Note:** From task 1, you know that SD\_DDR\_CLK is a generated clock defined at an output port. The purpose of defining outgoing clocks is that Prime Time calculates source latency for this clock and include this latency as part of the data required time.

.....

✓ Look at the data required time section of the timing report from the last step and notice that no clock latency is reported. Confirm this with the following command:

violation?



# This report will return nothing as Primetime
has not calculated source latency for SD\_DDR\_CLK

Question 22: Why has PrimeTime not calculated source latency for the

pt shell> report clock -skew SD DDR CLK

|                                                                                                                                                                                                                                        | •••• |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|
|                                                                                                                                                                                                                                        |      |
| <ul> <li>Note: After speaking with the designer, it turns out there wa<br/>miscommunication. The designer was expecting you to turn on a varia<br/>that will propagate all clocks!</li> </ul>                                          |      |
| ✓ There is a variable that can be used to make all clocks propagated. Use the Temprocedure a to help you identify the appropriate variable:                                                                                            | 1    |
| aa propagate                                                                                                                                                                                                                           |      |
| Question 23 : What is the name of this variable?                                                                                                                                                                                       | •••• |
| Question 24: Using a man page, explain what this variable will do?                                                                                                                                                                     | •••• |
| ✓ Use the man page for check_timing to find the name of the additional check the will flag all ideal clocks. The following command opens the man page in a positive up window with a scroll bar that simplifies viewing long reports.: |      |
| pt_shell> vman check_timing                                                                                                                                                                                                            |      |
|                                                                                                                                                                                                                                        |      |

**Note:** The above command is an allas created in the synopsys\_pt.setup file. It uses a command called view that is available on SolvNetPlus, Doc

**Note:** The alias vman will not work if the "wish" executable, the main executable in the Tk package, is not installed and made available in your

Id 000006678.

lab environment





| Question 25: How will you modify check timing to add a check to |
|-----------------------------------------------------------------|
| validate that all clocks are propagated?                        |
| 1 1 0                                                           |
|                                                                 |
| ••••••                                                          |
|                                                                 |
| •••••                                                           |
|                                                                 |
|                                                                 |

✓ Quit PrimeTime

#### 4.5 Task 5: Re-Execute the Run Script to reduce violation

**Instructions**: Follow the below instructions and answer the given questions based on your observations after the execution of the relevant instructions.

- ✓ You are provided with the file ./scripts/orca\_pt\_variables.tcl that will accomplish the following two things.
  - Adds to the default checks performed by check timing the check that will flag ideal clocks.
  - All created clocks will be created as propagated clocks.
- ✓ Execute the run script. /RUN.tcl from the lab4 clocks Unix directory. Log the results to the log file run.log.:

- ✓ Invoke PrimeTime and restore the newly saved session in the Unix directory orca\_savesession
- ✓ Use the appropriate commands to confirm the information below:
  - The out setup violations have been reduced.
  - All clocks are propagated.
  - Execute check\_timing to confirm it is performing its default checks in addition to the check for ideal clocks
  - The source latency is now calculated for SD DDR CLK.
  - The timing report to sd\_DQ [3] includes this calculated source latency.
  - There will be additional violations (more setup violations as well as out hold violations) that you can ignore.
- ✓ Quit Prime Time.



## 5. <u>Lab 05 – Additional Constraints</u>

**Objective :** To understand how to add additional constraints apply user specified annotated delays to explore time borrowing with latches.

Working Directory :/home/<user name>PD Labs/PT/Lab05

**Relevant Files & Directories :** 

Lab04 : current working directory

.synopys\_pt.setup : Automatically read PT setup file

orca\_savesession: Saved Session directorylogs/: log files from run scriptRUN.tcl: Run script for ORCA

#### **Learning outcomes:**

- ✓ How to apply user specified annotated delays.
- ✓ How to debug PTE-070 messages

#### 5.1 Task 1 : Debug PTE-070 Information Messages

**Instructions**: Follow the below instructions and answer the given questions based on your observations after the execution of the relevant instructions.

✓ Invoke PrimeTime from the lab5 additional Unix directory.

```
Lab04]$ pt shell - RUN.tcl | tee -i run.log
```

Shown below is the full message regarding a non-unate path on the clock network. In the next step, you will be asked to generate a timing report through this pin. In order to copy and paste and avoid typos - either find this message in the log file from another terminal window or use the Uni command grep from within PrimeTime as shown.

```
# From ./ run. log
Information: A non-unate path in clock
network detected.
Propagating both inverting and noninverting
senses of clock 'SDRAM CLK' from pin
'I _ORCA_ TOP/I_SDRAM_IF/sd mux dq_out_0/Z'.
(PTB-070)
```

```
pt_shell> sh grep -A1 -B 1 PTE-070 run.log
```

• **Note :** The command sh (or alternatively exec) allows you to execute Unix commands from within the PrimeTime shell.



✓ Generate a timing report for setup through the above pin and answer the following questions.

#### pt\_shell> report\_timing -input -through <through pin>

| • | <b>Question 1:</b> Which lines in the timing report did you use to validate it is for setup and the timing path start point is the source for the clock SDRAM CLK?                                                         |
|---|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|   |                                                                                                                                                                                                                            |
| • | Question 2: How does this timing report confirm that the pin in the warning above is on a data path (i.e. a clock source being used and constrained as a data path) and not on a clock path?                               |
|   |                                                                                                                                                                                                                            |
| • | <b>Question 3:</b> Which sense is propagated through the above pin (i.e. positive unate or negative unate)? Look for a small arrow in the timing report which will locate the specific pin of interest.                    |
|   |                                                                                                                                                                                                                            |
|   | e at least one additional timing report to show the use of a negative unate rc through the pin of interest.                                                                                                                |
| • | Question 4: Which lines in the timing report did you use to validate it is for setup, the timing path start point is the source for the clock SDRAM_CLK and that the timing arc is negative unate for the pin of interest? |
|   |                                                                                                                                                                                                                            |
|   |                                                                                                                                                                                                                            |

### 5.2 Task 2: Explore Time Borrow and Latches

✓ Do not quit PrimeTime.

**Instructions**: Follow the below instructions and answer the given questions based on your observations after the execution of the relevant instructions.

✓ There is only one latch in this design. Use the following commands to find it. Take advantage of command and option completion with the tab key.



pt shell> all\_registers -level\_sensitive
pt\_shell> !! -clock\_pin
pt\_shell> all\_registers -level\_sensitive -data\_pins

| 3116 | :11> a.              | II_registers -level_sensitive -data_pins                                                                                                                                                                                                                                                                    |
|------|----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      | •                    | Question 5: What is the name of the clock pin for this latch?                                                                                                                                                                                                                                               |
|      |                      |                                                                                                                                                                                                                                                                                                             |
|      |                      |                                                                                                                                                                                                                                                                                                             |
|      | •                    | Question 6: What are the names of the three data pins?                                                                                                                                                                                                                                                      |
|      |                      |                                                                                                                                                                                                                                                                                                             |
| ✓    | the cloc<br>this tim | te a timing report starting at the latch for setup time (be specific by using the pin as the start point and not just the cell name!). This lab will refer to ing report as "path segment #2*. The function of this latch in the ORCA is to generate a clock gating signal to turn on and off the clock LK. |
|      | •                    | <b>Question 7:</b> Describe how you know this latch is not experiencing time borrow from the previous stage?                                                                                                                                                                                                |
|      |                      |                                                                                                                                                                                                                                                                                                             |
| ✓    | report a             | te a timing report for the previous stage (this lab will refer to this timing s "path segment #1*). Use the D input pin of the latch as the end point or ing path.                                                                                                                                          |
|      | •                    | <b>Question 8 :</b> How much more time can path segment #1 take before would start borrowing time from path segment #2?                                                                                                                                                                                     |
|      |                      |                                                                                                                                                                                                                                                                                                             |
| ✓    |                      | ath segment #1 to borrow time from path segment #2 by annotating a net f 4ns as shown below:                                                                                                                                                                                                                |
| Us   | e cut                | and paste to avoid typos on the pin name                                                                                                                                                                                                                                                                    |
|      |                      |                                                                                                                                                                                                                                                                                                             |

pt\_shell> set\_annotated\_delay -net 4 \
-to \_ORCA\_TOP/I\_BLENDER/latched\_clk\_en\_reg/D





| ✓ | Generate the timing report for path segment #1 again (take advantage of the up |
|---|--------------------------------------------------------------------------------|
|   | and down arrows to scroll through the history event list).                     |

|   | •      | <b>Question 9 :</b> How much time is path segment #1 borrowing from path segment #2? |
|---|--------|--------------------------------------------------------------------------------------|
|   |        |                                                                                      |
|   |        |                                                                                      |
|   | •      | Question 10: What is the slack for path segment #1?                                  |
|   |        |                                                                                      |
| ✓ | Re-gen | erate the timing report for path segment #2.                                         |
|   | •      | <b>Note</b> : The start point of the timing path will now be the D pin of the        |

latch (not the clock pin as used before because you are interested in reporting the timing path that includes time borrow.

```
pt_shell> report_timing -from \
    I_ORCA_TOP/I_BLENDER/latched_clk_en_reg/D
```

| expectations? | Question 11:  | Does the time a | given to path segr                      | nent #1 now match |
|---------------|---------------|-----------------|-----------------------------------------|-------------------|
|               | expectations? |                 |                                         |                   |
|               | <br>-         |                 |                                         |                   |
| •••••         |               |                 |                                         |                   |
|               | <br>          | •••••           | • • • • • • • • • • • • • • • • • • • • |                   |
|               |               |                 |                                         |                   |

✓ Change the latch behaviour for transparency; that is, make it transparent when data arrives between the opening and closing edges of the cock.

```
pt_shell> set_app_var timing_enable_through_paths true
```

✓ Repeat your timing report to the latch D pin. Notice that, even though the latch is transparent, you can still specify the D pin as an endpoint.

pt\_shell> report\_timing -to \
 I ORCA TOP/I BLENDER/latched clk en reg/D



## **VLSI Training Services**Setting standards in VLSI Design

| •          | <b>Question 12:</b> What is the start point?                 |
|------------|--------------------------------------------------------------|
|            |                                                              |
|            |                                                              |
|            |                                                              |
|            |                                                              |
| ✓ Do a tim | ning report FROM the start point you just identified.        |
| - <b>-</b> | report_timing -from \ A_TOP/I_PARSER/blender_clk_en_reg/CP   |
|            |                                                              |
| •          | <b>Question 13:</b> What is the path endpoint?               |
|            | Question 10 1 What is the path enapoint.                     |
|            |                                                              |
|            |                                                              |
|            |                                                              |
| •          | Question 14: What are the transparency open and close edges? |
|            |                                                              |
|            |                                                              |
|            | •••••                                                        |
| •          | <b>Question 15:</b> Did data arrive between them?            |
|            |                                                              |
|            |                                                              |
|            | •••••                                                        |
| •          | Question 16: Was there time borrowing?                       |
|            |                                                              |
|            |                                                              |
|            | •••••                                                        |
| •          | <b>Question 17:</b> Was the slack positive?                  |
|            |                                                              |
|            |                                                              |
|            |                                                              |
|            |                                                              |
| ✓ Quit Pri | meTime.                                                      |