Last Updated on : 2024-11-20 02:13:27download
This topic describes the serial protocol that is used to implement serial communication between Tuya’s Bluetooth module and the third-party MCU, as shown in the following diagram.
 
Baud: 9600/115200 bps
Data bit: 8
Parity check: none
Stop bit: 1
Data flow control: none
After the Bluetooth module is powered on or restarted, it will start automatic baud rate detection. The module sends a heartbeat packet to the MCU at the baud rate configured last time. It changes to another baud rate at the next heartbeat interval and so on.
If the module receives the correct response from the MCU, it will stop baud rate detection and write the current serial port configuration to the flash memory. Some legacy firmware versions do not support automatic baud rate detection.
| Term | Description | 
|---|---|
| Data point (DP) | A data point (DP) is an abstract representation of a product function. For more information, see Product Functions. | 
| Product ID (PID) | A product is an abstract representation of a collection of product functions. Each product created on the Tuya Developer Platform is assigned a unique PID that is associated with the product information, including DPs, app control panel, and purchase information. | 
| Bind Bluetooth device | Bind a Bluetooth device with an app account through the Tuya-specific Bluetooth protocol to register the device to the cloud. | 
| Unbind Bluetooth device | Unbind a Bluetooth device from an app account. The device will be in the unbound and not connected state. | 
| Reset Bluetooth device | Unbind a Bluetooth device and clear the user data by using the app. The difference between resetting and unbinding is whether the user data is cleared. | 
| Bluetooth connection | Indicate a Bluetooth device is in the connection state in the link layer. | 
| Bluetooth advertising | Indicate a Bluetooth device is in the advertising state in the link layer. | 
| Bluetooth pairing mode | Indicate a Bluetooth device that is not bound and connected is advertising specified data, allowing the mobile app to discover the advertising device. | 
| Bluetooth bound and connected | Indicate a Bluetooth device is online. The device is bound with and establishes a secure connection with the app through the Tuya-specific Bluetooth protocol. | 
| Bluetooth bound but not connected | Indicate a Bluetooth device is offline. The device is bound with but not connected to the app. | 
| Bluetooth gateway online | The gateway connection status depends on the logic to determine the online/offline status, which can vary depending on the gateway for use. 
 | 
| No. | Bytes | Field | Description | 
|---|---|---|---|
| 0 1 | 2 | Header | 0x55 0xAA | 
| 2 | 1 | Version number | The protocol version. | 
| 3 | 1 | Command (CMD) | The frame type. | 
| 4 5 | 2 | Data length (Len) | Upper 8 bits Lower 8 bits | 
| 6 to 6+Len-1 | Len | Data | |
| 6+Len | 1 | CRC8 | Start from the header, add up all the bytes, and then divide the sum by 256 to get the remainder. | 
All data greater than one byte is transmitted in big-endian format.
| Field | Bytes | Description | 
|---|---|---|
| dp_id | 1 | The ID of a DP. | 
| dp_type | 1 | The data type of a DP. | 
| dp_data_len | 2 | The data length of a DP. | 
| dp_data_value | dp_data_len | The data of a DP. | 
The value range and description of dp_type (cloud defined):
| dp_type | Value | Bytes | Description | 
|---|---|---|---|
| raw | 0x00 | 1 to 255 | The raw data in hexadecimal format. | 
| bool | 0x01 | 1 | Boolean type. | 
| value | 0x02 | 4 | Integer type. | 
| string | 0x03 | 0 to 255 | String type. It might be empty. | 
| enum | 0x04 | 1 | Enum type | 
| bitmap | 0x05 | 1/2/4 | Data greater than one byte is transmitted in big-endian format. | 
The following table lists the firmware support information.
| Product category | Chip | Module | 
|---|---|---|
| Basis | 
 | 
 | 
| Locks | 
 | 
 | 
| Shared devices | 
 | 
 | 
| Sensors | 
 | 
 | 
