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

发布者:sky0001最新更新时间:2023-01-11 来源: elecfans关键字:S3C2410开发板  U-BOOT  移植 手机看文章 扫描二维码
随时随地手机看文章

引言

随着嵌入式系统的日趋复杂,它对大容量数据存储的需求越来越紧迫。而嵌入式设备低功耗、小体积以及低成本的要求,使硬盘无法得到广泛的应用。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在嵌入式系统中运行良好。


关键字:S3C2410开发板  U-BOOT  移植 引用地址:基于S3C2410开发板的U-BOOT移植解决方案

上一篇:U-boot在S3C2440上的移植详解(五)
下一篇:关于S3C2440的Ethercat实时

推荐阅读最新更新时间:2024-11-04 19:29

Linux2.6.22内核移植
平台:mini2440 交叉工具链:arm-linux-gcc-4.3.2 一、内核移植基本知识 移植内核也叫构建BSP(boardsupprot packet)。BSP的作用有两个:一是为内核运行提供底层支持,二是屏蔽与板相关的细节。 BSP的构建分三个层次 1、体系结构层次 对一些体系结提供linux内核支持,比如说ARM,X86等芯片。这一类工作一般在arc/xxx/下面额除了palt-xxx和mach-xxx目录的其他目录完成。 2、SOC层次 对一些公司提供的SOC微处理器提供linux内核支持,比如说三星
[单片机]
Ubuntu下移植内核到OK6410开发板
环境:Win7+virsualBox+ubuntu12.04+ok6410开发板 一,下载源码:我这里下载的版本是--linux-3.12.7 http://www.kernel.org/ 二,解压内核: tar -xvf linux-3.12.7-tar.xz 三,更改权限(最好赋予全部权限) sudo chmod -R 777 linux-3.12.7/* 四,修改源码(针对基于smdk6410架构的ok6410开发板) 1,在arch/arm/mach-s3c64xx/目录下的mach-smdk6410.c 复制一份在当前文件下命名为mach-ok6410.c wu@wu-VirtualBox:/opt
[单片机]
Ubuntu下<font color='red'>移植</font>内核到OK6410<font color='red'>开发板</font>
U-Boot-2009-03移植笔记(第二阶段:时钟!)
根据U-Boot-2009-03移植笔记(第二阶段移植准备)最后的总结,需要针对S3C2440来移植时钟初始化的代码。 在lib_arm/board.c中,个init_sequence数组,定义了所有的初始化函数指针。 时钟的驱动,在函数board_init中,位于board/xinna2440/xinna2440.c,我们这里只支持S3C2440,删除文件头部的时钟参数宏定义,直接改为 1 #define FCLK_SPEED 1 2 3 #define M_MDIV 0x7f 4 #define M_PDIV 0x2 5 #define M_SDIV 0x1 6 7 #define USB_CLO
[单片机]
U-Boot-2009-03<font color='red'>移植</font>笔记(第二阶段:时钟!)
不增加成本的32位移植设计
  一个8位的或者16位的CPU或许能够满足你当前的应用需求。但是为了保持竞争力,你必须对你的产品做出持续不断地改进,包括你要不断的增加它的新特性、不断地提升它的速度,并在提升它规格的同时降低成本。如果你不做这些,而你的竞争对手在做,你将被甩开。   保持竞争优势的一个方法是通过逐步改善你现有的设计。但随着时间的推移,架构的限制可能会是这个过程变得越来越缓慢,成本也越来越高。因此你可以将你的设计移植到32为平台,这会提升你产品在以下几个方面的性能。        表1:移植到32位平台的优势   你真的需要将你的产品移植到32位平台吗?   当你把产品重一个8位的CPU移植到一个32位的CPU上面的时候,有几点时一定要考虑的。首
[电源管理]
不增加成本的32位<font color='red'>移植</font>设计
uC/OS-II在EP7312上的移植
摘要:首先介绍μC/OS-II操作系统的特点,重点分析μC/OS-II在EP7312上的移植方法,介绍μC/OS-II在EP7312中的开发过程。 关键词:嵌入式操作系统 μC/OS-II EP7312 引 言   随着Internet和后PC时代的到来,嵌入式系统的应用愈来愈广泛,嵌入式产品在人们的生活中无处不在。今天,嵌入式系统带来的工业年产值已超过1万亿美元,已经在IT产业中占有很大的比重。   通常,应用程序对嵌入式软件的基本要求是体积小、执行速度快、具有较好的裁减性和可移植性。嵌入式软件的灵魂是嵌入式操作系统。在特定的操作系统之上开发应用软件,可以让程序开发人员屏蔽掉很多低层硬件细节,使得应用程序调试方便、移植简
[应用]
u-boot-2009.08在mini2440上的移植(七)---增加LCD显示功能
移植环境 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
[单片机]
u-boot-2009.08在mini2440上的<font color='red'>移植</font>(七)---增加LCD显示功能
at91sam9260 OpenWRT u-boot移植
1. 直接在make menuconfig中选择编译at91sam9260ek平台的u-boot,烧写到开发板后效果 **U-Boot 2010.06-dirty (Jun 28 2017 - 09:14:34) DRAM: 64 MiB NAND: 1024 MiB *** Warning - bad CRC, using default environment In: serial Out: serial Err: serial Net: macb0 macb0: Starting autonegotiation...** ==警告,u-boot环境变量校验失败,并且一段时间后启动重启(怀疑看门狗打开,但没
[单片机]
STM32移植lwip之建立tcp客户端
本篇目标:在之前能ping通pc机的工程基础上搭建tcp客户端,并可以主动发数据给pc机,同时也能与pc机收发数据,并在网络调试工具上显示 材料准备: 基础工程:修改后能ping通pc机的工程( STM32官方移植lwip修改代码 ) 调试工具:用来调试tcp连接下的数据接收( 网络调试助手 ) 搭建工程:最终搭建好tcp客户端数据接收的工程( tcp客户端建立工程 ) 搭建TCP客户端 搭建TCP客户端的过程与上一章TCP服务器也相似,所以尽量把重点的地方加粗显示来区别 在搭建TCP客户端之前可以先理一下概念,客户端与服务器的区别: 客户端:主动建立tcp去连接目标IP 服务器:拥有静态IP,能让其他设备被动连接
[单片机]
小广播
设计资源 培训 开发板 精华推荐

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

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

换一换 更多 相关热搜器件
随便看看

 
EEWorld订阅号

 
EEWorld服务号

 
汽车开发圈

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