4 STM32MP1 Linux系统启动过程

1. ROM代码

  这是ST官方写的代码,在STM32MP1出厂时就已经烧录进去,不能被修改。ROM代码是上电以后首先执行的程序,它的主要工作就是读取STM32MP1的BOOT引脚电平,然后根据电平来判断当前启动设备,最后从选定的启动设备里面读取FSBL代码,将FSBL代码放在对应的RAM空间。

  STM32MP1启动Linux内核是链式结构:ROM Code → FSBL → SSBL → Linux kernel → rootfs,系统启动的时候要保证整个链式结构都是安全的。ROM首先对FSBL进行鉴权,同样,FSBL对下个阶段鉴权以此类推,直到设备系统正确启动。

2. FSBL

  FSBL代码是初始化时钟树和外部RAM控制器,也就是DDR。FSBL将SSBL加载到DDR里面运行SSBL代码。

  一般FSBL代码是TF-A或Uboot的SPL代码,但可以换成STM32MP1 A7的内核裸机代码。

3. SSBL

  因为SSBL代码是在DDR内,无需担心空间不足,所以SSBL代码就有使能USB、网络、显示等等。SSBL一般是Uboot,用来启动Linux内核。

4. Linux内核

  SSBL部分的Uboot就只有一个使命,启动Linux内核,Uboot将Linux内核加载到DDR上并运行。Linux内核启动就是初始化开发板上的各种外设。

5. Linux用户空间

   系统启动的时候会通过 init 进程切换到用户空间,在这个过程中会初始化根文件系统里面的各种框架以及服务。

  • 11
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值