Note that the generic firmware support for specific protocols depends on product categories and models. If you have any questions about protocols, submit a service ticket.
After power on, the module will send a heartbeat packet to the MCU every 3 seconds. If the MCU correctly responds to a heartbeat, it indicates the MCU works properly. After the first-time heartbeat communication, the module will send the MCU a command to get product information.
The MCU can determine whether the module works properly by the regular heartbeat check. If the MCU does not receive a heartbeat packet as expected, it can use the reset pin to reset the module.
After getting the MCU information, the module checks the heartbeat every 10 seconds in standard power mode. In low power mode, there is no heartbeat check.
The Telink Bluetooth modules do not perform heartbeat checks both in low power mode and after getting the MCU information in standard power mode. They cannot detect whether the MCU has been restarted.
The module sends the following data.
| No. | Bytes | Field | Description | 
|---|---|---|---|
| 0 1 | 2 | Header | 0x55 0xAA | 
| 2 | 1 | Version number | 0x00 | 
| 3 | 1 | Command (CMD) | 0x00 | 
| 4 5 | 2 | Data length. | 0x00 0x00 | 
| 6 | 1 | CRC8 | Start from the header, add up all the bytes, and then divide the sum by 256 to get the remainder. | 
The MCU returns the following data.
| No. | Bytes | Field | Description | 
|---|---|---|---|
| 0 1 | 2 | Header | 0x55 0xAA | 
| 2 | 1 | Version number | 0x00 | 
| 3 | 1 | Command (CMD) | 0x00 | 
| 4 5 | 2 | Data length. | 0x00 0x01 | 
| 6 | 1 | State | Return value | 
| 7 | 1 | CRC8 | Start from the header, add up all the bytes, and then divide the sum by 256 to get the remainder. | 
Return value
Product information consists of the product ID (PID) and the MCU software version number.
The module sends the following data.
| No. | Bytes | Field | Description | 
|---|---|---|---|
| 0 1 | 2 | Header | 0x55 0xAA | 
| 2 | 1 | Version number | 0x00 | 
| 3 | 1 | Command (CMD) | 0x01 | 
| 4 5 | 2 | Data length. | 0x00 0x00 | 
| 6 | 1 | CRC8 | Start from the header, add up all the bytes, and then divide the sum by 256 to get the remainder. | 
The MCU returns the following data.
| No. | Bytes | Field | Description | 
|---|---|---|---|
| 0 1 | 2 | Header | 0x55 0xAA | 
| 2 | 1 | Version number | 0x00 | 
| 3 | 1 | Command (CMD) | 0x01 | 
| 4 5 | 2 | Data length. | 0x00 0x0d | 
| 6 to 18+n | 13+n | Data | See the following table. | 
| 19+n | 1 | CRC8 | Start from the header, add up all the bytes, and then divide the sum by 256 to get the remainder. | 
Data format
| 1 to 8 | 9 to 13 | 14 to 14+n | 
|---|---|---|
| Product ID (PID) | The reserved field. | The optional information TLD [TLD] [TLD]… | 
Example: 55 AA 00 01 00 0D 66 74 62 38 78 32 78  30 31 2E 30 2E 30 C0, indicating the PID is ftb8x2x0 and the MCU version number is 1.0.0.
PID: an 8-digit string, such as ftb8x2x0.
Reserved field: populated with the MCU version number as the placeholder by default. The module does not parse this field. The MCU reports its version number using the command 0xE8 or 0xE9.
TLD: used to configure the features and capabilities for the generic firmware. TLD refers to a custom data format:
T is short for Type, indicating the ID of the feature to set.L is short for Length, indicating the length of the data to set.D is short for Data, indicating the data to set.You can set one or multiple TLDs. If you use the default configuration, you can leave this field as is. Otherwise, populate it with the desired content.
The values of T and L are fixed. The module can get the value of D by parsing the T and L. There is no order requirement for multiple TLDs.
The following table lists the TLD data format. The number refers to the sequence number of the byte.
When T is 0x07 and L is 0x01, D indicates the configuration of beacon capability. This is an optional TLD. If you do not choose and set it, beacon is not supported by default.
| 1 | 2 | 3 | 
|---|---|---|
| T(0x07) | L(0x01) | beacon_enable | 
beacon_enable: indicates the beacon capability for status reporting. With beacon enabled, the device in bound but not connected can report status to the gateway or app by using broadcasting. For more information, see Status reporting (0x07).
0x00: Disable
0x01: Enable
Others: reserved
Example: 55 AA 00 01 00 10 6D 6E 75 78 64 38 30 75 31 2E 30 2E 30 07 01 01 0F
When T is 0x03 and L is 0x01, D indicates the configuration of device online policy. This is an optional TLD. If you do not choose and set it, the default value is 0x00.
| 1 | 2 | 3 | 
|---|---|---|
| T(0x03) | L(0x01) | online_flag | 
online_flag: the flag of device online policy. The policy depends on the Bluetooth gateway for use instead of the mobile app.
Example: 55 AA 00 01 00 13 6D 6E 75 78 64 38 30 75 31 2E 30 2E 30 07 01 01 03 01 01 17
When T is 0xBA and L is 0x01, D indicates the SMP enablement. This is an optional TLD. If you do not choose and set it, the default value is 0x00.
| 1 | 2 | 3 | 
|---|---|---|
| T(0xBA) | L(0x01) | SMP_ENABLE | 
SMP_ENABLE: the enablement of Bluetooth SMP feature.
Example: 55 AA 00 01 00 10 34 6B 78 36 68 6C 61 78 31 2E 30 2E 30 BA 01 01 B3
When T is 0x01 and L is 0x01, D indicates the configuration of the secure connection type. This is an optional TLD. If you do not choose and set it, the default value is 0x00.
| 1 | 2 | 3 | 
|---|---|---|
| T(0x01) | L(0x01) | Secure_connect_type | 
Secure_connect_type: the type of secure Bluetooth connection.
Example: 55 AA 00 01 00 10 34 6B 78 36 68 6C 61 78 31 2E 30 2E 30 01 01 01 FA
When T is 0xC2 and L is 0x01, D indicates the configuration of accessory support. This is an optional TLD. If you do not choose and set it, the default value is 0x00.
| 1 | 2 | 3 | 
|---|---|---|
| T(0xC2) | L(0x01) | Accessory_Support | 
Accessory_Support: specifies whether to support non-smart accessories.
Example: 55 AA 00 01 00 10 34 6B 78 36 68 6C 61 78 31 2E 30 2E 30 C2 01 01 BB
The MCU information and configuration are stored in the flash memory. If you do not set the optional information, the module will use the default configuration or the previous configuration if any.
The working mode indicates how the network status is indicated and the way to trigger module reset. Theoretically, the module can work in the following two modes:
The Bluetooth module only supports the first collaboration mode.
The module sends the following data.
| No. | Bytes | Field | Description | 
|---|---|---|---|
| 0 1 | 2 | Header | 0x55 0xAA | 
| 2 | 1 | Version number | 0x00 | 
| 3 | 1 | Command (CMD) | 0x02 | 
| 4 5 | 2 | Data length. | 0x00 0x00 | 
| 6 | 1 | CRC8 | Start from the header, add up all the bytes, and then divide the sum by 256 to get the remainder. | 
Example: 55 aa 00 02 00 00 01
The MCU returns the following data.
| No. | Bytes | Field | Description | 
|---|---|---|---|
| 0 1 | 2 | Header | 0x55 0xAA | 
| 2 | 1 | Version number | 0x00 | 
| 3 | 1 | Command (CMD) | 0x02 | 
| 4 5 | 2 | Data length. | 0x00 0x00 | 
| 6 | 1 | CRC8 | Start from the header, add up all the bytes, and then divide the sum by 256 to get the remainder. | 
Example: 55 AA 00 02 00 00 01
0x02.The module sends the following data.
| No. | Bytes | Field | Description | 
|---|---|---|---|
| 0 1 | 2 | Header | 0x55 0xAA | 
| 2 | 1 | Version number | 0x00 | 
| 3 | 1 | Command (CMD) | 0x03 | 
| 4 5 | 2 | Data length. | 0x00 0x01 | 
| 6 | 1 | State | Return value | 
| 7 | 1 | CRC8 | Start from the header, add up all the bytes, and then divide the sum by 256 to get the remainder. | 
| State | Description | Things to note | 
|---|---|---|
| 0x00 | Unbound | The shared devices either in the unbound state or bound but not connected state are considered as ready for pairing with the mobile app. | 
| 0x01 | Bound but not connected | Same as above. | 
| 0x02 | Bound and connected | For shared devices, this state indicates that a device is paired and connected. | 
0x04 will not clear the virtual ID.The MCU sends the following data.
| No. | Bytes | Field | Description | 
|---|---|---|---|
| 0 1 | 2 | Header | 0x55 0xAA | 
| 2 | 1 | Version number | 0x00 | 
| 3 | 1 | Command (CMD) | 0x04 | 
| 4 5 | 2 | Data length. | 0x00 0x00 | 
| 6 | 1 | CRC8 | Start from the header, add up all the bytes, and then divide the sum by 256 to get the remainder. | 
Example: 55 aa 00 04 00 00 03
The module returns the following data.
| No. | Bytes | Field | Description | 
|---|---|---|---|
| 0 1 | 2 | Header | 0x55 0xAA | 
| 2 | 1 | Version number | 0x00 | 
| 3 | 1 | Command (CMD) | 0x04 | 
| 4 5 | 2 | Data length. | 0x00 0x00 | 
| 6 | 1 | CRC8 | Start from the header, add up all the bytes, and then divide the sum by 256 to get the remainder. | 
Example: 55 AA 00 04 00 00 03
0x04. The only difference is that using this command to reset a Telink-based module will clear its virtual ID.The MCU sends the following data.
| No. | Bytes | Field | Description | 
|---|---|---|---|
| 0 1 | 2 | Header | 0x55 0xAA | 
| 2 | 1 | Version number | 0x00 | 
| 3 | 1 | Command (CMD) | 0x05 | 
| 4 5 | 2 | Data length. | 0x00 0x00 | 
| 6 | 1 | CRC8 | Start from the header, add up all the bytes, and then divide the sum by 256 to get the remainder. | 
Example: 55 aa 00 05 00 00 04
The module returns the following data.
| No. | Bytes | Field | Description | 
|---|---|---|---|
| 0 1 | 2 | Header | 0x55 0xAA | 
| 2 | 1 | Version number | 0x00 | 
| 3 | 1 | Command (CMD) | 0x05 | 
| 4 5 | 2 | Data length. | 0x00 0x00 | 
| 6 | 1 | CRC8 | Start from the header, add up all the bytes, and then divide the sum by 256 to get the remainder. | 
Example: 55 AA 00 05 00 00 04
The module sends the following data.
| No. | Bytes | Field | Description | 
|---|---|---|---|
| 0 1 | 2 | Header | 0x55 0xAA | 
| 2 | 1 | Version number | 0x00 | 
| 3 | 1 | Command (CMD) | 0x06 | 
| 4 5 | 2 | Data length (Len) | Upper 8 bits Lower 8 bits | 
| 6 to 6+Len-1 | Len | DP | See the following table. | 
| 6+Len | 1 | CRC8 | Start from the header, add up all the bytes, and then divide the sum by 256 to get the remainder. | 
DP format:
| 1 | 2 | 3 to 4 | 5 and greater | … | n | n+1 | n+1 to n+2 | n+3 and greater | 
|---|---|---|---|---|---|---|---|---|
| dp1_id | dp1_type | dp1_len | dp1_data | … | dpN_id | dpN_type | dpN_len | dpN_data | 
Example: 55 aa 00 06 00 05 03 01 00 01 01 10
The MCU returns the following data.
None
dp_len in each packet is four bytes. For more information about the beacon capability, see Get MCU information.The MCU sends the following data.
| No. | Bytes | Field | Description | 
|---|---|---|---|
| 0 1 | 2 | Header | 0x55 0xAA | 
| 2 | 1 | Version number | 0x00 | 
| 3 | 1 | Command (CMD) | 0x07 | 
| 4 5 | 2 | Data length (Len) | Upper 8 bits Lower 8 bits | 
| 6 to 6+Len-1 | Len | DP | See the following table. | 
| 6+Len | 1 | CRC8 | Start from the header, add up all the bytes, and then divide the sum by 256 to get the remainder. | 
DP format:
| 1 | 2 | 3 to 4 | 5 and greater | … | n | n+1 | n+1 to n+2 | n+3 and greater | 
|---|---|---|---|---|---|---|---|---|
| dp1_id | dp1_type | dp1_len | dp1_data | … | dpN_id | dpN_type | dpN_len | dpN_data | 
Example: 55 aa 00 07 00 05 03 01 00 01 01 11
The module returns the following data.
| No. | Bytes | Field | Description | 
|---|---|---|---|
| 0 1 | 2 | Header | 0x55 0xAA | 
| 2 | 1 | Version number | 0x00 | 
| 3 | 1 | Command (CMD) | 0x07 | 
| 4 5 | 2 | Data length. | 0x00 0x01 | 
| 6 | 1 | State | Return value | 
| 7 | 1 | CRC8 | Start from the header, add up all the bytes, and then divide the sum by 256 to get the remainder. | 
Return value
0x07.The Telink generic firmware does not support detecting MCU restart.
The module sends the following data.
| No. | Bytes | Field | Description | 
|---|---|---|---|
| 0 1 | 2 | Header | 0x55 0xAA | 
| 2 | 1 | Version number | 0x00 | 
| 3 | 1 | Command (CMD) | 0x08 | 
| 4 5 | 2 | Data length. | 0x00 0x00 | 
| 6 | 1 | CRC8 | Start from the header, add up all the bytes, and then divide the sum by 256 to get the remainder. | 
Example: 55 aa 00 08 00 00 07
The MCU returns the following data.
None
This command does not apply to the generic firmware for the shared devices.
The MCU sends the following data.
| No. | Bytes | Field | Description | 
|---|---|---|---|
| 0 1 | 2 | Header | 0x55 0xAA | 
| 2 | 1 | Version number | 0x00 | 
| 3 | 1 | Command (CMD) | 0x09 | 
| 4 5 | 2 | Data length. | 0x00 0x00 | 
| 6 | 1 | CRC8 | Start from the header, add up all the bytes, and then divide the sum by 256 to get the remainder. | 
The module returns the following data.
| No. | Bytes | Field | Description | 
|---|---|---|---|
| 0 1 | 2 | Header | 0x55 0xAA | 
| 2 | 1 | Version number | 0x00 | 
| 3 | 1 | Command (CMD) | 0x09 | 
| 4 5 | 2 | Data length. | 0x00 0x01 | 
| 6 | 1 | State | Return value | 
| 7 | 1 | CRC8 | Start from the header, add up all the bytes, and then divide the sum by 256 to get the remainder. | 
Return value
0x03.The MCU sends the following data.
| No. | Bytes | Field | Description | 
|---|---|---|---|
| 0 1 | 2 | Header | 0x55 0xAA | 
| 2 | 1 | Version number | 0x00 | 
| 3 | 1 | Command (CMD) | 0x0A | 
| 4 5 | 2 | Data length. | 0x00 0x00 | 
| 6 | 1 | CRC8 | Start from the header, add up all the bytes, and then divide the sum by 256 to get the remainder. | 
If the module is offline when receiving reported data from the MCU, it will save the data to its flash memory and send the stranded data after going online. After the last piece of stranded data is sent to the cloud, the module will release the cache.
The module can cache up to N pieces of DP data. When the limit is reached, the newest record will overwrite the oldest one.
The time drift of the module’s internal clock is less than one minute in 24 hours. The module will sync its clock with the server time each time it is connected to the cloud. If you require highly accurate time, you can report data using the MCU’s timestamp.
To ensure reliable data transmission, we recommend you use this command to report record-type data no matter what connection status the module is in.
The MCU sends the following data.
| No. | Bytes | Field | Description | 
|---|---|---|---|
| 0 1 | 2 | Header | 0x55 0xAA | 
| 2 | 1 | Version number | 0x00 | 
| 3 | 1 | Command (CMD) | 0xE0 | 
| 4 5 | 2 | Data length (Len) | Upper 8 bits Lower 8 bits | 
| 6 to 6+Len-1 | Len | Data | See the following table. | 
| 6+Len | 1 | CRC8 | Start from the header, add up all the bytes, and then divide the sum by 256 to get the remainder. | 
Data format
| 1 | 2 to x | x | x+1 | x+2 to x+3 | x+4 and greater | … | n | n+1 | n+1 to n+2 | n+3 and greater | 
|---|---|---|---|---|---|---|---|---|---|---|
| TYPE | Time_Str | dp1_id | dp1_type | dp1_len | dp1_data | … | dpN_id | dpN_type | dpN_len | dpN_data | 
Time_Str: 13-digit Unix timestamp.
| TYPE_bit3_bit0 | The time data for use | 
|---|---|
| 0x01 | Format 1: Report status with the time data from the Bluetooth module | 
| 0x03 | Format 3: Report status with the time data from the MCU | 
| TYPE_bit5_bit4 | Reporting type | 
|---|---|
| 0x00 | Report data both to the cloud and the app panel. | 
| 0x01 | Report data to the cloud but not to the app panel. | 
| 0x02 | Report data to the app panel but not to the cloud. | 
TYPE_bit7_bit6: Reserved
Enum for TYPE field:
unix_time_string: It is required only when TYPE_bit3-bit0 is 0x03.
Example:
Format 1: Report status with the time data from the Bluetooth module.
55 AA 00 E0 00 17 01 66 02 00 04 00 00 00 01 67 03 00 05 72 77 72 77 77 68 04 00 01 00 89
Format 3: Report status with the time data from the MCU
55 AA 00 E0 00 28 03 31 35 38 39 31 36 38 33 32 37 30 30 30 66 02 00 04 00 00 00 01 67 03 00 09 72 77 72 77 77 61 66 61 66 68 04 00 01 00 D0
The module returns the following data.
| No. | Bytes | Field | Description | 
|---|---|---|---|
| 0 1 | 2 | Header | 0x55 0xAA | 
| 2 | 1 | Version number | 0x00 | 
| 3 | 1 | Command (CMD) | 0xE0 | 
| 4 5 | 2 | Data length. | 0x00 0x01 | 
| 6 | 1 | State | Return value | 
| 7 | 1 | CRC8 | Start from the header, add up all the bytes, and then divide the sum by 256 to get the remainder. | 
Return value
After the module is online, it will proactively sync the server time with the MCU.
The MCU returns the following data.
| No. | Bytes | Field | Description | 
|---|---|---|---|
| 0 1 | 2 | Header | 0x55 0xAA | 
| 2 | 1 | Version number | 0x00 | 
| 3 | 1 | Command (CMD) | 0xE1 | 
| 4 5 | 2 | Data length. | 0x00 0x01 | 
| 6 | 1 | Time_Type | See the following table. | 
| 7 | 1 | CRC8 | Start from the header, add up all the bytes, and then divide the sum by 256 to get the remainder. | 
Time_type:
| Time_Type_bit3-bit0 | Time type | 
|---|---|
| 0x00 | Format 0: 7-byte time type and 2-byte time zone value (local time) | 
| 0x01 | Format 1: 13-byte Unix time value in milliseconds and 2-byte time zone value (GMT) | 
| 0x02 | Format 2: 7-byte time type and 2-byte time zone value (local time) | 
It is recommended to use the format 0x02 to request year, month, and day.
| Time_Type_bit5_bit4 | Source of time data | 
|---|---|
| 0x00 | Request the server time through the mobile app. | 
| 0x01 | Request the internal software clock of the module. | 
Time_Type_bit7_bit6: Reserved
Enum for Time_Type:
0x00: Request the server time in format 0 through the mobile app.
0x01: Request the server time in format 1 through the mobile app.
0x02: Request the server time in format 2 through the mobile app.
0x10: Request the internal software clock of the module in format 0.
0x11: Request the internal software clock of the module in format 1.
0x12: Request the internal software clock of the module in format 2.
Request for custom time data in format 0 might cause compatibility issues across different chipset platforms. This format will be deprecated in the future. We recommend you use the date and time format 0x02.
800 represents GMT+8.The module returns the following data.
| No. | Bytes | Field | Description | 
|---|---|---|---|
| 0 1 | 2 | Header | 0x55 0xAA | 
| 2 | 1 | Version number | 0x00 | 
| 3 | 1 | Command (CMD) | 0xE1 | 
| 4 5 | 2 | Data length (Len) | Upper 8 bits Lower 8 bits | 
| 6 to 6+Len-1 | Len | Time_Data | See the following table. | 
| 6+Len | 1 | CRC8 | Start from the header, add up all the bytes, and then divide the sum by 256 to get the remainder. | 
Time_Data format 0:
| Result | Time format | Year | Month | Day | Hour | Minute | Second | Day of week | Time zone | 
|---|---|---|---|---|---|---|---|---|---|
| 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 to 11 | 
| Result | Time_Type | 2018+year | mon | day | hour | min | sec | week | time_zone | 
Time_Data format 1:
| Result | Time format | Unix timestamp in milliseconds | Time zone | 
|---|---|---|---|
| 1 | 2 | 3 to 15 | 16 to 17 | 
| Result | Time_Type | unix_time_string | time_zone | 
Time_Data format 2:
| Result | Time format | Year | Month | Day | Hour | Minute | Second | Day of week | Time zone | 
|---|---|---|---|---|---|---|---|---|---|
| 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 to 11 | 
| Result | Time_Type | 2000+year | mon | day | hour | min | sec | week | time_zone | 
Result is 0x00, it indicates success. All other values indicate failure.week ranges from 1 to 7 to represent Monday to Sunday.Example:
Time_Data format 0:
55 AA 00 E1 00 01 00 E1.55 AA 00 E1 00 0B 00 00 01 0C 1E 0F 34 1F 01 03 20 9C, indicating 15:52:31, Monday, December 30, 2019, GMT+8.Time_Data format 1:
55 AA 00 E1 00 01 01 E2.55 AA 00 E1 00 11 00 01 31 35 37 37 36 39 32 33 39 35 30 30 30 03 20 BB, indicating a timestamp 1577692395000, GMT+8.Time_Data format 2:
55 AA 00 E1 00 01 02 E3.55 AA 00 E1 00 0B 00 02 13 0C 1E 10 09 29 01 03 20 90, indicating 16:09:35, Monday, December 30, 2019, GMT+8.The module sends the following data.
| No. | Bytes | Field | Description | 
|---|---|---|---|
| 0 1 | 2 | Header | 0x55 0xAA | 
| 2 | 1 | Version number | 0x00 | 
| 3 | 1 | Command (CMD) | 0xA1 | 
| 4 5 | 2 | Data length. | 0x00 0x00 | 
| 6 | 1 | CRC8 | Start from the header, add up all the bytes, and then divide the sum by 256 to get the remainder. | 
The MCU returns the following data.
None
The MCU sends the following data.
| No. | Bytes | Field | Description | 
|---|---|---|---|
| 0 1 | 2 | Header | 0x55 0xAA | 
| 2 | 1 | Version number | 0x00 | 
| 3 | 1 | Command (CMD) | 0xA0 | 
| 4 5 | 2 | Data length. | 0x00 0x00 | 
| 6 | 1 | CRC8 | Start from the header, add up all the bytes, and then divide the sum by 256 to get the remainder. | 
The module returns the following data.
| No. | Bytes | Field | Description | 
|---|---|---|---|
| 0 1 | 2 | Header | 0x55 0xAA | 
| 2 | 1 | Version number | 0x00 | 
| 3 | 1 | Command (CMD) | 0xA0 | 
| 4 5 | 2 | Data length. | 0x00 0x06 | 
| 6 to 11 | 6 | DATA | See the following table. | 
| 12 | 1 | CRC8 | Start from the header, add up all the bytes, and then divide the sum by 256 to get the remainder. | 
Data format
| 1 to 3 | 4 to 6 | 
|---|---|
| Soft_Ver | Hard_ver | 
Soft_Ver: The firmware version of the module. For example, 0x01 00 02 represents v1.0.2.Hard_ver: The hardware version of the module, the PCBA version number.The module sends the following data.
| No. | Bytes | Field | Description | 
|---|---|---|---|
| 0 1 | 2 | Header | 0x55 0xAA | 
| 2 | 1 | Version number | 0x00 | 
| 3 | 1 | Command (CMD) | 0xE8 | 
| 4 5 | 2 | Data length. | 0x00 0x00 | 
| 6 | 1 | CRC8 | Start from the header, add up all the bytes, and then divide the sum by 256 to get the remainder. | 
The MCU returns the following data.
| No. | Bytes | Field | Description | 
|---|---|---|---|
| 0 1 | 2 | Header | 0x55 0xAA | 
| 2 | 1 | Version number | 0x00 | 
| 3 | 1 | Command (CMD) | 0xE8 | 
| 4 5 | 2 | Data length. | 0x00 0x06 | 
| 6 to 11 | 6 | DATA | See the following table. | 
| 12 | 1 | CRC8 | Start from the header, add up all the bytes, and then divide the sum by 256 to get the remainder. | 
Data format
| 1 to 3 | 4 to 6 | 
|---|---|
| Soft_Ver | Hard_ver | 
Soft_Ver: The firmware version of the MCU. For example, 0x01 00 02 represents v1.0.2.
Hard_ver: The hardware version of the MCU, the PCBA version number.
The MCU returns the following data.
| No. | Bytes | Field | Description | 
|---|---|---|---|
| 0 1 | 2 | Header | 0x55 0xAA | 
| 2 | 1 | Version number | 0x00 | 
| 3 | 1 | Command (CMD) | 0xE9 | 
| 4 5 | 2 | Data length. | 0x00 0x06 | 
| 6 to 11 | 6 | DATA | See the following table. | 
| 12 | 1 | CRC8 | Start from the header, add up all the bytes, and then divide the sum by 256 to get the remainder. | 
Data format
| 1 to 3 | 4 to 6 | 
|---|---|
| Soft_Ver | Hard_ver | 
Soft_Ver: The firmware version of the MCU. For example, 0x01 00 02 represents v1.0.2.Hard_ver: The hardware version of the MCU, the PCBA version number.The module returns the following data.
| No. | Bytes | Field | Description | 
|---|---|---|---|
| 0 1 | 2 | Header | 0x55 0xAA | 
| 2 | 1 | Version number | 0x00 | 
| 3 | 1 | Command (CMD) | 0xE9 | 
| 4 5 | 2 | Data length. | 0x00 0x01 | 
| 6 | 1 | State | Return value | 
| 7 | 1 | CRC8 | Start from the header, add up all the bytes, and then divide the sum by 256 to get the remainder. | 
Return value

