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永远不会写。