0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

深度解读S3C2410A的嵌入式系统的U-Boot移植

电子工程师 来源:现代电子技术 作者:丁小俊 2021-05-05 17:45 次阅读

0 引 言

ARM嵌入式处理器已被广泛应用于消费电子产品无线通信网络通信工业控制等领域。其中,ARM9的芯片更是以其低价格、低功耗、高性能在手持设备中占据着重要市场。在嵌入式操作系统中,LinuxVxworks,WinCE三足鼎立,其中Linux由于其开源性、稳定性、安全性、可裁减性更是一支独放。在嵌入式系统中,如何实现在ARM9平台下Linux操作系统的引导工作是嵌入式技术开发的重要环节。

1 嵌入式系统的软件组成

1.1 系统的软件组成

嵌入式的软件系统主要由Bootloader、操作系统、文件系统、应用程序等组成。其中,Bootloader是介于硬件和操作系统之间的一层,其作用就好像PC机中的BIOS。系统加电运行后,由系统自动加载。通过这段程序,可以初始化硬件设备,建立内存空间的映射图,从而将系统的硬件环境带到一个合适的状态,以便为最终调用操作系统内核准备好环境。对于一个嵌入式系统,通常BootLoader是依赖于硬件而实现的。对于不同类型的嵌入式芯片、不同的操作系统和外围接口都需要重新移植、修改和编译Bootloader。

1.2 U-Boot分析

嵌入式Linux系统中常用的Bootloader引导程序有U-Boot,redboot,blob和vivi等,其中U-Boot遵循GPL条款的开放源码项目,功能最为强大;U-Boot对PowerPC系列处理器支持最丰富,同时还支持MIPS,x86,ARM,Nios,XScale等诸多常用系列的处理器;U-Boot引导程序分为Stage 1和Stage 2两大部分,Stage 1中主要包括设备初始化、中断设置、时钟设置和存储器初始化等工作,并且采用汇编语言实现,而一些通用功能大多采用C语言实现,放在Stage 2中。

2 U-Boot的启动分析

Stage 1的代码在CPU/arm920t/start.s中定义,它包括从系统上电后在0x00000000地址开始执行的部分。这部分代码系统启动后,从NAND FLASH自动加载到SDRAM中,它包括对S3C2410A中寄存器的初始化和将U-Boot的Stage 2代码从FLASH拷贝到SDRAM。Stage 2的起始地址是在Stage1代码中指定的。被复制到SDRAM后,就从第一阶段跳到这个入口地址,开始执行剩余部分代码。第二阶段主要是对内存的分配,对NAND FLASH以及对外围设备的初始化,其代码在lib-arm/board.C中。启动的流程分析如图1所示。

pIYBAGB1aliAESuvAABYoeFqfI8363.png

(1)跳转到C语言程序之后,首先定义初始化函数表,程序在lib-arm/board.e中,如下所示:

o4YBAGB1amqAaI7xAACXumMCR_0447.png

(2)初始化FLASH设备和显示FLASH设备信息

(3)初始化系统内存分配函数;

(4)如果目标系统拥有NAND设备,则初始化NAND设备;

(5)初始化显示设备;

(6)初始化网络设备,填写IP地址、MAC地址等信息;

(7)开启中断处理;

(8)进入命令循环,接收用户从串口的命令输入。

3 U-Boot的移植方法

本文选用交叉编译环境arm-linux-gcc-2.95.3,选用U-Boot-1.1.4版本作为移植平台。为了使U-Boot支持新的开发板,一种简便的做法是在U-Boot已经支持的开发板中选择一种与目标板接近的,在其基础上进行修改。这里选用的是smdk2410的配置。

3.1 修改cpu/arm920t/start.S文件

Start.s是采用汇编语言编写的U-Boot程序入口代码,完成对底层硬件的初始化,其中有一个很重要的功能是从NAND FLASH中把Stage 2阶段的代码复制到SDRAM中。在此阶段,涉及到对NANDFLASH的读操作,在U-Boot中,没有对NANDFLASH读操作的驱动,采用以下方法实现:

pIYBAGB1apuAdZ9dAABqd2lZsyg313.png

通过调用board/smdk2410/nand_read.C中的nand_read_11函数将Stage 2阶段的代码复制到ram中。

3.2 修改board/smdk2410目录下文件

(1)增加对NANDFLASH的读驱动nand_read.c

o4YBAGB1asiAPKbKAADjA2rQaSI613.png

(2)在smdk2410.C文件中添加对NANDFLASH初始化的程序

在此主要是对主板的GPIO的一些设置,并加上对NANDFLASH初始化程序。

o4YBAGB1awKAP5VmAAB0Cdw32VA388.png

pIYBAGB1axSAf55yAADhJCx3cEQ657.png

(3)在该目录下的Makefile文件中添加nand_read.C文件的编译

OBJS:=smdk24 10.o FLASH.o nand_read.o

3.3 在include文件中设置NAND FLASH硬件参数

在/linux/mtd/nand_ids.h中设置参数:

pIYBAGB1a0iAV6JYAAAyIvA0qbc179.png

3.4 编译与运行

配置好以后,进入U-Boot主目录,重新编译U-Boot代码,运行命令:

(1)查看交叉编译器的版本号

arm-linux-gcc-v

(2)清除生成的连接

Make distclean

(3)编译make smdk2410_config

(4)make CROSS-COMPILE=arm-linux-编译成功后,将生成三个文件:

u-boot:ELF格式的文件,可以被大多数Debug程序识别。

u-boot.bin:二进制bin文件,纯碎的U-Boot二进制执行代码,不保存ELF格式和调试信息。这个文件用于烧到用户的开发板中。

