10.2 自制操作系统: risc-v Supervisor寄存器sscratch/sepc/scause/stval/senvcfg

Supervisor Scratch Register (sscratch)

sscratch是一个SXLEN-bit 读写寄存器,在supervisor下使用。通常,在hart执行user代码时,sscratch是用于保存一个指向本地 supervisor上下文的地址。在trap处理开始时,sscratch与user 寄存器交换,提供一个初始的working寄存器。

Supervisor Exception Program Counter (sepc)

管理者异常程序计数器
sepc是一个SXLEN-bit 读写寄存器。格式如下:

sepc[0]总是为0。在只支持IALIGN=32的实现中,两个低位(sepc[1:0])总是0。

如果实现允许IALIGN为16或32(例如,通过更改CSR misa),那么,每当IALIGN=32时,位sepc[1]在读取时被屏蔽,使其看起来为0。这种屏蔽也发生在SRET指令隐式读取时。尽管被屏蔽,当IALIGN=32时,sepc[1]仍然是可写的。

sepc是一个WARL寄存器,必须能够保存所有有效的虚拟地址。它不需要能够保存所有可能的无效地址。在编写sepc之前,实现可能会将一个无效地址转换成其他一些sepc可以保存的无效地址。

当一个trap陷入s模式时,sepc被写入被中断或遇到异常的指令的虚拟地址。否则,sepc永远不会写。

Supervisor Cause Register (scause)<

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

byd yes

你的鼓励是我最大的动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值