首页
/ RISC-V ISA手册中Smcdeleg与Ssccfg扩展的技术解析

RISC-V ISA手册中Smcdeleg与Ssccfg扩展的技术解析

2025-06-16 02:11:25作者:劳婵绚Shirley

背景介绍

在RISC-V特权架构中,Smcdeleg和Ssccfg是一对密切相关的扩展,它们共同为计数器委托机制提供了硬件支持。这两个扩展分别针对不同的特权级别:Smcdeleg是面向机器模式(M-mode)的扩展,而Ssccfg则是面向监管模式(S-mode)的扩展。

扩展定义与功能划分

Smcdeleg扩展("Sm"代表特权架构和机器级扩展,"cdeleg"代表计数器委托)为硬件线程(hart)添加了所有相关的CSR寄存器,并修改了所有特权级别的行为。这个扩展提供了完整的计数器委托功能,包括:

  1. 机器级环境配置寄存器(menvcfg)中的CDE位
  2. 计数器委托相关的控制和状态寄存器
  3. 跨特权级别的行为修改

Ssccfg扩展("Ss"代表特权架构和监管级扩展,"ccfg"代表计数器配置)则提供了对委托计数器的访问权限,以及新的监管级状态。具体功能包括:

  1. 访问委托计数器的权限
  2. 新增的监管级状态寄存器
  3. 虚拟化支持(包括scountovf和LCOFIs)

实现关系

在标准的RISC-V硬件平台上,Smcdeleg和Ssccfg必须同时实现。这种设计遵循了RISC-V特权架构的常见模式,即一个完整的扩展通常包含机器级部分和监管级部分。类似的例子还包括Smaia/Ssaia和Smcsrind/Sscsrind等扩展对。

这种设计允许:

  • 机器模式固件通过menvcfg.CDE位控制是否向监管模式暴露计数器委托功能
  • 监管模式软件可以独立检测和使用Ssccfg扩展,无需了解底层机器模式的实现细节
  • 保持架构的层次性和可扩展性

技术细节

当监管模式软件(如操作系统内核)通过设备树(DT)或ACPI发现Ssccfg扩展存在时,它可以:

  1. 访问scountinhibit寄存器
  2. 通过sireg*寄存器选择计数器(当siselect寄存器值为0x40..0x5F时)
  3. 使用虚拟化支持功能,包括scountovf和LCOFI(监管级计数器溢出中断)

值得注意的是,即使硬件实现了Smcdeleg扩展,如果机器模式固件将menvcfg.CDE位设为0,监管模式软件将无法看到Ssccfg扩展的功能。

未来架构考虑

虽然当前RISC-V特权规范要求所有硬件平台必须实现机器模式,但架构设计上已经预留了可能性,允许未来出现不依赖机器模式的纯监管模式执行环境。这种前瞻性设计体现在:

  1. Ssccfg等监管级扩展的独立命名
  2. 功能上的清晰划分
  3. 为可能的仿真或非标准实现场景提供支持

这种设计理念确保了RISC-V架构的长期灵活性和适应性,同时也为各种实现场景提供了明确的技术规范。

总结

Smcdeleg和Ssccfg扩展共同构成了RISC-V计数器委托机制的基础,它们的设计体现了RISC-V架构的几个关键特点:

  1. 特权级别的清晰划分
  2. 硬件功能的灵活配置
  3. 当前实现与未来扩展的平衡
  4. 不同特权级别软件的独立检测和使用能力

理解这对扩展的关系和实现要求,对于开发RISC-V系统的固件和操作系统内核都具有重要意义。

登录后查看全文
热门项目推荐

项目优选

收起
kernelkernel
deepin linux kernel
C
22
6
ohos_react_nativeohos_react_native
React Native鸿蒙化仓库
C++
192
270
RuoYi-Vue3RuoYi-Vue3
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
909
541
Cangjie-ExamplesCangjie-Examples
本仓将收集和展示高质量的仓颉示例代码,欢迎大家投稿,让全世界看到您的妙趣设计,也让更多人通过您的编码理解和喜爱仓颉语言。
Cangjie
341
1.21 K
openGauss-serveropenGauss-server
openGauss kernel ~ openGauss is an open source relational database management system
C++
142
188
nop-entropynop-entropy
Nop Platform 2.0是基于可逆计算理论实现的采用面向语言编程范式的新一代低代码开发平台,包含基于全新原理从零开始研发的GraphQL引擎、ORM引擎、工作流引擎、报表引擎、规则引擎、批处理引引擎等完整设计。nop-entropy是它的后端部分,采用java语言实现,可选择集成Spring框架或者Quarkus框架。中小企业可以免费商用
Java
8
0
openHiTLSopenHiTLS
旨在打造算法先进、性能卓越、高效敏捷、安全可靠的密码套件,通过轻量级、可剪裁的软件技术架构满足各行业不同场景的多样化要求,让密码技术应用更简单,同时探索后量子等先进算法创新实践,构建密码前沿技术底座!
C
377
387
金融AI编程实战金融AI编程实战
为非计算机科班出身 (例如财经类高校金融学院) 同学量身定制,新手友好,让学生以亲身实践开源开发的方式,学会使用计算机自动化自己的科研/创新工作。案例以量化投资为主线,涉及 Bash、Python、SQL、BI、AI 等全技术栈,培养面向未来的数智化人才 (如数据工程师、数据分析师、数据科学家、数据决策者、量化投资人)。
Jupyter Notebook
63
58
CangjieCommunityCangjieCommunity
为仓颉编程语言开发者打造活跃、开放、高质量的社区环境
Markdown
1.1 K
0
note-gennote-gen
一款跨平台的 Markdown AI 笔记软件,致力于使用 AI 建立记录和写作的桥梁。
TSX
87
4