

# **Vivado Design Suite Tutorial**

## **Creating and Packaging Custom IP**

UG1119 (v2020.2) February 4, 2021





# **Revision History**

The following table shows the revision history for this document.

| Section                   | Revision Summary              |  |  |
|---------------------------|-------------------------------|--|--|
| 02/04/2021 V              | ersion 2020.2                 |  |  |
| General updates           | Validated for release 2020.2. |  |  |
| 06/24/2020 Version 2020.1 |                               |  |  |
| General updates           | Validated for release 2020.1. |  |  |





# Table of Contents

| Revision History                                 | 2  |
|--------------------------------------------------|----|
| Introduction to Creating and Packaging Custom IP | 5  |
| Introduction                                     | 5  |
| Software Requirements                            | 5  |
| Tutorial Design Description                      | 5  |
| Locating Tutorial Design Files                   | 6  |
| Lab 1: Packaging a Project                       | 7  |
| Introduction                                     | 7  |
| Step 1: Open the Vivado Project                  | 7  |
| Step 2: Preparing Design Constraints             | 8  |
| Step 3: Package the IP                           |    |
| Step 4: Modify the IP Definition                 | 17 |
| Step 5: Add a Product Guide to the IP            | 19 |
| Step 6: Review and Package the IP                | 22 |
| Step 7: Validate the New IP                      | 23 |
| Conclusion                                       | 29 |
| Lab 2: Packaging a Specified Directory           | 30 |
| Introduction                                     |    |
| Step 1: Examine the IP Directory                 |    |
| Step 2: Create a New Vivado Project              | 31 |
| Step 3: Package the IP Directory                 |    |
| Step 4: Examine and Update the Packaged IP       | 33 |
| Step 5: Validate the Custom IP                   |    |
| Conclusion                                       | 38 |
| Lab 3: Packaging Legacy IP                       | 40 |
| Introduction                                     |    |
| Step 1: Create a New Vivado Project              | 40 |
|                                                  |    |
| Step 2: Package a Library Core                   |    |



| Step 4: Validate the New Custom IP                 | 50 |
|----------------------------------------------------|----|
| Conclusion                                         |    |
| Lab 4: Packaging IP in a Revision Source (Trunk)   |    |
| Introduction                                       | 53 |
| Step 1: Examine the Repository Trunk Directory     | 53 |
| Step 2: Create a New Vivado Project                | 54 |
| Step 3: Package the Library Core                   | 55 |
| Step 4: Package the IP                             | 58 |
| Step 5: Validate the IP                            | 65 |
| Conclusion                                         | 66 |
|                                                    |    |
| Appendix A: Additional Resources and Legal Notices | 68 |
| Xilinx Resources                                   | 68 |
| Documentation Navigator and Design Hubs            | 68 |
| References                                         | 69 |
| Please Read: Important Legal Notices               | 70 |





# Introduction to Creating and Packaging Custom IP

### Introduction

This tutorial takes you through the required steps to create and package a custom IP in the Vivado<sup>®</sup> Design Suite IP packager tool.

The Vivado Design Suite provides an IP-centric design flow that helps you quickly turn designs and algorithms into reusable IP. The Vivado IP catalog is a unified IP repository that provides the framework for the IP-centric design flow. This catalog consolidates IP from all sources including Xilinx<sup>®</sup> IP, third-party IP, and end-user designs targeted for reuse as IP into a single environment.

The Vivado IP packager is a unique design reuse feature, which is based upon the IP-XACT standard. The IP packager provides you with the ability to package a design at any stage of the design flow and deploy the core as system-level IP.

See the Vivado Design Suite User Guide: Creating and Packaging Custom IP (UG1118) for more information about the Vivado IP packager.

**VIDEO:** You can also learn more about the creating and using IP cores in Vivado Design Suite by viewing the quick take videos: Configuring and Managing Custom IP.

### **Software Requirements**

See the Vivado Design Suite User Guide: Release Notes, Installation, and Licensing (UG973) for a complete list and description of the system and software requirements.

### **Tutorial Design Description**

The small sample design used in this tutorial has a set of RTL design sources consisting of Verilog files, along with a PDF that describes how to add a document file to your IP.



### **Locating Tutorial Design Files**

- 1. Download the design files from the Reference Design Files on the Xilinx website.
- 2. Extract the zip file contents into any write-accessible location.





Lab 1

# Packaging a Project

### Introduction

In this lab, you define a new custom IP from an existing Vivado<sup>®</sup> project, using the Create and Package IP wizard.

You start with an existing design project in the Vivado IDE, define identification information for the new IP, add documentation to support its use, and add the IP to the IP catalog.

After packaging, you verify the new IP through synthesis in a separate design project.

The lab project contains Verilog source files for a simple UART interface.

### **Step 1: Open the Vivado Project**

- 1. Launch the Vivado<sup>®</sup> IDE.
  - On Linux:
    - Change to the directory where the lab materials are stored: cd <Extract\_Dir>/ lab\_1.
    - Launch the Vivado Design Suite IDE: vivado.
  - On Windows:
    - Launch the Vivado Design Suite IDE:

Select Start  $\rightarrow$  All Programs  $\rightarrow$  Xilinx Design Tools  $\rightarrow$  Vivado 2020.x  $\rightarrow$  Vivado 2020.x.

Or

Click the Vivado 2020.x desktop icon to start the Vivado IDE.

The Vivado IDE Getting Started page displays with links to open or create projects, and to view documentation. For either Windows or Linux, continue the lab from this point.

2. Click Open Project, and browse to: <Extract\_Dir>/lab\_1.

Note: Your Vivado Design Suite installation might have a different name on the Start menu.



3. Select the my\_simple\_uart.xpr project and click OK.

The design loads, and you see the Vivado IDE in the default layout view, with the Project Summary information as shown in the following figure.

| in Edt Now Icols Anopeti                                                                                       | Thursd ration Tan Hab                                                                   | NOT RELEASE                                               |                                                                                                                   |                                                            | Ready                                                                                                                       |
|----------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------|-----------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------|
| A = 0 0 X ▶.                                                                                                   | # O X # # X                                                                             |                                                           |                                                                                                                   |                                                            | II Default Layout                                                                                                           |
| ow Navigator 0.0.7.                                                                                            | PROJECT MANAGER - my_umple_uart                                                         |                                                           |                                                                                                                   |                                                            | 7                                                                                                                           |
| PROJECT MANAGER                                                                                                | Sources 7 _ 0 0                                                                         | × Project Summary                                         |                                                                                                                   |                                                            | 100                                                                                                                         |
| The second s | 9 2 9 4 2 9 4                                                                           | Overview   Dashboar                                       | d                                                                                                                 |                                                            |                                                                                                                             |
| Add Sources<br>Language Templates                                                                              | <ul> <li>Design Sources (1)</li> <li>A saint top (usit, fop.v) (2)</li> </ul>           | Settings Edit                                             |                                                                                                                   |                                                            |                                                                                                                             |
| O # Catalog                                                                                                    | > to Constraints (1)<br>> to Serulation Sources (1)                                     | Project name                                              | my_smple_uart                                                                                                     |                                                            |                                                                                                                             |
| P syllegration<br>Create Block Design                                                                          | > 🗄 Utility Sources                                                                     | Project location<br>Product family<br>Project parts       | Aug1119-shade-creating packaging o<br>Kintex-7<br>wc7x325tfg800-2                                                 | p-design/tab_1                                             |                                                                                                                             |
| Open Block Design                                                                                              |                                                                                         | Top module name:                                          | uwt_top                                                                                                           |                                                            |                                                                                                                             |
| Generate Block Design                                                                                          | Herarchy Libraries Compile +                                                            | Target language<br>Senulator language                     | VHDL<br>Mored                                                                                                     |                                                            |                                                                                                                             |
| SMALATION                                                                                                      | Properties 7 _ D D                                                                      |                                                           |                                                                                                                   |                                                            |                                                                                                                             |
| Run Simulation                                                                                                 |                                                                                         | Synthesis                                                 |                                                                                                                   | Implementation                                             |                                                                                                                             |
| RTL ANALYSIS<br>> Open Baborated Design                                                                        | Salect an object to see properties                                                      | Status<br>Messages<br>Part<br>Strategy<br>Report Strategy | Not started<br>No errors or warrings<br>xc7k3258fg900-2<br>Vivado Synthesis Defaults<br>Vivado Synthesis Defaults | Status<br>Messages<br>Part:<br>Strategy<br>Report Strategy | Not started<br>No errors or warnings<br>xc?ki256fg906-2<br>Vivado Implementation Defaults<br>Vivado Implementation Defaults |
| svintHesis<br>Ir Run Sjinthesis                                                                                |                                                                                         | incremental synthesis                                     |                                                                                                                   | Incremental implementations                                | None                                                                                                                        |
| <ul> <li>Open Synthesized Design</li> </ul>                                                                    | Til Console Messages Log I                                                              | Design Burgs                                              |                                                                                                                   |                                                            | 7 - 0 0                                                                                                                     |
| Replacementation                                                                                               | Incorporation and a contraction of the second                                           | + %                                                       |                                                                                                                   |                                                            | 7 = 6 3                                                                                                                     |
| <ul> <li>Open implemented besign</li> </ul>                                                                    | Name Constraints Status<br>-> synth_1 constra_1 Not star<br>> impl 1 constra_1 Not star | ted                                                       | es TPWS Total Power Failed Rout                                                                                   | es LUT FF BRAN URAM C                                      | SP Start Elapsed Run Strategy<br>Wado Synthesis D<br>Wado Implementa                                                        |
| PROGRAM AND DEBUG                                                                                              | a second a second                                                                       |                                                           |                                                                                                                   |                                                            | trade approximate                                                                                                           |
| E Generate Bititream                                                                                           |                                                                                         |                                                           |                                                                                                                   |                                                            |                                                                                                                             |

### **Step 2: Preparing Design Constraints**

The existing design includes timing constraints defined in an XDC file (uart\_top.xdc). These constraints were defined for the UART design as a standalone design. However, when packaged as an IP, the design inherits some of the needed constraints from the parent design. In this case, you must modify the XDC file to separate constraints the IP requires when used in the context of a parent design, and the constraints the IP requires when used out-of-context (OOC) in a standalone capacity. This requires splitting the current XDC file. You should prepare the design constraints prior to packaging the design for inclusion in the IP catalog; however, you can also perform these steps after packaging the IP.

**IMPORTANT!** The Vivado tools create a synthesized design checkpoint (DCP) as part of the default Outof-Context (OOC) design flow for IP packaging and use.

To ensure that the packaged IP functions properly in the default OOC design flow, the IP packaging must include a standalone XDC file to define all external clocking information for the IP.

Vivado synthesis uses the standalone XDC file in the OOC synthesis run to constrain the IP to the recommended clock frequency.

When used in the context of a top-level design, the parent XDC file provides the clock constraints and the standalone OOC XDC file is not needed.

For more information on the OOC design flow, and the use of the DCP file, see the Vivado Design Suite User Guide: Designing with IP (UG896).



**TIP:** Depending on the function and use of the packaged IP, you might need to adjust the design constraints to ensure proper scoping, For more information, see "Constraints Scoping" in the Vivado Design Suite User Guide: Using Constraints (UG903).

### **Analyze the Current Constraints Files**

1. In the Hierarchy pane of the Sources window, open the target XDC file (uart\_top.xdc) under the Constraints folder, as shown in the following figure:



There are two items to take note of in the XDC file, as seen above.

- create\_clock constraints (lines 1 and 2)
- set\_max\_delay constraint relying on the clock object period value (line 14).

**Note:** The line numbers referenced in the above figure might differ from the line numbers in your XDC file because the constraints were edited for easier viewing in this tutorial.

2. Examine all create\_clock constraints prior to packaging the new IP definition.

If the created clock is internal to the IP (GT), or if the IP contains an input buffer (IBUF), the create\_clock constraint should stay in the IP XDC file because it is necessary to define local clocks.

In the next sub-step, you move clocks that are not internal, or local, to the IP from the IP XDC file to an OOC XDC file, because the parent design provides the clock.

For this example, you move the create\_clock constraints on line 1 and 2 from the design XDC file to an OOC XDC file. When a user instantiates the IP you are packaging from the IP catalog into a design, the IP inherits the clock definitions from the parent design.



The set\_max\_delay constraint is also noteworthy in that it has a dependency on the PERIOD property of defined clocks, (get\_clocks -of\_objects). This dependency is affected by the order of processing of the constraints of the IP and top-level design.

By default, when IP customizations are instantiated into a design, the Vivado<sup>®</sup> IDE processes the XDC files of an IP before the XDC files of the top-level design. This is known as EARLY processing, and is defined by the PROCESSING ORDER property on the XDC file.

By default, the XDC files of the top-level design are marked for NORMAL processing. This means that the processing of XDC files for IP constraints happens before the top-level design constraints created by the user.

In the case of the set max delay constraint, the dependency on the clock PERIOD will cause errors in processing the IP constraints early and defining the clock later.

To resolve this issue, mark the XDC files of the UART IP for LATE processing.

#### **TIP:** Xilinx<sup>®</sup> delivered IP with $\_clock$ appended to the XDC filename are all marked for LATE processing.

### Creating an Out-Of-Context (OOC) XDC file

1. From the Flow Navigator, or from the File menu, select Add Sources.

The Add Sources dialog box opens.

- Select Add or create constraints, and click Next.
- 3. In the Add or Create Constraints dialog box, click Create File.
- 4. In the Create Constraints File dialog box, fill in the constraints file information, as shown in the figure below:
  - File type: XDC
  - File name: uart\_top\_ooc.xdc
  - File location: <Local to Project>
- 5. Click OK.





| 🝌 Create Consti            | raints File                        | ×   |
|----------------------------|------------------------------------|-----|
| Create a new co<br>project | onstraints file and add it to your | 4   |
| <u>F</u> ile type:         | ■ XDC                              | ~   |
| F <u>i</u> le name:        | uart_top_ooc.xdc                   | ⊗   |
| Fil <u>e</u> location:     | <local project="" to=""></local>   | ~   |
| ?                          | ОК Сап                             | cel |

**TIP:** For Xilinx-delivered IP, the out-of-context XDC file has \_000 appended to the filename; however, it is the USED\_IN property of the file that determines if it is an OOC XDC file, not the filename.

6. Click **Finish** to complete the Add Sources dialog box.

The Vivado<sup>®</sup> tools create a new XDC file in the project and displays the file under the Constraints section in the Hierarchy pane of the Sources window.

You now move the create\_clock constraints from the XDC file of the original design (uart\_top.xdc) into the OOC XDC file (uart\_top\_ooc.xdc).

- 7. In the Sources window, open the new OOC XDC file (uart\_top\_ooc.xdc) by doubleclicking the file. The file is empty.
- 8. Cut and paste the create\_clock constraints, from lines 1 and 2 of the IP XDC file (uart\_top.xdc) into the empty OOC XDC file.

