转载:
nand启动与nor启动的区别主要分为以下几部分说明:
1、nand flash与nor flash的最主要区别
2、s3c2440的nand启动与nor启动原理
3、nand启动与nor启动的时候uboot做了什么
1、在JZ2440开发板上有两种Flash,分别为nand flash和nor flash。这两种flash的最主要的区别为:nor flash比较稳定,存在里面的数据不易丢失,但是容量小,nor flash在读的时候可以像内存一样操作;nand flash容量大,但是存在位反转,会导致数据丢失,读写需要通过一定的时序。所以一般nor flash里面存放的uboot代码,而nand flash里面存放的是占用容量比较大的linux内核和文件系统。在JZ2440上,nand flash的容量为256M,而nor flash只有2M。
2、s3c2440的nand启动与nor启动原理
a、如图所以当OM0引脚与OM1引脚分别为 01或10的时候,当芯片复位之后是从nor flash直接取指运行的。
b、OM0引脚与OM1为00的时候,当芯片复位之后是从nand flash的0地址处拷贝4K内容到芯片的内部ram运行的。
3、nand启动与nor启动的时候uboot做了什么
在
u-boot之ARM920T的start.S分析分析start.s的时候已经知道了uboot需要从flash中拷贝内容到ram上运行。
int CopyCode2Ram(unsigned long start_addr, unsigned char *buf, int size)
{
unsigned int *pdwDest;
unsigned int *pdwSrc;
int i;
if (bBootFrmNORFlash())//判断是从nand启动的还是从nor启动的,如果条件成立,表示是从nor启动的
{
pdwDest = (unsigned int *)buf;
pdwSrc = (unsigned int *)start_addr;
/* 从 NOR Flash启动 */
for (i = 0; i < size / 4; i++)//4字节的写入,所以需要size / 4 by andy
{
pdwDest[i] = pdwSrc[i];//norfalsh可以在配置完内存管理单元后,读数据可以像内存一样操作
}
return 0;
}
else
{
/* 初始化NAND Flash */
nand_init_ll();
/* 从 NAND Flash启动 */
nand_read_ll_lp(buf, start_addr, (size + NAND_BLOCK_MASK_LP)&~(NAND_BLOCK_MASK_LP));
return 0;
}
}
芯片根据向0地址写入一个数据,然后读出,如果没有改变的话就是NOR FLASH(因为NOR FLASH写入需要一定时序)的方式判断是从nor拷贝uboot内容还是从nand拷贝uboot的内容。
int bBootFrmNORFlash(void)
{
volatile unsigned int *pdw = (volatile unsigned int *)0;
unsigned int dwVal;
/*
* 无论是从NOR Flash还是从NAND Flash启动,
* 地址0处为指令"b Reset", 机器码为0xEA00000B,
* 对于从NAND Flash启动的情况,其开始4KB的代码会复制到CPU内部4K内存中,
* 对于从NOR Flash启动的情况,NOR Flash的开始地址即为0。
* 对于NOR Flash,必须通过一定的命令序列才能写数据,
* 所以可以根据这点差别来分辨是从NAND Flash还是NOR Flash启动:
* 向地址0写入一个数据,然后读出来,如果没有改变的话就是NOR Flash
*/
dwVal = *pdw;
*pdw = 0x12345678;
if (*pdw != 0x12345678)
{
return 1;//从nor启动
}
else
{
*pdw = dwVal;//复原原先0地址处的数据
return 0;//从nand启动
}
}