历史上的今天
返回首页

历史上的今天

今天是:2026年01月11日(星期日)

2023年01月11日 | 基于S3C2410开发板的U-BOOT移植解决方案

2023-01-11 来源:elecfans

引言

随着嵌入式系统的日趋复杂,它对大容量数据存储的需求越来越紧迫。而嵌入式设备低功耗、小体积以及低成本的要求,使硬盘无法得到广泛的应用。NAND闪存设备就是为了满足这种需求而迅速发展起来的。目前关于U-BOOT的移植解决方案主要面向的是微处理器中的NOR 闪存,如果能在微处理器上的NAND 闪存中实现U-BOOT的启动,则会给实际应用带来极大的方便。


U-BOOT简介

U-BOOT 支持ARM、 PowerPC等多种架构的处理器,也支持Linux、NetBSD和VxWorks等多种操作系统,主要用来开发嵌入式系统初始化代码bootloader。bootloader是芯片复位后进入操作系统之前执行的一段代码,完成由硬件启动到操作系统启动的过渡,为运行操作系统提供基本的运行环境,如初始化CPU、堆栈、初始化存储器系统等,其功能类似于PC机的BIOS。U-BOOT执行流程图如图1所示。

基于S3C2410开发板的U-BOOT移植解决方案

图1 U-BOOT启动流程图

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 MBn”, 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在嵌入式系统中运行良好。


推荐阅读

史海拾趣

广芯电子(BROADCHIP)公司的发展小趣事

撰写五个关于广芯电子(BROADCHIP)公司在电子行业发展的故事可能内容过多,我可以先为您提供一个故事的示例,如果需要更多故事,可以在之后输入继续。


广芯电子:从创业起步到业界翘楚的飞跃

在电子行业的广阔天地中,广芯电子以其坚韧不拔的精神和前瞻性的技术布局,逐渐崭露头角,成为业界的一匹黑马。

故事要从创始人戴忠伟的海外求学经历说起。深受邓小平南巡讲话的影响,戴忠伟毅然辞去稳定的工作,选择留学深造。在异国他乡,他深耕半导体集成电路领域,积累了丰富的技术经验和人脉资源。毕业后,他先后在多家知名美国半导体公司担任技术专家和设计总监,为后来的创业之路打下了坚实的基础。

回国后,戴忠伟敏锐地洞察到国内半导体市场的巨大潜力,于是决定创立广芯电子,致力于中高端功率器件的晶圆代工业务。创业初期,公司面临着资金短缺、技术瓶颈等重重困难,但戴忠伟带领团队凭借着对技术的执着追求和对市场的深刻理解,逐步攻克了一个又一个难关。

经过几年的努力,广芯电子实现了从交付第一千万颗芯片到第一亿颗芯片的跨越,并在短短七年内实现了交付第十亿颗芯片的壮举。这一成绩的背后,是公司对技术创新的不断投入和对产品质量的严格把控。同时,广芯电子还积极拥抱资本市场,成功登陆新三板,为公司的进一步发展注入了强劲的动力。

随着公司规模的扩大和业务的拓展,广芯电子逐渐在电子行业中树立了良好的口碑。公司先后获得了上海市“专精特新”企业称号和工信部“专精特新小巨人”企业称号,这是对广芯电子在技术创新和市场竞争力方面的充分认可。

如今,广芯电子已经成为电子行业中不可或缺的一员。公司不仅在国内市场占据了一席之地,还积极拓展海外市场,与多家国际知名企业建立了紧密的合作关系。未来,广芯电子将继续秉持着创新、务实、高效的企业精神,不断推动电子行业的发展,为人类社会的进步贡献自己的力量。


若您想要探索更多内容,随时可以继续输入。

HIT(日立)公司的发展小趣事
对于可能产生热量的元件(如可控硅),应采取适当的散热措施,防止元件过热损坏。
厦门法拉(faratronic)公司的发展小趣事

随着电子技术的飞速发展,FMI公司紧跟时代步伐,不断研发新技术和新产品。在1992年,FMI成功将频率管理扩展到OEM市场,进一步拓宽了其业务范围。这一举措不仅增强了公司的市场竞争力,还为公司带来了更多的商业机会。通过为计算机外设、工业仪器、局域网/广域网等多个领域提供定制化的频率控制解决方案,FMI逐渐成为了行业内的佼佼者。

