首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

Linux内核源码分析 - 系统调用 . 续

上一篇文章 Linux内核源码分析 - 系统调用 中分析了linux下的系统调用在kernel space层是如何实现的,现在我们来分析下user space层的实现。...上篇结尾讲到我们可以使用syscall机器指令来调用系统调用,那如何指定系统调用的编号及参数,以及如何获取返回值呢?...详细介绍可以参考这篇文章: http://man7.org/linux/man-pages/man2/syscall.2.html 简而言之就是通过一定的约定来实现指定系统调用编号和传递参数及返回值。...注意,这里的write并不是kernel内部的系统调用write,而是glibc中的一个wrapper,这个wrapper里面再帮我们调用真正的系统调用write。...我们在写c时(其他语言也一样),调用的其实是glibc里的wrapper,glibc里的wrapper再帮我们调用对应的系统调用,之后再将结果从rax中取出,返回给我们,这样我们使用起来就非常方便了。

2.3K40
您找到你想要的搜索结果了吗?
是的
没有找到

内核地址空间大冒险:系统调用

“年轻人,这是系统调用表,来,把你的编号给我”,老头转过身来。 我想起来这里之前,名为open的房间里纸上的那个编号,记得我把它放到eax寄存器里去了。...“那当然,从帝国诞生的第一天起,我就在这里工作了,帝国的三百多个系统调用我早就背的滚瓜烂熟了,刚来的时候我也和你差不多年轻,现在都满头白发咯,岁月不饶人啊!”,老头又捋了捋胡须。...3 系统调用系统调用?什么意思?”,我第一次听到这几个字。 “你现在来到我们这里办事,这就叫系统调用啊!”。 “还是不太明白,还请老先生赐教”。 “好吧,年轻人好学,老朽就给你说道说道。...“老先生您说了这么多,这跟系统调用又有什么关系呢?” “别着急啊,听我继续说给你听。应用程序和帝国核心分开后,应用程序就没法直接访问磁盘、内存、网络等等设备了。那他们需要访问这些设备怎么办呢?...而你们这些应用程序想要来办事,就带着办事窗口的编号,从这个虫洞过来,而我就在这头接待你们,指引你们去具体的窗口办理业务,整个过程呢就叫做系统调用啦!终于讲完了,可累死老夫了”。 ? "虫洞?

60010

Linux 内核0.11 系统调用详解(上)

https://blog.csdn.net/u014688145/article/details/50608829 备注:本文通过三个问题,引出Linux 内核0.11的系统调用。...---- 操作系统为什么要引出系统调用? 回答这个问题前,请先参看如下图: ?...由图可以看出,从操作系统的角度来看,一台计算机主要分为两级:用户级以及内核级,系统调用主要作用就是连接用户级和内核级的“插座”。...对底层的操作,如果不通过系统调用限制,会发生用户应用程序修改系统内核等误操作,造成操作系统运行瞬间奔溃,考虑到系统的稳定性、安全性等问题,我们需要向上提供接口,限制应用层连入内核的权限。...系统调用,基本结束了,剩下的即是内核代码的编写。在下一节中,我们将在实际的操作系统编写两段内核代码函数,让用户程序能调用系统函数。尽请期待!o(∩_∩)o

1.6K31

内核地址空间大冒险:系统调用

“年轻人,这是系统调用表,来,把你的编号给我”,老头转过身来。 我想起来这里之前,名为open的房间里纸上的那个编号,记得我把它放到eax寄存器里去了。...“那当然,从帝国诞生的第一天起,我就在这里工作了,帝国的三百多个系统调用我早就背的滚瓜烂熟了,刚来的时候我也和你差不多年轻,现在都满头白发咯,岁月不饶人啊!”,老头又捋了捋胡须。...3 系统调用系统调用?什么意思?”,我第一次听到这几个字。 “你现在来到我们这里办事,这就叫系统调用啊!”。 “还是不太明白,还请老先生赐教”。 “好吧,年轻人好学,老朽就给你说道说道。...“老先生您说了这么多,这跟系统调用又有什么关系呢?” “别着急啊,听我继续说给你听。应用程序和帝国核心分开后,应用程序就没法直接访问磁盘、内存、网络等等设备了。那他们需要访问这些设备怎么办呢?...而你们这些应用程序想要来办事,就带着办事窗口的编号,从这个虫洞过来,而我就在这头接待你们,指引你们去具体的窗口办理业务,整个过程呢就叫做系统调用啦!终于讲完了,可累死老夫了”。 ? "虫洞?

