

# **Design Separation Methodology User Guide**

## Introduction

This guide describes the design separation methodology required to implement security and safety-critical applications. For a system to be secure and reliable, all critical subsystems in the design should be independent of each other.

Traditionally, a system with security and safety-critical requirements is built with each critical subsystem implemented using multiple integrated circuits (ICs). With each critical subsystem as an independent IC, fault and reliability analysis is simplified. In a traditional Field Programmable Gate Array (FPGA) design, netlists generated for place-and-route often are flattened for efficient placement. Design functions from various parts of the design hierarchy may share physical resources. To meet critical security and safety application requirements, critical subsystems within an FPGA design might need to be isolated to simplify failure analysis and prevent propagation of faults from one subsystem adversely affecting another.

The Microchip Design Separation methodology provides a way to create independent critical subsystems on a single FPGA. Functional blocks that must be independent can be isolated physically from other functional elements in the FPGA using place-and-route constraints in the Libero SoC software. The following figure shows a top-level view for implementing a security and safety-critical application in a Microchip FPGA.



Figure 1. Implementing Security and Safety-Critical Applications in Microchip FPGAs

# **Table of Contents**

| Intr | oductio | n                                                                 | 1  |
|------|---------|-------------------------------------------------------------------|----|
| 1.   | Desig   | n Methodology                                                     | 5  |
|      | 1.1.    | Design Separation Methodology Components                          | 5  |
|      | 1.2.    | Design Separation Methodology Steps                               | 5  |
|      | 1.3.    | Creating Blocks                                                   | 7  |
|      | 1.4.    | Assigning I/Os to the Block                                       | 9  |
|      | 1.5.    | Optional CoreSMIP Block                                           | 11 |
|      | 1.6.    | Creating a Top-level Design                                       | 11 |
|      | 1.7.    | FloorPlanning with Design Separation Regions                      | 12 |
|      | 1.8.    | IRS Regions                                                       | 16 |
|      | 1.9.    | Considerations for Global Clock Resources                         | 16 |
|      | 1.10.   | Initialization of Hard ASIC Blocks                                | 17 |
|      | 1.11.   | Complete Place-and-Route                                          | 17 |
|      | 1.12.   | Configuring Security Settings and Generating the Programming File | 17 |
|      | 1.13.   | Auditing by MSVT                                                  | 17 |
|      | 1.14.   | Executing MSVT                                                    | 18 |
|      | 1.15.   | Further Considerations and Adjustments                            | 20 |
| 2.   | Exam    | ple                                                               | 22 |
|      | 2.1.    | Creating HDL Subsystems                                           | 22 |
|      | 2.2.    | Creating Blocks                                                   | 23 |
|      | 2.3.    | Publishing the Block                                              | 28 |
|      | 2.4.    | Creating a Top-level Design                                       | 29 |
|      | 2.5.    | Floorplanning Design with Separation Regions                      | 34 |
|      | 2.6.    | Complete Place-and-Route                                          | 37 |
|      | 2.7.    | Configure Security Settings and Generate the Programming File     | 37 |
|      | 2.8.    | Execute MSVT                                                      | 39 |
| 3.   | Revis   | on History                                                        | 42 |
| 4.   | Micro   | chip FPGA Technical Support                                       | 43 |
|      | 4 1     | Customer Service                                                  | 43 |
|      | 4.2     | Customer Technical Support                                        | 43 |
|      | 4.3     | Website                                                           | 43 |
|      | 4.4.    | Outside the U.S.                                                  | 43 |
| The  | Micro   | chip Website                                                      | 44 |
| Pro  | duct Cl | hange Notification Service                                        | 44 |
| -    |         |                                                                   |    |
| Cus  | stomer  | Support                                                           | 44 |
| Mic  | rochip  | Devices Code Protection Feature                                   | 44 |
| Leg  | al Noti | ce                                                                | 45 |
| Tra  | demark  | S                                                                 | 45 |

| Quality Management System   | 46 |
|-----------------------------|----|
| Worldwide Sales and Service | 47 |

## 1. Design Methodology

The following topics describe the design methodology.

## 1.1 Design Separation Methodology Components

The Microchip Design Separation methodology comprises of the following features:

- Ability to create independent subsystems.
- Ability to validate that isolation.
- Ability to monitor for faults.

The Design Separation methodology leverages an existing design methodology referred to as a "Block flow" to achieve isolated functions. Block flow is a bottom-up design methodology that allows an incremental design approach. In a Block flow compile, component modules in a design are compiled and optimized in independent stages from the rest of the project. After compiling, the component modules are published as a netlist (or "Block"), and then imported to a top-level project for integration with other modules in the larger system design.

Because the Block must be compiled with all the required physical resources, resource reservation is a key component of Block flow. Routing reservation and logic reservation are both constraint options available from the Block flow methodology. As a result, creating isolated subsystems for security and safety-critical applications is an application of Block flow. All critical subsystems are assigned to an exclusive region (a region with strict resource reservation) and floorplanned with a guard-band of unused clusters away from all other logic. **Note:** The width of the guard-band depends on individual project requirements.

Signal connections to another module (known as "Inter-Region Signals" within this flow) are assigned to another resource-reserved region called the "IRS Region". This region overlaps the source and sink regions. In this way, the Inter-Region Signals are members of the source region, the sink region, and the IRS Region. The IRS Region acts as a constrained routing channel.

A separate tool known as the Microchip Separation Verification Tool (MSVT) checks that a design meets the separation requirements defined by the system requirements of the design. MSVT is an independent tool included with the Libero installation. Libero SoC generates the parameter file MSVT.param automatically, which describes the Blocks in the design, and the number of signals entering and leaving a Block. MSVT checks the final design place-and-route against the MSVT.param file and reports any violations based on the separation requirement defined by the user.

Anti-Tamper (AT) must be considered in addition to the isolation of critical design subsystems. PolarFire<sup>®</sup>, SmartFusion<sup>®</sup>2, and IGLOO<sup>®</sup>2 devices come with standard robust design security, a critical portion of which is AT and fault detection. PolarFire, SmartFusion2 and IGLOO2 devices include mechanisms that allow an FPGA design to monitor the integrity of the device during operation.

Fault detection is a critical part of security-and safety-critical systems. To address this requirement, an IP core ties together the relevant AT hooks in CoreSMIP\_PF (PolarFire) and CoreSMIP (SmartFusion2 and IGLOO2) devices.

## 1.2 Design Separation Methodology Steps

The following flow chart shows the various steps of the design separation methodology.

#### Figure 1-1. Microchip Design Separation Methodology



- Create an RTL description for each subsystem. Each subsystem should be independent from the others with its own logic resources. The RTL module defining each subsystem should be independent of other subsystems.
- 2. Define each independent subsystem as a Block. The Block design flow creates logical partitions for the subsystems in question as a handle for place-and-route constraints in later stages of the design separation methodology.

**Note:** All corresponding I/O ports of a subsystem should be assigned to the respective Block. In the design separation methodology, all logic must be a member of an isolated Block region.

- 3. For each Block, run Synthesis and Compile. Assess the size and shape of suitable regions based on the types of I/O, count and length of cascaded Math blocks, RAM count, PLLs, peripherals and fabric resource usage. Publish the Block without place-and-route.
- Write a top-level module that only instantiates and connects all the Blocks. Import each published Block. Enable the Design Separation Methodology option in the Project Settings... > Design Flow > Design Separation > Enable Design Separation Methodology.
- 5. For each Block in the design, create separation regions by specifying region constraints using Chip Planner or defining regions in a PDC file.
- 6. Assign Blocks to the isolated regions.
- 7. If two Blocks interact with each other, create an overlapping IRS region constraint connecting the Blocks. These IRS regions should also be physically isolated from other blocks and IRS regions. Assign IRS nets to each respective IRS region.
- 8. Enter the necessary timing constraints. Perform design iterations to achieve timing closure.
- 9. Verify all aspects of timing and power.
- 10. Generate back-annotated files and perform post-layout simulations when required.
- 11. Configure security and programming options before generating the programming file. This step also exports information for MSVT.
- 12. Run MSVT from the command line. If MSVT fails, re-examine the floorplan and iterate the entire design flow with corrected region constraints.

## 1.3 Creating Blocks

A security and safety-critical application may consist of one or more independent subsystems. Using Hardware Description Language (HDL), define each subsystem to be independent from the rest of the system.

Each subsystem should have its own resources, including I/O buffers for external FPGA signals. A Block element is created for each such subsystem, which is then instantiated in a top-level design. To create a Block element for each subsystem:

- 1. Right-click the target module in the **Design Hierarchy** tab and choose **Set as root**.
- 2. Enable block creation from Project Settings (see the following figure).

#### Figure 1-2. Project Settings for Block Creation

| Project settings                                                                                                                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                |
|-----------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| Device selection<br>Device settings<br>Design flow<br>Analysis operating conditions<br>Simulation options<br>Do file<br>Waveforms<br>Visim commands | HDL source files language options Libers SoC supports mixed-HDL language designs; you can import Verlog and VHDL in the same project. For Verlog files you can enable the System Versyntax option if your Verlog files contain System Verlog constructs. For VHDL files, you may choose between VHDL-2008 and VHDL-33. SystemVerlog defines the notion of "compliation unit." When enabling the Multi-File Compliation Unit (MFCU) option, all files are compiled in the same of an arcros defined in one file will be seen by other files compiled later based on the file order. When disabling that option, each file is compiled as a separate compliation unit. | rrllog Discard |
| - Simulation libraries<br>                                                                                                                          | C Verlog 2001 C System Verlog Multi File Compliation Unit                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                |
| General Settings<br>Global Include Paths                                                                                                            | MGL-<br><sup>©</sup> WGL-2008 <sup>©</sup> WGL-93                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                |
|                                                                                                                                                     | HDL generated fiest language options HDL files generated by Libero SoC such as configured cores, SmartDesign components and post-layout gate level netists use the preferred language option. VHDL VHDL                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                |
|                                                                                                                                                     | Block flow - Block flow - Block flow - Block flow enables you to publish a rousable component that can be instantiated into another design. A block component may not contain 1/0 cells and cannot be programmed by itself. It could include iming constraints, physical constraints, placement or routing.                                                                                                                                                                                                                                                                                                                                                          |                |
|                                                                                                                                                     | Root Mod4  Foot Mod4  Foot Bade synthesis  D Enable PPGA Hardware Brealpoint Auto Instantiation                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                |
|                                                                                                                                                     | Design Separation                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                |
|                                                                                                                                                     | Reports                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                |
|                                                                                                                                                     | Image: Abort flow if errors are found in Physical Design Constraints (FDC)         Image: Abort flow if errors are found in Timing Constraints (SDC)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                |
| Help                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | Close          |

**Note:** Block flow is a bottom-up design methodology. The Block attribute in the Block flow identifies components in an HDL hierarchy to be reused within a team-based design flow as a modular resource.

- 3. If a Block uses physical I/O pins, define those physical resources as part of that block. This requires explicit definition of I/O to be assigned to the Block using I/O pads. Use direct instantiation of an I/O buffer within the module in question or from the Catalog in Libero's SmartDesign tool.
- 4. For each module that has its I/Os defined, run Synthesis and Compile. Analyze the Compile report to assess the size and shape of suitable regions based on types of I/O, count and length of cascaded Math blocks, RAM count, PLLs, peripherals and fabric resource usage.
- 5. Optional: Enter timing constraints and run place-and-route followed by timing analysis to achieve timing closure for each individual Block. This step indicates the difficulty of timing closure at the top level of the design.
- 6. The Block is ready to be published. Because these Blocks will be assigned to isolated separation regions (explained in subsequent sections), publish the Block without placement and routing information. Configure Publish Block options to exclude placement and routing information, as shown in the following figure.

#### Figure 1-3. Configuring Publish Block Options

|                             | 990 \Desktop  | o\msvt\design1\designe | r\block4 Browse |
|-----------------------------|---------------|------------------------|-----------------|
| Publish Block               | Configuration |                        |                 |
| Publish                     | Placement     |                        |                 |
| Publish                     | Routing       |                        |                 |
| Publish                     | Region        |                        |                 |
|                             |               |                        |                 |
|                             |               |                        |                 |
| Language                    |               | ~                      |                 |
| <ul> <li>Verilog</li> </ul> |               | C VHDL                 |                 |

Libero exports the <block\_name>.cxz file to the <project\_path>/designer/<block\_name>/export directory when a Block is published. The <block\_name>.cxz file is the published Block. This is the file you import into the top-level design to instantiate the Block.

### 1.4 Assigning I/Os to the Block

Signals that route to physical I/O pins within each module should belong to the corresponding Block. For design separation, physical I/O resources must be associated with an isolation region. Enabling Block flow disables automatic I/O insertion by the Synthesis tool. Therefore, the design separation methodology requires explicit instantiation of I/O buffers that are required per Block. These I/O buffers can be inserted from the I/O Configurator in the SgCore Catalog or the Macro Library Catalog. For more information, see the SmartDesign sections in the Libero Online Help. These macros ensure that all design ports assigned to them infer an I/O port assigned to the given Block.

#### Note:

Do not insert I/O buffer on ports that are used to interconnect with other blocks (that is, IRS nets).

To insert I/Os in a Block, Microchip recommends you use Libero's SmartDesign tool. Follow these steps to create a SmartDesign component of the subsystem.

- 1. Create a SmartDesign and instantiate the module in SmartDesign.
- 2. Insert appropriate macros from the Macro library catalog for each type of port. The relevant macros are: INBUF, INBUF\_DIFF, OUTBUF, OUTBUF\_DIFF, TRIBUFF, TRIBUFF\_DIFF, BIBUF, and BIBUF\_DIFF.
- 3. If ports belong to a bus, use the I/O configurator with required width and type of buffer.
- 4. After required macros are instantiated in SmartDesign, connect the ports of the design with the respective macros.
- 5. Rename the I/O pads with names defined in the module. Generate SmartDesign.
- 6. Set the generated SmartDesign as the root module and create a Block using this module as described in 2.2 Creating Blocks.

The following figure shows a SmartDesign component in which a subsystem has been instantiated and top-level ports are assigned to its I/Os using OUTBUF macros.





As an alternative to SmartDesign, you can instantiate the macros and connect them to the top-level ports of the design.

Because lower level modules are compiled independently from the top-level design, ensure unique I/O pin names across the design are used in the lower level project. Microchip recommends checking the I/O pin

names across the project to ensure uniqueness when building a lower level project. It is important to realize that some cores have pins that are not true single point inputs or outputs that can also be fed back internally. Therefore, they should be carefully placed between blocks.

The cells connected to IRS regions must be isolated from other IRS regions connected to a different set of blocks. It is best to insert a buffer or register (with only global clocks and resets) at the source and sinks of IRS.

### 1.5 Optional CoreSMIP Block

The Security Monitor IP (CoreSMIP or CoreSMIP\_PF) is a core provided by Microchip for tamper detection to enhance the security of the system. For more information, see the *CoreSMIP or CoreSMIP\_PF User Guide*. CoreSMIP and CoreSMIP\_PF is present in the catalog under the Tamper section.

The Design Separation methodology requires each subsystem to be defined as a Block. Therefore, if your design includes CoreSMIP\_or CoreSMIP\_PF, create such a block using the same steps as the other Blocks.

## 1.6 Creating a Top-level Design

After all Blocks are published, create a new Libero project for the top-level design using the following steps.

- 1. Create SmartDesign block where you instantiate all the individual blocks and connect their IRS signals. This top-level module should contain instantiations of all Blocks along with interconnects between them to replicate a complete system.
- Set this top-level module as the root module in Libero and disable Block Creation. Navigate to the File > Import > Blocks menu and import all published subsystem Blocks (<block\_name>.cxz files) into this design. Typically, you need not run Synthesis, because all published Blocks have already completed Synthesis and have I/Os assigned to them.

The following figure shows **Project Settings** required for top-level design with Block Creation and Synthesis disabled and **Enable Design Separation Methodology** enabled.

#### Figure 1-5. Project Settings for Top-level Design

