hugebird 发表于 2008-2-12 21:10:59

Broadcom路由DSL猫用的JTAG工具最新版

熟悉Broadcom路由器的朋友,应该知道HairyDairyMaid WRT54G DeBrick JTAG工具。此次发布的是个Mod版。主要增加了对Big Endian BCM6338,6348等Broadcom DSL芯片的支持,修正了DMA数据访问和字节颠倒的问题,读写时间大大加快。增加对64K tiny CFE的支持。增加了自定义并口的支持。



=============================================
Broadcom EJTAG Debrick Utility v1.0-hugebird
=============================================
ABOUT: This program reads/writes flash memory on the Broadcom MIPS(LE)
      Chip and compatible routers via EJTAG using either DMA Access
      routines or PrAcc routines (slower/more compatible). Processor chips
      supported in this version include the following chips:
            Supported Chips
            ---------------
            Broadcom BCM4702 Rev 1 CPU            
            Broadcom BCM4704 KPBG Rev 9 CPU         
            Broadcom BCM4704 Rev 8 CPU            
            Broadcom BCM4712 Rev 1 CPU            
            Broadcom BCM4712 Rev 2 CPU            
            Broadcom BCM4785 Rev 1 CPU            
            Broadcom BCM5350 Rev 1 CPU            
            Broadcom BCM5352 Rev 1 CPU            
            Broadcom BCM5354 KFBG Rev 1 CPU         
            Broadcom BCM5354 KFBG Rev 2 CPU         
            Broadcom BCM5365 Rev 1 CPU            
            Broadcom BCM5365 Rev 1 CPU            
            Broadcom BCM6345 Rev 1 CPU            
            Broadcom BCM6338 Rev 1 CPU            
            Broadcom BCM6348 Rev 1 CPU            
            Broadcom BCM6358 Rev 1 CPU            
            TI AR7WRD TNETD7300GDU Rev 1 CPU      
            BRECIS MSP2007-CA-A1 CPU               
            TI TNETV1060GDW CPU                     