The OOC XDC file contains only the two create\_clock constraints.

| Project Summary × uart_top.xdc * × uart_top_ooc.xdc * × | ? 🗆 🖸 |
|---------------------------------------------------------|-------|
|                                                         | •     |
| 1 create_clock -period 5.000 [get_ports rx_clk]         | ^     |
| 2 create_clock -period 6.000 [get_ports tx_clk]         |       |
|                                                         |       |
|                                                         |       |
|                                                         |       |
|                                                         |       |
|                                                         |       |
|                                                         |       |
|                                                         | ~     |
| <                                                       | >     |

9. Right-click in the text area and select Save All Files.

This saves both XDC files that are currently open.

10. Check to be sure that the create\_clock commands are removed from the IP XDC file (uart\_top.xdc), and save the file.



The create\_clock constraints are not necessary because parent design defines the clocks. The IP XDC file should now only contain the constraints, as shown in the following figure. The OOC XDC file defines the clocks needed for standalone processing.



11. Close the two open XDC files.

With the OOC and IP XDC files defined, you must set the USED\_IN and PROCESSING\_ORDER properties on the XDC files so that the Vivado tools processes the constraint files for the IP correctly.

12. In the Hierarchy pane of the Sources window, select the OOC XDC file (uart\_top\_ooc.xdc) listed under the Constraints section.

The Source File Properties window displays the file automatically.

13. In the Properties pane of the Source File Properties window, scroll down to find the Used In selection, shown in the figure below.

| Source File Properties    | ? _ D @ X            |
|---------------------------|----------------------|
| uart_top_ooc.xdc          | ←   →   ✿            |
| Q ≚ ≑ €                   | + - 6 2+             |
| NEEDS_REFRESH             | ^                    |
| PATH_MODE                 | RelativeFirst 🗸      |
| PROCESSING_ORDER          | NORMAL 🗸             |
| SCOPED_TO_CELLS           |                      |
| SCOPED_TO_REF             |                      |
| USED_IN                   | synthesis, impleme ⊡ |
| USED_IN_IMPLEMEN          |                      |
| USED_IN_SYNTHESIS         | <ul> <li></li> </ul> |
| General <b>Properties</b> |                      |



The Make Selection dialog box opens.

14. Select **out\_of\_context** in the unused values and select the **Move Right** button **>**, to add the value to the USED\_IN property, shown in the following figure.

| 🝌 Make Selection                                                          |                                                                               | ×                |
|---------------------------------------------------------------------------|-------------------------------------------------------------------------------|------------------|
| Unused values: 32                                                         | Selected values: 3                                                            |                  |
| ipstatic<br>iptraffic<br>opt_design<br>opt_design_post<br>phys_opt_design | <ul> <li>synthesis</li> <li>implementation</li> <li>out_of_context</li> </ul> | ↑<br>↓<br>↑<br>± |
|                                                                           | OK Cancel                                                                     |                  |

15. (Optional) You can adjust the USED\_IN property in the Tcl Console. To set the USED\_IN property of the OOC XDC file to include the "out\_of\_context" using the following Tcl command:

set\_property USED\_IN {synthesis implementation out\_of\_context}\
[get\_files uart\_top\_ooc.xdc]

16. When the USED\_IN property includes the out\_of\_context setting, the XDC file is only used for synthesis or implementation in out-of-context (OOC) runs (-mode out\_of\_context).

**IMPORTANT!** The USED\_IN property for an OOC XDC file should be {synthesis implementation out\_of\_context}. If it is just OOC, it is not used during synthesis or implementation

### Setting the Processing Order for the IP XDC

- 1. In the Hierarchy pane of the Sources window, select the IP XDC file (uart\_top.xdc) listed under the Constraints section.
- 2. In the Source File Properties window, scroll down and change the PROCESSING\_ORDER property value to **LATE**, as shown in the following figure.





| Source File Properties    | ? _ D @ X                  |
|---------------------------|----------------------------|
| uart_top.xdc              | <b>←</b>   ⇒   <b>⊅</b>    |
| Q   ¥   ♦   €   +         | - 0 2+                     |
| CLASS                     | file                       |
| CORE_CONTAINER            |                            |
| FILE_TYPE                 | XDC 🗸                      |
| IMPORTED_FROM             | C:/Tutorials/workspace/u   |
| IS_AVAILABLE              | ~                          |
| IS_ENABLED                | $\checkmark$               |
| IS_GENERATED              |                            |
| IS_GLOBAL_INCLUDE         |                            |
| LIBRARY                   | xil_defaultlib 🖉           |
| NAME                      | C:/Tutorials/workspace/ug1 |
| NEEDS_REFRESH             | ~                          |
| PATH_MODE                 | RelativeFirst 🗸            |
| PROCESSING_ORDER          | LATE                       |
| SCOPED_TO_CELLS           | EARLY                      |
| SCOPED_TO_REF             | NORMAL                     |
| USED_IN                   | LATE                       |
| USED_IN_IMPLEMENTA1       | $\checkmark$               |
| USED_IN_SYNTHESIS         | $\checkmark$               |
| General <b>Properties</b> |                            |

You could also change the property value in the Tcl Console with the following Tcl command:

set\_property PROCESSING\_ORDER LATE [get\_files uart\_top.xdc]

After completing the above steps, the XDC files are correctly prepared for packaging and the OOC design flow.

### Step 3: Package the IP

After setting up the design and supporting constraint files, the next step is to create and package the new IP Definition, and add it to the IP catalog.

1. From the Tools menu, select the **Create and Package New IP** command to open the Create and Package IP Wizard.

The Welcome window opens for the Create and Package New IP dialog box.

2. Click Next.





The Create and Package new IP dialog box opens, as shown in the following figure.

| 🝌 Create and Package New | IP                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | × |
|--------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|
| VIVADO.                  | Create and Package New IP<br>This wizard can be used to accomplish following tasks:                                                                                                                                                                                                                                                                                                                                                                                                                       |   |
|                          | <ul> <li>Package a new IP for the Vivado IP Catalog</li> <li>This wizard will guide you through the process of creating a new Vivado IP using source files and information from your current project, block design or specified directory.</li> <li>Create a new AXI4 Peripheral</li> <li>This wizard will guide you through the process of creating a new AXI4 peripheral which includes HDL, driver, software test application, IP Integrator VIP simulation and debug demonstration design.</li> </ul> |   |
| <b>£</b> XILINX.         | Click Next to continue                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |   |
| ?                        | < <u>B</u> ack <u>Einish</u> Cance                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | I |

- 3. Click Next.
- 4. Select the **Package your current project** option to use the current project as the source for creating the new IP Definition.
- 5. Click Next.

The Package Your Current Project dialog box opens, as shown in the following figure.

| A Create and Package New IP                                   |                                                                | ×    |
|---------------------------------------------------------------|----------------------------------------------------------------|------|
| Package Your Current Project                                  |                                                                |      |
| Select the directory where the IP Definition will be project. | created and the associated options for packaging the current   | A    |
| IP location: c:/tutorials/workspace/ug1119-vi                 | ivado-creating-packaging-ip-design/lab_1/my_simple_uart.sr 🔊 💽 |      |
| ?                                                             | < <u>B</u> ack <u>N</u> ext > <u>Finish</u> Car                | ncel |

6. Click **Next** to accept the defaults.



The New IP Creation dialog box, as shown in the following figure, opens with a summary of the information the wizard will automatically gather from the project.



7. Click Finish.

After the wizard completes, the Vivado IDE initially packages the current project as an IP for inclusion in the IP repository, and the Package IP dialog box opens to report success.

The Package IP window opens and displays the basic IP package in a staging area for editing and repackaging, as seen in the following figure.





| Package IP - uart_top                        |                      |                                                                                             | _ 🗆 🖓         |
|----------------------------------------------|----------------------|---------------------------------------------------------------------------------------------|---------------|
| Packaging Steps                              | Identification       |                                                                                             |               |
| ✓ Identification                             | Vendor:              | xilinx.com                                                                                  | 8             |
| <ul> <li>Compatibility</li> </ul>            | Library:             | user                                                                                        | 8             |
| ✓ File Groups                                | Name:                | uart_top                                                                                    | $\otimes$     |
| <ul> <li>Customization Parameters</li> </ul> | Version:             | 1.0                                                                                         | $\otimes$     |
|                                              | Display name:        | uart_top_v1_0                                                                               | $\otimes$     |
| Ports and Interfaces                         | Description:         | uart_top_v1_0                                                                               | 8             |
| Addressing and Memory                        | Vendor display name: |                                                                                             |               |
| <ul> <li>Customization GUI</li> </ul>        | Company url:         |                                                                                             |               |
| Review and Package                           | Root directory:      | c:/tutorials/workspace/ug1119-vivado-creating-packaging-ip-design/lab_1/my_simple_uart.src  | 5             |
|                                              | Xml file name:       | c:/tutorials/workspace/ug1119-vivado-creating-packaging-ip-design/lab_1/my_simple_uart.srcs | component.xml |
|                                              | Categories           |                                                                                             |               |
|                                              | +  -  +              | ŧ                                                                                           |               |
|                                              | /UserIP              |                                                                                             |               |
|                                              |                      |                                                                                             |               |
|                                              |                      |                                                                                             |               |
|                                              |                      |                                                                                             |               |
|                                              |                      |                                                                                             |               |

### **Step 4: Modify the IP Definition**

The Package IP window shows the current IP identification information, including Vendor, Library, Name, and Version (VLNV) attributes of the newly packaged IP.

- 1. In the Package IP window, select the **Identification** pane in the left side panel, and fill in the right side with the following information:
  - Vendor: my\_company
  - Library: user
  - Name: my\_simple\_uart
  - Version: 1.0
  - Display name: My Simple UART
  - **Description:** My simple example UART interface
  - Vendor display name: <My Company>
  - Company url: <company\_URL>
- 2. For the Categories option, select the **Add** button **t** to open the Choose IP Categories dialog box, as shown in the following figure.





| ▲ IP Categories ×                |
|----------------------------------|
| Choose or create an IP category. |
| Q   素   ♦   +   -                |
| AXI Infrastructure               |
| ~      Automotive & Industrial   |
| Automotive                       |
| BaselP                           |
| ✓ □ Basic Elements               |
| Accumulators                     |
| Comparators                      |
| Counters                         |
| Memory Elements                  |
| Registers, Shifters & Pipelining |
| Communication & Networking       |
| Error Correction                 |
| Ethernet                         |
| Modulation                       |
| Networking                       |
| Serial Interfaces                |
| Telecommunications               |
| Wireless                         |
| ✓ □ Debug & Verification         |
| ChipScope Pro 🗸                  |
| OK Cancel                        |

The Choose IP Categories dialog box lets you select various appropriate categories to help classify the new IP definition. When you add the IP definition to the IP catalog, the IP lists under the specified categories.

- 3. Select the **Serial Interfaces** box under Communications & Networking because the IP is a UART interface.
- 4. Click OK.





### Step 5: Add a Product Guide to the IP

1. On the left side of the Package IP window, select the **File Groups** item to display the File Groups panel on the right side.

The File Groups page provides a listing of the files to package as part of the IP, as shown in the following figure:

| Packaging Steps          | File Groups                        |              |               |            |                                        |   |
|--------------------------|------------------------------------|--------------|---------------|------------|----------------------------------------|---|
| Identification           | Q   X   ♦   🖬 🕂                    | G            |               |            |                                        |   |
| Compatibility            | Name                               | Library Name | Туре          | Is Include | File Group Name                        | Ν |
| Comparising              | 🗸 🗁 Standard                       |              |               |            |                                        |   |
| File Groups              | ✓                                  |              |               |            |                                        |   |
|                          | src/uart_top.xdc                   |              | xdc           |            | xilinx_anylanguagesynthesis            |   |
| Customization Parameters | src/uart_top_ooc.xdc               |              | xdc           |            | xilinx_anylanguagesynthesis            |   |
| Ports and Interfaces     | estimate state estimate            |              | verilogSource |            | xilinx_anylanguagesynthesis            |   |
|                          | <pre>we src/uart_baud_gen.v</pre>  |              | verilogSource |            | xilinx_anylanguagesynthesis            |   |
| Addressing and Memory    | <pre>we src/uart_rx.v</pre>        |              | verilogSource |            | xilinx_anylanguagesynthesis            |   |
| Customization GUI        | <pre>we src/uart_rx_ctl.v</pre>    |              | verilogSource |            | xilinx_anylanguagesynthesis            |   |
|                          | <pre>we src/uart_tx.v</pre>        |              | verilogSource |            | xilinx_anylanguagesynthesis            |   |
| Review and Package       | <pre>we src/uart_tx_ctl.v</pre>    |              | verilogSource |            | xilinx_anylanguagesynthesis            |   |
|                          | <pre>we src/uart_top.v</pre>       |              | verilogSource |            | xilinx_anylanguagesynthesis            |   |
|                          | <ul> <li>Simulation (7)</li> </ul> |              |               |            |                                        |   |
|                          | e src/meta_harden.v                |              | verilogSource |            | xilinx_anylanguagebehavioralsimulation |   |
|                          | e src/uart_baud_gen.v              |              | verilogSource |            | xilinx_anylanguagebehavioralsimulation |   |
|                          | e src/uart_rx.v                    |              | verilogSource |            | xilinx_anylanguagebehavioralsimulation |   |
|                          | e src/uart_rx_ctl.v                |              | verilogSource |            | xilinx_anylanguagebehavioralsimulation |   |
|                          | <pre>@ src/uart_tx.v</pre>         |              | verilogSource |            | xilinx_anylanguagebehavioralsimulation |   |
|                          | <pre>w src/uart_tx_ctl.v</pre>     |              | verilogSource |            | xilinx_anylanguagebehavioralsimulation |   |
|                          | e src/uart_top.v                   |              | verilogSource |            | xilinx_anylanguagebehavioralsimulation |   |
|                          | ✓                                  |              |               |            |                                        |   |
|                          | > 🚍 UI Layout (1)                  |              |               |            |                                        |   |

2. Open the Messages window, and review the IP packager messages as seen in the following figure:





The IP packager messages inform you of the state of the IP. The File Groups Wizard message indicates that the IP definition does not include any documentation.

The Customization Parameters Wizard informs you that specific parameters of the IP do not have range values.

As INFO messages, these are quick checks of the IP definition that do not prevent you from moving forward if you choose. However, in the next step you add the product guide to the IP definition.

The Ports and Interfaces wizard has warnings related to the inferred single-bit clock interfaces inferred by the IP packager for missing ASSOCIATED\_BUSIF parameters. These parameters are required for AXI interfaces in the Vivado IP integrator. The reason for the warning is that the IP integrator tool works best with interfaces, and it expects that you would typically be using AXI interfaces. You do not have any bus interfaces in your design, and therefore, you can safely ignore this warning.