| C supports mixed-HDL language designs; you can import Verilog and VHDL in the same project.<br>g files you can enable the System Verilog syntax option if your Verilog files contain System Verilog constructs.<br>files, you may choose between VHDL-2008 and VHDL-93. | Save<br>Discard                                                                                                             |                                                                                                                                         |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------|
| C Verlog 2001                                                                                                                                                                                                                                                           |                                                                                                                             |                                                                                                                                         |
|                                                                                                                                                                                                                                                                         |                                                                                                                             |                                                                                                                                         |
| C VHOL-93                                                                                                                                                                                                                                                               |                                                                                                                             |                                                                                                                                         |
| e options                                                                                                                                                                                                                                                               |                                                                                                                             |                                                                                                                                         |
| o SoC such as configured cores, SmartDesign components and post-layout gate level netlists use the preferred language option.                                                                                                                                           |                                                                                                                             |                                                                                                                                         |
| C VHDL                                                                                                                                                                                                                                                                  |                                                                                                                             |                                                                                                                                         |
|                                                                                                                                                                                                                                                                         |                                                                                                                             |                                                                                                                                         |
| blich a reusable component that can be instantiated into another design. A block component may not contain I/O cells and cannot be programmed by itself.<br>aints, physical constraints, placement or routing.                                                          |                                                                                                                             |                                                                                                                                         |
|                                                                                                                                                                                                                                                                         |                                                                                                                             |                                                                                                                                         |
| Breakpoint Auto Instantiation                                                                                                                                                                                                                                           |                                                                                                                             |                                                                                                                                         |
|                                                                                                                                                                                                                                                                         |                                                                                                                             |                                                                                                                                         |
| an Methodology                                                                                                                                                                                                                                                          |                                                                                                                             |                                                                                                                                         |
| nout nets to be displayed: 10                                                                                                                                                                                                                                           |                                                                                                                             |                                                                                                                                         |
| found in Physical Design Constraints (PDC)                                                                                                                                                                                                                              |                                                                                                                             |                                                                                                                                         |
| found in Timing Constraints (SDC)                                                                                                                                                                                                                                       |                                                                                                                             |                                                                                                                                         |
|                                                                                                                                                                                                                                                                         | a options a configured cores, SmartDesign components and post-layout gate level netlists use the preferred language option. | a options o SoC such as configured cores, SmartDesign components and post-layout gate level netistis use the preferred language option. |

### 1.7 FloorPlanning with Design Separation Regions

After you create the top-level design with subsystem Blocks, floorplan the design by defining separation regions and IRS regions. In a design that follows the Microchip Design Separation methodology, all logic should be contained in a logic region with dedicated place-and-route resources.

A logic region is a user-defined area on the device within which logic can be assigned. A Separation region is a logic region with the following features:

- It is a resource reserved (place-and-route) region which may be an exclusive or inclusive constraint.
- May be a non-rectangular region (built from a union of multiple rectangular floorplan regions).
- Regions are separated from each other by reserving a perimeter of unused clusters.

You can use Chip Planner to create regions or create them with PDC commands. Chip Planner is the floorplanning tool used to create and edit regions on the chip and assign logic to these regions.

Create a Separation region for each Block present in the design. The size of and shape of the region should depend on quantity of fabric resources, I/O types, RAM, Math blocks, PLL and peripherals being used in each block.

Each Block region is a place-and-route constraint for logic elements that are associated with it. Physical separation is achieved by allowing some unused logic clusters as a guard-band around each Block region. The unused cluster spacing between regions is dependent upon final system requirements. Floorplan according to the guard-band that is appropriate for the security and safety requirements of the target design.

PolarFire, SmartFusion2 and IGLOO2 FPGA architecture is cluster-based. A cluster is made up of 12 Logic Elements. A Logic Element includes a 4 input-LUT, a register, and a carry chain. In the Chip Planner coordinate system, each Logic Element component has a unique coordinate. As such, each Cluster occupies an area of 12x3. The following figure shows a single cluster as shown in the Chip Planner with dimensions noted. The granularity of Chip Planner region sizes is one cluster.

#### Figure 1-6. One Cluster of PolarFire, SmartFusion2 and IGLOO2 FPGA



You can define regions for each Block using either the Chip Planner or a Physical Design Constraints (PDC) file. The size of each region should accommodate all resources used by a given block, including all embedded hard blocks such as I/Os, RAM, Math blocks, PLL and peripheral blocks.

**Note:** LSRAM and Math blocks take up a footprint of three clusters in the FPGA floorplans. The makeup of such embedded blocks include the hard IP resource itself abutted to a set of Interface Clusters. The Interface Clusters help route signals to and from the embedded hard Block to the rest of the fabric array. The following figures provide details of the makeup of a embedded hard Block and its corresponding visualization within the Chip Planner floorplan, respectively.



#### Figure 1-7. Interface Cluster for an Embedded Hard IP Block

Figure 1-8. LSRAM Block as Shown in Chip Planner



An isolated region constraint must include the entire embedded hard Block resource within its boundaries for the resource to be usable within the target region. Use non-rectangular regions to efficiently allocate a floorplan to include these embedded hard blocks.

More information about the fabric architecture for FPGA devices can be found in the PolarFire FPGA fabric user guide or the SmartFusion2 FPGA fabric user guide.

The following figures provide a sample floorplan from a sample design using a PDC file and the floorplan as shown in the Chip Planner, respectively. The granularity of placement units are logic modules in the Chip Planner coordinate system and the granularity of region sizes is clusters. Therefore, regions must be a multiple of 12 in the horizontal direction and a multiple of 3 in the vertical direction.





Following are the details of Physical design constraints file of the top-level design. Note the regions are defined with -route true to constrain routing.

```
define_region -region_name Block1region -type exclusive -color 2143338688 -route
true -push_place true -x1 456 -y1 195 -x2 1631 -y2 371
define_region -region_name Block2region -type exclusive -color 2143338688 -route
true -push_place true -x1 1752 -y1 189 -x2 2435 -y2 377
define_region -region_name Block3region -type exclusive -color 2143338688 -route
true -push_place true -x1 0 -y1 0 -x2 335 -y2 41 \
```

0 -y1 42 -x2 1067 -y2 161 \ -x1 -x1 804 -y1 0 -x2 1067 -y2 41 define\_region -region\_name Block4region -type exclusive -color 2143338688 -route 0 -x2 2351 -y2 158 true -push place true -x1 1200 -y1 define region -region name SMIPregion -type exclusive -color 2143338688 -route true -push\_place true -x1 384 -y1 0 -x2 755 -y2 11 define\_region -region\_name IBR1\_2 -type inclusive -color 2147442270 -route true push place false -x1 1584 -y1 282 -x2 2027 -y2 362 define\_region -region\_name IBR1\_3 -type inclusive -color 2147442270 -route true push\_place false -x1 636 -y1 102 -x2 851 -y2 239 define\_region -region\_name IBR1\_4 -type inclusive -color 2143338688 -route true push place false -x1 1356 -y1 126 -x2 1499 -y2 245 define region -region name IBR2 4 -type inclusive -color 2147442270 -route true push place false -x1 2148 -y1 105 -x2 2327 -y2 266 define region -region name IBR3 4 -type inclusive -color 2147442270 -route true push\_place false -x1 888 -y1 45 -x2 1463 -y2 98 assign\_region -region\_name Block1region -inst\_name block1\_0 assign\_region -region\_name Block2region -inst\_name block2\_0 assign region -region name Block3region -inst name block3 0 assign region -region name Block4region -inst name block4 0 assign\_region -region\_name Block4region -inst\_name RESETN\_ibuf assign\_region -region\_name SMIPregion \_inst\_name pf\_smip\_0 assign net macros -region name IBR1 2 -net name block1 0 APBmslave0 PENABLE include driver true assign net macros -region name IBR1 2 -net name block1 0 APBmslave0 PSELx include driver true assign net macros -region name IBR1 2 -net name block1 0 APBmslave0 PWRITE include driver true assign net macros -region\_name IBR1\_2 -net\_name block1\_0\_APBmslave0\_PREADY include driver true assign net macros -region name IBR1 2 -net name {block1 0 APBmslave0 PADDR[\*]} include driver true assign net macros -region name IBR1 2 -net name {block1 0 APBmslave0 PRDATA[\*]} include driver true assign net macros -region name IBR1 2 -net name {block1 0 APBmslave0 PWDATA[\*]} include driver true assign net macros -region name IBR1 3 -net name {block1 0 dataOut[\*]} include driver true assign net macros -region name IBR1 3 -net name {block3 0 dataOut 0[\*]} include driver true assign\_net\_macros -region\_name IBR1\_4 -net\_name block4\_0\_TX -include\_driver true assign\_net\_macros -region\_name IBR1\_4 -net\_name block4\_0\_Y\_0 -include\_driver true assign\_net\_macros -region\_name IBR1\_4 -net\_name block1\_0\_TX -include\_driver true assign\_net\_macros -region\_name IBR2\_4 -net\_name block4\_0\_Y -include\_driver true assign net macros -region name IBR3 4 -net name {block3 0 dataOut[\*]} include driver true

For more information about floorplaning with the Chip Planner and PDC syntax, see the Chip Planner online help in Libero SoC.

#### Figure 1-10. Sample Floorplan of Top-level Design



### 1.8 IRS Regions

Since each Block is defined in an isolated region, it must be ensured that a routing channel with valid inter-Block communication interconnect exists that is separated from other unrelated regions. These inter-Block interconnect channels are defined using IRS regions.

An IRS region is another routing region that overlaps with the isolated Block regions. All signals that have a valid connection point between the source and destination Blocks are explicitly assigned to the IRS routing region.

IRS regions have the same requirements as the separation regions mentioned in 1.7 FloorPlanning with Design Separation Regions. IRS regions should contain valid communication interconnect nets assigned to them. An IRS region overlaps with the separation regions being connected.

Each IRS region should connect only one set of connected Blocks. Each set of IRS regions should also be separated by a certain number of clusters from all other Blocks in all directions, both inside and outside the connected Blocks. The extent of separation required depends on your system requirements.

The cells connected to IRS regions must be isolated from other IRS regions connected to a different set of Blocks. It is best to insert a buffer or register (with only global clocks and resets) at the source and sinks of IRS.

### 1.9 Considerations for Global Clock Resources

The global clock network on PolarFire, SmartFusion2, and IGLOO2 FPGA devices provide a dedicated low-skew, high-fanout network to all logic clusters within the fabric array. There are a number of global buffers per device with the following potential inputs:

- Dedicated Global I/Os
- Clock Conditioning Circuits (inclusive of PLLs)
- On-Chip (hardened) oscillators
- Transceivers
- FPGA fabric routing

A detailed description of the clock distribution architecture and associated clocking resources can be found in the PolarFire Clocking Resources User Guide or the SmartFusion2 Clocking Resources User Guide.

The design separation flow only considers physical isolation of the logic regions through the analysis of routing elements on the programmable switch fabric in the FPGA. Global networks, as it is a dedicated routing tree, are not analyzed as part of this flow. Hence, for design separation, global signals that are common to multiple regions (such as clock and Reset) need not be separated from any other signal. If the location of a global resource like PLL or CCC overlaps with a block region, you must make the type of the block region inclusive. Alternatively, you could include the global resource within the block and bring out the global net for distributing to other blocks.

**Note:** High fanout-signals from the fabric array often are promoted automatically to the global network. In such cases, you may want high fanout signals that are meant for a region to use local routing resources only. To understand which signals are promoted onto the global network, inspect the Compile log and Global Net report to confirm which nets get assigned to GB and which nets get implemented on Row Global Buffer (RGB) resources. You can control the promotion and demotion of signals using Synthesis attributes. You can also configure Synthesis options in Libero SoC to modify the threshold values where global promotion occurs.

As MSVT only audits the programmable switch fabric, any hard macro resources (such as the CCC, PLL, DLL, clock divider, or an RC oscillator) are not audited. Most inputs to the CCC are from hard blocks, such as from a dedicated I/O pin or the RC oscillator and are routed on dedicated metal traces. However, CCC inputs may also be driven from the fabric. If an input or output of a CCC is routed, then design separation constraints will apply. In such a case, the physical CCC resource must also be encapsulated within the same region as the source signal driving the CCC. The locations of the CCC may be restrictive for planning the regions—they occur in pairs in each quadrant and some quadrants may not have any CCCs.

RGB resources (RCLKINT/RGCLKINT macros), if used, must be included in a design separation region. Connectivity in the row served by a RGB is dictated by programmable switches, and therefore, is analyzed by the MSVT. RGBs are distributed along a few columns across the fabric array (locations are device dependent). You need to be aware of the location of the RGB columns. The width of such regions is determined by the span of the RGB output.

### 1.10 Initialization of Hard ASIC Blocks

SmartFusion2 and IGLOO2 FPGA devices contain a number of hardened peripherals, such as SERDES blocks, and hardened memory controllers. These peripherals often rely on initialization routines, where register values are configured to the desired operational parameters. In the standard Libero flow, initialization of these hardened peripherals is controlled through a centralized initialization controller. Fabric routing resources are used to connect with the centralized configuration controller, and in such cases will cause a violation of design separation constraints. If hardened peripherals are used in the design, the standalone initialization flow must be used with the design separation flow.

For more information about standalone initialization of peripheral blocks, see the *Standalone Peripheral Initialization User Guide*.

### 1.11 Complete Place-and-Route

After a floorplan of the entire design is complete with separation regions and IRS regions defined, run place-and-route and verify post-layout implementation as per the regular Libero design flow.

Verify that timing closure can be achieved for the design. If the design does not meet timing, clone, and modify the timing constraints scenario for Timing-Driven Place-and-Route (TDPR) and explore alternative optimization through High-effort or Power-driven options. You can also change the floorplan and iterate through the design. Standard FPGA design practices like incremental flow are available. Make sure all criteria required for separation of design remains intact while changing the design floorplan.

## 1.12 Configuring Security Settings and Generating the Programming File

You can use the Security Policy Manager (SPM) to set design security attributes after completing place-and-route and before you generate programming files. This procedure includes setting user encryption keys and hardware access control policies. Configure the SPM as appropriate for the target system design. For more information about design security and the options available in the Security Policy Manager, see the PolarFire FPGA Security User Guide or the SmartFusion2 FPGA Security User Guide.

### 1.13 Auditing by MSVT

MSVT is a standalone tool provided with the Libero installation. It is used to verify that the design meets design separation requirements.

The tool accepts as input the design database and a parameter file that is generated every time a programming file is generated. The parameter file describes the isolation regions in the design as well as the inter-region signals between isolation regions. This file is generated when the **Enable Design Separation Methodology** check box in the **Project Settings** dialog is enabled. This file is exported to the following location:

<project\_path>/designer/<Top\_Level\_Module>/msvt.param

The tool can work on any placed and routed design which has a Block that requires a separation from all elements external to the block. The tool works iteratively on every Block to be verified. Internal signals and IRS are verified separately. The tool checks whether the separation criteria is satisfied for each Block and the corresponding sets of IRS signals.

MSVT prints a comprehensive report on each Block and the corresponding IRS regions being verified. If any Block or IRS signals do not satisfy minimum separation criteria, the tool reports details of affected instances. For more information about the MSVT output report, see the *MSVT User Guide*.

An MSVT failure indicates that the design has not met the design separation criteria and one or more sub-blocks (or signals) are not independent of rest of the system. In such a case, do the following:

- Identify instances that cause violations in the MSVT output, and modify the design floorplan accordingly.
- Recompile the design to generate a new place-and-routed netlist.
- Verify the modified design using the MSVT tool.

If the design satisfies separation criteria, the MSVT output reports MSVT Check succeeded to indicate that the required design separation has been achieved in the design.

### 1.14 Executing MSVT

The msvt.param file contains the parameters required by MSVT to verify design separation. The following shows a sample parameter file.

