4026|7

85

帖子

0

TA的资源

一粒金砂(初级)

楼主
 

wince eboot之flash管理问题 [复制链接]

我使用S3C2410芯片和K9F1208的FLASH。现在我的EBOOT可以实现直接下载NK.BIN并在RAM中启动,但是无法在FLASH中启动。
超级终端显示如下:
TFTP: Desktop losing ACK, block number = 18570, Ack again
TFTP: Desktop losing ACK, block number = 32099, Ack again
rom_offset=0x0.
ROMHDR at Address 8C300044h
::OEMLaunch, ImageStart:0x8C300000, ImageLength:0x1189134, LaunchAddr:0x8C301000

EbootWaitForHostConenct
Got EDBG_CMD_JUMPIMG
Got EDBG_CMD_CONFIG, flags:0x00000000
KitlTransport: 0x1
OEMLaunch: (IMAGE_TYPE_RAMIMAGE|IMAGE_TYPE_BINFS)
+WriteRegionsToBootMedia: ImageStart: 0x8C300000, ImageLength: 0x1189134, Launch
Addr:0x8C301000
INFO: OEMLaunch: Found chain extenstion: '' @ 0x8C300000
Writing single region/multi-region update, dwBINFSPartLength: 18387252
IsValidMBR: MBR sector = 0xFFFFFFFF
OpenPartition: Invalid MBR.  Formatting flash.
Enter LowLevelFormat [0x0, 0x7F].
Erasing flash block(s) [0x0, 0x7F] (please wait): EraseBlocks: found a bad block
(0x0) - skipping...
EraseBlocks: found a bad block (0x1) - skipping...
EraseBlocks: found a bad block (0x2) - skipping...
...
EraseBlocks: found a bad block (0x7F) - skipping...
Done.
BP_LowLevelFormat: no good blocks
OpenPartition: Partition Exists=0x0 for part 0x21.
CreatePartition: Enter CreatePartition for 0x21.
LastLogSector: Last log sector is: 0x101F.
CreatePartition: sectors [0x1F020, 0x8C60] requested are out of range or taken b
y another partition
ERROR: WriteRegionsToBootMedia: Failed to open/create BINFS partition.
WARNING: OEMLaunch: Failed to store BinFS regions to boot media.
另外eboot格式化FLASH功能也不好使
大家帮帮忙,看看该如何解决

最新回复

我解决了,谢谢大家是 loader.h里面有个参数错了   详情 回复 发表于 2009-5-30 12:14
点赞 关注

回复
举报

65

帖子

0

TA的资源

一粒金砂(初级)

沙发
 
up
 
 

回复

69

帖子

0

TA的资源

一粒金砂(初级)

板凳
 
EraseBlocks: found a bad block (0x1) - skipping...
EraseBlocks: found a bad block (0x2) - skipping...

看样子,所有的Block都会被提示bad了。
先检查你的eboot里的flash部分的程序。重点是EraseBlock的,如果找不到问题就贴代码。
 
 
 

回复

75

帖子

0

TA的资源

一粒金砂(初级)

4
 
BP_LowLevelFormat: no good blocks

全部都被标记为了坏块。。。还怎么下载呢
 
 
 

回复

87

帖子

0

TA的资源

一粒金砂(初级)

5
 
全部被标记为坏块,估计驱动有问题
 
 
 

回复

71

帖子

0

TA的资源

一粒金砂(初级)

6
 
OpenPartition: Invalid MBR.  Formatting flash.
主引导程序MBR(Master Boot Record)错误。
检测MBR的有效性。通过函数IsValidMBR()实现。

检测MBR的有效性,首先要知道MBR保存在哪里,前面说过NANDFLASH的第0 BLOCK,第1 Sector为主引导扇区,也就是MBR,但是NAND如果被当作启动芯片,○地址一般被BOOTLOADER代码占据,MBR只有放在后面的BLOCK中。所以我把第0 个BLOCK放NBOOT,第1个BLOCK放TOC,第2个BLOCK放EBOOT,第3个BLOCK保留,第4个BLOCK就放MBR。


  1. static BOOL IsValidMBR()

  2. {

  3.     // Check to see if the MBR is valid

  4.     // MBR block is always located at logical sector 0

  5.     g_dwMBRSectorNum = GetMBRSectorNum();        



  6.     RETAILMSG (1, (TEXT("IsValidMBR: MBR sector = 0x%x\r\n"), g_dwMBRSectorNum));

  7.    

  8.     if ((g_dwMBRSectorNum == INVALID_ADDR) || !FMD_ReadSector (g_dwMBRSectorNum, g_pbMBRSector, NULL, 1)) {

  9.        RETAILMSG (1, (TEXT("IsValidMBR-----return FALSE-------------------\r\n")));

  10.         return FALSE;  

  11.     }   

  12.     return ((g_pbMBRSector[0] == 0xE9) &&

  13.          (g_pbMBRSector[1] == 0xfd) &&

  14.          (g_pbMBRSector[2] == 0xff) &&

  15.          (g_pbMBRSector[SECTOR_SIZE_FS-2] == 0x55) &&

  16.          (g_pbMBRSector[SECTOR_SIZE_FS-1] == 0xAA));

  17. }
复制代码


 
 
 

回复

80

帖子

0

TA的资源

一粒金砂(初级)

7
 
引用 2 楼 shuiyan 的回复:
EraseBlocks: found a bad block (0x1) - skipping...
EraseBlocks: found a bad block (0x2) - skipping...

看样子,所有的Block都会被提示bad了。
先检查你的eboot里的flash部分的程序。重点是EraseBlock的,如果找不到问题就贴代码。

很同意这种观点,肯定是你的flash 驱动有问题。
 
 
 

回复

69

帖子

0

TA的资源

一粒金砂(初级)

8
 
我解决了,谢谢大家是
loader.h里面有个参数错了
 
 
 

回复
您需要登录后才可以回帖 登录 | 注册

随便看看
查找数据手册?

EEWorld Datasheet 技术支持

相关文章 更多>>
关闭
站长推荐上一条 1/7 下一条

 
EEWorld订阅号

 
EEWorld服务号

 
汽车开发圈

About Us 关于我们 客户服务 联系方式 器件索引 网站地图 最新更新 手机版

站点相关: 国产芯 安防电子 汽车电子 手机便携 工业控制 家用电子 医疗电子 测试测量 网络通信 物联网

北京市海淀区中关村大街18号B座15层1530室 电话:(010)82350740 邮编:100190

电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2025 EEWORLD.com.cn, Inc. All rights reserved
快速回复 返回顶部 返回列表