一、 MSM8K Boot Flow
图2:
系统上电后从RPM PBL启动到 APPS PBL 然后SBL1 ,再启动APPSBL 等等,整个过程看似非常复杂,但其实很多代码OEM厂家是看不到,也修改不了的。
那我们需要我们做什么能做点什么呢呵呵!不会没事情做的。 SBL1和appsbl高通是有开放代码。
本章我重点关注SBL1,且主要描述我认为重点的几方面:
1、 CDT : Platform ID和DDR参数
2、 debug log :
3、 download : msm8K 新平台软件download支持两种协议,sahara和firehose
4、 ramdump :死机异常信息dump
好的,下面将SBL1我比较关注的点调用流程总结成如下图,后面再针对关注点展开,逐个分析。
图6:
总结:通过修改cdt和dts,sbl、lk、kernel阶段使用如下接口,可以将同一个branch代码中多项目区分出来!
sbl_board_subtype // sbl高通没有,自己开发一个接口
board_hardware_subtype // lk接口
of_board_is_xxx // kernel 接口
3、CDB1:DDR参数的配置流程/h2>
cdt中还有一项重要内容是CDB1: DDR参数,下面看看如何利用这些参数进行ddr初始化的。
ddr初始化涉及如下重要三函数:
boot_procedure_func_type load_qsee_pre_procs[] =
{
…….
/* Copy the configure data table from eeprom */
boot_config_data_table_init,
…….
/* Configure ddr parameters based on eeprom CDT table data. */
sbl1_ddr_set_params, // 保存cdt ddr 参数到底层
/* Initialize DDR */
(boot_procedure_func_type)sbl1_ddr_init, //初始化ddr
…….
/* Last entry in the table. */
NULL
};
下面重点介绍这三个函数:
图8:
sbl1_ddr_set_params调用ddr_set_params,将ddr参数保存到ddr_device_table。
获取num_of_device保存到ddr_device_table_entry_num 。

图9:
sbl1_ddr_init 通过 HAL_SDRAM_Init调用到如下函数,
HAL_SDRAM_Ram_Rank_Detection,========》cs auto detect
HAL_SDRAM_Ram_Size_Detection, =========> ram size auto detect by :row、col、bank、width , manufacture_id
ddr_params_detection , ========》 two DDR chips auto detect
声明:本站部分文章及图片源自用户投稿,如本站任何资料有侵权请您尽早请联系jinwei@zod.com.cn进行处理,非常感谢!