```
11
11
   This is input parameters file for MSVT Check program
11
DEVICE = MPF300TS
DESIGN = SD Top.msvt
VERIFY BLOCKS = block4 0 block2 0 block3 0 block1 0 pf smip 0 // empty list means
all blocks in design will be verified
REQUIRED SEPARATION = 1
MAX VIOLATIONS PER REPORT SECTION = 1
IRS block4_0 block\overline{2}_0 = block4_0_Y
IRS block2_0 block4_0 =
IRS block4_0 block3_0 =
IRS block3 0 block4 0 = block3_0_dataOut[31] block3_0_dataOut[30]
block3 0 dataOut[29]
        block3 0 dataOut[28] block3 0 dataOut[27] block3 0 dataOut[26]
block3 0 dataOut[25]
        block3 0 dataOut[24] block3 0 dataOut[23] block3 0 dataOut[22]
block3_0_dataOut[21]
        block3 0 dataOut[20] block3 0 dataOut[19] block3 0 dataOut[18]
block3 0 dataOut[17]
        block3_0_dataOut[16] block3_0_dataOut[15] block3_0_dataOut[14]
block3 0 dataOut[13]
        block3 0 dataOut[12] block3 0 dataOut[11] block3 0 dataOut[10]
block3 0 dataOut[9]
        \overline{b}lock3 0 dataOut[8] block3 0 dataOut[7] block3 0 dataOut[6]
block3_0_dataOut[5]
        block3 0 dataOut[4] block3 0 dataOut[3] block3 0 dataOut[2]
block3_0_dataOut[1]
        block3 0 dataOut[0]
IRS block4 0 \overline{block1} 0 = block4 0 TX block4 0 Y 0
IRS block1_0 block4_0 = block1_0_TX
IRS block4_0 pf_smip_0 =
IRS pf_smip_0 block4_0 =
IRS block2 0 block3 0 =
IRS block3 0 block2 0 =
IRS block2_0 block1_0 = block1_0_APBmslave0_PRDATA[31]
block1_0_APBmslave0_PRDATA[30]
        block1 0 APBmslave0 PRDATA[29] block1 0 APBmslave0 PRDATA[28]
block1 0 APBmslave0 PRDATA[27]
        block1 0 APBmslave0 PRDATA[26] block1 0 APBmslave0 PRDATA[25]
block1 0 APBmslave0 PRDATA[24]
        block1 0 APBmslave0 PRDATA[23] block1 0 APBmslave0 PRDATA[22]
block1 0 APBmslave0_PRDATA[21]
        block1 0 APBmslave0 PRDATA[20] block1 0 APBmslave0 PRDATA[19]
block1_0_APBmslave0 PRDATA[18]
        block1 0 APBmslave0 PRDATA[17] block1 0 APBmslave0 PRDATA[16]
block1 0 APBmslave0 PRDATA[15]
        block1 0 APBmslave0 PRDATA[14] block1 0 APBmslave0 PRDATA[13]
block1 0 APBmslave0 PRDATA[12]
        block1 0 APBmslave0 PRDATA[11] block1 0 APBmslave0 PRDATA[10]
block1 0 APBmslave0 PRDATA[9]
        block1 0 APBmslave0 PRDATA[8] block1 0 APBmslave0 PRDATA[7]
block1 0 APBmslave0 PRDATA[6]
        block1 0 APBmslave0 PRDATA[5] block1 0 APBmslave0 PRDATA[4]
block1 0 APBmslave0 PRDATA[3]
```

```
block1 0 APBmslave0 PRDATA[2] block1 0 APBmslave0 PRDATA[1]
block1 0_APBmslave0_PRDATA[0]
        block1 0 APBmslave0 PREADY
IRS block1 0 block2 0 = block1 0 APBmslave0 PADDR[11] block1 0 APBmslave0 PADDR[10]
        block1_0_APBmslave0_PADDR[9] block1_0_APBmslave0_PADDR[8]
block1 0 APBmslave0 PADDR[7]
        block1 0 APBmslave0 PADDR[6] block1 0 APBmslave0 PADDR[5]
block1 0 APBmslave0 PADDR[4]
        block1 0 APBmslave0 PADDR[3] block1 0 APBmslave0 PADDR[2]
block1 0 APBmslave0 PADDR[1]
        block1 0 APBmslave0 PADDR[0] block1 0 APBmslave0 PWDATA[31]
block1 0 APBmslave0 PWDATA[30]
        block1_0_APBmslave0_PWDATA[29] block1_0_APBmslave0_PWDATA[28]
block1 0 APBmslave0 PWDATA[27]
        block1 0 APBmslave0 PWDATA[26] block1 0 APBmslave0 PWDATA[25]
block1 0 APBmslave0 PWDATA[24]
        block1 0 APBmslave0 PWDATA[23] block1 0 APBmslave0 PWDATA[22]
block1_0_APBmslave0_PWDATA[21]
        block1 0 APBmslave0 PWDATA[20] block1 0 APBmslave0 PWDATA[19]
block1 0 APBmslave0 PWDATA[18]
        block1 0 APBmslave0 PWDATA[17] block1_0_APBmslave0_PWDATA[16]
block1 0 APBmslave0 PWDATA[15]
        block1_0_APBmslave0_PWDATA[14] block1 0 APBmslave0 PWDATA[13]
block1 0 APBmslave0 PWDATA[12]
        block1 0 APBmslave0 PWDATA[11] block1 0 APBmslave0 PWDATA[10]
block1 0 APBmslave0 PWDATA[9]
        block1 0 APBmslave0 PWDATA[8] block1 0 APBmslave0 PWDATA[7]
block1 0 APBmslave0 PWDATA[6]
        block1 0 APBmslave0 PWDATA[5] block1 0 APBmslave0 PWDATA[4]
block1 0 APBmslave0 PWDATA[3]
        block1 0 APBmslave0 PWDATA[2] block1_0_APBmslave0_PWDATA[1]
block1 0 APBmslave0 PWDATA[\overline{0}]
        block1 0 APBmslave0 PENABLE block1 0 APBmslave0 PSELx
block1_0_APBmslave0_PWRITE
IRS block2 0 pf smip 0 =
IRS pf smip 0 block2 0 =
IRS block3 \overline{0} block1 \overline{0} = block3 0 dataOut 0[7] block3 0 dataOut 0[6]
block3_0_dataOut_0[5]
        block3_0_dataOut_0[4] block3_0_dataOut_0[3] block3_0_dataOut_0[2]
block3_0_dataOut_0[1]
block3_0_dataOut_0[0]
IRS block1 0 b\overline{lock3} 0 = \overline{b}\overline{lock1} 0 dataOut[7] block1 0 dataOut[6] block1 0 dataOut[5]
        block1 0 dataOut[4] block1 0 dataOut[3] block1 0 dataOut[2]
block1 0 dataOut[1]
IRS pf_smip_0 block3_0 =
IRS block1 0 pf smip 0 =
IRS pf_smip_0 block1 0 =
REGIONS VERBOSITY = \overline{0}
```

- 1. Inspect the generated MSVT parameter file. Edit the required separation parameter per guideline requirements and adjust other parameters to refine the verification criteria. You can specify the blocks you want to verify and the names of each IRS signal, and limit the maximum number of violations to be reported. For more descriptions about each parameter, see the *MSVT User Guide*.
- <sup>2.</sup> To verify the design using MSVT for SmartFusion2 and IGLOO2 devices, issue the following command:

```
<Libero_path>/bin64/msvt_check -p <project_path>/designer/<Top_Level_Module>/
msvt.param [-o msvt_check.log]
```

To verify the design using MSVT for PolarFire devices, issue the following command:

```
<Libero_path>/bin64/msvt_check_pf -p <project_path>/designer/
<Top Level Module>/msvt.param [-o msvt check.log]
```

A comprehensive report is printed into the filename given with the -o argument or to stdout if -o is omitted. On successful completion of this command, the message "MSVT Check failed" indicates that the design failed to meet one or more of separation criteria and the message "MSVT Check succeeded" indicates that the design met all separation criteria.

## 1.15 Further Considerations and Adjustments

- It might be convenient to have the chip-level resources related to the global network at the top-level design; particularly, if they are connected to multiple blocks.
- Certain PolarFire XCVR ERM related cells are automatically inserted or duplicated in the pre-placer that circumvent the floorplanning in the PDC. These instances do not appear in any of the user blocks and cannot be constrained by your region constraints.
- See the following table of coordinate that spans per device to floorplan any of the indicated instances. Overlapping spans must belong to the same block.

| Cell                  | MPF100T       |               | MPF200T       |               | MPF300T       |               | MPF500T       |               |
|-----------------------|---------------|---------------|---------------|---------------|---------------|---------------|---------------|---------------|
|                       | Min-span<br>X | Min-span<br>Y | Min-span<br>X | Min-span<br>Y | Min-span<br>X | Min-span<br>Y | Min-span<br>X | Min-span<br>Y |
| DRI                   | 240 408       | 01            | 240 408       | 01            | 384 552       | 01            | 384 552       | 01            |
| APBM                  | 240 408       | 01            | 240 408       | 01            | 384 552       | 01            | 384 552       | 01            |
| SCB                   | 240 363       | 02            | 240 363       | 02            | 384 507       | 02            | 384 507       | 02            |
| ENFORC<br>E           | 252 362       | 01            | 252 362       | 01            | 396 506       | 01            | 396 506       | 01            |
| DEBUG                 | 252 396       | 02            | 252 396       | 02            | 396 540       | 02            | 396 540       | 02            |
| TVS                   | 240 371       | 02            | 240 371       | 02            | 384 515       | 02            | 384 515       | 02            |
| OSC_RC<br>200MHZ      | 240 368       | 02            | 240 368       | 02            | 384 512       | 02            | 384 512       | 02            |
| PF_SPI                | 240 408       | 02            | 240 408       | 02            | 384 552       | 02            | 384 552       | 02            |
| SC_STAT<br>US         | 252 366       | 02            | 252 366       | 02            | 396 510       | 02            | 396 510       | 02            |
| UJTAG_S<br>EC         | 240 360       | 02            | 240 360       | 02            | 384 504       | 02            | 384 504       | 02            |
| SYS_SE<br>RVICES      | 240 408       | 02            | 240 408       | 02            | 384 552       | 02            | 384 552       | 02            |
| VOLTAG<br>EDETEC<br>T | 240 363       | 01            | 240 363       | 01            | 384 507       | 01            | 384 507       | 01            |
| OSC_RC<br>2MHZ        | 240 367       | 02            | 240 367       | 02            | 384 511       | 02            | 384 511       | 02            |
| INIT                  | 240 364       | 02            | 240 364       | 02            | 384 508       | 02            | 384 508       | 02            |
| TAMPER                | 288 408       | 02            | 288 408       | 02            | 432 552       | 02            | 432 552       | 02            |
| PCIE                  | 1572<br>1596  | 92 153        | 1572<br>1596  | 180 234       | 2436<br>2460  | 180 234       | 2724<br>2748  | 261 315       |
| PCIE                  | 1572<br>1596  | 159 201       | 1572<br>1597  | 227 282       | 2436<br>2460  | 240 282       | 2724<br>2748  | 321 363       |

Table 1-1. Coordinates that Span Per Device to Floorplan any of the Indicated Instances

| cont               | inued         |               |               |               |               |               |               |               |
|--------------------|---------------|---------------|---------------|---------------|---------------|---------------|---------------|---------------|
| Cell               | MPF100T       |               | MPF200T       |               | MPF300T       |               | MPF500T       |               |
|                    | Min-span<br>X | Min-span<br>Y | Min-span<br>X | Min-span<br>Y | Min-span<br>X | Min-span<br>Y | Min-span<br>X | Min-span<br>Y |
| XCVR_PI<br>PE_AXI1 | 1572<br>1596  | 159 182       | 1572<br>1598  | 236 252       | 2436<br>2462  | 236 252       | 2724<br>2748  | 321 344       |
| XCVR_PI<br>PE_AXI0 | 1572<br>1596  | 111 155       | 1572<br>1597  | 192 236       | 2436<br>2461  | 192 236       | 2724<br>2748  | 273 317       |
| XCVR_PI<br>PE_AXI0 | 1572<br>1597  | 159 189       | 1572<br>1599  | 236 270       | 2436<br>2463  | 236 270       | 2724<br>2749  | 321 351       |
| XCVR_PI<br>PE_AXI1 | 1572<br>1596  | 128 147       | 1572<br>1596  | 210 236       | 2436<br>2460  | 210 236       | 2724<br>2748  | 290 309       |

# 2. Example

The following topics describe how to implement a complete PolarFire design using Microchip Design Separation methodology.

The design consists of six subsystems defined in Verilog:

- block1.v
- block2.v
- block3.v
- block4.v
- pf\_smip.v
- PF CCC C0.v

The following figure shows a top-level view of these subsystems with interconnects between them.

### Figure 2-1. Top-Level View of Example Design



This design is implemented using the design separation methodology steps defined in 1.2 Design Separation Methodology Steps.

**Note:** To understand the design flow and floorplanning terminology in the following topics, see the Libero SoC Design Flow and Chip Planner help topics in Libero.

### 2.1 Creating HDL Subsystems

The first step when implementing a complete system using Microchip Design Separation methodology is to achieve logical separation of various subsystems. Create logically separate HDL modules corresponding to the system.

This example defines the following subsystems:

- block1.v
- block2.v
- block3.v
- block4.v
- pf smip.v
- PF CCC C0.v

These subsystems are independent of each other. They communicate with each other using the interconnect signals. To begin with creating the HDL subsystem, follow these steps:

1. After you identify the subsystems to be implemented using design separation, import these modules into a Libero project.

- Create a new Libero project for the FPGA device chosen for the design. In this example, the design using a MPF300TS, 484 FCVG device is implemented. Import the HDL files using File > Import > HDL Source file menu into the Libero Project.
- 3. Create a Block for each subsystem of this design.

## 2.2 Creating Blocks

The next step is to create a Block for each subsystem of this design.

- 1. Select a module to be the root module. For example, select **block4** as shown in the following figure.
  - Figure 2-2. Selecting a Module as the Root of a Block

