从Nand Flash启动U-BOOT的基本原理

发布者:彭勇最新更新时间:2016-12-07 来源: eefocus关键字:Nand  Flash  启动  U-BOOT 手机看文章 扫描二维码
随时随地手机看文章

前4K的问题 
如果S3C2410被配置成从Nand Flash启动(配置由硬件工程师在电路板设置), S3C2410的Nand Flash控制器有一个特殊的功能,在S3C2410上电后,Nand Flash控制器会自动的把Nand Flash上的前4K数据搬移到4K内部RAM中,并把0x00000000设置内部RAM的起始地址,CPU从内部RAM的0x00000000位置开 始启动。这个过程不需要程序干涉。 
程序员需要完成的工作,是把最核心的启动程序放在Nand Flash的前4K中。 
启动程序的安排 
由于Nand Flash控制器从Nand Flash中搬移到内部RAM的代码是有限的,所以在启动代码的前4K里,我们必须完成S3C2410的核心配置以及把启动代码(U-BOOT)剩余部分搬到RAM中运行。 
u-boot源码不支持从nand flash启动,可是s3c2410支持从nand flash启动,开发板(sbc-2410x)加电后s3c2410将nand flash的前4k(保存有u-boot的部分功能--拷贝功能--把nand flash中的内容拷贝到SDRAM)拷贝到sram(s3c2410芯片内的sram)。这就需要修改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无法取得可以执行的代码,也就不能初始化系统了。 
2. NAND FLASH是顺序存取设备,不能够被随机访问,程序就不能够分支或跳转,这样你如何去设计程序。 
U-BOOT 支持ARM、 PowerPC等多种架构的处理器,也支持Linux、NetBSD和VxWorks等多种操作系统,主要用来开发嵌入式系统初始化代码 bootloader。bootloader是芯片复位后进入操作系统之前执行的一段代码,完成由硬件启动到操作系统启动的过渡,为运行操作系统提供基本 的运行环境,如初始化CPU、堆栈、初始化存储器系统等,其功能类似于PC机的BIOS. 
 
从NAND闪存中启动U-BOOT的设计 
摘要:本文介绍了S3C2410中NAND闪存的工作原理,分析了从NAND闪存启动U-BOOT的设计思路,并着重描述了NAND闪存支持U-BOOT的程序设计,移植后U-BOOT在嵌入式系统中运行良好。 
关键词:U-BOOT;NAND闪存;S3C2410;嵌入式系统 引言 
随着嵌入式系统的日趋复杂,它对大容量数据存储的需求越来越紧迫。而嵌入式设备低功耗、小体积以及低成本的要求,使硬盘无法得到广泛的应用。NAND闪存 设备就是为了满足这种需求而迅速发展起来的。目前关于U-BOOT的移植解决方案主要面向的是微处理器中的NOR 闪存,如果能在微处理器上的NAND 闪存中实现U-BOOT的启动,则会给实际应用带来极大的方便。U-BOOT简介 
U-BOOT 支持ARM、 PowerPC等多种架构的处理器,也支持Linux、NetBSD和VxWorks等多种操作系统,主要用来开发嵌入式系统初始化代码 bootloader。bootloader是芯片复位后进入操作系统之前执行的一段代码,完成由硬件启动到操作系统启动的过渡,为运行操作系统提供基本 的运行环境,如初始化CPU、堆栈、初始化存储器系统等,其功能类似于PC机的BIOS。NAND闪存工作原理 
S3C2410开发板的NAND闪存由NAND闪存控制器(集成在S3C2410 CPU中)和NAND闪存芯片(K9F1208U0A)两大部分组成。当要访问NAND闪存芯片中的数据时,必须通过NAND闪存控制器发送命令才能完 成。所以, NAND闪存相当于S3C2410的一个外设,而不位于它的内存地址区。 
NAND闪存(K9F1208U0A)的数据存储结构分层为:1设备(Device) = 4096 块(Block);1块= 32页/行(Page/row);1页= 528B = 数据块 (512B) + OOB块 (16B) 
在每一页中,最后16个字节(又称OOB)在NAND闪存命令执行完毕后设置状态,剩余512个字节又分为前半部分和后半部分。可以通过NAND闪存命令00h/01h/50h分别对前半部、后半部、OOB进行定位,通过NAND闪存内置的指针指向各自的首地址。 
NAND 闪存的操作特点为:擦除操作的最小单位是块;NAND闪存芯片每一位只能从1变为0,而不能从0变为1,所以在对其进行写入操作之前一定要将相应块擦 除;OOB部分的第6字节为坏快标志,即如果不是坏块该值为FF,否则为坏块;除OOB第6字节外,通常用OOB的前3个字节存放NAND闪存的硬件 ECC(校验寄存器)码; 
从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在嵌入式系统中运行良好。


