5.3 Getting Started

The following sections describe how to start using Libero SoC.

5.3.1 Starting Libero SoC

When you start Libero SoC, the Welcome screen appears. In the left pane, links under Projects allow you to create a new Libero SoC project or open an existing one.

5.3.2 Design Report

The Design Report tab lists the reports available for your design. Reports are added automatically as you move through design development. For example, timing reports are added when you run timing analysis on your design. Reports are updated each time you run a timing analysis.

To display the Design Report tab, click Design > Reports.

If a report is not listed in the tab, you might have to create it manually. For example, you must start Verify Power manually before its report is available.

The following table lists the reports you can view in the Design Report tab.
Table 5-8. Reports in the Design Report Tab
CategoryReport
Project Summary
Programming
Export

5.3.3 Creating a New Project

To simplify project creation, Libero SoC provides a wizard that takes you through the process of creating a new Libero SoC project.

To start a new Libero SoC project, click Project > New. The following table summarizes the screens in the wizard.
Table 5-9. Screens in the New Project Wizard
ScreenDescription
Project DetailsSpecify the name and location of your project, device family and parts, I/O standards, and HDL source files and design constraint files.
Device SelectionSelect a device for your project. After you select a device, or in any wizard screen that follows, you can click the Finish button to create the project and exit the wizard.
SmartFusion 2 and IGLOO 2: Device SettingsSpecify the device I/O technology and reserve pins for probes.
Design TemplateThis dialog box might not be available if there are no design templates for the chosen technology.
Add HDL SourcesAdd HDL design source files to your Libero SoC project.
Add ConstraintsAdd timing and physical constraints files to your Libero SoC project.

5.3.3.1 New Project Creation Wizard: Project Details

Project Details is the first screen that appears in the New Project Creation Wizard.

Figure 5-14. Libero SoC New Project Creation Wizard - Project Details

The following table describes the fields in the Project Details screen. After you complete the fields, click Next to go to Device Selection.

Table 5-10. Fields in the Libero SoC New Project Creation Wizard - Project Details
FieldDescription
Project NameIdentifies your project name. Do not use spaces or reserved Verilog or VHDL keywords.
Project LocationIdentifies your project location on disk.
DescriptionGeneral information about your design and project.
Preferred HDL TypeSets your HDL type to one of the following:
  • Verilog
  • VHDL

Libero-generated files (SmartDesigns, SmartGen cores, and so on) are created in the HDL type you specify. Libero SoC supports mixed HDL designs.

Enable Block CreationAllows you to build blocks for your design. These blocks can be assembled in other designs, with partial layout, and been optimized for timing and power performance for a specific Microchip device. Once optimized, you can use the same blocks in multiple designs.

5.3.3.2 New Project Creation Wizard: Device Selection

The Device Selection screen is where you can specify the Microchip device for your project. Use the filters and drop-down lists to refine your search for the right part to use for your design.

