uboot第一阶段关键位置分析】的更多相关文章

/* * the actual reset code */ reset: /* * set the cpu to SVC32 mode */ mrs r0,cpsr bic r0,r0,#0x1f orr r0,r0,#0xd3 msr cpsr,r0 为什么一来需要把cpu 设置成svc管理模式? usr模式,此模式不可以直接访问板子的硬件资源,而uboot初始化,必须要去访问此类资源,所以不可以设置为usr模式. svc模式属于特权模式,可以访问所有硬件受控资源.相对于其他的模式,SVC模式…
U-boot的启动一般分为两个阶段,现在我们先将第一阶段. 在此之前,我们先了解一下uboot的目录结构,各个文件夹是什么作用. 如果连各个文件夹是干什么的都不清楚就开始移植剪裁,势必会和我刚拿到开发板时对着uboot一脸懵逼的情景一样. 所以,我们先看uboot文件夹到底包含了哪些内容: Board:存放和开发板有关的文件. U-boot 支持的每个开发板的文件,都会以子目录的形式存放在 baord 目录下.比如我们关注的 2440 开发板,与之最相近的目录,便是 SMDK2410 文件夹.或…
嵌入式Linux系统从软件角度通常可以分为以下4个层次: 引导加载程序 | Linux内核 | 文件系统 | 用户应用程序 嵌入式Linux系统中典型分区结构: 正常启动过程中,Bootloader首先运行,然后它将内核复制到内核中,并且在内存某个固定地址设置好要传递给内核的参数,最后运行内核.内核启动之后,它会挂接根文件系统,启动文件系统中的应用程序. 一.Bootloader的作用: CPU上电后,会从某个地址开始执行,对于ARM结构的CPU是从0x00000000开始,Bootloader…
作者:围补 本来启动方式这节不是什么复杂的事儿,不过想简单的说清楚明白,还真是不知道怎么组织.毕竟文字跟有声语言表达有别.但愿简单的东西别让我讲的太复杂! Arm板系统文件一般有三个——bootloader(uboot).kernel(uImage)及根文件系统(rootfs).在arm板上电后,按uboot->kernel->rootfs的顺序依次启动.由于开发板上有多种存储介质,三个文件可以放在任何可以存储的介质上,因此也就导致文件的多种启动方式.本文就来讨论,以上三个文件对应不通存放位置…
http://blog.csdn.net/xautfengzi/article/details/7470134 前段时间了看了UBoot的源码,放了一段时间之后忘得差不多了.现做一些注释,方便以后温习. 第一阶段代码主要位于start.S中,其流程如下: 1.设置中断向量表. 2.设置CPU为管理员模式. 3.禁狗. 4.关中断. 5.设置系统时钟. 6.跳至cpu_init_crit.(注意bl指令,bl指令是相对跳转,绝对跳转用mov lr,pc.由于此阶段代码是位置无关代码,所以在跳至的细…
1.启动过程特征总结(1)第一阶段为汇编阶段(start.s).第二阶段为C阶段(board.c中的start_armboot 函数)(2)第一阶段在SRAM中.第二阶段在DRAM中(3)第一阶段注重SoC内部.第二阶段注重SoC外部Board内部 2.移植时的注意点(1)x210_sd.h头文件中的宏定义(2)特定硬件的初始化函数位置(譬如网卡) start.s分析 主要功能分析 头文件包含 -28-启动代码的16字节头部占位 -49-()构建异常向量表 -58- ()设置CPU为SVC模式…
uboot执行"make smdk2410_config"之后就可以进行编译了,可以执行make命令进行编译, 因为整个输出太长,我仅仅列出部分最关键的输出(部分我不关心的内容直接用......代替): arm-linux-/arch/arm/cpu/u-boot.lds >u-boot.lds arm-linux-ld  -pie -T u-boot.lds -Bstatic -Ttext 0x0 $UNDEF_LST arch/arm/cpu/arm920t/start.o…
作者:围补 本来启动方式这节不是什么复杂的事儿,不过想简单的说清楚明白,还真是不知道怎么组织.毕竟文字跟有声语言表达有别.但愿简单的东西别让我讲的太复杂! Arm板系统文件一般有三个--bootloader(uboot).kernel(uImage)及根文件系统(rootfs).在arm板上电后,按uboot->kernel->rootfs的顺序依次启动.由于开发板上有多种存储介质,三个文件可以放在任何可以存储的介质上,因此也就导致文件的多种启动方式.本文就来讨论,以上三个文件对应不通存放位置…
目标板:2440开发板 u-boot启动的第一阶段是在文件start.S中完成的,这个过程对不同硬件平台的设置是不同的.下面进入start.S _start: b reset //跳转到reset //设置CPU为SVC32安全管理模式 reset: /* * set the cpu to SVC32 mode */ mrs r0,cpsr bic r0,r0,#0x1f orr r0,r0,#0xd3 msr cpsr,r0 //关闭看门狗 #if defined(CONFIG_S3C2400…
经过了上一篇的配置,我们已经执行make就可以编译出一个uboot.bin,但这还不够,首先,此时的uboot并不符合三星芯片对bootloader的格式要求,其次,此时的uboot.bin也没有结合我们的开发板进行配置,还无法使用.而要进行这样的个性化配置,前提条件就是对uboot开机流程和编译系统有所了解,本文主要讨论前者.uboot是一个两阶段bootloader,第一阶段主要做硬件直接相关的初始化,使用汇编编写;第二阶段主要为操作系统的运行准备环境,主要用C编写,这里以ARM平台为例分析…