USAGE: BrJtag </noreset> </noemw> </nocwd> </nobreak> </noerase>
                      </notimestamp> </dma> </nodma> <port:XXX> <revendian>
                      <start:XXXXXXXX> </length:XXXXXXXX>
                      </silent> </skipdetect> </instrlen:XX> </fc:XX> /bypass
            Required Parameter
            ------------------
            -backup:cfe
            -backup:tfe
            -backup:nvram
            -backup:kernel
            -backup:wholeflash
            -backup:custom
            -backup:bsp
            -erase:cfe
            -erase:nvram
            -erase:kernel
            -erase:ternel
            -erase:wholeflash
            -erase:custom
            -erase:bsp
            -flash:cfe
            -flash:nvram
            -flash:kernel
            -flash:wholeflash
            -flash:custom
            -flash:bsp
            -probeonly
            Optional Switches
            -----------------
            /noreset ........... prevent Issuing EJTAG CPU reset
            /noemw ............. prevent Enabling Memory Writes
            /nocwd ............. prevent Clearing CPU Watchdog Timer
            /nobreak ........... prevent Issuing Debug Mode JTAGBRK
            /noerase ........... prevent Forced Erase before Flashing
            /notimestamp ....... prevent Timestamping of Backups
            /dma ............... force use of DMA routines
            /nodma ............. force use of PRACC routines (No DMA)
            /window:XXXXXXXX ... custom flash window base (in HEX)
            /start:XXXXXXXX .... custom start location (in HEX)
            /length:XXXXXXXX ... custom length (in HEX)
            /silent ............ prevent scrolling display of data
            /skipdetect ........ skip auto detection of CPU Chip ID
            /instrlen:XX ....... set instruction length manually
            /wiggler ........... use wiggler cable
            /bypass ............ Unlock Bypass command & disable polling
            /revendian.......... reverse chip endianess. (default is little)
            /tinycfe............ enable tiny CFE support
            /port:XXX........... custom parallel port(default XXX is 378)
                                 only use for Windows version
            /fc:XX = Optional (Manual) Flash Chip Selection
            -----------------------------------------------
            /fc:01 ............. MX29LV800BTC 512kx16 TopB(1MB)      
            /fc:02 ............. MX29LV800BTC 512kx16 BotB(1MB)      
            /fc:03 ............. AMD 29lv160DB 1Mx16 BotB   (2MB)      
            /fc:04 ............. AMD 29lv160DT 1Mx16 TopB   (2MB)      
            /fc:05 ............. EON EN29LV160A 1Mx16 BotB(2MB)      
            /fc:06 ............. EON EN29LV160A 1Mx16 TopB(2MB)      
            /fc:07 ............. MBM29LV160B 1Mx16 BotB   (2MB)      
            /fc:08 ............. MBM29LV160T 1Mx16 TopB   (2MB)      
            /fc:09 ............. MX29LV161B 1Mx16 BotB      (2MB)      
            /fc:10 ............. MX29LV161T 1Mx16 TopB      (2MB)      
            /fc:11 ............. K8D1716UTC1Mx16 TopB   (2MB)      
            /fc:12 ............. K8D1716UBC1Mx16 BotB   (2MB)      
            /fc:13 ............. ST M29W160EB 1Mx16 BotB    (2MB)      
            /fc:14 ............. ST M29W160ET 1Mx16 TopB    (2MB)      
            /fc:15 ............. Macronix MX25L160A         (2MB)      
            /fc:16 ............. K8D3216UTC2Mx16 TopB   (4MB)      
            /fc:17 ............. K8D3216UBC2Mx16 BotB   (4MB)      
            /fc:18 ............. AMD 29lv320MB 2Mx16 BotB   (4MB)      
            /fc:19 ............. AMD 29lv320MT 2Mx16 TopB   (4MB)      
            /fc:20 ............. AMD 29lv320MT 2Mx16 TopB   (4MB)      
            /fc:21 ............. TC58FVB321 2Mx16 BotB      (4MB)      
            /fc:22 ............. TC58FVT321 2Mx16 TopB      (4MB)      
            /fc:23 ............. AT49BV/LV16X 2Mx16 BotB    (4MB)      
            /fc:24 ............. AT49BV/LV16XT 2Mx16 TopB   (4MB)      
            /fc:25 ............. MBM29DL323BE 2Mx16 BotB    (4MB)      
            /fc:26 ............. MBM29DL323TE 2Mx16 TopB    (4MB)      
            /fc:27 ............. AMD 29lv320DB 2Mx16 BotB   (4MB)      
            /fc:28 ............. AMD 29lv320DT 2Mx16 TopB   (4MB)      
            /fc:29 ............. MBM29LV320BE 2Mx16 BotB    (4MB)      
            /fc:30 ............. MBM29LV320TE 2Mx16 TopB    (4MB)      
            /fc:31 ............. MX29LV320AB 2Mx16 BotB   (4MB)      
            /fc:32 ............. MX29LV320AB 2Mx16 BotB   (4MB)      
            /fc:33 ............. MX29LV320AT 2Mx16 TopB   (4MB)      
            /fc:34 ............. MX29LV320AT 2Mx16 TopB   (4MB)      
            /fc:35 ............. ST 29w320DB 2Mx16 BotB   (4MB)      
            /fc:36 ............. ST 29w320DT 2Mx16 TopB   (4MB)      
            /fc:37 ............. W19B(L)320ST   2Mx16 TopB(4MB)      
            /fc:38 ............. W19B(L)320SB   2Mx16 BotB(4MB)      
            /fc:39 ............. M29DW324DT 2Mx16 TopB      (4MB)      
            /fc:40 ............. M29DW324DB 2Mx16 BotB      (4MB)      
            /fc:41 ............. TC58FVM6T2A4Mx16 TopB    (8MB)      
            /fc:42 ............. TC58FVM6B2A4Mx16 BopB    (8MB)      
            /fc:43 ............. K8D6316UTM4Mx16 TopB   (8MB)      
            /fc:44 ............. K8D6316UBM4Mx16 BotB   (8MB)      
            /fc:45 ............. Intel 28F160B3 1Mx16 BotB(2MB)      
            /fc:46 ............. Intel 28F160B3 1Mx16 TopB(2MB)      
            /fc:47 ............. Intel 28F160C3 1Mx16 BotB(2MB)      
            /fc:48 ............. Intel 28F160C3 1Mx16 TopB(2MB)      
            /fc:49 ............. Intel 28F320B3 2Mx16 BotB(4MB)      
            /fc:50 ............. Intel 28F320B3 2Mx16 TopB(4MB)      
            /fc:51 ............. Intel 28F320C3 2Mx16 BotB(4MB)      
            /fc:52 ............. Intel 28F320C3 2Mx16 TopB(4MB)      
            /fc:53 ............. Sharp 28F320BJE 2Mx16 BotB (4MB)      
            /fc:54 ............. Intel 28F640B3 4Mx16 BotB(8MB)      
            /fc:55 ............. Intel 28F640B3 4Mx16 TopB(8MB)      
            /fc:56 ............. Intel 28F640C3 4Mx16 BotB(8MB)      
            /fc:57 ............. Intel 28F640C3 4Mx16 TopB(8MB)      
            /fc:58 ............. Intel 28F160S3/5 1Mx16   (2MB)      
            /fc:59 ............. Intel 28F320J3 2Mx16       (4MB)      
            /fc:60 ............. Intel 28F320J5 2Mx16       (4MB)      
            /fc:61 ............. Intel 28F320S3/5 2Mx16   (4MB)      
            /fc:62 ............. Intel 28F640J3 4Mx16       (8MB)      
            /fc:63 ............. Intel 28F640J5 4Mx16       (8MB)      
            /fc:64 ............. Intel 28F128J3 8Mx16      (16MB)      
            /fc:65 ............. SST39VF1601 1Mx16 BotB   (2MB)      
            /fc:66 ............. SST39VF1602 1Mx16 TopB   (2MB)      
            /fc:67 ............. SST39VF3201 2Mx16 BotB   (4MB)      
            /fc:68 ............. SST39VF3202 2Mx16 TopB   (4MB)      
            /fc:69 ............. SST39VF320 2Mx16         (4MB)      
            /fc:70 ............. SST39VF6401 4Mx16 BotB   (8MB)      
            /fc:71 ............. SST39VF6402 4Mx16 TopB   (8MB)      
            /fc:72 ............. SST39VF6401B 4Mx16 BotB    (8MB)      
            /fc:73 ............. SST39VF6402B 4Mx16 TopB    (8MB)      
            /fc:74 ............. Spansion S29GL032M BotB    (4MB)      
            /fc:75 ............. Spansion S29GL032M TopB    (4MB)      
            /fc:76 ............. Spansion S29GL064M BotB    (8MB)      
            /fc:77 ............. Spansion S29GL064M TopB    (8MB)      

