Matter(当时称为 Project Connected Home over IP 或 Project CHIP)于2019年12月11日首次宣布。当时,它是由苹果、谷歌、亚马逊和联发科技等公司共同发起的一个项目,目的是创建一个开放标准,提高智能家居设备之间的互操作性。在2021年,该项目更名为 "Matter",同时宣布了首个 Matter 1.0 版本的发布,这标志着 Matter 开始为开发者和制造商提供稳定的规范,以便构建和推出兼容的智能家居设备。
本篇采用 nordic 的 nrf-connect-sdk v2.5.0,matter 标准1.1.0,体验 Matter over Thread 开发。
本文基于 Matter over Thread 的网络:
Tip:下载相关操作需要梯子。
方式一:使用 vscode 编译与下载(推荐),使用 vscode 的 nrf connect sdk 扩展去下载 toolchain 和 sdk 即可。
方式二:使用 命令行 编译与下载。
方式三:使用 SEGGER Embedded Studio(SES) 编译与下载。
配置文件选择 prj_no_dfu.conf,不需要烧录 bootloader,其他需要先编译并烧录bootloader。
sudo apt update
sudo apt install radvd
/etc/radvd.conf
,例如:其中 wlan0 为网卡名称,根据实际情况修改,运行ifconfig
查看网卡名称。interface wlan0 {
AdvManagedFlag on;
AdvSendAdvert on;
MinRtrAdvInterval 30;
MaxRtrAdvInterval 60;
prefix fd11:33::1/64 {
AdvOnLink on;
AdvAutonomous on;
AdvRouterAddr on;
};
};
sudo systemctl restart radvd
git clone https://github.com/openthread/ot-br-posix.git --depth 1
cd ot-br-posix
./script/bootstrap
INFRA_IF_NAME=wlan0 ./script/setup
$ sudo service otbr-agent status
● otbr-agent.service - Border Router Agent
Loaded: loaded (/lib/systemd/system/otbr-agent.service; enabled; vendor preset: enabled)
Active: activating (auto-restart) (Result: exit-code) since Mon 2021-03-01 05:43:38 GMT; 2s ago
Process: 2444 ExecStart=/usr/sbin/otbr-agent $OTBR_AGENT_OPTS (code=exited, status=2)
Main PID: 2444 (code=exited, status=2)
对树莓派 sudo reboot 重启更改生效
west build -p always -b nrf52840dongle_nrf52840 nrf/samples/openthread/coprocessor/
打包:
nrfutil pkg generate --hw-version 52 --sd-req=0x00 \
--application build/zephyr/zephyr.hex --application-version 1 build/zephyr/zephyr.zip
烧录:
nrfutil dfu usb-serial -pkg build/zephyr/zephyr.zip -p /dev/ttyACM0
/etc/default/otbr-agent
,改变tty端口和主干接口波特率。OTBR_AGENT_OPTS="-I wpan0 -B wlan0 spinel+hdlc+uart:///dev/ttyUSB0?uart-baudrate=100000"
sudo systemctl start otbr-agent.service
使用官方的最新 chip 项目:
git clone https://github.com/project-chip/connectedhomeip.git
cd connectedhomeip
git submodule update -f --init --recursive
./scripts/examples/gn_build_example.sh examples/chip-tool BUILD_PATH
other:Android chip tool;IOS chiptool。
sudo ot-ctl dataset init new
sudo ot-ctl dataset networkkey 00112233445566778899aabbccddeeff
sudo ot-ctl dataset extpanid 1111111122222222
sudo ot-ctl dataset panid 0x1234
sudo ot-ctl dataset channel 15
sudo ot-ctl dataset commit active
sudo ot-ctl ifconfig up
sudo ot-ctl thread start
- 初始化一个新的 OpenThread 数据集。
- 设置网络密钥(Network Key)为给定的值。这是用于保障网络安全性的密钥。
- 设置扩展PAN ID(Extended PAN ID)为给定的值。这是网络的唯一标识符。
- 设置PAN ID为给定的值。这是一个短地址,用于在同一网络中唯一标识设备。
- 设置网络通信的频道为给定的值。在 IEEE 802.15.4 网络中,通信频道的选择对于网络的性能和干扰有影响。
- 提交对数据集的更改,并激活新的数据集。这将应用上述设置。
- 启动 OpenThread 接口,准备进行通信。
- 启动 OpenThread 线程栈,使设备成为网络的一部分。
Matter Light 等待配对状态下 LED1 慢闪,配对中快闪,配对后常亮(nrf5340dk 按住 button1 3s 以上恢复出厂设置)。执行编译出来的 chip-tool 应用如下命令进行配对:
sudo ./chip-tool pairing ble-thread 1234 hex:0e08000000000001000035060004001fffe00708fd9e914e6def9df2030f4f70656e5468726561642d323361350410542ccde31a710d5b17af34e12fec0f140c0402a0f7f8051000112233445566778899aabbccddeeff0208111111112222222201021234000300000f 20202021 3840
$ ./chip-tool pairing ble-thread
hex:
pairing ble-thread
: 指定使用 BLE Thread 进行配对。: 设备的节点ID。这是设备在网络中的唯一标识符。
hex:
: 操作数据集(Operational Dataset)的十六进制表示。这是设备的操作参数,用于配置设备的网络连接等信息。: PIN码。这是一种简单的配对方法,用户可以输入此代码来验证设备。
: 辨识码。用于在设备之间进行配对时进行标识的参数。
node_id 自定义为 1234。 operational_dataset 获取在 raspberry pi 终端中执行:
sudo ot-ctl dataset active -x
得到
0e08000000000001000035060004001fffe00708fd9e914e6def9df2030f4f70656e5468726561642d323361350410542ccde31a710d5b17af34e12fec0f140c0402a0f7f8051000112233445566778899aabbccddeeff0208111111112222222201021234000300000f
Done
pin_code、
discriminator 在 Matter Light 启动时
可以在设备的日志终端(例如UART)中找到,当前 pin_code
:20202021,discriminator:
3840。
I: 658 [DL]Device Configuration:
I: 662 [DL] Serial Number: 11223344556677889900
I: 666 [DL] Vendor Id: 65521 (0xFFF1)
I: 670 [DL] Product Id: 32773 (0x8005)
I: 673 [DL] Product Name: not-specified
I: 677 [DL] Hardware Version: 0
I: 681 [DL] Setup Pin Code (0 for UNKNOWN/ERROR): 20202021
I: 687 [DL] Setup Discriminator (0xFFFF for UNKNOWN/ERROR): 3840 (0xF00)
I: 694 [DL] Manufacturing Date: (not set)
I: 698 [DL] Device Type: 65535 (0xFFFF)
$ ./chip-tool onoff toggle
为委托节点的用户自定义ID。
是已实现 OnOff 集群的端点的 ID。
$ ./chip-tool levelcontrol move-to-level
0
是在和之间编码的亮度级别254
,除非在集群中配置了自定义范围。
是过渡时间。
是选项掩码。
是选项覆盖。
为委托节点的用户自定义ID。
是实现了 LevelControl 集群的端点的 ID。
exmple:
翻转LED2:
sudo ./chip-tool onoff toggle 1234 1
LED2 亮度 18,过渡时间 3s:
sudo ./chip-tool levelcontrol move-to-level 18 3 0 0 1234 1