The module sends the following data.
| No. | Bytes | Field | Description | 
|---|---|---|---|
| 0 1 | 2 | Header | 0x55 0xAA | 
| 2 | 1 | Version number | 0x00 | 
| 3 | 1 | Command (CMD) | 0xEA | 
| 4 5 | 2 | Data length. | 0x00 0x02 | 
| 6 to 7 | 2 | The maximum length of one packet Len1 | See the information below. | 
| 8 | 1 | CRC8 | Start from the header, add up all the bytes, and then divide the sum by 256 to get the remainder. | 
Len1: The size of the largest packet that can be transmitted over the serial port, in the unit of bytes.
Example: 55 AA 00 EA 00 02 00 C8 B3
The MCU returns the following data.
| No. | Bytes | Field | Description | 
|---|---|---|---|
| 0 1 | 2 | Header | 0x55 0xAA | 
| 2 | 1 | Version number | 0x00 | 
| 3 | 1 | Command (CMD) | 0xEA | 
| 4 5 | 2 | Data length. | 0x00 0x06 | 
| 6 to 11 | 6 | Data | See the following table. | 
| 12 | 1 | CRC8 | Start from the header, add up all the bytes, and then divide the sum by 256 to get the remainder. | 
Data format
| 1 | 2 to 4 | 5 to 6 | 
|---|---|---|
| Flag | The MCU’s current firmware version ( Version) | The MCU-specified maximum length of one packet ( Len2) | 
Flag: 0x00 indicates the update is accepted. 0x01 indicates the update is rejected.Version: The current firmware version. For example, 0x01 00 02 represents v1.0.2.Len1: The module-specified maximum length of one packet.Len2: The MCU-specified maximum length of one packet. If len1 is less than len2, len1 prevails. Otherwise, len2 prevails.Example: 55 AA 00 EA 00 06 00 01 00 00 00 C8 B8
The module sends the following data.
| No. | Bytes | Field | Description | 
|---|---|---|---|
| 0 1 | 2 | Header | 0x55 0xAA | 
| 2 | 1 | Version number | 0x00 | 
| 3 | 1 | Command (CMD) | 0xEB | 
| 4 5 | 2 | Data length. | 0x00 0x23 | 
| 6 to 40 | 35 | Data | See the following table. | 
| 41 | 1 | CRC8 | Start from the header, add up all the bytes, and then divide the sum by 256 to get the remainder. | 
Data format
| 8 bytes | 3 bytes | 16 bytes | 4 bytes | 4 bytes | 
|---|---|---|---|---|
| PID | The firmware version. | The MD5 hash. | The file length. | CRC32 checksum. | 
0x010002 represents v1.0.2.The MCU returns the following data.
| No. | Bytes | Field | Description | 
|---|---|---|---|
| 0 1 | 2 | Header | 0x55 0xAA | 
| 2 | 1 | Version number | 0x00 | 
| 3 | 1 | Command (CMD) | 0xEB | 
| 4 5 | 2 | Data length. | 0x00 0x19 | 
| 6 to 30 | 25 | Data | See the following table. | 
| 31 | 1 | CRC8 | Start from the header, add up all the bytes, and then divide the sum by 256 to get the remainder. | 
Data format
| 1 byte | 4 bytes | 4 bytes | 16 bytes | 
|---|---|---|---|
| STATE | The size of the update that has already been downloaded. | The CRC32 checksum of the update that has already been downloaded. | The MD5 hash value of the update that has already been downloaded. (Not used currently) | 
STATE:
0x00: The update is performed as expected.
0x01: The received PID does not match the one written to the device.
0x02: The update version is earlier than or equal to the current version.
0x03: The update size exceeds the upper limit.
Other fields: Reserved
For more information about the support for protocols, see Firmware types.
The module sends the following data.
| No. | Bytes | Field | Description | 
|---|---|---|---|
| 0 1 | 2 | Header | 0x55 0xAA | 
| 2 | 1 | Version number | 0x00 | 
| 3 | 1 | Command (CMD) | 0xEC | 
| 4 5 | 2 | Data length. | 0x00 0x04 | 
| 6 to 9 | 4 | Offset | See the following table. | 
| 10 | 1 | CRC8 | Start from the header, add up all the bytes, and then divide the sum by 256 to get the remainder. | 
offset: indicate where to start downloading the update.
The MCU returns the following data.
| No. | Bytes | Field | Description | 
|---|---|---|---|
| 0 1 | 2 | Header | 0x55 0xAA | 
| 2 | 1 | Version number | 0x00 | 
| 3 | 1 | Command (CMD) | 0xEC | 
| 4 5 | 2 | Data length. | 0x00 0x04 | 
| 6 to 9 | 4 | Offset | See the following table. | 
| 10 | 1 | CRC8 | Start from the header, add up all the bytes, and then divide the sum by 256 to get the remainder. | 
offset: the start offset specified by the MCU.
The start offset address specified by the MCU should take precedence over the one provided by the app. The MCU-specified offset is usually less than the one provided by the app.
For more information about the support for protocols, see Firmware types.
The module sends the following data.
| No. | Bytes | Field | Description | 
|---|---|---|---|
| 0 1 | 2 | Header | 0x55 0xAA | 
| 2 | 1 | Version number | 0x00 | 
| 3 | 1 | Command (CMD) | 0xED | 
| 4 5 | 2 | Data length (Len) | Upper 8 bits Lower 8 bits | 
| 6 to 6+Len-1 | Len | Data | See the following table. | 
| 6+Len | 1 | CRC8 | Start from the header, add up all the bytes, and then divide the sum by 256 to get the remainder. | 
Data format
| 2 bytes | 2 bytes | 2 bytes | n byte(s) | 
|---|---|---|---|
| Packet ID | The size of the current packet n | The CRC16 checksum of the current packet | The payload of the current packet | 
The packet ID starts from 0. The size of the current packet cannot exceed the specified maximum length of one packet.
The MCU returns the following data.
| No. | Bytes | Field | Description | 
|---|---|---|---|
| 0 1 | 2 | Header | 0x55 0xAA | 
| 2 | 1 | Version number | 0x00 | 
| 3 | 1 | Command (CMD) | 0xED | 
| 4 5 | 2 | Data length. | 0x00 0x01 | 
| 6 | 1 | State | Return value | 
| 7 | 1 | CRC8 | Start from the header, add up all the bytes, and then divide the sum by 256 to get the remainder. | 
Return value
For more information about the support for protocols, see Firmware types.
The module sends the following data.
| No. | Bytes | Field | Description | 
|---|---|---|---|
| 0 1 | 2 | Header | 0x55 0xAA | 
| 2 | 1 | Version number | 0x00 | 
| 3 | 1 | Command (CMD) | 0xEE | 
| 4 5 | 2 | Data length. | 0x00 0x00 | 
| 6 | 1 | CRC8 | Start from the header, add up all the bytes, and then divide the sum by 256 to get the remainder. | 
The MCU returns the following data.
| No. | Bytes | Field | Description | 
|---|---|---|---|
| 0 1 | 2 | Header | 0x55 0xAA | 
| 2 | 1 | Version number | 0x00 | 
| 3 | 1 | Command (CMD) | 0xEE | 
| 4 5 | 2 | Data length. | 0x00 0x01 | 
| 6 | 1 | State | Return value | 
| 7 | 1 | CRC8 | Start from the header, add up all the bytes, and then divide the sum by 256 to get the remainder. | 
Return value
Perform the received signal strength indicator (RSSI) test on modules to measure the RF performance.
Test tool:
ty_mdev.Test steps:
Some chip models such as BK3431Q and BK3432 do not support scanning for a designated beacon. You need to perform an RF test with a dongle.
The MCU sends the following data.
| No. | Bytes | Field | Description | 
|---|---|---|---|
| 0 1 | 2 | Header | 0x55 0xAA | 
| 2 | 1 | Version number | 0x00 | 
| 3 | 1 | Command (CMD) | 0x0E | 
| 4 5 | 2 | Data length. | 0x00 0x00 | 
| 6 | 1 | CRC8 | Start from the header, add up all the bytes, and then divide the sum by 256 to get the remainder. | 
The module returns the following data.
| No. | Bytes | Field | Description | 
|---|---|---|---|
| 0 1 | 2 | Header | 0x55 0xAA | 
| 2 | 1 | Version number | 0x00 | 
| 3 | 1 | Command (CMD) | 0x0E | 
| 4 5 | 2 | Data length (Len) | Upper 8 bits Lower 8 bits | 
| 6 to 6+Len-1 | Len | Data | See the following table. | 
| 6+Len | 1 | CRC8 | Start from the header, add up all the bytes, and then divide the sum by 256 to get the remainder. | 
Data format
| Data | Description | 
|---|---|
| {“ret”:true,“rssi”:“-55”} | The RSSI is -55 dB. | 
| {“ret”:false} | The designated signal is not found. | 
The module can operate in low power or standard power mode.
Standard power mode: The advertising interval is about 100 ms, which is not configurable currently. The two-way serial communication works.
Low power mode: The advertising interval is set by the MCU, defaulting to 1 second. If the interval is 0, advertising is turned off. For serial communication, the module only sends data to but does not receive data from the MCU.
After BK3432 enters low power mode, it will proactively disconnect from Bluetooth and turn off advertising.
The MCU can pull down or up the low power pin on the module to make the module enter or exit the low power mode. Lowpower_moudle_enable indicates whether you need to use the command 0xE5 to enable low power mode, as shown in the following table.
| Chip (product category) | Lowpower_moudle_enable | Moudle_wakeup_pin | Wakeup_level | Idle_level | 
|---|---|---|---|---|
| TLSR825x (all) | Need | TL_B5 | High | Low | 
| PHY6222 (all) | Need | P26 | High | Low | 
| BK3432 (all) | Need | P03 (configurable) | High | Low | 
| BK3431Q (locks) | Not need | P03 | High | Low | 
| nRF52832 (locks) | Not need | I/O11 | Low | High | 
| FR8016 (all) | Need | PA0 | High | Low | 
After the module wakes up, a 100 ms time delay before serial communication is recommended. After waking up from deep sleep, Telink based modules need one second for startup.
To send data to the MCU, the module will wake up the MCU with the wakeup_level and then wait for a specified time before starting serial transmission. After data is sent, the wake-up pin will go back to the Idle_level, as shown in the following table.
| Chip (product category) | Lowpower_moudle_enable | Wakeup_mcu_pin | Wakeup_level | Idle_level | 
|---|---|---|---|---|
| TLSR825x (all) | Need | TL_D2 | High | Low | 
| PHY6222 (all) | Need | P31 | High | Low | 
| BK3432 (all) | Need | / | / | / | 
| BK3431Q (locks) | Not need | P10 | High | Low | 
| nRF52832 (locks) | Not need | I/O 14 | Low | High | 
| FR8016 (all) | Need | PA1 | High | Low | 
For more information about the wake-up time, see Configure MCU wake-up (0xB0).
Each time the module is connected to the cloud, it will sync the internal clock with the app time. The accuracy of the module’s internal clock depends on the crystal oscillator. If your product requires accurate time, make sure to measure the accuracy of the internal clock. If you have any questions about measuring clock accuracy, submit a service ticket. The internal clock is reset after the power is turned off.
You can turn off the system timer in low power mode to reduce power consumption.
When the supply voltage is below the operating voltage, operations on the flash memory of the module might cause errors in firmware or user data. You can try the following methods to avoid this issue:
When the MCU detects a low battery level, it powers off the module or turns off advertising and makes the module enter sleep mode.
When the module detects a low battery level, it enters sleep mode.
The wake-up pin configuration varies depending on chipset platforms. Do not leave the wake-up pin on the MCU floating.
Lowpower_moudle_enable of your module is Need, the MCU must send this command to the module to enable the low power feature. This way, Moudle_wakeup_pin can control the operation mode of the module. The configuration is stored in the nonvolatile memory.The MCU sends the following data.
| No. | Bytes | Field | Description | 
|---|---|---|---|
| 0 1 | 2 | Header | 0x55 0xAA | 
| 2 | 1 | Version number | 0x00 | 
| 3 | 1 | Command (CMD) | 0xE5 | 
| 4 5 | 2 | Data length. | 0x00 0x01 | 
| 6 | 1 | Data | See the following table. | 
| 7 | 1 | CRC8 | Start from the header, add up all the bytes, and then divide the sum by 256 to get the remainder. | 
The valid values:
The module returns the following data.
| No. | Bytes | Field | Description | 
|---|---|---|---|
| 0 1 | 2 | Header | 0x55 0xAA | 
| 2 | 1 | Version number | 0x00 | 
| 3 | 1 | Command (CMD) | 0xE5 | 
| 4 5 | 2 | Data length. | 0x00 0x01 | 
| 6 | 1 | State | Return value | 
| 7 | 1 | CRC8 | Start from the header, add up all the bytes, and then divide the sum by 256 to get the remainder. | 
Return value
To further reduce the power consumption in sleep mode, you can use this command to turn off the system timer. If your MCU does not need timekeeping, you can also turn off the system timer. The configuration is stored in the nonvolatile memory.
For BK3431Q and TYBN1 modules, writing time data to flash memory is high power consumption and is turned off in sleep mode by default. The timekeeping function is still available because it uses less power. After you turn on the system timer, the time will be saved to the flash memory every one minute, which can fix the issue of clock reset after the module is restarted. The system timer is turned off by default.
With both the timer and advertising turned off, the Telink-based module can enter deep sleep with the power consumption reduced to 3 μA. After waking up, the module will restart.
The MCU sends the following data.
| No. | Bytes | Field | Description | 
|---|---|---|---|
| 0 1 | 2 | Header | 0x55 0xAA | 
| 2 | 1 | Version number | 0x00 | 
| 3 | 1 | Command (CMD) | 0xE4 | 
| 4 5 | 2 | Data length. | 0x00 0x01 | 
| 6 | 1 | Data | See the following table. | 
| 7 | 1 | CRC8 | Start from the header, add up all the bytes, and then divide the sum by 256 to get the remainder. | 
The valid values:
The module returns the following data.
| No. | Bytes | Field | Description | 
|---|---|---|---|
| 0 1 | 2 | Header | 0x55 0xAA | 
| 2 | 1 | Version number | 0x00 | 
| 3 | 1 | Command (CMD) | 0xE4 | 
| 4 5 | 2 | Data length. | 0x00 0x01 | 
| 6 | 1 | State | Return value | 
| 7 | 1 | CRC8 | Start from the header, add up all the bytes, and then divide the sum by 256 to get the remainder. | 
Return value
This command only applies to the BK3432 generic firmware.
You can use this command to set the custom pin to wake up the module from sleep. You can invoke this command after the UART initialization to configure the custom pin.
The configuration is stored in the nonvolatile memory.
For more information about the support for protocols, see Firmware types.
Since the module stops receiving serial data in the low power mode, the MCU must send this command within one second after the module is powered on, or before enabling the low power feature.
The MCU sends the following data.
| No. | Bytes | Field | Description | 
|---|---|---|---|
| 0 1 | 2 | Header | 0x55 0xAA | 
| 2 | 1 | Version number | 0x00 | 
| 3 | 1 | Command (CMD) | 0xE3 | 
| 4 5 | 2 | Data length. | 0x00 0x06 | 
| 6 to 11 | 6 | Payload data CFG | See the following table. | 
| 12 | 1 | CRC8 | Start from the header, add up all the bytes, and then divide the sum by 256 to get the remainder. | 
Payload in CFG format
| 4 bytes | 1 byte | 1 byte | 
|---|---|---|
| PIN_NUM | Reserved | Reserved | 
PIN_NUM is a reserved field in big-endian format. It is not parsed so you can set it to 0xff or 0x00. If you have any questions about PIN_NUM, submit a service ticket.
Example:
Set the P03 on BK3432 as the wake-up pin. The PIN_NUM for P03 is 0x03.
55 AA 00 E3 00 06 00 00 00 03 00 00 EB
Set the P11 on BK3432 as the wake-up pin. The PIN_NUM for P11 is 0x11.
55 AA 00 E3 00 06 00 00 00 11 00 00 F9
The configurable pins on BK3432 are P02, P03, P04, P05, P10, P11, P12, P13, P34, P14, P35, P32. and P31. The PIN_NUM for Pxx on BK3432 is 0xxx.
The module returns the following data.
| No. | Bytes | Field | Description | 
|---|---|---|---|
| 0 1 | 2 | Header | 0x55 0xAA | 
| 2 | 1 | Version number | 0x00 | 
| 3 | 1 | Command (CMD) | 0xE3 | 
| 4 5 | 2 | Data length. | 0x00 0x01 | 
| 6 | 1 | State | Return value | 
| 7 | 1 | CRC8 | Start from the header, add up all the bytes, and then divide the sum by 256 to get the remainder. | 
Return value
You can use this command to set the time (t) used for waking up the MCU from sleep.
The module pulls up or down the wake-up pin for a specified time (t) before sending data to the MCU.
After modification, you must verify whether the specified time works. If not, you need to set a larger value.
You can invoke this command after the MCU receives the command 0x02. The configuration is stored in the volatile memory so it will reset to default when the module is turned off or restarted.
For more information about the support for protocols, see Firmware types.
The MCU sends the following data.
| No. | Bytes | Field | Description | 
|---|---|---|---|
| 0 1 | 2 | Header | 0x55 0xAA | 
| 2 | 1 | Version number | 0x00 | 
| 3 | 1 | Command (CMD) | 0xB0 | 
| 4 5 | 2 | Data length. | 0x00 0x01 | 
| 6 | 1 | interval | See the information below. | 
| 7 | 1 | CRC8 | Start from the header, add up all the bytes, and then divide the sum by 256 to get the remainder. | 
interval indicates the unit of the wake-up time. The value ranges from 1 to 20, which means 10 ms to 200 ms.
Example:
55 aa 00 E2 00 01 00 E2, indicating advertising is turned off in low power mode.55 aa 00 E2 00 01 06 E8, indicating the advertising interval is 600 ms in low power mode.The module returns the following data.
| No. | Bytes | Field | Description | 
|---|---|---|---|
| 0 1 | 2 | Header | 0x55 0xAA | 
| 2 | 1 | Version number | 0x00 | 
| 3 | 1 | Command (CMD) | 0xB0 | 
| 4 5 | 2 | Data length. | 0x00 0x01 | 
| 6 | 1 | State | Return value | 
| 7 | 1 | CRC8 | Start from the header, add up all the bytes, and then divide the sum by 256 to get the remainder. | 
Return value
This section describes how to implement the extended features such as dynamic data reporting, bulk data storage, file download, and weather services. You can implement these features as needed.
The MCU sends the following data.
| No. | Bytes | Field | Description | 
|---|---|---|---|
| 0 1 | 2 | Header | 0x55 0xAA | 
| 2 | 1 | Version number | 0x00 | 
| 3 | 1 | Command (CMD) | 0xA4 | 
| 4 5 | 2 | Data length (Len) | Upper 8 bits Lower 8 bits | 
| 6 to 6+Len-1 | Len | Data | See the following table. | 
| 6+Len | 1 | CRC8 | Start from the header, add up all the bytes, and then divide the sum by 256 to get the remainder. | 
Data format
| 2 bytes | 1 byte | 1 byte | (Optional) 13 bytes | m byte(s) | 
|---|---|---|---|---|
| Sequence number (SN) | Flag | Time_flag | Time_date | DP | 
Sequence number (SN): two bytes in length, in big-endian (high byte first) format.
Flag:
Time_flag:
Time_date: 13-digit Unix timestamp. This field is required when Time_flag is set to 0x01.
DP data: the payload. For more information, see DP format.
For example, dynamic data is only reported to the app panel and without the time data.
55 AA 00 A4 00 0B 00 FF 02 02 65 00 00 03 13 23 66 B5
The module returns the following data.
| No. | Bytes | Field | Description | 
|---|---|---|---|
| 0 1 | 2 | Header | 0x55 0xAA | 
| 2 | 1 | Version number | 0x00 | 
| 3 | 1 | Command (CMD) | 0xA4 | 
| 4 5 | 2 | Data length. | 0x00 0x04 | 
| 6 to 9 | 4 | Data | See the following table. | 
| 10 | 1 | CRC8 | Start from the header, add up all the bytes, and then divide the sum by 256 to get the remainder. | 
Data format
| 2 bytes | 1 byte | 1 byte | 
|---|---|---|
| Sequence number (SN) | Flag | State | 
0x00 indicates success. All other values indicate failure.The MCU sends the following data.
| No. | Bytes | Field | Description | 
|---|---|---|---|
| 0 1 | 2 | Header | 0x55 0xAA | 
| 2 | 1 | Version number | 0x00 | 
| 3 | 1 | Command (CMD) | 0xB5 | 
| 4 5 | 2 | Data length (Len) | Upper 8 bits Lower 8 bits | 
| 6 | 1 | SubCmd | See the information below. | 
| 7 to 7+Len-1 | Len | Data | See the information below. | 
| 7+Len | 1 | CRC8 | Start from the header, add up all the bytes, and then divide the sum by 256 to get the remainder. | 
SubCmd (Subcommand):
The format of the Data field varies depending on subcommands. The module parses data according to the SubCmd and the Data format.
When SubCmd is 0x00, the format of the Data field is as follows:
| 1 to 3 | 4 | 5 to x | x | x+1 | x+2 to x+3 | x+4 and greater | … | n | n+1 | n+1 to n+2 | n+3 and greater | 
|---|---|---|---|---|---|---|---|---|---|---|---|
| Res | TYPE | Time_Str | dp1_id | dp1_type | dp1_len | dp1_data | … | dpN_id | dpN_type | dpN_len | dpN_data | 
Res: 3-byte reserved field. Set it to 0x00.
| TYPE | The time data for use | 
|---|---|
| 0x01 | Format 1: Report status with the time data from the Bluetooth module | 
| 0x03 | Format 3: Report status with the time data from the MCU | 
Time_Str:
TYPE is 0x03.When SubCmd is 0x01, the format of the Data field is as follows:
| CFG (1 byte) | Description | 
|---|---|
| 0x00 | Store small data that can contain two DPs of value type. dplen1+3+[dplen2+3]+[dplen_n+3]≤ 17 | 
| 0x01 | Store medium data that can contain six DPs of value type. dplen1+3+[dplen2+3]+[dplen_n+3]≤ 49. | 
| 0x02 | The default configuration dplen1+3+[dplen2+3]+[dplen_n+3]≤ 113 | 
When CFG is changed, the module will clear the bulk data storage.
The module returns the following data.
| No. | Bytes | Field | Description | 
|---|---|---|---|
| 0 1 | 2 | Header | 0x55 0xAA | 
| 2 | 1 | Version number | 0x00 | 
| 3 | 1 | Command (CMD) | 0xB5 | 
| 4 5 | 2 | Data length. | 0x00 0x01 | 
| 6 | 1 | SubCmd | See the following table. | 
| 7 to 7+Len-1 | Len | Data | See the information below. | 
| 7+Len | 1 | CRC8 | Start from the header, add up all the bytes, and then divide the sum by 256 to get the remainder. | 
SubCmd (Subcommand):
The format of the Data field varies depending on subcommands. The module parses data according to the SubCmd and the Data format.
When SubCmd is 0x00, the format of the Data field is as follows:
STATE (1 byte):
When SubCmd is 0x01, the format of the Data field is as follows:
| 1 | 2 | 3 to 4 | 
|---|---|---|
| STATE | MAX_SIZE | TOTAL_NUM | 
MAX_SIZE: The maximum length of a piece of data.TOTAL_NUM: The total number of pieces of data that can be stored.Example:
55 aa 00 b5 00 02 01 00 B7.55 aa 00 b5 00 02 01 01 B8.55 aa 00 b5 00 02 01 02 B9.55 AA 00 B5 00 12 00 01 01 02 00 04 00 00 01 04 02 02 00 04 00 00 00 DB.The MCU sends the following data.
| No. | Bytes | Field | Description | 
|---|---|---|---|
| 0 1 | 2 | Header | 0x55 0xAA | 
| 2 | 1 | Version number | 0x00 | 
| 3 | 1 | Command (CMD) | 0xB6 | 
| 4 5 | 2 | Data length (Len) | Upper 8 bits Lower 8 bits | 
| 6 to 6+Len-1 | Len | Data | See the information below. | 
| 6+Len | 1 | CRC8 | Start from the header, add up all the bytes, and then divide the sum by 256 to get the remainder. | 
Data description:
| Location | Weather parameter | Number of forecast days | 
|---|---|---|
| 1 byte | 4 bytes | 1 byte | 
Location:
Weather parameter
(1 << 0), /**< temperature. */
(1 << 1), /**< high temperature. */
(1 << 2), /**< low temperature. */
(1 << 3), /**< humidity. */
(1 << 4), /**< weather condition. */
(1 << 5), /**< pressure. */
(1 << 6), /**< sensible temperature. */
(1 << 7), /**< uvi. */
(1 << 8), /**< sunrise. */
(1 << 9), /**< sunset. */
(1 << 10), /**< unix time, Use with sunrise and sunset. */
(1 << 11), /**< local time, Use with sunrise and sunset. */
(1 << 12), /**< wind speed. */
(1 << 13), /**< wind direction. */
(1 << 14), /**< wind speed scale/level. */
(1 << 15), /**< aqi. */
(1 << 16), /**< tips. */
(1 << 17), /**< Detailed AQI status and national ranking. */
(1 << 18), /**< pm10. */
(1 << 19), /**< pm2.5. */
(1 << 20), /**< o3. */
(1 << 21), /**< no2. */
(1 << 22), /**< co. */
(1 << 23), /**< so2. */
(1 << 24), /**< weather condition mapping id. */
Number of forecast days: Specifies the number of days for which the server returns forecast data. The valid value ranges from 1 to 7 (1 indicates today). For more information, see the Appendix.
The module returns the following data.
| No. | Bytes | Field | Description | 
|---|---|---|---|
| 0 1 | 2 | Header | 0x55 0xAA | 
| 2 | 1 | Version number | 0x00 | 
| 3 | 1 | Command (CMD) | 0xB6 | 
| 4 5 | 2 | Data length (Len) | Upper 8 bits Lower 8 bits | 
| 6 to 6+Len-1 | Len | Data | See the information below. | 
| 6+Len | 1 | CRC8 | Start from the header, add up all the bytes, and then divide the sum by 256 to get the remainder. | 
Data description: status (1 byte) + weather_values (0 bytes or Len-1 bytes).
Status:
0x00: Success
0x01: Parameter error
0x02: Request failed
0x03: Request timeout
0x04: Repeated request
0x05: Status error
Weather_values: The value of weather, which is valid when status is 0x00. For more information about the data format, see the following table.
| Day | Weather parameter (little-endian) | Data type | Data length | Data | … | 
|---|---|---|---|---|---|
| 1 byte | 4 bytes | 1 byte | 1 byte | x byte(s) | … | 
Data type:
0x00: Integer0x01: StringExample:
The MCU sends the following data to the module:
55 AA 00 B6 00 06 01 00 00 00 0F 01 CC 
The module returns the following data to the MCU:
55 AA 00 B6 00 2D 00 01 01 00 00 00 00 04 00 00 00 21 01 02 00 00 00 00 04 00 00 00 24 01 04 00 00 00 00 04 00 00 00 1C 01 08 00 00 00 00 04 00 00 00 44 AA
The MCU sends the following data.
| No. | Bytes | Field | Description | 
|---|---|---|---|
| 0 1 | 2 | Header | 0x55 0xAA | 
| 2 | 1 | Version number | 0x00 | 
| 3 | 1 | Command (CMD) | 0xBC | 
| 4 5 | 2 | Data length (Len) | Upper 8 bits Lower 8 bits | 
| 6 to 6+Len-1 | Len | Data | See the description below. | 
| 6+Len | 1 | CRC8 | Start from the header, add up all the bytes, and then divide the sum by 256 to get the remainder. | 
Data description:
| ENABLE | ON_OFF | TIME | 
|---|---|---|
| 1 byte | 1 byte | 2 bytes | 
ENABLE:
0x00: Disable the triggered pairing mode, using the default pairing mode. When you set this field to 0x00, the module does not parse the subsequent fields.0x01: Enable the triggered pairing mode.ON_OFF:
0x00: Exit pairing mode immediately. When you set this field to 0x00, the module does not parse the subsequent fields.0x01: Enter pairing mode immediately.TIME: Timeout for triggering pairing mode, in seconds, ranging from 10 to 600.The module returns the following data.
| No. | Bytes | Field | Description | 
|---|---|---|---|
| 0 1 | 2 | Header | 0x55 0xAA | 
| 2 | 1 | Version number | 0x00 | 
| 3 | 1 | Command (CMD) | 0xBC | 
| 4 5 | 2 | Data length (Len) | Upper 8 bits Lower 8 bits | 
| 6 to 6+Len-1 | Len | Status | See the description below. | 
| 6+Len | 1 | CRC8 | Start from the header, add up all the bytes, and then divide the sum by 256 to get the remainder. | 
Status:
0x00: Success0x01: Parameter error0x02: Request failed0x03: Status error (The device is not in the unbound state.)This feature allows the user to control a device using a physical Bluetooth remote control. It is disabled by default.
CFG field, the module will allow pairing with a Bluetooth remote control within 30 seconds of powering on.CFG field, the MCU can accept or reject the pairing request.The MCU sends the following data.
| No. | Bytes | Field | Description | 
|---|---|---|---|
| 0 1 | 2 | Header | 0x55 0xAA | 
| 2 | 1 | Version number | 0x00 | 
| 3 | 1 | Command (CMD) | 0xC1 | 
| 4 5 | 2 | Data length | 0x00 0x02 | 
| 6 | 1 | Subcommand | 0x00 | 
| 78 | 2 | Data | 
 | 