NOTES: 1) If 'flashing' - the source filename must exist as follows:
         CFE.BIN, NVRAM.BIN, KERNEL.BIN, WHOLEFLASH.BIN or CUSTOM.BIN
         BSP.BIN, CFE.BIN, TERNEL.BIN
      2) If you have difficulty auto-detecting a particular flash part
         you can manually specify your exact part using the /fc:XX option.
      3) If you have difficulty with the older bcm47xx chips or when no CFE
         is currently active/operational you may want to try both the
         /noreset and /nobreak command line options together.Some bcm47xx
         chips *may* always require both these options to function properly.
      4) When using this utility, usually it is best to type the command line
         out, then plug in the router, and then hit <ENTER> quickly to avoid
         the CPUs watchdog interfering with the EJTAG operations.
      5) /bypass - enables Unlock bypass command for some AMD/Spansion type
         flashes, it also disables polling
      6) When enable 64K tiny CFE option, two option combins can be uesed.
         one, CFE or KERNEL choice and add /tinycfe option.
         another, use TFE and TERNEL to replace CFE and KERNEL ons.
***************************************************************************
* Flashing the KERNEL or WHOLEFLASH will take a very long time using JTAG *
* via this utility.You are better off flashing the CFE & NVRAM files    *
* & then using the normal TFTP method to flash the KERNEL via ethernet.   *
***************************************************************************