| ign Hierarchy                                                 |                                                                                                                                                                                                                                                                                                    | ć |
|---------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|
| Build Hierarchy                                               | Show: Components 💌 🛨 = ?                                                                                                                                                                                                                                                                           | 8 |
|                                                               | 32IMC_ram_singleport_addreg (opsrv_merged.v) [work]<br>32IMC_opsrv_dummy_ram (opsrv_merged.v) [work]<br>32IMC_common_buffer_behav (submicron_merged.v) [.<br>32IMC_axi_xaddr_buffer (opsrv_merged.v) [work]<br>32IMC_axi_egress_buffer (opsrv_merged.v) [work]<br>4RTapb_C1 (CoreUARTapb_v5.6.102) |   |
|                                                               | Set As Root                                                                                                                                                                                                                                                                                        | ŀ |
| So block2     So block1     So compp     So fpupac     MIV RV | Open Component<br>Generate Component<br>Export Component Description(Tcl)<br>Hierarchical Export Component Description(Tcl)                                                                                                                                                                        |   |
| MIV_RV                                                        | Rename Component                                                                                                                                                                                                                                                                                   |   |
|                                                               | Gen HDL File<br>Check HDL File                                                                                                                                                                                                                                                                     |   |
|                                                               | Create I/O Constraint from Module                                                                                                                                                                                                                                                                  |   |
|                                                               | Create Testbench                                                                                                                                                                                                                                                                                   |   |
| Puplicate N                                                   | / Delete                                                                                                                                                                                                                                                                                           | ł |
| Componer                                                      | Copy File Path                                                                                                                                                                                                                                                                                     |   |
|                                                               | Show Module Parameters                                                                                                                                                                                                                                                                             |   |
| esign Flow Design Hi                                          | Properties                                                                                                                                                                                                                                                                                         |   |
|                                                               | - Show Module                                                                                                                                                                                                                                                                                      |   |

2. Use **Project > Project Settings > Design Flow > Enable Block Creation** to enable Block flow for this module, as shown in the following figure.

|                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                 | -                                                                                                                                                                                           |        |
|--------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|
| vice selection                                               |                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                                                                                                                                                                             | _      |
| vice settings                                                | HDL source files language options                                                                                                                                                                                                                                                                                                                                                                                               |                                                                                                                                                                                             | Save   |
| sign flow<br>alysis operating conditions<br>nulation options | Libero SoC supports mixed-HDL language designs; you<br>syntax option if your Verilog files contain System Verilog                                                                                                                                                                                                                                                                                                               | can import Verilog and VHDL in the same project. For Verilog files you can enable the System Verilog<br>g constructs. For VHDL files, you may choose between VHDL-2008 and VHDL-33.         | Discar |
| DO file<br>Waveforms<br>Vsim commands                        | and macros defined in one file will be seen by other file<br>When disabling that option, each file is compiled as a se                                                                                                                                                                                                                                                                                                          | when endaning the Hours he Complication on mix (HPCU) option, an mes are complied in the same complication unit,<br>s complied later based on the file order.<br>eparate complication unit. |        |
| Timescale                                                    | Verilog                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                             |        |
| nulation libraries<br>PolarFire<br>COREAHBLITE LIB           | C Verling 2001                                                                                                                                                                                                                                                                                                                                                                                                                  | Gr System Verlog     ☐ Multi File Compliation Unit                                                                                                                                          |        |
| COREAPB3 LIB                                                 | VHDL                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                             |        |
| neral Settings<br>abal Include Paths                         | @ WHDL-2008                                                                                                                                                                                                                                                                                                                                                                                                                     | C WHDL-93                                                                                                                                                                                   |        |
|                                                              | HDL generated files language options                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                             |        |
|                                                              | HDL files generated by Libero SoC such as configured cores, SmartDe                                                                                                                                                                                                                                                                                                                                                             | sign components and post-layout gate level netists use the preferred language option.<br>VHDL                                                                                               |        |
|                                                              | Block flow                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                                                                                                                                             |        |
|                                                              | Block flow enables you to publish a reusable component that can be in                                                                                                                                                                                                                                                                                                                                                           | istantiated into another design. A block component may not contain I/O cells and cannot be programmed by itself.                                                                            |        |
|                                                              | It could include timing constraints, physical constraints, placement or n                                                                                                                                                                                                                                                                                                                                                       | reuting.                                                                                                                                                                                    |        |
|                                                              | It could include timing constraints, physical constraints, placement or n Fenable block creation Root block4                                                                                                                                                                                                                                                                                                                    | routing.                                                                                                                                                                                    |        |
|                                                              | It could include timing constraints, physical constraints, placement or in                                                                                                                                                                                                                                                                                                                                                      | reving.                                                                                                                                                                                     |        |
|                                                              | It could include timing constraints, physical constraints, placement or n                                                                                                                                                                                                                                                                                                                                                       | routing.                                                                                                                                                                                    |        |
|                                                              | It could include timing constraints, physical constraints, placement or in<br>Finale block creation<br>Root block4<br>Finale synthesis<br>Enable PFGA Hardware Breakpoint Auto Instantiation<br>Design Separation                                                                                                                                                                                                               | reving.                                                                                                                                                                                     |        |
|                                                              | It could include timing constraints, physical constraints, placement or in                                                                                                                                                                                                                                                                                                                                                      |                                                                                                                                                                                             |        |
|                                                              | It could include timing constraints, physical constraints, placement or i                                                                                                                                                                                                                                                                                                                                                       |                                                                                                                                                                                             |        |
|                                                              | It could include timing constraints, physical constraints, placement or in  Foot block -  For Enable Post A tardware Breakpoint Auto Instantiation  Design Separation  Enable Design Separation  Reports  Maximum number of high fanout nets to be displayed: 10                                                                                                                                                                |                                                                                                                                                                                             |        |
|                                                              | It could include timing constraints, physical constraints, placement or in  P Enable block creation  Root block4  Enable PCA Hardware Breakpoint Auto Instantiation  Design Separation  Enable Design Separation Methodology  Reports  Maximum number of high fanout nets to be displayed: 10  P Abort flow if errors are found in Physical Design Constraints (PDC                                                             | country.                                                                                                                                                                                    |        |
|                                                              | It could include timing constraints, physical constraints, placement or in  P Enable block creation  Root block4  Enable PSGA Hardware Breakpoint Auto Instantiation  Design Separation  Enable Design Separation Methodology  Reports  Maximum number of high fanout nets to be displayed: 10  P Abort flow if errors are found in Physical Design Constraints (PDC  Abort flow if errors are found in Thing Constraints (SDC) | )                                                                                                                                                                                           |        |

### Figure 2-3. Project Settings for Block Creation

The **Publish Block** option is enabled in the design flow, as shown in the following figure.

|               |          | 1000          |      |      |    |    |    |     |   |   |   |   |   |   |   |   |    |    |    |    |    |     |    |     |    |   |   |   |   |    |    |    |    |    |    |   |   |   |    |    |    |   |   |   |    |    | _ |    |   |    |     |    |    | 1 | _ | e. | , | ~ |   |
|---------------|----------|---------------|------|------|----|----|----|-----|---|---|---|---|---|---|---|---|----|----|----|----|----|-----|----|-----|----|---|---|---|---|----|----|----|----|----|----|---|---|---|----|----|----|---|---|---|----|----|---|----|---|----|-----|----|----|---|---|----|---|---|---|
| op Module(ro  | ot): blo | ck4           |      |      |    |    |    |     |   |   |   |   |   |   |   |   |    |    |    |    |    |     |    |     |    |   |   |   |   |    |    |    |    |    |    |   |   |   |    |    |    |   |   |   |    | Ľ  | 1 |    | L | 2  |     | u  | ā. |   | 归 | IJ | 3 | 2 | 5 |
| ctive Synthes | is Imple | ementation: s | synt | the  | he | e  | 2  | 25  | - | 2 | 2 | 2 | 2 | 2 | 2 |   | s  | si | s  |    |    |     |    |     |    |   |   |   |   |    |    |    |    |    |    |   |   |   |    |    |    |   |   |   |    |    |   |    |   |    |     |    |    |   |   |    |   |   |   |
| Tool          |          |               |      |      |    |    |    |     |   |   |   |   |   |   |   |   |    |    |    |    |    |     |    |     |    |   |   |   |   |    |    |    |    |    |    |   |   |   |    |    |    |   |   |   |    |    |   |    |   |    |     |    |    |   |   |    |   | 4 |   |
|               | SL       | Create :      | Sma  | a    | ar | r  | r  | r   | r | r | r | r | r | r | r | 1 | t  | tl | D  | )( | e  | S   | i  | g   | n  | 1 | 1 | 1 | e | s  | 51 | tk | 2  | er | n  | с | h | h |    |    |    |   |   |   |    |    |   |    |   |    |     |    |    |   |   |    |   |   |   |
|               | 📋        | Create H      | IDL  | Ľ    | 1  | T  | T  | I   | I | I |   | 1 | 1 | 1 | I | I | 1  | e  | 25 | st | tk | b   | e  | er  | 10 | c | h | ١ |   |    |    |    |    |    |    |   |   |   |    |    |    |   |   |   |    |    |   |    |   |    |     |    |    |   |   |    |   |   |   |
|               | ÷        | Verify F      | Pre  |      | -S | S  | S  | 5   | 5 | S | 5 | S | S | S | S | 5 | 5  | y  | 1  | 1  | t  | ł   | 1  | e   | si | i | z | e | - | d  | ł  | C  | D  | e  | si | i | g | 1 | n  |    |    |   |   |   |    |    |   |    |   |    |     |    |    |   |   |    |   |   |   |
|               | Ļ.       | Simu          | ulat | te   | e  | e  | 2  | •   | • | • | • | 2 | 2 | 2 | • |   |    |    |    |    |    |     |    |     |    |   |   |   |   |    |    |    |    |    |    |   |   |   |    |    |    |   |   |   |    |    |   |    |   |    |     |    |    |   |   |    |   |   |   |
| <u> </u>      | ) Co     | onstraint     | s    |      |    |    |    |     |   |   |   |   |   |   |   |   |    |    |    |    |    |     |    |     |    |   |   |   |   |    |    |    |    |    |    |   |   |   |    |    |    |   |   |   |    |    |   |    |   |    |     |    |    |   |   |    |   |   |   |
|               |          | Manage        | Co   | on   | n  | ns | 15 | 1.5 | 1 | 1 | ۱ | n | n | n | 1 | 5 | s  | 51 | tr | 6  | ai | i   | n  | ts  | 5  |   |   |   |   |    |    |    |    |    |    |   |   |   |    |    |    |   |   |   |    |    |   |    |   |    |     |    |    |   |   |    |   |   |   |
| <u> </u>      | ) In     | plement       | D    | e    | es | s  | s  | 5   | 5 | 5 | 5 | s | s | s | 5 | 5 | 1  | į  | g  | r  | 1  |     |    |     |    |   |   |   |   |    |    |    |    |    |    |   |   |   |    |    |    |   |   |   |    |    |   |    |   |    |     |    |    |   |   |    |   |   |   |
|               | 5        | Open No       | etli | ist  | st | t  | t  |     |   |   |   | t | t | t |   |   | 1  | ٧  | /i | ie | e  | v   | V  | e   | r  |   |   |   |   |    |    |    |    |    |    |   |   |   |    |    |    |   |   |   |    |    |   |    |   |    |     |    |    |   |   |    |   |   |   |
|               | G        | Synthes       | ize  | •    |    |    |    |     |   |   |   |   |   |   |   |   |    |    |    |    |    |     |    |     |    |   |   |   |   |    |    |    |    |    |    |   |   |   |    |    |    |   |   |   |    |    |   |    |   |    |     |    |    |   |   |    |   |   |   |
|               | ÷        | Verify I      | os   | st   | t- | H  | -  |     |   |   |   |   |   |   |   |   | 5  | 5  | Ŋ  | /1 | n  | 1   | ł  | 16  | e  | s | i | Z | 4 | e  | c  | ł  | C  | )  | e  | s | i | g | ļr | n  |    |   |   |   |    |    |   |    |   |    |     |    |    |   |   |    |   |   |   |
|               |          | • Gen         | era  | at   | te | te | e  | e   | e | e | 6 | 6 | 6 | 6 | e | e | e  |    | S  | Si | ir | Y   | 1  | ul  | la | a | t | i | C | n  | n  | 1  | Fi | 10 | e  |   |   |   |    |    |    |   |   |   |    |    |   |    |   |    |     |    |    |   |   |    |   |   |   |
|               |          | Simu          | ulat | te   | e  | e  | 2  | •   | • | • | • | 2 | 2 | 2 | • |   |    |    |    |    |    |     |    |     |    |   |   |   |   |    |    |    |    |    |    |   |   |   |    |    |    |   |   |   |    |    |   |    |   |    |     |    |    |   |   |    |   |   |   |
|               | Pla      | Place an      | nd F | R    | 20 | 0  | 0  | 0   | c | c | C | c | c | c | c | 0 | 0  | 1  | u  | t  | e  | •   |    |     |    |   |   |   |   |    |    |    |    |    |    |   |   |   |    |    |    |   |   |   |    |    |   |    |   |    |     |    |    |   |   |    |   |   |   |
|               |          | Edit Pos      | t La | ay   | y  | y  | 10 | (   | ( | 1 | 1 | 1 | 1 | 1 | 1 | ( | c  | 0  | u  | It |    | [   | )  | e   | s  | i | c | , | n | l  |    |    |    |    |    |   |   |   |    |    |    |   |   |   |    |    |   |    |   |    |     |    |    |   |   |    |   |   |   |
|               | ÷        | Verify F      | os   | st   | t  | 1  | 1  | 1   | 1 |   |   |   |   |   |   | 1 | l  | Ĺ  | a  | Ŋ  | 1  | c   | )  | u   | t  | 1 | I | n | n | F  | p  | l  | e  | m  | 1  | e | r | 1 | ta | a  | ti | i | 0 | n | 1  |    |   |    |   |    |     |    |    |   |   |    |   |   |   |
|               |          | • 🗋 Gen       | era  | at   | te | te | e  | e   | e | e | e | 6 | 6 | 6 | e | e | e  | •  | E  | 3  | a  | 0   | 1  | (   | A  |   | n | 1 | n | c  | )  | t  | a  | te | ec | d |   | F | i  | le | 25 | 5 |   |   |    |    |   |    |   |    |     |    |    |   |   |    |   |   |   |
|               | -        | Simu          | ulat | te   | e  | 9  | 2  | •   | • | • | • | • | • | • | • |   |    |    |    |    |    |     |    |     |    |   |   |   |   |    |    |    |    |    |    |   |   |   |    |    |    |   |   |   |    |    |   |    |   |    |     |    |    |   |   |    |   |   |   |
|               |          | 🖄 Verif       | уT   | l ir | in | n  | n  | γ   | 1 | 1 | 1 | n | n | n | 1 | ĩ | n  | n  | ir | n  | g  | ļ   |    |     |    |   |   |   |   |    |    |    |    |    |    |   |   |   |    |    |    |   |   |   |    |    |   |    |   |    |     |    |    |   |   |    |   |   |   |
|               |          | 💩 Ope         | n S  | Sm   | m  | n  | n  | n   | 1 | 1 | 1 | n | n | n | 1 | 1 | lá | a  | r  | ť  | T  | ſ   | ir | n   | e  | 9 |   |   |   |    |    |    |    |    |    |   |   |   |    |    |    |   |   |   |    |    |   |    |   |    |     |    |    |   |   |    |   |   |   |
|               |          | 🕆 🚺 Verif     | y P  | 00   | 01 | 01 | N  | V   | ١ | ١ | ١ | 1 | 1 | 1 | ١ | V | M  | V  | e  | er | r  |     |    |     |    |   |   |   |   |    |    |    |    |    |    |   |   |   |    |    |    |   |   |   |    |    |   |    |   |    |     |    |    |   |   |    |   |   |   |
|               |          | 🛛 🛱 Ope       | n S  | SS   | SI | 51 | 1  | 1   | ľ | 1 | 1 | 1 | 1 | 1 | 1 | ľ | N  | V  |    | A  | 1  | n   | 2  | aly | y  | Z |   | e | r |    |    |    |    |    |    |   |   |   |    |    |    |   |   |   |    |    |   |    |   |    |     |    |    |   |   |    |   |   |   |
| <u> </u>      | Pr       | ogram D       | esi  | ig   | g  | JI | 1  | 1   | I |   |   | l | l | l |   | 1 | r  | 1  |    |    |    |     |    |     |    |   |   |   |   |    |    |    |    |    |    |   |   |   |    |    |    |   |   |   |    |    |   |    |   |    |     |    |    |   |   |    |   |   |   |
|               | •        | Configu       | ire  | D    | D  | )( | )( | )(  | ) | ) | ) | ) | ) | ) | ) | - | e  | e  | s  | i  | g  | , 1 | n  | l   | n  | i | t | i | 2 | 1  | li | Z  | 3  | ti | ic | ) | n | 1 | C  | ); | a  | t | a | 1 | ar | nd | N | le | m | nc | ori | es | ;  |   |   |    |   |   |   |
|               | •        | Generat       | te D | De   | )e | e  | e  | e   | e | e | 2 | e | e | e | e | 2 | 2  | s  | i  | g  | ļľ | n   | 1  | In  | i  | t | i | 2 | 1 | li | Z  | a  | at | i  | D  | n | ۱ | [ | D  | a  | t  | а | 1 |   |    |    |   |    |   |    |     |    |    |   |   |    |   |   |   |
| ė             | PI       | blish De      | sig  | In   | n  | 1  |    |     |   |   |   |   |   |   |   |   |    |    |    |    |    |     |    |     |    |   |   |   |   |    |    |    |    |    |    |   |   |   |    |    |    |   |   |   |    |    |   |    |   |    |     |    |    |   |   |    |   |   |   |
|               | Đ        | Publish I     | Blo  | oc   | ck | k  | k  | k   | k | k |   | k | k | k | k | k | c  |    |    |    |    |     |    |     |    |   |   |   |   |    |    |    |    |    |    |   |   |   |    |    |    |   |   |   |    |    |   |    |   |    |     |    |    |   |   |    |   |   |   |

3. If a Block requires physical I/O resources, specify explicit instantiation of I/O resources. All logic within the Microchip Design Separation methodology must be incorporated within an isolated region. Therefore, you must associate all physical I/O resources with an isolated region. You can insert I/Os through direct instantiation or through insertion of I/O buffers using SmartDesign.

This example uses the Catalog in SmartDesign to insert I/Os to top-level signals. **block4** subsystem has following port list:

- CLK , RESETN , RX, dataIn: Top-level input signals
- DataOut: Top-level output signals
- TX, Y 0: IRS signals to **block1**
- Y: IRS signals to **block2**
- 4. Because each Block should have I/Os inserted for its top-level I/O signals, insert I/O ports to the top-level signals of this subsystem.
- 5. Create a SmartDesign with the name **block4**. Instantiate the COREAPB3, COREGPIO, and MIV\_RV32IMC components into **block4**.
- 6. For each top-level output signal, assign an OUTBUF macro. This instantiates a single I/O port for each of the signals. The output signal DataOut has a width of 32 bits.



| alog<br>P Catalog                             | 🔍 🔻 🗌 Simulation Mode | e<br>0 - |
|-----------------------------------------------|-----------------------|----------|
| Name                                          | / Version             |          |
| GCLKBUF DIFF                                  | 1.0                   |          |
| GCLKINT                                       | 1.0                   |          |
| INBUF                                         | 1.0                   |          |
| INBUF DIFF                                    | 1.0                   |          |
| INV                                           | 1.0                   |          |
| INVD                                          | 1.0                   |          |
| LIVE PROBE A                                  | 1.0                   |          |
| LIVE PROBE_B                                  | 1.0                   |          |
| MACC PA                                       | 1.0                   |          |
| MACC PA BC ROM                                | 1.0                   |          |
| MX2                                           | 1.0                   |          |
| MX4                                           | 1.0                   |          |
| NAND2                                         | 1.0                   |          |
| NAND3                                         | 1.0                   |          |
| NAND4                                         | 1.0                   |          |
| NOR2                                          | 1.0                   |          |
| NOR3                                          | 1.0                   |          |
| NOR4                                          | 1.0                   |          |
| OR2                                           | 1.0                   |          |
| OR3                                           | 1.0                   |          |
| OR4                                           | 1.0                   |          |
| OSC_RC160MHZ                                  | 1.0                   |          |
| OSC_RC2MHZ                                    | 1.0                   |          |
| OUTBUF                                        | 1.0                   |          |
| OUTBUF_DIFF                                   | 1.0                   | -        |
|                                               |                       |          |
| New cores are available                       | Download them now!    |          |
| esign Flow Design Hierarchy Stimulus Hierarch | ny Catalog Files      |          |

- 7. After you instantiate all required I/O macros, rename them to a unique name and connect these I/O pads to respective ports of **block4** instance.
- 8. Since DataOut, TX, Y, and Y\_0 are interconnected signals, right-click the ports and promote them to the top. The following figure shows the schematics of the **block4** SmartDesign component.



### Figure 2-6. SmartDesign Component for block4 Subsystem along with I/Os

- 9. Generate **block4**, set this module as the root module, and enable Block creation for this module as described in the previous section.
- 10. Publish the Block.

### 2.3 Publishing the Block

After you create the module with I/Os inserted, publish the Block. Run Synthesis, and compile the subsystem (or its wrapper SmartDeisgnor HDL component). You can check for timing closure on the Block. Publish the Block without place-and-route information.

- 1. For **block4**, run Synthesis.
- Disable Publish Placement and Publish Routing information in Publish Block > Configure Options, as shown in the following figure. Publish the block.
   Note: Placement and routing information is not needed until the Block is integrated with the top-level project. Enabling these options results in a longer Compile cycle.
- <sup>3.</sup> Figure 2-7. Publishing the Block without Placement and Routing Information

| Folder:       | 990\Des       | ktop\msvt\design1\d | esigner \block4 | Browse. |
|---------------|---------------|---------------------|-----------------|---------|
| Publish Block | Configuration |                     |                 |         |
| Publish I     | Placement     |                     |                 |         |
| Publish       | Routing       |                     |                 |         |
| Publish       | Region        |                     |                 |         |
|               |               |                     |                 |         |
| Language      |               |                     |                 |         |
| Verilog       |               | C VHDL              |                 |         |
|               |               |                     |                 |         |

The following figure shows the state of the completed design flow after you publish the Block.

Figure 2-8. Completed Block Flow along with Resource Usage from Compile

| odule(root): block4 E 🔰 🖬 🔚 🦉                     |   | <ul> <li>Project Summ</li> <li>block4 report</li> </ul> | ary<br>s                            | Resource Usa           | ge     |        |           |
|---------------------------------------------------|---|---------------------------------------------------------|-------------------------------------|------------------------|--------|--------|-----------|
| Tool                                              |   | Compone     Synthesize                                  | nts                                 | Туре                   | Used   | Total  | Percentag |
| Create SmartDesign Testbench                      | · | synplit                                                 | y.log                               | 4LUT                   | 6303   | 299544 | 2.10      |
| Create HDL Testbench                              |   | - 🔔 bl                                                  | ock4.srr                            | DFF                    | 2121   | 299544 | 0.71      |
| Verify Pre-Synthesized Design                     |   | run_or                                                  | otions.txt                          | I/O Register           | 0      | 1536   | 0.00      |
| Simulate                                          |   | block4                                                  | _dsp_rpt.txt                        | Liser I/O              | 32     | 512    | 6.25      |
| Constraints                                       |   | block4                                                  | _ram_rpt.txt                        | Circle and d I/O       | 20     | 640    | C.05      |
| Manage Constraints                                |   | block                                                   | _compile_netlist_resources.xml      | Single-ended I/O       | 32     | 512    | 6.25      |
| Implement Design                                  |   | block                                                   | _compile_netlist_hier_resources.csv | Differential I/O Pairs | 0      | 256    | 0.00      |
| Sentharia                                         |   | - block                                                 | _compile_ioff.xml                   | uSRAM                  | 6      | 2772   | 0.22      |
| Synthesize                                        |   |                                                         | ock4_compile_netlist.log            | LSRAM                  | 16     | 952    | 1.68      |
| Generate Simulation File                          |   | - Non root com                                          | ponents                             | Math                   | 0      | 924    | 0.00      |
|                                                   |   | H block2                                                |                                     | H-Chin Global          | 1      | 48     | 2.08      |
| Place and Route                                   |   | E block3                                                |                                     | DU                     |        | 0      | 0.00      |
| Edit Post Layout Design                           |   | CoreAHBL                                                | ite C0                              | FLL                    | 0      | 0      | 0.00      |
| Verify Post Layout Implementation                 |   | CoreAPB3                                                | CO                                  | DLL                    | 0      | 8      | 0.00      |
| <ul> <li>Generate Back Annotated Files</li> </ul> |   | E CoreAPB3                                              | C1                                  | Transceiver Lanes      | 0      | 16     | 0.00      |
| - 📰 Simulate                                      |   | E CoreGPIO                                              | CO                                  | Transceiver PCIe       | 0      | 2      | 0.00      |
| 💩 Verify Timing                                   |   | CoreGPIO                                                | _C1                                 |                        |        |        |           |
| 🖳 💩 Open SmartTime                                |   | CoreGPIO                                                | _C2                                 |                        |        |        |           |
| Verify Power                                      |   | CoreGPIO                                                | _C3                                 | Detailed Logic         | Dec    | ource  | lleage    |
| - R Open SSN Analyzer                             |   | E CoreUART                                              | apb_C0                              | Detailed Logic         | nes    | ource  | e Usage   |
| Program Design                                    |   | CoreUART                                                | apb_C1                              | Type                   | 41.117 | DEE    |           |
| Configure Design Initialization Data and Memories |   | MIV_RV32                                                | IMC_CO                              | Tabia Losia            |        | 4470   |           |
| Bublish Decign                                    |   | MIV_RV32                                                |                                     | Fabric Logic           | 2055   | 14/3   |           |
|                                                   |   | PF_SKAWI_                                               | AUDT AVI CO                         | uSRAM Interface Logic  | 72     | 72     |           |
| ap rubian block                                   | - |                                                         |                                     | LSRAM Interface Logic  | 576    | 576    |           |
|                                                   | - |                                                         |                                     | Math Interface Logic   | 0      | 0      |           |

Publishing a Block creates a <block\_name>.cxz file in the <project\_path>/designer/ <block\_name>/export directory.

For the preceding subsystem, Libero creates the block4.cxz file in the export directory under the designer directory of the Project location, as shown in the following figure.

|                                           | 8 |
|-------------------------------------------|---|
| 🕂 🗀 component                             |   |
| 🗄 🗀 constraint                            |   |
| 😑 🗀 designer                              |   |
| 🕀 🗀 block1                                |   |
| 🗄 🖻 block2                                |   |
| ⊞ 🗀 block3                                |   |
| 🖻 🗝 block4                                |   |
| 🖮 🗎 block4.adl                            |   |
| 🖮 🗎 block4.afl                            |   |
| - 🗎 block4.cfrt                           |   |
| 🖶 block4.cxz                              |   |
| 🚽 🗎 block4.loc                            |   |
| 🖮 🗎 block4.mvn.pdc                        |   |
| 🚽 🗎 block4.nmatinit.pdc                   |   |
| 🖳 🗎 block4.nmatinit.txt                   |   |
| 🚽 🗎 block4.seg                            |   |
| 🖿 🗎 block4.smat.seg                       |   |
| block4_block_region_violation             |   |
| block4_compile_ioff.rpt                   |   |
| block4_compile_ioff.xml                   |   |
| block4_compile_netlist.log                |   |
| block4_compile_netlist_hier_resources.csv |   |
| block4_compile_netlist_resources.rpt      |   |
| block4_compile_netlist_resources.xml      |   |
| block4_core.tcml                          |   |
| block4_glb_net_report.html                |   |
| block4_glb_net_report.xml                 |   |
| block4_has_io_constraints                 |   |
| block4_has_violations                     |   |
| block4_ioff.rpt                           |   |
| block4_maxdelay_timing_report.xml         | - |

### Figure 2-9. Published Block as .cxz file in Export Directory

4. Repeat this procedure for the other four subsystems, and then publish Blocks for each of them. Use the Block names shown in the following table.

| Subsystem | Block Name |
|-----------|------------|
| block1    | block1     |
| block2    | block2     |
| block3    | block3     |
| pf_smip   | pf_smip    |

5. Create a top-level design.

# 2.4 Creating a Top-level Design

After you published the subsystem Blocks, create a new Libero project for the top-level design. Create a SmartDesign block where you instantiate all the individual blocks and connect their IRS signals. This example writes a top-level module SD\_Top.v that instantiates these Blocks along with required interconnects. The following shows an example description of the top-level SD\_Top module.

| - | /////////////////////////////////////// |
|---|-----------------------------------------|
|   | `timescale 1ns / 100ps                  |
|   | // top                                  |
|   | module top(                             |
|   | // Inputs                               |
|   | input DataInO,                          |
|   | input DataIn1,                          |
|   | input DataIn10,                         |
|   | input DataInII,                         |
|   | input DataInI2,                         |
|   | input DataInI3,                         |
|   | input DataIn14,                         |
|   | input DataIn16.                         |
|   | input DataIn17.                         |
|   | input DataIn18,                         |
|   | input DataIn19,                         |
|   | input DataIn2,                          |
|   | input DataIn20,                         |
|   | input DataIn21,                         |
|   | input DataIn22,                         |
|   | input DataIn23,                         |
|   | input DataIn24,                         |
|   | input DataIII23,                        |
|   | input DataIn27.                         |
|   | input DataIn28,                         |
|   | input DataIn29,                         |
|   | input DataIn3,                          |
|   | input DataIn30,                         |
|   | input DataIn31,                         |
|   | input DataIn4,                          |
|   | input DataIn5,                          |
|   | input Dataino,                          |
|   | input Datain',                          |
|   | input DataIn9.                          |
|   | input BEF CLK 0,                        |
|   | input RESETN,                           |
|   | input pf smip reset,                    |
|   | // Outputs                              |
|   | output DataOut0,                        |
|   | output DataOutl,                        |
|   | output DataOut10,                       |
|   | output DataOut11,                       |
|   | output DataOut13                        |
|   | output DataOut14.                       |
|   | output DataOut15,                       |
|   | output DataOut16,                       |
|   | output DataOut17,                       |
|   | output DataOut18,                       |
|   | output DataOut19,                       |
|   | output DataOut2,                        |
|   | output DataOut20,                       |
|   | output DataOut21,                       |
|   | output DataOut22,                       |
|   | output DataOut24,                       |
|   | output DataOut25,                       |
|   | output DataOut26,                       |
|   | output DataOut27,                       |
|   | output DataOut28,                       |
|   | output DataOut29,                       |
|   | output DataOut3,                        |
|   | ομερμέ ματασμέζο,                       |

```
output DataOut31,
    output DataOut4,
    output DataOut5,
    output DataOut6,
    output DataOut7,
    output DataOut8,
    output DataOut9,
    output pf_smip_out
);
//----
                   _____
