u-boot之NAND启动与NOR启动的区别

发布者:RainbowMelody最新更新时间:2024-08-29 来源: cnblogs关键字:u-boot  NAND启动 手机看文章 扫描二维码
随时随地手机看文章

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

    }

}


关键字:u-boot  NAND启动 引用地址:u-boot之NAND启动与NOR启动的区别

上一篇:u-boot之start_armboot函数分析
下一篇:u-boot之make all执行过程分析

推荐阅读最新更新时间:2024-11-10 11:06

u-boot-2009.08在mini2440上的移植(五)---增加yaffs2文件系统
移植环境 1,主机环境:VMare下CentOS 5.5 ,1G内存。 2,集成开发环境:Elipse IDE 3,编译编译环境:arm-linux-gcc v4.4.3,arm-none-eabi-gcc v4.5.1。 4,开发板:mini2440,2M nor flash,128M nand flash。 5,u-boot版本:u-boot-2009.08 6,参考文章: http://blogold.chinaunix.net/u3/101649/showart.php?id=2105215 http://blog.chinaunix.net/space.php?uid=23787856&do=blog&id=1153
[单片机]
OK6410A 开发板 (八) 83 linux-5.11 OK6410A arm-gdb+JLinkGDBServer+Jlink+JTAG接口 调试 u-boot
之前在 https://blog.csdn.net/u011011827/article/details/118713517 中可以看到 可以调试裸机. 可见我加载了bin文件到0x50000000,这是外部sdram的空间 所以加载之前,必须要初始化,而这个初始化动作,u-boot帮忙给做了(我的板子烧好了u-boot) 在调试裸机前u-boot已经跑到cmdline了 当然你调试bin文件大小小于8KB的裸机程序时,可以将其加载到sram中,这样就不用初始化sdram了. 自己手动加载u-boot 到内存 u-boot 也是一个裸机程序,这个程序和 led.bin 不同 u-boot.bin 要大,但是两个的调试方
[单片机]
u-bootNAND启动NOR启动的区别
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里面存放的是占用容量
[单片机]
<font color='red'>u-boot</font>之<font color='red'>NAND</font><font color='red'>启动</font>与<font color='red'>NOR</font><font color='red'>启动</font>的区别
关于S3C2440 u-boot支持nand hw ecc
https://blog.csdn.net/hurry_liu/article/details/8741565 ---这篇文章(文章1)讲的很详细。 http://www.xuebuyuan.com/zh-hant/916448.html ----这篇文章(文章2)也讲的差不多。 文章1和文章2的描述是一样的,只是代码内容不一样。 一开始我是看到了文章1,按照那个代码来修改自己的代码,结果还是不成功,总是在读取的时候出现如下错误。 S3C NAND: ECC uncorrectable errordetected. Not correctable. NAND read from offset 0 failed -74 后来看
[单片机]
关于S3C2440 <font color='red'>u-boot</font>支持<font color='red'>nand</font> hw ecc
u-boot-2014.10移植(8)重定位,支持NAND启动
前面链接地址都是0x0,可以从nor正常启动内核和文件系统。 现在把链接地址改成0x33f00000 一旦更改了链接地址, u-boot从nor flash加载时,串口没有任何输出 添加文件boot_init.c #define NFCONF (*((volatile unsigned long *)0x4E000000)) #define NFCONT (*((volatile unsigned long *)0x4E000004)) #define NFCMMD (*((volatile unsigned char *)0x4E000008)) #define NFADDR (*((volatile unsigned
[单片机]
u-boot-在2440上的移植详解(五)
嵌入式Linux之我行,主要讲述和总结了本人在学习嵌入式linux中的每个步骤。一为总结经验,二希望能给想入门嵌入式Linux的朋友提供方便。如有错误之处,谢请指正。 共享资源,欢迎转载: http://hbhuanggang.cublog.cn 一、移植环境 主 机:VMWare--Fedora 9 开发板:Mini2440--64MB Nand, Kernel:2.6.30.4 编译器: arm-linux-gcc-4.3.2.tgz u-boot: u-boot-2009.08.tar.bz2 二、移植步骤 上接: u-boot-2009.08在2440上的移植详解(四) 9)实现u-boot对yaf
[单片机]
u-boot-在2440上的移植详解(五)
s3c2440 NANDNOR启动方式详解+个人验证
一:地址空间的分配 1:s3c2440是32位的,所以可以寻址4GB空间,内存(SDRAM)和端口(特殊寄存器),还有ROM都映射到同一个4G空间里. 2:开发板上一般都用SDRAM做内存flash(nor、nand)来当做ROM。其中nand flash没有地址线,一次至少要读一页(512B).其他两个有地址线 3:nandflash不用来运行代码,只用来存储代码,NORflash,SDRAM可以直接运行代码) 4:s3c2440总共有8个内存banks 6个内存bank可以当作ROM或者SRAM来使用 留下的2个bank除了当作ROM或者SRAM,还可以用SDRAM(各种内存的读写方式不一样) 7个bank的起始地址是固定的
[单片机]
s3c2440 <font color='red'>NAND</font>与<font color='red'>NOR</font><font color='red'>启动</font>方式详解+个人验证
TQ2440 学习笔记—— 31、移植U-BootU-Boot启动过程第二阶段源码分析】
二、U-Boot第二阶段代码分析 U-Boot 第二阶段流程图 移植U-Boot 的主要工作在于对硬件的初始化、驱动,所以下面的重点放在硬件的操作上。 (1)初始化本阶段要使用到的硬件设备 最主要的是设置系统时钟、初始化串口,只要这两个设置好了就可以从串口看到打印信息。 board_init 函数设置MPLL、改变系统时钟,它是开发板相关的函数,在board/EmbedSky/EmbedSky.c 中实现。 board_init 函数还保存了机器类型ID,这将在调用内核时传给内核代码如下: 串口的初始化函数主要是 serial_init,它设置 UART 控制器,是CPU 相关的函数,在cpuarm92
[单片机]
TQ2440 学习笔记—— 31、移植<font color='red'>U-Boot</font>【<font color='red'>U-Boot</font> 的<font color='red'>启动</font>过程第二阶段源码分析】
小广播
设计资源 培训 开发板 精华推荐

最新单片机文章
何立民专栏 单片机及嵌入式宝典

北京航空航天大学教授,20余年来致力于单片机与嵌入式系统推广工作。

 
EEWorld订阅号

 
EEWorld服务号

 
汽车开发圈

电子工程世界版权所有 京ICP证060456号 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2024 EEWORLD.com.cn, Inc. All rights reserved