当前位置: 首页 > news >正文

浅谈Linux中一次系统调用的执行过程

本文以 X86体系架构,Linux操作系统 来叙述。

我们以open()系统调用来说,这里我们要明白一点 open() 是glibc封装之后的系统调用。

// glibc 源码 (sysdeps/unix/sysv/linux/open.c)
int open(const char *file, int oflag, ...) {return INLINE_SYSCALL(open, 3, file, oflag, ...);
}

当用户程序中调用了 open( ... ),编译器在预处理阶段会将open( ... ) 当作宏替换,产生一些代码,这些代码包括:将open() 系统调用的系统调用号,存储在eax寄存器中。

 

当真正执行到 open( ... ) 的时候,首先将open() 系统调用的系统调用号,存储在eax寄存器中,之后执行 int 0x80。

mov eax, 5       ; __NR_open
mov ebx, path    ; 参数1: 文件路径指针
mov ecx, flags   ; 参数2: 打开标志
mov edx, 0666o   ; 参数3: 文件模式 (可省略)
int 0x80

让CPU去查中断向量表的0x80号中断服务函数,发现是系统调用入口函数,entry_INT80_32,保存当前用户寄存器信息,再读取eax中的系统调用函数的函数号,查系统调用函数的系统调用函数表,发现是open系统调用,之后执行sys_open(),参数通过ebx,ecx,edx传递,将执行玩的结果存放在eax中,恢复用户寄存器,执行iret返回用户态。

 

相关文章:

  • PHP框架在内容管理系统开发中的优势:效率、安全与扩展性!
  • JMeter 处理 UTF-16 转 UTF-8 乱码问题解决方案(deepseek)
  • arm服务器运行Jmeter报错问题UseG1GC
  • 使用Jmeter做功能测试有哪些优点?
  • 网络中基础的三张表(mac、arp、route)
  • Jmeter中变量如何使用?
  • 抖音授权登录-获取用户授权调用凭证
  • D. Plus Minus Permutation
  • PocketSCP:蛋白质口袋动态时空拓扑可视化分析新方法
  • 论文略读:DAILYDILEMMAS:REVEALINGVALUEPREFERENCES OFLLMSWITHQUANDARIESOFDAILYLIFE
  • OCR(光学字符识别)算法
  • 智能合约中人工智能驱动的漏洞分析:趋势、挑战与未来方向
  • 【leetcode-合并两个有序链表】
  • AI助手一键生成专业PPT(Gamma/Genspark/Kimi)
  • [Git] 标签管理
  • 三.Gitee远程操作标签操作
  • FastAPI基础入门(三)
  • 智慧医疗能源事业线深度画像分析(下)
  • MySQL 基础笔记
  • Reactive-Resume:重构你的简历编写体验
  • 网站开发过程总结/推56论坛
  • 河北廊坊建设银行网站/怎么找需要做推广的公司
  • 零基础学习网站开发/沈阳高端关键词优化
  • 手机网站用什么开发/营销型网站有哪些平台
  • 网络服务商是啥/网站seo快速
  • 网站自动seo/成品短视频app下载有哪些软件