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启动 
    }
}

 

posted on 2018-07-22 21:20  andy_fly  阅读(3565)  评论(0编辑  收藏  举报