在线咨询
eetop公众号 创芯大讲堂 创芯人才网
切换到宽版

EETOP 创芯网论坛 (原名:电子顶级开发网)

手机号码,快捷登录

手机号码,快捷登录

找回密码

  登录   注册  

快捷导航
搜帖子
芯片精品文章合集(500篇!) 创芯人才网--重磅上线啦!
查看: 2711|回复: 2

[求助] ARMv8架构中,如果Arch32要去切换到Arch64,是如何运作的?

[复制链接]
发表于 2017-3-13 18:55:10 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

您需要 登录 才可以下载或查看,没有账号?注册

x
各位大神,ARMv8架构中,如果Arch32要去切换到Arch64,是如何运作的?状态会清空吗?
 楼主| 发表于 2017-3-14 10:35:32 | 显示全部楼层
自答一波,是不是这样的?
当exception执行时,处理器的当前状态PSTATE存储在寄存器SPSR_Eln(n=1,2,3)中
在V8中,interrupt跟exception是差不多的一个东西
exception的变换有三个指令,SVC,HVC,和SMC
当状态切换的时候需要升高层级,然后再返回
所以首先需要指令来中断当前状态
然后升高层级,再返回到低层级执行另外一个指令集的app
异常发生时:SPSR_Eln 更新(其中n是执行异常的异常级别),以存储异常结束时正确返回所需的PSTATE信息。 PSTATE被更新以反映新的处理器状态。
通过执行ERET指令,处理器通过软件被告知什么时候从异常返回。 这将从SPSR_ELn恢复异常之前的PSTATE,并通过从ELR_Eln中恢复PC将程序执行返回到原始位置。
ELR_ELn寄存器用于存储异常的返回地址。 该寄存器中的值(实际上是几个寄存器)在进入异常时自动写入,并写入PC以执行用于从异常返回的ERET指令。
发表于 2017-3-15 09:01:12 | 显示全部楼层
EL0~3各自工作在哪个指令集是寄存器定义好的,其中最高exception level的指令集是在reset时候指定的,aarch32到aarch64只发生在从低的EL到高的EL的跃迁过程中,属于exception的处理范围,所以状态肯定是不会清空的,会保存下来。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

关闭

站长推荐 上一条 /2 下一条


小黑屋| 手机版| 关于我们| 联系我们| 在线咨询| 隐私声明| EETOP 创芯网
( 京ICP备:10050787号 京公网安备:11010502037710 )

GMT+8, 2024-11-25 08:21 , Processed in 0.016775 second(s), 6 queries , Gzip On, Redis On.

eetop公众号 创芯大讲堂 创芯人才网
快速回复 返回顶部 返回列表