系统调用入口机制:多架构对比理解(以 ARM64 为主)


📖 推荐阅读:《Yocto项目实战教程:高效定制嵌入式Linux系统》
🎥 更多学习视频请关注 B 站:嵌入式Jerry


系统调用入口机制:多架构对比理解(以 ARM64 为主)

本篇内容聚焦于系统调用的入口实现机制,重点以 ARM64 架构为例,同时对比 x86RISC-V 架构的实现方式,从多角度帮助构建系统调用的总体认知体系。


在这里插入图片描述

一、系统调用的核心概念

  • 定义:系统调用是用户态程序请求内核服务的一种受控方式。
  • 目的:实现从用户态到内核态的“安全切换”,如文件访问、进程创建、内存管理等。
  • 典型例子open(), read(), write(), fork() 等。

二、系统调用的触发方式对比

架构触发指令注释触发入口源文件位置
ARM64svc #0使用 SVC(Supervisor Call)陷入内核arch/arm64/kernel/entry.S
x86int $0x80 / syscall前者为老方式,后者为现代 CPU 使用方式arch/x86/entry/entry_64.S
RISC-Vecall通过环境调用指令陷入内核arch/riscv/kernel/entry.S

三、以 ARM64 为例的系统调用执行流程

🔹 1. 用户态触发

int fd = open("/etc/passwd", O_RDONLY);
  • glibc 中 open()syscall(SYS_open, ...)
  • 执行 svc #0 指令,触发异常

🔹 2. 异常向量入口

// arch/arm64/kernel/entry.S
el0_sync:bl el0_svc

说明:el0_sync 是从 EL0(用户态)同步异常进入 EL1(内核态)的处理入口。

🔹 3. C 语言调用链

el0_sync└── el0_svc (arch/arm64/kernel/entry-common.c)└── do_el0_svc() (arch/arm64/kernel/syscall.c)└── syscall_trace_enter() + invoke_syscall()
  • invoke_syscall() 中执行:

    • 读取 x8(系统调用号)
    • 查表:sys_call_table[x8]
    • 执行对应系统调用实现函数,如 __arm64_sys_open()

四、系统调用参数与返回值对比

架构参数传递寄存器系统调用号寄存器返回值寄存器
ARM64x0~x5x8x0
x86eax, ebx, ecxeaxeax
RISC-Va0~a5a7a0

五、系统调用表与绑定机制

系统调用表是 syscall number 与实际内核函数之间的映射桥梁,实现“按号调用”的机制。

🔹 syscall 表文件位置

架构系统调用表路径
ARM64arch/arm64/kernel/syscall_table.S
x86arch/x86/entry/syscalls/syscall_64.tbl
RISC-Varch/riscv/kernel/syscall_table.c

