MSM8937系统启动流程【转】
本文转载自:https://blog.csdn.net/chenzhen1080/article/details/54945992?utm_source=blogxgwz8
1 Boot Address for Processors使用的处理器
chipsets里有不同的处理器,下图显示了处理器的类型以及启动地址
Subsystem Processor Boot address
APPS Cortex-A53 0x00100000*
RPM Cortex-M3 0x00200000 |
(Subsystem view) | 0x0(System view)
Modem MSS_QDSP6 Configurable*
WCNSS (Pronto) ARM9 0x0 or 0xFFFF0000 or hardware remap*
LPASS LPASS_QDSP6 Configurable* | LPASS
*No change in the boot address in system and subsystem views
APPS:应用处理器
RPM:resource and power management 用来进行电源管理
Modem:打电话2G 3G 4G的相关功能 (由dsp实现)
WCNSS:wireless connectivity network subsystem,wifi上网
LPASS:low power audio subsystem,低功耗音频子系统(sensorhub也在这里实现)(由dsp实现)
2 Boot Call Stack
Component
组件 Based on
processor
哪个处理器执行 Loaded from
从哪加载 Executes in
再哪里执行 Function
功能
Application Processor
Primary Boot Loader
(APPS PBL)
AP的第一个Bootloader Cortex-A53
(AArch32) NA APPS ROM Boot device and interface detection,
Emergency Download mode support,
loads and authenticates SBL1 ELF
segments across L2TCM, and RPM
code RAM
Secondary Boot
Loader stage 1 (SBL1)
第二个bootloader的
第一阶段 Cortex-A53
(AArch32) eMMC
L2 TCM
(segment1) L2 TCM
OCIMEM —
RPM code RAM
(segment2) RPM code
RAM
Initial memory subsystem (buses,
DDR, clocks, and CDT), loads/
authorizes TrustZone, DEVCFG,
RPM_FW, APPS BL images, memory
dump via USB 2.0 and Sahara,
Watchdog debug retention, e.gfor
example, L2 flush, RAM dump to
eMMC/SD support, USB driver
support, USB charging, thermal
check, PMIC driver support,
configures DDR, and flushes
L1/L2/ETB to crash debug
support-related configuration
QSEE/TrustZone Cortex-A53
(AArch64) eMMC LPDDR3 Equivalent to TZBSP; sets up secure
runtime environment, configures xPU,
supports fuse driver, authenticates
any subsystem images; abnormal
RESET debug functionality is added
DEVCFG Cortex-A53
(AArch64) eMMC LPDDR3 OEM configurable data, for example,
xPU configuration, PIL loading image
regions
Component Based on
processor Loaded from Executes in Function
Debug policy1
(fuse的机器可以调试,
是可选的) Cortex-A53
(Aarch 32) eMMC LPDDR3 Enables debugging on commercial
secure devices
Resource Power
Manager Firmware
(RPM_FW) Cortex-M3 eMMC RPM code RAM Resource power management
APPSBL/boot
manager and
OS loader
(就是lk) Cortex-A532
(AArch32/
AArch64) eMMC LPDDR3 Splash screen, loads and
authenticates the kernel, and
provides HLOS-specific boot loader
features using UEFI
High-Level Operating
System (HLOS)
(就是android) Cortex-A53
(AArch32/
AArch64) eMMC LPDDR3 Boots HLOS images, for example,
A53 HLOS kernel image, WCNSS
(Pronto) image, and so on.
Modem Primary Boot
Loader (Modem PBL)
(modem的bootloader) MSS_QDSP6 NA Modem ROM
Qualcomm® Hexagon™ TCM
(data and stack) Sets up Hexagon TCM, copies MBA
from LPDDR3 into Hexagon TCM,
and authenticates MBA in Hexagon
TCM
Modem Boot
Authenticator (MBA)
(modem验证) MSS_QDSP6 eMMC Hexagon TCM Authenticates the modem image, xPU
protects the DDR regions for modem,
and memory dump
1Debug policy image is an optional image loaded by the SBL. See Debug Policy User Guide for MSM8996, MSM8976, MSM8956
(80-NV396-72).
2LK boot loader will start in 32-bit
PS:debug policy是针对fuse过的机器,让fuse过的机器也可以调试
3 Boot Code Flow启动流程
Boot Flowchart
1. The system powers on and takes the MSM8937/MSM8953/MSM8940 apps processor CPU out of reset.
按下power键后,MSM8937/MSM8953/MSM8940的apps处理器开始执行,APPS PBL在ROM里执行
2. In Cortex-A53, APPS PBL loads and authenticates the following:
a. SBL1 segment 1 from the boot device to L2 (as TCM)
将sbl1加载到l2中
b. SBL1 segment 2 (SDI equivalent) to RPM code RAM, then jumps to SBL1
将RPM的代码加载到RPM的code RAM中,跳转执行SBL1
3. SBL1 segment 1 initializes DDR and loads and authenticates the following:
a. QSEE/TrustZone image from the boot device to DDR
将QSEE/TrustZone加载到DDR
b. DEVCFG image from the boot device to DDR
将DEVCFG 加载到DDR
c. Debug Policy image from the boot device to DDR
将Debug Policy加载到DDR
d. HLOS APPSBL image from the boot device to DDR
将APPSBL(即lk)加载到DDR
e. RPM firmware image from the boot device to RPM code RAM
将RPM firmware image加载到DDR
4. SBL1 transfers the execution to QSEE/TrustZone. QSEE/TrustZone sets up a secure environment, configures xPU, and supports the fuse driver.
sbl1执行完后,执行QSEE,QSEE设置安全环境,配置xPU,
a. SBL1 runs in AArch32 mode. QSEE/TrustZone runs in AArc64 mode. For AArch64 mode switch, SBL1 sets boot remapper for QSEE entry and writes to RMR register, and then triggers warm-reset. QSEE now starts in AArch64 mode.
SBL1运行在AArch32 模式,QSEE/TrustZone运行在AArc64 模式,SBL1将QSEE 的入口remap,写RMR寄存器,warm-reset,这样QSEE就在AArch64 模式
5. QSEE notifies RPM to start the RPM firmware execution.
QSEE通知RPM执行RPM的固件
6. QSEE transfers execution to the HLOS APPSBL to initialize the system.
HLOS APPSBL (即lk)初始化系统
a. The Linux APPS boot loader (HLOS APPSBL) starts the execution in AArch32 mode only.
HLOS APPSBL运行在AArch32 模式
b. This is done by EL3/Monitor mode by looking at the ELF header for HLOS APPSBL, which indicates that it uses 32-bit instruction set architecture. EL3/Monitor mode changes to 32-bit mode and starts Linux APPS boot loader (HLOS APPSBL) execution in 32-bit mode.
通过查看 HLOS APPSBL的ELF的文件头,需要使用32位的指令集,系统切换到32位的模式
7. The HLOS APPSBL loads and authenticates the HLOS kernel. The Linux APPS boot loader (HLOS APPSBL) will indicate about the HLOS kernel AArch64 mode by making an SCM call to secure the monitor before exiting. LK does not jump into the kernel directly as it did previously.
HLOS APPSBL(即lk)加载内核,通过SCM调用切换到AArch64 模式
8. The HLOS kernel loads the MBA to DDR via PIL.
HLOS kernel 通过pil加载MBA到DDR
9. The HLOS kernel brings the Hexagon modem DSP out of reset.
HLOS kernel复位modem的DSP
10. The Modem PBL then continues its boot process.
Modem的PBL执行
11. The HLOS kernel loads the AMSS modem image to DDR via PIL.
HLOS kernel 通过pil加载AMSS modem image 到DDR
12. The Modem PBL authenticates MBA and then jumps to it.
modem的PBL验证MBA,然后跳进执行
13. HLOS loads the WCNSS (Pronto) image to DDR via PIL.
HLOS kernel 通过pil加载WCNSS 到DDR
14. HLOS brings the WCNSS (Pronto) image out of reset so that the Pronto image starts executing.
HLOS复位wifi的处理器,wifi的固件开始执行
15. HLOS loads the LPASS image to DDR via PIL.
HLOS kernel 通过pil加载LPASS(音频子系统)到DDR
16. HLOS brings the LPASS image out of reset so that the LPASS image starts executing.
HLOS kernel 复位处理音频的dsp,音频子系统开始运行
---------------------
作者:茫茫大士
来源:CSDN
原文:https://blog.csdn.net/chenzhen1080/article/details/54945992
版权声明:本文为博主原创文章,转载请附上博文链接!
MSM8937系统启动流程【转】的更多相关文章
- Linux操作系统启动流程梳理
接触linux系统运维已经好几年了,常常被问到linux系统启动流程问题,刚好今天有空来梳理下这个过程:一般来说,所有的操作系统的启动流程基本就是: 总的来说,linux系统启动流程可以简单总结为以下 ...
- CentOS系统启动流程
CentOS系统启动流程 POST --> Boot Sequence(BIOS) --> Boot Loader(MBR) --> kernel(ramdisk) --> r ...
- CentOS系统启动流程你懂否
一.Linux内核的组成 相关概念: Linux系统的组成部分:内核+根文件系统 内核:进程管理.内存管理.网络协议栈.文件系统.驱动程序. IPC(Inter-Process Communicati ...
- linux基础-附件1 linux系统启动流程
附件1 linux系统启动流程 最初始阶段当我们打开计算机电源,计算机会自动从主板的BIOS(Basic Input/Output System)读取其中所存储的程序.这一程序通常知道一些直接连接在主 ...
- Linux系统启动流程及安装命令行版本
Debian安装 之前也安装过很多次linux不同版本的系统,但安装后都是直接带有桌面开发环境的版本,直接可以使用,正好最近项目不是很忙,想一直了解下Linux的整个启动流程,以及如何从命令行模式系统 ...
- 【转载】Linux系统启动流程
原文:Linux系统启动流程 POST(Power On Self Test/上电自检)-->BootLoader(MBR)-->Kernel(硬件探测.加载驱动.挂载根文件系统./sbi ...
- Linux系统启动流程及grub重建(1)
日志系统 Linux系统启动流程 PC: OS(Linux) POST-->BIOS(Boot Sequence)-->MBR(bootloader,446)-->Kernel--& ...
- Linux第八讲随笔 -tar / 系统启动流程
linux 第八讲1.tar 参考 作用:压缩和解压文件.tar本身不具有压缩功能.他是调用压缩功能实现的. 语法:tar[必要参数][选择参数][文件] 参数:必要参数有如下: -A 新增压缩文件到 ...
- 【Android 系统开发】 Android 系统启动流程简介
作者 : 万境绝尘 (octopus_truth@163.com) 转载请注明出处 : http://blog.csdn.net/shulianghan/article/details/3889548 ...
随机推荐
- SQL SERVER深入学习学习资料参考
SQL SERVER深入学习学习资料参考 1.微软Webcast<sql server 2000完结篇>. 尽管微软Webcast出了很多关于Sql Server的系列课程,但是最为深入讲 ...
- hadoop备战:yarn框架的简单介绍(mapreduce2)
新 Hadoop Yarn 框架原理及运作机制 重构根本的思想是将 JobTracker 两个基本的功能分离成单独的组件,这两个功能是资源管理和任务调度 / 监控.新的资源管理器全局管理全部应用程序计 ...
- 仿照hibernate封装的一个对数据库操作的jdbc工具类
package project02_Order_management.util; import java.io.IOException; import java.lang.reflect.Field; ...
- adb server version (31) doesn't match this client (36)
运行adb 命令的时候报错: C:\Users\Administrator>adb devices List of devices attachedadb server version (31) ...
- ROS学习笔记一(ROS的catkin工作空间)
在安装完成ROS indigo之后,需要查看环境变量是否设置正确,并通过创建一个简单的实例来验证ROS能否正常运行. 1 查看环境变量 在ROS的安装过程中,我们执行了如下命令:(此命令就是向当前用户 ...
- bootstrap modal插件弹出窗口如何限制最大高度,并且在内容过多时可以滚动显示
.modal-body{ max-height:400px; overflow-y:auto; } 只有在modal-body类上限制高度才能起作用,其他地方的限制均不起作用
- mysql数据库的初始化及相关配置
接着上篇文章我们继续探讨在安装完mysq数据库之后的一些相关配置: 一.mysql数据库的初始化 我们在安装完mysql数据库以后,会发现会多出一个mysqld的服务,这个就是咱们的数据库服务,我们通 ...
- AdaBoost Classifier和Regressor
Adaboost原理传送门 AdaBoost在我看理论课程的时候,以分类为例子来讲解的,谁知道sklearn里面基本上都有classifier和regressor两种.这个倒是我没想到的!!! fro ...
- -webkit-line-clamp超过两行就出现省略号
-webkit-line-clamp 是一个 不规范的属性(unsupported WebKit property),它没有出现在 CSS 规范草案中. 限制在一个块元素显示的文本的行数. 为了实现该 ...
- c#中ref和out使用及区别
在c#中,使用方法获得返回值时,只能获取一个返回值.当使用ref和out关键字后,可以获取多个返回值. MSDN对ref和out关键字的说明如下: ref 关键字: 使参数按引用传递.其效果是,当控制 ...