找回密码
 注册

QQ登录

只需一步,快速开始

楼主: hugebird

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

    [复制链接]
发表于 2008-12-7 00:37:42 | 显示全部楼层
二位,请早点休息。我会一直测试我能想到的办法,无论结果是顺利搞定,还是有什么问题再发贴出来。
 楼主| 发表于 2008-12-7 01:19:03 | 显示全部楼层
我测试了一下,用Dlink 2740B ,2.73

1.准备TFE.bin和/128K 重组的固件
brfwmod -decomp -i EU_DSL-2740B_2.73b246CFE.bin
2. 改所有展开文件的名字,并备份一个CFE.bin
copy cfe.bin tfe.bin
3.ultraedit编辑tag.bin ,0x8a处改成ASC “1”
4,完成重组
brfwmod -comp /m:2 /128K -o new273.bin
5. 拷贝brjtag.exe到重组固件的存放目录
=======================================================
1.开电,brjtag -erase:wholeflash /unppb, 完成后关电
2. 开电, brjtag -flash:tfe  烧入刚才得到的TFE.BIN
3. 关电,上TTL线, 启动超级终端,电脑网线连在猫上,开电
4. 超级终端按空格进CFE> ,执行"e a" "y" 清楚整个flash
5. "e a" 完成后设备重启,终端上及时按空格进CFE>
6, IE访问CFE下载界面 htt://192.168.1.1
7, 下载new273.bin, 观察终端把固件烧在be020000
8. 在下载完成之后设备备重启,终端上及时按空格进CFE>
9. IE访问CFE下载界面 htt://192.168.1.1
10, 再次下载new273.bin, 观察终端把固件烧在be800000
11. 在下载完成之后设备备重启,恢复成功


终端的完整log

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?注册

×
发表于 2008-12-7 13:05:41 | 显示全部楼层
刚才打了一大半的消息,没有输入完,没有发出消息,有个朋友来了,离开了40分钟这样,结果消息发送失败.

谢谢你写的恢复步骤,我现在正在用最慢的办法做一次测试(直接写入WHOLEFLASH).估计要到下午4:00可以完成.
发表于 2008-12-7 13:09:22 | 显示全部楼层
昨夜,我试过2.73 ,3.04,2.61,RG100A-AA的固件,全部都是用128K处理过了的.除2.61可以启动并引导外,其余的,都是在CFE启动后,初始化FLASH分区分配的时候死在那里了.

不过,我试刷第一分固件的时候是用0的标志,来不及用1的标志试(没有机会,因为0的标志都没有启动).我贴个图出来.

等到4点钟后,再按你92楼所讲的再做一遍.看看结果如何...这个就是前些天,我全部用128K 及 0 或1 重新打包的固件.
下面是昨夜一直在试刷的LOG记录文件.RG100A-AA CFE 到初始化分区的时候就停下,还没有能看得到提示按键终止.

[ 本帖最后由 天涯 于 2008-12-7 05:21 编辑 ]

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?注册

×
发表于 2008-12-7 13:44:11 | 显示全部楼层
C:\rg100av12\261>brfwmod -comp -o 2.61-cfe-128k-1.bin /M:2 /128K

===============================================================
Broadcom Chip ADSL FW Image De/Compress Utility v1.5-hugebird
===============================================================

Warning!...Source TAG Checksum not match, but build continue...
============decoding Tag information===================
    Tag Ver signature   = '6'
    SIG1(comany info)   = 'Broadcom Corporatio'
    SIG2(FW version)    = '3.10.02.EU'
    chip ID             = '6358'
    board ID            = '96358GW'
    FW endianess        = Big Endian
=======================================================

->Start packing a new image
  ->CFE will load at    0xBFC00000, length 0x0000FDBC Bytes.
  ->get CFE NVRAM Board_ID:     96358GW
  ->get CFE NVRAM MacAddress:   007404E4908F
  ->build CFE NVRAM block. Done!
  ->use cfe length 64956 to cal RootFS loading addr
  ->RootFS will load at 0xBFC20100, length 0x00322000 Bytes.
  ->Kernel will load at 0xBFF42100, length 0x0007E24C Bytes.
  ->get RootFS+Kernel checksum. CRC32 = 0x4A603558
  ->get image checksum.         CRC32 = 0x1570834E
  ->get tag checksum.           CRC32 = 0xF516B180
  ->write Tag to new image...
  ->write buffer to new image...
