u-boot(三)启动文件

目录

  • u-boot(三)启动文件

    • 汇编
    • C:_start_armboot
      • 代码摘要
    • C:main_loop
      • 内核启动
      • 菜单处理(自定义实现)
      • 命令处理


title: u-boot(三)启动文件

tags: linux

date: 2018-09-24 20:56:05

---

u-boot(三)启动文件

汇编

cpu/arm920t/start.S

u-boot也是一个牛逼的单片机程序,所以也就需要:

  1. 硬件相关初始化

    1. 看门狗
    2. 时钟
    3. sdram
    4. nand copy程序
  2. 设置sp
  3. 接下去就是读取内核,启动内核等

程序实际的步骤是:

1.set the cpu to SVC32 mode
2.turn off the watchdog
3.mask all IRQs
4.判断是不是从内部ram启动还是仿真直接烧写到链接地址,如果不在正确的加载地址的话,执行cpu_init_crit
  cpu_init_crit执行SDRAM初始化
    flush v4 I/D caches,
    disable MMU stuff and caches,
    lowlevel_init 这个会去初始化sdram,这个函数在lowlevel_init.S in your board directory
                    也就是board\100ask24x0\lowlevel_init.S
5.Set up the stack
6.clock_init        board\100ask24x0\boot_init.c
7.relocate           自动识别当前是nor还是nand启动,nand启动时自动cp到内部ram中运行,所以可写
8.bss段清零
9.调用C函数 _start_armboot

堆栈设置如下

0x33F80000 uboot程序
·=-CFG_MALLOC_LEN malloc area
.=-CFG_GBL_DATA_SIZE bdinfo
.=-CONFIG_STACKSIZE_IRQ IRQ 的栈
.=-CONFIG_STACKSIZE_FIQ FRQ的栈
.=-12 leave 3 words for abort-stack
sp的初始位置

内存图:

C:_start_armboot

文件路径:lib_arm\board.c,这里就是u-boot执行C代码的地方了.

  • 分配了一个gd的结构体内存

    gd = (gd_t*)(_armboot_start - CFG_MALLOC_LEN - sizeof(gd_t));
    
    //在这里,_armboot_start=_start,根据链接脚本,这也就是代码段的起始=0x33F80000
    //也就是指向了内存图128的地方了
  • init_sequence这里执行一些初始化
    • board_init中设置了gd->bd->bi_arch_number = MACH_TYPE_S3C2440;,设置了一个参数gd->bd->bi_boot_params = 0x30000100;这个就是启动内核参数的地址
  • flash/nand 初始化
  • 堆栈初始化
  • 环境变量的设置存储(一种是代码写死,一种在FLASH上保存)
  • 进入主循环main_loop

代码摘要

