Start a Project#

Simplicity Studio® 5 (SSv5) supports several different project types, which can be created through File > New. These include:

  • Silicon Labs Project Wizard (creates Project Configurator projects, as described in this section)

  • Solution...

  • Project... (opens the New Project Wizards dialog)

  • Other (combines all of the above selections with other, rarely used options)

Select Files > New > Project to open the New Project Wizards dialog.

New project wizardsNew project wizards

Most notably:

This page focuses on Project Configurator (*.slcp) projects. On this page:

Project Creation#

New Simplicity Studio® 5 (SSv5) projects are created through a sequence of three dialogs:

The three project creation dialogs in sequenceThe three project creation dialogs in sequence

An indicator at the top of the dialog shows you where you are.

the sequence indicator positioned on target SDKthe sequence indicator positioned on target SDK

You can start a project from three different locations in the Launcher Perspective. Where you start determines which of the three dialogs you will land on. Click BACK to move to an earlier dialog, if you need to make a change.

  • From the OVERVIEW tab: Click Create New Project. Starts on the Examples dialog.

  • From the EXAMPLE PROJECTS tab: Use the filters as needed, select a project, and click CREATE. Starts on the Project Configuration dialog.

  • From the file menu: Select New >> Silicon Labs Project Wizard. Starts on the Target, SDK, and Toolchain Selection dialog.

While you are getting started, you can leave the default values in place.

Target, SDK, and Toolchain Selection#

If you have connected or selected a target, all information is pre-populated. Otherwise you can select target parts here. Click NEXT.

Target, SDK, and Toolchain selection dialog, with the default GNU ARM toolchainTarget, SDK, and Toolchain selection dialog, with the default GNU ARM toolchain

Note that if you want to use IAR in SSv5, select it here. If you are developing in the Project Configurator environment, it is difficult to change compilers once the project is created.

Examples#

Use the checkboxes or keywords to find the example of interest, then select it and click NEXT.

New Project examples filtered by Proprietary FlexNew Project examples filtered by Proprietary Flex

Configuration#

Rename your project if you want. The three selections under "With project files" control which sources are copied and which are linked. If a linked source is modified, the changes apply to any other project linking to that source.

  • Link to sources: The project links both to the SDK files and to project files such as app.c.

  • Link SDK and copy project sources (default): Project sources are copied to your workspace. Note that the SDK folder structure is created but if you drill down you will see that all folders are empty.

  • Copy contents: Both project files and the SDK files are copied to your workspace.

Click FINISH.

New project configuration linking to the sdk and copying project sourceNew project configuration linking to the sdk and copying project source

Once you finish project creation, the Simplicity IDE perspective opens. There may be a slight delay for initial configuration. For details on all the features and functions available in this perspective, see About the Simplicity IDE.

simplicity IDE with editor and views numberedsimplicity IDE with editor and views numbered

1 - Editor area (depends on the project).

2 - Project Explorer view: Lists the projects and solutions available in your workspace.

3 - Debug Adapters view: Lists the kits or SEGGER J-Links connected to your computer via USB or detected on a local network.

4 - Developer views: A set of views of use during the development process.

The editor in the Simplicity IDE perspective depends on the project:

  • Project Configurator: Used for all Gecko SDK protocols and tools beginning with Gecko SDK 4.0; Project files end in .slcp.

  • 8-bit Hardware Configurator: Used for 8-bit device applications.

  • AppBuilder: Used for Zigbee EmberZNet and Gecko Bootloader in Gecko SDK 3.2 and lower; Project files end in .isc.

Project Configurator Projects#

As well as introducing Project Configurator projects, this page also introduces

Note: The Memory Editor is a beta implementation of a tool that will primarily be used with solutions.

Project Configurator projects are defined in .slcp (Silicon Labs Configurator project) files. Users can modify the project by adding, removing, and configuring components on the Software Components tab. See Developing with Project Configurator for details.

NOTE: Beginning with Simplicity Studio version 5.3, you can create a project in the Simplicity IDE by importing an .slcp file. See Import and Export for more information.

The project opens, generally either on a README tab containing an example project description, or on an OVERVIEW tab.

Project configurator with overview tab selected.Project configurator with overview tab selected.

