首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >发生FIQ时从el3返回nwd 32位进程时出现分段故障

发生FIQ时从el3返回nwd 32位进程时出现分段故障
EN

Stack Overflow用户
提问于 2016-09-26 21:33:05
回答 1查看 139关注 0票数 0

我使用信任区模拟运行qemu。64位Linux在普通世界(NWD) EL1中运行,一些专有代码在EL3和安全世界(SWD) EL1中运行。我也有这样的中断配置: 1)为SWD分配FIQ;2)为NWD分配IRQ。

另外,nwd可以被FIQ中断的情况有三种: 1) NWD在内核模式(64位Linux)下执行;2) NWD在64位用户模式下执行;3) NWD在32位用户模式下执行

当FIQ发生时,它会被EL3捕获。然后通过EL3的代码保存NWD上下文,并开始执行FIQ的处理程序。从el3返回NWD后,1),2)所有情况都工作正常-中断的过程继续工作。但在情况3)从el3返回NWD后,由于进程中断,出现了分段故障。这也是从el3返回到NWD EL0之前的spsr_el3寄存器的值- 0x600f0010 -看起来正常。此外,我已经比较了案例3在EL3中保存和恢复的上下文,它看起来也没问题。看起来这是qemu中的某个bug。有人知道问题出在哪里吗?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2016-09-27 23:27:36

实际上,我已经解决了这个问题。该问题存在于文件'op_helper.c‘中,执行'eret’指令:'env->regs 15=env->elr_el 1& ~0x1;‘。“%1”需要更改为“cur_el”。另外,这个bug已经在最新的qemu中修复了,所以我需要更新我的一个。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/39704321

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档