HPS作为一个SoC器件,所有执行程序都要遵循严格的启动流程,本文针对对于HPS的启动引导流程不曾关注过或者不是十分清楚的开发人员。 HPS的启动是多阶段的流程,每一个阶段都会完成自己相应的工作并把下一阶段的执行代码引导起来。下图展示了一个典型的HPS的启动流程 HPS 典型的启动流程 系统复位(上电或者硬件复位)之后,HPS内部boot Rom开始在CPU0上执行(通过指定复位向量指定BOOT ROM区域实现自动执行BOOT ROM),完成工作并引导用户程序,当然用户程序的构架会因为具体引用有所差别! 5 {4 T5 @; L6 Q# F/ P
此处先介绍Boot ROM! 总的来说,Boot ROM是HPS内核的一段ROM上固化的可执行程序,完成的工作是系统复位以后,执行引导preloader并把CPU使用权交给preloader 的过程!特殊情况是不需要执行preloader而直接引导应用程序,这种情况是可能的,比如DS-5中baremental HelloWorld程序,但是这种情况并没有实际运用意义:其一是限制了程序大小,容量受片上RAM限制;其二是运用程序基本只能够使用到MPU内部的寄存器,外设没有被初始化(没有相应的时钟)。所以更多的应用是Boot ROM通过引导preloader把CPU使用权交给preloader进行后续的引导工作。# Q8 h" e; F$ d+ P! x8 F) V
BOOT ROM除了引导用户软件外还完成的具体工作有:
8 _8 h0 a2 F. m0 D! ^7 D● 使能指令缓存, branch predictor,浮点单元,NEON 向量单元[在ARM内部做过图形加速的可能比较熟悉]; L) E5 I: N C8 |! ^
● 设定看门狗0定时器,BOOT ROM保留适用,参考文档 page A-11 + L+ ~' q, R! n" p% b# j R
● 根据CLKSEL设定配置MainPLL 和外设PLL
' X: r& K7 ^6 k; Z# y● 根据BOOTSEL设定配置I/Opin的复用(此处应该只是完成了QSPI or SPI Flash or SDMMC controller 的pin的复用,更多的pin的复用需要根据preloader才能够完成设定)! N6 c, Q1 e. y- |1 d
● 初始化FLASH Controller 到默认设置' I S$ g7 @9 Y% E% t) `! }
BOOT ROM 引导的preloader来源分为三类:" N: `: x, u/ s* `5 v+ i
▲片上RAM热启动,对应下图中的矩形框①; B5 C% S& Y2 F! H- v# ?8 r
如果之前执行过一次preloader了,preloader会留在On-chip RAM 中,按下WARM reset 后,会首先选择从on-chip ARAM 启动,此过程具有最高优先权,但是从on-chip ARAM 启动时会对遗留的preloader代码进行CRC校验(具体是否校验用户可以通过warmramgrp配置决定),校验成功才会执行。防止了用户对ON-chip 里的内容进行更改!如校验失败,会选择从Flash中启动preloader,对应图中矩形框 ③
" u+ v. A0 q' f9 g9 B( }▲从FPGA部分冷启动,对应下图中的矩形框②0 M& g9 c! J- n5 q# ~* Z
具有第二优先权,如果用户设定了bootsel从FPGA启动,则会等待FPGA配置成功[通过FPGA manager获取FPGA的状态]!HPS会通过 HPS-to-FPGAbridge执行位于 0xC0000000【相对于HPS-to-FPGAbridge偏移地址为0】的momory中的指令。对应着GHRD中on-chip memory的功用,这里大概知道即可。
8 G1 y+ d4 r4 h▲ 从Flash 存储器启动,对应图中矩形框④; k4 O6 D) o* b3 [/ G- n: |- @
▲ 如果在Flash中找不到preloader的话,则会检验FPGA处的回调镜像(callback image)【这个image暂没有见到更多说明和使用】: z D! p& j$ ~0 P. C
▲依然不成功就只能坐等被复位了!见图中矩形框 ⑤ 、 ⑥ ![]() BOOT ROM执行流程 说明:3 A2 V0 N' }9 X' p
⑴只有冷启动才会选择从FPGA 引导
/ `% k! ~" U5 g* I$ K! ?. @+ X⑵不论热启动还是FPGA冷启动,如不成功都会进入到了红色框的QSPI启动中
) N/ I- j6 F8 \0 h. ]( G4 G⑶ 矩形框②中的yes 和 no 由bootsel 决定,矩形框③、④中最后具体是使用哪个FLASH存储器也由bootsel管脚决定。 # m4 a9 c7 K2 w! {6 R3 E5 k
上文中讲到BOOT ROM在HPS启动过程中的左右以及搜寻preloader的工程,接下来介绍preloader的相关理论知识。后面会介绍如何生成preloader,并讲述如何在从SD 卡启动的时候更新preloader。 preloader的命名是相对于BOOTLoader的!其作用类似于PC主板上的BIOS。BIOS基本上是系统启动启动 之前控制着板上的硬件设备,引导系统启动程序。preloader在HPS系统中完成功能主要包括了系统时钟配置,所有pin脚的复用配置,存储器的初始 化以及引导下一步用户软件!下一步用户软件可以直接是用户的baremental 程序,也可以不需要bootloader的系统程序,如ucos,或者是操作系统的引导程序,如u-boot。 此处列出HPS启动过程中三大典型用户软件构架:, D R, G4 ~6 n: H7 ^# f
①preloader+baremental code# k% | U: Z5 e1 b0 y2 K& A
②preloader+无bootloader的操作系统(如ucos)+用户定义软件. m+ b3 n# g4 U. l* P
③preloader+bootloader code(如u-boot)+操作系统(如linux)+用户定义软件
* H2 T% H# b" |preloader从BOOT ROM中接手CPU的时候CPU的状态列表(可能对于进行汇编开发或者AMP构架开发的用户有用):# q$ C2 E2 S+ k( j' n8 y
(以下仅适用于CPU0从FLASH memory 启动的状态)
6 I: l, T1 ?4 S● 指令缓存使能
6 {5 z K5 [ Q/ ~; \6 j● Branch predictor 使能
0 |3 y4 k( I3 \ G+ T% Q& [● 数据缓存使能
* o+ A. S7 d7 k4 q● MMU 没有被使能
4 P) D9 @4 m; d● 浮点单元使能
/ v* P# S: F1 l7 r( i● NEON 向量单元使能* X! i- a9 C4 ^1 ~( i) k. S7 t! p
● ARM处理处于secure supervisor状态 6 n: R) i" Y& o( m
ARM Cortex-A9 MPCore 的寄存器的值:; b1 n! V# U* J" v2 E
● r0—共享内存的地址指针, 共享内存用于在BOOTROM和preloader直接传递数据.共享内存位于on-chip RAM的高4K地址.( }8 ^ [% _" D4 I1 Q5 t l
具体内容参考文档page A-8。; v1 l) R6 Q" |3 {+ H4 Y
● r1—共享内存的大小.' h, w& A4 Q7 U1 \0 [" N+ m
● r2—复位值0x0.: ^- u, F, ?; \# V8 _
● r3—保留.' ?0 l/ s& x# j# X) N
其他寄存器的状态无定义。: `* M5 I5 u: b
如果CPU0从FPGA BOOT或者CPU1参与了boot,以上描述皆不适用! / F& F9 r$ }8 C3 \" G9 |
另外,prelaoder接手CPU的时候,还有下面两个状态:
6 O* L' p8 K0 p# x1 p+ `3 @● boot ROM 被映射在地址0x0。需要重新映射on-chip RAM 使得异常可以被preloader执行。
0 s$ m0 n6 g0 T& f, ]● L4 看门狗0定时器处于激活状态并已触发。preloader可以任意处理此定时器。 * {" n k! w3 ?/ i8 m+ I
. e' ]- f0 s1 o, i S, l! }
preloader具体完成的工具包含了下面部分:* f) E; `+ ]( T9 ~4 C' O) ?' ?5 \
■ 初始化SDRAM接口. ( v0 ` @3 x4 ~& |* T* `2 W) b+ O
■ 配置 remap 寄存器,把ton-chipRAM 映射至地址0x0,异常会被preloader处理.
9 `; I$ ?- h* e+ C■ on-chip RAM 可以被读写,初始地址从0x0对齐. 6 e! k+ E! Q5 M7 M* m5 Q" n
■ 通过scan manager配置HPS I/O. v' d! c" u: U, }6 {9 ?
■ 通过system manager配置pin 复用. 2 j& ~4 g9 |! Z( e
■ 通过clock manager配置HPS clocks .
: X* J' a6 C. M■ 初始化包含了下一阶段启动代码的flash控制器(NAND, SD/MMC, or quad SPI). ' Q( B! s. l+ u# @
■ 把下一阶段启动或者叫用户代码引导入SDRAM并把控制权交至下一段代码.# `. B5 r9 m0 i
●用户可以在preloader阶段使用HPSconfigure FPGA # g$ C4 i, P1 L) G4 O
preloader 的具体执行流程有机会会结合preloader code 讲述!
& [) X/ x+ F8 _2 S, A1 u5 o本文参考:
|