The OVERVIEW tab has three cards with information, some with settings that may be changed:

  • Target and Tool Settings, where you can change your development target, SDK, and project generators. Scroll down and click Change Target/SDK/Generators to edit these settings. The Project Generators configuration determines the IDE or build system project files that SSv5 generates as you configure your project. (Note: The compiler / toolchain used by Simplicity IDE is configurable in Project > Build Configurations. The default IDE is configurable in Preferences > Simplicity Studio > Preferred IDE.)

  • Project Details, where you can rename the project, change the project source import mode and, if necessary, force the generation of project and source files (in the autogen folder).

    • Import mode controls which resources are copied and which are linked. If you modify a linked source, your changes apply to any other project linking to that source.

    • Force Generation can be used in rare cases when auto-generation is not triggered, usually because of some change made outside of SSv5 such as editing the .slcp file.

  • Quick Links provides links to the tools commonly used to modify the project or lower-level configurations such as radio or peripheral connections. The links vary based on the SDK and target device.

Project Configurator Overview tab with the three cardsProject Configurator Overview tab with the three cards

To configure the project through the component library, click the SOFTWARE COMPONENTS tab. A number of filters as well as a keyword search are available to help you explore the various component categories. Note that components for all installed SDKs are presented.

Project Configurator with Software Components tab openProject Configurator with Software Components tab open

Expand a component category\subcategory to see individual components. Components installed in the project are checked (1), and can be uninstalled. Configurable components are indicated by a gear symbol (2).

Software Components tab with a checked project and a configurable project in the left panel indicated by numbersSoftware Components tab with a checked project and a configurable project in the left panel indicated by numbers

Click the gear symbol next to the component name or Configure in the configurable component description to open the Component Editor. Here you can change parameters or edit the component source directly.

Component editor open on the Bluetooth Core componentComponent editor open on the Bluetooth Core component

Changes are autosaved in the Component Editor.

Component editor with saved changesComponent editor with saved changes

As you make changes in the Project Configurator, for example installing or uninstalling a component, project output files are autogenerated. Progress is shown in the lower right of the Perspective.

Generation and indexing progress barsGeneration and indexing progress bars

Speed varies depending on your system. Be sure that generation is complete before building the application image.

Build the application image and flash it to your target device as described in Building and Flashing.

A CONFIGURATION TOOLS tab provides an easy way to open a tool when the tool's tab is not already open, as an alternative to the Quick Links card on the general tab. It shows configuration tools relevant to the project type. For example, a Bluetooth Mesh project shows a number of tools, while an OpenThread project might only show the Pin Tool. Click Open on the tool's card to open it in a separate tab.

Project Configurator Configuration tools tabProject Configurator Configuration tools tab

Pin Tool#

The Pin Tool lets you modify the target device's pin use and parameters. As well as opening the Pin Tool through the CONFIGURATION TOOLS tab, you can also double-click the <project>.pintool file in the Project Explorer view.

Pin tool tabPin tool tab

Double-click a Software Component to open the Component Editor and configure that function. Pin Tool does not autosave.

Bluetooth GATT Configurator#

Bluetooth and Bluetooth Mesh projects are also configured with the Bluetooth GATT Configurator.

GATT configurator tabGATT configurator tab

The Bluetooth GATT configurator menu allows you to add and remove services and characteristics.

GATT configurator menu with numbered controlsGATT configurator menu with numbered controls

  1. Add an item.

  2. Duplicate the selected item.

  3. Move the selected item up.

  4. Move the selected item down.

  5. Import a Bluetooth GATT database.

  6. Add Predefined.

  7. Delete the selected item.

To add a custom service, click Profile (Custom BLE GATT), and then click Add (1). To add a custom characteristic, select a service and then click Add (1). To add a predefined service/characteristic click Add Predefined (6).

Bluetooth Mesh Configurator#

Bluetooth Mesh project Device Composition Data is configured through the Bluetooth Mesh Configurator. The Device Composition Data is presented in three areas: device information, elements, and models.

Mesh configurator tabMesh configurator tab

Device information is determined by the company selected in the first field.

Each node has at minimum a primary element. To add more elements click the green + symbol in the bottom right.