// Nets
//----
                           _____
wire [31:0] block1_0_APBmslave0_PADDR;
wire block1_0_APBmslave0_PENABLE;
wire [31:0] block1 0 APBmslave0 PRDATA;
wire
               block1 0 APBmslave0 PREADY;
wire block1_0_APBmslave0_PSELx;
wire block1_0_APBmslave0_PSELx;
wire [31:0] block1_0_APBmslave0_PWDATA;
wire block1_0_APBmslave0_PWRITE;
wire [7:0] block1 0 dataOut;
               block1_0_TX;
wire
wire
       [31:0] block3_0_dataOut;
[7:0] block3_0_dataOut_0;
block4_0_TX;
wire
wire
               block4_0_Y;
wire
              block4 0 Y 0;
wire
wire
               REF_CLK_ibuf_Y;
               RESETN ibuf Y;
wire
               PF CCC CO 0 OUTO FABCLK 0;
wire
//----
                _____
                                         _____
// Component instances
//-----
//----block1
block1 block1 0(
         // Inputs
         .CLK ( PF_CCC_CO_0_OUT0_FABCLK_0 ),
.HRESETN ( block4_0_Y_0 ),
.PREADYS0 ( block1_0_APBmslave0_PREADY ),
         .PSLVERRS0 ( block1 0 APBmslave0 PSLVERR ),
                    ( block4<sup>0</sup>TX ),
         .RX
         .PRDATASO ( block1_0_APBmslave0_PRDATA ),
         .dataIn (block3_0_dataOut_0),
         // Outputs
         .PENABLES ( block1 0 APBmslave0 PENABLE ),
         .PSELSO ( block1 0 APBmslave0 PSELx ),
         .PWRITES ( block1_0_APBmslave0_PWRITE ),
         .TX (block1_0_TX),
.PADDRS (block1_0_APBmslave0_PADDR),
.PWDATAS (block1_0_APBmslave0_PWDATA),
         .dataOut ( block1_0_dataOut )
         );
