Toggle navigation
首页
问答
文章
积分商城
专家
专区
更多专区...
文档中心
返回主站
搜索
提问
会员
中心
登录
注册
ARMv8
线程上下文调度切换_context
20
arm v8中执行ERET指令时,ELR_EL2值错乱,原因不明?
发布于 2022-08-19 11:47:31 浏览:1208
订阅该版
我在armv8中使用VHE编写一个虚拟化项目。当我准备从Hypervisor切换到Guest OS时,切换代码: ``` /* * void __vcpu_entry(void *regs) * x0 = pc, x1 = spsr */ .globl __vcpu_entry __vcpu_entry: //RESTORE_CONTEXT ldp x0, x1, [x0] msr elr_el2, x0 msr spsr_el2, x1 ERET ``` 这段代码简化了其他寄存器的恢复过程,只保留了PC和SPSR的ERET值 我的想法是:在第一次调度到vcpu/VM时,我们把PC改为0x00208000,这是Guest OS的入口。 但实验的结果是:ELR_EL2的值被改成了`0x00000200`。 而这个地址不支持,也没有MMU stage 2映射,然后就取指令失败`instruction abort`了。 所以,我想知道ELR_EL2的值是怎么/为什么改变了?我看其他项目的代码也是这样写的啊 有没有专家大佬可以给我一些建议?求求了!救救孩子吧! ![微信图片_20220819114643.jpg](https://oss-club.rt-thread.org/uploads/20220819/9ce1034ea7f14290531b4ba97717137b.jpg "微信图片_20220819114643.jpg") **问题补充更新:** 项目的背景是这样的:我准备利用arm v8.1的VHE特性,在RT-thread的上实现一个虚拟化软件。 这一个部分是创建新的虚拟机并从hypervisor(EL2)第一次切入虚拟机vcpu(EL1)的过程。切换的过程,我参考了几个项目([minos切换过程](https://sourcegraph.com/github.com/minosproject/minos@master/-/blob/arch/aarch64/core/vector.S "minos切换过程") / [bao](https://sourcegraph.com/github.com/bao-project/bao-hypervisor/-/blob/src/arch/armv8/exceptions.S?L171&subtree=true "bao")),基本都是和线程切换类似的上下文切换。当然在此基础上还要补充一些vcpu的初始化状态,比如HCR_EL2, VTCR_EL2, VTTBR_EL2等。 然后在从hypervisor(EL2)第一次切入虚拟机vcpu(EL1)的过程中,理论上应该只要修改SPSR_EL2和ELR_EL2,然后执行ERET即可,硬件会将这两个寄存器的值分别赋予PSTATE和PC。但是在实验结果中,ELR_EL2的值发生了变化,变成了莫名奇妙的0x00000200。 内存的分配,我默认做的是:一次性分配到位,这个测试里面分配了64M,每块2M block分配32块,对应虚拟地址0x00200000 ~ 0x00200000+64M。那么0x00000200这个地址就根本无从说起,自然也就不会在MMU的stage 2中有映射。于是当PC取指就会报错ESR_EL2=0x820000006(MMU指令中止异常,stage 2翻译错误)。 我在想是不是已经进入了虚拟机系统里面了,但如果是这种情况,也不应该产生0x00000200这个地址。另外我使用RT-thread的上下文切换中的宏定义:RESTORE_CONTEXT 之后,结果如下: ![](https://oss-club.rt-thread.org/uploads/20220819/f0dc3d5ebc88cd0f74f951985e6b1801.jpg "微信图片_20220819171245.jpg") 图中:HCR_EL2的值使用的是[bao项目](https://sourcegraph.com/github.com/bao-project/bao-hypervisor/-/blob/src/arch/armv8/vmm.c?subtree=true "bao项目")里面的值 E2H | RW | TVM | TSC | IMO | FMO | (SWIO) | VM。 所以,我很疑惑,这中间到底是谁修改了ELR_EL2的值,使得我切入不了虚拟机? 补充:这个虚拟机的镜像使用的是RT-thread系统在GitHub上的[默认hello world工程](https://github.com/RT-Thread/rt-thread/blob/master/bsp/rockchip/rk3568/README_zh.md "默认hello world工程"),相当于hypervisor和guest OS都是RT-thread系统。 辛苦各位大佬!小弟下半年研三了,再捣鼓不出来要延毕了。。。 **第二次补充:** 实验开发板firefly的 roc-rk3568-pc,四核a55 > hypervisor镜像: [rtthread_host.bin](https://club.rt-thread.org/file_download/1aaa38e6941f0b5d) > rt-thread hello world标准镜像 可独立运行 [rtthread.bin](https://club.rt-thread.org/file_download/0226d9958d7a7169) 以上两个镜像都是单核版本(非SMP),我想先搞定单核的,再看能不能支持SMP 使用uboot引导 tftp下载文件到开发板内存 ``` setenv ipaddr 192.168.31.101 setenv serverip 192.168.31.136 setenv masknet 255.255.255.0 setenv gatewayip 192.168.31.1 tftp 0x09408000 rtthread_host.bin;tftp 0x208000 rtthread.bin;dcache flush;go 0x09408000 ``` 进系统后创建新的虚拟机 ``` create_vm -i 0 -n test ``` 然后运行(只输入run,然后按tab可以补全命令) ``` run_vm ```
查看更多
GuEe_GUI
2022-08-20
这家伙很懒,什么也没写!
盲猜楼主用的是rk3568 a55芯片,如果是的话,stage2需要进一步做特殊处理。
4
个回答
默认排序
按发布时间排序
aozima
2022-08-20
调网络不抓包,调I2C等时序不上逻辑分析仪,就像电工不用万用表!多用整理的好的文字,比截图更省流量,还能在整理过程中思考。
帮顶! 👍不明觉厉!
Yanye0xFF
2022-08-20
https
不懂帮顶,armv8还没接触过
qoxxdi
2023-10-31
这家伙很懒,什么也没写!
留个联系方式?我也在做类似东西
撰写答案
登录
注册新账号
关注者
2
被浏览
1.2k
关于作者
KDZH_8663
这家伙很懒,什么也没写!
提问
3
回答
0
被采纳
0
关注TA
发私信
相关问题
1
modbusRTU如何避免因为被高优先级任务切走而导致本次通讯失败
2
RT-Thread 4.0.2初次上下文切换失败
3
pendSV中bx lr指令,lr指向哪里?psp中剩余的寄存器啥时候弹出的?
4
Cortex-M0在bootloader环境下的上下文切换问题?
5
arc内核移植线程切换
6
rt_thread_yield 无法在同级别中释放cpu
7
线程执行完后退出 是如何通知cpu切换任务的
8
RTT-NANO 3.1.3 线程切换问题
9
线程切换,打印出来的时间不对
10
软件定时器的回调函数里可以挂起或解挂另一个线程吗?
推荐文章
1
RT-Thread应用项目汇总
2
玩转RT-Thread系列教程
3
国产MCU移植系列教程汇总,欢迎查看!
4
机器人操作系统 (ROS2) 和 RT-Thread 通信
5
五分钟玩转RT-Thread新社区
6
【技术三千问】之《玩转ART-Pi》,看这篇就够了!干货汇总
7
关于STM32H7开发板上使用SDIO接口驱动SD卡挂载文件系统的问题总结
8
STM32的“GPU”——DMA2D实例详解
9
RT-Thread隐藏的宝藏之completion
10
【ART-PI】RT-Thread 开启RTC 与 Alarm组件
最新文章
1
开源共生 商业共赢 | RT-Thread 2024开发者大会议程正式发布!
2
【24嵌入式设计大赛】基于RT-Thread星火一号的智慧家居系统
3
RT-Thread EtherKit开源以太网硬件正式发布
4
如何在master上的BSP中添加配置yml文件
5
使用百度AI助手辅助编写一个rt-thread下的ONVIF设备发现功能的功能代码
热门标签
RT-Thread Studio
串口
Env
LWIP
SPI
AT
Bootloader
Hardfault
CAN总线
FinSH
ART-Pi
USB
DMA
文件系统
RT-Thread
SCons
RT-Thread Nano
线程
MQTT
STM32
RTC
FAL
rt-smart
ESP8266
I2C_IIC
WIZnet_W5500
UART
ota在线升级
PWM
cubemx
freemodbus
flash
packages_软件包
BSP
潘多拉开发板_Pandora
定时器
ADC
GD32
flashDB
socket
中断
Debug
编译报错
msh
SFUD
rt_mq_消息队列_msg_queue
keil_MDK
ulog
MicroPython
C++_cpp
本月问答贡献
踩姑娘的小蘑菇
7
个答案
3
次被采纳
a1012112796
19
个答案
2
次被采纳
张世争
9
个答案
2
次被采纳
rv666
6
个答案
2
次被采纳
用户名由3_15位
13
个答案
1
次被采纳
本月文章贡献
程序员阿伟
9
篇文章
2
次点赞
hhart
3
篇文章
4
次点赞
RTT_逍遥
1
篇文章
6
次点赞
大龄码农
1
篇文章
5
次点赞
ThinkCode
1
篇文章
1
次点赞
回到
顶部
发布
问题
分享
好友
手机
浏览
扫码手机浏览
投诉
建议
回到
底部