[ 本帖最后由 hugebird 于 2008-2-12 13:16 编辑 ]

victor2002 发表于 2010-10-8 21:47:49

回复 985# wshaofan


    终于知道我的JLINK为啥不能用了,原来是我升到了最新4.20版FW的缘故,降回到4.08版就可以了。

hugebird 发表于 2009-9-18 22:00:25

307# hugebird


这两天调试代码,RG100AA遇到JTAG挂住的问题,虽然尝试修改软件,但收效甚微。
不过还是想办法解决了。另外这个帖子里面遇到同样的问题,有兴趣的可以参考一下
https://www.chinadsl.net/viewthread.php?tid=30557

现象是这样,brjtag提示无法进入Debug模式,1.6r -1.7t所有版本都会挂在这里,不能继续,
Halting Processor ... <Processor did NOT enter Debug Mode!> ... Done

挂住的原因是:处理器由于flash 启动扇区的混乱代码造成进入非正常状态,无法响应jtag调试中断,所以调试指令无法被响应执行。

解决方法: 在打开modem电源之前,将flash的输出使能OE#引脚接地,再打开电源,
释放OE的短接线,最后执行Brjtag代码。

hugebird 发表于 2008-7-13 13:15:19

附件里的这个版本加入了 Spansion S29GL128N 16MB flash的支持,没有设备测试不知道ID检查是否正确,S29GLxxxN系列的flash采用的是统一扇区架构,S29GL128有128个扇区,每扇区128KB。

如果不能正确检测ID号,可以强制使用/fc:78定制使用新加入的16MB芯片参数。

因为这个新的16MB flash是128KB扇区,而NVRAM只有64KB,所以删除或者写操作NVRAM可能会出现问题,原ejtag代码没有考虑这一点,我一直想改这部分代码,因为没有时间,所以到现在也没去修改。如果有人要清NVRAM,还是用TTL在CFE系统里去擦除吧。

顺便说一下,-probeonly 现在可以显示未知flash芯片的ID号,便于增加新的芯片参数。

[ 本帖最后由 hugebird 于 2008-7-13 05:20 编辑 ]

liuyuexing 发表于 2008-3-19 03:37:19

anqingling 发表于 2008-3-23 19:30:35

MINE 发表于 2008-3-23 19:37:54

不错的软件,刚好支持我的BCM6358,可惜我没JTAG线。

MINE 发表于 2008-3-23 19:50:26

不知道我的S29GL128N10TF101要用哪个fc参数。

z2315 发表于 2008-3-28 08:53:20

顶,修复的好工具:victory:

mzdeng 发表于 2008-3-28 20:22:08

:( 不会用。。有教程吗

lengwail 发表于 2008-6-30 22:23:34

hotqj 发表于 2008-7-7 13:21:27

楼主能帮下我吗?我的Flash是S29GL128N10TFI01,,,是个16M的Flash,下边有这个Flash的PDF文件,能不能帮下编译个可以支持这个Flash的版本发给我啊。先谢谢啦。

下图为我的猫的接口,看样子应该是JTAG接口,不过不知道针脚定义和JTAG的线如何做法。帮下啦。
现已经知道,2.4.6.8.10.12为GND其它的就不知道了。

[ 本帖最后由 hotqj 于 2008-7-7 06:08 编辑 ]

7ac012674 发表于 2008-7-7 14:46:26

不会用。。有教程吗
页: [1] 2 3 4 5 6 7 8 9 10
查看完整版本: Broadcom路由DSL猫用的JTAG工具最新版