->Done


*** REQUESTED OPERATION IS COMPLETE, Bye! ***

刚才改为1后,出现一个警告提示,之前我做别的版本都没有发现这个提示, 为何故呢?

要如何修正这个TAG的CRC32校验值? 谢谢
 楼主| 发表于 2008-12-7 13:57:42 | 显示全部楼层
TAG修改一个数自然CRC32会有问题。每次重组,TAG的CRC都要重新计算,这个不用担心。


CFE里面试试用web界面刷fw,别用终端的f命令

[ 本帖最后由 hugebird 于 2008-12-7 06:00 编辑 ]
发表于 2008-12-7 14:06:57 | 显示全部楼层
对的,昨晚一直都是用F命令加载的,我运行了那个3cdaemon 这个东东,这个使用上很方便,就用习惯了.等下午我用WEB页面加载,完全按照你写的步骤再来一次.看看能否顺利...

祝我好运 :)
发表于 2008-12-7 15:26:59 | 显示全部楼层
我用BRJTAG 写入整个FLASH备份,在写到 26%的时候,再也写不下去了。
  1. D:\brjtag15>wflash

  2. D:\brjtag15>brjtag -flash:WHOLEFLASH /dma /fc:79

  3. ==============================================
  4. Broadcom EJTAG Debrick Utility v1.5-hugebird
  5. ==============================================

  6. Probing bus ... Done

  7. Instruction Length set to 5

  8. CPU running under BIG endian

  9. CPU Chip ID: 00000110001101011000000101111111 (0635817F)
  10. *** Found a Broadcom BCM6358 Rev 1 CPU chip ***

  11.     - EJTAG IMPCODE ....... : 00000000100000011000100100000100 (00818904)
  12.     - EJTAG Version ....... : 1 or 2.0
  13.     - EJTAG DMA Support ... : Yes
  14.     - EJTAG Implementation flags: R4k MIPS16 MIPS32
  15.     *** DMA Mode Forced On ***

  16. Issuing Processor / Peripheral Reset ... Done
  17. Enabling Memory Writes ... Done
  18. Halting Processor ... <Processor Entered Debug Mode!> ... Done
  19. Clearing Watchdog ... Done
  20. Initialize EBI ... Skipped

  21. Manual Flash Selection ... Match Flash Chip (VenID:DevID = 017e : 2101)
  22. *** Manually Selected a Spansion S29GL128N/P Uni  (16MB) Flash Chip ***

  23.     - Flash Chip Window Start .... : 1f000000
  24.     - Flash Chip Window Length ... : 01000000
  25.     - Selected Area Start ........ : 1f000000
  26.     - Selected Area Length ....... : 01000000


  27. *** You Selected to Flash the WHOLEFLASH.BIN ***

  28. =========================
  29. Flashing Routine Started
  30. =========================
  31. Total Blocks to Erase: 128

  32. Erasing block: 1 (addr = 1f000000)...Done
  33. Erasing block: 2 (addr = 1f020000)...Done
  34. Erasing block: 3 (addr = 1f040000)...Done
  35. Erasing block: 4 (addr = 1f060000)...Done
  36. Erasing block: 5 (addr = 1f080000)...Done
  37. Erasing block: 6 (addr = 1f0a0000)...Done
  38. Erasing block: 7 (addr = 1f0c0000)...Done
  39. Erasing block: 8 (addr = 1f0e0000)...Done
  40. Erasing block: 9 (addr = 1f100000)...Done
  41. Erasing block: 10 (addr = 1f120000)...Done
  42. Erasing block: 11 (addr = 1f140000)...Done
  43. Erasing block: 12 (addr = 1f160000)...Done
  44. Erasing block: 13 (addr = 1f180000)...Done
  45. Erasing block: 14 (addr = 1f1a0000)...Done
  46. Erasing block: 15 (addr = 1f1c0000)...Done
  47. Erasing block: 16 (addr = 1f1e0000)...Done
  48. Erasing block: 17 (addr = 1f200000)...Done
  49. Erasing block: 18 (addr = 1f220000)...Done
  50. Erasing block: 19 (addr = 1f240000)...Done
  51. Erasing block: 20 (addr = 1f260000)...Done
  52. Erasing block: 21 (addr = 1f280000)...Done
  53. Erasing block: 22 (addr = 1f2a0000)...Done
  54. Erasing block: 23 (addr = 1f2c0000)...Done
  55. Erasing block: 24 (addr = 1f2e0000)...Done
  56. Erasing block: 25 (addr = 1f300000)...Done
  57. Erasing block: 26 (addr = 1f320000)...Done
  58. Erasing block: 27 (addr = 1f340000)...Done
  59. Erasing block: 28 (addr = 1f360000)...Done
  60. Erasing block: 29 (addr = 1f380000)...Done
  61. Erasing block: 30 (addr = 1f3a0000)...Done
  62. Erasing block: 31 (addr = 1f3c0000)...Done
  63. Erasing block: 32 (addr = 1f3e0000)...Done
  64. Erasing block: 33 (addr = 1f400000)...Done
  65. Erasing block: 34 (addr = 1f420000)...Done
  66. Erasing block: 35 (addr = 1f440000)...Done
  67. Erasing block: 36 (addr = 1f460000)...Done
  68. Erasing block: 37 (addr = 1f480000)...Done
  69. Erasing block: 38 (addr = 1f4a0000)...Done
  70. Erasing block: 39 (addr = 1f4c0000)...Done
  71. Erasing block: 40 (addr = 1f4e0000)...Done
  72. Erasing block: 41 (addr = 1f500000)...Done
  73. Erasing block: 42 (addr = 1f520000)...Done
  74. Erasing block: 43 (addr = 1f540000)...Done
  75. Erasing block: 44 (addr = 1f560000)...Done
  76. Erasing block: 45 (addr = 1f580000)...Done
  77. Erasing block: 46 (addr = 1f5a0000)...Done
  78. Erasing block: 47 (addr = 1f5c0000)...Done
  79. Erasing block: 48 (addr = 1f5e0000)...Done
  80. Erasing block: 49 (addr = 1f600000)...Done
  81. Erasing block: 50 (addr = 1f620000)...Done
  82. Erasing block: 51 (addr = 1f640000)...Done
  83. Erasing block: 52 (addr = 1f660000)...Done
  84. Erasing block: 53 (addr = 1f680000)...Done
  85. Erasing block: 54 (addr = 1f6a0000)...Done
  86. Erasing block: 55 (addr = 1f6c0000)...Done
  87. Erasing block: 56 (addr = 1f6e0000)...Done
  88. Erasing block: 57 (addr = 1f700000)...Done
  89. Erasing block: 58 (addr = 1f720000)...Done
  90. Erasing block: 59 (addr = 1f740000)...Done
  91. Erasing block: 60 (addr = 1f760000)...Done
  92. Erasing block: 61 (addr = 1f780000)...Done
  93. Erasing block: 62 (addr = 1f7a0000)...Done
  94. Erasing block: 63 (addr = 1f7c0000)...Done
  95. Erasing block: 64 (addr = 1f7e0000)...Done
  96. Erasing block: 65 (addr = 1f800000)...Done
  97. Erasing block: 66 (addr = 1f820000)...Done
  98. Erasing block: 67 (addr = 1f840000)...Done
  99. Erasing block: 68 (addr = 1f860000)...Done
  100. Erasing block: 69 (addr = 1f880000)...Done
  101. Erasing block: 70 (addr = 1f8a0000)...Done
  102. Erasing block: 71 (addr = 1f8c0000)...Done
  103. Erasing block: 72 (addr = 1f8e0000)...Done
  104. Erasing block: 73 (addr = 1f900000)...Done
  105. Erasing block: 74 (addr = 1f920000)...Done
  106. Erasing block: 75 (addr = 1f940000)...Done
  107. Erasing block: 76 (addr = 1f960000)...Done
  108. Erasing block: 77 (addr = 1f980000)...Done
  109. Erasing block: 78 (addr = 1f9a0000)...Done
  110. Erasing block: 79 (addr = 1f9c0000)...Done
  111. Erasing block: 80 (addr = 1f9e0000)...Done
  112. Erasing block: 81 (addr = 1fa00000)...Done
  113. Erasing block: 82 (addr = 1fa20000)...Done
  114. Erasing block: 83 (addr = 1fa40000)...Done
  115. Erasing block: 84 (addr = 1fa60000)...Done
  116. Erasing block: 85 (addr = 1fa80000)...Done
  117. Erasing block: 86 (addr = 1faa0000)...Done
  118. Erasing block: 87 (addr = 1fac0000)...Done
  119. Erasing block: 88 (addr = 1fae0000)...Done
  120. Erasing block: 89 (addr = 1fb00000)...Done
  121. Erasing block: 90 (addr = 1fb20000)...Done
  122. Erasing block: 91 (addr = 1fb40000)...Done
  123. Erasing block: 92 (addr = 1fb60000)...Done
  124. Erasing block: 93 (addr = 1fb80000)...Done
  125. Erasing block: 94 (addr = 1fba0000)...Done
  126. Erasing block: 95 (addr = 1fbc0000)...Done
  127. Erasing block: 96 (addr = 1fbe0000)...Done
  128. Erasing block: 97 (addr = 1fc00000)...Done
  129. Erasing block: 98 (addr = 1fc20000)...Done
  130. Erasing block: 99 (addr = 1fc40000)...Done
  131. Erasing block: 100 (addr = 1fc60000)...Done
  132. Erasing block: 101 (addr = 1fc80000)...Done
  133. Erasing block: 102 (addr = 1fca0000)...Done
  134. Erasing block: 103 (addr = 1fcc0000)...Done
  135. Erasing block: 104 (addr = 1fce0000)...Done
  136. Erasing block: 105 (addr = 1fd00000)...Done
  137. Erasing block: 106 (addr = 1fd20000)...Done
  138. Erasing block: 107 (addr = 1fd40000)...Done
  139. Erasing block: 108 (addr = 1fd60000)...Done
  140. Erasing block: 109 (addr = 1fd80000)...Done
  141. Erasing block: 110 (addr = 1fda0000)...Done
  142. Erasing block: 111 (addr = 1fdc0000)...Done
  143. Erasing block: 112 (addr = 1fde0000)...Done
  144. Erasing block: 113 (addr = 1fe00000)...Done
  145. Erasing block: 114 (addr = 1fe20000)...Done
  146. Erasing block: 115 (addr = 1fe40000)...Done
  147. Erasing block: 116 (addr = 1fe60000)...Done
  148. Erasing block: 117 (addr = 1fe80000)...Done
  149. Erasing block: 118 (addr = 1fea0000)...Done
  150. Erasing block: 119 (addr = 1fec0000)...Done
  151. Erasing block: 120 (addr = 1fee0000)...Done
  152. Erasing block: 121 (addr = 1ff00000)...Done
  153. Erasing block: 122 (addr = 1ff20000)...Done
  154. Erasing block: 123 (addr = 1ff40000)...Done
  155. Erasing block: 124 (addr = 1ff60000)...Done
  156. Erasing block: 125 (addr = 1ff80000)...Done
  157. Erasing block: 126 (addr = 1ffa0000)...Done
  158. Erasing block: 127 (addr = 1ffc0000)...Done
  159. Erasing block: 128 (addr = 1ffe0000)...Done

  160. Loading WHOLEFLASH.BIN to Flash Memory...
  161.   26%   bytes = 4468968
