Skip to content

Latest commit

 

History

History
137 lines (78 loc) · 8.25 KB

File metadata and controls

137 lines (78 loc) · 8.25 KB

Bluetooth - BTHome v2 - Internal Temperature Monitor

Type badge Technology badge License badge SDK badge Required board Build badge Flash badge RAM badge

Overview

The example showcases the implementation of BTHome support for Silabs development kits.

The example application illustrates how BTHome can be effectively utilized with Silabs development kits to communicate internal temperature sensor values to a HomeAssistant setup running on a Raspberry Pi 4. This demonstration will provide developers with insights into integrating BTHome with Silabs hardware for IoT applications.

overview

The BTHOME v2 sensor device is a BGM220 Explorer Kit that reads the internal temperature sensor and sends BLE advertisement packets in the BTHome v2 format.

Raspberry Pi 4 runs a Home Assistant OS that scans for and detects BTHome v2 sensor device. Users use the Home Assistant application on the smartphone to communicate with Raspberry Pi 4 to get the advertisement packet of the BTHome v2 sensor device, parse and display it on a smartphone.

Gecko SDK Version

Hardware Required

NOTE: Tested boards for working with this example:

Board ID Description
BRD2601B EFR32xG24 Dev Kit
BRD2703A EFR32xG24 Explorer Kit - XG24-EK2703A
BRD4314A BGM220 Bluetooth Module Explorer Kit - BGM220-EK4314A
BRD4108A EFR32BG22 Explorer Kit Board
BRD2704A Sparkfun Thing Plus MGM240P

Connections Required

The following picture shows the connection for this application:

connection

Setup

To test this application, you can either create a project based on an example project or start with a "Bluetooth - SoC Empty" project based on your hardware.

Create a project based on an example project

  1. From the Launcher Home, add your product name to My Products, click on it, and click on the EXAMPLE PROJECTS & DEMOS tab. Find the example project with the filter "bthome v2".

  2. Click Create button on Bluetooth - BTHome v2 - Internal Temperature Monitor example. Example project creation dialog pops up -> click Create and Finish and the project should be generated.

    Create project from example

  3. Build and flash this example to the board.

Start with a "Bluetooth - SoC Empty" project

  1. Create a Bluetooth - SoC Empty project for your hardware using Simplicity Studio 5.

  2. Copy all the src/app.c file into the project root folder (overwriting the existing file).

  3. Install the software components:

    • Open the .slcp file in the project

    • Select the SOFTWARE COMPONENTS tab

    • Install the following components:

      • [Platform] → [Driver] → [TEMPDRV]
      • [Third-Party Hardware Drivers] → [Services] → [BTHome v2]
  4. Build and flash the project to your board.

Note:

How It Works

Application Initialization

application initialization

BLE System Boot Event

System boot event flow

Periodic Timer Callback

Timer callback handle

Testing

To test this application and monitor the temperature, you need the following materials:

  • Raspberry Pi 4 runs Home Assistant OS.
  • Home Assistant application on a smartphone.
  • BTHOME sensor device, which is BGM220 Explorer Kit runs the Bluetooth - BTHome v2 - Internal Temperature Monitor example.

Note: To utilize the BTHOME sensor device, you have two options. You can use Silabs development kits and run either the "BTHome v2 - Internal Temperature Monitor" example or create your own project by following the instructions provided in the "Setup" section above.

  1. Power on Raspberry Pi 4 and BTHOME sensor device. After powering on, the BTHOME sensor device sends the advertisement packet every 10 seconds that contains the temperature value.

    Sensor initialization

  2. Open the Home Assistant application on the smartphone, select [Settings] → [Devices and Services] → [Add Integration]

    Setting on the home assistant application

  3. Add Integration with the name 'BTHome'. You can see the list of device, which is advertising in BTHome format. Choose your device with the correct name (it is 'Temp 79B4' in this example) and submit the Bindkey, which is defined in the firmware of the BTHOME sensor device. Note: To be able to find your sensor device with the home assistant application, you need to use the same network on both Raspberry Pi 4 and the smartphone.

    Add a device with Name and Bindkey

    The name and Bindkey in the firmware of the sensor device.

    Check name and Bindkey in the firmware of sensor device

  4. After adding your sensor device successfully with the Bindkey, select a suitable area where your sensor device is located.

    Set area for sensor device and track temperature

  5. Now you can see your sensor is already added to the Home Assistant system. You can track the temperature value from your sensor by selecting your device in BTHome.