关键字:Nand  Flash  启动  U-BOOT 引用地址:从Nand Flash启动U-BOOT的基本原理

上一篇:ARM ADS中的AXD 调试经验集锦
下一篇:LPC2103开发板WDT看门狗测试试验

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

MIUI开机启动页提小米新Logo
在今年3月的小米春季新品发布会上,由日本国际著名设计大师原研哉操刀设计的小米全新Logo正式亮相。 原研哉表示,新Logo融入了设计师对于“Alive”设计理念的思考。 日前,MIUI 12.5开发版内测21.6.30更新正式推送,原MIUI光锥特效界面,更换为小米新Logo。 另外,在此次更新中,还去掉了诸多过度动画,使用更加流畅顺滑。 据介绍,在设计新标识的同时,原研哉还重新设计了“Xiaomi”字母Logo。 对于品牌形象,原研哉建议只用品牌标识,对于更高精度的智能手机之类的设备,使用字母Logo的效果更高。 值得一提的是,小米原有的品牌颜色——橙色得以保留,会继续作为企业品牌颜色来使用。同时,新增了黑色和银色作为辅
[手机便携]
STM32开发笔记69: 外设启动的先后次序
单片机型号:STM32F070F6P6 今天,在程序框架中增加了Timer16定时器驱动,但程序不能正常运行,本篇日志记录其原因。 驱动程序框架,定义了回调函数Timer16_InterruptFunction,写在main.cpp中用于逻辑层设计。Timer16_InterruptFunction调用的间隔为1ms,具体程序如下: void Timer16_InterruptFunction(void) { Target.HAL.L2.Turn(); } 此程序完成以1ms为间隔L2闪烁的程序,但是将此程序烧写到目标板后,程序不能正常运行。经过调试,最后将问题锁定在启动顺序上,看一下程序外设的启动顺序,具体程序如下
[单片机]
STM8L芯片启动时钟分频问题及发现
1,在STM8L参考手册上,可以找到如下说明。 上面写着分频器的几种设置方法,其中写有“复位默认:0x03”即8分频。理论上说,启动时钟后的时钟应该是2MHz。可是实际在单片机上下载程序发现,启动时为16MHz。 2,首先我是怀疑自己的实验平台存在问题,于是改用仿真调试,再加上对分频器进行多种设置后,发现单片机是正常的,程序设计也没问题。 3,怀疑是参考手册文档的版本问题,可能我下载的文档是旧版本的。于是在ST官网下载新版型号完全对应的新手册,发现手册上的说明依然是复位后8分频。 4,怀疑可能是文档编写错误,于是在网上搜索“STM8L 分频 默认”等相关信息,看看别人是否遇见同样的问题,或是ST官方有没有对错误的通
[单片机]
“中国航信杯”第七届全国信息技术应用水平大赛正式启动
5月16日下午,“中国航信杯”第七届全国信息技术应用水平大赛新闻发布会在教育部顺利召开,标志着本届大赛正式拉开帷幕。教育部教育管理信息中心总工程师曾德华、教育部教育管理信息中心开发处处长薛玉梅、中国民航信息集团公司市场部部长常伯彤出席了发布会并发表讲话,中兴通讯、联想集团、和利时集团、亚控科技、知金教育等大赛支持单位的领导出席了会议。 这项赛事的前身是“全国ITAT教育工程就业技能大赛”,从2011年的第六届开始更名为“全国信息技术应用水平大赛”。前面六届累计参赛学校达到3400所,参赛学生超过41万人次,对引导学校积极开展应用型人才的培养,促进学生就业起到了积极作用,得到了教育部有关领导的高度重视,相关司局的大力支持,
[网络通信]
物联网、5G以及人工智能的演进,兆易创新迎来巨大增长潜力
北京兆易创新科技股份有限公司于2005-04-06在北京市工商行政管理局登记成立。法定代表人朱一明,公司经营范围包括微电子产品、计算机软硬件、计算机系统集成等。 根据摩根斯坦利发布的报告,今年第二季度时,NOR Flash的库存为60天左右。第三季度NOR Flash产品基本会达到供需平衡,甚至需求超过供给。 NOR Flash做为通用型器件应用广泛,兆易创新重点专注6大应用领域,产品种类多样,例如宽电压、低功耗、高性能、大容量以及安全等针对不同特性已形成非常全面的产品体系。 但从去年Q4到今年Q1,受贸易战、需求放缓、信心不足等影响,市场环境不太景气;直到今年3月份之后,尤其Q2、Q3兆易创新的订单量逐渐提升。值得注
[嵌入式]
物联网、5G以及人工智能的演进,兆易创新迎来巨大增长潜力
NOR Flash市场依然供不应求,旺宏要“盘满钵满”了
NOR Flash是一种非易失闪存技术,是Intel在1988年创建。是现在市场上两种主要的非易失闪存技术之一。NOR的特点是芯片内执行(XIP, eXecute In Place),这样应用程序可以直接在flash闪存内运行,不必再把代码读到系统RAM中。NOR的传输效率很高,在1~4MB的小容量时具有很高的成本效益,但是很低的写入和擦除速度大大影响了它的性能。下面就随嵌入式小编一起来了解一下相关内容吧。 旺宏总经理卢志远表示,2018年品牌NOR Flash市场需求还会增加,要不缺货还有点困难,旺宏第1季全球NOR Flash市占率达26%,全年目标30%,中长期看50%市占,同时董事会也追加新台币17.85亿元的资本支出
[嵌入式]
stm32.cube(六)——HAL.FLASH
一、片内Flash特性 1.1 FLash结构简图 我的开发板是stm32f103xx,所以片内flash主存储器大小128K,单页为1K。不同的芯片flash大小不同,页大小也不同。 主存储器 用来存储Rom程序,烧写的区域。当然也可以存一些其他东西,比如做nvram使用。 信息块 这个区域分两个部分。 存储区,用户不可写区域,用来存储ISP下载时用到的程序。当用ISP模式进行烧写时,自动调用里面的程序下载数据并烧写到flash里。 用户选项字,存储硬件配置信息。某些复用的外设可能在上电复位后就要立即知道它被用作其中哪个用途。 用户选项字默认不可写,它上电自动加锁。只有通过向FLASH_OPTKEYR依次写入约定解锁码KE
[单片机]
FLASH存储器的测试方法研究
1.引言 随着当前移动存储技术的快速发展和移动存储市场的高速扩大,FLASH型存储器的用量迅速增长。FLASH芯片由于其便携、可靠、成本低等优点,在移动产品中非常适用。市场的需求催生了一大批FLASH芯片研发、生产、应用企业。为保证芯片长期可靠的工作,这些企业需要在产品出厂前对FLASH存储器进行高速和细致地测试,因此,高效FLASH存储器测试算法的研究就显得十分必要。 不论哪种类型存储器的测试,都不是一个十分简单的问题,不能只将存储器内部每个存储单元依次测试一遍就得出结论,这是因为每一个存储单元的改变都有可能影响存储器内部其他单元的变化(这种情况又是常常发生的)。这种相关性产生了巨大的测试工作量[1]。另外,FLAS
[测试测量]
<font color='red'>FLASH</font>存储器的测试方法研究
小广播
添点儿料...
无论热点新闻、行业分析、技术干货……
设计资源 培训 开发板 精华推荐

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

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

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