RISC-V ISA手册中Smcdeleg与Ssccfg扩展的技术解析
背景介绍
在RISC-V特权架构中,Smcdeleg和Ssccfg是一对密切相关的扩展,它们共同为计数器委托机制提供了硬件支持。这两个扩展分别针对不同的特权级别:Smcdeleg是面向机器模式(M-mode)的扩展,而Ssccfg则是面向监管模式(S-mode)的扩展。
扩展定义与功能划分
Smcdeleg扩展("Sm"代表特权架构和机器级扩展,"cdeleg"代表计数器委托)为硬件线程(hart)添加了所有相关的CSR寄存器,并修改了所有特权级别的行为。这个扩展提供了完整的计数器委托功能,包括:
- 机器级环境配置寄存器(menvcfg)中的CDE位
- 计数器委托相关的控制和状态寄存器
- 跨特权级别的行为修改
Ssccfg扩展("Ss"代表特权架构和监管级扩展,"ccfg"代表计数器配置)则提供了对委托计数器的访问权限,以及新的监管级状态。具体功能包括:
- 访问委托计数器的权限
- 新增的监管级状态寄存器
- 虚拟化支持(包括scountovf和LCOFIs)
实现关系
在标准的RISC-V硬件平台上,Smcdeleg和Ssccfg必须同时实现。这种设计遵循了RISC-V特权架构的常见模式,即一个完整的扩展通常包含机器级部分和监管级部分。类似的例子还包括Smaia/Ssaia和Smcsrind/Sscsrind等扩展对。
这种设计允许:
- 机器模式固件通过menvcfg.CDE位控制是否向监管模式暴露计数器委托功能
- 监管模式软件可以独立检测和使用Ssccfg扩展,无需了解底层机器模式的实现细节
- 保持架构的层次性和可扩展性
技术细节
当监管模式软件(如操作系统内核)通过设备树(DT)或ACPI发现Ssccfg扩展存在时,它可以:
- 访问scountinhibit寄存器
- 通过sireg*寄存器选择计数器(当siselect寄存器值为0x40..0x5F时)
- 使用虚拟化支持功能,包括scountovf和LCOFI(监管级计数器溢出中断)
值得注意的是,即使硬件实现了Smcdeleg扩展,如果机器模式固件将menvcfg.CDE位设为0,监管模式软件将无法看到Ssccfg扩展的功能。
未来架构考虑
虽然当前RISC-V特权规范要求所有硬件平台必须实现机器模式,但架构设计上已经预留了可能性,允许未来出现不依赖机器模式的纯监管模式执行环境。这种前瞻性设计体现在:
- Ssccfg等监管级扩展的独立命名
- 功能上的清晰划分
- 为可能的仿真或非标准实现场景提供支持
这种设计理念确保了RISC-V架构的长期灵活性和适应性,同时也为各种实现场景提供了明确的技术规范。
总结
Smcdeleg和Ssccfg扩展共同构成了RISC-V计数器委托机制的基础,它们的设计体现了RISC-V架构的几个关键特点:
- 特权级别的清晰划分
- 硬件功能的灵活配置
- 当前实现与未来扩展的平衡
- 不同特权级别软件的独立检测和使用能力
理解这对扩展的关系和实现要求,对于开发RISC-V系统的固件和操作系统内核都具有重要意义。
Kimi-K2.5Kimi K2.5 是一款开源的原生多模态智能体模型,它在 Kimi-K2-Base 的基础上,通过对约 15 万亿混合视觉和文本 tokens 进行持续预训练构建而成。该模型将视觉与语言理解、高级智能体能力、即时模式与思考模式,以及对话式与智能体范式无缝融合。Python00
GLM-4.7-FlashGLM-4.7-Flash 是一款 30B-A3B MoE 模型。作为 30B 级别中的佼佼者,GLM-4.7-Flash 为追求性能与效率平衡的轻量化部署提供了全新选择。Jinja00
VLOOKVLOOK™ 是优雅好用的 Typora/Markdown 主题包和增强插件。 VLOOK™ is an elegant and practical THEME PACKAGE × ENHANCEMENT PLUGIN for Typora/Markdown.Less00
PaddleOCR-VL-1.5PaddleOCR-VL-1.5 是 PaddleOCR-VL 的新一代进阶模型,在 OmniDocBench v1.5 上实现了 94.5% 的全新 state-of-the-art 准确率。 为了严格评估模型在真实物理畸变下的鲁棒性——包括扫描伪影、倾斜、扭曲、屏幕拍摄和光照变化——我们提出了 Real5-OmniDocBench 基准测试集。实验结果表明,该增强模型在新构建的基准测试集上达到了 SOTA 性能。此外,我们通过整合印章识别和文本检测识别(text spotting)任务扩展了模型的能力,同时保持 0.9B 的超紧凑 VLM 规模,具备高效率特性。Python00
KuiklyUI基于KMP技术的高性能、全平台开发框架,具备统一代码库、极致易用性和动态灵活性。 Provide a high-performance, full-platform development framework with unified codebase, ultimate ease of use, and dynamic flexibility. 注意:本仓库为Github仓库镜像,PR或Issue请移步至Github发起,感谢支持!Kotlin07
compass-metrics-modelMetrics model project for the OSS CompassPython00