This screen contains a table of all the parts, with associated FPGA resource details generated based on a value you enter in a filter. When you select a filter value:

  • The parts table is updated to reflect the result of the new filtered value.
  • All other filters are updated, and only relevant items are available in the filter drop-down lists. For example, if you select PolarFire in the Family filter, the parts table includes only PolarFire parts, and the Die filter includes only PolarFire dies in the Die drop-down list.
    Figure 5-15. Libero SoC New Project Creation Wizard - Device Selection
    The following table describes the fields in the Device Selection screen. After you complete the fields, click Next to go to the Device Settings screen or click Finish to create the new project by accepting all of the remaining default settings.
    Table 5-11 5-16 5-17. Fields in the Libero SoC New Project Creation Wizard - Device Selection
    FieldDescription
    FamilyMicrochip device family. Only devices that belong to the family appear in the parts table.
    Die/Package/SpeedDevice die, package, and speed grade. Use the Die/Package/Speed filters to view only the selections that interest you. The Die/Package/Speed grades available for selection depend on the level of Libero SoC license you have (Evaluation, Silver, Gold, or Platinum). For more information, see the Libero SoC Licensing web page.
    Core VoltageCore voltage for your device. Two numbers separated by a “~” are shown if a wide range voltage is supported. For example, 1.2~1.5 means that the device core voltage can vary between 1.2 and 1.5 volts.
    Range (PolarFire)Voltage and temperature range a device might encounter in your application. Tools such as SmartTime, SmartPower, timing-driven layout, power-driven layout, the timing report, and back-annotated simulation are affected by operating conditions.

    Select the appropriate option for your device. Supported operating condition ranges vary according to your device and package. To find your recommended temperature range, see your device datasheet. Choices are:

    • All: All ranges
    • EXT: Extended
    • IND: Industrial
    • MIL: Military
    Range (SmartFusion 2, IGLOO 2, and RTG4)Temperature ranges a device can encounter in your application. Junction temperature is a function of ambient temperature, air flow, and power consumption. Tools such as SmartTime, SmartPower, timing-driven layout, power-driven layout, the timing report, and back-annotated simulation are affected by operating conditions. Choices are:
    • ALL: All ranges
    • EXT: Extended
    • COM: Commercial (not available for RTG4 devices)
    • IND: Industrial
    • TGrade1: Automotive (not available for RTG4 devices)
    • TGrade2: Automotive (not available for RTG4 devices)
    • MIL: Military

    Supported operating condition ranges vary according to your device and package. Refer to the device datasheet to find your recommended temperature range. The temperature range corresponding to the value selected from the pick list can also be found by checking Project Settings > Analysis operating conditions.

    Reset FiltersResets all filters to the default ALL option except Family.
    Search PartsCharacter-by-character search for parts. Search results appear in the parts table.

5.3.3.3 New Project Creation Wizard: Device Settings

Device settings vary by device family.

5.3.3.3.1 PolarFire Device Settings

For PolarFire, the Device Settings page is where you can set the core voltage, default I/O technology, and enable reserve pins for probes.
Figure 5-16 5-17. New Project Creation Wizard – Device Settings Page (PolarFire)
The following table describes the fields in the Device Settings screen. After you complete the fields, click Next to go to the next screen or click Finish to create the new project by accepting all of the remaining default settings.
Table 5-12 5-13. Fields in the Libero SoC New Project Creation Wizard - Device Settings (PolarFire)
FieldDescription
Core VoltageSet the core voltage for your device.
Default I/O technologySet all your I/Os to a default value. You can change the values for individual I/Os in the I/O Attribute Editor. The I/O Technology available is family-dependent.
Reserve pins for probesReserve your pins for probing if you intend to debug using SmartDebug. If unchecked, the I/Os can be used as General Purpose I/Os.

5.3.3.3.2 SmartFusion 2 and IGLOO 2 Device Settings

For SmartFusion 2 and IGLOO 2, the Device Settings page is where you can set the device I/O technology, enable reserve pins for probes, set power supplies, and enable system controller suspended mode.
Figure 5-16 5-17. New Project Creation Wizard – Device Settings Page (SmartFusion 2 and IGLOO 2)
The following table describes the fields in the Device Settings screen for SmartFusion 2 and IGLOO 2. After you complete the fields, click Next to go to the next screen or click Finish to create the new project by accepting all of the remaining default settings.
Table 5-12 5-13. Fields in the Libero SoC New Project Creation Wizard - Device Settings (SmartFusion 2 and IGLOO 2)
FieldDescription
Default I/O technologySet all your I/Os to a default value. You can change the values for individual I/Os in the I/O Attribute Editor. The I/O Technology available is family-dependent.
Reserve pins for probesReserve your pins for probing if you intend to debug using SmartDebug. If unchecked, the I/Os can be used as General Purpose I/Os.
PLL supply voltage (V) Set the voltage for the power supply that you plan to connect to all the PLLs in your design, such as MDDR, FDDR, SERDES, and FCCC.
VDD Supply Ramp TimePower-up management circuitry is designed into every SmartFusion 2 and IGLOO 2 FPGA. These circuits ensure easy transition from the powered-off state to the powered-up state of the device. The SmartFusion 2, IGLOO 2, and RTG4 system controller is responsible for systematic power-on reset whenever the device is powered on or reset. All I/Os are held in a high-impedance state by the system controller until all power supplies are at their required levels and the system controller has completed the reset sequence.

