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

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

    关注

    5082

    文章

    19104

    浏览量

    304815
  • 无线通信
    +关注

    关注

    58

    文章

    4564

    浏览量

    143496
  • u-boot
    +关注

    关注

    0

    文章

    121

    浏览量

    38222
收藏 人收藏

    评论

    相关推荐

    新手怎么学嵌入式?

    。但面对这个复杂的领域,很多人可能会感到迷茫,不知从何处入手。别担心,本文将为你提供一些入门学习嵌入式技术的建议。 新手入门学习嵌入式技术的途径 1. 了解基础知识 首先,要对嵌入式系统
    发表于 12-12 10:51

    如何在Petalinux下Patch u-boot源码

    在软件开发过程中我们经常遇到用 Patch 来传递和更新代码的场景。本文以一个端到端的例子来演示在 Petalinux 使用过程中,如何给 u-boot 的源码生成 Patch 并在 Petalinux 中编译。
    的头像 发表于 12-04 16:26 990次阅读
    如何在Petalinux下Patch <b class='flag-5'>u-boot</b>源码

    【北京迅为】i.mx8mm嵌入式linux开发指南第四篇 嵌入式Linux系统移植篇第六十九章uboot移植

    【北京迅为】i.mx8mm嵌入式linux开发指南第四篇 嵌入式Linux系统移植篇第六十九章uboot移植
    的头像 发表于 10-22 14:46 593次阅读
    【北京迅为】i.mx8mm<b class='flag-5'>嵌入式</b>linux开发指南第四篇 <b class='flag-5'>嵌入式</b>Linux<b class='flag-5'>系统</b><b class='flag-5'>移植</b>篇第六十九章uboot<b class='flag-5'>移植</b>

    七大嵌入式GUI盘点

    嵌入式图形用户界面(GUI)是一种为嵌入式系统设计的用户界面,它可以让用户通过图形化的方式与设备进行交互。以下是对七种嵌入式 GUI 的盘点。 emWin 由德国SEGGER公司
    发表于 09-02 10:58

    深度学习算法在嵌入式平台上的部署

    随着人工智能技术的飞速发展,深度学习算法在各个领域的应用日益广泛。然而,将深度学习算法部署到资源受限的嵌入式平台上,仍然是一个具有挑战性的任务。本文将从嵌入式平台的特点、
    的头像 发表于 07-15 10:03 1331次阅读

    飞凌全志T527开发板U-Boot添加自定义菜单

    调起菜单 U-Boot的入口程序文件是 /common/main.c,入口函数main_loop(): /* <u-boot>/common/main.c
    发表于 07-15 09:42

    嵌入式系统怎么学?

    C++或者Python。这些语言在嵌入式系统开发中都被广泛应用。 3、微处理器/微控制器架构:学习常见的微处理器和微控制器架构,如ARM、AVR、PIC等,了解其特性和应用场景。
    发表于 07-02 10:10

    嵌入式学习-飞凌嵌入式ElfBoard ELF 1板卡-如何移植NCNN?

    在计算机视觉和深度学习领域,NCNN(Netural Network Computer Vision)是一个轻量级的神经网络计算框架,被广泛应用于各类嵌入式设备和移动平台。今天,让我们一同跟随共创
    发表于 05-29 17:24

    再谈嵌入式实时操作系统

    程序的可移植性得到了增强,系统开发的工作量减轻的同时也提高了开发效率。对实时性和可靠性日益增长的要求正在塑造某些现代领域的嵌入式实时操作系统的发展方向,例如航空航天、工业控制、汽车电子
    的头像 发表于 04-09 17:27 787次阅读
    再谈<b class='flag-5'>嵌入式</b>实时操作<b class='flag-5'>系统</b>

    如何成为一名嵌入式C语言高手?

    如何成为一名嵌入式C语言高手? 嵌入式系统是当今科技领域的核心,而C语言则是嵌入式
    发表于 04-07 16:03

    瑞萨CTSU程序在向嵌入式OS操作系统移植时的注意事项

    瑞萨CTSU程序在向嵌入式OS操作系统移植时的注意事项
    的头像 发表于 03-29 08:05 348次阅读
    瑞萨CTSU程序在向<b class='flag-5'>嵌入式</b>OS操作<b class='flag-5'>系统</b><b class='flag-5'>移植</b>时的注意事项

    如何成为一名嵌入式C语言高手?

    如何成为一名嵌入式C语言高手? 嵌入式系统是当今科技领域的核心,而C语言则是嵌入式
    发表于 03-25 14:12

    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

    请问ADuC7060能否移植uCOS II嵌入式操作系统

    我想问一下ADuC7060能否移植uCOS II嵌入式操作系统
    发表于 01-15 06:59

    s3c2410中断控制模块的中断源状态寄存器是?

    S3C2410是一款由三星电子公司设计的具有多种功能的嵌入式处理器。其中的中断控制模块用于管理系统的中断请求和中断服务程序。在S3C2410中,中断源状态寄存器是用来标识当前正在发生的
    的头像 发表于 01-05 17:28 716次阅读