blob: 7252f9923694223a709af6dc6c83b68a2415a8ed [file] [log] [blame] [view]
<p align="center">
<img src="https://raw.githubusercontent.com/ARMmbed/mbed-os/master/logo.png" alt="ARM Mbed-OS logo"/>
</p>
# Mbed-OS platform overview
The Mbed-OS platform is a
[Matter](https://github.com/project-chip/connectedhomeip) platform that uses Arm
Mbed-OS 6.
The following diagram shows a simplified structure of a Matter application which
runs on the top of the Mbed-OS.
<p align="center">
<img src="images/matter_mbedos_overview_simplified.png" alt="matter_mbedos_overview_simplified">
</p>
# ARM Mbed-OS
Arm Mbed OS is an open source embedded operating system designed specifically
for the "things" in the Internet of Things. It includes all the features you
need to develop a connected product based on an Arm Cortex-M microcontroller,
including security, connectivity, an RTOS and drivers for sensors and I/O
devices.
Mbed OS provides an abstraction layer for the microcontrollers it runs on, so
that developers can focus on writing C/C++ applications that call functionality
available on a range of hardware. That means Mbed OS applications can be reused
on any Mbed-compatible platform.
Mbed OS uses a hardware abstraction layer (HAL) to support the most common parts
of a microcontroller, such as timers. This foundation facilitates writing
applications against a common set of application programming interfaces (APIs);
device automatically includes necessary libraries and driver support for
standard MCU peripherals, such as I2C, serial and SPI.
Mbed OS has an RTOS core, so it supports deterministic, multithreaded, real-time
software execution. The RTOS primitives are always available, allowing drivers
and applications to rely on threads, semaphores, mutexes and other RTOS
features.
The structure of Mbed OS enables matching applications and storage systems. In
other words, where the block level storage options vary and are application
dependent, The file system that best fits the IoT device can be chosen. The FAT
file system - backed by an SD card - provides compatibility with other operating
systems, such as Windows, Mac OS or Linux. When high reliability and recovery
from power failure are important, it makes sense to use our embedded file
system, backed with a (Q)SPI NOR flash chip.
Finally, Mbed OS implements the retargeting layer and boot process integration
of each supported toolchain, so application development feels similar to C or
C++ development for any other operating system.
# Bluetooth and IP stacks
In the Mbed-oS platform applications, the Bluetooth LE interface is used to
perform pairing and Wi-Fi network provisioning operations between the Matter
device and the Matter controller. Afterwards, the fully provisioned device is
able to communicate with other devices inside the Wi-Fi network.
For the Bluetooth LE communication purposes, the Mbed-OS platform application is
using
[ARM Mbed BLE](https://os.mbed.com/docs/mbed-os/latest/apis/bluetooth-apis.html)
(also called BLE_API) - Bluetooth Low Energy software solution which interfaces
with the BLE controller on the hardware target. Arm Mbed BLE hides the BLE
stack’s complexity behind C++ abstractions and is compatible with all
BLE-enabled Mbed board. The Mbed OS BLE_API automatically configuring the
clocks, timers and other hardware peripherals to work at their lowest power
consumption.
For Wi-FI communication purposes, the Mbed-OS application is using the internal
Mbed LWIP stack and Mbed Socket API together. To integrate it with Matter
network layer, special glue socket layer has been introduced to take care of
adapting the Mbed socket to BSD interface which is used inside the Matter
endpoints implementation.
## Matter integration
The Bluetooth LE and Wi-Fi used stacks provided by the Mbed-OS have been
integrated with the Matter stack using a special intermediate layer.
This layer contains platform-specific implementations of abstract manager
interfaces defined in the Matter stack. The application is able to use Matter's
platform agnostic interfaces and no additional platform-related actions are
needed to perform communication through the Matter stack.
# Matter example applications
Sample Matter applications are provided for the Mbed OS platform. They can be
used to speed up development:
- [shell](../../examples/shell/mbed)
- [all-clusters-app](../../examples/all-clusters-app/mbed)
- [lock-app](../../examples/lock-app/mbed/README.md)
- [lighting-app](../../examples/lighting-app/mbed/README.md)
- [pigweed-app](../../examples/pigweed-app/mbed/README.md)
## Example configuration
Each of the supporting examples contains the `config.in` file which allows you
to configure the application in a proper way. You can define/disable/enable
application settings. Then they are propagated through Mbed-OS and Matter stack
build systems.
## Matter stack configuration
In each of supported examples, the Matter stack can be configured by modifying
`CHIPProjectConfig.h` file which is placed inside the project directory.
## Mbed-OS configuration
Mbed-OS gives possibility to tweak its parameters by using the
[Mbed-OS configuration system](https://os.mbed.com/docs/mbed-os/latest/program-setup/advanced-configuration.html).
The same configuration system can be used to change default hardware target
setup used in application. Additionally, it is the first place for adding
support of the new hardware target support into the application. Mbed-OS
configuration system can be accessed by modifying the `mbed_app.json` file which
exists in each sample project directory.
## Build system
The Mbed-OS platform makes use of the following build systems to generate ninja
build scripts:
- GN - Used by the Matter project in majority of cases.
- CMake (+ mbed-tools) - Used by the Mbed-OS user application and other
components within Mbed ecosystem.
Matter's stack and platform modules are built with GN and output a library file.
The application, Mbed-OS and target specific libraries are built with CMake and
the Matter library file is imported during the compilation process.
## Build profiles
Arm Mbed OS defines three collections of toolchain flags used during the build:
- develop
- release
- debug
Build profiles can be easy selected when building example application using
either vscode task or its associated build script directly
([mbed_examples.sh](../../scripts/examples/mbed_example.sh)).
For more details about each of this profiles, please visit official
[ARM Mbed documentation](https://os.mbed.com/docs/mbed-os/latest/program-setup/build-profiles-and-rules.html).