An alternative firmware for the Mijia Xiaomi Desk Lamp
After finding fvollmers project, it was possible to create this firmware. Thanks for the inspiration and the helpful details like GPIOs and pinouts.
- This alternative firmware compiles with the Arduino IDE.
- It provides a webserver and URLs for controlling the light.
- The rotary knob reacts on single click and toggles between OFF an ON
The initial upload requires the following steps:
- Open the desk lamp. Three screws are hidden underneath the rubber. Slightly peel away the rubber and unfasten the screws.
- Then look for the PCB-A located below the rotary knob, it carries the ESP8266 module. Unfasten the screws of that PCB-A, pull off the knob gently and turn the PCB-A around. To protect the knob, I wrapped some electrical tape around it to prevent scratches and used pliers to pull it upwards, away from the PCB-A.
- Solder cables to
RX
,TX
andGPIO0
.GND
is also required for programming, but depending on your programming cable this signal is easily accessible even when the PCB is put back in place. Soldering to the ESP8266 module will result in fragile connections. Because of that, I decided to provide cable support afterwards by applying hot-melt-glue, otherwise the connections would not last long when handled. A labeled picture certainly helps. - Put back the PCB-A, fasten the screws.
- Attach a 3.3V USB to serial adapter cable. Connect cables
GND
toGND
, cablesTx
toRx
and cablesRx
toTx
. If you want to check correct wiring, power up the lamp and use the serial-monitor for any activity. Most likely it will just print gibberish due to mismatched baudrate, but this is enough to seeRx
andTx
should be wired correctly; if there is no activity when powering the lamp try swapping theRx
andTx
lines.
Arduino Settings:
- Generic ESP8266 Module
- CPU Frequency 80 Mhz
- Flash Size 1 M (64k SPIFFS)
- Flash Mode is QIO
- Crystal Frequency is 26 MHz
- Reset Method "ck"
- Connect GPIO0 to GND. Keep it pulled low until firmware has uploaded from the Arduino IDE.
- Compile the firmware and upload from within the Arduino IDE.
- Unconnect GPIO0 from GND, power-cycle the lamp and it should dim-up. The serial monitor should inform you about the startup (115200, 8N1).
Once the firmware has uploaded initially, you can reupload through WiFi using the BASH script (assuming the desk-lamp got the IP adress 192.168.2.99):
# ./flash.sh 192.168.2.99
The stdout-messages should look as follows:
./flash.sh 192.168.2.99
enableUpdates: 1
<META http-equiv="refresh" content="15;URL=/">Update Success! Rebooting...
To monitor the log messages, use the log.sh
BASH script. It refreshes the log messages every second.
./log.sh 192.168.22.99
The internal webserver serves files from SPIFFS. To fill SPIFFS the most convenient way is creating a subfolder data
in the sketch-folder and upload with the provided BASH-file upload.sh
.
Uploading all files from ./data
to SPIFFS:
./upload_files.sh 192.168.2.99
Upload a single file file to SPIFFS:
./upload_files.sh 192.168.2.99 myfile
Actually, just basic commands are supported via MQTT:
- Power ON:
desklamp/power/ON
- Power OFF:
desklamp/power/OFF
- Toggle:
desklamp/toggle
You can know the current status of the lamp by subscribe on this topic:
- Status:
desklamp/status
To send commands to the desk lamp or read the state, the following HTTP-handlers are implemented:
- Power off:
http://192.168.2.99/poweroff
- Set color to 100% warmwhite:
http://192.168.2.99/color?ratio=1.0&brightness=1.0
- Set color to 100% coldwhite:
http://192.168.2.99/color?ratio=0.0&brightness=1.0
- Set color to 25% coldwhite and 25% warmwhite:
http://192.168.2.99/color?ratio=0.5&brightness=0.5
- Get color as JSON:
http://192.168.2.99/color
- Get current state as JSON:
http://192.168.2.99/all
- Get log messages:
http://192.168.2.99/log
- Reset / Restart the lamp:
http://192.168.2.99/reset
- Retrieve the config as JSON (does not expose the WiFi credentials):
http://192.168.2.99/config.json
- There are more URLs to flash the firmware and upload files for the webserver (namely:
unlock
,edit
,format
,update
). To prevent unauthorized flashing of (malicious) firmware or webserver files at least a hardcoded password is required. If you worry about this password change it in the sourcedode and notice that HTTP does not encrypt it.