| 9 | 1 | CRC8 | Start from the header, add up all the bytes, and then divide the sum by 256 to get the remainder. | 
Example: 55 AA 00 C1 00 03 00 01 05 C9, meaning to enable the Bluetooth remote control.
The module returns the following data.
| No. | Bytes | Field | Description | 
|---|---|---|---|
| 0 1 | 2 | Header | 0x55 0xAA | 
| 2 | 1 | Version number | 0x00 | 
| 3 | 1 | Command (CMD) | 0xC1 | 
| 4 5 | 2 | Data length | 0x00 0x02 | 
| 6 | 1 | Subcommand | 0x00 | 
| 7 | 1 | Data | 
 | 
| 8 | 1 | CRC8 | Start from the header, add up all the bytes, and then divide the sum by 256 to get the remainder. | 
The module sends the following data.
| No. | Bytes | Field | Description | 
|---|---|---|---|
| 0 1 | 2 | Header | 0x55 0xAA | 
| 2 | 1 | Version number | 0x00 | 
| 3 | 1 | Command (CMD) | 0xC1 | 
| 4 5 | 2 | Data length | 0x00 0x06 | 
| 6 | 1 | Subcommand | 0x01 | 
| Data | 
 | ||
| 13 | 1 | CRC8 | Start from the header, add up all the bytes, and then divide the sum by 256 to get the remainder. | 
The MCU returns the following data.
| No. | Bytes | Field | Description | 
|---|---|---|---|
| 0 1 | 2 | Header | 0x55 0xAA | 
| 2 | 1 | Version number | 0x00 | 
| 3 | 1 | Command (CMD) | 0xC1 | 
| 4 5 | 2 | Data length | 0x00 0x01 | 
| 6 | 1 | Subcommand | 0x01 | 
| 7 | 1 | CRC8 | Start from the header, add up all the bytes, and then divide the sum by 256 to get the remainder. | 
This feature applies when you enable the Bluetooth remote control.
The module sends the following data.
| No. | Bytes | Field | Description | 
|---|---|---|---|
| 0 1 | 2 | Header | 0x55 0xAA | 
| 2 | 1 | Version number | 0x00 | 
| 3 | 1 | Command (CMD) | 0xC1 | 
| 4 5 | 2 | Data length | 0x00 0x03 | 
| 6 | 1 | Subcommand | 0x02 | 
| 7 8 | 2 | Data | 
 | 
