深入理解Linux系统调用
1、系统调用号查询
我的学号位数是08,在64位调用表里可以查到对应的系统调用函数是__x64_sys_lseek

2、lseek函数
由于没用过该函数,所以先去了解一下这个函数的作用:

直白的说就是用来移动文件指针,演示一下(c语言调用lseek库函数)

可以看到图片里我输出了两次a.txt文本里的内容
第一次是从头开始输出的,第二次这是将指针从开头移动了30个位移量,返回结果result 也为30,输出的结果自然也和第一次不一样了。
3、汇编语言调用

在64位系统中,参数的传递不再使用ebx ecx edx等寄存器了
而是使用rdi、rsi、rdx寄存器传递参数,
rdi传递第一个参数file,也就是文件描述符,%1表示第一个输入,表示后面的"m"(file)
rsi传递第二个参数offset,我直接设置成了30
rdx传递第三个参数position,传入0表示从文件开始开始移动
后传入系统调用号0x08至eax,并执行syscall
结果返回至result变量中
4、gdb调试和分析
由于要在内核下进行调试分析,所以得使用busybox为内核制作一个根文件系统
并将c文件使用静态编译后
gcc -o myfile myfile.c -static
放入rootfs/home下,以便后续执行

接着先开启一个terminal,输入命令:
qemu-system-x86_64 -kernel arch/x86/boot/bzImage -initrd rootfs.cpio.gz -S -s -nographic -append "console=ttyS0"
然后在开启一个terminal,依次输入
gdb vmlinux target remote:1234
如图,并打上断点:
b __x64_sys_lseek

可以看到这个函数在fs/read_write.c文件里的第322行,用vscode打开查看下函数

可以看见有两个SYSCALL_DEFIND3和一个SYSCALL_DEFIND5,都是lseek相关的
但本次使用的是第322行的SYSCALL_DEFIND3调用(跟后面并无太大区别,后面的SYSCALL_DEFIND3只是使用了宏,有使用条件)
随后执行ksys_lseek函数,该函数执行:
1、检查文件标识符是否存在,其次调用vfs_llseek(....args)函数开始移动文件指针
vfs_llseek(....args)函数如下:

最后返回一个off_t类型的retval结果,off_t在linux64位下即long int类型
从代码中我们可以看出,如果偏移量没有超出文件范围或者第三个参数位置传递无误的话
返回的retval刚好等于我们移动的指针偏移量

在前面的运行结果中也刚好等于30
接着我们运行home文件夹下的myfile可执行文件

可以看到并没有任何输出,被阻塞在了SYSCALL_DEFINE3函数调用上
我们可以使用n 命令单步执行, bt查看堆栈

可以看到程序先去执行了entry_syscall_64函数
后common.c下执行了do_syscall_64函数
最后随着两个popq出栈指令,恢复了rdi和rsp寄存器,系统调用完成。
先来到entry_64.S文件

它在保存上下文信息和传递完参数后随即去执行do_syscall_64
接着去common.c中查看下do_syscall_64函数做了什么

可见它在sys_call_table表中拿到系统调用号后存入regs->ax中,后开始执行系统调用
也就是执行read_write里面的SYSCALL_DEFIND3,调用lseek移动文件指针
执行完后又回到do_syscall_64函数中,接下来要执行的 syscall_return_slowpath 函数要为恢复现场做准备。

执行完后又回到上一层的堆栈即entry_syscall_64函数

继续在vscode中查看entry_syscall_64后续的代码

