精选flash的不同之处在于Nor.docx
- 文档编号:28701343
- 上传时间:2023-07-19
- 格式:DOCX
- 页数:11
- 大小:230.48KB
精选flash的不同之处在于Nor.docx
《精选flash的不同之处在于Nor.docx》由会员分享,可在线阅读,更多相关《精选flash的不同之处在于Nor.docx(11页珍藏版)》请在冰豆网上搜索。
精选flash的不同之处在于Nor
Author-------Dansen-----xzd2734@
NorFlash与Nandflash的不同之处在于NorFlash的地址和数据线是不共用的,所以NorFlash比较象ROM,是可以按地址自由读的,这样就非常适合存储代码,在开机时从NorFlash中取代码来执行。
在我的板子上有16M的Intel的NorFlashE28F128J3A150,以此为例来研究一下NorFlash的一些常用操作。
E28F128J3A150每个sector是128k,擦除是按扇区操作了。
首先来看下E28F128J3A150与s3c2410的接口吧。
一般情况下ROM与s3c2410的接口我们可以在s3c2410的手册上看到,如下图所示
仔细看下16位和8位数据接口在地址线连接上的区别吧,16位的地址线是要移位的,A1接到A0上,这当然是比较容易理解的,位宽大了一倍,地址就少了一条。
对于E28F128J3A150其实也是这样,不过又有点不一样,仔细看看E28F128J3A150的手册吧。
下面给出接线图。
不同之处E28F128J3A150貌似并没有移位,其实只是因为E28F128J3A150的A1就相对于别的16位ROM的A0,其A0就相当于他们的A(-1)是用来指示8位地址的,所以还是一样的。
来看看Flash操作的命令集吧
以几个比较重要的操作来说明比较容易懂
首先就是ReadIdentifierCodes
先给定我们的flash开始的地址吧,flash_addr=ioremap(0x0,0x1000000);
物理地址从0x0开始的0x1000000(16M)地址空间,这样得到了可访问的虚拟地址flash_addr
很简单,看命令表,先写一个命令writew(0x90,flash_addr);
然后把ManufactureCode读回来readw(flash_addr);
接着再读DeviceCodereadw(flash_addr+2);
细节部分还是参考手册吧
其实内核已经MTD驱动完全支持NorFlash的操作,所以不必要自己再写了。
不过在JTAG烧写flash的程序中可以加入对我们自己的flash的支持。
来看看其中对E28F128J3A150的烧写代码,分析一下。
intStrata_CheckID(inttargetAddr)//返回ManufactureCode
{
_WR(targetAddr,0x0090);
return_RD(targetAddr);//_WR和_RD都是半字操作
}
intStrata_CheckDevice(inttargetAddr)//返回DeviceCode
{
_WR(targetAddr,0x0090);
return_RD(targetAddr+0x2);
}
看着BlockEraseFlowchart再对照着BlockErase的函数看就比较能完全看懂了
voidStrata_EraseSector(inttargetAddress)
{
unsignedlongReadStatus;
unsignedlongbSR5;
unsignedlongbSR7;
_WR(targetAddress,0x0020);//擦除命令firstcycle
_WR(targetAddress,0x00d0);//擦除命令secondcycle
_WR(targetAddress,0x0070);//读状态寄存器命令
ReadStatus=_RD(targetAddress);//读状态寄存器
bSR7=ReadStatus&(1<<7);
while(!
bSR7)//需要判断状态寄存器的第7位
{
_WR(targetAddress,0x0070);
ReadStatus=_RD(targetAddress);
bSR7=ReadStatus&(1<<7);
}
_WR(targetAddress,0x0070);
ReadStatus=_RD(targetAddress);
bSR5=ReadStatus&(1<<5);
if(bSR5==0)
{
printf("Block@%xhEraseO.K.\n",targetAddress);
}
else
{
_WR(targetAddress,0x0050);////ClearStatusRegister
error_erase=1;
}
_RESET();//就相当于_WR(targetAddress,0x00ff),回到ReadArray的状态。
}
很清晰的流程吧。
Byte/WordProgramFlowchart
共两种Program方式可以把数据写到Flash中,一般也只用到这种就可以了
intStrata_ProgFlash(U32realAddr,U16data)
{
unsignedlongReadStatus;
unsignedlongbSR4;
unsignedlongbSR7;
_WR(realAddr,0x0040);
_WR(realAddr,data);
_WR(realAddr,0x0070);
ReadStatus=_RD(realAddr);
bSR7=ReadStatus&(1<<7);
while(!
bSR7)
{
_WR(realAddr,0x0070);
ReadStatus=_RD(realAddr);
bSR7=ReadStatus&(1<<7);
}
_WR(realAddr,0x0070);
ReadStatus=_RD(realAddr);
bSR4=ReadStatus&(1<<4);
if(bSR4==0)
{
//printf("SuccessfulProgram!
!
\n");
}
else
{
_WR(realAddr,0x0050);//ClearStatusRegister
error_program=1;
}
_RESET();
return0;
}
以上这种写会很慢,以致于JTAG烧写相当得慢。
intStrata_unprotect_sector(inttargetAddr)//去除sector的写保护
{
intSR7,SR3,SR4,SR5,ReadStatus;
intres=0;
_WR(targetAddr,0x0050);//ClearStatusRegister
_WR(targetAddr,0x0060);//Firstbuscycle
_WR(targetAddr,0x00D0);//Secondbuscycle
_WR(targetAddr,0x0070);
ReadStatus=_RD(targetAddr);
SR7=ReadStatus&(1<<7);
while(!
SR7)
{
_WR(targetAddr,0x0070);
ReadStatus=_RD(targetAddr);
SR7=ReadStatus&(1<<7);
}
_WR(targetAddr,0x0070);
ReadStatus=_RD(targetAddr);
SR3=ReadStatus&(1<<3);
SR4=ReadStatus&(1<<4);
SR5=ReadStatus&(1<<5);
if(SR3){printf("VoltageRangeError");res=-1;}
if(SR4&&SR5){printf("CommandSequenceError");res=-2;}
if(SR5){printf("ClearBlockLock-BitsError");res=-3;}
_RESET();
returnres;
}
另外按照writetobuffer的流程自己写了一个函数,没有test,不想再去烧写了,太烦了,就这样好了。
voidStrata_buffer_program(intblockAddress,inttagetAddress,U16*buf)
{
unsignedlongReadStatus;
unsignedlongbSR4;
unsignedlongbSR7;
inti;
do{
_WR(blockAddress,0x00E8);
_WR(blockAddress,0x0070);
ReadStatus=_RD(blockAddress);
bSR7=ReadStatus&(1<<7);
}while(!
bSR7);
_WR(blockAddress,0x001F);
for(i=0;i<=0x1F;i++)
_WR(targetAddress+2*i,*(buf+i));
_WR(blockAddress,0x00D0);
do{
_WR(blockAddress,0x0070);
ReadStatus=_RD(blockAddress);
bSR7=ReadStatus&(1<<7);
}while(!
bSR7);
_WR(blockAddress,0x0070);
ReadStatus=_RD(blockAddress);
bSR4=ReadStatus&(1<<4);
if(bSR4==0)
{
//printf("SuccessfulProgram!
!
\n");
}
else
{
_WR(blockAddress,0x0050);
error_program=1;
}
_RESET();
}
以几个比较重要的操作来说明比较容易懂
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 精选 flash 不同之处 在于 Nor