- 3. In the Package IP window, right-click in the File Groups pane, and select Add File Group.
- 4. In the Add IP File Group dialog box, select **Product Guide** from the Standard File Groups section, as shown in the following figure:

| Add File Group                                                                                                          | ×      |
|-------------------------------------------------------------------------------------------------------------------------|--------|
| Select File Group(s) to add.                                                                                            | 2      |
|                                                                                                                         |        |
| File Group                                                                                                              |        |
| Q X \$                                                                                                                  |        |
| ✓ 	☐ Standard                                                                                                           | ^      |
| Synthesis                                                                                                               |        |
| Synthesis Memory Archive                                                                                                |        |
| Simulation                                                                                                              |        |
| Simulation Memory Archive                                                                                               |        |
| Product Guide                                                                                                           |        |
| Readme                                                                                                                  |        |
| Examples                                                                                                                | $\sim$ |
|                                                                                                                         |        |
| Description Product Guide                                                                                               |        |
| The IP documentation URL which previously consisted of separate readme, datasheet, user guide and other collateral disk | ^      |
| files.                                                                                                                  | ~      |
| OK Cance                                                                                                                | el     |
|                                                                                                                         |        |

5. Click OK.

The IP File Groups pane now updates with the Product Guide group in the list. There is a "0" next to the Product Guide name because there are no files added to the newly created group.



- 6. Right-click the **Product Guide** file group, and select **Add Files**.
- 7. In the opened Add IP Files (Product Guide) dialog box, click Add Files.
- 8. Browse to <Extract\_Dir>/lab\_1/docs, and select All Files in the Files of type: entry line.
- 9. Select my\_simple\_uart\_product\_guide.pdf, and click OK.
- 10. In the Add IP Files (Product Guide) dialog box, shown in the following figure, ensure that **Copy sources into project** is selected.

The option ensures that the file imports into the project sources directory, and not remotely referenced by the IP packager.

| À Add IP Fil   | es (Product    | Guide)                           |             |                      | ×        |
|----------------|----------------|----------------------------------|-------------|----------------------|----------|
| Select files t | to add to file | e group.Product Guide            |             |                      | A        |
| +, -           | 1 + 1          | Ļ                                |             |                      |          |
|                | Index          | Name                             | Library     | Location             |          |
| -              | 1              | my_simple_uart_product_guide.pdf | N/A         | C:/Tutorials/workspa | ace/ug11 |
| <              |                |                                  |             |                      | >        |
|                |                | Add Files Add Directories        | <u>C</u> re | ate File             |          |
| Scan ar        | nd add RTL j   | nclude files into project        |             |                      |          |
| Copy se        | ources into p  | project                          |             |                      |          |
|                |                | subdirectories                   |             |                      |          |
|                |                |                                  |             | ОК                   | Cancel   |

#### 11. Click **OK**.

The IP packager adds the PDF file of the Product Guide to the files defined as part of the IP, and resolves the Documentation Info check.





### **Step 6: Review and Package the IP**

The custom IP was initially packaged at the end of the Create and Package IP wizard, but because changes were made in the Package IP window, the custom IP must be re-packaged for the changes to take effect.

1. On the left side of the Package IP window, select the **Review and Package** panel.

The Review and Package pane provides a summary of the IP being packaged, as shown in the following figure:

| Project Summary X Packa                      | ge IP - uart_top X                                                                                                                                                                                                                                                        |
|----------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Packaging Steps                              | Review and Package                                                                                                                                                                                                                                                        |
| <ul> <li>Identification</li> </ul>           | • 2 warnings 1 info message                                                                                                                                                                                                                                               |
| <ul> <li>Compatibility</li> </ul>            | Summary                                                                                                                                                                                                                                                                   |
| ✓ File Groups                                | Display name: My Simple UART<br>Description: My simple example UART interface                                                                                                                                                                                             |
| <ul> <li>Customization Parameters</li> </ul> | Root directory: /group/xhdwts/chinmays/UG1119_review/17_6/ug1119-vivado-creating-pa                                                                                                                                                                                       |
| 9 Ports and Interfaces                       |                                                                                                                                                                                                                                                                           |
| Addressing and Memory                        |                                                                                                                                                                                                                                                                           |
| <ul> <li>Customization GUI</li> </ul>        | After Packaging                                                                                                                                                                                                                                                           |
| Review and Package                           | An archive will not be generated. Use the settings link below to change your preference<br>IP will be made available in the catalog using the repository -<br>/group/xhdwts/chinmays/UG1119_review/17_6/ug1119-vivado-creating-packaging-ip-de<br>Edit packaging settings |
|                                              | Package IP                                                                                                                                                                                                                                                                |

With default settings of the current project, Vivado does not generate an archive for this IP after packaging. This is reflected in the After Packaging section of the Review and Package pane of the Package IP window.

- 2. Make a note of the location of the IP repository in the After Packaging section. This is necessary to validate the custom IP in the next step.
- 3. In the Package IP window, click **Package IP** to package the current project and add it to the IP catalog.
- 4. After the packaging process completes, close the Vivado project from the File menu.



### Step 7: Validate the New IP

With the new custom IP definition packaged and added to the IP Catalog, you can validate that the IP works as expected when added to designs. To validate the IP, add a new customization of the UART IP to a project, and synthesize the design.

1. From the Vivado IDE Getting Started page, select Manage IP → New IP Location to create a new project.



TIP: You can use either an RTL project or a Manage IP project to validate IP.

- 2. Click **Next** in the New IP Location dialog box.
- 3. In the Manage IP Settings dialog box, set the following options as they appear in the following figure.
  - Part: xc7k325tffg900-2
  - Target language: Verilog
  - Target Simulator: Vivado simulator
  - Simulator Language: Mixed
  - IP Location: <Extract\_Dir>/lab\_1





| À New IP Location                                 |                                                               | ×      |
|---------------------------------------------------|---------------------------------------------------------------|--------|
| Manage IP Settings<br>Set options for creating an | d generating IP.                                              | 4      |
| Part:                                             | © xc7k325tffg900-2                                            |        |
| Target language:                                  | Verilog                                                       | ~      |
| Target simulator:                                 | Vivado Simulator                                              | ~      |
| Simulator language:                               | Mixed                                                         | ~      |
| IP location:                                      | C:/Tutorials/ug1119-vivado-creating-packaging-ip-design/lab_1 | ⊗ …    |
|                                                   |                                                               |        |
|                                                   |                                                               |        |
|                                                   |                                                               |        |
| (?)                                               | < <u>B</u> ack <u>N</u> ext > <u>Finish</u>                   | Cancel |

4. Click **Finish** to create the Manage IP project.

A new Manage IP project opens in the Vivado IDE. The IP catalog opens automatically in a Manage IP project; however, the IP Catalog does not contain the repository used to package the custom UART IP.

You now add the IP repository to the IP catalog.

- 5. In the IP Catalog window, right-click and select **IP Settings**, and expand IP to show Repository.
- 6. In the Repository Manager tab, click the **Add Repository** button to show and then select the IP Repositories Dialog Box.
- 7. In the IP Repositories dialog box, browse to and select the following location:

<Extract\_Dir>/my\_simple\_uart.srcs/

8. Click Select to add the selected repository, as shown in the following figure:





| 🝌 IP Repositories 🛛 🗙                                                          | ( |
|--------------------------------------------------------------------------------|---|
| Recent: 🖻 C:/Tutorials/ug1119-viva 🗸 🕇 🏠 📮 🛓 🐥 📮 [                             | 2 |
| Directory: C:\Tutorials\ug1119-vivado-creating-packaging-ip-design\lab_1       |   |
| ✓ ▲ lab_1                                                                      |   |
| > docs<br>> ip_user_files                                                      |   |
| <ul> <li>&gt; managed_ip_project</li> <li>&gt; my_simple_uart.cache</li> </ul> |   |
| > I my_simple_uart.hw > I my_simple_uart.sim                                   |   |
| inty_simple_uart.srcs                                                          | 1 |
| > 💄 constrs_1                                                                  |   |
| > 📕 sources_1                                                                  |   |
| > 📕 lab_2                                                                      |   |
| > 📕 lab_3                                                                      |   |
| > 📕 lab_4                                                                      | / |
| Select Cancel                                                                  |   |

The added location displays in the IP Repositories section, and any packaged IP found in the repositories displays under the IP in Selected Repository. The My Simple UART IP definition that you packaged in Step 3: Package the IP is listed.

9. Click **OK** twice to add the IP repository to the IP Catalog and close the dialog box.

**TIP:** To define a custom IP repository for use across multiple design projects, you can use the **Tools**  $\rightarrow$ **Settings** command in the Vivado IDE to set the Default IP Repository Search Paths under the General IP options. The default IP repository search path is stored in the *vivado.xml* file, and added to new projects using the IP\_REPO\_PATHS property for the current\_fileset:set\_property IP\_REPO\_PATHS {...} [current\_fileset]. (See the Vivado Design Suite Properties Reference Guide (UG912) for more information.)

10. In the search field at the top of the IP Catalog, type UART.

The My Simple UART is reported under the UserIP and Serial Interfaces categories that it was previously assigned to during packaging, as shown in the following figure.





| IP Catalog                                                                                       |                     | ?          | _ D @ X  |
|--------------------------------------------------------------------------------------------------|---------------------|------------|----------|
| Cores   Interfaces                                                                               |                     |            |          |
| ¥   ♣   ₩   ₺   ∅   ■   Q- UART                                                                  | 8                   |            | ٥        |
| Name ^1                                                                                          | AXI4                | Status     | License  |
| <ul> <li>User Repository (c:/Tutorials/ug1119-vivado-creating-packaging-ip-design/lab</li> </ul> | _1/my_simple_uart.s | rcs)       | ^        |
| Communication & Networking                                                                       |                     |            |          |
| Serial Interfaces                                                                                |                     |            |          |
| 🍄 My Simple UART                                                                                 |                     | Production | Included |
| ✓ 	☐ UserIP                                                                                      |                     |            |          |
| 🍄 My Simple UART                                                                                 |                     | Production | Included |
| Vivado Repository                                                                                |                     |            |          |
| Embedded Processing                                                                              |                     |            |          |
| 🗸 🖨 AXI Peripheral                                                                               |                     |            | ~        |
|                                                                                                  |                     |            | >        |
| Details                                                                                          |                     |            |          |
| Select an IP or Interface or Repository to :                                                     | see details         |            |          |

**Note:** This IP Catalog view shows when the Taxonomy and the Repository options are selected for grouping the IP. See the *Vivado Design Suite User Guide: Creating and Packaging Custom IP* (UG1118) for more information about IP Groups.

- 11. Select the **My Simple UART** by clicking it under either the UserIP or Serial Interfaces category.
- 12. Examine the Details pane of the IP Catalog window, as shown in the following figure.

Notice that the details match the information provided when you packaged the IP.

| Details      |                                                                                   |
|--------------|-----------------------------------------------------------------------------------|
| Name:        | My Simple UART                                                                    |
| Version:     | 1.0 (Rev. 2)                                                                      |
| Description: | My simple example UART interface                                                  |
| Status:      | Production                                                                        |
| License:     | Included                                                                          |
| Vendor:      | My Company                                                                        |
| VLNV:        | my_company:user:my_simple_uart:1.0                                                |
| Repository:  | c:/Tutorials/ug1119-vivado-creating-packaging-ip-design/lab_1/my_simple_uart.srcs |

13. In the IP catalog, double-click **My Simple UART** to open the Customize IP dialog box, shown in the following figure.





| À Customize IP                                                                                                                                      | ×                               |
|-----------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------|
| My Simple UART (1.0)  Ocumentation IP Location C Switch to Defaults                                                                                 | 4                               |
| Show disabled ports<br>rx_clk frm_err<br>rx_i rx_data[7:0]<br>rx_rst rx_i_sync<br>tx_clk rx_rdy<br>tx_ready_i tx_o<br>tx_rst tx_cts<br>tx_data[7:0] | Component Name my_simple_uart_0 |
|                                                                                                                                                     | OK Cancel                       |

- 14. (Optional) In the Customize IP dialog box, click **Documentation** and open the Product Guide.
- 15. Click **OK**, accepting the default Component Name and other options.

The Vivado packager adds the customized IP to the current project, and displays the IP in the IP Sources window.

The Generate Output Products dialog box opens, as shown in the following figure.





| 🝌 Generate Output Products                              | ×   |
|---------------------------------------------------------|-----|
| The following output products will be generated.        | A   |
| Preview                                                 |     |
| Q, ,                                                    |     |
| ✓ ♀ ■ my_simple_uart_0.xci (OOC per IP)                 |     |
| Instantiation Template                                  |     |
| e following output products will be generated.  Preview |     |
| Structural Simulation                                   |     |
|                                                         |     |
| Number of jobs: 4                                       |     |
| Apply     Generate     S                                | kip |

#### 16. Click Generate.

This generates the various files required for this IP in the current Manage IP project, and launches an out-of-context (OOC) synthesis run for the IP, which creates a design checkpoint (DCP) file.

Recall this OOC synthesis run uses the OOC XDC file that defines the necessary clocks for the standalone IP.

The Generate Output Products dialog box re-opens to report the output products generated successfully.

- 17. Click **OK**.
- 18. Examine the IP Sources window and the various design and simulation source files that are added to the project.
- 19. In the Design Runs window, shown in the following figure, verify that the Out-Of-Context synthesis run was successful.





| Die Edit Jools Reports Window Leyou                                                                |         | Belp G-Duck Access                                     |                                                                 |                 |
|----------------------------------------------------------------------------------------------------|---------|--------------------------------------------------------|-----------------------------------------------------------------|-----------------|
| 9, 6 h × 0 K / )                                                                                   | ¢       |                                                        | I Default Lay                                                   |                 |
| ROJECT MANAGER - xc7k325tfg900-2                                                                   |         |                                                        |                                                                 | 7.3             |
| Sources 7 _                                                                                        | 0 0 X   | IP Catalog                                             |                                                                 | 7 U U X         |
| Q ž 0 +                                                                                            | 0       | Cores   Interfaces                                     |                                                                 |                 |
| → S P (1) → O # my simple uset 0 (28)                                                              |         | Q = 0 # < / / 0 0                                      |                                                                 | ۰               |
| <ul> <li>b) instantiation Feedbale (b)</li> <li>b) (b) (b) (b) (b) (b) (b) (b) (b) (b) (</li></ul> |         | Search: Q                                              |                                                                 |                 |
|                                                                                                    |         | Name                                                   | ADDA Status License VOW                                         |                 |
|                                                                                                    |         | <ul> <li>Senal interfaces</li> </ul>                   | Va0_1mg_emple_sert.e/cs)                                        |                 |
|                                                                                                    |         | Hy Simple UART                                         | Producti included my_cos                                        |                 |
| <ul> <li>my_simple_uart_0_stub.vhdl</li> <li>my_simple_uart_0_stub.v</li> </ul>                    |         | v 🖘 UserP                                              |                                                                 |                 |
|                                                                                                    |         | Wy Simple UART     Simple UART     Simple Vealorements | Producti included my_cor                                        |                 |
| IP Sources                                                                                         |         | / - man appared                                        |                                                                 |                 |
| Source File Properties 🦷 💡 :                                                                       | υв×     | Details                                                |                                                                 |                 |
| ny_simple_uart_0.xci 🗰 🗠                                                                           | - 0     |                                                        |                                                                 |                 |
| Strabled<br>General Properties P                                                                   |         | Select an                                              | IP or interface of Aspository to see details                    |                 |
| Id Console   Hessages   Log   Design Run                                                           | 4. X    |                                                        |                                                                 | 7 _ 0 0         |
| Q Ξ ● H ≪ ⊨ > %                                                                                    |         |                                                        |                                                                 |                 |
| Name Constraints<br>- S Out of Context Module Runs                                                 | Retu    | WHS THIS WHIS THIS TPARS Total Powe                    | r Falled Routes LUT FF BRAM URAM DSP Start Elapsed Run Strategy |                 |
| v my_simple_uart_0_synth_1 my_simple_uart                                                          | 0 8/103 | design Completer                                       | 54 48 0.0 0 0 1/25/2 00:00:56 Vivado Synthe                     | isis Defaults 🕅 |
|                                                                                                    |         |                                                        |                                                                 |                 |
|                                                                                                    |         |                                                        |                                                                 |                 |
|                                                                                                    |         |                                                        |                                                                 | >               |

