串口打印出信息后,发现打印出Flash: 0 Bytes,很明显没有识别出norflash,因此在代码中搜索“Flash: ”,定位到initr_flash(),一路跟踪下去,flash_init(),
flash_detect_legacy()中有以下一段代码:
flash_read_jedec_ids(info); debug("JEDEC PROBE: ID %x %x %x\n", info->manufacturer_id, info->device_id, info->device_id2); if (jedec_flash_match(info, info->start[0])) break;
flash_read_jedec_ids函数读出厂商ID,设备ID等,debug能打印出来,因此我们要想看看ID读得对不对,就在smdk2410.h中定义DEBUG宏,让它打印出来。
改完编译烧写,发现读出的厂商ID和设备ID是正确的。因此,再看 jedec_flash_match函数,它将读出的ID和jedec_table对比,看是否存在这一项,表格里面并没有我们的norflash类型,于是我们仿照其他项自己添加上去,如下所示:
{ .mfr_id = (u16)MX_MANUFACT, .dev_id = 0x2249, .name = "MX29LV160D", .uaddr = { [1] = MTD_UADDR_0x0555_0x02AA /* x16 */ }, .DevSize = SIZE_2MiB, .CmdSet = CFI_CMDSET_AMD_LEGACY, .NumEraseRegions= 4, .regions = { ERASEINFO(0x10000, 31), ERASEINFO(0x08000, 1), ERASEINFO(0x02000, 2), ERASEINFO(0x04000, 1), } },
编译烧写,提示错误too many flash sectors,在代码中搜索,发现CONFIG_SYS_MAX_FLASH_SECT这个宏定义为19,而我们的norflash扇区数为35,大于19,于是把这个宏改为64,重新编译烧写,正确识别出了norflash为2M。我们来测试下norflash能否正确读写,cp.b 0 30000000 80;cmp.b 0 30000000 80 ,用上面两条命令发现读norflash没有问题。再用以下几条命令测试写norflash:mw.b 30000000 12 3; protect off all; erase 0 ffff; cp.b 30000000 0 3; md.b 0 3;发现也是121212;因此写norflash成功,u-boot已经支持norflash。
时间: 2024-10-12 14:52:58