u-boot.srec:Motorola S-Record格式,可以通过串口下载到开发板中。

将得到的u-boot.bin文件借助于FLASH芯片烧写工具,通过JTAG口下载到目标板后,检查U-Boot能否正常工作。如果能从串口输出正确的启动信息,就表明移植基本成功。

4 结 语

目前笔者移植的U-Boot已经能稳定地运行在开发板上。U-Boot引导程序是嵌入式Linux系统软件开发中的一个重要环节。在此通过分析U-Boot的代码结构和启动过程,并针对开发板系统的硬件资源,通过分析与调试,实现了U-Boot的移植,并且能够引导嵌入式Linux内核和文件系统,为今后进一步开发奠定了坚实的基础。

编辑:jq

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 嵌入式
    +关注

    关注

    4983

    文章

    18286

    浏览量

    288509
  • 无线通信
    +关注

    关注

    56

    文章

    4198

    浏览量

    142345
  • u-boot
    +关注

    关注

    0

    文章

    116

    浏览量

    38044
收藏 人收藏

    评论

    相关推荐

    STM32MP135移植U-Boot 2022.10-stm32mp-r1提示No serial driver found的原因?

    STM32MP135移植U-Boot 2022.10-stm32mp-r1提示No serial driver found
    发表于 03-11 08:13

    【米尔-TIAM62开发板-接替335x-试用评测】+(二)配置U-Boot步骤实战

    科技有限公司茜茜的周日及时回复和帮助!感谢深圳市米尔科技有限公司提供的技术支持与帮助! 谢谢! 在嵌入式系统开发的过程中,理解并正确配置U-Boot是非常重要的一步。U-Boot,全称
    发表于 11-13 12:36

    简单讲讲u-boot和bootloader有啥区别

    嵌入式软件开发,掌握u-boot 和 bootloader应该是必备的技能之一,但很多工程师依然不知道它们到底是啥。
    的头像 发表于 11-09 12:24 423次阅读

    S3C2410A存储控制器中文数据手册

    S3C2410A的存储器控制器提供访问外部存储器所需要的存储器控制信号。S3C2410A的存储器控制器有以下的特性。
    发表于 10-20 16:12 2次下载
    <b class='flag-5'>S3C2410A</b>存储控制器中文数据手册

    基于S3C2410A嵌入式织物密度检测装置研究

    电子发烧友网站提供《基于S3C2410A嵌入式织物密度检测装置研究.pdf》资料免费下载
    发表于 10-19 10:36 1次下载
    基于<b class='flag-5'>S3C2410A</b>的<b class='flag-5'>嵌入式</b>织物密度检测装置研究

    S3C2410嵌入式系统多串口通讯设计

    电子发烧友网站提供《S3C2410嵌入式系统多串口通讯设计.pdf》资料免费下载
    发表于 10-13 09:16 0次下载
    S3C<b class='flag-5'>2410</b><b class='flag-5'>嵌入式</b><b class='flag-5'>系统</b>多串口通讯设计

    SS524V100 单板移植和烧写U-boot(一)

    SS524V100单板的Bootloader采用U-boot,。当选用的外围芯片的型号与单板上外围芯片的型号不同时,需要修改U-boot配置文件,本文主要介绍了U-boot移植与烧写
    的头像 发表于 08-22 10:31 391次阅读

    U-boot的执行流程

    本文主要讲述了U-boot的执行流程。
    发表于 07-14 16:58 468次阅读
    <b class='flag-5'>U-boot</b>的执行流程

    U-boot的基本介绍

    从本文开始,将陆续推送“手把手教你移植U-boot”系列文章,目标是由浅入深地讲解U-boot的工作流程、原理、配置方法和移植方法,手把手教你完成U
    发表于 07-14 16:52 1494次阅读
    <b class='flag-5'>U-boot</b>的基本介绍

    imx6ull开发板u-boot下网络部分的移植和调试

    今天给大家讲一讲如何将u-boot网络部分的移植和调试。
    发表于 07-12 15:11 1189次阅读
    imx6ull开发板<b class='flag-5'>u-boot</b>下网络部分的<b class='flag-5'>移植</b>和调试

    U-boot的DPU驱动移植方法

    U-boot的VIDEO驱动子系统集成了ARM Mali系列显示处理器的驱动,支持Mali-DP500、Mali-DP550和Mali-DP650显示处理器,驱动源码位于目录./drivers/video。
    的头像 发表于 06-09 14:35 790次阅读
    <b class='flag-5'>U-boot</b>的DPU驱动<b class='flag-5'>移植</b>方法

    基于armv8架构来对u-boot进行启动流程分析

    首先引用wiki上的简介:u-boot 是一个主要用于嵌入式系统的引导加载程序,可以支持多种不同的计算机系统结构。
    发表于 06-09 09:39 413次阅读
    基于armv8架构来对<b class='flag-5'>u-boot</b>进行启动流程分析

    简单讲讲u-boot和bootloader的内容以及区别

    嵌入式软件工程师都听说过 u-boot 和 bootloader,但很多工程师依然不知道他们到底是啥。
    的头像 发表于 06-06 10:01 1059次阅读

    如何用usb命令编译u-boot的文档?

    我想在s32g2的u-boot中使用usb命令,但是s32g2的u-boot中没有usb命令。 有编译好的u-boot可以解决这个问题吗?或
    发表于 06-05 09:28

    有没有办法恢复默认的u-boot环境?比如恢复出厂设置?

    BuildInfo: - ATF f1d7187 - U-Boot 2020.04-00022-g332c0bf3 switch to partitions #0, OK mmc2(part 0
    发表于 05-16 06:46