### Conclusion

In this lab, you did the following:

- Used the Create and Package IP wizard to create a custom IP definition for the tutorial project, my\_simple\_uart.
- Setup the XDC files to support the processing order requirements as well as Out-Of-Context synthesis.
- Validated the packaged IP by creating a Managed IP project, and then adding the new IP repository to the IP catalog.
- Created a customization of the IP, and generated a DCP of the IP to validate that the IP definition was complete and included all the necessary files to support using the IP in other designs.





Lab 2

# Packaging a Specified Directory

### Introduction

In this lab, you create a new Vivado<sup>®</sup> project and package a custom IP from a specified directory.

You start with an IP repository directory and create a new Vivado project. In the Vivado project, you package the custom IP in the repository using the Create and Package Wizard, define the identification information, and verify the packaged files.

After packaging, you validate the IP was created successfully by completing Synthesis in the created Vivado project.

The lab project contains source files for a non-working version of the Wave Generator example design.

### **Step 1: Examine the IP Directory**

1. Examine the <Extract\_Dir>/lab\_2/custom\_ip\_repo/wave\_gen\_v1\_0 location.

This directory contains the custom IP files required for packaging the IP. Notice the three directories are created, as shown in the following figure:

- doc: Directory contains the documentation related to the custom IP.
- src: Directory contains the synthesis and simulation sources for the custom IP.
- tb: Directory contains the test bench for the custom IP.

The directory containing the custom IP should be organized to ensure proper packaging.

When specifying a directory for packaging, there are inference rules that assist in packaging the IP correctly. For more information, see the *Vivado Design Suite User Guide: Creating and Packaging Custom IP* (UG1118).

2. Examine the files in each of the directories for more information about the custom IP.



### Step 2: Create a New Vivado Project

### Launch Vivado

On Linux:

- Change to the directory where the lab materials are stored: cd <Extract\_Dir>/lab\_2.
- Launch the Vivado® IDE: vivado.

On Windows:

• Launch the Vivado Design Suite IDE:

Select Start  $\rightarrow$  All Programs  $\rightarrow$  Vivado 2020.x  $\rightarrow$  Vivado 2020.x.

Or

Click the Vivado 2020.x desktop icon to start the Vivado IDE.

The Vivado IDE Getting Started page displays with links to open or create projects, and to view documentation. For either Windows or Linux, continue the lab from this point.

### **Create a New Project**

1. From the Vivado<sup>®</sup> IDE Getting Started page, select **Create Project** to create an empty Vivado project.

A new or existing project is required to creating and packaging a custom IP. The project information is used for populating certain fields in the Package IP window.

- 2. Click Next at the New Project wizard dialog box.
- 3. In the Project Name page, as shown in the following figure, set the following options for the project location:
  - Project name: project\_lab2
  - **Project location:** <Extract\_Dir>/lab\_2
- 4. Click Next.
- 5. Select **RTL Project** as the Project Type and **Do not specify sources at this time**.
- 6. Click Next.
- 7. In the Default Part dialog box, select the **xc7k70tfbg484-2** part, and click **Next**.

For this lab, you select a Kintex<sup>®</sup>-7 device. This device family is used for the initial compatibility of the custom IP.

8. Click **Finish** to close the New Project Summary page, and create the project.



The Vivado IDE opens project\_lab2, with the default layout.

### **Step 3: Package the IP Directory**

After creating the new empty project, the next step is to create and package the custom IP directory.

- 1. From the Tools menu, select **Create and Package New IP** to open the Create and Package IP wizard.
- 2. Click **Next** at the Welcome screen for the Create and Package New IP dialog box, shown in the following figure.
- 3. In the Create Peripheral, Package IP, or Package a Block Design dialog box, select **Package a specified directory**, and click **Next**.



4. Set Directory to <Extract\_Dir>/lab2/custom\_ip\_repo/wave\_gen\_v1\_0, as shown in the following figure.



| 🝌 Create and Package New IP                                                                     | ×    |
|-------------------------------------------------------------------------------------------------|------|
| Package a Specified Directory<br>Select the directory where sources to be packaged are located. | 4    |
| Directory: reating-packaging-ip-design/lab_2/custom_ip_repo/wave_gen_v1_0                       |      |
|                                                                                                 |      |
|                                                                                                 |      |
|                                                                                                 |      |
|                                                                                                 |      |
| < Back                                                                                          | ncel |

- 5. Click Next.
- 6. On the Edit in IP Packager Project Name page, leave the default name and location, and click **Next**.

When packaging a specified directory, the custom IP is packaged through an edit IP project. The default options create an edit IP project in the project temporary location. The edit IP project can be saved for future editing, but a new edit IP project can always be created later.

7. Click Finish.

An edit IP project opens in a new Vivado window with the Package IP window opened. The Package IP window displays the basic IP package in a staging area for editing and repackaging.

8. Leave project\_lab2 open during this process.

### Step 4: Examine and Update the Packaged IP

The edit IP project is created as a standard RTL project with the directory sources included. The Package IP window shown below, lists the current IP identification information.





| Fiaure | 1:  | Package | IP |
|--------|-----|---------|----|
|        | ••• |         |    |

| Package IP - wave_gen                                                                                                                                                                                                                                                                             |                                                                                                                                                                      | -                                                                                                                        | . 🗆 🛛 Х                                                                         |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------|
| Packaging Steps                                                                                                                                                                                                                                                                                   | Identification                                                                                                                                                       |                                                                                                                          |                                                                                 |
| Packaging Steps         ✓       Identification         ✓       Compatibility         ✓       File Groups         ✓       Customization Parameters         ✓       Ports and Interfaces         Addressing and Memory       ✓         ✓       Customization GUI         Review and Package       ✓ | Vendor:<br>Library:<br>Name:<br>Version:<br>Display name:<br>Description:<br>Vendor display name:<br>Company url:<br>Root directory:<br>Xml file name:<br>Categories | xilinx.com user user i.0 c/Tutorials/ug1119-vivado-creating-packaging-ip-design/lab_2/custom_ip_repo/wave_gen_v1_0/compo | C)<br>C)<br>C)<br>C)<br>C)<br>C)<br>C)<br>C)<br>C)<br>C)<br>C)<br>C)<br>C)<br>C |
|                                                                                                                                                                                                                                                                                                   | /UserIP                                                                                                                                                              |                                                                                                                          |                                                                                 |

### **Update the IP Identification**

- 1. In the Identification page, set the following options:
  - Vendor: my\_company
  - Name: wave\_gen\_tutorial
  - Display name: Wave Generator Tutorial
  - Description: UG1119 Tutorial Lab #2- Wave Generator tutorial design
  - Vendor display name: My Company
  - Company url: <company\_URL>
- 2. In the Categories section, click the **Add** button **t** to add a new category.
- 3. In the IP Categories dialog box, click the **Add** button + to add a custom category.
- 4. In the Add IP Category dialog box, set the option to My Company, and click OK.
- 5. Click OK to close the Add IP Categories dialog box.



### **Examine the IP File Groups**

The File Groups page provides a listing of the files to be packaged as part of the custom IP.

1. Examine the files packaged as part of the custom IP, shown in the following figure, to understand how the IP directory correlates to the File Groups.

| Packaging Steps                              | File Groups           |                 |      |               |                     |                 |               |
|----------------------------------------------|-----------------------|-----------------|------|---------------|---------------------|-----------------|---------------|
| <ul> <li>Identification</li> </ul>           |                       |                 |      |               |                     |                 |               |
| ✓ Compatibility                              | Name                  | Library<br>Name | Туре | ls<br>Include | Used In<br>Constant | File Group Name | Model<br>Name |
| ✓ File Groups                                | Standard              |                 |      |               |                     |                 |               |
|                                              | > 🖙 Synthesis (26)    |                 |      |               |                     |                 | wave_ge       |
| <ul> <li>Customization Parameters</li> </ul> | > 🗁 Simulation (24)   |                 |      |               |                     |                 | wave_ge       |
| <ul> <li>Ports and Interfaces</li> </ul>     | > 🗁 Product Guide (1) |                 |      |               |                     |                 |               |
| Addressing and Memory                        | Advanced              |                 |      |               |                     |                 |               |
|                                              | > 🗁 Test Bench (9)    |                 |      |               |                     |                 |               |
| <ul> <li>Customization GUI</li> </ul>        | >  UI Layout (1)      |                 |      |               |                     |                 |               |

- 2. In the Packaging Steps toolbar, select the File Groups page.
- 3. Expand the file group folders as shown in the following figure.

| Packaging Steps                              | File Groups             |                 |               |               |                     |                        |
|----------------------------------------------|-------------------------|-----------------|---------------|---------------|---------------------|------------------------|
| <ul> <li>Identification</li> </ul>           | Q X 0 C                 |                 |               |               |                     |                        |
| <ul> <li>Compatibility</li> </ul>            | Name                    | Library<br>Name | Туре          | ls<br>Include | Used In<br>Constant | File Group Name        |
| <ul> <li>File Groups</li> </ul>              | Standard                |                 |               |               |                     |                        |
|                                              | Synthesis (26)          |                 |               |               |                     |                        |
| <ul> <li>Customization Parameters</li> </ul> | src/wave_gen_pins.xdc   |                 | xdc           |               |                     | xilinx_anylanguagesynt |
| Ports and Interfaces                         | src/wave_gen_timing.xdc |                 | xdc           |               |                     | xilinx_anylanguagesynt |
|                                              | src/char_fifo.v         |                 | verilogSource |               |                     | xilinx_anylanguagesynt |
| Addressing and Memory                        | src/clk_core.v          |                 | verilogSource |               |                     | xilinx_anylanguagesynt |
| <ul> <li>Customization GUI</li> </ul>        | src/clk_div.v           |                 | verilogSource |               |                     | xilinx_anylanguagesynt |
|                                              | src/clk_gen.v           |                 | verilogSource |               |                     | xilinx_anylanguagesynt |
| Review and Package                           | src/clogb2.vh           |                 | verilogSource |               |                     | xilinx_anylanguagesynt |
|                                              | src/clkx_bus.v          |                 | verilogSource |               |                     | xilinx_anylanguagesynt |
|                                              | src/cmd_parse.v         |                 | verilogSource |               |                     | xilinx_anylanguagesynt |
|                                              | src/dac_spi.v           |                 | verilogSource |               |                     | xilinx_anylanguagesynt |
|                                              | src/debouncer.v         |                 | verilogSource |               |                     | xilinx_anylanguagesynt |
|                                              | src/lb_ctl.v            |                 | verilogSource |               |                     | xilinx_anylanguagesynt |
|                                              | src/meta_harden.v       |                 | verilogSource |               |                     | xilinx_anylanguagesynt |
|                                              | src/out_ddr_flop.v      |                 | verilogSource |               |                     | xilinx_anylanguagesynt |
|                                              | src/reset_bridge.v      |                 | verilogSource |               |                     | xilinx_anylanguagesynt |
|                                              | src/resp_gen.v          |                 | verilogSource |               |                     | xilinx_anylanguagesynt |
|                                              | src/rst_gen.v           |                 | verilogSource |               |                     | xilinx_anylanguagesynt |

The File Groups page is the listing of the files for the custom IP. The file groups for the custom IP match with directory structure of the IP directory.

The synthesis and simulation file groups contain the HDL files associated with the /src directory. The synthesis file group contains two additional files from the /src directory, the XDC files.

The Product Guide file group is populated with the PDF from the /doc directory and the Testbench file group is populated with the /tb directory.

4. Notice that the test benches are located within its own file group and not in the Simulation file group.



### Repackage the IP

The custom IP was packaged at the end of the Create and Package IP wizard. Because changes occurred in the Package IP window, the custom IP must be repackaged for the changes to take effect.

1. In the Packaging Steps toolbar, shown in the following figure, select the **Review and Package** page.

| Pr  | oject Summary × Package IP | -wave_gen ×                                                                             | 06 |
|-----|----------------------------|-----------------------------------------------------------------------------------------|----|
| F   | Packaging Steps            | Review and Package                                                                      |    |
| 4   | Identification             | Summary                                                                                 |    |
| 1   | Compatibility              | Display name: wave_gen_v1_0                                                             |    |
| 1   | File Groups                | Description: UG1119 Tutorial Lab#2 Wave Generator tutorial<br>design                    |    |
| 1   | Customization Parameters   | Root directory: c:/Temp/lab_2/custom_ip_repo/wave_gen_v1_0                              |    |
| 1   | Ports and Interfaces       | After Packaging                                                                         |    |
|     | Addressing and Memory      | An archive will not be generated. Use the settings link below to change your preference |    |
| 1   | Customization GUI          | Project will be removed after completion<br>Edit packaging settings                     |    |
|     | Review and Package         |                                                                                         |    |
|     |                            |                                                                                         |    |
| < 0 | >                          | Package IP                                                                              |    |

- 2. Click the **Package IP** button to repackage the IP.
- 3. After the packaging process completes, close the Vivado edit IP project.

### **Step 5: Validate the Custom IP**

