ARM Mbed-OS logo

Mbed-OS add new hardware target

WARNING, MbedOS is deprecated and support for it will be removed from the connectedhomeip project

Overview

This document shows how to add the new Mbed OS hardware target to Matter project.

Please check the list of supported development boards which are compatible with Mbed OS.

In order to adapt the new hardware target to the Matter project, you need to remember about the following requirements:

  • Bluetooth Low Energy support.
  • Wireless communication module with WiFi or Thread network support (IPv6 protocol is required).
  • Serial port support
  • On-chip debug with OpenOCD support

Additional target component requirements are different for each of example application. Check the Device UI paragraph in example description.

Example Application

The first step to add the new target to each of example application is to modify the examples/example_name/mbed/mbed_app.json file. It contains the common project settings and override the default values for supported boards. You should add the necessary components and parameters for the target there.

If the new target uses the external libraries, it will be required to link it in the CMakeLists.txt file.

Building

To add the new hardware target to the build system the scripts/examples/mbed_example.sh script should be modify. Extend SUPPORTED_TARGET_BOARD variable with a new target name.

Example:

SUPPORTED_TARGET_BOARD=(CY8CPROTO_062_4343W NEW_TARGET_NAME)

The next step is add the target name to build task in .vscode/task.json file. Extend the options variable in mbedTarget input setting.

Example:

{
    "type": "pickString",
    "id": "mbedTarget",
    "description": "What mbed target do you want to use?",
    "options": ["CY8CPROTO_062_4343W", "NEW_TARGET_NAME"],
    "default": "CY8CPROTO_062_4343W"
}

Flashing

Mbed OS example application flashing process uses the Open On-Chip Debugger. The first step is to create the target configuration file inside config/mbed/scripts directory. The file name should be the same as target and the extension should be .tcl. The target CPU and programming interface definitions are essential parts of the configuration file.

The next steps are the same as for building process. Adding the name of the target to scripts/examples/mbed_example.sh and .vscode/task.json files allows the use of available flashing processes.

Additional flashing option is based on VSCode launch task. Adding the new target to it required .vscode/launch.json modification. Extend the options variable in mbedTarget input setting.

Example:

{
    "type": "pickString",
    "id": "mbedTarget",
    "description": "What mbed target do you want to use?",
    "options": ["CY8CPROTO_062_4343W", "NEW_TARGET_NAME"],
    "default": "CY8CPROTO_062_4343W"
}

Debugging

Debugging process of Mbed OS applications is also based on VSCode launch task. Adding the new target to it required .vscode/launch.json modification. Extend the options variable in mbedTarget input setting.

Example:

{
    "type": "pickString",
    "id": "mbedTarget",
    "description": "What mbed target do you want to use?",
    "options": ["CY8CPROTO_062_4343W", "NEW_TARGET_NAME"],
    "default": "CY8CPROTO_062_4343W"
}

CI

The Matter project continue integration process is based on Github Actions tool. It uses workflow configuration files to execute actions on CI server.

To add the new target to the validation process of building Mbed OS applications you need to modify the .github/workflows/examples-mbed.yaml file. Extend the job's environment variable APP_TARGET with the target name.

Example:

APP_TARGET: [CY8CPROTO_062_4343W, NEW_TARGET_NAME]