The power-on reset circuitry in SmartFusion 2 and IGLOO 2 devices requires the VDD and VPP supplies to ramp monotonically from 0 V to the minimum recommended operating voltage within a predefined time. There is no sequencing requirement on VDD and VPP. Four ramp rate options are available during design generation: 50 μs, 1 ms, 10 ms, and 100 ms. Each selection represents the maximum ramp rate to apply to VDD and VPP.

Device information (such as Die, Package, and Speed) can be modified later in the Project Settings dialog box.

System controller suspended modeSuspends operation of the System Controller. Checking this box places the System Controller in a reset state when the device is powered up. This suspends all system services from being performed. For a list of system services for SmartFusion 2 and IGLOO 2, see the System Controller User's Guide for your device.

5.3.3.3.3 RTG4 Device Settings

For RTG4, the Device Settings page is where you can set the default I/O technology and activate reserve pins for probes and enable single event transient mitigation.
Figure 5-18. New Project Creation Wizard – Device Settings Page (RTG4)
The following table describes the fields in the Device Settings screen for RTG4. After you complete the fields, click Next to go to the next screen or click Finish to create the new project by accepting all of the remaining default settings.
Table 5-14. Fields in the Libero SoC New Project Creation Wizard - Device Settings (RTG4)
FieldDescription
Default I/O technologySet all your I/Os to a default value. You can change the values for individual I/Os in the I/O Attribute Editor. The I/O Technology available is family-dependent.
Reserve pins for probesReserve your pins for probing if you intend to debug using SmartDebug. If unchecked, the I/Os can be used as General Purpose I/Os.
Enable Single Event Transient mitigationControls the mitigation of Single Event Transient (SET) in the FPGA fabric. When this box is checked, SET filters are turned on globally to help mitigate radiation-induced transients. By default, this box is not checked.

5.3.3.4 New Project Creation Wizard: Design Template (SmartFusion 2 and IGLOO 2)

The Design Template page is where you can use Libero SoC’s built-in template to automate your SmartFusion 2 or IGLOO 2 design process. The template uses the System Builder tool for system-level design or the Microcontroller Subsystem (MSS) in your design. Both will speed up the design process.
Figure 5-19. New Project Creation Wizard – Design Template Page
???

The following table describes the fields in the Device Template screen. After you complete the fields, click Next to go to the Add HDL Sources page or click Finish to create the new project by accepting all of the remaining default settings.

Table 5-15. Fields in the Libero SoC New Project Creation Wizard - Device Template
FieldDescription
NoneSelect if you do not want to use a design template.
Create a System Builder based designUse System Builder to generate your top-level design.
Create a Microcontroller (MSS) based designInstantiate a Microcontroller (MSS) in your design. The version of the MSS cores available in your vault is displayed. Select the version you desire.
Use Standalone Initialization for MDDR/FDDR/SERDES PeripheralsCheck if you want to create your own peripheral initialization logic in SmartDesign for each design peripheral (MDDR/FDDR/SERDES). When checked, System Builder does not build the peripherals initialization logic for you. Stand-alone initialization is useful if you want to make the initialization logic of each peripheral separate from and independent of each other.
Instantiate System Builder/MSS component in a SmartDesign on creationUncheck if you are using this project to create System Builder or MSS components and do not plan on using them in a SmartDesign based design. This is especially useful for design flows where the System Builder or MSS components are stitched in a design using HDL.

5.3.3.5 New Project Creation Wizard: Add HDL Source Files

