nand flash启动分析

发布者:lidong4069最新更新时间:2016-11-27 来源: eefocus关键字:nand  flash  启动分析 手机看文章 扫描二维码
随时随地手机看文章



           2410支持从nand flash启动。通过将flash中最开始的4k代码拷贝到,2410片内的一块不用初始化的sram中运行,该拷贝过程完全由硬件支持,无需软件操作。 
  Nand Flash控制器有一个特殊的功能,在S3C2410上电后,Nand Flash控制器会自动的把Nand Flash上的前4K数据搬移到4K内部RAM中,并把0x00000000设置内部RAM的起始地址,CPU从内部RAM的0x00000000位置开始启动。这个过程不需要程序干涉。程序员需要完成的工作,是把最核心的启动程序放在Nand Flash的前4K中。 
  u-boot源码不支持从nand flash启动,可是s3c2410支持从nand flash启动,开发板(sbc-2410x)加电后s3c2410将nand flash的前4k(保存有u-boot的部分功能--拷贝功能--把nand flash中的内容拷贝到SDRAM)拷贝到sram(s3c2410芯片内的sram),即nGCS0,映射地址为0x00000000。这就需要修改u-boot源码,增加u-boot的功能:使u-boot在得到执行权后能够将其自身拷贝到开发板上SDRAM中,以便处理器能够执行u-boot。Nand Flash的命令、地址、数据都通过I/O口发送,管脚复用,这样做做的好处是,可以明显减少NAND FLASH的管脚数目,将来如果设计者想将NAND FLASH更换为更高密度、更大容量的,也不必改动电路板。 
  NAND FLASH不能够执行程序,本人总结其原因如下: 
  1. 
  NAND FLASH本身是连接到了控制器上而不是系统总线上。CPU启动后是要取指令执行的,如果是SROM、NOR FLASH 等之类的,CPU 
   发个地址就可以取得指令并执行,NAND FLASH不行,因为NAND FLASH是管脚复用,它有自己的一套时序,这样CPU无法取得可以执行的代码,也就不能初始化系统了。例如:str r0,[r1],该命令包含了目的地址和源寄存器,按照cpu的时序将寄存器中的数据保存到内存中。如果想把数据存储到nand flash上,必须按照nand flash的读写时序进行,如先写NFCONF,然后NFCMD,NFADDR,最后读NFDATA。 
  2. 
  NAND FLASH是顺序存取设备,不能够被随机访问,读写访问以页为单位,程序就不能够分支或跳转,这样你如何去设计程序。 
  bootloader 
  bootloader是芯片复位后进入操作系统之前执行的一段代码,完成由硬件启动到操作系统启动的过渡,为运行操作系统提供基本的运行环境,如初始化CPU、堆栈、初始化存储器系统等,其功能类似于PC机的BIOS。 
  从NAND闪存启动U-BOOT的设计思路 
  如果S3C2410被配置成从NAND闪存启动,上电后,S3C2410的NAND闪存控制器会自动把NAND闪存中的前4K数据搬移到内部RAM中,并把0x00000000设置为内部RAM的起始地址,CPU从内部RAM的0x00000000位置开始启动。因此要把最核心的启动程序放在NAND闪存的前4K中。 
  由于NAND闪存控制器从NAND闪存中搬移到内部RAM的代码是有限的,所以在启动代码的前4K里,必须完成S3C2410的核心置,并把启动代码的剩余部分搬到RAM中运行。在U-BOOT中,前4K完成的主要工作就是U-BOOT启动的第一个阶段(stage1)。 根据U-BOOT的执行流程图,可知要实现从NAND闪存中启动U-BOOT,首先需要初始化NAND闪存,并从NAND闪存中把U-BOOT搬移到RAM中,最后需要让U-BOOT支持NAND闪存的命令操作。 
  开发环境 
  本设计中目标板硬件环境如下:CPU为S3C2410,SDRAM为HY57V561620,NAND闪存为64MB的K9F1208U0A。 
  主机软件环境为Redhat9.0、 u-boot-1.1.3、gcc 2.95.3。修改U-BOOT的Makefile,加入: 
  wch2410_config : unconfig 
  @./mkconfig $(@:_config=) arm arm920t wch2410 NULL s3c24x0 
  即将开发板起名为wch2410,接下来依次进行如下操作: 
  mkdir board/wch2410 
  cp board/smdk2410 board/wch2410 
  mv smdk2410.c wch2410.c 
  cp include/configs/smdk2410.h include/configs/wch2410.h 
  export PATH=/usr/local/arm/2.95.3/bin:$PATH 
  最后执行: 
  make wch2410_config 
  make all ARCH=arm 
  生成u-boot.bin,即通过了测试编译。 
  具体设计 
  支持NAND闪存的启动程序设计 
  因为U-BOOT的入口程序是/cpu/arm920t/start.S,故需在该程序中添加NAND闪存的复位程序,以及实现从NAND闪存中把U-BOOT搬移到RAM中的功能程序。 
  首先在/include/configs/wch2410.h中加入CONFIG_S3C2410_NAND_BOOT, 如下: 
  #define CONFIG_S3C2410_NAND_BOOT 1 @支持从NAND 闪存中启动 
  然后在/cpu/arm920t/start.S中添加 
  #ifdef CONFIG_S3C2410_NAND_BOOT 
  copy_myself: 
  mov r10, lr 
  ldr sp, DW_STACK_START @安装栈的起始地址 
  mov fp, #0 @初始化帧指针寄存器 
  bl nand_reset @跳到复位C函数去执行,执行NAND闪存复位 
  ....... 
  /*从NAND闪存中把U-BOOT拷贝到RAM*/ 
  ldr r0, =UBOOT_RAM_BASE @ 设置第1个参数: UBOOT在RAM中的起始地址 
  mov r1, #0x0 @ 设置第2个参数:NAND闪存的起始地址 
  mov r2, #0x20000 @ 设置第3个参数: U-BOOT的长度(128KB) 
  bl nand_read_whole @ 调用nand_read_whole(),把NAND闪存中的数据读入到RAM中 
  tst r0, #0x0 @ 如果函数的返回值为0,表示执行成功 
  beq ok_nand_read @ 执行内存比较,把RAM中的前4K内容与NAND闪存中的前4K内容进行比较, 如果完全相同, 则表示搬移成功 
  其中,nand_reset (),nand_read_whole()被加在/board/wch2410/wch2410.c中。 
  支持U-BOOT命令设计 
   在U-BOOT下对nand闪存的支持主要是在命令行下实现对nand闪存的操作。对nand闪存实现的命令为:nand info(打印nand Flash信息)、nand device(显示某个nand闪存设备)、nand read(读取nand闪存)、nand write(写nand闪存)、nand erease(擦除nand闪存)、nand bad(显示坏块)等。 
  用到的主要数据结构有:struct nand_flash_dev、struct nand_chip。前者包括主要的芯片型号、存储容量、设备ID、I/O总线宽度等信息;后者是具体对NAND闪存进行操作时用到的信息。 
  a. 设置配置选项 
  修改/include/configs/wch2410.h,主要是在CONFIG_COMMANDS中打开CFG_CMD_NAND选项。定义NAND闪存控制器在SFR区中的起始寄存器地址、页面大小,定义NAND闪存命令层的底层接口函数等。 
  b. 加入NAND闪存芯片型号 
  在/include/linux/mtd/ nand_ids.h中对如下结构体赋值进行修改: 
  static struct nand_flash_dev nand_flash_ids[] = { 
  ...... 
  {"Samsung K9F1208U0A", NAND_MFR_SAMSUNG, 0x76, 26, 0, 3, 0x4000, 0}, 
  ....... 
  } 
  这样对于该款NAND闪存芯片的操作才能正确执行。 
  c. 编写NAND闪存初始化函数 
  在/board/wch2410/wch2410.c中加入nand_init()函数。 
  void nand_init(void) 
  { 
  /* 初始化NAND闪存控制器, 以及NAND闪存芯片 */ 
  nand_reset(); 
  /* 调用nand_probe()来检测芯片类型 */ 
  printf ("%4lu MB\n", nand_probe(CFG_NAND_BASE) >> 20); 
  } 
  该函数在启动时被start_armboot()调用。 
  最后重新编译U-BOOT并将生成的u-boot.bin烧入NAND闪存中,目标板上电后从串口输出如下信息: 
  U-Boot 1.1.3 (Nov 14 2006 - 11:29:50) 
  U-Boot code: 33F80000 -> 33F9C9E4 BSS: -> 33FA0B28 
  RAM Configuration: 
  Bank #0: 30000000 64 MB 
  ## Unknown Flash on Bank 0: ID 0xffff, Size = 0x00000000 = 0 MB 
  Flash: 0 kB 
  NAND: 64 MB 
  In: serial 
  Out: serial 
  Err: serial 
  Hit any key to stop autoboot: 0 
  wch2410 # 
  结语 
  以往将U-BOOT移植到ARM9平台中的解决方案主要针对的是ARM9中的NOR闪存,因为NOR闪存的结构特点致使应用程序可以直接在其内部运行,不用把代码读到RAM中,移植过程相对简单。从NAND闪存中启动U-BOOT的设计难点在于NAND闪存需要把U-BOOT的代码搬移到RAM中,并要让U-BOOT支持NAND闪存的命令操作。本文介绍了实现这一设计的思路及具体程序。移植后,U-BOOT在嵌入式系统中运行良好。 
  参考文献 
  1 杜春雷 . ARM 体系结构与编程 [M]. 北京 : 清华大学出版社, 2003 
  2 S3C2410 User's Mannual[Z].Samsung 
  vivi中的源码 
  #ifdef CONFIG_S3C2410_NAND_BOOT 
  @ 
  @ copy_myself: copy vivi to ram 
  @ 
  copy_myself: 
  mov r10, lr 
  @ reset NAND 
  mov r1, #NAND_CTL_BASE 
  ldr r2, =0xf830 @ initial value 
  str r2, [r1, #oNFCONF] 
  ldr r2, [r1, #oNFCONF] 
  bic r2, r2, #0x800 @ enable chip 
  str r2, [r1, #oNFCONF] 
  mov r2, #0xff @ RESET command 
  strb r2, [r1, #oNFCMD] 
  mov r3, #0 @ wait 
  1: add r3, r3, #0x1 
  cmp r3, #0xa 
  blt 1b 
  2: ldr r2, [r1, #oNFSTAT] @ wait ready 
  tst r2, #0x1 
  beq 2b 
  ldr r2, [r1, #oNFCONF] 
  orr r2, r2, #0x800 @ disable chip 
  str r2, [r1, #oNFCONF] 
  @ get read to call C functions (for nand_read()) 
  ldr sp, DW_STACK_START @ setup stack pointer 
  mov fp, #0 @ no previous frame, so fp=0 
  @ copy vivi to RAM 
  ldr r0, =VIVI_RAM_BASE 
  mov r1, #0x0 
  mov r2, #0x20000 
  bl nand_read_ll 
  tst r0, #0x0 
  beq ok_nand_read

关键字:nand  flash  启动分析 引用地址:nand flash启动分析

上一篇:S3C2440快速启动的实现描述
下一篇:u-boot-在2440上的移植详解(一)

推荐阅读最新更新时间:2024-03-16 15:22

NAND flash价格回升 位增长将创历史新低
一位存储器产业分析师表示,NAND flash平均销售价格已从去年第四季度的每Gbyte 80多美分上涨至超过现金成本。 Forward Insights分析师Gregory Wong指出,2009年NAND flash资本支出预计减少69%,技术迁移将成为主导。Wong称NAND flash厂商对消费市场需求下滑做出了反应,逐步停止200mm工厂产能,第一季度产能利用率削减至70%左右。 然而Wong说厂商恢复盈利的可能性很小。削减产能将缓解2009年和2010年价格下滑,但同样也会限制价格的增长动力,厂商很有可能在价格回升和供应暂时短缺时开启闲置产能。 Wong表示,2009年供应量减少和需求低迷
[半导体设计/制造]
为功耗敏感应用选择最佳的低功耗、低成本FPGA
功耗敏感应用的设计人员如今面对前所未有严格的系统总体功耗限制、规范和标准。与此同时,这类应用所要求的功能、性能和复杂度正不断增加,但却不能以增加电池消耗和成本作为代价。对大多数工程决定来说,确定最佳的器件取决于功耗、性能、逻辑和I/O数量方面的设计约束。由于基于Flash的非易失性FPGA不需要数百万耗电的SRAM配置数据存储单元,其静态功耗较之于基于SRAM的解决方案低很多,因而成为功耗敏感应用的理想器件。 可选的解决方案 以前,大多数设计人员依赖ASIC来满足设计中的低功耗约束,而不是采用FPGA。由于开发周期较长、NRE高、缺乏应对标准变化及后期设计修改灵活性差,采用硬连线的ASIC风险较高,对产品生命周期较
[嵌入式]
消息称三星 NAND 拟进一步涨价,明年一、二季度将逐季调涨 20%
11 月 2 日消息,据台湾地区《经济日报》今日报道,存储芯片巨头三星计划加大 NAND Flash 的涨价力度,预计明年前二季度逐季调涨 20%。 这一消息是由韩国半导体产业多名消息人士透露的。据称,三星在本季调升 NAND 报价 10-20% 之后,已决定明年第一、第二季度逐季调涨 20%,此举是三星为了努力稳定 NAND 价格、且达成明年上半年逆转市场等目标的一系列行动。 报道称,三星执行副总裁金在俊于当地时间 10 月 31 日的财报会议上宣布,公司接下来的减产行动,将比目前 DRAM 缩减产出的规模更大。目前,三星在积极提高报价的同时,也通过持续减产来控制市场供给量。 据 TrendForce 集邦咨询 9 月公布的报告
[半导体设计/制造]
ARM 开发板 NAND FLASH空间不足解决方法
由于FL2440自带128M 的NAND flash,而分给Linux文件系统的只有60M,由于系统中有许多库文件,导致文件系统过大。 可以有两种解决方案: 1、修改bootloader和内核源代码中有关分区的信息,删除Windows CE分区,重新编译bootloader和内核,当然这样比较麻烦可以参考 http://blog.csdn.net/ll_0520/archive/2010/12/25/6098565.aspx 这需要有心理准备,很可能会遇到很多麻烦,当然解决麻烦也是锻炼动手能力的一个过程。 2、将文件系统中一些有关QT界面的库文件如:/usr/lib目录以NFS的形式挂载,这样可以节省出20M的空间 具
[单片机]
第一季度NAND闪存领域竞争加剧
据IHS iSuppli公司的研究,2011年第一季度NAND闪存领域争夺头号排名的竞争加剧,排名第二的东芝接近与三星电子平起平坐。长期以来,三星一直是最大的NAND闪存厂商。 第一季度三星的NAND闪存营业收入为19.1亿美元,占35.9%的份额。东芝的营业收入为18.9亿美元,份额为35.6%。 第一季度东芝NAND闪存营业收入环比增长13.9%,三星则增长11.4%。但更令人瞩目的是,2011年第一季度东芝的NAND闪存营业收入比2010年同期大增28.5%,而三星仅增长13.8%。结果,这两家厂商的市场份额差距从2010年第四季度的1.1个百分点缩小至只有0.3个百分点。 美光排名第三,与前两名相距甚
[嵌入式]
第一季度<font color='red'>NAND</font>闪存领域竞争加剧
USB海量存储类设备功能在ARM系统中的应用
技术发展到今天的信息时代,数据的存储和传输在嵌入式系统有了越来越重要的地位。而USB是目前设计成熟、应用广泛且使用极为简捷的技术,USB传输是一种高效方便的数据传输方式。基于上述原因,本文重点论述基于USB的海量存储(USB Mass Storage)设备功能在ARM嵌入式系统中设计和应用。使用该设备功能,上位机可以像读写普通U盘一样对于系统采集并存储在FLASH中的数据进行读写。 1 硬件方案 l.1 器件简介 S3C44B0X 是SAMSUNG公司出品的基于ARM7TDMI内核的RISC型微处理器,8 kB指令和数据共享的缓存,主频可达66 MHz,可以运行16位的Thumb指令和32位的ARM指令,且接口丰富,具有通用
[缓冲存储]
STM32学习笔记一一FLASH 模拟 EEPROM
1. 简述 STM32 本身没有自带 EEPROM,但是 STM32 具有在应用编程(IAP:In Application Programming)功能,可以把它的 FLASH 当成 EEPROM 来使用。 不同型号的 STM32,其 FLASH 容量也有所不同,最小的只有 16K 字节,最大的则达到了1024K 字节。MiniSTM32 开发板选择的 STM32F103RCT6 的 FLASH 容量为 256K 字节,属于大容量产品,闪存模块组织如下图: 1.1 主存储器: 该部分用来存放代码和数据常数(如 const 类型的数据)。对于大容量产品,其被划分为 256 页,每页 2K 字节。**注意:**小容量和中
[单片机]
STM32学习笔记一一<font color='red'>FLASH</font> 模拟 EEPROM
C8051F020的Flash操作
C8051F020的Flash可以实现IAP功能(In Application Programming),即程序可对Flash存储区进行编程,也就是说Flash除了可以存放程序代码,还可以在剩下的空间内存储数据,即起到EEPROM的功能,下图是C8051F020的存储组织结构图 可以看到它的结构是64K+128字节的形式,0xfe00~0xffff为工厂保留区,不能进行操作,当64K的Flash用作存储数据时,先确定程序代码的位置,以免覆盖程序导致出错,还有操作Flash前必须禁止中断,否则可能会出现无法预知的错误,下面是我写的驱动,经测试没问题: void Flash_area_Erase(bit type,u
[单片机]
小广播
添点儿料...
无论热点新闻、行业分析、技术干货……
设计资源 培训 开发板 精华推荐

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

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

换一换 更多 相关热搜器件
电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2024 EEWORLD.com.cn, Inc. All rights reserved