| 9 | 1 | CRC8 | Start from the header, add up all the bytes, and then divide the sum by 256 to get the remainder. | 
The following table lists the frame format for Bluetooth and network module combo protocol.
| No. | Bytes | Field | Description | 
|---|---|---|---|
| 0 1 | 2 | Header | 0x55 0xAA | 
| 2 | 1 | Version number | 0x00 | 
| 3 | 1 | Command (CMD) | 0xC0 | 
| 4 5 | 2 | Data length (Len) | Upper 8 bits Lower 8 bits | 
| 6 to 6+Len-1 | 1 | SubCmd | The subcommand. | 
| Len-1 | Data | The subcommand data. | |
| 6+Len | 1 | CRC8 | Start from the header, add up all the bytes, and then divide the sum by 256 to get the remainder. | 
The MCU can use this command to access the network module (such as the LTE Cat.1 module) as instructed in LTE Cat.1 Serial Port Protocol to get information, such as positioning information.
Frame format:
| No. | Bytes | Field | Description | 
|---|---|---|---|
| 0 1 | 2 | Header | 0x55 0xAA | 
| 2 | 1 | Version number | 0x00 | 
| 3 | 1 | Command (CMD) | 0xC0 | 
| 4 5 | 2 | Data length (Len) | Upper 8 bits Lower 8 bits | 
| 6 to 6+Len-1 | 1 | SubCmd | 0x00 | 
| Len-1 | DATA | Includes the version number, command, data length, and data fields for the pass-through protocol. | |
| 6+Len | 1 | CRC8 | Start from the header, add up all the bytes, and then divide the sum by 256 to get the remainder. | 
 
The MCU sends the following data.
| No. | Bytes | Field | Description | 
|---|---|---|---|
| 0 1 | 2 | Header | 0x55 0xAA | 
| 2 | 1 | Version number | 0x00 | 
| 3 | 1 | Command (CMD) | 0xC0 | 
| 4 5 | 2 | Data length (Len) | Upper 8 bits Lower 8 bits | 
| 6 to 6+Len-1 | 1 | SubCmd | 0x01 | 
| Len-1 | DATA | See the following table. | |
| 6+Len | 1 | CRC8 | Start from the header, add up all the bytes, and then divide the sum by 256 to get the remainder. | 
Data format:
| 1 byte | 1 byte | 
|---|---|
| op_type | op_object | 
op_type:
0x01: Notify. When the MCU bypasses the Bluetooth module and directly controls the power on/off of the extended module, it notifies the Bluetooth module to update the power status.0x02: Control. The MCU controls the power on/off of the extended module through the specific pin on the Bluetooth module.0x03: Read. The MCU reads the power status of the extended module.op_object:
bit0: The pin to control the power of the extended module 1 (cellular module). 0 indicates power off and 1 indicates power on.bit1: The pin to control the power of the extended module 2 (GPS module). 0 indicates power off and 1 indicates power on.The module returns the following data.
| No. | Bytes | Field | Description | 
|---|---|---|---|
| 0 1 | 2 | Header | 0x55 0xAA | 
| 2 | 1 | Version number | 0x00 | 
| 3 | 1 | Command (CMD) | 0xC0 | 
| 4 5 | 2 | Data length (Len) | Upper 8 bits Lower 8 bits | 
| 6 to 6+Len-1 | 1 | SubCmd | 0x01 | 
| Len-1 | DATA | See the following table. | |
| 6+Len | 1 | CRC8 | Start from the header, add up all the bytes, and then divide the sum by 256 to get the remainder. | 
Data format:
| 1 byte | 1 byte | 1 byte | 
|---|---|---|
| op_type | op_object | status | 
Status:
The MCU sends the following data.
| No. | Bytes | Field | Description | 
|---|---|---|---|
| 0 1 | 2 | Header | 0x55 0xAA | 
| 2 | 1 | Version number | 0x00 | 
| 3 | 1 | Command (CMD) | 0xC0 | 
| 4 5 | 2 | Data length (Len) | Upper 8 bits Lower 8 bits | 
| 6 | 1 | SubCmd | 0x02 | 
| 7 | 1 | CRC8 | Start from the header, add up all the bytes, and then divide the sum by 256 to get the remainder. | 
The module returns the following data.
| No. | Bytes | Field | Description | 
|---|---|---|---|
| 0 1 | 2 | Header | 0x55 0xAA | 
| 2 | 1 | Version number | 0x00 | 
| 3 | 1 | Command (CMD) | 0xC0 | 
| 4 5 | 2 | Data length (Len) | Upper 8 bits Lower 8 bits | 
| 6 | 1 | SubCmd | 0x02 | 
| 7 | 1 | Status | 
 | 
| 8 | 1 | CRC8 | Start from the header, add up all the bytes, and then divide the sum by 256 to get the remainder. | 
0x01 but before the command 0x02. If you invoke the command in other places, the module will check for configuration consistency and reset the extended module if a mismatch occurs.The MCU sends the following data.
| No. | Bytes | Field | Description | 
|---|---|---|---|
| 0 1 | 2 | Header | 0x55 0xAA | 
| 2 | 1 | Version number | 0x00 | 
| 3 | 1 | Command (CMD) | 0xC0 | 
| 4 5 | 2 | Data length (Len) | Upper 8 bits Lower 8 bits | 
| 6 | 1 | SubCmd | 0x03 | 
| Configurations | {“apn”:“xxx”} | ||
| 7 | 1 | CRC8 | Start from the header, add up all the bytes, and then divide the sum by 256 to get the remainder. | 
Example:
55 AA 00 C0 00 10 03 7B 22 61 70 6E 22 3A 22 63 6E 69 6F 74 22 7D EB ({“apn”,“cniot”}})
55 AA 00 C0 00 0B 03 7B 22 61 70 6E 22 3A 22 22 7D C6 (Clear the configuration)
The module returns the following data.
| No. | Bytes | Field | Description | 
|---|---|---|---|
| 0 1 | 2 | Header | 0x55 0xAA | 
| 2 | 1 | Version number | 0x00 | 
| 3 | 1 | Command (CMD) | 0xC0 | 
| 4 5 | 2 | Data length (Len) | Upper 8 bits Lower 8 bits | 
| 6 | 1 | SubCmd | 0x03 | 
| 7 | 1 | Status | 
 | 
| 8 | 1 | CRC8 | Start from the header, add up all the bytes, and then divide the sum by 256 to get the remainder. | 
This protocol extends the capabilities of the MCU to the non-smart accessories.
The MCU sends the following data.
| No. | Bytes | Field | Description | 
|---|---|---|---|
| 0 1 | 2 | Header | 0x55 0xAA | 
| 2 | 1 | Version number | 0x00 | 
| 3 | 1 | Command (CMD) | 0xC2 | 
| 4 5 | 2 | Data length (Len) | 0x00 0x02 | 
| 6 to 6+Len-1 | 1 | SubCmd | 0x00 | 
| 1 | Status | 
 | |
| 6+Len | 1 | CRC8 | Start from the header, add up all the bytes, and then divide the sum by 256 to get the remainder. | 
The module returns the following data.
| No. | Bytes | Field | Description | 
|---|---|---|---|
| 0 1 | 2 | Header | 0x55 0xAA | 
| 2 | 1 | Version number | 0x00 | 
| 3 | 1 | Command (CMD) | 0xC2 | 
| 4 5 | 2 | Data length (Len) | 0x00 0x02 | 
| 6 | 1 | SubCmd | 0x00 | 
| 7 | 1 | Status | 
 | 
