Bluetooth/BLE

October 1, 2019 ยท View on GitHub

General information on how BLE is used in Xiaomi's devices.

General context

Xiaomi (and it's many, many sub-brands) uses several wireless protocols for their devices, mainly zigbee (aqara devices), BLE (many "standalone" devices and smartbands/smartwatches from huami and amazfit), and wifi (usually their "biggest" devices such as the vacuum cleaner, and some yeelight devices, basically, what's guaranteed to have enough power at all times)

Xiaomi is known to share it's logistics division with it's sub-OEMs, and also it's "Mi Home" ecosystem. They also seems to share some proprietary protocols, especially in BLE and zigbee.

BLE notes

  • Almost every devices implement a similar (if not the same) firmware upgrade logic, there seems to have differences as some uses Nordic semiconductors' DFU service, and other seems to only mimic parts of it. I guess they started by using Nordic microchips and then expanded, and did reproduce the Nordic's DFU mode to their other devices so they still can share most of the code.
  • Some devices implement authentication, even if it's "optional" as you can still talk to the device for some time (around a minute) before it drops the connection. The authentication is encrypted using a custom JNI, "libblecipher.so". These devices seems to include the Flora plant monitor, the Soocare toothbrush, and the temperature sensor, it isn't excluded that they use the same mechanism in other devices such as the mi bands.
  • Xiaomi does have 3 16b UUIDs, but i've only seen fe95 being used so far.
  • Huami have 2 16b UUIDs used by the mi bands: 0xFEE0 and 0xFEE1

Devices covered (Aka. what's coming sooner or later)

If you have a xiaomi ecosystem device and did reverse engineer it, feel free to contribute. For now, for obvious reasons, i'll focus on some devices i already own:

Device nameDevice IDDocumentationStatus
Mi Body Composition Scalehuami.health.scale2*DocDone
Mi toothbrushsoocare.toothbrush.m1DocDone
Yeelight Bedside lampyeelink.light.ble1DocTODO
Mi LED Desk lampyeelink.light.lamp1DocTODO
Yeelight Candelayeelink.light.mb2grpDocTODO
Mi Kettle V1yunmi.kettle.v1DocTODO
Temperature/Humidity sensorcleargrass.sensor_ht.dk1DocWIP
Flora plant monitorhhcc.plantmonitor.v1DocTODO
Mi Band 1xiaomi.watch.band1DocTODO
Mi Band 2xiaomi.watch.band2DocTODO
iHealth Track Blood Pressure Monitorihealth.bp.550btDocWIP

* Guesstimate, it isn't in mi home, but in some other app, of the ecosysteme or OEM's one

And for other protocols?