//----block2
block2 block2 0(
         // Inputs
                      ( PF_CCC_C0_0_OUT0_FABCLK_0 ),
         .PCLK
         .PENABLE_in ( block1_0_APBmslave0_PENABLE ),
.PRESETN ( block4_0_Y ),
.PSEL_in ( block1_0_APBmslave0_PSELx ),
         .PWRITE in ( block1 0 APBmslave0 PWRITE ),
         .PADDR in ( block1 0 APBmslave0 PADDR ),
         .PWDATA_in ( block1_0_APBmslave0_PWDATA ),
         // Outputs
         .PREADY in ( block1 0 APBmslave0 PREADY ),
         .PSVERR in ( block1 0 APBmslave0 PSLVERR ),
```

|              | .PRDATA_in );                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | ( block1_0_APBmslave0_PRDATA )                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| //block3     | block3<br>block3_0(<br>// Inputs<br>.CLK<br>.DataIn0<br>.DataIn1<br>.DataIn2<br>.DataIn3<br>.DataIn4<br>.DataIn5<br>.DataIn6<br>.DataIn7<br>.DataIn8<br>.DataIn9<br>.DataIn10<br>.DataIn10<br>.DataIn12<br>.DataIn12<br>.DataIn13<br>.DataIn14<br>.DataIn15<br>.DataIn16<br>.DataIn17<br>.DataIn18<br>.DataIn17<br>.DataIn18<br>.DataIn17<br>.DataIn18<br>.DataIn19<br>.DataIn19<br>.DataIn20<br>.DataIn21<br>.DataIn23<br>.DataIn23<br>.DataIn24<br>.DataIn25<br>.DataIn25<br>.DataIn26<br>.DataIn27<br>.DataIn28<br>.DataIn20<br>.DataIn20<br>.DataIn21<br>.DataIn20<br>.DataIn21<br>.DataIn22<br>.DataIn23<br>.DataIn24<br>.DataIn27<br>.DataIn28<br>.DataIn29<br>.DataIn30<br>.DataIn31<br>.RESETN<br>.dataOut<br>.dataOut<br>.0; | <pre>( PF_CCC_C0_0_OUT0_FABCLK_0 ),<br/>( DataIn0 ),<br/>( DataIn1 ),<br/>( DataIn1 ),<br/>( DataIn2 ),<br/>( DataIn3 ),<br/>( DataIn3 ),<br/>( DataIn5 ),<br/>( DataIn5 ),<br/>( DataIn6 ),<br/>( DataIn7 ),<br/>( DataIn7 ),<br/>( DataIn9 ),<br/>( DataIn10 ),<br/>( DataIn10 ),<br/>( DataIn11 ),<br/>( DataIn12 ),<br/>( DataIn12 ),<br/>( DataIn13 ),<br/>( DataIn14 ),<br/>( DataIn15 ),<br/>( DataIn16 ),<br/>( DataIn17 ),<br/>( DataIn18 ),<br/>( DataIn19 ),<br/>( DataIn20 ),<br/>( DataIn20 ),<br/>( DataIn21 ),<br/>( DataIn22 ),<br/>( DataIn22 ),<br/>( DataIn23 ),<br/>( DataIn25 ),<br/>( DataIn26 ),<br/>( DataIn29 ),<br/>( DataIn31 ),<br/>( RESETN_ibuf_Y ),<br/>( block3_0_dataOut_0 )</pre> |
| //<br>block4 | block4<br>block4_0(<br>// Inputs<br>.CLK<br>.RESETN<br>.RX<br>.dataIn<br>// Outputs<br>.DataOut0<br>.DataOut1<br>.DataOut2<br>.DataOut3<br>.DataOut4<br>.DataOut5<br>.DataOut6<br>.DataOut7<br>.DataOut8<br>.DataOut9<br>.DataOut10<br>.DataOut11<br>.DataOut12<br>.DataOut13                                                                                                                                                                                                                                                                                                                                                                                                                                                         | <pre>( PF_CCC_C0_0_OUT0_FABCLK_0 ),<br/>( RESETN_ibuf_Y ),<br/>( block1_0_TX ),<br/>( block3_0_dataOut ),<br/>( DataOut0 ),<br/>( DataOut1 ),<br/>( DataOut2 ),<br/>( DataOut2 ),<br/>( DataOut3 ),<br/>( DataOut3 ),<br/>( DataOut4 ),<br/>( DataOut5 ),<br/>( DataOut5 ),<br/>( DataOut5 ),<br/>( DataOut6 ),<br/>( DataOut7 ),<br/>( DataOut8 ),<br/>( DataOut9 ),<br/>( DataOut10 ),<br/>( DataOut11 ),<br/>( DataOut12 ),<br/>( DataOut13 ),</pre>                                                                                                                                                                                                                                                             |

```
.DataOut14 ( DataOut14 ),
        .DataOut15 ( DataOut15 ),
        .DataOut16 ( DataOut16 ),
        .DataOut17 ( DataOut17 ),
        .DataOut18 ( DataOut18 ),
        .DataOut19 ( DataOut19 ),
        .DataOut20 ( DataOut20 ),
        .DataOut21 ( DataOut21 ),
        .DataOut22 ( DataOut22 ),
        .DataOut23 ( DataOut23 ),
        .DataOut24 ( DataOut24 ),
        .DataOut25 ( DataOut25 ),
        .DataOut26 ( DataOut26 ),
        .DataOut27 ( DataOut27 ),
        .DataOut28 ( DataOut28 ),
        .DataOut29 ( DataOut29 ),
        .DataOut30 ( DataOut30 ),
        .DataOut31 ( DataOut31 ),
        .TX
                   ( block4_0_TX ),
( block4_0_Y ),
        .Y
                  ( block4<sup>0</sup> Y 0 )
        .Y 0
        );
//----INBUF
INBUF REF CLK ibuf(
        // Inputs
        .PAD ( REF_CLK_0 ),
        // Outputs
        .Y ( REF_CLK_ibuf_Y )
        );
//----INBUF
INBUF RESETN ibuf (
        // Inputs
        .PAD ( RESETN ),
        // Outputs
        .Y
            ( RESETN ibuf Y )
        );
//----PF CCC C0
PF CCC C0 PF CCC C0 0(
        // Inputs
        .REF CLK 0
                        ( REF CLK ibuf Y ),
        // Outputs
        .OUT0_FABCLK_0 ( PF_CCC_C0_0_OUT0_FABCLK_0 ),
        .PLL LOCK 0
                       ( )
        );
//----pf_smip
pf_smip_pf_smip_0(
// Inputs
                        ( PF CCC CO O OUTO FABCLK O ),
        .CLK
        .pf_smip_reset ( pf_smip_reset ),
        // Outputs
        .pf_smip_out ( pf_smip_out )
        );
```

#### endmodule

Set the top-level module as the root module, and import all Blocks (<block\_name>.cxz files) using File >
 Import > Blocks in Libero. The following figure shows Design Hierarchy of the top-level SD\_Top module with
 all Blocks instantiated.

#### Figure 2-10. Top-level Design Hierarchy

| esign Hierarchy        |               |             |                  |   |     |   | 83 |
|------------------------|---------------|-------------|------------------|---|-----|---|----|
| Top Module(root): SD_T | ор            |             |                  |   |     |   |    |
| Build Hierarchy        |               |             | Show: Components | • | ± - | ? | 8  |
| 🖻 🗰 work               |               |             |                  |   |     |   |    |
| 🖻 🔊 SD                 | Тор           |             |                  |   |     |   |    |
| P                      | PF_CCC_C0 (P  | F_CCC_v2.2. | 100)             |   |     |   |    |
|                        | block1        |             |                  |   |     |   |    |
| - 🗇                    | block2        |             |                  |   |     |   |    |
|                        | block3        |             |                  |   |     |   |    |
| 🗊                      | block4        |             |                  |   |     |   |    |
| - <b>1</b>             | pf_smip       |             |                  |   |     |   |    |
| 🖻 🛅 Compo              | nents         |             |                  |   |     |   |    |
| 🗍 bloo                 | ck1           |             |                  |   |     |   |    |
| 🗖 blog                 | ck2           |             |                  |   |     |   |    |
| 🗇 bloc                 | ck3           |             |                  |   |     |   |    |
| 🗖 bloo                 | k4            |             |                  |   |     |   |    |
| PF_(                   | CCC_CO (PF_CO | C_v2.2.100  | )                |   |     |   |    |
| 🗇 🗇 pf_s               | mip           |             |                  |   |     |   |    |
| SD SD                  | Тор           |             |                  |   |     |   |    |
|                        |               |             |                  |   |     |   |    |

2. For this module, uncheck the boxes for **Enable block creation** and **Enable synthesis** (in **Project Settings**) and check **Enable Design Separation Methodology**, as shown in the following figure.

Figure 2-11. Project Settings for the Top-level Design

|                                                                                             | HDL source files language options                                                                                                                                                                                                                                                                                                       | -       |
|---------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|
| Device settings<br>Design flow<br>nalysis operating conditi<br>imulation options<br>DO file | Libero SoC supports mixed-HDL language designs; you can import Verilog and VHDL in the same project.<br>For Verilog files you can enable the System Verilog syntax option if your Verilog files contain System Verilog constructs.<br>For VHDL files, you may choose between VHDL-2008 and VHDL-93.                                     | Discard |
| Waveforms<br>Vsim commands                                                                  | Verlog  Verlog   Verlog 2001                                                                                                                                                                                                                                                                                                            |         |
| Timescale<br>mulation libraries<br>PolarFire                                                | VHDL-2008 C VHDL-93                                                                                                                                                                                                                                                                                                                     |         |
| obal Include Paths                                                                          | HDL generated files language options                                                                                                                                                                                                                                                                                                    |         |
|                                                                                             | HDL files generated by Libero SoC such as configured cores, SmartDesign components and post-layout gate level netists use the preferred language option.                                                                                                                                                                                |         |
|                                                                                             | Block flow Block flow Block flow enables you to publish a reusable component that can be instantiated into another design. A block component may not contain I/O cells and cannot be programmed by itself. It could include timing constraints, physical constraints, placement or routing. Enable block creation Enable block creation |         |
|                                                                                             | Root SD_Top Enable synthesis                                                                                                                                                                                                                                                                                                            | ]       |
|                                                                                             | Enable PPGA Hardware Breakpoint Auto Instantiation     Design Separation                                                                                                                                                                                                                                                                |         |
|                                                                                             | Frable Design Separation Methodology                                                                                                                                                                                                                                                                                                    |         |
|                                                                                             | Reports Maximum number of high fanout nets to be displayed: [10                                                                                                                                                                                                                                                                         | ]       |
|                                                                                             | Abort flow if errors are found in Physical Design Constraints (PDC)                                                                                                                                                                                                                                                                     | 1       |
|                                                                                             |                                                                                                                                                                                                                                                                                                                                         |         |

3. Assign each Block of the design to a separation region.

## 2.5 Floorplanning Design with Separation Regions

Each Block of the design must be assigned to a separation region. You can define separation regions in Chip Planner or use a PDC file. For more information about floorplanning a design using Chip Planner, see the Libero online help.

This example defines a separation region using Chip Planner for instance block4\_0, which corresponds to the block4 Block.

1. Open Chip Planner from **Manage Constraints > Floor Planner > Edit** in the **Design Flow** window, as shown in the following figure.

#### Figure 2-12. Opening Chip Planner

|        | dule(r | et):   | 50_Top 🖸 🖸                             | d 🗍 🤅 | ¥ | 1/O Attributes | Tining F   | loor Planner   Netle | it Attributes                                                              |
|--------|--------|--------|----------------------------------------|-------|---|----------------|------------|----------------------|----------------------------------------------------------------------------|
| Active | Synth  | sis br | mplementation: synthesis               |       | - | Nev            | Import     | Link                 | Edit Vew Check Help                                                        |
|        | Too    |        |                                        |       | 1 |                |            |                      | Modify the set of selected Floor Planning PDC files using the Chip Planner |
|        | 8      | ۶.     | Create Design                          |       |   | dari mand Cl   | Terl(D) Te | a black fa ada       |                                                                            |
|        |        |        | Create SmartDesign                     |       |   | designer/si    | 210p\30_10 | pulockip.pac         |                                                                            |
|        |        |        | E Create HDL                           |       |   | constrainty    | h/toh/har  |                      |                                                                            |
|        |        |        | Create SmartDesign Testbench           |       |   |                |            |                      |                                                                            |
|        |        |        | Create HDL Testbench                   |       |   |                |            |                      |                                                                            |
|        |        | 8-     | Verify Pre-Synthesized Design          |       |   |                |            |                      |                                                                            |
|        |        |        | Simulate                               |       |   |                |            |                      |                                                                            |
|        | 8      | ۶.     | Constraints                            |       |   |                |            |                      |                                                                            |
|        |        |        | Manage Constraints                     |       |   |                |            |                      |                                                                            |
| V      | 8      | ۶.     | Implement Design                       |       |   |                |            |                      |                                                                            |
|        |        |        | Q Open Netlist Viewer                  |       |   |                |            |                      |                                                                            |
| 1      |        |        | Synthesize                             |       | _ |                |            |                      |                                                                            |
|        |        | 8.     | Verify Post-Synthesized Design         |       |   |                |            |                      |                                                                            |
|        |        |        | Generate Simulation File               |       |   |                |            |                      |                                                                            |
|        |        |        | Simulate                               |       |   |                |            |                      |                                                                            |
| ~      |        |        | Place and Route                        |       |   |                |            |                      |                                                                            |
|        |        |        | Edit Post Layout Design                |       |   |                |            |                      |                                                                            |
|        |        | 8-     | Verify Post Layout Implementation      |       |   |                |            |                      |                                                                            |
|        |        |        | - • Generate Back Annotated Files      |       |   |                |            |                      |                                                                            |
|        |        |        | - Simulate                             |       |   |                |            |                      |                                                                            |
|        |        |        | - 💩 Verify Timing                      |       |   |                |            |                      |                                                                            |
|        |        |        | Open SmartTime                         |       |   |                |            |                      |                                                                            |
|        |        |        | R Verify Power                         |       |   |                |            |                      |                                                                            |
|        |        |        | Copen SSN Analyzer                     |       |   |                |            |                      |                                                                            |
|        | 8-     | •      | Configure Hardware                     |       |   |                |            |                      |                                                                            |
|        |        |        | Programming Connectivity and Interface |       |   |                |            |                      |                                                                            |
|        |        |        | Configure Programmer                   |       | - |                |            |                      |                                                                            |

Create a separation region for each Block according to the estimate obtained from the resource usage reports.
 Note: For more information, see Creating routing regions in the Chip Planner help.

**1.7** FloorPlanning with Design Separation Regions shows a sample floorplan for the design. This example creates an exclusive routing region constraint for instance block4\_0, as shown in the following figure. (You can define the region type to be inclusive if a top-level global instance needs to be placed within the same region).

### Figure 2-13. Creating an Exclusive Routing Region

| Primitives PF_CCC_C0_0 block1_0                    | Properties       |                        |          |        | ×                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                        |
|----------------------------------------------------|------------------|------------------------|----------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------|
| block2_0<br>block3_0                               | Region Name: Boo | Aregion                |          |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                        |
| D Printives     CoreAPB3 C2 0     CoreGPIO C4 0    | туре: С          | Inclusive<br>Exclusive |          |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                        |
| MIV RV32IMC C2 0     Diock4 IO 0     AB Primitives | Routing          | Empty                  |          |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                        |
| pr2smp_0                                           | Constrain rout   | *0                     |          |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | IBR1_2                                 |
|                                                    |                  | Region                 | Extents  |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Block2region                           |
|                                                    | origin           | endpt                  | width    | height | 2-11                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | SIMI                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | e BrockEr egien                        |
|                                                    | (1200.0)         | (2351.158)             | 1152     | 159    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 7001 4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | - IDD2 4                               |
|                                                    |                  | Reso                   | ources   |        | Contract of Contract                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | JDR1_1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | IDK4_T                                 |
|                                                    | Resource         | Assigned               | Capacity | % Used |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                        |
|                                                    | 4LUT + CARRY_C   | AIN 6241               | 59280    | 10.53  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | <u>al/Aragian</u>                      |
|                                                    | CARRY_CHAIN      | 644                    | 38760    | 1.66   | 1BH                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                        |
|                                                    | CC_CONFIG        | 64                     | 38760    | 0.17   | lion                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | and the state of the second state of the secon |                                        |
|                                                    | 10               | 2120                   | 39280    | 100.00 | address of the local division of the local d |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | •••••••••••••••••••••••••••••••••••••• |
|                                                    | MATH             | 0                      | 192      | 0.00   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                        |
|                                                    | SRAM             | 16                     | 192      | 8.33   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                        |
|                                                    | URAM             | 6                      | 570      | 1.05   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                        |
|                                                    |                  |                        |          |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                        |
|                                                    |                  |                        |          |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                        |
|                                                    |                  |                        |          |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                        |

3. Create separation regions for all blocks of the design. Then assign Block instances to the respective separation region. For this example, the floorplan resembles the following figure.

Figure 2-14. Floorplan of Design with Separation Regions Defined



4. After you create separation regions corresponding to the Blocks, create IRS regions for each set of connections between the Blocks. In the example, block1\_0 connects to IBR1\_2 and IBR1\_2 connects to block2\_0. Consequently, define the remaining three sets of IRS regions.

IRS region is an inclusive routing region that is created in a similar way as the separation regions. The following figure show an example of an IRS region for instances block1\_0 to IBR1\_2.



### Figure 2-15. Creating an IRS Region Between Two Blocks

5. Assign valid IRS net macros to the respective IRS regions.

A complete floorplan of the example design resembles the following figure.

### Figure 2-16. Complete Floorplan of Design



The separation between each region should be at least equal to the required number of clusters to satisfy the separation criteria.

The following shows a sample PDC file that can be used to implement the preceding floorplan. Note the regions are defined with -route true to constrain routing. Separation regions are assigned by their highest level hierarchy name using the assign\_region command. IRS nets are assigned with wildcards using the assign\_net\_macros command.

```
define_region -region_name Block1region -type exclusive -color 2143338688 -
route true -push_place true -x1 456 -y1 195 -x2 1631 -y2 371
define_region -region_name Block2region -type exclusive -color 2143338688 -
route true -push_place true -x1 1752 -y1 189 -x2 2435 -y2 377
define_region -region_name Block3region -type exclusive -color 2143338688 -
route true -push_place true -x1 0 -y1 0 -x2 335 -y2 41 \
```

-x1 0 -y1 42 -x2 1067 -y2 161 \

```
-x1 804 -y1 0 -x2 1067 -y2 41
define_region -region_name Block4region -type exclusive -color 2143338688 -
route true -push_place true -x1 1200 -y1 0 -x2 2351 -y2 158
define region -region name SMIPregion -type exclusive -color 2143338688 -
```

route true -push place true -x1 384 -y1 0 -x2 755 -y2 11 define\_region -region\_name IBR1\_2 -type inclusive -color 2147442270 -route true -push\_place false -x1 1584 -y1 282 -x2 2027 -y2 362 define\_region -region\_name IBR1\_3 -type inclusive -color 2147442270 -route true -push\_place false -x1 636 -y1 102 -x2 851 -y2 239 define region -region name IBR1 4 -type inclusive -color 2143338688 -route true -push place false -x1 1356 -y1 126 -x2 1499 -y2 245 define\_region -region\_name IBR2\_4 -type inclusive -color 2147442270 -route true -push place false -x1 2148 -y1 105 -x2 2327 -y2 266 define\_region -region\_name IBR3\_4 -type inclusive -color 2147442270 -route true -push place false -x1 888 -y1 45 -x2 1463 -y2 98 assign\_region -region\_name Block1region -inst\_name block1\_0 assign\_region -region\_name Block2region -inst\_name block2\_0 assign\_region -region\_name Block3region -inst\_name block3\_0 assign\_region -region\_name Block4region -inst\_name block4\_0 assign region -region name Block4region -inst name RESETN ibuf assign region -region name SMIPregion -inst name pf smip 0 assign net macros -region name IBR1 2 -net name block1\_0\_APBmslave0\_PENABLE -include driver true assign net macros -region name IBR1 2 -net name block1 0 APBmslave0 PSELx -include driver true assign net macros -region name IBR1 2 -net name block1\_0\_APBmslave0\_PWRITE -include driver true assign\_net\_macros -region\_name IBR1\_2 -net\_name block1\_0\_APBmslave0\_PREADY -include driver -include driver true assign net macros -region name IBR1 2 -net name {block1 0 APBmslave0 PADDR[\*]} -include driver true assign net macros -region name IBR1 2 -net name {block1 0 APBmslave0 PRDATA[\*]} -include driver true assign net macros -region name IBR1 2 -net name {block1\_0\_APBmslave0\_PWDATA[\*]} -include\_driver true assign net macros -region name IBR1 3 -net name {block1 0 dataOut[\*]} include driver true assign\_net\_macros -region\_name IBR1\_3 -net\_name {block3\_0\_dataOut\_0[\*]} include driver true assign net macros -region name IBR1 4 -net name block4 0 TX -include driver true assign net macros -region name IBR1 4 -net name block4 0 Y 0 -include driver true assign net macros -region name IBR1 4 -net name block1 0 TX -include driver true assign net macros -region name IBR2 4 -net name block4 0 Y -include driver true assign net macros -region name IBR3 4 -net name {block3 0 dataOut[\*]} include driver true

6. Complete place-and-route.

### 2.6 Complete Place-and-Route

After you complete the floorplan, edit the timing constraints and run place-and-route until you achieve timing closure on the design.

### 2.7 Configure Security Settings and Generate the Programming File

After you complete place-and-route, extract the design information to execute MSVT.

1. Navigate to **Configure Security > Configure Options > Debug Policy** and configure the security and programming options per system requirements, as shown in the following figure.

#### Figure 2-17. Security Settings Before Programming

| Del<br>DPK has not been provided and will r<br>SmartDebug user debug access and<br>SmartDebug stwith debug as enabled.                             | sug Policy<br>of be programmed.<br>Scher probes en enabled.                                          | _ |
|----------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------|---|
| OPK has not been provided and will r<br>SmartDebug user debug access and<br>SmartDebug Live Probe debug acces<br>SmartDebug sNVM debug is enabled. | at be programmed.<br>active probes are enabled.<br>is is enabled.                                    | - |
| TAG (1149.1) boundary scan is ena<br>TAG or SPI Slave reading of temper                                                                            | ice is enabled.<br>bled.<br>hute and voltage sensor is enabled.                                      |   |
| Mic                                                                                                                                                | rosemi Factory Access                                                                                |   |
| Allow Microsemi factory test mode as                                                                                                               | cess. This is required to perform Failure Analysis on the device.                                    |   |
| νπε                                                                                                                                                | IG/SPI Slave Commands Policy                                                                         | - |
| I IE amulation through TTAC and CD                                                                                                                 | Churs is sublished                                                                                   |   |
| Security key mode                                                                                                                                  |                                                                                                      |   |
| C Bitstream encryption                                                                                                                             | ith default key Custom security options                                                              |   |
| Update Policy                                                                                                                                      | 0x                                                                                                   | f |
| Debug Policy                                                                                                                                       | Disable Live Probe     Disable stWM                                                                  |   |
|                                                                                                                                                    | Disable UJTAG command through JTAG interface                                                         |   |
| Microsemi<br>Factory<br>Access                                                                                                                     | Deable JTAG (1149.1) boundary scan<br>Deable reading temperature and voltage sensor (JTAG/SPI Slave) |   |
| JTAG/SPI Slave                                                                                                                                     | Reset to default                                                                                     |   |

2. Export the programming file from Program Design > Export FlashPro Express Job. A programming file and files required for the MSVT are generated. Libero exports these files into the <project\_path>/designer/SD\_Top/SD\_Top.msvt.dtf directory and creates a parameter file in the <project\_path>/designer/SD\_Top/msvt.param file, as shown in the following figure. The msvt.param file contains a list of parameters that you can adjust before executing MSVT.

#### Figure 2-18. Generated MSVT Files

|                             | • |
|-----------------------------|---|
| 🗎 clocklist.txt             | 4 |
|                             |   |
| coverage_placeandroute      |   |
| export                      |   |
| io_pcbit_info.ddf           |   |
| 🗎 msvt.param                |   |
| options.txt                 |   |
| pinslacks.txt               |   |
| place_route.sdc             |   |
| rptstyle.xsl                |   |
| run_compile.tcl             |   |
| run_mapper.def              |   |
| run_pinrpt.tcl              |   |
| run_placer.def              |   |
| run_placer_st_shell_cmd.tcl | _ |
| run_placer_st_shell_des.tcl |   |
| run_router.def              |   |
| run_tao.tcl                 |   |
| run_tao_adl.tcl             |   |
| run_tao_adl_vt.tcl          |   |
| run_timrpt_st_shell_cmd.tcl |   |
| run_timrpt_st_shell_des.tcl |   |
| SD_Top.adl                  |   |
| D_SD_Top.afl                |   |
| SD_Top.block.fp.pdc         |   |
| SD_Top.block.io.pdc         |   |
| SD_Top.cfrt                 |   |
| D_SD_Top.loc                |   |
| SD_Top.map                  |   |
| 🗣 늘 SD_Top.msvt.dtf         |   |
| SD_Top.mvn.pdc              |   |

- esign Flow Design Hierarchy Stimulus Hierarchy Catalog Files
- 3. Modify the REQUIRED\_SEPARATION parameter according to your system requirements before executing MSVT.

### 2.8 Execute MSVT

You can now run the MSVT to verify that the design adheres to the required separation criteria.

MSVT is invoked from <Libero Path>/bin64/msvt check pf. It is executed from the command line.

To verify the design using MSVT, run the following command:

```
<Libero_path>/bin64/msvt_check_pf -p <project_path>/designer/SD_Top/msvt.param -o msvt_check_pf.log
```

This command prints an exhaustive report to  $msvt\_check\_pf.log$  file given with the -o argument or to *stdout* if -o is omitted. The argument -p is required, along with the path to the msvt.param file generated from Libero.

When this command completes successfully, the message MSVT Check failed appears if the design failed to meet one or more separation criteria and the message MSVT Check succeeded appears if the design met all separation criteria.

Because Microchip Design Separation methodology guidlines are followed in the example, the following output shows the conclusion of MSVT output indicating that the design was verified for the given separation criteria.

```
MSVT Check
Design: SD_Top.msvt
                                     Started: Fri Jan 8 16:50:41 2021