With the new custom IP packaged, the next step is to verify the repository in the IP catalog and validate the generation of the custom IP. You can use the project\_lab2 created in the earlier steps to validate the IP.

### **Check the IP Repository Project Settings**

The project that packaged the specified directory has the IP repository path in the project repository manager. You can validate the IP repository in the project settings at this time.

- 1. In Flow Navigator → Project Manager, select Settings.
- 2. In the Settings dialog box, expand IP and select Repository.
- 3. In the Repository Manager tab, check for the IP repository: <Extract\_Dir>/lab\_2/ custom\_ip\_repo/wave\_gen\_v1\_0.



The Wave Generator Tutorial IP shows in the IP in Selected Repository list, as shown below.

|                                                                |   | IP > Repository                                                                                                                                                          |
|----------------------------------------------------------------|---|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>roject Settings</b><br>General<br>Simulation<br>Elaboration | Î | Add directories to the list of repositories. You may then add additional IP to a selected repository. If an IP is disabled then a tool-tip will alert you to the reason. |
| Synthesis                                                      |   | +  -  +   +                                                                                                                                                              |
| Implementation<br>Bitstream<br>~ IP                            |   | /ug1119-vivado-creating-packaging-ip-design/lab_2/custom_ip_repo/wave_gen_v1_0 (Project                                                                                  |
| Repository                                                     |   |                                                                                                                                                                          |
| Packager                                                       |   | <                                                                                                                                                                        |
| ool Settings<br>Project                                        |   | Refresh All                                                                                                                                                              |
| IP Defaults                                                    |   |                                                                                                                                                                          |
| Source File                                                    |   |                                                                                                                                                                          |
| Display                                                        |   |                                                                                                                                                                          |
| WebTalk<br>Help                                                |   |                                                                                                                                                                          |
| Text Editor                                                    | ~ |                                                                                                                                                                          |

*Note:* The Vivado tool selects the IP directory location as the repository. You can select the parent repository directory and Vivado traverses the subdirectories for packaged IP.

4. Click OK.

## **Customize the IP**

- 1. Select Flow Navigator  $\rightarrow$  Project, and then select IP Catalog.
- 2. In the search field at the top of the IP Catalog, type Wave Generator.



The Wave Generator Tutorial IP shows under the UserIP category, as well as the custom category My Company, that was created during packaging.



**Note:** This IP catalog view shows when you select Taxonomy and the Repository options for grouping the IP. See the *Vivado Design Suite User Guide: Creating and Packaging Custom IP* (UG1118) for more information about IP Groups.

3. Right-click the Wave Generator Tutorial IP and select Customize IP.

The following figure shows the Wave Generator Tutorial IP view.

| 💫 Customize IP                                                                                   |               |                 |           | ×     |
|--------------------------------------------------------------------------------------------------|---------------|-----------------|-----------|-------|
| Wave Generator Tutorial (1.0)         Occumentation         IP Location         C Switch to Defa | ults          |                 |           | A     |
| Show disabled ports                                                                              | Component Nan | ne wave_gen_tut | orial_0   | 0     |
|                                                                                                  | Baud Rate     | 115200          | $\otimes$ |       |
|                                                                                                  | Clock Rate Rx | 20000000        | $\otimes$ |       |
|                                                                                                  | Clock Rate Tx | 166667000       | $\otimes$ |       |
| − clk_pin_p = spi_clk_pin −                                                                      | Nsamp Wid     | 10              | $\otimes$ |       |
| – clk_pin_n spi_mosi_pin –<br>– rst_pin –                                                        | Pw            | 3               | $\otimes$ |       |
| - rxd_pin dac_cs_n_pin -<br>rxd_pin dac_clr_n_pin -<br>lb_sel_pin led_pins[7:0] -                |               |                 |           |       |
|                                                                                                  |               | ОК              | Ca        | ancel |

- 4. Click **OK** to accept the default configuration options.
- 5. In the Generate Output Products dialog box, select Generate.

This generates the various files required for this IP in the current Manage IP project, and launches an Out-Of-Context synthesis run for the IP to create a DCP. The Generate Output Products dialog re-opens to report the output products generated successfully.

6. Close the Vivado tool.

## Conclusion

You have successfully created the Wave Generator Tutorial IP by packaging a specified directory. Close the project and exit the Vivado tool. You cannot continue further with this design because it will not complete implementation. In this lab, you did the following:



- Used the Create and Package IP wizard to package a specified directory for the Wave Generator Tutorial design.
- Validated the generation of the Wave Generator Tutorial IP output products.





Lab 3

# Packaging Legacy IP

# Introduction

You might need to use a legacy core in Vivado<sup>®</sup> originally created in the Xilinx Platform Studio (XPS) tool.

In this lab, you learn how to convert an XPS processor core, or Pcore, to a Vivado Design Suite native IP for use in IP integrator. To migrate a legacy core, you need all the libraries on which the main core is dependent. This lab uses a simple AXI GPIO Pcore from an XPS project. This core has several dependencies on the following libraries:

- proc\_common\_v3\_00\_a
- axi\_lite\_ipif\_v1\_01\_a
- interrupt\_control\_v2\_01\_a
- axi\_gpio\_v1\_01\_b

To migrate this Pcore, you must determine all the files that are needed for the AXI GPIO IP, package them as library cores (or sub-cores), add the sub-cores to the IP catalog, and then package the AXI GPIO IP.

# Step 1: Create a New Vivado Project

## Launch Vivado

On Linux:

- Change to the directory where the lab materials are stored: cd <Extract\_Dir>/lab\_3.
- Launch the Vivado IDE: vivado.

On Windows:

• Launch the Vivado Design Suite IDE, by using either of the following methods:



Select Start  $\rightarrow$  All Programs  $\rightarrow$  Xilinx Design Tools  $\rightarrow$  Vivado 2020.x  $\rightarrow$  Vivado 2020.x.

Or

Click the Vivado 2020.x desktop icon.

The Vivado IDE Getting Started page displays with links to open or create projects, and to view documentation. For either Windows or Linux, continue the lab from this point.

## **Create a New Project**

1. From the Vivado IDE Getting Started page, select **Create New Project** to create an empty Vivado project.

A new or existing project is required to creating and packaging a custom IP. The project information populates certain fields in the Package IP window.

- 2. In the New Project Wizard dialog box, click **Next**.
- 3. As shown in the following figure, set the following options:
  - Project name: project\_lab3
  - **Project location:** <Extract\_Dir>/lab\_3
  - Check the Create Project subdirectory box.
- 4. Click Next.
- 5. Select **RTL Project** for Project Type and **Do not specify sources at this time**.
- 6. Click Next.
- 7. On the Default Part page, select the **xc7k70tfbg484-2** part, and click **Next**.

The following figure shows the New Project: Default Part dialog box.



| ose a defa      | <b>rt</b><br>ault Xilinx par | rt or board for yo | ur proiect.    |            |     |                     |            |                 |            |
|-----------------|------------------------------|--------------------|----------------|------------|-----|---------------------|------------|-----------------|------------|
|                 |                              | ,,.                |                |            |     |                     |            |                 |            |
|                 |                              |                    |                |            |     |                     |            |                 |            |
| Parts           | Boards                       |                    |                |            |     |                     |            |                 |            |
| Reset All       | Filters                      |                    |                |            |     |                     |            |                 |            |
| Category:       | All                          |                    | ~              | Package:   | All | ~                   | Temperatu  | re: All         | ~          |
| amily:          | All                          |                    | ~              | Speed:     | All | ~                   | Ĩ          |                 |            |
|                 |                              |                    |                |            |     |                     |            |                 |            |
|                 |                              |                    |                |            |     |                     |            |                 |            |
| Search:         | Q.                           |                    | ~              |            |     |                     |            |                 |            |
| Part<br>xc/a200 | tsdv484-2L                   | I/O Pin Count      | Available IOBs | LUT Elemer | nts | FlipFlops<br>269200 | Block RAMs | Ultra RAMs<br>U | DSI<br>/40 |
| xc7a200         | tsbv484-1                    | 484                | 285            | 134600     |     | 269200              | 365        | 0               | 740        |
| xc7k70tf        | bg484-3                      | 484                | 285            | 41000      |     | 82000               | 135        | 0               | 240        |
| xc7k70tf        | bg484-2                      | 484                | 285            | 41000      |     | 82000               | 135        | 0               | 240        |
| xc7k70tf        | bg484-2L                     | 484                | 285            | 41000      |     | 82000               | 135        | 0               | 240        |
| xc7k70tf        | bg484-1                      | 484                | 285            | 41000      |     | 82000               | 135        | 0               | 240        |
| xc7k70tf        | bg676-3                      | 676                | 300            | 41000      |     | 82000               | 135        | 0               | 240        |
| xc7k70tf        | bg676-2                      | 676                | 300            | 41000      |     | 82000               | 135        | 0               | 240        |
| xc7k70tf        | bg676-2L                     | 676                | 300            | 41000      |     | 82000               | 135        | 0               | 240 🗸      |
| <               |                              |                    |                |            |     |                     |            |                 | >          |
|                 |                              |                    |                |            |     |                     |            |                 |            |

You selected a Kintex<sup>®</sup>-7 device. This device family is used for the initial compatibility of the custom IP.

8. In the New Project Summary page, which opens, click **Finish** to create the project.

The Vivado IDE opens project\_lab3, with the default layout.

# Step 2: Package a Library Core

As discussed in the Introduction of this lab, the AXI GPIO Pcore requires several library references (sub-cores) to function.

Because these library cores do not exist in the latest Vivado releases, start by packaging the libraries before you package the AXI GPIO Pcore.

## Use the Create and Package Wizard

1. From the Tools menu, select **Create and Package New IP** to open the Create and Package IP wizard.



- 2. In the Create and Package New IP dialog box welcome screen, click **Next**.
- 3. In the Create Peripheral, Package IP, or Package a Block Design screen, select **Package a specified directory**.



- 4. In the Package a Specified Directory dialog box, shown in the following figure, set the options as follows:
  - Directory: <Extract\_Dir>/lab3/pcores/proc\_common\_v3\_00\_a
  - Check the **Package as a library core** option.





| À Create and Package New I                              | )              |                  |                 | ×          |
|---------------------------------------------------------|----------------|------------------|-----------------|------------|
| Package a Specified Di<br>Select the directory where so | -              | ed are located.  |                 | A          |
| Directory: creating-pa                                  |                | lab_3/pcores/pro | oc_common_v3_00 | <u>_a⊗</u> |
| (?)                                                     | < <u>B</u> ack | <u>N</u> ext >   | <u> </u>        | Cancel     |

- 5. Click Next.
- 6. In the Edit in IP Packager Project Name page, leave the default name and location, and click **Next**.
- 7. Click Finish.

An edit IP project opens in a new Vivado window with the Package IP window opened. The Package IP window displays the basic IP package in a staging area for editing and repackaging.

#### **Update the IP Information**

Because you selected the library core option, the Package IP window has as subset of available options for the custom IP, as shown in the following figure.

- 1. Update the library core with the necessary information, as follows:
- 2. Select the Identification page, and fill in the following fields:
  - Display name: proc\_common\_v3\_00\_a
  - Description: Proc Common v3.00.a Library Core

Notice that the Vendor and Library fields are auto-populated.



| Package IP - proc_common |                      |                                                                                              | _ 🗆 🕫 🗙     |
|--------------------------|----------------------|----------------------------------------------------------------------------------------------|-------------|
| Packaging Steps          | Identification       |                                                                                              |             |
| Identification           | Vendor:              | xilinx.com                                                                                   | 8           |
| ✓ File Groups            | Library:             | İp                                                                                           | 8           |
| Review and Package       | Name:                | proc_common                                                                                  | 8           |
|                          | Version:             | 3.00.a                                                                                       | 8           |
|                          | Display name:        | proc_common_v3_00_a                                                                          | 8           |
|                          | Description:         | Proc Common v3.00.a Library Core                                                             | 8           |
|                          | Vendor display name: |                                                                                              |             |
|                          | Company url:         |                                                                                              |             |
|                          | Root directory:      | c:/Tutorials/ug1119-vivado-creating-packaging-ip-design/lab_3/pcores/proc_common_v3_00_a     |             |
|                          | Xml file name:       | c:/Tutorials/ug1119-vivado-creating-packaging-ip-design/lab_3/pcores/proc_common_v3_00_a/con | nponent.xml |
|                          | Categories           |                                                                                              |             |
|                          | $+  -  \uparrow  $   | 1                                                                                            |             |
|                          |                      |                                                                                              |             |
|                          |                      | No content                                                                                   |             |
|                          |                      |                                                                                              |             |
|                          |                      |                                                                                              |             |
|                          |                      |                                                                                              |             |

3. Select **Review and Package** to view the name, location, and Root directory information about the library core, as shown in the following figure:

| Package IP - proc_common                            | _ D 7 ×                                                                                                                                                                                                                                                |
|-----------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Packaging Steps                                     | Review and Package                                                                                                                                                                                                                                     |
| Identification<br>File Groups<br>Review and Package | Summary           Display name:         proc_common_v3_00_a           Description:         Proc Common v3.00.a Library Core           Root directory:         c:/Tutorials/ug1119-vivado-creating-packaging-ip-design/lab_3/pcores/proc_common_v3_00_a |
|                                                     | After Packaging An archive will not be generated. Use the settings link below to change your preference Project will be removed after completion Edit packaging settings                                                                               |
|                                                     | Package IP                                                                                                                                                                                                                                             |





4. Click Package IP.

This completes the packaging for the proc\_common\_v3\_00\_a library core. If prompted, close the edit\_ip\_project.

## **Package Additional Library Cores**

Repeat the steps to package the axi\_lite\_ipif\_v1\_01 library and the interrupt\_control\_v2\_01\_a libraries. When packaging these two library cores, ensure that the display name and descripts for each of the library cores are as follows.

| Library Core      | Display Name              | Description                            |
|-------------------|---------------------------|----------------------------------------|
| axi_lite_ipif     | axi_lite_ipif_v1_01_a     | AXI Lite IPIF v1.01.a Library Core     |
| interrupt_control | interrupt_control_v2_01_a | Interrupt Control V2.01.a Library Core |

**IMPORTANT!** When packaging the additional library cores, the  $axi_lite_ipif$  and the  $interrupt_control_v2_01_a$  libraries will display a green checkmark for the File Group page.

# Step 3: Package the GPIO IP

Now that all the library cores are properly packaged, you can package the GPIO IP from the originally created lab\_3 project.

- 1. From the Tools menu, select **Create and Package New IP** to open the Create and Package IP wizard.
- 2. Click Next at the Welcome screen for the Create and Package New IP dialog box.
- 3. In the Create Peripheral, Package IP, or Package a Block Design dialog box, select **Package a specified directory**.
- 4. In the Package a Specified Directory dialog box, set the following option:

**Directory:** <Extract\_Dir>/lab3/pcores/axi\_gpio\_v1\_01\_b.





| 🝌 Create and Pa | ackage New IP       |                                  |                 |                     | ×      |
|-----------------|---------------------|----------------------------------|-----------------|---------------------|--------|
|                 | pecified Director   | <b>y</b><br>be packaged are loca | ited.           |                     | 4      |
| Directory:      | 'ug1119-vivado-crea | ating-packaging-ip-de            | sign/lab_3/pcor | es/axi_gpio_v1_01_t | »⊗ ··· |
| Packag          | e as a library core |                                  |                 |                     |        |
|                 |                     |                                  |                 |                     |        |
|                 |                     |                                  |                 |                     |        |
|                 |                     |                                  |                 |                     |        |
|                 |                     |                                  |                 |                     |        |
|                 |                     |                                  |                 |                     |        |
|                 |                     |                                  |                 |                     |        |
| ?               |                     | < <u>B</u> ack                   | <u>N</u> ext >  | Einish              | Cancel |

- 5. Click Next.
- 6. On the Edit in IP Packager Project Name page, leave the default locations, click **Next**, and then click **Finish**.

The Create and Package IP wizard collects the available information from the specified location. When specifying a directory for packaging, there are inference rules that assist in packaging the IP correctly.

For XPS processor cores (Pcores), if a peripheral analyze order file (PAO file) exists in the data directory, the wizard reads this file and uses the associated library information.

An edit IP project opens in a new Vivado<sup>®</sup> packaging window with the Package IP window opened, as shown below.



| Pack | age IP - axi_gpio                                                                                                                                                                      |                                                                                                                                      | _ D 🗗 X                                                                                                                                                                  |
|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Pac  | kaging Steps                                                                                                                                                                           | Identification                                                                                                                       |                                                                                                                                                                          |
| Pace | kaging Steps<br>Identification<br>Compatibility<br>File Groups<br>Customization Parameters<br>Ports and Interfaces<br>Addressing and Memory<br>Customization GUI<br>Review and Package | Vendor:<br>Library:<br>Name:<br>Version:<br>Display name:<br>Description:<br>Vendor display name:<br>Company url:<br>Root directory: | xilinx.com   user  user  axi_gpio  1.0  axi_gpio_v1_0  axi_gpio_v1_0  C/Tutorials/ug1119-vivado-creating-packaging-ip-design/lab_3/pcores/axi_gpio_v1_01_b/component.xml |
|      |                                                                                                                                                                                        | Categories                                                                                                                           | ۶<br>                                                                                                                                                                    |

## **Update the IP Identification**

- 1. In the Package IP window, update the following information:
  - Vendor: my\_company
  - Display name: My AXI GPIO EDK Pcore Tutorial
  - Description: UG1119 Tutorial Lab #3 AXI GPIO EDK Pcore
  - Vendor display name: My Company
  - Company url: <company\_URL>
- 2. Click the **File Groups** page to validate that the proper Sub-Core References (Library Cores) are added to the Package IP window.

In this case, the Interrupt Controller, the AXI4-Lite IPIG and the Proc Common display in the /Sub-Core References directories for Synthesis and Simulation.





| ackage IP - axi_gpio                         |                                        |                  | - 0 2     |
|----------------------------------------------|----------------------------------------|------------------|-----------|
| Packaging Steps                              | File Groups                            |                  |           |
| <ul> <li>Identification</li> </ul>           | Q   ¥   ♦   •€   +   C                 |                  |           |
| Constant Mile 1914                           | Name                                   | Library Name     | Туре      |
| <ul> <li>Compatibility</li> </ul>            | Standard                               |                  |           |
| <ul> <li>File Groups</li> </ul>              | ✓                                      |                  |           |
|                                              | Sub-Core References                    |                  |           |
| <ul> <li>Customization Parameters</li> </ul> | xilinx.com:ip:proc_common:3.00.a       |                  |           |
| <ul> <li>Ports and Interfaces</li> </ul>     | xilinx.com:ip:axi_lite_ipif:1.01.a     |                  |           |
|                                              | xilinx.com:ip:interrupt_control:2.01.a |                  |           |
| <ul> <li>Addressing and Memory</li> </ul>    | M hdl/vhdl/gpio_core.vhd               | axi_gpio_v1_01_b | vhdlSourc |
| <ul> <li>Customization GUI</li> </ul>        | M hdl/vhdl/axi_gpio.vhd                | axi_gpio_v1_01_b | vhdlSourc |
| Customization GOI                            | Simulation (2)                         |                  |           |
| Review and Package                           | Sub-Core References                    |                  |           |
|                                              | xilinx.com:ip:proc_common:3.00.a       |                  |           |
|                                              | xilinx.com:ip:axi_lite_ipif:1.01.a     |                  |           |
|                                              | xilinx.com:ip:interrupt_control:2.01.a |                  |           |
|                                              | M hdl/vhdl/gpio_core.vhd               | axi_gpio_v1_01_b | vhdlSourc |
|                                              | M hdl/vhdl/axi_gpio.vhd                | axi_gpio_v1_01_b | vhdlSourc |
|                                              | ✓                                      |                  |           |
|                                              | doc/html/change_log.html               |                  | html      |
|                                              | Advanced                               |                  |           |
|                                              | V 🗎 UI Layout (1)                      |                  |           |
|                                              | xgui/axi_gpio_v1_0.tcl                 |                  | tclSource |
|                                              | Data Sheet (1)                         |                  |           |
|                                              | 🔁 doc/ds744_axi_gpio.pdf               |                  | pdf       |

3. Click the **Customization Parameters**, as shown below, to explore the parameters defined for the custom IP.

| ackaging Steps           | Customization Parameters |             |                     |               |                         |              |              |
|--------------------------|--------------------------|-------------|---------------------|---------------|-------------------------|--------------|--------------|
| Identification           | Q   ¥   ♦   •€   +   C   |             |                     |               |                         |              |              |
|                          | Name                     | Description | Display Name        | Value         | Value Bit String Length | Value Format | Value Source |
| Compatibility            | Customization Parameters |             |                     |               |                         |              |              |
| File Groups              | C_INSTANCE               |             | C Instance          | axi_gpio_inst | 0                       | string       | default      |
|                          | C_S_AXI_ADDR_WIDTH       |             | C S Axi Addr Width  | 9             | 0                       | long         | default      |
| Customization Parameters | C_S_AXI_DATA_WIDTH       |             | C S Axi Data Width  | 32            | 0                       | long         | default      |
| Ports and Interfaces     | C_GPIO_WIDTH             |             | C Gpio Width        | 32            | 0                       | long         | default      |
|                          | C_GPIO2_WIDTH            |             | C Gpio2 Width       | 32            | 0                       | long         | default      |
| Addressing and Memory    | C_ALL_INPUTS             |             | C All Inputs        | 0             | 0                       | long         | default      |
| Customization GUI        | C_ALL_INPUTS_2           |             | C All Inputs 2      | 0             | 0                       | long         | default      |
| Gustornization Gor       | C_INTERRUPT_PRESENT      |             | C Interrupt Present | 0             | 0                       | long         | default      |
| Review and Package       | C_DOUT_DEFAULT           |             | C Dout Default      | 0x00000000    | 32                      | bitString    | default      |
|                          | C_TRI_DEFAULT            |             | C Tri Default       | 0xFFFFFFFF    | 32                      | bitString    | default      |
|                          | C_IS_DUAL                |             | C Is Dual           | 0             | 0                       | long         | default      |
|                          | C_DOUT_DEFAULT_2         |             | C Dout Default 2    | 0x00000000    | 32                      | bitString    | default      |
|                          | C_TRI_DEFAULT_2          |             | C Tri Default 2     | 0xFFFFFFFF    | 32                      | bitString    | default      |

4. Click **Review and Package** to view the Summary of the custom IP, as shown in the following figure.





| Packaging Steps                             | Review and Package                                                                                                                                                |
|---------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <ul> <li>Identification</li> </ul>          | Summary                                                                                                                                                           |
| <ul> <li>Compatibility</li> </ul>           | Display name: My AXI GPIO EDK Pcore Tutorial                                                                                                                      |
| <ul> <li>File Groups</li> </ul>             | Description: UG1119 Tutorial Lab #3 - AXI GPIO EDK Pcore<br>Root directory: c:/Tutorials/ug1119-vivado-creating-packaging-ip-design/lab_3/pcores/axi_gpio_v1_01_b |
| <ul> <li>Customization Parameter</li> </ul> |                                                                                                                                                                   |
| <ul> <li>Ports and Interfaces</li> </ul>    |                                                                                                                                                                   |
| <ul> <li>Addressing and Memory</li> </ul>   | After Packaging                                                                                                                                                   |
| <ul> <li>Customization GUI</li> </ul>       | An archive will not be generated. Use the settings link below to change your preference<br>Project will be removed after completion                               |
| Review and Package                          | Edit packaging settings                                                                                                                                           |
|                                             |                                                                                                                                                                   |
|                                             | Package IP                                                                                                                                                        |

- 5. Click the **Package IP** button to update the IP with the changes you made in the Package IP window.
- 6. After packaging is complete, close the edit\_ip\_project.

## **Step 4: Validate the New Custom IP**

After completing packaging of the library cores and the AXI GPIO IP, you can use project\_lab3 that you created to validate the generation of the custom IP.

**IMPORTANT!** Because you packaged the custom IP and library cores in this lab, the Repository Manager already contains the paths to the custom IP. If you use another project for validation, the repository paths for the custom IP and the library cores must be set.

- 1. In the Flow Navigator  $\rightarrow$  Project Manager, select IP Catalog.
- 2. In the search field at the top of the IP catalog, type AXI GPIO.

The My AXI GPIO EDK Pcore Tutorial IP shows under the /UserIP directory, shown in the figure.



