三星S5PV210的启动

news/2025/1/11 20:07:16/

三星S5PV210的启动


文章目录

  • 三星S5PV210的启动
    • ARM架构:
    • S5PV210架构示意图:
      • ARM公司的核心(类似PC机的北桥部分)
      • 由半导体厂商设计的部分(相当于PC机的南桥)
    • S3C6410的启动机制:
    • S5PV210的起动过程:
    • 异常处理:
      • 异常向量的地址映射:
    • ARM 的流水线:


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 的流水线:

在这里插入图片描述



http://www.ppmy.cn/news/157814.html

相关文章

别了5320xm,迎来5230

我的小五被偷一周后,实在是不习惯。想到小五还跟新的一样,就被我弄丢了,阵阵悔意。用了索爱的w302C后依然十分怀念我的小五,可惜,没人手头太紧,又不想找家里要钱,心中十分纠结。 对爸爸妈…

三星 4521 linux 驱动下载,三星4521f驱动

软件标签:三星 三星scx-4521f打印机驱动是为同名打印机设计的一款驱动,三星4521f打印机是集扫描、打印机、复印和传真为一体的多功能一体机,想要正常使用就必须安装驱动才可以,此次51小编提供的是打印机驱动,安装之后就能保证正常打印了,需要的朋友可以下载! 三星4521f驱…

白天过节,晚上了解了下 Threejs3D

文章目录 I. 介绍Three.js 3DA. 什么是Three.jsB. Three.js的历史C. Three.js的应用领域 II. 开始使用Three.js 3DA. 安装和引入Three.jsB. 创建Three.js场景C. 添加3D对象到场景D. 控制相机和灯光E. 渲染场景 III. Three.js 3D中的基本概念A. 坐标系统和变换B. 材质和纹理C. 几…

三星Galaxy A52新鲜上市,点亮你的个性生活

2021年3月17日,三星Galaxy A52 5G正式发布并启动0元登记购机活动,酷炫5G配合超流畅滚屏,以全新的震撼设计搭配实力出众的不俗配置,让更多用户感受三星A系列带来的全新5G体验。 时尚与实力兼得,尽享青春潮流 三星Galax…

sdb连接三星手表调试(galaxy watch 3)

我的电脑环境: win11,amd处理器(导致不能装haxm) 三星手表3: Tizen5.5 目录 一、安装TizenStudio 二、找到sdb工具 三、手表上操作 四、连接手表 可能遇到的问题: 一、安装TizenStudio 下载网址&a…

解决下列软件包有未满足的依赖关系:

解决下列软件包有未满足的依赖关系: 有读者反映,安装aptitude后宕机,请各位酌情配置,这只是个解决方案。 根据各位反应的情况,会在适配的同时会修改掉一些必要的核心库,从而导致严重的系统问题。大家可以…

软考A计划-网络规划设计师-学习笔记-上

点击跳转专栏>Unity3D特效百例点击跳转专栏>案例项目实战源码点击跳转专栏>游戏脚本-辅助自动化点击跳转专栏>Android控件全解手册点击跳转专栏>Scratch编程案例 👉关于作者 专注于Android/Unity和各种游戏开发技巧,以及各种资源分享&am…

栈和队列的基本认识

栈:一种特殊的线性表,其只允许在固定的一端进行插入和删除元素操作。进行数据插入和删除操作的一端称为栈 顶,另一端称为栈底。栈中的数据元素遵守后进先出LIFO(Last In First Out)的原则。 压栈:栈的插入操…