Checking IRS connectivity against parameter file
        The following instances do not belong to any routing region:
                                                          _____
  PF_CCC_C0_0/PF_CCC_C0_0/pll inst 0
  REF CLK 0 ibuf/U IOIN
The following IRS nets are not constrained by any routing region:
_____
  block4 0 TX
  block1 0 TX
Analyzing floorplan ...
  block4 0 and block2 0 : Minimal floorplan separation = 9 clusters.
     block4 0 at cluster (144,62)
     block20 at cluster (144,52)
  block4 0 and block2 0 : Minimal placement separation = 21 clusters.
      (2148,156) containing cell block4 0/BUFD 1/U0
      (2148,225) containing cell block2 0/BUFD 0/U0
  block4 0 and block3 0 : Minimal floorplan separation = 11 clusters.
     block4 0 at cluster (99,27)
     block3 0 at cluster (87,27)
  block4 0 and block3 0 : Minimal placement separation = 11 clusters.
      (1211,82) containing cell block4 0/CoreGPIO C4 0/CoreGPIO C4 0/inData s2[6]
      (1057,81) containing cell block3_0/APB_dp_fp_1/U0/i_post_norm_mul/
s shl2 RNIS34841[4]
  block4 0 and block1 0 : Minimal floorplan separation = 11 clusters.
     block4 0 at cluster (99,64)
     block1 0 at cluster (99,52)
  block4 0 and block1 0 : Minimal placement separation = 13 clusters.
      (1368,156) containing cell block4 0/BUFD 0/U0
      (1368,201) containing cell block1 0/BUFD 0/U0
  block4 0 and pf smip 0 : Minimal floorplan separation = 37 clusters.
     block4 0 at cluster (99,0)
