当前位置:   article > 正文

u-boot-2012.04.01移植(七)提供nor flash支持_please reset the board

please reset the board

无论系统从NOR启动还是从NAND启动,都会打印相同的错误信息

Flash:*** failed ***

### ERROR ### Please RESET the board

 

正常的打印信息应该是

Flash: 2M

2M表示Flash大小

显然这里Flash识别出错

 

通过下面命令定位错误在arch/arm/lib/board.c:506:

grep "Flash: " * -nR

分析arch/arm/lib/board.c:506行后的代码可以知道,打印错误信息的原因可能是nor flash初始化不成功

flash_size = flash_init();

分析flash_init,这个函数会调用子函数检测nor flash信息

  1. if (!flash_detect_legacy(cfi_flash_bank_addr(i), i))
  2. flash_get_size(cfi_flash_bank_addr(i), i);

在检测函数中有debug信息,在drivers/mtd/cfi_flash.c中定义宏DEBUG为1,开启调试信息

重新编译烧写u-boot,从nor flash启动后可以看到调试信息

JEDEC PROBE: ID c2 2249 0

对比nor flash芯片手册,打印的id正确

搜索JEDEC PROBE,定位到drivers/mtd/cfi_flash.c:1697

grep “JEDEC PROBE” * -nR

定位位置其后的代码会去jedec_table数组中寻找匹配的nor flash

  1. if (jedec_flash_match(info, info->start[0]))
  2. break;

检查jedec_table数组,没有一项描述我们所使用的nor flash,故自行添加一项

  1. {
  2. .mfr_id = (u16)MX_MANUFACT,
  3. .dev_id = 0x2249,
  4. .name = "MXIC MT29LV160DB",
  5. .uaddr = {
  6. [1] = MTD_UADDR_0x0555_0x02AA /* x16 */
  7. },
  8. .DevSize = SIZE_2MiB,
  9. .CmdSet = P_ID_AMD_STD,
  10. .NumEraseRegions= 4,
  11. .regions = {
  12. ERASEINFO(16*1024, 1),
  13. ERASEINFO(8*1024, 2),
  14. ERASEINFO(32*1024, 1),
  15. ERASEINFO(64*1024, 31),
  16. }
  17. },

mfr_id和dev_id是厂家id等信息

uaddr:[1]表示16位位宽,其值表示解锁方法

DevSize:nor flash大小

CmdSet:命令标准

NumEraseRegions:擦除分区数

regions:分区结构

重新编译烧写试验发现,打印错误

ERROR: too many flash sectors

搜索定位到drivers/mtd/cfi_flash.c:2018

grep “ERROR: too many flash sectors” * -nR

修改include/configs/smdk2440.h

  1. //#define CONFIG_SYS_MAX_FLASH_SECT 19
  2. #define CONFIG_SYS_MAX_FLASH_SECT (1+2+1+31)

 

重新编译烧写,至此uboot已经可以支持nor flash,把前面定义的宏DEBUG删除,重新编译

 

 

 

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/代码探险家/article/detail/899268
推荐阅读
相关标签
  

闽ICP备14008679号