🔹 syscall 映射机制

  1. 用户态设置 syscall number(如 ARM64 用 x8
  2. 内核读取 syscall number,从 syscall 表中查找对应函数指针
  3. 执行绑定的系统调用函数(如 __arm64_sys_open()

🔸 例子(ARM64 的 syscall_table.S):

.long __arm64_sys_open        // 对应 __NR_open
.long __arm64_sys_read        // 对应 __NR_read

🔹 SYSCALL_DEFINE 展开示意

SYSCALL_DEFINE3(open, const char __user *filename, int flags, umode_t mode)
  • 宏展开后生成 __arm64_sys_open()
  • 并作为 syscall 表的一项注册

六、完整调用路径梳理(ARM64)

用户态↓
svc #0 (用户态发起陷入)↓
el0_sync (arch/arm64/kernel/entry.S)↓
el0_svc (arch/arm64/kernel/entry-common.c)↓
do_el0_svc (arch/arm64/kernel/syscall.c)↓
syscall_trace_enter → invoke_syscall()↓
sys_call_table[x8] → __arm64_sys_open()

七、调试与分析工具推荐

工具用途
strace跟踪用户态发起的系统调用
ftrace跟踪内核态 syscall 调用链
gdb可调试汇编入口与寄存器设置
objdump / readelf查看符号表与 ELF 结构

八、常见问题总结

问题答案
系统调用是中断吗?是一种同步异常(软中断),可类比中断处理但不同于 IRQ。
为什么每种架构入口不一样?不同指令集的陷入方式、特权级切换方式、寄存器约定不一样。
系统调用号在哪设置?通常在用户态库中写入指定寄存器(如 ARM64 的 x8)。
怎么找到系统调用函数?查 syscall 表,通过 syscall number 定位函数指针。
参数怎么传?不同架构采用不同寄存器(x0x5, a0a5, eax+ebx…)。
syscall 表作用是什么?它是内核中系统调用号和函数之间的查找映射表,按号定位函数地址执行。

📌 本文重点理解系统调用的“陷入路径”,构建从用户态到内核态的调用跳转逻辑。后续配合“系统调用如何连接内核子系统”篇章,深入剖析 syscall 如何与 VFS、进程管理等模块协作。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.pswp.cn/news/914621.shtml
繁体地址,请注明出处:http://hk.pswp.cn/news/914621.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

java MultipartFile初始化

在Java中,MultipartFile 是Spring框架中用于处理文件上传的接口。​开发者通常不会直接初始化MultipartFile对象,而是通过Spring MVC的控制器方法参数接收上传的文件。如果需要在测试或模拟场景中创建其实例,可以使用Spring的MockMultipartFi…

Linux C IO多路复用

在上一节利用管道实现了一个简单的聊天室,但这个聊天室有一个很明显的问题就是,当A处于读阻塞情况下是不能向B发送消息的,只有收到B的消息才能发送。如何实现同时既能接受B的消息,又能向其发送消息?很遗憾,…

day21——特殊文件:XML、Properties、以及日志框架

文章目录一、特殊文件概述二、Properties属性文件2.1 文件特点2.2 Properties类解析2.3 写入属性文件三、XML文件详解3.1 XML核心特性3.2 XML解析(Dom4J)3.3 XML写入3.4 XML约束(了解)四、日志技术(Logback&#xff09…

经典VB与现代VB(VB.NET)

Visual Basic(VB)目前其发展状态可以分为经典VB(VB6及之前)​和现代VB(VB.NET)​两个阶段。经典VB诞生于1991年,凭借​“快速开发(Rapid Application Development, RAD)”…

iOS UI视图面试相关

iOS UI视图面试相关 UITableVIew相关 重用机制 cell [tableView dequeueReusableCellWillIdentifier:identifer];其中A2、A3、A4、A5是完全显示在屏幕,A2、A6显示部分,A1和A7不在显示范围内,假如现在是从下滑时的结果,在A1消失时…

网络编程-tcp连接:服务器与客户端

使用服务器和客户端的代码&#xff0c;实现服务器和客户端的互相聊天功能 实现两台电脑之间互相聊天 方案一&#xff1a;服务器代码&#xff08;server.c&#xff09;#include <stdio.h> #include <stdlib.h> #include <string.h> #include <unistd.h>…

跨平台移动开发技术深度分析:uni-app、React Native与Flutter的迁移成本、性能、场景与前景

1. 引言 跨平台移动开发技术已成为提升开发效率、降低成本的战略性选择。uni-app、React Native&#xff08;RN&#xff09;和Flutter作为主流方案&#xff0c;在迁移成本、应用性能、适用场景及未来发展上呈现显著差异。本报告基于最新行业数据与技术演进&#xff08;2025年&…

详解低速容错CAN(附与高速CAN对比表)

文章目录前言一、低速容错CAN-低速二、低速容错CAN-容错2.1 信号电平2.2 终端电阻2.3 容错机制前言 在ISO 11898-3 Low-speed, fault-tolerant, medium-dependent interface部分描述了低速CAN的容错行为及其物理层内容。既然称为低速容错CAN&#xff0c;主要需要搞清楚的两个核…

维基框架发布 1.0.11 至中央仓,深化国产化 DevOps 生态整合

一、核心事件&#xff1a;维基框架 1.0.11 正式入驻中央仓库​ ​维基框架&#xff08;Wiki-Framework&#xff09;​​ 作为国产全场景 Java 企业级开发框架&#xff0c;于 7 月 9 日正式发布 ​v1.0.11 版本​ 至中央软件仓库&#xff08;Maven Central&#xff09;&#xf…

vscode 打开c++文件注释乱码

之前一直都主要用vscode编辑lua和python脚本语言&#xff0c;没怎么编辑过c文件&#xff0c;今天想打开一个文件看一个东西&#xff0c;但是注释全部乱码了&#xff0c;我也知道是文件编码的问题&#xff0c;但没找到修改编码格式的地方&#xff0c;好了废话不多说&#xff0c;…

波动回升正当时!期权合成多头:震荡市攻守兼备利器

上周&#xff0c;A股喜提关键突破&#xff01;上证指数自21年初以来首次稳稳站上3500点大关&#xff0c;市场整体震荡上行。尐程序&#xff1a;期权汇不过&#xff0c;热闹之下也藏有隐忧&#xff1a;虽然日均成交维持在1.4万亿加&#xff0c;但周五放量冲高&#xff08;成交达…

Python 基础(十四): 错误和异常

目录 1 错误2 异常 2.1 内置异常2.2 异常处理2.3 抛出异常2.4 自定义异常 程序中的错误我们通常称为 bug &#xff0c;工作中我们不仅需要改自己程序中的 bug &#xff0c;还需要改别人程序中的 bug &#xff0c;新项目有 bug 要改&#xff0c;老项目也有 bug 要改&#xff…

OpenCV-Python Tutorial : A Candy from Official Main Page(三)

3.11傅立叶变换3.11.1Fourier Transform in OpenCV-cv.dft、cv.magnitude、cv.idft这两个函数是图像频域处理&#xff08;如去噪、边缘增强、纹理分析&#xff09;的基础工具。1.cv.dft() —— 离散傅里叶变换功能&#xff1a; 将图像从空间域&#xff08;像素强度&#xff09;…

移动端字体适配

一、移动端图片适配1、使用 <img> 的 srcset<img src"logo.png"srcset"logo2x.png 2x,logo3x.png 3x"alt"Logo">优点&#xff1a;原生支持&#xff0c;浏览器自动选择最合适的图片。2、使用媒体查询切换背景图.logo {background-ima…

git起步

git官网&#xff1a;https://git-scm.com git使用手册&#xff1a;https://git-scm.com/book/zh/v2 一、Git 是什么&#xff1f; 1、版本控制 版本控制是一种记录一个或若干文件内容变化&#xff0c;以便将来查阅特定版本修订情况的系统。我们经常是用的是保存软件源代码的…

SSL与HTTP概述

一、概念1.SSL概念SSL&#xff08;Secure Sockets Layer&#xff09;是一种网络安全协议&#xff0c;用于在互联网通信中建立加密链接&#xff0c;保护在网络中传输的敏感数据免遭窃取或篡改。2.TLS概念虽然现在更先进的 TLS&#xff08;Transport Layer Security&#xff09; …

前端报错:“Uncaught SyntaxError: missing ) after argument list

问题描述&#xff1a;前端报错&#xff1a;“Uncaught SyntaxError: missing ) after argument list在 JavaScript 中遇到“SyntaxError: missing ) after argument list”这个错误通常意味着在函数调用或者声明中&#xff0c;参数列表的括号没有正确闭合。错误代码&#xff1a…

广州邮科光纤交换机的应用:网络世界中的幕后核心

你知道吗&#xff1f;在我们每天畅游互联网&#xff0c;发送邮件、看视频、打游戏时&#xff0c;背后支撑这一切流畅体验的关键设备之一就是光纤交换机。它像一个幕后英雄&#xff0c;默默地确保信息传输高效、稳定。那么&#xff0c;究竟邮科光纤交换机有哪些不可或缺的应用领…

C++内存布局、构造函数规则和优化策略解析

一、类对象内存布局深度解析 1.1 核心内存占用规则 ​非静态成员变量​&#xff1a;每个对象独立存储&#xff0c;按声明顺序排列&#xff08;含内存对齐填充&#xff09; 示例&#xff1a;class A{int x; char y;}; → 实际占用8字节&#xff08;413填充&#xff09;4​静态…

Fastapi框架总览与核心架构

Fastapi框架总览与核心架构 FastAPI 是一个基于 Python 的现代 Web 框架&#xff0c;专注于 高性能、高并发 和 开发效率&#xff0c;特别适合构建 异步 API 服务、微服务接口&#xff0c;同时在大模型接口封装中也广泛应用。它基于 Starlette&#xff08;异步 Web 框架&#x…