```

pf smip 0 at cluster (61,0) block4 0 and pf smip 0 : Minimal placement separation = 38 clusters. (1219,2) containing cell block4\_0/block4\_IO\_0/OUTBUF\_31/U\_IOTRI (746,2) containing cell pf smip 0/PF IO C1 0/PF IO C1 0/I IOD 0 block4 0 and 'others' : Minimal floorplan separation = overlapping. block4 0 at cluster (99,0) 'others' at cluster (99,0) block4 0 and 'others' : Minimal placement separation = 0 clusters. (1219,2) containing cell block4 0/block4 IO 0/OUTBUF 31/U IOTRI (1202,2) containing cell RESETN ibuf/U IOIN block2\_0 and block3\_0 : Minimal floorplan separation = diagonal. block2\_0 and block3\_0 : Minimal placement separation = diagonal. block2 0 and block1 0 : Minimal floorplan separation = 9 clusters. block2 0 at cluster (144,93)block1 0 at cluster (134,93) block2\_0 and block1\_0 : Minimal placement separation = 9 clusters. (1743,282) containing cell block2 0/BUFD 53/U0 (1620,282) containing cell block1\_0/BUFD\_87/U0 block2\_0 and pf\_smip\_0 : Minimal floorplan separation = diagonal. block2 0 and pf smip 0 : Minimal placement separation = diagonal. block2 0 and 'others' : Minimal floorplan separation = 9 clusters. block2 0 at cluster (144,62) 'others' at cluster (144,52) block2 0 and 'others' : Minimal placement separation = diagonal. block3 0 and block1 0 : Minimal floorplan separation = 10 clusters. block3 0 at cluster (38, 64)block1 0 at cluster (38,53) block3\_0 and block1\_0 : Minimal placement separation = 22 clusters. (842,124) containing cell block3\_0/CoreGPIO\_C2\_0/CoreGPIO\_C2\_0/dataOut[7] (842,196) containing cell block1\_0/CoreGPIO\_C0\_0/CoreGPIO\_C0\_0/inData\_s1[7] block3\_0 and pf\_smip\_0 : Minimal floorplan separation = 4 clusters. block3 0 at cluster (66,0) pf smip 0 at cluster (61,0) block $\overline{3}$  0 and pf smip 0 : Minimal placement separation = 4 clusters. (811,2) containing cell block3 0/Block3 IO 0/INBUF 17/U IOIN (746,2) containing cell pf smip 0/PF IO C1 0/PF IO C1 0/I IOD 0 block3 0 and 'others' : Minimal floorplan separation = 11 clusters. block3 0 at cluster (99,0) 'others' at cluster (87,0) block3 0 and 'others' : Minimal placement separation = 15 clusters. (1010,2) containing cell block3\_0/Block3\_IO\_0/INBUF\_19/U\_IOIN (1202,2) containing cell RESETN ibuf/U IOIN block1 0 and pf smip 0 : Minimal floorplan separation = 60 clusters. block1 0 at cluster (38,64) pf\_smip\_0 at cluster (38,3)  $block\overline{1}$  0 and pf smip 0 : Minimal placement separation = diagonal. block1 0 and 'others' : Minimal floorplan separation = 11 clusters. block1 0 at cluster (99,64) 'others' at cluster (99,52) block1\_0 and 'others' : Minimal placement separation = 66 clusters. (1204,204) containing cell block1 0/MIV RV32IMC C0 0/MIV RV32IMC C0 0/ u\_opsrv\_0/u\_core\_0/u\_lsu\_0/un1\_lsu\_expipe\_req\_op\_2 (1202,2) containing cell RESETN ibuf/U IOIN pf\_smip\_0 and 'others' : Minimal floorplan separation = 37 clusters. pf\_smip\_0 at cluster (61,0) 'others' at cluster (99,0) pf smip 0 and 'others' : Minimal placement separation = 37 clusters.

(746,2) containing cell pf\_smip\_0/PF\_IO\_C1\_0/PF\_IO\_C1\_0/I\_IOD\_0 (1202,2) containing cell RESETN\_ibuf/U\_IOIN

Checking internal nets for block block4 0 ... \_\_\_\_\_ Checking IRS nets for block block4\_0 ... — Propagating IRS nets outgoing from block4 0 to block2 0 \_\_\_\_\_ Propagating IRS nets outgoing from block4 0 to block1 0 \_\_\_\_\_\_ \_\_\_\_\_ Checking internal nets for block block2 0 ... \_\_\_\_\_ Checking IRS nets for block block2 0 ... ------Propagating IRS nets outgoing from block2\_0 to block1\_0 Checking internal nets for block block3 0 ... \_\_\_\_\_ Checking IRS nets for block block3 0 ... \_\_\_\_\_ Propagating IRS nets outgoing from block3 0 to block4 0 \_\_\_\_\_\_ Propagating IRS nets outgoing from block3 0 to block1 0 === ====== \_\_\_\_\_ Checking internal nets for block block1\_0 ... \_\_\_\_\_ Checking IRS nets for block block1 0 ... \_\_\_\_\_ Propagating IRS nets outgoing from block1 0 to block4 0 \_\_\_\_\_ Propagating IRS nets outgoing from block1 0 to block2 0 \_\_\_\_\_\_ Propagating IRS nets outgoing from block1\_0 to block3\_0 \_\_\_\_ \_\_\_\_\_ -----Checking internal nets for block pf smip 0 ... \_\_\_\_\_ Checking IRS nets for block pf\_smip\_0 ... \_\_\_\_\_ \_\_\_\_\_ Design has met 2 switches separation requirement MSVT Check succeeded. Number of errors: 0

# 3. Revision History

| Revision | Date    | Description      |
|----------|---------|------------------|
| A        | 04/2021 | Initial Revision |

# 4. Microchip FPGA Technical Support

Microchip FPGA Products Group backs its products with various support services, including Customer Service, Customer Technical Support Center, a website, and worldwide sales offices. This section provides information about contacting Microchip FPGA Products Group and using these support services.

### 4.1 Customer Service

Contact Customer Service for non-technical product support, such as product pricing, product upgrades, update information, order status, and authorization.

- From North America, call 800.262.1060
- From the rest of the world, call 650.318.4460
- Fax, from anywhere in the world, **650.318.8044**

### 4.2 Customer Technical Support

Microchip FPGA Products Group staffs its Customer Technical Support Center with highly skilled engineers who can help answer your hardware, software, and design questions about Microchip FPGA Products. The Customer Technical Support Center spends a great deal of time creating application notes, answers to common design cycle questions, documentation of known issues, and various FAQs. So, before you contact us, please visit our online resources. It is very likely we have already answered your questions.

You can communicate your technical questions through our Web portal and receive answers back by email, fax, or phone. Also, if you have design problems, you can upload your design files to receive assistance. We constantly monitor the cases created from the web portal throughout the day. When sending your request to us, please be sure to include your full name, company name, and your contact information for efficient processing of your request.

Technical support can be reached at soc.microsemi.com/Portal/Default.aspx.

For technical support on RH and RT FPGAs that are regulated by International Traffic in Arms Regulations (ITAR), log in at soc.microsemi.com/Portal/Default.aspx, go to the **My Cases** tab, and select **Yes** in the ITAR drop-down list when creating a new case. For a complete list of ITAR-regulated Microchip FPGAs, visit the ITAR web page.

You can track technical cases online by going to My Cases.

### 4.3 Website

You can browse a variety of technical and non-technical information on the Microchip FPGA Products Group home page, at www.microsemi.com/soc.

### 4.4 Outside the U.S.

Customers needing assistance outside the US time zones can either contact technical support at (https://soc.microsemi.com/Portal/Default.aspx) or contact a local sales office.

Visit About Us for sales office listings and corporate contacts.

# The Microchip Website

Microchip provides online support via our website at www.microchip.com/. This website is used to make files and information easily available to customers. Some of the content available includes:

- **Product Support** Data sheets and errata, application notes and sample programs, design resources, user's guides and hardware support documents, latest software releases and archived software
- **General Technical Support** Frequently Asked Questions (FAQs), technical support requests, online discussion groups, Microchip design partner program member listing
- **Business of Microchip** Product selector and ordering guides, latest Microchip press releases, listing of seminars and events, listings of Microchip sales offices, distributors and factory representatives

# Product Change Notification Service

Microchip's product change notification service helps keep customers current on Microchip products. Subscribers will receive email notification whenever there are changes, updates, revisions or errata related to a specified product family or development tool of interest.

To register, go to www.microchip.com/pcn and follow the registration instructions.

# Customer Support

Users of Microchip products can receive assistance through several channels:

- Distributor or Representative
- Local Sales Office
- Embedded Solutions Engineer (ESE)
- · Technical Support

Customers should contact their distributor, representative or ESE for support. Local sales offices are also available to help customers. A listing of sales offices and locations is included in this document.

Technical support is available through the website at: www.microchip.com/support

# **Microchip Devices Code Protection Feature**

Note the following details of the code protection feature on Microchip devices:

- Microchip products meet the specifications contained in their particular Microchip Data Sheet.
- Microchip believes that its family of products is secure when used in the intended manner and under normal conditions.
- There are dishonest and possibly illegal methods being used in attempts to breach the code protection features of the Microchip devices. We believe that these methods require using the Microchip products in a manner outside the operating specifications contained in Microchip's Data Sheets. Attempts to breach these code protection features, most likely, cannot be accomplished without violating Microchip's intellectual property rights.
- · Microchip is willing to work with any customer who is concerned about the integrity of its code.
- Neither Microchip nor any other semiconductor manufacturer can guarantee the security of its code. Code
  protection does not mean that we are guaranteeing the product is "unbreakable." Code protection is constantly
  evolving. We at Microchip are committed to continuously improving the code protection features of our products.
  Attempts to break Microchip's code protection feature may be a violation of the Digital Millennium Copyright Act.
  If such acts allow unauthorized access to your software or other copyrighted work, you may have a right to sue
  for relief under that Act.

# Legal Notice

Information contained in this publication is provided for the sole purpose of designing with and using Microchip products. Information regarding device applications and the like is provided only for your convenience and may be superseded by updates. It is your responsibility to ensure that your application meets with your specifications.

THIS INFORMATION IS PROVIDED BY MICROCHIP "AS IS". MICROCHIP MAKES NO REPRESENTATIONS OR WARRANTIES OF ANY KIND WHETHER EXPRESS OR IMPLIED, WRITTEN OR ORAL, STATUTORY OR OTHERWISE, RELATED TO THE INFORMATION INCLUDING BUT NOT LIMITED TO ANY IMPLIED WARRANTIES OF NON-INFRINGEMENT, MERCHANTABILITY, AND FITNESS FOR A PARTICULAR PURPOSE OR WARRANTIES RELATED TO ITS CONDITION, QUALITY, OR PERFORMANCE.

IN NO EVENT WILL MICROCHIP BE LIABLE FOR ANY INDIRECT, SPECIAL, PUNITIVE, INCIDENTAL OR CONSEQUENTIAL LOSS, DAMAGE, COST OR EXPENSE OF ANY KIND WHATSOEVER RELATED TO THE INFORMATION OR ITS USE, HOWEVER CAUSED, EVEN IF MICROCHIP HAS BEEN ADVISED OF THE POSSIBILITY OR THE DAMAGES ARE FORESEEABLE. TO THE FULLEST EXTENT ALLOWED BY LAW, MICROCHIP'S TOTAL LIABILITY ON ALL CLAIMS IN ANY WAY RELATED TO THE INFORMATION OR ITS USE WILL NOT EXCEED THE AMOUNT OF FEES, IF ANY, THAT YOU HAVE PAID DIRECTLY TO MICROCHIP FOR THE INFORMATION. Use of Microchip devices in life support and/or safety applications is entirely at the buyer's risk, and the buyer agrees to defend, indemnify and hold harmless Microchip from any and all damages, claims, suits, or expenses resulting from such use. No licenses are conveyed, implicitly or otherwise, under any Microchip intellectual property rights unless otherwise stated.

# Trademarks

The Microchip name and logo, the Microchip logo, Adaptec, AnyRate, AVR, AVR logo, AVR Freaks, BesTime, BitCloud, chipKIT, chipKIT logo, CryptoMemory, CryptoRF, dsPIC, FlashFlex, flexPWR, HELDO, IGLOO, JukeBlox, KeeLoq, Kleer, LANCheck, LinkMD, maXStylus, maXTouch, MediaLB, megaAVR, Microsemi, Microsemi logo, MOST, MOST logo, MPLAB, OptoLyzer, PackeTime, PIC, picoPower, PICSTART, PIC32 logo, PolarFire, Prochip Designer, QTouch, SAM-BA, SenGenuity, SpyNIC, SST, SST Logo, SuperFlash, Symmetricom, SyncServer, Tachyon, TimeSource, tinyAVR, UNI/O, Vectron, and XMEGA are registered trademarks of Microchip Technology Incorporated in the U.S.A. and other countries.

AgileSwitch, APT, ClockWorks, The Embedded Control Solutions Company, EtherSynch, FlashTec, Hyper Speed Control, HyperLight Load, IntelliMOS, Libero, motorBench, mTouch, Powermite 3, Precision Edge, ProASIC, ProASIC Plus, ProASIC Plus logo, Quiet-Wire, SmartFusion, SyncWorld, Temux, TimeCesium, TimeHub, TimePictra, TimeProvider, WinPath, and ZL are registered trademarks of Microchip Technology Incorporated in the U.S.A.

Adjacent Key Suppression, AKS, Analog-for-the-Digital Age, Any Capacitor, AnyIn, AnyOut, Augmented Switching, BlueSky, BodyCom, CodeGuard, CryptoAuthentication, CryptoAutomotive, CryptoCompanion, CryptoController, dsPICDEM, dsPICDEM.net, Dynamic Average Matching, DAM, ECAN, Espresso T1S, EtherGREEN, IdealBridge, In-Circuit Serial Programming, ICSP, INICnet, Intelligent Paralleling, Inter-Chip Connectivity, JitterBlocker, maxCrypto, maxView, memBrain, Mindi, MiWi, MPASM, MPF, MPLAB Certified logo, MPLIB, MPLINK, MultiTRAK, NetDetach, Omniscient Code Generation, PICDEM, PICDEM.net, PICkit, PICtail, PowerSmart, PureSilicon, QMatrix, REAL ICE, Ripple Blocker, RTAX, RTG4, SAM-ICE, Serial Quad I/O, simpleMAP, SimpliPHY, SmartBuffer, SMART-I.S., storClad, SQI, SuperSwitcher, SuperSwitcher II, Switchtec, SynchroPHY, Total Endurance, TSHARC, USBCheck, VariSense, VectorBlox, VeriPHY, ViewSpan, WiperLock, XpressConnect, and ZENA are trademarks of Microchip Technology Incorporated in the U.S.A. and other countries.

SQTP is a service mark of Microchip Technology Incorporated in the U.S.A.

The Adaptec logo, Frequency on Demand, Silicon Storage Technology, and Symmcom are registered trademarks of Microchip Technology Inc. in other countries.

GestIC is a registered trademark of Microchip Technology Germany II GmbH & Co. KG, a subsidiary of Microchip Technology Inc., in other countries.

All other trademarks mentioned herein are property of their respective companies.

<sup>©</sup> 2021, Microchip Technology Incorporated, Printed in the U.S.A., All Rights Reserved.

ISBN: 978-1-5224-7566-8

# Quality Management System

For information regarding Microchip's Quality Management Systems, please visit www.microchip.com/quality.



# **Worldwide Sales and Service**

| AMERICAS                        | ASIA/PACIFIC          | ASIA/PACIFIC            | EUROPE                              |
|---------------------------------|-----------------------|-------------------------|-------------------------------------|
| Corporate Office                | Australia - Sydney    | India - Bangalore       | Austria - Wels                      |
| 2355 West Chandler Blvd.        | Tel: 61-2-9868-6733   | Tel: 91-80-3090-4444    | Tel: 43-7242-2244-39                |
| Chandler, AZ 85224-6199         | China - Beiiing       | India - New Delhi       | Fax: 43-7242-2244-393               |
| Tel: 480-792-7200               | Tel: 86-10-8569-7000  | Tel: 91-11-4160-8631    | Denmark - Copenhagen                |
| Fax: 480-792-7277               | China - Chengdu       | India - Pune            | Tel: 45-4485-5910                   |
| Technical Support:              | Tel: 86-28-8665-5511  | Tel: 91-20-4121-0141    | Fax: 45-4485-2829                   |
| www.microchip.com/support       | China - Chongging     | Japan - Osaka           | Finland - Espoo                     |
| Web Address:                    | Tel: 86-23-8980-9588  | Tel: 81-6-6152-7160     | Tel: 358-9-4520-820                 |
| www.microchip.com               | China - Dongguan      | Japan - Tokvo           | France - Paris                      |
| Atlanta                         | Tel: 86-769-8702-9880 | Tel: 81-3-6880- 3770    | Tel: 33-1-69-53-63-20               |
| Duluth, GA                      | China - Guangzhou     | Korea - Daegu           | Fax: 33-1-69-30-90-79               |
| Tel: 678-957-9614               | Tel: 86-20-8755-8029  | Tel: 82-53-744-4301     | Germany - Garching                  |
| Fax: 678-957-1455               | China - Hangzhou      | Korea - Seoul           | Tel: 49-8931-9700                   |
| Austin. TX                      | Tel: 86-571-8792-8115 | Tel: 82-2-554-7200      | Germany - Haan                      |
| Tel: 512-257-3370               | China - Hong Kong SAR | Malaysia - Kuala Lumpur | Tel: 49-2129-3766400                |
| Boston                          | Tel: 852-2943-5100    | Tel: 60-3-7651-7906     | Germany - Heilbronn                 |
| Westborough, MA                 | China - Naniing       | Malavsia - Penang       | Tel: 49-7131-72400                  |
| Tel: 774-760-0087               | Tel: 86-25-8473-2460  | Tel: 60-4-227-8870      | Germany - Karlsruhe                 |
| Eax: 774-760-0088               | China - Qingdao       | Philippines - Manila    | Tel: 49-721-625370                  |
| Chicago                         | Tel: 86-532-8502-7355 | Tel: 63-2-631-9065      | Germany - Munich                    |
|                                 | China - Shanghai      | Singanore               | Tel: 40-80-627-144-0                |
| Tel: 630-285-0071               | Tel: 86-21-3326-8000  | Tel: 65-6334-8870       | Fax: 40-80-627-144-0                |
| Fax: 630-285-0075               | China - Shenyang      | Taiwan - Hsin Chu       | Germany - Rosenheim                 |
| Dallas                          | Tel: 86-24-2334-2829  | Tel: 886-3-577-8366     | Tel: 10-8031-351-560                |
| Addison TY                      | China Shonzhon        | Taiwan Kaobsiung        |                                     |
| Tal: 072 818 7423               | Tol: 86 755 8864 2200 | Tal: 886 7 213 7830     | Tol: 072 0 744 7705                 |
| Fex: 072 919 2024               | China Suzbou          | Teiwan Teinei           | Itely Miler                         |
| Detroit                         | Tol: 86 186 6233 1526 | Tal: 886 2 2508 8600    | Tal: 30 0331 7/2611                 |
| Nevi MI                         | China Wuhan           | Theiland Bangkok        | Eax: 30 0331 466781                 |
| Tol: 248 848 4000               | Tal: 96 27 5090 5200  |                         | Italy Badaya                        |
| Heuston TY                      | China Vian            | Vietnem He Chi Minh     |                                     |
| Tol: 281 804 5083               |                       |                         | Nothorlands Drupon                  |
| Indianapolis                    | China Viamon          | Tel. 04-20-3440-2100    | Tol: 31 416 600300                  |
| Noblosvillo, IN                 | Tol: 86 502 2388138   |                         | Eax: 31 416 600340                  |
|                                 | China Zhubai          |                         | Nervey Trendheim                    |
| Fox: 217 772 5452               |                       |                         | Tal: 47 72994299                    |
| 1 al. 311-113-3433              | 161. 00-700-3210040   |                         | Boland Warsaw                       |
|                                 |                       |                         | Tal. 49.00.0205727                  |
| Los Aligeles                    |                       |                         | Pomania Rucharaat                   |
|                                 |                       |                         |                                     |
| 101. 343-402-3023               |                       |                         | 101.40-21-407-07-00<br>Spain Madrid |
| Fax. 343-402-3000               |                       |                         | Spail - Wauriu                      |
| 101. 901-213-1000<br>Releigh NC |                       |                         | Eav: 24.01.709.02.04                |
| <b>Railey II, NG</b>            |                       |                         | Fax. 34-91-100-00-91                |
|                                 |                       |                         |                                     |
| New TOFK, NT                    |                       |                         | 1et: 40-31-704-00-40                |
| Tel: 031-435-0000               |                       |                         |                                     |
| San Jose, CA                    |                       |                         | 1ei: 46-8-5090-4654                 |
|                                 |                       |                         |                                     |
| Iei: 408-436-4270               |                       |                         | Iei: 44-118-921-5800                |
| Canada - Toronto                |                       |                         | ⊢ax: 44-118-921-5820                |
| Tel: 905-695-1980               |                       |                         |                                     |
| ⊦ax: 905-695-2078               |                       |                         |                                     |