复制代码
发表于 2008-12-7 16:27:48 | 显示全部楼层

经过再次测试刷新,仍然是无法保存配置信息

Flash write error.  Verify failed
Error writing flash sector 127.Flash write error.  Verify failed
Error writing flash sector 127.Scratch pad is not initialized.
Scratch pad is not initialized.
No scratch pad found.  Initialize scratch pad...
Flash write error.  Verify failed

仍然是写 扇区 127 出错.

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?注册

×
发表于 2008-12-7 17:41:54 | 显示全部楼层
刚才把全部可以刷并可以启动的固件都试了一遍,RG100A,2.73,9113都试了,都无法保存配置。基本上都和这个类似的提示:Error writing flash sector 127.Flash write error.  Verify failed

我恨死这个127,固件也直是固执,那个地方写不进去,怎么就不知道哪能写得进去的地方写呢? :)

只有等HUGEBIRD大大来指点了。
*滑块验证:
您需要登录后才可以回帖 登录 | 注册

本版积分规则

QQ|Archiver|小黑屋|宽带技术网 |网站地图

粤公网安备 44152102000001号

GMT+8, 2024-4-30 09:09 , Processed in 0.026318 second(s), 4 queries , Redis On.

Powered by Discuz! X3.5 Licensed

Copyright © 2001-2020, Tencent Cloud.

快速回复 返回顶部 返回列表