2.4 opensbi: riscv: opensbi源码解析

4.6 sbi_hart_init()函数

sbi_hart_init(scratch, TRUE)
1.支持hypervisor扩展模式的话,设置trap的基地址为__sbi_expected_trap_hext

2.分配在扩展区域分配struct hart_features结构体

3.记录feature到struct hart_features结构体中

4.1.是否支持浮点数扩展

4.2.是否支持向量扩展

4.3.是否支持SCOUNTEREN

4.4.是否支持MCOUNTEREN

4.5.是否支持MCOUNTINHIBIT

如果支持则开启

4.6.关闭中断

4.7.禁止satp

4.8.将M模式的中断和异常发送到S模式下执行

2.4 opensbi: riscv: opensbi源码解析_第1张图片

4.7 sbi_console_init()函数

串口初始化

4.8 sbi_pmu_init()函数

pmu主要用于性能测试和性能监测等。

4.9 sbi_boot_print_banner()函数

打印opensbi log,但需要再spl传递的option参数为0才可以,一般默认参数为1

[13:44:05:970] OpenSBI v1.0␍␊
[13:44:05:970]    ____                 

你可能感兴趣的:(risc-v,opensbi)