Recovering the Linksys WRT54GL via TFTP

Last May, DD-WRT released the (long in development) v24 of their firmware. I had been running one of the release candidates for it on my Linksys WRT54GL, but decided today to upgrade to the stable release. I downloaded the appropriate file (dd-wrt.v24_std_generic.bin), followed the instructions for flashing through the web GUI, and promptly bricked the router.

It wasn’t totally destroyed. I could still ping the router, but couldn’t access it in any other way. The power light would flash repeatedly, and no other lights came on. No amount of hard resets would fix it.

According to DD-WRT’s wiki article on bad flashes, the repetitive blinking of the power light means that the bootloader is defective, but that the problem might be solved using a TFTP recovery. The idea is that when the router first boots up, there’s a brief moment where it will accept an upload. By pushing through firmware, you are able to temporarily boot the router.

On older Linksys routers, this only works with the official Linksys firmware, so I downloaded the latest version from Linksys’ support page for the WRT54GL. Because the router will only accept the firmware at the very start of the boot process, I first unplugged the router, turning it off. To monitor the router during the process, I started a ping from my machine.

$ ping 192.168.1.1

Then, using the TFTP client that ships with OS X, I executed the upload

$ echo "put FW_WRT54GL_4.30.12.3_US_EN_code.bin" | tftp -e 192.168.1.1

and immediately plugged the router back in. In 10 seconds, TFTP reported that the file had been sent.

At this point, the router stopped responding to my pings for about 30 seconds. When it began replying again, I was able to access the default Linksys web GUI. The first thing I did in the GUI was to hit the “reset to factory defaults” button, which clears the NVRAM of my bad DD-WRT image and installs the fresh Linksys image. After that, I installed a new DD-WRT “mini” image (the WRT54GL requires you flash with “mini” before upgrading to “standard” when moving from the default firmware), by uploading dd-wrt.v24_mini_generic.bin via the upgrade page. This worked without a hitch.

In the DD-WRT web interface, I tried to flash the router with the standard firmware, but was greeted by a vague error message that told me only that the upgrade had failed. I went back to the wiki to see what the differences were between mini and standard and decided that it would be find to leave the router with mini. All I needed was for the router to act as a wireless repeater with a virtual interfaces. The mini firmware supports this, so I was able to setup the router just as before.

Return

I’ve returned early from Spain, arriving in the States last night.

I walked only about 110 miles on the Camino de Santiago, from St. Jean-Pied-de-Port to Logrono, before deciding that it was time to come back. During my short time on the walk, the Camino gave me what it could, and I gladly accept the gift, but I felt the remaining miles had nothing more to offer.

Following the Camino’s yellow arrows day after day, while comforting in their promise of direction and safety, is too structured an experience. This, the cultivated landscape, and the crowds of walkers contribute to a feeling of limitation.

I seek to find my own paths, and to forge my own way. Only by traveling into the unknown can we explore our selves. And so, despite the cultural differences, despite the linguistic barrier, and despite the unknown country, I think the Camino is flawed. There are no yellow arrows for the mind, save for those we paint our selves.

For me, it must be a journey wilder than this. One for which I do not have my way painted upon the landscape. A journey in which I am dependent on the self, alone in a solitary wilderness. To explore that is to touch the crevices of consciousness, running one’s finger upon the peculiar bumps of its surface.

From the 21st of June till the 1st of July, I walked, taking a day off in Pamplona and in Viana. In Logrono, I spent 3 nights before taking a train back to Madrid, where I’ve been for the past week.

I continue my pilgrimage elsewhere.

IMG_1716