The Add HDL Source Files screen is where you can add HDL design source files to your Libero SoC project. The HDL source files can be imported or linked to the Libero SoC project.
Figure 5-20. Libero SoC New Project Creation Wizard - Add HDL Source Files
The following table describes the elements in the Add HDL Source Files screen. After you complete the fields, click Next to go to the Add Constraints screen or click Finish to create the new project by accepting all of the remaining default settings.
Table 5-11 5-16 5-17. Elements in the Libero SoC New Project Creation Wizard - Add HDL Source Files
ElementDescription
Import File buttonImports an HDL source file. When the dialog box appears, go to the location where the HDL source resides, select the HDL file, and click Open. The HDL file is copied to the <prj_folder>/hdl folder in your Libero project.
Link File buttonAllows you to continue with an absolute or relative path for linked files. When the Link files dialog box appears (see the following figure), go to the location where the HDL source resides, select the HDL file, and click Open.

Create links relative to the path set in Environment variable

Available when you click the Link File button. The HDL file is linked to the Libero project. Check this check box if the HDL source file is located and maintained outside the Libero project. This option requires you to specify an environment variable that has a relative path set to it. Links are created relative to the path set in the environment variable.

Note: If you select relative path and provide an environment variable for the relative path, you cannot switch to absolute path. After the environment variable is set, this option becomes read-only in all other link files dialog boxes.
Delete buttonDeletes the selected HDL source file from your project. If the HDL source file is linked to the Libero project, the link will be removed.
Figure 5-21. New Project Creation Wizard – Link Files Dialog Box

5.3.3.6 New Project Creation Wizard: Add Constraints

The Add Constraints screen is where you add timing constraints and physical constraints files to your Libero SoC project. The constraints file can be imported or linked to the Libero SoC project.
Figure 5-22. Libero SoC New Project Creation Wizard – Add Constraints
The following table describes the elements in the Add Constraints screen.
Table 5-11 5-16 5-17. Elements in the Libero SoC New Project Creation Wizard - Add Constraints
ElementDescription
Import File buttonGo to the location where the constraints file resides. Select the constraints file and click Open. The constraints file is copied to the <prj_folder>/constraint folder in your Libero project.
Link File buttonClick this button if the constraint file is located and maintained outside the Libero project. When the Link files dialog box appears (see the following figure), specify an absolute path or choose a relative path for linked files. Go to the location where the constraints file resides. Select the constraints file and click Open. The constraints file is linked to the Libero project.
Create links relative to the path set in Environment variable

Available when you click the Link File button. The constraints file is linked to the Libero project. Check this check box if the constraints file is located and maintained outside the Libero project. This option requires you to specify an environment variable that has a relative path set to it. Links are created relative to the path set in the environment variable.

Note: If you select relative path and provide an environment variable for the relative path, you cannot switch to absolute path. After the environment variable is set, this option becomes read-only in all other link files dialog boxes.
Delete buttonDeletes the selected constraints file from your project. If the constraints file is linked to the Libero project, the link will be removed.
Figure 5-23. New Project Creation Wizard – Link Files Dialog Box
After you complete the fields, click Finish to complete new project creation. The Reports tab shows the result of your new project.
Figure 5-24. Reports Tab

5.3.4 Opening a Project

To open a project:

  1. From the File menu, choose Open Project.
  2. Select the project file you want to open. The file ends in the extension .prjx.
  3. Click Open.
Note: Opening a project created using a relative path for linked files displays the following error message if the environment variable does not exist or the path set in the environment variable is empty and cancels opening the project.
Figure 5-25. Error Message
When you open an existing Libero SoC project:
  • A Design Flow window appears on the left side.
  • A log and message window appear at the bottom.
  • Project information windows appear on the right side.
The following figure is an example of a newly created project, with only the top-level Design Flow window steps shown.
Figure 5-26. Sample Design Flow Window

The Design Flow window might appear different for each technology family. However, all flows include some version of the following design steps:

  • Create Design
  • Constraints
  • Implement Design
  • Configure Hardware
  • Program Design
  • Debug Design
  • Handoff Design for Production
  • Handoff Design for Debugging