67510

【Linux 内核 内存管理】mmap 系统调用源码分析 ① ( mmap 与 mmap2 系统调用 | Linux 内核中的 mmap 系统调用源码 )

文章目录 一、mmap 与 mmap2 系统调用 二、Linux 内核中的 mmap 系统调用源码 一、mmap 与 mmap2 系统调用 ---- mmap 创建 " 内存映射 " 的 系统调用 有...mmap2 ; 2 者区别是 : mmap 偏移单位是 " 字节 " , mmap2 偏移单位是 " 页 " , 但是在 arm 64 体系架构中 , 没有实现 mmap2 , 只实现了 mmap 系统调用...; 二、Linux 内核中的 mmap 系统调用源码 ---- arm64 架构体系中 , 使用 mmap 系统调用 创建 " 内存映射 " , 调用 mmap 系统调用函数 , 执行如下操作 : 先检查..." 偏移 " 是否是 " 内存页大小 " 的 " 整数倍 " , 如果偏移不是内存页大小的整数倍 , 返回 -EINVAL 错误 ; 如果偏移是内存页大小的整数倍 , 则调用 sys_mmap_pgoff...函数 , 继续向下执行 ; mmap 系统调用代码如下 : SYSCALL_DEFINE1(old_mmap, struct mmap_arg_struct __user *, arg) { struct

10.6K40

【Linux 内核】进程管理 ( 系统调用简介 | 进程相关系统调用源码 )

文章目录 一、系统调用简介 二、进程相关系统调用源码 一、系统调用简介 ---- 在开发应用程序时 , 进行 " 进程创建 " , 调用的 fork() , vfork() , clone() 等函数..., 就是 " 系统调用 " ; " 系统调用 " 是 操作系统 提供的 应用程序 调用 内核功能 的接口 , : 创建进程 , 文件操作 等 ; 系统调用内核 的关系 : 在 应用进程 中调用...fork() 系统调用 函数 , 实际上调用的是 Linux 内核中的 sys_fork() 函数 ; 在 应用进程 中调用 vfork() 系统调用 函数 , 实际上调用的是 Linux 内核中的...sys_vfork() 函数 ; 在 应用进程 中调用 clone() 系统调用 函数 , 实际上调用的是 Linux 内核中的 sys_clone() 函数 ; Linux 内核中的 sys_fork...() , sys_vfork() , sys_clone() 函数 , 调用的是 _do_fork() 函数 , _do_fork() 函数调用的是 copy_process() 函数 ; 二、进程相关系统调用源码

2.1K20

系统调用mmap的内核实现分析

也就是说,该内存段就是操作系统为mmap系统调用新分配出来的区域。 由pmap的输出可以看到,该内存段的大小是4kb,实际物理内存占用(rss)是0。 实际物理内存占用为什么是0呢?...看下mmap系统调用对应的内核源码: // arch/x86/kernel/sys_x86_64.c SYSCALL_DEFINE6(mmap, unsigned long, addr, unsigned...其实,操作系统为进程分配的内存段都是以page为单位的。 之后,该方法又调用了get_unmapped_area来获取mmap的内存段的起始地址,这个方法就不详细看了。...再之后,mmap_region方法会调用vma_link方法将新创建的vma链接到struct mm_struct的mmap字段和mm_rb字段,标识该进程拥有vma表示的这段内存区域。...由上可以看到,mmap系统调用只是为当前进程分配并初始化了一个vma实例,用来标识该进程拥有这段以vma表示的内存空间,并没有实际分配物理内存。 对此感兴趣的朋友也可以去读读相关的内核源码。 完。

2.7K10

【Linux 内核 内存管理】Linux 内核堆内存管理 ② ( 动态分配堆内存方式 | brk 系统调用 | mmap 系统调用 | brk 系统调用源码介绍 )

文章目录 一、Linux 系统 动态分配堆内存 方式 二、brk 系统调用 动态分配堆内存 一、Linux 系统 动态分配堆内存 方式 ---- Linux 系统中 , 提供了 2 种方式 进行 "...动态分配堆内存 " 操作 ; ① brk 系统调用 : 该方式本质是 设置 " 进程数据段 “ 的 结束地址 , 将该 ” 结束地址 " 向 高或低 移动 , 实现堆内存的 扩张或收缩 ; ② mmap...系统调用 : 向 Linux 操作系统 申请 " 虚拟地址空间 " 内存 , 并且将某个文件 " 映射 “ 到该申请的内存中 ; 如果 不需要映射文件 到该空间中 , 则该空间就是 ” 匿名空间 "..., 可作为 " 堆内存 " 使用 ; 二、brk 系统调用 动态分配堆内存 ---- " brk 系统调用 “ 可以指定 ” 堆内存 “ 在 ” 虚拟内存空间 “ 的 ” 结束地址 " ; 如果要 "...扩张 " 堆内存 , 可以将 结束地址 " 大于当前值 " , 如果要 " 收缩 " 堆内存 , 可以将 结束地址 " 小于当前值 " ; brk 系统调用 源码在 Linux 源码中的 linux-5.6.18

5.1K20

探索操作系统内核、启动和系统调用的奥秘

应用程序如果需要进入内核空间,就需要使用系统调用。接下来我们来看一下系统调用的过程:计算机启动过程这里简单引一下ROM,ROM(Read-Only Memory)是一种存储在计算机主板上的固化程序。...系统调用我们之前提到过,如果需要切换用户态到内核态,是需要系统调用的,系统调用是操作系统提供给应用程序的一种接口,它允许应用程序请求操作系统执行特定的操作或提供特定的服务。...应用程序通过系统调用来访问操作系统内核的功能,文件操作、网络通信、进程管理等。...所以,打印机的直接操作是放在操作系统内核里面的,进程不能随便操作。系统调用会给进程提供一个内核级别的互斥锁,他往往比你自己的程序界别的锁更加可靠。...内核是操作系统的核心,负责管理进程和线程、内存、硬件设备以及提供系统调用接口。计算机启动过程中,ROM负责加载并执行BIOS程序,而RAM用于存储运行中的程序和数据。

28210

Linux动态为内核添加新的系统调用

时间白驹过隙,快十年过去了,今天我来旧事重提。 ---- 添加新的系统调用 ,这是一个老掉牙的话题。...本文的主题依然不是劫持系统调用,而是添加系统调用,并且是动态添加系统调用,即在不重新编译内核的前提下添加系统调用,毕竟如果可以重新编译内核的话,那实在是没有意思。...至于说为什么系统调用号必须是逐渐递增的,请看: callq *-0x7e9b2c40(,%rax,8) 上述代码的含义是: call index * 8 + disp32_offset 这意味着内核是按照数组下标的方式索引系统调用的...text被copy到了新的页面,因此最好不要调用内核函数。...封堵模块加载的接口即可咯,反正不加载内核模块,谁也别想看到当前系统内核被hack成了什么样子,哦,对了,把/dev/mem的mmap也堵死哦... ....不过这是下面文章的主题了。

1.7K30

【Linux 内核 内存管理】内存管理系统调用 ④ ( 代码示例 | mmap 创建内存映射 | munmap 删除内存映射 )

文章目录 一、mmap 创建内存映射代码示例 1、fopen 打开或创建文件 2、lseek 设置文件大小 3、mmap 函数使用 4、munmap 删除内存映射 二、完整代码示例 一、mmap 创建内存映射代码示例...---- 1、fopen 打开或创建文件 使用 fopen 函数 , 打开一个文件 , 此时文件可能不存在 , 需要创建文件 ; // 打开文件 fd = open(argv[1],.../ 该操作的作用是将文件大小设置为 10 个 student 结构体大小 lseek(fd, sizeof(student) * 10 - 1, SEEK_SET); 3、mmap 函数使用 调用...if (p_student == (void*) - 1) { printf("mmap 文件映射创建失败 !")...; return -1; } // 创建完文件映射之后 , 文件描述符就可以释放了 close(fd); 4、munmap 删除内存映射 调用 munmap 函数

1.4K10

Linux内核设备驱动之系统调用笔记整理

在linux中,系统调用是用户空间访问内核的唯一手段,除异常和中断外,他们是内核唯一的合法入口。系统调用的数量很少,在i386上只有大概300个左右。...应用程序–>C库–>内核系统调用 从程序员的角度来看,系统调用无关紧要,他们只需要跟API打交道就可以了; 从内核的角度来看,内核只跟系统调用打交道,库函数及应用程序怎么使用系统调用不是内核所关心的。...内核中所有的系统调用函数都用sys_开头。...int80将系统调用号保存在eax寄存器中,而SWI将其直接集成在指令中(SWI 0x124)。...c.系统调用必须编译到核心的内核映像中,可以将系统调用的定义放置到和其功能联系最紧密的代码中,kernel/sys.c,加入: #include /*

1.8K31

内核必须懂(一): 用系统调用打印Hello, world!

前言 要自定义系统调用, 常规的两个方法是模块和重编内核, 一起来看看吧. ---- 模块与系统调用 用模块打印Hello, world! 首先看下系统版本和内核版本....rmmod ---- 用模块添加自定义系统调用 注意, 题目是用系统调用打印Hello, world!, 之前的只是熟悉一下模块的使用, 还不是系统调用打印出来的....();//使内核地址空间可写 sys_call_table_my[NUM]=(unsigned long) &sys_mycall;//用自己的系统调用替换NUM位置上的系统调用 setback_cr0...set-default multi-user.target sudo reboot sudo systemctl set-default graphical.target sudo reboot ---- 重编内核添加系统调用...设置调用编号 打开sys.c写自定义函数, 注意函数名对应. ? 自定义系统调用函数 申明函数, 还是注意名称对应. ? 申明函数 ---- 编译内核 需要先补下库.

1.3K30

Linux内核之旅张凯捷——系统调用分析(2)

在《系统调用分析(1)》Linux内核之旅/张凯捷——系统调用分析(1)中,首先介绍了系统调用的概念,并对早期通过软中断(int 80)来进行系统调用的相关过程进行了分析,最后分析和介绍了为了提高系统调用的响应执行速度的两种机制...本篇文章将介绍和分析在指令层面上对系统调用响应速度的优化——快速系统调用指令,32位下使用的sysenter/sysexit;64位下使用的syscall/sysret,以及linux内核中为了支持这些快速系统调用指令所做的相关操作...4.2 syscall系统调用初始化 基于linux-4.20内核源码进行分析: syscall系统调用初始化在内核启动执行路径中:start_kernel() -> trap_init() ->...,以及对linux-2.6.39和linux-4.20内核源码中支持快速系统调用相关部分进行分析,了解了进行系统调用的执行过程和内核对快速系统调用的相关操作。...下篇将基于Linux-5.0-rc2内核,添加系统调用,完成一个”系统调用日志收集系统“,并对系统调用分析进行总结。 ----

1.9K20

Linux内核之旅张凯捷——系统调用分析(1)

主要意思是: (1) 系统调用是程序以程序化的方式向其执行的操作系统请求服务。 (2) 请求的服务可能包括硬件相关服务(访问磁盘驱动器)、新进程创建和执行等。...用户在调用系统调用时会向内核传递一个系统调用号,然后系统调用处理程序通过此号从系统调用表中找到相应地内核函数执行(系统调用服务例程),最后返回。...3 总结 操作系统内核提供了许多服务,服务在物理表现上为内核空间的函数,系统调用即为在用户空间对这些内核提供服务的请求,即在用户空间程序“调用内核空间的函数完成相应地服务。...// 系统调用实现分析 int / iret 0 1 早些时候,通过int 80来进行系统调用调用一个系统调用示意图: 图2-1 int80系统调用示意图 下面基于linux-2.6.39内核进行分析...,因为处理器必须中断当前正在执行的任务并从用户态切换到内核态,执行完系统调用程序后又从内核态切换回用户态。

1.6K30
领券