arm 处理器虚拟化模式初始化 笔记版(尚未完成) 转载请注明出处---crosskernel@gmail.com

本文详细介绍了在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`函数在初始化超线程模式页表和内存映射中的作用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >



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
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值