void start_armboot (void)
{
//-----
    /* Pointer is writable since we allocated a register for it */
    gd = (gd_t*)(_armboot_start - CFG_MALLOC_LEN - sizeof(gd_t));
//-----
    //函数指针,初始化设备
    for (init_fnc_ptr = init_sequence; *init_fnc_ptr; ++init_fnc_ptr) {
        if ((*init_fnc_ptr)() != 0) {
            hang ();
        }
    }
//----  flash初始化,识别
#ifndef CFG_NO_FLASH
    /* configure available FLASH banks */
    size = flash_init ();
    display_flash_config (size);
#endif /* CFG_NO_FLASH */
////----  nand初始化
#if (CONFIG_COMMANDS & CFG_CMD_NAND)
    puts ("NAND:  ");
    nand_init();        /* go init the NAND */
#endif
//------
    //分配堆
    /* armboot_start is defined in the board-specific linker script */
    mem_malloc_init (_armboot_start - CFG_MALLOC_LEN);
//-----
    //uboot的环境变量
    /* initialize environment */
    env_relocate ();
//-----
    //经过一系列的初始化
    /* main_loop() can return to retry autoboot, if so just run it again. */
    for (;;) {
        main_loop ();

}

init_fnc_t *init_sequence[] = {
    cpu_init,       /* basic cpu dependent setup */
    board_init,     /* basic board dependent setup */
    interrupt_init,     /* set up exceptions */
    env_init,       /* initialize environment */
    init_baudrate,      /* initialze baudrate settings */
    serial_init,        /* serial communications setup */
    console_init_f,     /* stage 1 init of console */
    display_banner,     /* say that we are here */
#if defined(CONFIG_DISPLAY_CPUINFO)
    print_cpuinfo,      /* display cpu info (and speed) */
#endif
#if defined(CONFIG_DISPLAY_BOARDINFO)
    checkboard,     /* display board info */
#endif
    dram_init,      /* configure available RAM banks */
    display_dram_config,
    NULL,
};

int board_init (void)
{
    ---
    /* support both of S3C2410 and S3C2440, by www.100ask.net */
    if (isS3C2410)
    {
        /* arch number of SMDK2410-Board */
        gd->bd->bi_arch_number = MACH_TYPE_SMDK2410;
    }
    else
    {
        /* arch number of SMDK2440-Board */
        gd->bd->bi_arch_number = MACH_TYPE_S3C2440;
    }

    /* adress of boot parameters */
    gd->bd->bi_boot_params = 0x30000100;

}

C:main_loop

common/main.c

内核启动

这里实现了u-boot的倒计时,有打印命令,获取环境变量等,最关键的代码是

s = getenv ("bootcmd");
if(倒计时结束)
{
    printf("Booting Linux ...\n");
    run_command (s, 0);
 }

实际的环境变量是bootcmd=nand read.jffs2 0x30007FC0 kernel; bootm 0x30007FC0,读取内核,启动内核

菜单处理(自定义实现)

如果倒计时结束前输入了空格,进入命令模式run_command("menu", 0);

命令处理

  1. 死循环
  2. 读取串口输入len = readline (CFG_PROMPT);
  3. 执行命令rc = run_command (lastcommand, flag);

原文地址:https://www.cnblogs.com/zongzi10010/p/10023676.html

时间: 2024-10-12 19:33:54

u-boot(三)启动文件的相关文章

启动bash shell的三种方式下,检查的启动文件

启动bash shell的三种方式 1.登录时当做默认登录shell 2.作为非登录shell的交互式shell 3.作为运行脚本的非交互shell 一.登录shell 登录Linux系统时,bash shell会作为登录shell启动,登录shell会从4个不同的启动文件里读取命令,下面是bash shell处理这些文件的次序: 1./etc/profile 2.$HOME/.bash_profile 3.$HOME/.bash_login 4.$HOME/.profile 其中/etc/pr

WIN7删除多余的启动选项:boot.ini这个文件已经取消了

win7里面根本没有boot.ini文件,可以在开始的搜索栏中输入cmd,然后右键以管理员身份运行,然后输入bcdedit,我的情况如下. 看到***的字了吗,这就是grub4dos的启动文件的信息,右键点标记并框下标识符后,右键点一下就复制了,留作下面的步骤用,我的是{df12b00e-989e-11df-8bd6-002622e06f8a}. 然后再输入bcdedit /delete {ID},ID就是你上面复制的标识符.重启一下,应该直接进入win7了,没有选择的界面了. bcdedit

springboot2.0入门(八)-- profile启动文件配置

一.不同环境使用不同配置文件 复制多份配置文件,修改不同的端口,在application.yml文件中添加具体启动的配置文件,可以看到不同的启动端口,使用maven的打包命令,将项目打入jar包: <!-- 跳打包test文件报错--> <plugin> <groupId>org.apache.maven.plugins</groupId> <artifactId>maven-surefire-plugin</artifactId>

u-boot start.S启动文件分析

u-boot start.S启动文件分析 u-bootstart.SBL1 u-boot start.S启动文件分析 一.start.S来源 1.为何要分析start.S 2.start.S的来源 3.头文件包含 二.start.S分析 1.Start.S分析 16字节校验头 异常向量表 16字节内存对齐 设置CPU为SVC模式 L2 cache操作 Invalidate L1 I/D 关掉MMU 读取启动引脚信息 第一次设置栈 ./board/samsung/x210/lowlevel_ini

spring boot应用启动原理分析

spring boot quick start 在spring boot里,很吸引人的一个特性是可以直接把应用打包成为一个jar/war,然后这个jar/war是可以直接启动的,不需要另外配置一个Web Server. 如果之前没有使用过spring boot可以通过下面的demo来感受下. 下面以这个工程为例,演示如何启动Spring boot项目: git clone [email protected]:hengyunabc/spring-boot-demo.git mvn spring-b

(转)认识oracle中的sqlnet.ora tnsnames.ora listener.ora三个文件

概述 在oracle安装目录$HOME/network/admin下,,经常看到sqlnet.ora tnsnames.ora listener.ora这三个文件,除了tnsnames.ora,其他两个文件详细的用途很多人都不太了解.sqlnet.ora 用在oracle client端,用于配置连接服务端oracle的相关参数. tnsnames.ora 用在oracle client端,用户配置连接数据库的别名参数,就像系统中的hosts文件一样.listener.ora 用在oracle

个人电脑修复小记——windows10系统bcd启动文件重做

问题:更新时强制关闭系统,导致系统崩溃,\EFI\Microsoft\boot\BCD文件丢失. 解决办法:在ESP分区中,将zh-CN的bootmgfw.efi文件复制到\efi\boot\中.重命名为bootx64.efi 使用bootice软件,在efp分区中的\efi\microsoft\boot\文件夹下建立bcd文件 编辑文件,指定磁盘为系统分区(非esp分区),制定启动文件为\windows\system32\winload.efi(注意:efi文件,非exe文件) 保存.退出.重

第14章 启动文件详解—零死角玩转STM32-F429系列

第14章     启动文件详解 全套200集视频教程和1000页PDF教程请到秉火论坛下载:www.firebbs.cn 野火视频教程优酷观看网址:http://i.youku.com/firege 本章参考资料<STM32F4xx 中文参考手册>第十章-中断和事件:表 46. STM32F42xxx 和 STM32F43xxx 的向量表:MDK中的帮助手册—ARM Development Tools:用来查询ARM的汇编指令和编译器相关的指令. 14.1 启动文件简介 启动文件由汇编编写,是

oracle的listener.ora sqlnet.ora tnsnames.ora三个文件的关联性

学习:http://www.cnblogs.com/william-lee/archive/2010/10/20/1856261.html 之前因为安装的是windows server 2008 r2的系统,oracle是11g r2 64bit,因为像很多网友一样,无法使用pl/sql developer 8连接oracle,今天可算连上了,对listener.ora sqlnet.ora tnsnames.ora三个文件.TNSListener服务的认识也深了一层. 先说说我是怎么样连接上的