可见后续的代码是在完成执行现场的恢复
最后的两个popq出栈指令恢复原 rdi 和 rsp的内容,也就是完成了堆栈的切换。
至此系统调用完成。
深入理解Linux系统调用的更多相关文章
- 理解Linux系统调用
目录 1.什么是系统调用 2.linux的系统调用 3.linux系统调用实现 1.什么是系统调用 系统调用,指的是操作系统提供给用户程序调用的一组特殊接口,用户程序可以根据这组接口获得操作系统内核的 ...
- [Linux]系统调用理解(1)
本文是Linux系统调用专栏系列文章的第一篇,对Linux系统调用的定义.基本原理.使用方法和注意事项大概作了一个介绍,以便读者对Linux系统调用建立一个大致的印象. 什么是系统调用? Linux内 ...
- [Linux]Linux系统调用列表
本文列出了大部分常见的Linux系统调用,并附有简要中文说明. 以下是Linux系统调用的一个列表,包含了大部分常用系统调用和由系统调用派生出的的函数.这可能是你在互联网上所能看到的唯一一篇中文注释的 ...
- 别出心裁的Linux系统调用学习法
别出心裁的Linux系统调用学习法 操作系统与系统调用 操作系统(Operating System,简称OS)是计算机中最重要的系统软件,是这样的一组系统程序的集成:这些系统程序在用户对计算机的使用中 ...
- 关于Linux系统调用,内核函数【转】
转自:http://blog.csdn.net/ubuntulover/article/details/5988220 早上听人说到某个程序的一部分是内核态,另一部分是用户态,需要怎么怎么.当时突然想 ...
- Linux系统调用(转载)
目录: 1. Linux系统调用原理 2. 系统调用的实现 3. Linux系统调用分类及列表 4.系统调用.用户编程接口(API).系统命令和内核函数的关系 5. Linux系统调用实例 6. Li ...
- 深入理解linux网络技术内幕读书笔记(三)--用户空间与内核的接口
Table of Contents 1 概论 1.1 procfs (/proc 文件系统) 1.1.1 编程接口 1.2 sysctl (/proc/sys目录) 1.2.1 编程接口 1.3 sy ...
- 理解 Linux 配置文件分类和使用
理解 Linux 配置文件分类和使用 本文说明了 Linux 系统的配置文件,在多用户.多任务环境中,配置文件控制用户权限.系统应用程序.守护进程.服务和其它管理任务.这些任务包括管理用户帐号.分配磁 ...
- UNIX环境高级编程——Linux系统调用列表
以下是Linux系统调用的一个列表,包含了大部分常用系统调用和由系统调用派生出的的函数.这可能是你在互联网上所能看到的唯一一篇中文注释的Linux系统调用列表,即使是简单的字母序英文列表,能做到这么完 ...
- Linux系统调用列表(转)
以下是Linux系统调用的一个列表,包含了大部分常用系统调用和由系统调用派生出的的函数.这可能是你在互联网上所能看到的唯一一篇中文注释的Linux系统调用列表,即使是简单的字母序英文列表,能做到这么完 ...
随机推荐
- SICP 笔记:环境配置
SICP 笔记:环境配置 记录学习<算机的程序的构造和解释>的笔记. 环境配置 SICP 里面使用的语言是一种 Lisp 的变体 Scheme. 使用 DrRacket 作为 IDE 来进 ...
- Div的几种选择器
Div 是一个html标签,一个块级元素(单独显示一行),单独使用没有意义,需要结合CSS来使用,主要用于页面的布局. div选择器: 1.元素选择器: 1 <style> 2 div{ ...
- Chrome 中的 JavaScript 断点设置和调试技巧--转自hanguokai.com
你是怎么调试 JavaScript 程序的?最原始的方法是用 alert() 在页面上打印内容,稍微改进一点的方法是用 console.log() 在 JavaScript 控制台上输出内容.嗯~,用 ...
- 权昌TSC条码打印机终极使用教程与开发版本代码大全
本教程使用的打印机型号:TSC TTP-244 Plus 官方文档 一.TSC打印机安装 1.机器安装 根据官方快速安装指南安装打印机,此处不详细说明,也可以看视频教程,唯一需要注意的地方就是碳带的方 ...
- TypeScript - 继承(extends) - 抽象类(abstract)
(function () { /** * abstract 开头的是抽象类, * 抽象类和其他区别不大,只是不能用来创建对象 * 抽象类专门是让别人继承的的类 */ abstract class An ...
- OSI网络七层模型简明教程
如果你读过计算机专业,或者学习过网络通信,那你一定听说过 OSI 模型,它曾无数次让你头大.OSI 是 Open System Interconnection 的缩写,译为"开放式系统互联& ...
- Java-AES256加密Util
1 public class AES256Util { 2 3 /** 4 * 密钥, 256位32个字节 5 */ 6 public static final String DEFAULT_SECR ...
- Simple Algebra
题意 给定方程\(f(x)=ax^2+bxy+cy^2\)和参数\(a\),\(b\),\(c\),试确定该方程的取值是否恒非负. 题解 参照文章http://math.mit.edu/~mckern ...
- 常用的js优秀框架个人记录
一.树框架 zTree http://www.treejs.cn/
- c++学习2 基础关键词
三 volatile强制访问内存 在一个变量的频繁使用中,系统为了提高效率,会自动将内存里面的数据放入CPU里的寄存器里.但在某些特殊场景下,放入寄存器这个操作反倒会导致CPU无法及时获取最新的一手数 ...