arm和riscv系统调用对比(笔记)

arm和riscv系统调用对比

时间

  • 日期:
    2024年9月13日

背景

将riscv芯片移植rt-thread系统,在处理异常时有所感悟,进行整理。

环境

无要求

复制代码
关键字:SVC, pendSV, ecall, 系统调用对比

一、基础认知

ARM

  • SVC(Supervisor Call)

主要用途: SVC 指令用于从用户模式(非特权模式)切换到内核模式(特权模式),以便执行操作系统提供的系统调用。它触发一个 SVC 异常,处理器跳转到 SVC 异常处理程序。

.

功能: 执行系统调用,处理从用户模式发出的请求。主要用于执行内核服务,通常包括文件操作、进程管理等。

  • PendSV(Pendable Service Exception)

《Cortex-M3权威指南》对PendSV的介绍

PendSV(可悬起的系统调用),它是一种CPU系统级别的异常,它可以像普通外设中断一样被悬起,而不会像SVC服务那样,因为没有及时响应处理,而触发Fault。

.

主要用途: PendSV 异常用于执行任务上下文切换和系统调度。它允许操作系统在后台处理任务调度,以便在不干扰实时任务的情况下进行任务切换。

.

功能: 处理任务调度和上下文切换。当任务需要被切换时,操作系统设置 PendSV 异常为挂起状态,然后在当前中断处理完成后执行 PendSV 异常处理程序来进行任务切换。

os_yiled设置上下文切换请求,真正执行上下文切换和压栈,出栈操作的是pendsv

systick和SVC都是通过os_yiled来触发 PendSV,从而进行上下文切换。

RISC-V

  • ecall

功能: ECALL 是 RISC-V 架构中的一种指令,用于触发系统调用。当用户态程序需要操作系统提供服务(例如文件操作、设备控制等)时,会执行 ECALL 指令。这会导致控制权转移到操作系统内核,通过异常处理机制处理系统调用。

.

系统调用: ECALL 类似于其他架构中的 syscall 指令,主要用于用户态和内核态的切换,以及在内核中处理系统服务请求。

二、对比总结

相似之处: ecall 和 SVC 都是用于从用户模式切换到内核模式,执行系统调用。它们的作用和使用方式非常相似,都是触发内核级别的处理,以处理用户请求的特权操作。

不同之处: PendSV 是一个用于任务切换的中断机制,与 ecall 和 SVC 的作用不同。PendSV 主要用于上下文切换,而 ecall 和 SVC 是用于请求系统服务的机制。

相关推荐
jianqiang.xue38 分钟前
ESP32-S3 入门教程:从环境搭建到物联网应用实战
c语言·单片机·嵌入式硬件·物联网·青少年编程·51单片机·嵌入式
im_AMBER40 分钟前
hello算法笔记 02
笔记·算法
yuxb731 小时前
华为云学习笔记(1):ECS 实例操作与密钥登录实践
笔记·学习·华为云
Su^!-苏释州1 小时前
Windows配置C/C++环境:MinGW+Vscode
c语言·c++·windows·vscode·大一新生学c语言
im_AMBER1 小时前
c回顾 03
c语言·学习
代码村新手1 小时前
C语言-指针
c语言·开发语言·jvm
yuxb731 小时前
华为云学习笔记(四):运维类服务与企业网站上云实践
笔记·学习·华为云
要做朋鱼燕2 小时前
ARM CoreSight:多核SoC调试追踪架构解析
开发语言·笔记·职场和发展·嵌入式·嵌入式软件
峰顶听歌的鲸鱼2 小时前
30.Linux DHCP 服务器
linux·运维·服务器·笔记·学习方法
一只小风华~3 小时前
Vue Router 命名路由学习笔记
前端·javascript·vue.js·笔记·学习·ecmascript