制作一个RISC-V的操作系统十三-抢占式多任务和兼容协作式多任务

文章目录

强占式多任务

流程

抢占式多任务由计时器中断触发,最后在处理程序中切换到下一个进程

代码具体流程

上下文中增加pc寄存器

寄存器保留上下文和切换,做调整

将mepc存到当前上下文的pc寄存器位置处

切换时将向下一个上下文的pc位置处的寄存器给mepc

兼容协作式多任务(软中断)

实现主动放弃CPU

依旧是由CLINT实现

寄存器 msip

RISC-V 规范定义了多种处理器模式,其中之一是 Machine 模式,这是一种最高权限模式,用于实现操作系统内核或 hypervisor 等核心功能。在 Machine 模式下,处理器提供了一系列 Memory-Mapped Control and Status Registers (CSRs),这些寄存器可以通过内存地址直接访问,就像普通的内存区域一样。

mip 即 Machine Interrupt Pending 寄存器,它是一个 CSR,用于指示哪些中断事件当前处于pending(待处理)状态。其中 mip.MSIP 是 Machine Software Interrupt Pending 位,专门用来表示机器级别的软件中断请求是否正在等待处理。

在RISC-V体系结构中,当一个hart(硬件线程)需要向另一个hart发送软件中断时,可以通过向另一个hart的MSIP位写入1来发起中断请求。MSIP映射到寄存器MSIP上的一个位,这个寄存器映射到内存上,即MSIP是memory-mapped的,这意味着可以通过内存访问指令(如load/store指令)来读写这个位,进而触发或清除中断。

具体而言,当mip.MSIP = 1时,表示有机器级别的软件中断待处理;当mip.MSIP = 0时,则表示没有此类中断待处理。通过这种方式,处理器能够在硬件级别支持高效的中断通信和管理。

流程

  1. 写入MSIP触发软中断,中断号为3

  2. 进入中断处理程序,然后切换上下文流程和抢占式多任务一样,就是触发切换的方式不同

代码

注意由于第一次切换上下文直接使用mret,此时mret会进行如下操作

  1. 通过mstatus的MPP恢复到当前的权限
  2. 通过mstatus中的pmie恢复mstatus中的pie

所以需要提前对mstatus做相应的设置

相关代码注意事项在代码注释中
https://github.com/FULLK/risllkos/tree/main/Fullkenerl8

结果

相关推荐
ChipCamp9 天前
ChipCamp探索系列 -- 1. Soft-Core RISC-V on FPGA
fpga开发·verilog·risc-v
ChipCamp12 天前
Chisel芯片开发入门系列 -- 18. CPU芯片开发和解释8(流水线架构的代码级理解)
开发语言·青少年编程·fpga开发·scala·dsp开发·risc-v·chisel
思尔芯S2C14 天前
Cost-Effective and Scalable: A Smarter Choice for RISC-V Development
fpga开发·risc-v·soc设计·prototyping
ChipCamp16 天前
Chisel芯片开发入门系列 -- 14. CPU芯片开发和解释4(Load/Store指令再探)
arm开发·青少年编程·fpga开发·scala·dsp开发·risc-v·chisel
芝士爱沙拉20 天前
智能落地扇方案:青稞RISC-V电机 MCU一览
单片机·嵌入式硬件·risc-v·电机驱动
OpenAnolis小助手24 天前
RISC-V基金会Datacenter SIG月会圆满举办,探讨RAS、PMU性能分析实践和经验
开源·龙蜥社区·risc-v·datacenter sig·龙蜥社区risc-v sig
月光技术杂谈1 个月前
《RISC-V 导论:设计与实践》开源课件(附下载链接)
开源·risc-v·课件
月光技术杂谈1 个月前
上海RISC-V峰会-香山开源RISC-V CPU随想随记
verilog·risc-v·chisel·vhdl·香山·开源cpu·xiangshan
随风ada1 个月前
Windows、macOS、liunx下使用qemu搭建riscv64/linux
linux·windows·ubuntu·macos·golang·qemu·risc-v
openKylin1 个月前
填补空白!openKylin率先完成RISC-V商业打印驱动全适配
risc-v