| ¥   ♦   ।        | ¥ 4 2 0 0                                                              |                         |                 |     |  |  |
|------------------|------------------------------------------------------------------------|-------------------------|-----------------|-----|--|--|
| Name             | A1                                                                     | AXI4                    | Status          | Lie |  |  |
| 🗸 🗎 User Re      | epository (c:/Tutorials/ug1119-vivado-creating-packaging-ip-design/lab | _3/pcores/axi_gpio_v*   | 1_01_b)         |     |  |  |
| 🗸 🖨 User         | 1P                                                                     |                         |                 |     |  |  |
| ₽ M              | y AXI GPIO EDK Pcore Tutorial                                          | AXI4                    | Production      | Inc |  |  |
| 🖹 User Re        | epository (c:/Tutorials/ug1119-vivado-creating-packaging-ip-design/lab | _3/pcores/interrupt_co  | ontrol_v2_01_a) |     |  |  |
| 🗎 User Re        | epository (c:/Tutorials/ug1119-vivado-creating-packaging-ip-design/lab | _3/pcores/axi_lite_ipit | _v1_01_a)       |     |  |  |
| 🗎 User Re        | epository (c:/Tutorials/ug1119-vivado-creating-packaging-ip-design/lab | _3/pcores/proc_comn     | non_v3_00_a)    |     |  |  |
| (                |                                                                        |                         |                 | >   |  |  |
| Details<br>Name: | My AXI GPIO EDK Pcore Tutorial                                         |                         |                 |     |  |  |
| Version:         | 1.0 (Rev. 1)                                                           |                         |                 |     |  |  |
| Interfaces:      |                                                                        |                         |                 |     |  |  |
| Description:     | UG1119 Tutorial Lab #3 - AXI GPIO EDK Pcore                            |                         |                 |     |  |  |
| Status:          | Production                                                             |                         |                 |     |  |  |
| License:         | Included                                                               |                         |                 |     |  |  |
| Vendor:          | My Company                                                             |                         |                 |     |  |  |
| VLNV:            | my_company:user:axi_gpio:1.0                                           |                         |                 |     |  |  |
|                  | c:/Tutorials/ug1119-vivado-creating-packaging-ip-design/lab_3/pcores   |                         |                 |     |  |  |

- 3. Right-click the My AXI GPIO EDK Pcore Tutorial IP and select Customize IP.
- 4. Click **OK** to accept the default configuration options.
- 5. In the Generate Output Products dialog box, select Generate.

The files required for this IP in the current Manage IP project generate, and an out-of-context (OOC) synthesis run for the IP generates and creates a DCP file.

The Generate Output Products dialog re-opens to report that the output products generated successfully.

6. Close the project and exit the Vivado tool.

# Conclusion

This concludes Lab 3. You have successfully created the AXI GPIO Pcore by packaging the /Pcore directory as well the library dependencies. In this lab, you did the following:



- Used the Create and Package IP Wizard to package a specified directory for each of the library cores.
- Used the Create and Package IP Wizard to package a specified directory for the AXI GPIO Pcore.
- Validated the generation of the AXI GPIO Pcore custom IP.



Lab 4

# Packaging IP in a Revision Source (Trunk)

# Introduction

In this lab, you define new custom IP from a set of example files that mimic a repository development trunk. In addition, this lab describes the process for creating custom IP that depend on files from other IP within the repository trunk.

You start with an IP repository trunk and create a new Vivado<sup>®</sup> project. In the Vivado project, you package the different custom IP in the repository using the Create and Package IP Wizard. You also identify which need to be library cores, and verify the packaged files. The lab project contains Verilog source files.

# Step 1: Examine the Repository Trunk Directory

1. Examine the <Extract\_Dir>/lab\_4/trunk location.

The directory contains the files for the respective custom IP that would exist in the repository. In particular, there are two source directories.

- common\_v1\_0: Directory contains source for logic common to the IP within the repository trunk.
- myip\_v1\_0: Directory contains source for custom IP.

The  $common_v1_0$  directory contains a source file that is required by  $myip_v1_0$ . Because the component.xml file for  $myip_v1_0$  cannot reference a source file from outside the IP root directory, the source file from  $common_v1_0$  must be referenced differently.

**Note:** The directories containing the source files should be organized to ensure proper packaging. For an example on how to properly organize your source files, see Lab 2: Packaging a Specified Directory. Although not described in this lab, if your repository trunk does not have the same structure, you can package each source directory by packaging the associated Vivado project.



2. Examine the files in each of the directories for more information about the structure of the repository trunk.

## **Step 2: Create a New Vivado Project**

#### Launch Vivado

On Linux:

- Change to the directory where the lab materials are stored: cd <Extract\_Dir>/lab\_4.
- Launch the Vivado IDE: vivado.

#### On Windows:

• Launch the Vivado Design Suite IDE, by using either of the following methods:

Select Start  $\rightarrow$  All Programs  $\rightarrow$  Xilinx Design Tools  $\rightarrow$  Vivado 2020.x  $\rightarrow$  Vivado 2020.x.

Or

Click the Vivado 2020.x desktop icon.

The Vivado IDE Getting Started page displays with links to open or create projects, and to view documentation. For either Windows or Linux, continue the lab from this point.

## **Create a New Project**

1. From the Vivado IDE Getting Started page, select **Create Project** to create an empty Vivado project.

*Note*: A new or existing project is required to creating and packaging a custom IP. The project information is used for populating certain fields in the Package IP window.

- 2. Click Next at the New Project wizard dialog box.
- 3. In the Project Name page, as shown in the following figure, set the following options for the project location:
  - Project name: project\_lab4
  - **Project location:** <Extract\_Dir>/lab\_4





| 🝌 New Project                       |                                                                                 | ×      |
|-------------------------------------|---------------------------------------------------------------------------------|--------|
| Project Name<br>Enter a name for yo | ur project and specify a directory where the project data files will be stored. | 4      |
| Project name:                       | project_lab4                                                                    | 8      |
| Project location:                   | C:/Tutorials/workspace/ug1119-vivado-creating-packaging-ip-design/lab_4         | ⊗ …    |
| Create projec                       | t subdirectory                                                                  |        |
| Project will be cre                 | eated at: C://lab_4/project_lab4                                                |        |
|                                     |                                                                                 |        |
|                                     |                                                                                 |        |
|                                     |                                                                                 |        |
|                                     |                                                                                 |        |
|                                     |                                                                                 |        |
| ?                                   | < <u>B</u> ack <u>N</u> ext > <u>F</u> inish                                    | Cancel |

- 4. Click Next.
- 5. Select RTL Project as the **Project Type** and select **Do not specify sources at this time**.
- 6. Click Next.
- 7. In the Default Part dialog box, select the xcku040-ffva1156-2-e part and click Next.
- 8. For this lab, you select an UltraScale<sup>™</sup> architecture device. This device family is used for the initial compatibility of the custom IP.
- 9. Click **Finish** to close the New Project Summary page, and create the project.

The Vivado IDE opens project\_lab4, with the default layout.

## Step 3: Package the Library Core

After creating the new empty project, the next step is to create and package the common IP directory. The order of the packaging the IP directories are important because they need to be packaged in the order of dependency. All of the child IP must be packaged prior to packaging the parent IP. You will be setting this IP directory as a library core, which is a special kind of IP which is not for standalone use.



## **Use the Create and Package IP Wizard**

- 1. From the Tools menu, select **Create and Package New IP** to open the Create and Package IP Wizard.
- 2. Click Next at the Welcome screen for the Create and Package New IP dialog box.
- 3. In the Create Peripheral, Package IP, or Package Block Design dialog box, select **Package a specified directory**, as shown in the following figure.



- 4. Click Next.
- 5. In the Package a Specified Directory dialog box, shown in the following figure, set the options as follows:
  - Directory: <Extract\_Dir>/lab\_4/trunk/common\_v1\_0
  - Check the Package as a library core option.





| 🍌 Create and Package New IP                                                               |                         |                      | ×                    |
|-------------------------------------------------------------------------------------------|-------------------------|----------------------|----------------------|
| Package a Specified Directory<br>Select the directory where sources to be packaged are le | ocated.                 |                      | A                    |
| Directory: C:/Tutorials/workspace/ug1119-vivado                                           | -creating-packaging-ip- | design/lab_4/trunk/4 | common_v1_0 💿 \cdots |
| (?)                                                                                       | < <u>B</u> ack          | <u>N</u> ext >       | Einish               |

The Package as a library core option is used when the source is not intended to be used as a standalone IP. The option is intended to mark IP in the IP Catalog that can only be used as a child of another IP.

However, any Custom IP can be a child to another IP. If your Custom IP is not a library core, the process for referencing a child IP is the same. This option is just used to mitigate confusion of which IP should be used and hidden in the Vivado IP Catalog.

- 6. Click Next.
- 7. On the Edit in IP Packager Project Name window, leave the default locations, and click Next.
- 8. Click Finish.

An edit IP project opens in a new Vivado window with the Package IP window opened. The Package IP window displays the basic IP package information determined through the wizard. The project opens in the staging area for editing and repackaging.

## **Update the IP Information**

Because you selected the library core option, the Package IP window has a subset of available options for packaging, as shown in the following figure.





| Pro | ject Summary × Package IP | - common ×           |                                               | 06        |
|-----|---------------------------|----------------------|-----------------------------------------------|-----------|
| Pa  | ickaging Steps            | Identification       |                                               |           |
|     | Identification            | Vendor:              | xilinx.com                                    | 8         |
| -   | File Groups               | Library:             | ip                                            | 8         |
|     | Review and Package        | Name:                | common                                        | 8         |
|     |                           | Version:             | 1.0.                                          | $\otimes$ |
|     |                           | Display name:        |                                               | •         |
|     |                           | Description:         |                                               | θ         |
|     |                           | Vendor display name: |                                               |           |
|     |                           | Company url:         |                                               |           |
|     |                           | Root directory:      | c:/Temp/lab_4/trunk/common_v1_0               |           |
|     |                           | Xml file name:       | c:/Temp/lab_4/trunk/common_v1_0/component.xml |           |
|     |                           | Categories           |                                               |           |
|     |                           | +  -  +              | +                                             |           |
|     |                           |                      |                                               |           |
|     |                           |                      | No content                                    |           |
|     |                           |                      |                                               |           |
|     |                           |                      |                                               |           |

- 1. Update the Identification information as follows:
  - Vendor: my\_company
  - Display Name: My Company Common Library
  - Description: My Company Common Library Files
  - Vendor Display Name: My Company
  - Company url: <company\_URL>
- 2. Click the **Review and Package** page to view the name, location, and root directory information about the library core.
- 3. Click **Package IP** to update the IP with the updated identification information.

This completes the packaging for the common\_v1\_0 library core. If prompted, you can close the edit\_ip\_project.

## Step 4: Package the IP

Using the same project previously created,  $project_lab4$ , you will create and package the  $myip_v1_0$  IP directory. Because the common IP directory has already been packaged, all the required dependencies are available to package the parent IP.



## Add the IP Repository

Before you package the parent IP, you must set the repository location in the project settings to include the  $common_v1_0$  IP that was just created in the IP catalog.

- 1. Select Flow Navigator  $\rightarrow$  Project Manager  $\rightarrow$  Settings  $\rightarrow$  IP.
- 2. Expand **IP** and select the **Repository**. In the view, the repository in which the previously packaged **IP** should automatically show up, if not click the **Add Repository** button.
- 3. In the IP Repositories dialog box, select the path <Extract\_Dir>/lab\_4/trunk and press Select to add the repository.

The Add Repository dialog box opens to display that the trunk repository was added to the project and one IP was found, as shown in the following figure.

| 🝌 Add | Repository                                                                                                          | $\times$ |
|-------|---------------------------------------------------------------------------------------------------------------------|----------|
| 0     | 1 repository was added to the project. For more information related to disabled<br>IPs, please refer to IP Catalog. |          |
| Repo  | sitory                                                                                                              |          |
| ¥     | \$                                                                                                                  |          |
| ~ 0   | ::/Tutorials/workspace/ug1119-vivado-creating-packaging-ip-design/lab_4/trunk > IPs (1)                             |          |
|       | ОК                                                                                                                  |          |

#### 4. Click OK.

The Repository Manager is now populated with the selected IP repository, in addition to the  $common_v1_0$  repository.

- 5. To remove the common\_v1\_0 repository, select it and then select the **Remove** button —.
- 6. Click **OK** to close the IP Setting dialog box.

#### **Use the Create and Package IP Wizard**

- 1. From the Tools menu, select **Create and Package New IP** to open the Create and Package IP Wizard.
- 2. Click Next at the Welcome screen for the Create and Package New IP dialog box.
- 3. In the Create Peripheral, Package IP, or Package Block Design dialog box, select **Package a specified directory**.



- 4. Click Next.
- 5. In the Package a Specified Directory dialog box, shown in the following figure, set the options as follows:
  - Directory: <Extract\_Dir>/lab\_4/trunk/myip\_v1\_0
  - Do not select the Package as a library core option.

| A Create and Package New IP                                                          |                       |                   |                   | ×      |
|--------------------------------------------------------------------------------------|-----------------------|-------------------|-------------------|--------|
| Package a Specified Directory<br>Select the directory where sources to be packaged a | are located.          |                   |                   | A      |
| Directory: C:/Tutorials/workspace/ug1119-viv                                         | ado-creating-packagin | g-ip-design/lab_4 | 4/trunk/myip_v1_0 |        |
| ?                                                                                    | < <u>B</u> ack        | <u>N</u> ext >    | Einish            | Cancel |

- 6. Click Next.
- 7. On the Edit in IP Packager Project Name window, leave the default locations, and click **Next**.
- 8. Click Finish.

An edit IP project opens in a new Vivado window with the Package IP window opened, as shown in the following figure, to continue with the next steps.





| ckage IP - myip_top      |                     | _ D ē                                                                                     |
|--------------------------|---------------------|-------------------------------------------------------------------------------------------|
| ackaging Steps           | Identification      |                                                                                           |
| / Identification         | Vendor:             | xilinx.com                                                                                |
| Compatibility            | Library:            | user                                                                                      |
| File Groups              | Name:               | myip_top                                                                                  |
| Customization Parameters | Version:            | 1.0                                                                                       |
| Ports and Interfaces     | Display name:       | myip_top_v1_0                                                                             |
|                          | Description:        | myip_top_v1_0                                                                             |
| Addressing and Memory    | Vendor display name |                                                                                           |
| Customization GUI        | Company url:        |                                                                                           |
| Review and Package       | Root directory:     | c:/Tutorials/ug1119-vivado-creating-packaging-ip-design/lab_4/trunk/myip_v1_0             |
|                          | Xml file name:      | c:/Tutorials/ug1119-vivado-creating-packaging-ip-design/lab_4/trunk/myip_v1_0/component.x |
|                          | Categories          |                                                                                           |
|                          | + - 1               | ÷                                                                                         |
|                          | /UserIP             |                                                                                           |
|                          |                     |                                                                                           |
|                          |                     |                                                                                           |
|                          |                     |                                                                                           |

- 9. Update the IP Information and Contents In the Package IP window, update the following information on the Identification page:
  - Vendor: my\_company
  - Display Name: My IP
  - Description: UG1119 Tutorial Lab #4 My IP
  - Vendor Display Name: My Company
  - Company url: <company\_URL>
- 10. Click the **File Groups** to examine the files included in the packaged IP, as shown in the following figure.





| Package IP - myip_top D 🖓 🗙              |                                                            |              |               |  |  |  |
|------------------------------------------|------------------------------------------------------------|--------------|---------------|--|--|--|
| Packaging Steps                          | File Groups                                                |              |               |  |  |  |
| Identification                           | Q   X   \$   <b>4</b>   <b>4</b>   C                       |              |               |  |  |  |
| <ul> <li>Compatibility</li> </ul>        | Name<br>V 🖨 Standard                                       | Library Name | Туре          |  |  |  |
| ✓ File Groups                            | ✓                                                          |              |               |  |  |  |
| Customization Parameters                 | <ul> <li>src/myip_top.v</li> <li>Simulation (1)</li> </ul> |              | verilogSource |  |  |  |
| <ul> <li>Ports and Interfaces</li> </ul> | src/myip_top.v                                             |              | verilogSource |  |  |  |
| Addressing and Memory                    | <ul> <li>Advanced</li> <li>ILayout (1)</li> </ul>          |              |               |  |  |  |
| <ul> <li>Customization GUI</li> </ul>    | xgui/myip_top_v1_0.tcl                                     |              | tclSource     |  |  |  |
| Review and Package                       |                                                            |              |               |  |  |  |

The packaged IP only contains the top-level source file, myip\_top, as this was the only file in the selected IP directory <Extract\_Dir>/lab\_4/trunk/myip\_v1\_0. This file instantiates the IP common\_v1\_0.

11. As reference, if you examine the Hierarchy Sources in the project, you can see that the common module is missing, as shown in the following figure.



This is expected behavior, because you add the missing IP source files through the Package IP window.

12. In the File Group window, right-click the Synthesis file group and select Add Sub-Core Reference, as shown in the following figure.



| Package IP - myip_top                    |                                                      |                                           | _ D @ X  |
|------------------------------------------|------------------------------------------------------|-------------------------------------------|----------|
| Packaging Steps                          | File Groups                                          |                                           |          |
| <ul> <li>Identification</li> </ul>       | Q   素   ♣   ■∎                                       | +   C                                     |          |
| <ul> <li>Compatibility</li> </ul>        | Name<br>V Standard                                   | Library Name                              | Туре     |
| ✓ File Groups                            | 🗸 🖹 Synthesis (1)                                    |                                           |          |
| Customization Parameters                 | <ul><li>in src/myip</li><li>✓ □ Simulation</li></ul> | Add Files<br>Add URL                      | ogSource |
| <ul> <li>Ports and Interfaces</li> </ul> | <ul><li>isrc/myip</li><li>✓ 	☐ Advanced</li></ul>    | Add Sub-Core Reference.<br>Add File Group | ogSource |
| Addressing and Memory                    | V 🗎 UI Layout (                                      | Remove File Group                         |          |
| <ul> <li>Customization GUI</li> </ul>    | 😢 xgui/myi                                           | Сору То                                   | urce     |
| Review and Package                       | с                                                    | Refresh Table                             | r        |
|                                          |                                                      | Export to Spreadsheet                     |          |
|                                          |                                                      |                                           |          |
|                                          | <                                                    |                                           | >        |

13. In the Add Sub-Core Reference dialog box, select the **My Company Common Library** that you created in the previous steps, as shown in the following figure.

| À Add Sub-Core Reference                   |                 |      |        |          |                           | ×      |
|--------------------------------------------|-----------------|------|--------|----------|---------------------------|--------|
| Select IP to be used as references in File | e Group: Synthe | sis  |        |          |                           | 4      |
| Search: Q- my comp                         | 🔕 (1 match)     |      |        |          |                           |        |
| Name                                       | ^1              | AXI4 | Status | License  | VLNV                      |        |
| 👎 My Company Common Library                |                 |      |        | Included | my_company:ip:common:1.0. |        |
|                                            |                 |      |        |          |                           |        |
|                                            |                 |      |        |          |                           |        |
|                                            |                 |      |        |          | ОК                        | Cancel |

#### 14. Click OK.

The File Groups page is updated with the selected Sub-Core Reference under the Synthesis File Group, as shown in the following figure.

Adding an IP as a Sub-Core Reference informs the Vivado IDE to copy the files associated IP to the parent IP during generation; therefore, when  $myip_v1_0$  is generated, the  $common_v1_0$  files are copied to the location with the rest of the generated output products. This mechanism allows users to systematically share IP files.



| Package IP - myip_top                    |                                                                            |              | _ D @ X       |
|------------------------------------------|----------------------------------------------------------------------------|--------------|---------------|
| Packaging Steps                          | File Groups                                                                |              |               |
| <ul> <li>Identification</li> </ul>       | Q ≭ ≑ 4 C                                                                  |              |               |
| ✓ Compatibility                          | Name<br>V 🖨 Standard                                                       | Library Name | Туре          |
| ✓ File Groups                            | ✓ ➡ Synthesis (1)                                                          |              |               |
| Customization Parameters                 | <ul> <li>Sub-Core References</li> <li>my_company:ip:common:1.0.</li> </ul> |              |               |
| <ul> <li>Ports and Interfaces</li> </ul> | src/myip_top.v     Simulation (1)                                          |              | verilogSource |
| Addressing and Memory                    | <pre>@ src/myip_top.v</pre>                                                |              | verilogSource |
| <ul> <li>Customization GUI</li> </ul>    | V C Advanced                                                               |              |               |
| Review and Package                       | xgui/myip_top_v1_0.tcl                                                     |              | tclSource     |
|                                          | <                                                                          | -            | >             |

The Sub-Core Reference is added for the Synthesis File Group, and the same process needs to be performed for Simulation.

- 15. In the File Group window, right-click the Simulation file group, and select **Add Sub-Core Reference**.
- 16. In Add Sub-Core Reference dialog box, select My Company Common Library.
- 17. Click **OK**.

The Sub-Core References are now added to both the Synthesis and Simulation File Groups, as shown in the following figure. The necessary files from the  $common_v1_0$  IP are available to  $myip_v1_0$  for both Synthesis and Simulation.





| Package IP - myip_top                    |                                                   |              | _ D @ X       |
|------------------------------------------|---------------------------------------------------|--------------|---------------|
| Packaging Steps                          |                                                   |              |               |
| <ul> <li>Identification</li> </ul>       | Q   ≚   ≑   <b>€</b>   +   C                      |              |               |
| <ul> <li>Compatibility</li> </ul>        | Name V Standard                                   | Library Name | Туре          |
| ✓ File Groups                            | Synthesis (1)                                     |              |               |
| Customization Parameters                 | ✓ Sub-Core References ₱ my_company:ip:common:1.0. |              |               |
| <ul> <li>Ports and Interfaces</li> </ul> | src/myip_top.v     Simulation (1)                 |              | verilogSource |
| Addressing and Memory                    | Sub-Core References                               |              |               |
| <ul> <li>Customization GUI</li> </ul>    | <pre> p my_company:ip:common:1.0. </pre>          |              |               |
| Review and Package                       | src/myip_top.v     Advanced                       |              | verilogSource |
|                                          | V 🖨 UI Layout (1)                                 |              |               |
|                                          | xgui/myip_top_v1_0.tcl                            |              | tclSource     |
|                                          | <                                                 |              | >             |

- 18. Click the **Review and Package** page to view the name, location, and root directory information about the IP.
- 19. Click **Package IP** to update the IP with the updated identification and Sub-Core Reference information.

This completes the packaging for the  $myip_v1_0$  IP. If prompted, you can close the  $edit_ip_project$ .

**Note:** Adding a sub-core reference in the Package IP window does affect the state of the edit IP project. The Hierarchy Sources window continues to display the missing modules located within the sub-core reference. This information only exists within the Package IP window and component.xml. If you want to verify the IP with the files from the Sub-Core Reference, you can reopen the packaged IP in an edit IP project through the IP catalog and the associated Sub-Core Reference files will be present.

## Step 5: Validate the IP

After completing the packaging of the common\_v1\_0 and myip\_v1\_0 IP, you can use project\_lab4 to validate the generation of myip\_v1\_0.

- 1. In the Flow Navigator  $\rightarrow$  Project Manager, select IP Catalog.
- 2. In the search field at the top of the IP catalog, type My IP.





The My IP core shows under the /UserIP directory, as shown in the following figure.

| P Catalog                                                |                                                           |                           |                         |                  |          |                              | ? _ 🗆 🖓 |
|----------------------------------------------------------|-----------------------------------------------------------|---------------------------|-------------------------|------------------|----------|------------------------------|---------|
| Cores   Int                                              | refaces                                                   |                           |                         |                  |          |                              |         |
| <b>X</b>   <b>♦</b>  [                                   | ₽   - Ç   ⊁   2   0                                       | 📴 🏮 🔍 My IP               |                         | 8                |          |                              |         |
| Name                                                     |                                                           | ^                         | 1 AXI4                  | Status           | License  | VLNV                         |         |
| 🖞 🗁 User R                                               | Repository (c:/Tutorials/ug11                             | 119-vivado-creating-packa | aging-ip-design/lab_4/l | trunk/myip_v1_0) |          |                              |         |
| 🗸 🖨 Use                                                  | erIP                                                      |                           |                         |                  |          |                              |         |
| 👎 UG1119 Tutorial Lab #4 - My IP                         |                                                           | y IP                      |                         | Production       | Included | my_company:user:myip_top:1.0 |         |
| Details                                                  |                                                           |                           |                         |                  |          |                              |         |
| Details                                                  |                                                           |                           |                         |                  |          |                              |         |
| Details<br>Name:                                         | UG1119 Tutorial Lab #4 -                                  | - My IP                   |                         |                  |          |                              |         |
|                                                          | UG1119 Tutorial Lab #4 -<br>1.0 (Rev. 1)                  | - My IP                   |                         |                  |          |                              |         |
| Name:<br>Version:                                        |                                                           | - My IP                   |                         |                  |          |                              |         |
| Name:<br>Version:                                        | 1.0 (Rev. 1)                                              | - My IP                   |                         |                  |          |                              |         |
| Name:<br>Version:<br>Description:                        | 1.0 (Rev. 1)<br>: myip_top_v1_0                           | - My IP                   |                         |                  |          |                              |         |
| Name:<br>Version:<br>Description:<br>Status:             | 1.0 (Rev. 1)<br>: myip_top_v1_0<br>Production             | - My IP                   |                         |                  |          |                              |         |
| Name:<br>Version:<br>Description:<br>Status:<br>License: | 1.0 (Rev. 1)<br>: myip_top_v1_0<br>Production<br>Included |                           |                         |                  |          |                              |         |

- 3. Right-click the My IP core and select Customize IP.
- 4. In the Customization IP dialog box, click **OK**.
- 5. In the Generate Output Products dialog box, select Generate.

By default, the IP is generated out-of-context (OOC), which means the IP is synthesized standalone, and producing a DCP file. This IP example has not been optimized for ideal use for OOC synthesis. For more information regarding proper use of your custom IP for OOC synthesis, see Lab 1: Packaging a Project.

- 6. Click **OK** to close the Generate Output Products message box.
- 7. After the Out-of-Context Module Run completes successfully, close the project and exit the Vivado tool.

# Conclusion

This concludes Lab 4. You have successfully created two IP within a repository trunk, and created an IP that referenced another IP through a sub-core reference.

In this lab, you did the following:

- Used the Create and Package IP Wizard to package a specified directory for the common\_v1\_0 library core.
- Used the Create and Package IP Wizard to package a specified directory for the myip\_v1\_0 IP.



- Referenced the common\_v1\_0 IP as a Sub-Core Reference in myip\_v1\_0 in the File Groups page.
- Validated the generation of the myip\_v1\_0 IP.





# Appendix A

# Additional Resources and Legal Notices

## **Xilinx Resources**

For support resources such as Answers, Documentation, Downloads, and Forums, see Xilinx Support.

## **Documentation Navigator and Design Hubs**

Xilinx<sup>®</sup> Documentation Navigator (DocNav) provides access to Xilinx documents, videos, and support resources, which you can filter and search to find information. To open DocNav:

- From the Vivado<sup>®</sup> IDE, select Help → Documentation and Tutorials.
- On Windows, select Start → All Programs → Xilinx Design Tools → DocNav.
- At the Linux command prompt, enter docnav.

Xilinx Design Hubs provide links to documentation organized by design tasks and other topics, which you can use to learn key concepts and address frequently asked questions. To access the Design Hubs:

- In DocNav, click the **Design Hubs View** tab.
- On the Xilinx website, see the Design Hubs page.

*Note*: For more information on DocNav, see the Documentation Navigator page on the Xilinx website.





## References

#### Xilinx Web Resources

- 1. Vivado IP Versioning
- 2. Xilinx Answer Record 68071
- 3. Vivado Design Suite Documentation

#### Vivado Design Suite Documentation

These documents provide supplemental material useful with this guide:

- 1. Vivado Design Suite Tcl Command Reference Guide (UG835)
- 2. Vivado Design Suite Tutorial: Design Flows Overview (UG888)
- 3. Vivado Design Suite User Guide: Design Flows Overview (UG892)
- 4. Vivado Design Suite User Guide: Using the Vivado IDE (UG893)
- 5. Vivado Design Suite User Guide: Using Tcl Scripting (UG894)
- 6. Vivado Design Suite User Guide: System-Level Design Entry (UG895)
- 7. Vivado Design Suite User Guide: Designing with IP (UG896)
- 8. Vivado Design Suite User Guide: Logic Simulation (UG900)
- 9. Vivado Design Suite User Guide: Synthesis (UG901)
- 10. Vivado Design Suite User Guide: Using Constraints (UG903)
- 11. Vivado Design Suite User Guide: Implementation (UG904)
- 12. Vivado Design Suite User Guide: Hierarchical Design (UG905)
- 13. Vivado Design Suite User Guide: Programming and Debugging (UG908)
- 14. Vivado Design Suite Properties Reference Guide (UG912)
- 15. Vivado Design Suite Tutorial: Programming and Debugging (UG936)
- 16. Vivado Design Suite Tutorial: Logic Simulation (UG937)
- 17. Vivado Design Suite Tutorial: Designing with IP (UG939)
- 18. UltraFast Design Methodology Guide for Xilinx FPGAs and SoCs (UG949)
- 19. Vivado Design Suite User Guide: Release Notes, Installation, and Licensing (UG973)
- 20. UltraScale Architecture Libraries Guide (UG974)
- 21. Vivado Design Suite User Guide: Designing IP Subsystems Using IP Integrator (UG994)
- 22. Vivado Design Suite: AXI Reference Guide (UG1037)



- 23. Vivado Design Suite User Guide: Creating and Packaging Custom IP (UG1118)
- 24. Vivado Design Suite Tutorial: Creating, Packaging Custom IP (UG1119)

#### **Xilinx IP Documentation**

- 1. Integrated Bit Error Ratio Tester 7 Series GTX Transceivers LogiCORE IP Product Guide (PG132)
- 2. Integrated Bit Error Ratio Tester 7 Series GTP Transceivers LogiCORE IP Product Guide (PG133)
- 3. Integrated Bit Error Ratio Tester 7 Series GTH Transceivers LogiCORE IP Product Guide (PG152)
- 4. Virtual Input/Output LogiCORE IP Product Guide (PG159)
- 5. Integrated Logic Analyzer LogiCORE IP Product Guide (PG172)
- 6. AXI Verification IP LogiCORE IP Product Guide (PG267)
- 7. AXI4-Stream Verification IP LogiCORE IP Product Guide (PG277)
- 8. AXI4-Stream Verification IP LogiCORE IP Product Guide (PG277)
- 9. Zynq-7000 SoC Verification IP Data Sheet (DS941)

#### **Third-Party Documentation**

- 1. IEEE 1735-2014 IEEE Recommended Practice for Encryption and Management of Electronic Design Intellectual Property (IP)
- 2. IEEE Standard for IP-XACT, Standard Structure for Packaging, Integrating, and Reusing IP within Tool Flows

## **Please Read: Important Legal Notices**

The information disclosed to you hereunder (the "Materials") is provided solely for the selection and use of Xilinx products. To the maximum extent permitted by applicable law: (1) Materials are made available "AS IS" and with all faults, Xilinx hereby DISCLAIMS ALL WARRANTIES AND CONDITIONS, EXPRESS, IMPLIED, OR STATUTORY, INCLUDING BUT NOT LIMITED TO WARRANTIES OF MERCHANTABILITY, NON-INFRINGEMENT, OR FITNESS FOR ANY PARTICULAR PURPOSE; and (2) Xilinx shall not be liable (whether in contract or tort, including negligence, or under any other theory of liability) for any loss or damage of any kind or nature related to, arising under, or in connection with, the Materials (including your use of the Materials), including for any direct, indirect, special, incidental, or consequential loss or damage (including loss of data, profits, goodwill, or any type of loss or damage suffered as a result of any action brought by a third party) even if such damage or loss was reasonably foreseeable or Xilinx had been advised of the possibility of the same. Xilinx assumes no obligation to correct any errors contained in the Materials or to notify you of updates to the Materials or to product specifications. You may not reproduce, modify, distribute, or publicly display the Materials without prior written consent. Certain products are subject to the terms and conditions of



Xilinx's limited warranty, please refer to Xilinx's Terms of Sale which can be viewed at https:// www.xilinx.com/legal.htm#tos; IP cores may be subject to warranty and support terms contained in a license issued to you by Xilinx. Xilinx products are not designed or intended to be fail-safe or for use in any application requiring fail-safe performance; you assume sole risk and liability for use of Xilinx products in such critical applications, please refer to Xilinx's Terms of Sale which can be viewed at https://www.xilinx.com/legal.htm#tos.

#### AUTOMOTIVE APPLICATIONS DISCLAIMER

AUTOMOTIVE PRODUCTS (IDENTIFIED AS "XA" IN THE PART NUMBER) ARE NOT WARRANTED FOR USE IN THE DEPLOYMENT OF AIRBAGS OR FOR USE IN APPLICATIONS THAT AFFECT CONTROL OF A VEHICLE ("SAFETY APPLICATION") UNLESS THERE IS A SAFETY CONCEPT OR REDUNDANCY FEATURE CONSISTENT WITH THE ISO 26262 AUTOMOTIVE SAFETY STANDARD ("SAFETY DESIGN"). CUSTOMER SHALL, PRIOR TO USING OR DISTRIBUTING ANY SYSTEMS THAT INCORPORATE PRODUCTS, THOROUGHLY TEST SUCH SYSTEMS FOR SAFETY PURPOSES. USE OF PRODUCTS IN A SAFETY APPLICATION WITHOUT A SAFETY DESIGN IS FULLY AT THE RISK OF CUSTOMER, SUBJECT ONLY TO APPLICABLE LAWS AND REGULATIONS GOVERNING LIMITATIONS ON PRODUCT LIABILITY.

#### Copyright

© Copyright 2013-2021 Xilinx, Inc. Xilinx, the Xilinx logo, Alveo, Artix, Kintex, Spartan, Versal, Virtex, Vivado, Zynq, and other designated brands included herein are trademarks of Xilinx in the United States and other countries. All other trademarks are the property of their respective owners.

