ARMv7架构U-boot 启动流程分析

本文深入分析了ARMv7架构下的U-boot启动流程,从u-boot-spl.lds链接文件入手,揭示了程序的入口地址在arch/arm/cpu/armv7/start.S中。启动过程中,board_init_f和board_init_r函数数组通过initcall_run_list()的for循环执行各种硬件初始化函数,确保系统顺利启动。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

首先分析 u-boot-spl.lds 链接文件 该文件决定了一个可执行程序的各个段的存储位置 及入口地址

文件内容如下:

MEMORY {
    .sram : ORIGIN = CONFIG_SPL_TEXT_BASE,\
        LENGTH = CONFIG_SPL_MAX_SIZE }
MEMORY {
    .sdram : ORIGIN = CONFIG_SPL_BSS_START_ADDR, \
        LENGTH = CONFIG_SPL_BSS_MAX_SIZE }
/* 内存分配 起始地址 和长度 */

OUTPUT_FORMAT("elf32-littlearm", "elf32-littlearm", "elf32-littlearm")
/* 定义输出文件格式为elf 32位 小端模式 */
OUTPUT_ARCH(arm)
/* 文件可用平台为ARM */
ENTRY(_start)
/* 文件入口 */
SECTIONS
{
   
    .text      :
    {
   
        __start = .;
        arch/arm/cpu/armv7/start.o    (.text)
        *(.text*)
    } > .sram
    /* 代码段 存储在SRAM中  具体的入口程序在文件arch/arm/cpu/armv7/start.S中  */

    . = ALIGN(4);
    .rodata : {
    *(SORT_BY_ALIGNMENT(.rodata*)) } >.sram
    /* 4字节对齐 只读数据段 存储在SRAM中 */

    . = ALIGN(4);
    .data : {
    *
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值