| 8 | 1 | CRC8 | Start from the header, add up all the bytes, and then divide the sum by 256 to get the remainder. | 
The MCU sends this command to the module to disconnect the Bluetooth connection and enter the advertising state.
The MCU sends the following data.
| No. | Bytes | Field | Description | 
|---|---|---|---|
| 0 1 | 2 | Header | 0x55 0xAA | 
| 2 | 1 | Version number | 0x00 | 
| 3 | 1 | Command (CMD) | 0xE7 | 
| 4 5 | 2 | Data length. | 0x00 0x00 | 
| 6 | 1 | CRC8 | Start from the header, add up all the bytes, and then divide the sum by 256 to get the remainder. | 
The module returns the following data.
| No. | Bytes | Field | Description | 
|---|---|---|---|
| 0 1 | 2 | Header | 0x55 0xAA | 
| 2 | 1 | Version number | 0x00 | 
| 3 | 1 | Command (CMD) | 0xE7 | 
| 4 5 | 2 | Data length. | 0x00 0x01 | 
| 6 | 1 | State | Return value | 
| 7 | 1 | CRC8 | Start from the header, add up all the bytes, and then divide the sum by 256 to get the remainder. | 
Return value
In standard power mode, the advertising interval is 100 ms. In low power mode, the advertising interval can range from 0 to 2,000 ms and defaults to 1,000 ms. 0 means turning off advertising. The module will be paired when the app receives the advertisement. This command allows the MCU to enable or disable advertising so that the MCU can determine when to perform pairing.
You need to invoke this command to set the advertising enablement after the UART initialization. The enablement state is stored in the flash memory. The MCU should enable advertising when performing pairing and disable it in other cases.
The advertising is enabled by default. After you disable advertising through this command, the module will not advertise both in standard and low power mode.
Disabling advertising will stop ongoing advertising immediately.
When advertising is enabled, the module will start advertising immediately.
For more information about the support for protocols, see Firmware types.
This command works for both the standard and the low power mode. Modification of advertising interval only works for the low power mode. Therefore, to modify the time for performing pairing, you must use the advertising enablement command.
The MCU sends the following data.
| No. | Bytes | Field | Description | 
|---|---|---|---|
| 0 1 | 2 | Header | 0x55 0xAA | 
| 2 | 1 | Version number | 0x00 | 
| 3 | 1 | Command (CMD) | 0xA3 | 
| 4 5 | 2 | Data length. | 0x00 0x01 | 
| 6 | 1 | Data | See the following table. | 
| 7 | 1 | CRC8 | Start from the header, add up all the bytes, and then divide the sum by 256 to get the remainder. | 
The valid values:
The module returns the following data.
| No. | Bytes | Field | Description | 
|---|---|---|---|
| 0 1 | 2 | Header | 0x55 0xAA | 
| 2 | 1 | Version number | 0x00 | 
| 3 | 1 | Command (CMD) | 0xA3 | 
| 4 5 | 2 | Data length. | 0x00 0x01 | 
| 6 | 1 | State | Return value | 
| 7 | 1 | CRC8 | Start from the header, add up all the bytes, and then divide the sum by 256 to get the remainder. | 
Return value
0xE0 to report record-type data. If the module is bound but not connected, the MCU will use this command to request to get the module online. Then, after getting online, the module will release the stranded data reported through 0xE0.0x02 format through the command 0xE0. After getting online, the module will send the stranded data to the app. This method is not recommended.The MCU sends the following data.
| No. | Bytes | Field | Description | 
|---|---|---|---|
| 0 1 | 2 | Header | 0x55 0xAA | 
| 2 | 1 | Version number | 0x00 | 
| 3 | 1 | Command (CMD) | 0xA5 | 
| 4 5 | 2 | Data length. | 0x00 0x00 | 
| 6 | 1 | CRC8 | Start from the header, add up all the bytes, and then divide the sum by 256 to get the remainder. | 
The module returns the following data.
| No. | Bytes | Field | Description | 
|---|---|---|---|
| 0 1 | 2 | Header | 0x55 0xAA | 
| 2 | 1 | Version number | 0x00 | 
| 3 | 1 | Command (CMD) | 0xA5 | 
| 4 5 | 2 | Data length. | 0x00 0x01 | 
| 6 | 1 | State | Return value | 
| 7 | 1 | CRC8 | Start from the header, add up all the bytes, and then divide the sum by 256 to get the remainder. | 
Return value
This command does not apply to the BK3432 generic firmware for shared devices.
To further reduce the power consumption in sleep mode, you can use this command to modify the advertising interval. The configuration is stored in the nonvolatile memory. If the interval is set to 0, advertising is turned off. The configuration is stored in the nonvolatile memory.
The advertisement interval defaults to one second in the low power mode. A long interval means taking more time to connect to a mobile phone. If the phone has poor radio performance, the Bluetooth connection attempt might fail.
For more information about the support for protocols, see Firmware types.
The MCU sends the following data.
| No. | Bytes | Field | Description | 
|---|---|---|---|
| 0 1 | 2 | Header | 0x55 0xAA | 
| 2 | 1 | Version number | 0x00 | 
| 3 | 1 | Command (CMD) | 0xE2 | 
| 4 5 | 2 | Data length. | 0x00 0x01 | 
| 6 | 1 | Adv_interval | See the following table. | 
| 7 | 1 | CRC8 | Start from the header, add up all the bytes, and then divide the sum by 256 to get the remainder. | 
Adv_interval: The valid values range from 0 to 20 in units of 100 ms. If the interval is set to 0, advertising is turned off.
Example:
55 aa 00 E2 00 01 00 E2, indicating advertising is turned off in low power mode.55 aa 00 E2 00 01 06 E8, indicating the advertising interval is 600 ms in low power mode.The module returns the following data.
| No. | Bytes | Field | Description | 
|---|---|---|---|
| 0 1 | 2 | Header | 0x55 0xAA | 
| 2 | 1 | Version number | 0x00 | 
| 3 | 1 | Command (CMD) | 0xE2 | 
| 4 5 | 2 | Data length. | 0x00 0x01 | 
| 6 | 1 | State | Return value | 
| 7 | 1 | CRC8 | Start from the header, add up all the bytes, and then divide the sum by 256 to get the remainder. | 
Return value
The MCU sends the following data.
| No. | Bytes | Field | Description | 
|---|---|---|---|
| 0 1 | 2 | Header | 0x55 0xAA | 
| 2 | 1 | Version number | 0x00 | 
| 3 | 1 | Command (CMD) | 0xB1 | 
| 4 5 | 2 | Data length. | 0x00 0x0B | 
| 6 to 16 | 11 | CFG | See the information below. | 
| 17 | 1 | CRC8 | Start from the header, add up all the bytes, and then divide the sum by 256 to get the remainder. | 
CFG format:
| 1 byte | 1 byte | 1 byte | 2 bytes | 2 bytes | 2 bytes | 2 bytes | 
|---|---|---|---|---|---|---|
| cfg_type | cfg_ack | mode | min_interval | max_interval | latency | timeout | 
cfg_type: The configuration method.
mode field. If min_interval, min_interval, latency, and timeout do not work, you can use this method.min_interval and timeout. This method applies to Bluetooth devices.cfg_ack: Acknowledgement (ACK) response.
mode:
min_interval: The minimal connection interval, in the unit of 1.25 ms. For more information, see the connection interval specified in the Generic Access Profile (GAP).
max_interval: The maximum connection interval, in the unit of 1.25 ms. For more information, see the connection interval specified in the Generic Access Profile (GAP).
latency: Peripheral latency. This parameter gives the peripheral device the option of skipping a number of connection events. For more information, see the connection interval specified in the Generic Access Profile (GAP).
timeout: The maximum amount of time between two successful connection events, in the unit of 10 ms. For more information, see the connection interval specified in the Generic Access Profile (GAP).
The field greater than two bytes is transmitted in big-endian format. You can set cfg_type and cfg_ack to 0x00 if these two parameters are not required for you.
The module returns the following data.
| No. | Bytes | Field | Description | 
|---|---|---|---|
| 0 1 | 2 | Header | 0x55 0xAA | 
| 2 | 1 | Version number | 0x00 | 
| 3 | 1 | Command (CMD) | 0xB1 | 
| 4 5 | 2 | Data length. | 0x00 0x09 | 
| 6 to 14 | 1 | State | Return value | 
| 15 | 1 | CRC8 | Start from the header, add up all the bytes, and then divide the sum by 256 to get the remainder. | 
State
| 1 byte | 2 bytes | 2 bytes | 2 bytes | 2 bytes | 
|---|---|---|---|---|
| result | min_interval | max_interval | latency | timeout | 
result:
0x00: The module receives the new connection parameters and will request a parameter update with the central. min_interval, max_interval, latency, and timeout indicate the parameters of the target connection.
0x01: The connection parameters are updated successfully. min_interval, max_interval, latency, and timeout indicate the parameters of the actual connection.
0x02: Updating the connection parameters failed. min_interval, max_interval, latency, and timeout indicate the parameters of the target connection.
0x03: Illegal state. Generally, the module is not in the bound and connected state.
0x06: Invalid parameter.
Other values: Failure
If cfg_ack is set to 0x01, the module syncs the current connection parameters to the MCU only after receiving the success ACK message. The result 0x01 or 0x02 can be returned only when cfg_ack is set to 0x01. Otherwise, the module will not return the operation result to the MCU.
Example:
Set to low-speed mode:
55 AA 00 B1 00 0B 00 00 02 00 00 00 00 00 00 00 00 BD55 AA 00 B1 00 09 00 01 90 01 A0 00 00 01 90 7CSet to balanced mode:
55 AA 00 B1 00 0B 00 00 01 00 00 00 00 00 00 00 00 BC55 AA 00 B1 00 09 00 00 90 00 A0 00 00 01 90 7ASet to fast-speed mode:
55 AA 00 B1 00 0B 00 00 00 00 00 00 00 00 00 00 00 BB55 AA 00 B1 00 09 00 00 32 00 3C 00 00 01 90 B8Set to custom parameters:
55 AA 00 B1 00 0B 01 00 00 01 90 01 A0 00 00 01 90 7F55 AA 00 B1 00 09 00 01 90 01 A0 00 00 01 90 7C0x01 to enable the SMP feature. Otherwise, the module will reject this HID command.The MCU sends the following data.
| No. | Bytes | Field | Description | 
|---|---|---|---|
| 0 1 | 2 | Header | 0x55 0xAA | 
| 2 | 1 | Version number | 0x00 | 
| 3 | 1 | Command (CMD) | 0xBA | 
| 4 5 | 2 | Data length (Len) | Upper 8 bits Lower 8 bits | 
| 6 | 1 | SubCmd | See the information below. | 
| 7 to 7+Len-1 | Len | Data | See the information below. | 
| 7+Len | 1 | CRC8 | Start from the header, add up all the bytes, and then divide the sum by 256 to get the remainder. | 
SubCmd (Subcommand):
0x00: Enable SMP.
Dynamic configuration of SMP is not supported so the MCU should report the SMP enablement when responding to the MCU information query 0x01. The SMP is disabled by default. After you enable or disable the SMP, the module will restart and clear the pairing information for initialization. The configuration can be retained after power off.
0x01: Request the HID pairing.
0x02: The RSSI of the HID pairing signal.
0x03: Query the HID pairing state.
The format of the Data field varies depending on subcommands. The module parses data according to the SubCmd and the Data format.
Data
When SubCmd is 0x01 and 0x03, the Data field is empty.
Example: Request the HID pairing
The MCU sends 55 aa 00 BA 00 01 01 BB.
Example: Query the HID pairing state
The MCU sends 55 aa 00 BA 00 01 03 BD.
When SubCmd is 0x02, the format of the Data field is as follows:
| 1 | 2 | 3 | 
|---|---|---|
| op | num | interval | 
op: Operation. 0x00: Stop getting the RSSI value. 0x01: Start getting the RSSI value.
num: The number of RSSI values to be obtained.
interval: The interval of sending RSSI values, ranging from 1 to 20 in the unit of 100 ms.
55 AA 00 BA 00 04 02 01 0A 02 CC.The module returns the following data.
| No. | Bytes | Field | Description | 
|---|---|---|---|
| 0 1 | 2 | Header | 0x55 0xAA | 
| 2 | 1 | Version number | 0x00 | 
| 3 | 1 | Command (CMD) | 0xBA | 
| 4 5 | 2 | Data length (Len) | Upper 8 bits Lower 8 bits | 
| 6 | 1 | SubCmd | See the following table. | 
| 7 to 7+Len-1 | Len | Data | See the information below. | 
| 7+Len | 1 | CRC8 | Start from the header, add up all the bytes, and then divide the sum by 256 to get the remainder. | 
SubCmd (Subcommand):
0x00: Enable SMP.
0x01: Request the HID pairing.
0x02: The RSSI of the HID pairing signal.
0x03: Get the HID pairing state
The format of the Data field varies depending on subcommands. The MCU parses data according to the SubCmd and the Data format.
When SubCmd is 0x00, the Data field is populated with a 1-byte status code.
Status:
When SubCmd is 0x01, the Data field is populated with a 1-byte status code.
Status:
When SubCmd is 0x02, the format of the Data field is as follows:
| 1 | 2 | 
|---|---|
| Status | rssi_raw | 
rssi_raw: If the value of status is not 0, rssi_raw is 0xff.rssi_real: The value is rssi_raw minus 110. Assume the value of rssi_raw is 50, the rssi_real is -60 dB.Status:
When SubCmd is 0x03, the Data field is populated with a 1-byte status code.
Status:
The MCU can set the advertising name when the module is not bound. Otherwise, the module will reject the request.
The MCU sends the following data.
| No. | Bytes | Field | Description | 
|---|---|---|---|
| 0 1 | 2 | Header | 0x55 0xAA | 
| 2 | 1 | Version number | 0x00 | 
| 3 | 1 | Command (CMD) | 0xBB | 
| 4 5 | 2 | Data length (Len) | Upper 8 bits Lower 8 bits | 
| 6 to 6+Len-1 | Len | Data | See the information below. | 
| 6+Len | 1 | CRC8 | Start from the header, add up all the bytes, and then divide the sum by 256 to get the remainder. | 
Data format
| 1 | 2–2+ADV_LOCAL_NAME_LEN-1 | 
|---|---|
| ADV_LOCAL_NAME_LEN | ADV_LOCAL_NAME | 
ADV_LOCAL_NAME_LEN: The length of the advertising name. Firmware earlier than v2.1.2 allows up to 5 bytes. Firmware v2.1.2 and later allows up to 14 bytes.ADV_LOCAL_NAME: The advertising name in ASCII.The module returns the following data.
| No. | Bytes | Field | Description | 
|---|---|---|---|
| 0 1 | 2 | Header | 0x55 0xAA | 
| 2 | 1 | Version number | 0x00 | 
| 3 | 1 | Command (CMD) | 0xBB | 
| 4 5 | 2 | Data length. | 0x00 0x01 | 
| 6 | 1 | State | Return value | 
| 7 | 1 | CRC8 | Start from the header, add up all the bytes, and then divide the sum by 256 to get the remainder. | 
Return value
The MCU sends the following data.
| No. | Bytes | Field | Description | 
|---|---|---|---|
| 0 1 | 2 | Header | 0x55 0xAA | 
| 2 | 1 | Version number | 0x00 | 
| 3 | 1 | Command (CMD) | 0xBD | 
| 4 5 | 2 | Data length | 0x00 0x02 | 
| 6 | 1 | OP | See the description below. | 
| 7 | 1 | TX_POWER | See the description below. | 
| 8 | 1 | CRC8 | Start from the header, add up all the bytes, and then divide the sum by 256 to get the remainder. | 
OP:
0x00: Get.0x01: Set.TX_POWER:
When OP is 0x00, this field only acts as a placeholder.
When OP is 0x01, set the transmitter power register. Consult Tuya’s technical support to determine an appropriate value.
The module returns the following data.
| No. | Bytes | Field | Description | 
|---|---|---|---|
| 0 1 | 2 | Header | 0x55 0xAA | 
| 2 | 1 | Version number | 0x00 | 
| 3 | 1 | Command (CMD) | 0xBD | 
| 4 5 | 2 | Data length | 0x00 0x02 | 
| 6 | 1 | OP | See the description below. | 
| 7 | 1 | Value | See the description below. | 
| 8 | 1 | CRC8 | Start from the header, add up all the bytes, and then divide the sum by 256 to get the remainder. | 
OP:
0x00: Get.0x01: Set.Value:
OP is 0x00, Value indicates TX_POWER.OP is others, Value indicates the setting result. 0x00 indicates success, while any other value indicates failure.The MCU can use this command to query the MAC address of the Bluetooth module.
The MCU sends the following data.
| No. | Bytes | Field | Description | 
|---|---|---|---|
| 0 1 | 2 | Header | 0x55 0xAA | 
| 2 | 1 | Version number | 0x00 | 
| 3 | 1 | Command (CMD) | 0xBE | 
| 4 5 | 2 | Data length | 0x00 0x00 | 
| 6 | 1 | CRC8 | Start from the header, add up all the bytes, and then divide the sum by 256 to get the remainder. | 
The module returns the following data.
| No. | Bytes | Field | Description | 
|---|---|---|---|
| 0 1 | 2 | Header | 0x55 0xAA | 
| 2 | 1 | Version number | 0x00 | 
| 3 | 1 | Command (CMD) | 0xBE | 
| 4 5 | 2 | Data length | 0x00 0x06 | 
| 6 to 11 | 6 | MAC | See the following table. | 
| 12 | 1 | CRC8 | Start from the header, add up all the bytes, and then divide the sum by 256 to get the remainder. | 
Suppose that the MAC address of the module is DC:23:66:11:22:33.
The MCU sends 55 AA 00 BE 00 00 BD to the module.
The module returns 55 AA 00 BE 00 06 DC 23 66 11 22 33 8E.
This section describes the extended protocol specific to smart look generic firmware, which does not apply to generic firmware for other categories.
The MCU sends the following data.
| No. | Bytes | Field | Description | 
|---|---|---|---|
| 0 1 | 2 | Header | 0x55 0xAA | 
| 2 | 1 | Version number | 0x00 | 
| 3 | 1 | Command (CMD) | 0xE6 | 
| 4 5 | 2 | Data length (Len) | Upper 8 bits Lower 8 bits | 
| 6 to 6+Len-1 | Len | Data | See the following table. | 
| 6+Len | 1 | CRC8 | Start from the header, add up all the bytes, and then divide the sum by 256 to get the remainder. | 
Data format
| 8 bytes | 1 byte | N byte(s) | N byte(s) | … | 
|---|---|---|---|---|
| password | The length of the admin password | The first admin password | The second admin password | … | 
password: The input password Data[0] to Data[7] ranges from 0 to 9, transferred in ASCII.
The request parameter of the admin password is not supported. Set its length to 0.
Example: The MCU sends a packet that does not contain the admin password.
55 aa 00 E6 00 09 30 31 32 33 34 35 36 37 00 8a
The module returns the following data.
| No. | Bytes | Field | Description | 
|---|---|---|---|
| 0 1 | 2 | Header | 0x55 0xAA | 
| 2 | 1 | Version number | 0x00 | 
| 3 | 1 | Command (CMD) | 0xE6 | 
| 4 5 | 2 | Data length. | 0x00 0x01 | 
| 6 | 1 | State | Return value | 
| 7 | 1 | CRC8 | Start from the header, add up all the bytes, and then divide the sum by 256 to get the remainder. | 
Return value
Example:
55 AA 00 E6 00 01 01 E7, indicating password verification failed.55 AA 00 E6 00 01 00 E6, indicating password verified.0xE6 but has different parameters.The MCU sends the following data.
| No. | Bytes | Field | Description | 
|---|---|---|---|
| 0 1 | 2 | Header | 0x55 0xAA | 
| 2 | 1 | Version number | 0x00 | 
| 3 | 1 | Command (CMD) | 0xA7 | 
| 4 5 | 2 | Data length (Len) | Upper 8 bits Lower 8 bits | 
| 6 to 6+Len-1 | Len | Data | See the following table. | 
| 6+Len | 1 | CRC8 | Start from the header, add up all the bytes, and then divide the sum by 256 to get the remainder. | 
Data format
| 1 byte | 1 byte | 1 byte | 1 byte | 1 byte | 1 byte | 1 byte | 1 byte | N byte(s) | 
|---|---|---|---|---|---|---|---|---|
| TimeSource | 2000+Year | Mon | Day | Hour | Min | Sec | Code_len | Code | 
TimeSource: Set it to 0x00.
0x00: Use the time data Year, Mon, Day, Hour, Min, and Sec uploaded by the MCU.
0x01: Use the internal time of the module. The Year, Mon, Day, Hour, Min, and Sec uploaded by the MCU are not parsed.
The MCU uploads the date and time in GMT. For example, 12:00:00 on June 20, 2020 is represented by 0x14 0x06 0x14 0x04 0x00 0x00 in GMT.
Code_len: The length of the password.
Code: The password. The command 0xE6 requires that the password be transferred in ASCII while with this command 0xA7, the MCU can send the digit directly. For example, 1 is 0x01. 9 is 0x09. See the following example.
Example:
55 AA 00 A7 00 10 00 14 0A 09 0D 33 2C 08 01 08 05 08 06 04 04 05 7A
The module returns the following data.
| No. | Bytes | Field | Description | 
|---|---|---|---|
| 0 1 | 2 | Header | 0x55 0xAA | 
| 2 | 1 | Version number | 0x00 | 
| 3 | 1 | Command (CMD) | 0xA7 | 
| 4 5 | 2 | Data length (Len) | Upper 8 bits Lower 8 bits | 
| 6 to 6+Len-1 | Len | State | Return value | 
| 6+Len | 1 | CRC8 | Start from the header, add up all the bytes, and then divide the sum by 256 to get the remainder. | 
Return value
Example:
55 AA 00 A7 00 01 01 A8, indicating password verification failed.55 AA 00 A7 00 01 00 A7, indicating password verified.Offline dynamic passwords can be used to unlock the door if a device is disconnected for long periods of time.
The time drift of the internal clock of the module is less than one minute in 24 hours. The internal clock is reset after power off. The module syncs its clock with the server time each time it is connected to the cloud.
If your MCU is connected to an external clock, we recommend you choose 0x00 for the clock source to use the time data from the MCU. If you use the internal clock of the module as the clock source, make sure to measure the accuracy.
For more information about the support for protocols, see Firmware types.
The MCU sends the following data.
| No. | Bytes | Field | Description | 
|---|---|---|---|
| 0 1 | 2 | Header | 0x55 0xAA | 
| 2 | 1 | Version number | 0x00 | 
| 3 | 1 | Command (CMD) | 0xA2 | 
| 4 5 | 2 | Data length (Len) | Upper 8 bits Lower 8 bits | 
| 6 to 6+Len-1 | Len | Data | See the following table. | 
| 6+Len | 1 | CRC8 | Start from the header, add up all the bytes, and then divide the sum by 256 to get the remainder. | 
Data format
| 1 byte | 1 byte | 1 byte | 1 byte | 1 byte | 1 byte | 1 byte | 1 byte | N byte(s) | 
|---|---|---|---|---|---|---|---|---|
| TimeSource | 2000+Year | Mon | Day | Hour | Min | Sec | Code_len | Code | 
TimeSource: Set it to 0x00.
0x00: Use the time data Year, Mon, Day, Hour, Min, and Sec uploaded by the MCU.
0x01: Use the internal time of the module. The Year, Mon, Day, Hour, Min, and Sec uploaded by the MCU are not parsed.
The MCU uploads the date and time in GMT. For example, 12:00:00 on June 20, 2020 is represented by 0x14 0x06 0x14 0x04 0x00 0x00 in GMT.
Code_len: The length of the password.
Code: The password. The dynamic password is transferred in ASCII while for the offline password, the MCU can send the digit directly. For example, 1 is 0x01. 9 is 0x09. See the following example.
The module returns the following data.
| No. | Bytes | Field | Description | 
|---|---|---|---|
| 0 1 | 2 | Header | 0x55 0xAA | 
| 2 | 1 | Version number | 0x00 | 
| 3 | 1 | Command (CMD) | 0xA2 | 
| 4 5 | 2 | Data length (Len) | Upper 8 bits Lower 8 bits | 
| 6 to 6+Len-1 | Len | Data | See the following table. | 
| 6+Len | 1 | CRC8 | Start from the header, add up all the bytes, and then divide the sum by 256 to get the remainder. | 
Data format
| 1 byte | 1 byte | 1 byte | N byte(s) | 
|---|---|---|---|
| Result | Type | Decode_len | Decode | 
Result:
Type:
Code_len: The length of the encrypted data.
code: The encrypted clear code and unlocking password.
Type and code are used to report DP status. The DPs related to the offline password feature are DP ID 65, 66, and 67.
For example, use the internal clock of the module and the password is 2279084005.
55 AA 00 A2 00 12 01 00 00 00 00 00 00 0A 02 02 07 09 00 08 04 00 00 05 E355 AA 00 A2 00 13 00 00 10 F3 50 3C 8F FF 03 F5 E9 0D 54 99 2A 62 A1 DE 42 F9The MCU sends the following data.
| No. | Bytes | Field | Description | 
|---|---|---|---|
| 0 1 | 2 | Header | 0x55 0xAA | 
| 2 | 1 | Version number | 0x00 | 
| 3 | 1 | Command (CMD) | 0xA6 | 
| 4 5 | 2 | Data length. | 0x00 0x04 | 
| 6 to 9 | 4 | DATA | See the following table. | 
| 10 | 1 | CRC8 | Start from the header, add up all the bytes, and then divide the sum by 256 to get the remainder. | 
CFG format:
| Configuration item 0 | Configuration item 1 | Configuration item 2 | Configuration item 3 | 
|---|---|---|---|
| 1 | 2 | 3 | 4 | 
| FLAG | PWD_NUM | PWD_BEGIN_NUM | Reserved (0x00) | 
FLAG:
bit0: Enable the lock accessory. 0 is for disabling and 1 is for enabling. This feature is disabled by default.
bit1: Enable accessory-triggered locking and unlocking. 0 is for disabling and 1 is for enabling. This feature is disabled by default.
bit0 and bit1 are mutually exclusive. When you enable either of them, the other is disabled automatically.
bit2: Reserved
bit3: Reserved
bit4: Reserved
bit5: Reserved
bit6: Reserved
bit7: Reserved
PWD_NUM: The number of digits on the keypad, defaulting 10 (0 to 9). If a keypad only has 4 to 9 consecutive digits, the MCU can use this field to configure the keypad. PWD_BEGIN_NUM is used to set the starting digit, which can be 0 or 1.
The valid values of PWD_NUM rang from 0x04 to 0x09. Invalid values will apply the default setting of 10 digits.
PWD_BEGIN_NUM: the starting digit, which can be 0 or 1. If the keypad starts from 0, set it to 0x00. If the keypad starts from 1, set it to 0x01.
The valid values of PWD_BEGIN_NUM are 0x00 and 0x01. Invalid values will apply the default 0x00.
Example:
55 AA 00 A6 00 04 01 00 00 00 AA: Enable the lock accessory.55 AA 00 A6 00 04 00 00 00 00 A9: Disable the lock accessory.The module returns the following data.
| No. | Bytes | Field | Description | 
|---|---|---|---|
| 0 1 | 2 | Header | 0x55 0xAA | 
| 2 | 1 | Version number | 0x00 | 
| 3 | 1 | Command (CMD) | 0xA6 | 
| 4 5 | 2 | Data length. | 0x00 0x01 | 
| 6 | 1 | State | Return value | 
| 7 | 1 | CRC8 | Start from the header, add up all the bytes, and then divide the sum by 256 to get the remainder. | 
Return value
What is this interface used for?
This interface is used to configure the DP-specific features. It applies to three features:
If the lock accessory features are not required for your product, you do not need to configure them. They are disabled by default. To set these features, the MCU should send the configuration to the module after the UART initialization. The configuration is stored in the nonvolatile memory.
How to set the positional notation for the keypad?
PWD_NUM: The number of digits on the keypad, defaulting 10 (0 to 9). If a keypad only has 4 to 9 consecutive digits, the MCU can use this field to configure the keypad. PWD_BEGIN_NUM is used to set the starting digit, which can be 0 or 1.
The valid values of PWD_NUM rang from 0x04 to 0x09. Invalid values will apply the default setting of 10 digits.
PWD_BEGIN_NUM: the starting digit, which can be 0 or 1. If the keypad starts from 0, set it to 0x00. If the keypad starts from 1, set it to 0x01.
The valid values of PWD_BEGIN_NUM are 0x00 and 0x01. Invalid values will apply the default 0x00.
Example
If the keypad has digits 1, 2, 3, 4, 5, and 6, set the PWD_NUM to 6 and PWD_BEGIN_NUM to 1.
If the keypad has digits 0, 1, 2, 3, 4, 5, 6, 7, and 8, set the PWD_NUM to 9 and PWD_BEGIN_NUM to 0.
How to implement the accessory feature on the lock?
Four DPs and one command 0xA6 together implement the lock accessory feature.
You do not need to take care of the Bluetooth pairing and reconnection, which has been implemented in the generic firmware.
Double identity verification in the service layer is implemented to ensure the security of the lock.
The cloud assigns the central (app or accessory) a unique code that consists of the central ID and a central random number to identify the central device. 
The cloud assigns the peripheral (lock) a unique code that includes the peripheral ID and a peripheral random number to identify the peripheral device.
After the cloud sends the unique code of the app and the peripheral ID of the lock to the lock, the lock is considered to be paired with the app. 
After the cloud sends the unique code of the accessory to the lock and sends the unique code of the accessory and the peripheral ID of the lock to the peripheral, the lock is considered to be paired with the accessory.
The lock stores: 
The unique code of the app
 The unique code of the accessory
 The peripheral ID of the lock
