三星S5PV210的启动

三星S5PV210的启动



ARM架构:

在这里插入图片描述

S5PV210架构示意图:

在这里插入图片描述

ARM公司的核心(类似PC机的北桥部分)

在这里插入图片描述

由半导体厂商设计的部分(相当于PC机的南桥)

在这里插入图片描述

arch/arm/cpu/armv7/start.S 中断与异常: 异常的优先级高于中断

S3C6410的启动机制:

在这里插入图片描述
上电后,6410会先起动iROM中的程序,该程序主要做两件事:

a、初始化时钟、看门狗等外围器件;

b、把flash或SD卡中前4K的内容(术语:BL1)加载到片内ram中去运行由于4K不是很大,这部分主
要完成对主存的初始化,然后把bootloader的大部(术语:BL2)加载到主存中并把程序的入口跳
转到BL2运行,BL2会把flash或SD卡中的OS的镜像(linux、Android)加载到主存中,在跳转到
OS的入口处继续运行,完成boot过程

U-boot被分为两个部分:

在这里插入图片描述
4K+200K ===> uboot.bin

uboot.bin会被烧到flash或SD卡中,当上电时iROM会把4K内容加载到SRAM当中该段程序会判断一
下当前程序是在静态RAM还是在动态RAM中,如果在静态RAM中,接下来会配置DDR主存,然后会把整
个bootloader加载到主存当中,跳到uboot入口执行,判断是在静态RAM还是在动态RAM中,如果在
静态RAM中,如果是在动态RAM中,跳到4K以后的地方运行bootloader的大部分内容,初始化相关
环境,把os加载到主存,跳转到OS的入口,起动内核。

S5PV210的起动过程:

在这里插入图片描述

如上图所示:芯片厂原本打算上电后,iROM把BL1加载到SRAM的BL1处,并把BL2加载到SRAM的BL2处, 对ADRAM初始化,并把OS加载到SDRAM中,但实际编译的Uboot大于96KB因此Uboot的制作者采取如下措 施:

uboot分为两部分:

在这里插入图片描述

ubootspl.bin(16k)(spl:second program loader)

			+

uboot.bin(210K)

上电后会把iROM会把16K的ubootspl.bin内容加载到SRAM,绕开BL2把210K的uboot.bin加载到主存中,uboot加载并起动内核

异常处理:

异常向量的地址映射:

由Arm手册可知,当异常发生后,会被映射到如下位置处

0x0000,0000 //该地址可以通过CP15的协处理器去配置 0xffff,0000
那么如何确定异常发生后,异常向量会在0x0000,0004的位置处?
在这里插入图片描述
由S5PV210的地址映射图可知,0x0000,0000是在片内的iROM中,是不能修改的,SPL镜像会被加载到BL1的地方,该地方的地址为0xD002,0000,即bl
reset 的指令地地址是0xD002,0010前一部分为校验和,ldr pc, XXXX
等指令会被放在0xD002,0014的位置,当发现异常后会跳转到0x0000,0004的地方(而非0xD002,0014).
异常向量和地址映射: 三星在内存中开辟了自己的异常向量表(Exception Vector
Table),所以当异常发生后会跳转到该位置,因此需要手工把异常向量表(即ldr pc,XXXX)拷贝到Exception Vector
Table处,这样异常发生后,就能跳转到相应的异常处理处进行异常处理了。 如果程序在片外的DDR中运行时的异常处理:

如 下图:

在这里插入图片描述

编译u-boot时会生成好多与u-boot相关的文件,
在这里插入图片描述
绿色的u-boot的组成:

start.S ====> start.o
board.c ====> board.o

|| || ===> 由链接器链接生成u-boot包含一些调试信息,段的信息,和
  常用命令: arm-linux-objdum -S u-boot //-S 显示原代码和汇编代码 arm-linux-objdum -S u-boot | less

在这里插入图片描述

ldr pc, undefinedinstruction
//把undefinedinstruction地址标号处的内容34800200放入PC指针 ldr pc,
undefinedinstruction 该指令是伪指令,编译器会将其转化为ldr pc, [pc, #20]
这样存取立即数20比较方便,当前指令的地址是34800004,PC指针的值为当前指令的地址加8即: PC = 34800004 + 0x08
= 3480000C PC 加立即数20 : 3480000C + 0x14 = 34800020

ARM 的流水线:

在这里插入图片描述


  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值