Difference between revisions of "Debrick Routers Using zJTAG and DIYGADGET.COM's FTA JTAG Cable"

From TIAO's Wiki
Jump to: navigation, search

10 PCS, 10cm x 10cm, 2 layers prototype for $38.80 shipped!
(Debrick it!)
 
(6 intermediate revisions by the same user not shown)
Line 25: Line 25:
  
 
If you have tried everything before the section "Recovery by JTAG cable" and it still doesn't work, you can now proceed with the following tutorials on how to save your router by using DIYGADGET's FTA JTAG cable.
 
If you have tried everything before the section "Recovery by JTAG cable" and it still doesn't work, you can now proceed with the following tutorials on how to save your router by using DIYGADGET's FTA JTAG cable.
 +
 +
 +
You need a PC with parallel port.  USB to parallel adapter will NOT work.
 +
 +
No USB port? no problem, use our USB JTAG:
 +
 +
[http://www.diygadget.com/tiao-usb-multi-protocol-adapter-jtag-spi-i2c-serial.html http://www.diygadget.com/media/catalog/product/t/u/tumpa-small.jpg]
 +
 +
[http://www.diygadget.com/tiao-usb-multi-protocol-adapter-jtag-spi-i2c-serial.html TIAO Multiple Protocol Adapter (JTAG/SPI/I2C/Serial)]
 +
 +
Tutorial (debrick router using USB):
 +
 +
[[Debrick Wireless Router Using TUMPA and zJTAG]]
  
 
==Router Basics==
 
==Router Basics==
Line 92: Line 105:
 
[[Image:Zjtag02.png|none]]
 
[[Image:Zjtag02.png|none]]
  
Download [[http://www.tiaowiki.com/download//file.php?id=34 zJTAG]] program and unzip it to a temp directory on your harddrive.
+
Download [[http://www.tiaowiki.com/download//file.php?id=37 zJTAG]] program and unzip it to a temp directory on your harddrive.
  
 
You will have the following files:
 
You will have the following files:
Line 106: Line 119:
 
In this demonstration, I soldered 12 pin header on my router (WRT54GS).
 
In this demonstration, I soldered 12 pin header on my router (WRT54GS).
  
This is the JTAG header on my WRT54GS router:
+
Now we need to make the following connections:
  
[[close up of the router header]]
+
10 PIN FTA header and WRT54GS:
  
This is the 10 pin header of the FTA JTAG cable:
+
[[image:Fta.jtag.10.conn.jpg|none]]
  
[[ closeup of the 10 pin jtag]]
+
or
  
This is the 20 pin header of the FTA JTAG cable:
+
20 PIN FTA header and WRT54GS:
  
[[ closeup of the 20 pin header]]
+
[[image:Fta.jtag.20.conn.jpg|none]]
  
Now we need to make the following connections:
 
 
[[ pic shows router header and 10 pin]]
 
 
or
 
 
[[ pic shows router header and 20 pin with connections]]
 
  
 
Now, make the connections using the flexible cables provided in the package.  You can use either 10 pin header or 20 pin header from the JTAG cable.
 
Now, make the connections using the flexible cables provided in the package.  You can use either 10 pin header or 20 pin header from the JTAG cable.
Line 147: Line 153:
  
 
[[image:Fta.jtag.png|none]]
 
[[image:Fta.jtag.png|none]]
 
  
 
===Debrick it!===
 
===Debrick it!===
Line 170: Line 175:
 
For a collection of the JTAG pinout of other routers, please take a look [[http://www.dd-wrt.com/wiki/index.php/JTAG_pinouts Router JTAG pinouts]].
 
For a collection of the JTAG pinout of other routers, please take a look [[http://www.dd-wrt.com/wiki/index.php/JTAG_pinouts Router JTAG pinouts]].
  
You can cut the DIYGADGET's JTAG cable, solder wire 1, 6, 3, 5, 7 and 9 of the 12 pin flat cable to your router's TDI, GND, TDO, TMS, TCK respectively.  You can check the schematic above for details.  (Make sure use wire 6 of the 12 pin flat cable for ground.  Wire 6 is the only GND line in the 12 pin flat cable, it connects to the DB25's 18-25).
+
You can use DIYGADGET's JTAG cable, connect wire 4, 3, 1, 6 and 9 of the 10 pin flat cable to your router's TDI, TCK, TMS, TDO, GND respectively, or, connect 9, 11, 13, 15 and 20 of the 20 pin flat cable to your router's TDI, TCK, TMS, TDO, GND respectively, then run zjtag with "/diygadgetfta" option to erase/backup/flash the flash chip.
 +
 
 +
 
  
 
<span class="plainlinks">
 
<span class="plainlinks">

Latest revision as of 16:07, 3 April 2012








Buy various JTAG cables for your Satellite Receiver, Cable Modem, Wireless Router, Standard Wiggler from http://www.easymg.com and http://www.diygadget.com


In this tutorial, I am going to show you how to debrick your router using DIYGADGET's FTA (All in one, 20 pin or 10 pin) JTAG cable for routers.


Before you try to JTAG your router, we highly recommend you to try a few other steps before you JTAG your router.

Things need to try before you JTAG the router

Please read carefully on this article:

Recover from a Bad Flash

If you have tried everything before the section "Recovery by JTAG cable" and it still doesn't work, you can now proceed with the following tutorials on how to save your router by using DIYGADGET's FTA JTAG cable.


You need a PC with parallel port. USB to parallel adapter will NOT work.

No USB port? no problem, use our USB JTAG:

tumpa-small.jpg

TIAO Multiple Protocol Adapter (JTAG/SPI/I2C/Serial)

Tutorial (debrick router using USB):

Debrick Wireless Router Using TUMPA and zJTAG

Router Basics

See Debrick_Routers_Using_JTAG_Cable#Router_Basics

Using JTAG Cable to Repair Bricked Router

If you have read this far, it means the only way to debrick your router is by using a JTAG cable. Sorry to hear that! However, don't worry, the steps are really straightforward!

DIYGADGET's Router FTA JTAG Cable

The is the schematic of the our FTA JTAG cable:

0.jpg

Ignore the signal names on the connections in above picture. It's up to the software to choose which pin is for what signal. For example, in above picture, FTA's JTAG software will use DB25's pin 4 as TDI. However this is not the case in the wireless router JTAG software (e.g. tjtag or zJTAG).

This is the JTAG pinout of the Linksys WRT54G(GS/GL) series routers:

nTRST  1   2 GND
TDI    3   4 GND
TDO    5   6 GND
TMS    7   8 GND
TCK    9  10 GND
nSRST 11  12 GND
Linksys Series Routers JTAG Pinout
DB25 Router Function
2 3 TDI
3 9 TCK
4 7 TMS
5 1 TRST (Not Connected)
13 5 TDO
18-25 2,4,6,8,10 GND


Looking at above table, the wireless router JTAG software (tjtag or zJTAG) uses DB25's pin 2, 3, 4, 13 and GND. Compare this with FTA's JTAG schematic, they use identical pins. FTA JTAG also uses these pins. So it is clear now, we can use FTA JTAG cable to debrick wireless routers.

Disassemble WRT54G/GS/GL) Series Router

See Debrick_Routers_Using_JTAG_Cable#Disassemble_WRT54G.2FGS.2FGL.29_Series_Router

Locate the JTAG Pins/Pads on the Router

See Debrick_Routers_Using_JTAG_Cable#Locate_the_JTAG_Pins.2FPads_on_the_Router

The Softwares

We will need to use DIYGADGET's zJTAG (version 0.2 or above) for our debricking process.

Zjtag02.png

Download [zJTAG] program and unzip it to a temp directory on your harddrive.

You will have the following files:

Zjtag.files.png

WinIO32 is used for accessing parallel port, no need to run loaddrv or giveio.

Making The JTAG Connection

This is the exciting part of this tutorial. If your router (like the Linksys WRT54G series) already has the standard 12 pin JTAG pads on the PCB, you mostly like do NOT need to solder wires on your PCB. Otherwise you many need to solder IDC headers on your board.

In this demonstration, I soldered 12 pin header on my router (WRT54GS).

Now we need to make the following connections:

10 PIN FTA header and WRT54GS:

Fta.jtag.10.conn.jpg

or

20 PIN FTA header and WRT54GS:

Fta.jtag.20.conn.jpg


Now, make the connections using the flexible cables provided in the package. You can use either 10 pin header or 20 pin header from the JTAG cable.

It looks like this:

10 PIN header:

Fta.jtag.10.close.jpg

10 Pin setup:

Fta.jtag.10.jpg

20 Pin header:

Fta.jtag.20.close.jpg

20 Pin setup:

Fta.jtag.20.jpg

Now get your PC ready, make sure the parallel port is 0x378 and mode is ECP or EPP. (Check BIOS setting of your PC if you are not sure).

Plug the db25 connector to your PC's parallel port:

Fta.jtag.png

Debrick it!

Let's debrick your router!

  1. Attach the router's power adapter to the wall outlet.
  2. From the command prompt cd to your unzipped zJTAG's windows directory and run zjtag.exe to get a list of options.
  3. To check your cable, run command zjtag.exe -probeonly /diygadgetfta. It will automatically detect the CPU type (see pic below for an example of LINKSYS WRT54GS). If not then check your cable.
    Probe Only Output
  4. Backup CFE (command zjtag.exe -backup:cfe /diygadgetfta):
    backup CFE
    . It took 60 seconds to backup my WRT54GS' CFE.
  5. Try above steps at least 2 times, generate backups again, then use a binary comparison software to compares the backups, make sure they are exactly the same before you erase anything.
  6. Finally to erase your NVRAM (the usual cause of the problem) with command zjtag.exe -erase:nvram /diygadgetfta
  7. If that doesn't work, erase the kernel (firmware): zjtag.exe -erase:kernel /diygadgetfta, then reflash the kernel via TFTP. This is a very good tutorial on how to flash your router with TFTP: [TFTP Flash]
  8. If it still doesn't work, try to find a CFE for your router (make sure model/version matches) first. Here are two repositories of some router's CFE: [CFE collection project] and [CFE collection 2]
  9. The CFE bin files in the repository all have MAC addresses that DO NOT MATCH your hardware. Use the CFE editing tool "IMGTOOL_NVRAM" available from The [Bitsum Wiki] to set the et0macaddr and il0macaddr before uploading the CFE. et0macaddr is the address printed on the outside; il0macaddr is that same address, plus one. Example: If the printed address is 00:90:4d:83:00:01, then et0macaddr is 00:90:4d:83:00:01 and il0macaddr is 00:90:4d:83:00:02. These are HEX numbers, so HEX 09 plus one is 0A, not 10.
  10. Erase the CFE of your router and flash the working CFE back. zjtag.exe -erase:cfe /diygadgetfta will erase your router's CFE and zjtag.exe -flash:cfe /diygadgetfta will flash the CFE back to your router. Remember to use the modified CFE bin.

Non Linksys Routers

If your router doesn't have JTAG headers or pads, but if it has JTAG enabled, you can still debrick it using the above technique. However, it is very likely you will need to solder the wire on the board.

For a collection of the JTAG pinout of other routers, please take a look [Router JTAG pinouts].

You can use DIYGADGET's JTAG cable, connect wire 4, 3, 1, 6 and 9 of the 10 pin flat cable to your router's TDI, TCK, TMS, TDO, GND respectively, or, connect 9, 11, 13, 15 and 20 of the 20 pin flat cable to your router's TDI, TCK, TMS, TDO, GND respectively, then run zjtag with "/diygadgetfta" option to erase/backup/flash the flash chip.



Buy various JTAG cables for your Satellite Receiver, Cable Modem, Wireless Router, Standard Wiggler from http://www.easymg.com and http://www.diygadget.com



10 PCS, 10cm x 10cm, 2 layers prototype for $38.80 shipped!