Good Will Instrument Co., Ltd.公司的发展小趣事

FMI公司成立于1971年,作为标准通信公司的受控供应商,公司自成立之初便专注于为通信市场提供快速交货和严格公差的石英晶体及晶体振荡器。在成立初期,FMI面临着市场竞争激烈和技术挑战的双重压力,但公司凭借其卓越的产品质量和快速响应客户需求的能力,逐渐在行业中站稳脚跟。通过不断的技术创新和产品优化,FMI逐渐扩大了其市场份额,为后续的快速发展奠定了坚实基础。

ECI公司的发展小趣事

面对日益激烈的市场竞争,ECI公司积极开拓国际市场。公司成立了专门的国际市场部,负责海外市场的调研、开发和推广。通过深入了解不同国家和地区的市场需求和文化差异,ECI公司成功推出了符合当地消费者需求的电子产品。同时,公司还与多家国际知名企业建立了长期稳定的合作关系,进一步扩大了市场份额。

ACI [Applied Concepts, Inc.]公司的发展小趣事

在环保意识日益增强的今天,ACI公司积极响应国家号召,将绿色环保理念融入产品设计和生产过程中。公司采用环保材料和生产工艺,推出了一系列绿色电子产品。这些产品不仅具有优异的性能,而且符合环保标准,得到了消费者的广泛认可。通过倡导绿色环保理念,ACI成功引领了行业潮流,树立了良好的企业形象。

问答坊 | AI 解惑

tms320vc5509的例程css3.3

tms320vc5509的例程css3.3 经过测试的…

查看全部问答>

钽电容封装及各种电阻电容封装说明

钽电容 长的话是+-0.2 ,宽是+-0.1 高 (MM) A 型的尺寸 3.2 X1.6 X1.6    俗称: A(3216) B 型的尺寸 3.5 X2.8 X1.9    俗称: B(3528) C 型的尺寸 6.0X 3.2X 2.6    俗称: C(6032) D 型的尺寸 7.3 X4.3 X2.9&nb ...…

查看全部问答>

eboot 下载 nk 出现错误

我用编译好的eboot 下载nk.bin ,老是出现Checksum failure on record , ABORT!!! ****** 不知道是什么原因? 是不是 cs8900a 不稳定造成的?我的平台S3C2440 + 64M NANDFLASH + 64M RAM wince5.0…

查看全部问答>

UNICODE_STRING问题。。。。

一段代码:        //创建设备名称         UNICODE_STRING devName;         RtlInitUnicodeString(&devName,L\"\\\\Device\\\\MyDDKDevice\");         ...…

查看全部问答>

终于可以踏上回家的行程,我兴奋啊!祝福兄弟姐妹们新年快乐!全家幸福!

终于可以踏上回家的行程,我兴奋啊!祝福兄弟姐妹们新年快乐!全家幸福!…

查看全部问答>

把kernel从vivi向u-boot移植的时候遇到问题了!

三星提供的kernel是for vivi 的,但俺想用u-boot来引导,结果移植上去之后,u-boot是跑起来了,但是引导kernel却出问题了 看了kernel的头部的二进制数据,发现kernel的格式竟然还和bootloader的类型有关,for vivi的kernel的头就是适合vivi,不 ...…

查看全部问答>

关于wince下MySqlParameter的一个问题

private void button1_Click(object sender, EventArgs e)         {             MySqlParameter[] paramter =            &nbs ...…

查看全部问答>

问个sdram的问题

对于sdram来说,当片选(CS#)为高时,数据线和地址线处于什么状态啊?好像不是高阻态。…

查看全部问答>

关于51单片机的地址设置

本人用的87c591,调试过程中存在这样的问题 (1)将变量地址设置到0x4000和0x4003,并且将一组数组设置到0x8000为起始地址,数组长度为245,如果设置为大模式,即xdata模式,将程序烧写进eeprom之后无法正常启动,其中寄存器的设置已经更改。 (2 ...…

查看全部问答>

Stellaris® MCU 的 Cortex 微控制器软件接口标准 (CMSIS):DSP 头文件

TI新出的资料 Stellaris® MCU 的 Cortex 微控制器软件接口标准 (CMSIS):DSP 头文件…

查看全部问答>