You will need a UART 3.3V USB adapter, open the device and connect the UART to a PC and to it.
The UART pinout and some more instructions you can find here. I was able to make a successful connection using a three pin connector without soldering.
After that, you will need to run a serial terminal on the PC (Putty for example) connected to the UART serial port @115200 bps.
Turn on your device, while it is booting in the serial console press "x". This will activate the web recovery. Then open a browser at 192.168.0.1 and upload the factory firmware. Wait a few minutes and the router will be recovered with the factory firmware. I have not tried but it may be possible to recover directly with the OpenWRT factory image.
I believe (just an hypothesis) the web recovery is not automatically activated because uboot finds a valid kernel and tries to load it. And what happens is what it seems kernel gets stuck for some reason and does not report any error.
That's why the device ends up bricked without any activity in the ethernet ports because kernel did not load and web recovery is not activated. TFTP is also not an option.
Therefore the only option is to attach a UART and activate web recovery manually via serial console before kernel load.
That's correct. What I was referring is that some UART adapters have a jumper to configure 3.3V or 5V as the signal/TTL level (see below). It needs to be 3.3V otherwise if you use 5V it may/will damage your router.
The wires that need to be connected to the router are only three: GND, TXD, RXD.
You should be good as is. Check the spec page of your Amazon link, it says 3.3V.
In other news, the offending commit has been located and reverted. I'd wait for new master images from the buildbots before trying to flash them (you can of course build your own).
If you measure between GND and RX you should see the nominal voltage. Between GND and RX you will see ~50% as it is pulling high and low in case anything is listening.
Important note: usually the pins are labeled from the device perspective. So the TXD (transmit data) pin of the adapter must be connected to the RXD (receive data) on the router, and vice-versa.
Have you tried 192.168.0.1? This router has a recovery web page. Otherwise you may need to open it and use an UART to activate the recovery page as described in this topic.
Can you explain how you connected it without soldering?
I have this (RPi) serial adapter and also a Pine64 woodpecker serial adapter, but I assume I'd need pins (like RPi's GPIO pins) to connect them, but all I see are the holes.
I have no soldering experience, so if I can do without that, that would be great.
I used a 3 pin header (like the one below, but cut with 3 pins only). I plugged the shorter side (without soldering) to the router board, and to the other side the serial wiring.
I don't think so. The enclosure of this device is pretty tight. So unless you drill a hole for the UART wires, I do not believe it will be possible to close the case with the UART wires attached.
Thanks for that very useful info, much appreciated
The Pine64 UART adapter does have individual wires, which might fit in the existing holes, but it looks like those holes are below the board, which means the chances of success are quite low.
I thought it may be an interesting learning experience, but I'm not willing to damage things for that.
Cheers