Gaining root

Solder 3 contacts GND, RX, TX to UART:

UART Pinout

Then connect UART 2 USB adapter. To use serial console while booting, you can use minicom/picocom on Linux or PuTTY on Windows. Use baudrate 115200. Stop booting by pressing any key in the uart terminal right after powering the device. If it not stops with prompt => you should reboot the gateway by plugging it off and then on.

Prepare a new password for the root user. It can be blank, but you have to confirm it after setting it in the console.

Enter the following line and boot will start:

setenv bootargs "${bootargs} single rw init=/bin/bash" && boot

As an alternative, if your terminal input displays weird characters, use sh instead of bash

setenv bootargs "${bootargs} single rw init=/bin/sh" && boot

After booting to linux bash console, enter:

passwd

Enter the prepared password 2 times. In case of an empty password, you have to press enter one more time to confirm it.

In case your password change is failing over and over again due to mismatched passwords - change it with following oneliner:

usermod --password $(echo NEW_PASSWORD | openssl passwd -1 -stdin) root

NOW YOUR GATEWAY HAS ROOT

Newer firmwares can provide init script with disabled shell login on the normal start and display this message:

INIT: no more processes left in this runlevel

Enable getty on serial console. If you have an older firmware, you can run this command as well, it will run as no-op.

sed -i "s/#mxc0/mxc0/" /etc/inittab && sync

To enable ssh server on the gateway add the following line at the end of /etc/rc.local before the /home/root/fac/fac_test line:

/etc/init.d/dropbear start &

Now you can reboot and connect to your gateway at *GATEWAY_IP*, port 22.

If you receive an error:

Starting Dropbear SSH server: Pseudo-terminal will not be allocated because stdin is not a terminal.
ssh: connect to host rsa port 22: Connection refused

It means that your dropbear is compiled without ssh-server support and can serve only as a client. Replace it with a fully functional ssh-server:

mv /usr/sbin/dropbearmulti /usr/sbin/dropbearmulti.backup
echo -e "GET /openlumi/openlumi.github.io/master/files/dropbearmulti HTTP/1.0\nHost: raw.githubusercontent.com\n" | openssl s_client -quiet -connect raw.githubusercontent.com:443 -servername raw.githubusercontent.com 2>/dev/null | sed '1,/^\r$/d' > /usr/sbin/dropbearmulti
chmod +x /usr/sbin/dropbearmulti

Setting Wi-Fi without Mi Home app.

You can omit this section in case the gateway is already connected using Mi Home application.

After rebooting, the gateway enables the testing console. To exit to normal login mode, type exit_factory, then press enter.

Then log in to the console with the user root and password you have set.

How gateway enables Wi-Fi

While booting, gateway while executing rc.local it runs the lines:

/home/root/set_mac.sh &
/lumi/app/miio/wifi_start.sh > /dev/null 2>&1 & 

Those lines check for the file /lumi/conf/wifi.conf and if it is absent, it starts an open Wi-Fi Access Point.

Creating Wi-Fi config

Run the following lines with your own Network name and password. Keep key_mgmt as is:

echo 'ssid="lao_mao"' > /lumi/conf/wifi.conf
echo 'psk="12345678"' >> /lumi/conf/wifi.conf
echo 'key_mgmt=WPA' >> /lumi/conf/wifi.conf

Also, you can use vi editor to set Wi-Fi credentials:

vi /lumi/conf/wifi.conf

Press i, then paste

ssid="lao_mao"
psk="12345678"
key_mgmt=WPA

Then exit with saving: (Press Esc, then type :qw and press Enter)

To check the config is correct you can manually run the lines from /etc/rc.local:

/lumi/app/miio/wifi_start.sh 

You will see the connection process. Press ctrl+c after you got the info if the device is connected or not. If the Wi-Fi credentials are set correctly, ifconfig will show IP address of the gateway.