The accessory stores: 
The unique code of the peripheral 
The peripheral ID of the lock
So far, the accessory can unlock the door. Before unlocking, it tells the lock the unique code of itself and the peripheral ID of the lock for verification.
The implementation of the above feature is included in the generic firmware. This feature is disabled by default because it requires the data of specific DP and the generic firmware does not process DP data but transmits the raw data. To use this feature, the MCU should use the command 0xA6 to enable it. The module just gets and parses the central ID, peripheral ID, and random numbers without modifying them.
If you do not enable this feature, the module will transmit the obtained raw DP data to the MCU. This way, the MCU should process the data.
Identity verification logic
The MCU enables the lock accessory feature through the command 0xA6. Then, the module processes the DP ID 70 (configure random number) without transmitting the raw DP data to the MCU.
For the DP ID 71 (unlock/lock) and 73 (set remote unlock), the module collects the central ID, peripheral ID, and random number from the DP data for identity verification.
The MCU processes the DP data
After the MCU enables the lock accessory feature, the module only verifies the accessory identity and determines whether to send the raw DP data to the MCU for processing. The MCU does not need to process the fields of central ID, peripheral ID, and random number but only adjusts the position of these fields. Take the DP ID 71 as an example:
| Feature | Data transmission | dp_id (1 byte) | dp_type (1 byte) | dp_da ta_len (1 byte) | dp_data_value | |||||||||
|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| Locking Unlocking | Cloud-to-device | 71 | raw | len | Central ID (2 bytes) | Peripheral ID (2 bytes) | Random number (8 bytes) | Operation (1 byte) | Locking/unlocking Timestamp (4 bytes) | Locking/unlocking Method (1 byte) | Locking/unlocking Info (len-12 bytes) | |||
| 0 to 10000 | 0 to 10000 | Central random number | 0x00: Lock. 0x01: Unlock | Description | Description | Description | ||||||||
| Device-to-cloud | 71 | raw | len | Peripheral ID (2 bytes) | Central ID (2 bytes) | Random number (8 bytes) | Operation (1 byte) | Locking/unlocking Timestamp (4 bytes) | Locking/unlocking Method (1 byte) | Return value (1 byte) | ||||
| 0 to 10000 | 0 to 10000 | Central random number | 0x00: Lock. 0x01: Unlock | Description | Description | Value range | ||||||||
The position of the central ID and the peripheral ID is exchanged.
55 AA 00 06 00 17 47 00 00 13 <kbd>00 02. 00 01 39 38 36 35 33 36 33 39 01 01 E4 6D 11 5F 00 ED55 AA 00 07 00 17 47 00 00 13 <kbd>00 01. 00 02 39 38 36 35 33 36 33 39 01 01 E4 6D 11 5F 00 EEDP ID 73 is processed the same way.
After the MCU receives data of DP ID 71, it stores the central ID, peripheral ID, and random number that will be used when the MCU reports the locking or unlocking record.
| Feature | Data transmission | dp_id (1 byte) | dp_type (1 byte) | dp_da ta_len (1 byte) | dp_data_value | |||||||||
|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| Locking Unlocking Record | Device-to-cloud | 72 | raw | len | Peripheral ID (2 bytes) | Central ID (2 bytes) | Random number (8 bytes) | Operation (1 byte) | Locking/unlocking Timestamp (4 bytes) | Locking/unlocking Method (1 byte) | Locking/unlocking Info (len-12 bytes) | |||
| 0 to 10000 | 0 to 10000 | Central random number | 0x00: Lock. 0x01: Unlock | Description | Description | Description | ||||||||
How to implement the accessory feature on the accessory?
The MCU enables the lock accessory feature through the command 0xA6.
After the module receives the unlock/lock command from the MCU, it will retrieve the accessory information according to the central ID. If the accessory has been added, it can unlock or lock the door. Then, the module will initiate a reconnection request and forward the DP for unlock/lock to the lock for command execution.
| Feature | Data transmission | dp_id (1 byte) | dp_type (1 byte) | dp_da ta_len (1 byte) | dp_data_value | |||||||||
|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| Locking Unlocking | Cloud-to-device | 71 | raw | len | Central ID (2 bytes) | Peripheral ID (2 bytes) | Random number (8 bytes) | Operation (1 byte) | Locking/unlocking Timestamp (4 bytes) | Locking/unlocking Method (1 byte) | Locking/unlocking Info (len-12 bytes) | |||
| 0 to 10000 | 0 to 10000 | Central random number | 0x00: Lock. 0x01: Unlock | Description | Description | Description | ||||||||
| Device-to-cloud | 71 | raw | len | Peripheral ID (2 bytes) | Central ID (2 bytes) | Random number (8 bytes) | Operation (1 byte) | Locking/unlocking Timestamp (4 bytes) | Locking/unlocking Method (1 byte) | Return value (1 byte) | ||||
| 0 to 10000 | 0 to 10000 | Central random number | 0x00: Lock. 0x01: Unlock | Description | Description | Value range | ||||||||
When the accessory’s MCU reports DP data, it only needs to populate the peripheral ID. If the accessory’s module has stored the information, it can populate the corresponding central ID and random number automatically.
The accessory’s MCU should store:
Peripheral ID (the lock’s ID)
The lock ID will be sent to the MCU when an unlocking method is added. For more information, see the DP protocol specification.
For data of other DPs, the module will not process it and directly send the raw data to the MCU.
After connecting to the accessory, the lock’s module will forward the unlock/lock request to the MCU and start a 30s timer. If the MCU fails to return the operation result after a timeout, the module will disconnect from the Bluetooth accessory. If the MCU returns a result, the module also disconnects from the Bluetooth accessory.
The MCU sends the following data.
| No. | Length (byte) | Field | Description | 
|---|---|---|---|
| 0 1 | 2 | Header | 0x55 0xAA | 
| 2 | 1 | Version number | 0x00 | 
| 3 | 1 | Command (CMD) | 0xA8 | 
| 4 5 | 2 | Data length. | 0x00 0x06 | 
| 6 to 11 | 6 | CFG | See the following table. | 
| 12 | 1 | CRC8 | Start from the header, add up all the bytes, and then divide the sum by 256 to get the remainder. | 
CFG format:
| 1 byte | 1 byte | 2 bytes | 2 bytes | 
|---|---|---|---|
| 1 | 2 | 3 to 4 | 4 to 5 | 
| operation | config_type | ibeacon_interval | timeout | 
operation:
config_type:
ibeacon_interval and timeout to 0x00.ibeacon_interval and timeout.ibeacon_interval: The iBeacon advertising interval in low power mode in the unit of 100 ms, ranging from 100 ms to 2,000 ms. The actual advertising interval is ibeacon_interval × 100 ms. It is fixed to 100 ms in standard power mode.
With iBeacon turned on, the advertising interval is as follows:
0xE2. With iBeacon turned on, the device advertises with the ibeacon_interval in low power mode.ibeacon_interval.ibeacon_interval. The interval for switching between advertising contents is one second, which is not configurable. Make sure ibeacon_interval is less than one second.timeout: iBeacon timeout in the unit of 5s. That is, iBeacon times out in 5 × timeout seconds. The valid values range from 5s to 2 min. This timeout only works for the anti-lost feature.
Example:
55 AA 00 A8 00 06 01 00 00 00 00 00 AE55 AA 00 A8 00 06 03 00 00 00 00 00 B0The module returns the following data.
| No. | Length (byte) | Field | Description | 
|---|---|---|---|
| 0 1 | 2 | Header | 0x55 0xAA | 
| 2 | 1 | Version number | 0x00 | 
| 3 | 1 | Command (CMD) | 0xA8 | 
| 4 5 | 2 | Data length. | 0x00 0x01 | 
| 6 | 1 | State | Return value | 
| 7 | 1 | CRC8 | Start from the header, add up all the bytes, and then divide the sum by 256 to get the remainder. | 
Return value
| Weather parameter (key) | Weather parameter (value) | Description | Value type | Mainland China | Other countries/regions | Real-time weather | Weather forecast | 
|---|---|---|---|---|---|---|---|
| w.temp | (1 << 0) | Temperature | Integer | Supported | Supported | Supported | Not supported | 
| w.thigh | (1 << 1) | The highest temperature | Integer | - | - | Not supported | Supported | 
| w.tlow | (1 << 2) | The lowest temperature | Integer | - | - | Not supported | Supported | 
| w.humidity | (1 << 3) | Humidity | Integer | Supported | Supported | Supported | 7-day forecast | 
| w.condition | (1 << 4) | The description of weather conditions is subject to the multilingual texts you set. You can use conditionNumto return the code of weather conditions. | String | Supported | Supported | Supported | 7-day forecast | 
| w.pressure | (1 << 5) | Air pressure | Integer | Not supported | Supported | Supported | 7-day forecast | 
| w.realFeel | (1 << 6) | Apparent temperature | Integer | Not supported | Supported | Supported | Not supported | 
| w.uvi | (1 << 7) | Ultraviolet index | Integer | Not supported | Supported | Supported | 7-day forecast | 
| w.sunRise | (1 << 8) | Sunrise time | String (format example: 2017-04-24 05:24:00) | Supported | Supported | Supported | 7-day forecast | 
| w.sunSet | (1 << 9) | Sunset time | String (format example: 2017-04-24 18:32:00) | Supported | Supported | Supported | 7-day forecast | 
| t.unix | (1 << 10) | GMT (used for the time of sunrise and sunset) | - | - | - | - | - | 
| t.local | (1 << 11) | Local time (used for the time of sunrise and sunset) | - | - | - | - | - | 
| w.windSpeed | (1 << 12) | Wind speed | String (format example: 0.9) | Supported | Supported | Supported | 7-day forecast | 
| w.windDir | (1 << 13) | Wind direction | String | Supported | Not supported | Supported | Not supported | 
| w.windLevel | (1 << 14) | Wind level | Integer | Supported | Not supported | Supported | Not supported | 
| w.aqi | (1 << 15) | Air quality index | Integer | Supported | Not supported | Supported | Not supported | 
| w.tips | (1 << 16) | Weather tips | String | - | - | Supported | Not supported | 
| w.rank/w.quality | (1 << 17) | AQI details and national ranking | String (format example: 447/609) | Supported | Not supported | Supported | Not supported | 
| w.pm10 | (1 << 18) | PM10 index | Integer | Supported | Not supported | Supported | Not supported | 
| w.pm25 | (1 << 19) | PM2.5 index | Integer | Supported | Not supported | Supported | Not supported | 
| w.o3 | (1 << 20) | Ozone index | Integer | Supported | Not supported | Supported | Not supported | 
| w.no2 | (1 << 21) | Nitrogen dioxide index | Integer | Supported | Not supported | Supported | Not supported | 
| w.co | (1 << 22) | Carbon monoxide index | Integer | Supported | Not supported | Supported | Not supported | 
| w.so2 | (1 << 23) | Sulfur dioxide index | Integer | Supported | Not supported | Supported | Not supported | 
| w.conditionNum | (1 << 24) | Weather conditions (such as sunny, rainy, and snowy) are represented by a digit code. | String | Supported | Supported | Supported | 7-day forecast | 
| conditionNum | Condition | Chinese characters in UTF-8 (Hexadecimal) | 
|---|---|---|
| 120 | Sunny | E699B4 | 
| 101 | Heavy rain | E5A4A7 E99BA8 | 
| 102 | Thunderstorm | E99BB7 E69AB4 | 
| 103 | Sandstorm | E6B299 E5B098 E69AB4 | 
| 104 | Light snow | E5B08F E99BAA | 
| 105 | Snow | E99BAA | 
| 106 | Freezing fog | E586BB E99BBE | 
| 107 | Rainstorm | E69AB4 E99BA8 | 
| 108 | Isolated shower | E5B180 E983A8 E998B5 E99BA8 | 
| 109 | Dust | E6B5AE E5B098 | 
| 110 | Thunder and lightning | E99BB7 E794B5 | 
| 111 | Light shower | E5B08F E998B5 E99BA8 | 
| 112 | Rain | E99BA8 | 
| 113 | Sleet | E99BA8 E5A4B9 E99BAA | 
| 114 | Dust devil | E5B098 E58DB7 E9A38E | 
| 115 | Ice pellet | E586B0 E7B292 | 
| 116 | Strong sandstorm | E5BCBA E6B299 E5B098 E69AB4 | 
| 117 | Sand blowing | E689AC E6B299 | 
| 118 | Light to moderate rain | E5B08F E588B0 E4B8AD E99BA8 | 
| 119 | Mostly clear | E5A4A7 E983A8 E699B4 E69C97 | 
| 121 | Fog | E99BBE | 
| 122 | Shower | E998B5 E99BA8 | 
| 123 | Heavy shower | E5BCBA E998B5 E99BA8 | 
| 124 | Heavy snow | E5A4A7 E99BAA | 
| 125 | Extraordinary rainstorm | E789B9 E5A4A7 E69AB4 E99BA8 | 
| 126 | Blizzard | E69AB4 E99BAA | 
| 127 | Hail | E586B0 E99BB9 | 
| 128 | Light to moderate snow | E5B08F E588B0 E4B8AD E99BAA | 
| 129 | Partly cloudy | E5B091 E4BA91 | 
| 130 | Light snow shower | E5B08F E998B5 E99BAA | 
| 131 | Moderate snow | E4B8AD E99BAA | 
| 132 | Overcast | E998B4 | 
| 133 | Needle ice | E586B0 E99288 | 
| 134 | Downpour | E5A4A7 E69AB4 E99BA8 | 
| 136 | Thundershower and hail | E99BB7 E998B5 E99BA8 E4BCB4 E69C89 E586B0 E99BB9 | 
| 137 | Freezing rain | E586BB E99BA8 | 
| 138 | Snow shower | E998B5 E99BAA | 
| 139 | Light rain | E5B08F E99BA8 | 
| 140 | Haze | E99CBE | 
| 141 | Moderate rain | E4B8AD E99BA8 | 
| 142 | Cloudy | E5A49A E4BA91 | 
| 143 | Thundershower | E99BB7 E998B5 E99BA8 | 
| 144 | Moderate to heavy rain | E4B8AD E588B0 E5A4A7 E99BA8 | 
| 145 | Heavy rain to rainstorm | E5A4A7 E588B0 E69AB4 E99BA8 | 
| Command (1 byte) | Generic command (1 byte) | Command data (4 bytes) Padded with 0 if needed | |
|---|---|---|---|
| Category ID | |||
| Generic: 0xFF Individual category Lighting product: 0x01 Socket/power strip: 0x02 Curtain switch: 0x03 Drying rack: 0x04 Fan: 0x05 Bathroom heater: 0x06 Air conditioner: 0x07 Garage door opener: 0x08 Water valve: 0x09 Disinfector: 0x0A Thermostat plug: 0x0B Dimmer switch: 0x0C Scene socket: 0x0D Switch: 0x0E Smart curtain switch module: 0x0F | Send key values: 0x01 | Byte 1: Button behavior (0 – Single press. 1 – Double press. 2 – Long press. 3 – Press and hold. 4 – Press and release) Byte 2: The key value. | |
| Switch: 0x04 | Byte 1: 0 – Turn off. 1 – Turn on. 2 – Pause. Byte 2: The number of gangs. 0 represents the main control. | ||
| Add favorites: 0x05 | Byte 1: 1 – Favorite a state. 2 – Go to a specified favorite. Byte 2: The ID of a favorite, ranging from 0 to 3. | ||
| Countdown timer: 0x06 | Bytes 1 to 2: The countdown time, in seconds and big-endian format. 0 indicates canceling the countdown timer. Byte 3: The action to run when the countdown timer is done. (Reserved byte) | ||
| One-click group query: 0x07 | The sub-device advertises the information about the added group. | ||
| Light on/off: 0x08 | Byte 1: 0 – Turn off. 1 – Turn on. Byte 2: 0 – The main switch. 1 – White light switch. 2 – Colored light switch. | ||
| Brightness adjustment: 0x09 | Byte 1: 0 – Brightness value. 1 – Brightness up. 2 – Brightness down. Byte 2: 0 – Brightness of the current mode. 1 – Brightness of white light. Byte 3: When Byte 1 is 0, this byte indicates brightness percentage (1 to 100%). When Byte 1 is 1 or 2, this byte indicates the step value of brightness (1 to 100%). | ||
| Stepless brightness adjustment: 0x0A | Byte 1: 0 – Start incrementing. 1 – Start decrementing. 2 – Stop adjustment. Byte 2: 0 – Brightness of the current mode. 1 – Brightness of white light. Byte 3: Rate (adjustment percentage per second) Byte 4: The target value. | ||
| Color temperature adjustment: 0x0B | Byte 1: 0 – Color temperature value. 1 – Color temperature up. 2 – Color temperature down. Byte 2: When Byte 1 is 0, this byte indicates color temperature percentage (0 to 100%). When Byte 1 is 1 or 2, this byte indicates the step value of color temperature (0 to 100%). | ||
| Stepless color temperature adjustment: 0x0C | Byte 1: 0 – Start incrementing. 1 – Start decrementing. 2 – Stop adjustment. Byte 2: Rate (adjustment percentage per second) Byte 3: The target value. | ||
| Color adjustment: 0x0D | Byte 1: 0 – Relative transition. 1 – The specified color. 2 – Start cycling adjustment. 3 – Stop cycling adjustment. Byte 2: The ID of the specified color when Byte 1 is 1. | ||
| Hue adjustment: 0x0E | Byte 1: 0 – Hue value. 1 – Hue up. 2 – Hue down. Byte 2: When Byte 1 is 0, this byte indicates hue percentage (0 to 100%). When Byte 1 is 1 or 2, this byte indicates the step value of hue (0 to 100%). | ||
| Stepless hue adjustment:0x0F | Byte 1: 0 – Start incrementing. 1 – Start decrementing. 2 – Stop adjustment. Byte 2: Rate (adjustment percentage per second) Byte 3: The target value. | ||
| Saturation adjustment: 0x10 | Byte 1: 0 – Saturation value. 1 – Saturation up. 2 – Saturation down. Byte 2: When Byte 1 is 0, this byte indicates saturation percentage (0 to 100%). When Byte 1 is 1 or 2, this byte indicates the step value of saturation (0 to 100%). | ||
| Stepless saturation adjustment: 0x11 | Byte 1: 0 – Start incrementing. 1 – Start decrementing. 2 – Stop adjustment. Byte 2: Rate (adjustment percentage per second) Byte 3: The target value. | ||
| Value adjustment: 0x12 | Byte 1: 0 – Value. 1 – Value up. 2 – Value down. Byte 2: When Byte 1 is 0, this byte indicates value percentage (1 to 100%). When Byte 1 is 1 or 2, this byte indicates the step value of value (1 to 100%). | ||
| Stepless value adjustment: 0x13 | Byte 1: 0 – Start incrementing. 1 – Start decrementing. 2 – Stop adjustment. Byte 2: Rate (adjustment percentage per second) Byte 3: The target value. | ||
| HSV (hue, saturation, value) adjustment: 0x14 | Byte 1: Hue percentage (0 to 100%) Byte 2: Saturation (0 to 100%) Byte 3: Value percentage (1 to 100%) | ||
| Scene adjustment: 0x15 | Byte 1: 0 – Relative transition. 1 – The specified scene. 2 – Start cycling adjustment. 3 – Stop cycling adjustment. Byte 2: The ID of the specified scene when Byte 1 is 1. | ||
| Lighting mode selection: 0x16 | Byte 1: 1 – Night light mode. | ||
| Motor rotation adjustment: 0x20 | Byte 1: 0 – Clockwise rotation. 1 – Counterclockwise rotation. 2 – Pause. Byte 2: Travel percentage (0 to 100%). 0 – Continuous rotation. Byte 3: The number of channels. 0 represents the total channel. | ||
| Motor travel setting: 0x21 | Byte 1: 0 – The start position. 1 – The fine-tuning position. 2 – The end position. Byte 2: 0 – The up limit. 1 – The down limit. 2 – The intermediate limit. Byte 3: The number of channels. 0 represents the total channel. | ||
| Movement speed adjustment: 0x22 | Byte 1: 0 – Speed. 1 – Step increment. 2 – Step decrement. Byte 2: The specified speed or step value of speed. Byte 3: The number of channels. 0 represents the total channel. | ||
| Stepless movement speed adjustment: 0x23 | Byte 1: 0 – Start incrementing. 1 – Start decrementing. 2 – Stop adjustment. Byte 2: Rate (adjustment percentage per second) Byte 3: The target value. <br>Byte 4: The number of channels. 0 represents the total channel. | ||
| Temperature adjustment: 0x24 | Byte 1: 0 – The temperature value. 1 – Temperature up. 2 – Temperature down. Bytes 2 to 3: When Byte 1 is 0, this byte indicates the specified temperature. When Byte 1 is 1 or 2, this byte indicates the step value of temperature. The 2-byte temperature value is stored in big-endian. The most significant bit represents the sign (minus or plus) and the rest of the bits represent the number. The number multiplied by 0.1°C is the actual temperature. | ||
| Stepless temperature adjustment: 0x25 | Byte 1: 0 – Start incrementing. 1 – Start decrementing. 2 – Stop adjustment. Byte 2: Rate (adjustment percentage per second) Bytes 3 to 4: The target value of temperature, which is calculated same as above. | ||
| Humidity adjustment: 0x26 | Byte 1: 0 – Humidity value. 1 – Humidity up. 2 – Humidity down. Byte 2: The specified humidity. | ||
| Stepless humidity adjustment: 0x27 | Byte 1: 0 – Start incrementing. 1 – Start decrementing. 2 – Stop adjustment. Byte 2: Rate (adjustment percentage per second) Byte 3: The target value. | ||
| Custom command | |||
| Custom category (1 byte) | Custom command (1 byte) | Parameter (3 bytes) | |
| Lights: 0xFF | RGBY (red, green, blue, yellow) adjustment:0x01 | Byte 1: 0 – Change color to red. 1 – Change color to green. 2 – Change color to blue. 3 – Change color to yellow. | |
| Fan: 0xFE | Fan mode: 0x01 | Byte 1: 0 – Manual adjustment. 1 – Natural wind. 2: Sleep wind. | |
| Bathroom heater: 0xFD | Bathroom heater mode: 0x01 | Byte 1: 0 – Heating. 1 – Ventilation. 2 – Drying. 3 – Fan. | |
| Air conditioner: 0xFC | Sleep: 0x01 | Byte 1: 0 – Off. 1 – On. | |
| Protocol version | Changes | Revision date | Description | 
|---|---|---|---|
| 3.3.0 | Added protocols for control of non-smart accessories. | May 10, 2023 | Added | 
| 3.2.0 | 
 | March 28, 2023 | Added | 
| 3.1.0 | 
 | February 21, 2023 | Added | 
| 3.0.3 | Added the request for weather data (0xB6). | August 1, 2022 | Added new protocol. | 
| 3.0.2 | Added the configuration of the secure connection type to the command 0x01. | May 1, 2022 | Improved the protocol. | 
| 3.0.1 | Modified some descriptions and improved the content layout. | February 15, 2022 | Improved the content layout. | 
| 3.0.0 | Modified the protocol architecture and added some protocols. | November 23, 2021 | For more information, see Bluetooth-specific protocol. | 
| 2.0.2 | Modified some descriptions. | October 16, 2021 | Modified some descriptions. | 
| 2.0.1 | Fixed incorrect description and added term description. | September 8, 2021 | Fixed incorrect description and added term description. | 
| 2.0.0 | Modified the commands 0x01,0x07, and0xE0and added the command0xB5. | July 6, 2021 | Added the bulk data storage and Beacon feature. | 
| 1.0.1 | Modified the description of the low power mode. | March 27, 2021 | None | 
| 1.0.0 | The first release | February 25, 2020 | None | 
Is this page helpful?
YesFeedbackIs this page helpful?
YesFeedback