zImage
从Hyper态返回SVC态
//reg—暂存寄存器
.macro safe_svcmode_maskall reg:req
#if __LINUX_ARM_ARCH__ >= 6
//读取cpsr到暂存寄存器reg
mrs \reg , cpsr
/*以下两条指令区分当前cpsr是否处在HYP_MODE,若处在HYP_MODE模式,标志位置零*/
eor \reg, \reg, #HYP_MODE
tst \reg, #MODE_MASK
bic \reg , \reg , #MODE_MASK
//在暂存寄存器里存放SVC控制位
orr \reg , \reg , #PSR_I_BIT | PSR_F_BIT | SVC_MODE
THUMB( orr \reg , \reg , #PSR_T_BIT )
/*若当前寄存器处于hyper模式,返回SVC模式走一个杜撰的HVC异常返回。*/
bne 1f
orr \reg, \reg, #PSR_A_BIT
/*设置返回到SVC态的地址是标号2,即该宏调用的后一条指令。*/
adr lr, BSYM(2f)
//退出hyper后的cpsr寄存器
msr spsr_cxsf, \reg
//放到ELR_hyp中
__MSR_ELR_HYP(14)
//返回到SVC态
__ERET

本文详细介绍了在ARM处理器上进行虚拟化模式初始化的过程,包括在Hyper态返回SVC态的步骤,设置异常表`__hyp_stub_vectors`,以及在SVC态下完成解压定位的工作。内容涉及zImage在不同状态下的处理,如`__hyp_stub_do_trap`函数的实现,以及如何通过`__hyp_set_vectors`和`__hyp_get_vectors`函数改动HVBAR。此外,还提到了`cpu_init_hyp_mode`和`kvm_mmu_init`函数在初始化超线程模式页表和内存映射中的作用。
最低0.47元/天 解锁文章
38

被折叠的 条评论
为什么被折叠?



