NOR Flash 编程1//**************************************************************************************************
//*** norflash操作原理:假设现在讨论的norflash连接在cpu的地址空间的0x0C000000位置的intel L18F256 32MB norflash(块大小为128KB)
/*
intel E28F128J3A150 16MB 16bit norflash 和bf561相连的接法为 :
bf561 <=> E28F128J3A150
A[23:1] => A[23:1] //bf561给norflash的地址信号
D[15:0] => D[15:0] //bf561给norflash的数据信号
/AMS0 => /CE //bf561给norflash的片选信号
/AOE => /OE //bf561给norflash的读信号
/AWE => /WE //bf561给norflash的写信号
/BYTE //上拉为高
VPEN //上拉为高
/RP //上拉为高
*/
1.norflash读取生产ID和设备ID的步骤:
1)执行相应的命令序列:=>向norflash的基地址发送命
*(0x0C000000 + 0x5555) = 0x00AA;
*(0x0C000000 + 0x2AAA) = 0x0055;
*(0x0C000000 + 0x5555) = 0x0090;
2)开始读取生产ID:
(u16)mnfID=*(0x0C000000+0x0);
3)开始读取设备ID:
(u16)devID=*(0x0C000000+0x2);
2.以块为单位擦除norflash的步骤:(假设擦除uboot所在分区:0x0C100000)
1)禁止flash的写保护: //设置EMIFS_CONFIG寄存器的最低位为1(即让wp引脚输出为高)
2)Block unlock
*((short*)0x0C100000) = 0x0060; //块对齐地址
*((short*)0x0C100000) = 0x00D0; //块对齐地址
while(!(*((s