The Bluetooth Mesh Configurator has editors for both SIG-adopted models and vendor models. SIG-adopted model components are provided but cannot be edited. You can, however, delete those models, and then add models to meet your needs. To delete a model, select it and click the red X symbol. To add a SIG-adopted model, drag the model from the left model pool to the SIG Models table in the correct element. A list of all the SIG-adopted models is displayed, and you can choose the one you want.

SIG-Adopted Model EditorSIG-Adopted Model Editor

Vendor models give you more flexibility when developing products not covered by the SIG-adopted models. Vendors can define their own specification in these vendor models, including states, messages, and the associated behaviors. The vendor model editor is shown in the following figure.

Vendor Model EditorVendor Model Editor

Memory Editor#

The Memory Editor is a graphical tool for editing the memory layout of the applications in your workspace. It is a beta implementation of the tool, which is designed for use with solutions. In this release, it can be used on a single project. Most projects do not have default settings included at this time, leading to the warning shown in the following figure. Save the default values that the tool calculates as your starting point.

Memory Editor RAM viewMemory Editor RAM view

Proprietary Radio Configurator#

The Radio Configurator is provided as part of the Proprietary SDK. Use the Radio Configurator to create standard or custom radio configurations for your RAIL-based radio applications.

Software components tab with the Radio Configurator selectedSoftware components tab with the Radio Configurator selected

The parameters in the Radio Configurator are arranged in cards, some of which are grouped together. Different radio profiles offer different views and parameter sets.

Radio Configurator showing general settings and channels overview cardsRadio Configurator showing general settings and channels overview cards

  1. In the General Settings card, select a radio profile in the Select radio profile drop-down menu. A radio profile may be any supported radio link technology. These technologies can be bound by standards (for example the Sigfox or WMBus protocols) or can be fully customized. The fully customizable profile is called the "Base Profile".

  2. Select a radio PHY (radio configuration) in the Select a radio PHY dropdown list. Each profile has "built-in" configurations ready to use.

  3. Review and update the profile options. By default, no changes are allowed; fields are grayed out. To enable customization, use the Customized switch on the General Settings card. This allows access to all the parameters defined by the profile.

General settings card showing the customized switchGeneral settings card showing the customized switch

Wi-SUN Configurator#

The Wi-SUN Configurator is provided as part of the Wi-SUN SDK. Use it to configure the main settings of the Wi-SUN application through three panels: Application, Security, and Radio. For some projects only the Radio panel is available. The Wi-SUN Configurator tab is available when a project is created or can be displayed by opening the project file /config/wisun/wisun_settings.wisunconf.

Wi-SUN Configurator application tabWi-SUN Configurator application tab

Zigbee Cluster Configurator#

The Zigbee Cluster Configurator is provided as part of the Zigbee EmberZNet SDK. Use it to manage Zigbee endpoints, clusters, and commands. The interface is based on adding or modifying endpoints.

Zigbee Cluster Configurator with an endpoint selectedZigbee Cluster Configurator with an endpoint selected

You can add and configure clusters as needed. The cluster configuration interface consists of three tabs:

  • Attributes

  • Attribute Reporting

  • Commands

Zigbee Cluster Configurator Clusters interfaceZigbee Cluster Configurator Clusters interface

Configuration changes made through the Zigbee Cluster Configurator are saved to the zcl_config.zap file. When you save the file, the Zigbee Cluster Configurator not only saves the .zap file into your project, but also automatically generates all the .c and .h files required for your Zigbee application.

AppBuilder Projects#

AppBuilder Projects are configured by modifying parameters in various tabs, especially the PLUGINS tab. See Developing with AppBuilder for details.

Simplicity IDE with the AppBuilder editorSimplicity IDE with the AppBuilder editor

When you have configured the project, click Generate to create project files. Build the application image and flash it to your target device as in Building and Flashing.

AppBuilder editor with Generate control highlightedAppBuilder editor with Generate control highlighted

To modify the target device's pin use and parameters, use the Hardware Configurator available on the HAL tab. Note that, although the interface is similar to the 8-bit Hardware Configurator, this is a different tool.

general tab with Hardware Configurator Interface highlightedgeneral tab with Hardware Configurator Interface highlighted

Changes made through the Hardware Configurator are stored in a board-specific .hwconf file.