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

Linux 内核 内存管理】munmap 系统调用源码分析 ① ( munmap 系统调用函数执行流程 | munmap 函数源码 | vm_munmap 函数源码 )

文章目录 一、munmap 系统调用函数执行流程 二、munmap 系统调用函数源码 三、vm_munmap 函数源码 一、munmap 系统调用函数执行流程 ---- munmap 系统调用函数 的作用是...munmap 系统调用函数 调用了 vm_munmap 函数 , 在 vm_munmap 函数 中 , 又调用了 do_munmap 函数 , do_munmap 函数 是 删除 内存映射 的 核心函数...; 二、munmap 系统调用函数源码 ---- munmap 系统调用函数 , 定义在 Linux 内核源码 linux-4.12\mm\mmap.c#2729 位置 ; munmap 系统调用函数源码如下...: linux-4.12\mm\mmap.c#2729 三、vm_munmap 函数源码 ---- vm_munmap 函数 , 定义在 Linux 内核源码 linux-4.12\mm\mmap.c...#2713 位置 ; 在 vm_munmap 函数 中 , 调用了 do_munmap 函数 , do_munmap 函数 是 删除 内存映射 的 核心函数 ; vm_munmap 函数源码如下 : int

1.8K20

Linux stat函数_python系统调用函数

---- 文章目录 1. inode节点与硬链接 2. stat函数与 struct stat 结构体 3. stat函数实例分析及stat命令 4....(非系统调用) *原型:struct tm *localtime(const time_t *timep); *参数:time_t类型,struct stat中time_t st_atime,这里应该是文件访问时间...(非系统调用) struct passwd *getpwuid(uid_t uid); 根据uid获取用户信息 struct passwd { char *pw_name; username char...穿透与非穿透 上面介绍了stat函数并通过stat函数实现了 ls -l 命令的功能。我们上面演示了使用自己实现的 ./mls 查看文件信息,假如说使用 ....那么我们自己如何实现获取符号链接的实际大小呢,这就用到了非穿透函数lstat,只要把上面代码实现中的函数调用stat替换为lstat就可以了,下面测试一下。

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

Linux 内核 内存管理】mmap 系统调用源码分析 ④ ( do_mmap 函数执行流程 | do_mmap 函数源码 )

文章目录 一、do_mmap 函数执行流程 二、do_mmap 函数源码 调用 mmap 系统调用 , 先检查 " 偏移 " 是否是 " 内存页大小 " 的 " 整数倍 " , 如果偏移是内存页大小的整数倍..., 则调用 sys_mmap_pgoff 函数 , 继续向下执行 ; 在 sys_mmap_pgoff 系统调用函数 中 , 最后调用了 vm_mmap_pgoff 函数 , 继续向下执行 ; 在 vm_mmap_pgoff..., 创建 " 虚拟内存区域 " ; addr = mmap_region(file, addr, len, vm_flags, pgoff, uf); 二、do_mmap 函数源码 ---- 创建 "...内存映射 " 主要是 do_mmap 函数实现的 , 该函数定义在 Linux 内核源码linux-4.12\mm\mmap.c#1320 位置 ; do_mmap 函数源码如下 : /* *...: linux-4.12\mm\mmap.c#1320

1.9K10

Linux 内核 内存管理】mmap 系统调用源码分析 ⑤ ( mmap_region 函数执行流程 | mmap_region 函数源码 )

文章目录 一、mmap_region 函数执行流程 1、检查内存申请是否合法 2、创建 " 虚拟内存区域 " 二、mmap_region 函数源码 调用 mmap 系统调用 , 先检查 " 偏移 "...是否是 " 内存页大小 " 的 " 整数倍 " , 如果偏移是内存页大小的整数倍 , 则调用 sys_mmap_pgoff 函数 , 继续向下执行 ; 在 sys_mmap_pgoff 系统调用函数 中...: linux-4.12\mm\mmap.c#1671 在后 , 调用 vma_link 函数 和 vma_set_page_prot 函数 , 完成 " 虚拟内存区域 " 创建 ; vma_link...(mm, vma, prev, rb_link, rb_parent); 源码路径 : linux-4.12\mm\mmap.c#1710 vma_set_page_prot(vma); 源码路径 :...linux-4.12\mm\mmap.c#1743 二、mmap_region 函数源码 ---- mmap_region 函数源码 定义在 Linux 内核源码linux-4.12\mm\mmap.c

1.8K20

Linux 内核 内存管理】mmap 系统调用源码分析 ② ( sys_mmap_pgoff 系统调用函数执行流程 | sys_mmap_pgoff 函数源码 )

文章目录 一、sys_mmap_pgoff 系统调用函数执行流程 二、sys_mmap_pgoff 系统调用函数源码 调用 mmap 系统调用 , 先检查 " 偏移 " 是否是 " 内存页大小 " 的..." 整数倍 " , 如果偏移是内存页大小的整数倍 , 则调用 sys_mmap_pgoff 函数 , 继续向下执行 ; 一、sys_mmap_pgoff 系统调用函数执行流程 ---- 在 sys_mmap_pgoff...系统调用函数源码 ---- 该 sys_mmap_pgoff 系统调用函数源码 , 定义在 Linux 内核源码linux-4.12\mm\mmap.c#1475 位置 ; sys_mmap_pgoff...函数源码如下 : SYSCALL_DEFINE6(mmap_pgoff, unsigned long, addr, unsigned long, len, unsigned long, prot,...: linux-4.12\mm\mmap.c#1475

1.1K20

Linux 内核 内存管理】mmap 系统调用源码分析 ③ ( vm_mmap_pgoff 函数执行流程 | vm_mmap_pgoff 函数源码 )

文章目录 一、vm_mmap_pgoff 函数执行流程 二、vm_mmap_pgoff 函数源码 调用 mmap 系统调用 , 先检查 " 偏移 " 是否是 " 内存页大小 " 的 " 整数倍 " ,...如果偏移是内存页大小的整数倍 , 则调用 sys_mmap_pgoff 函数 , 继续向下执行 ; 在 sys_mmap_pgoff 系统调用函数 中 , 最后调用了 vm_mmap_pgoff 函数..., 继续向下执行 ; 一、vm_mmap_pgoff 函数执行流程 ---- 在 vm_mmap_pgoff 函数中 , 首先 , 以 " 写者 " 身份 , 向 Linux 内核申请 读写 " 信号量...函数定义在 Linux 内核源码中的 linux-4.12\mm\util.c#296 位置 ; vm_mmap_pgoff 函数源码如下 : unsigned long vm_mmap_pgoff(...: linux-4.12\mm\util.c#296

2K10

Linux函数系统调用

程序中调用了 printf() 函数,而库函数 printf 本质上是调用了系统调用 write() 函数,实现了终端信息的打印功能。 二、库函数函数可以理解为是对系统调用的一层封装。...所有 C 函数库是相同的,而各个操作系统系统调用是不同的。 函数库调用是调用函数库中的一个程序,而系统调用是调用系统内核的服务。...函数库调用是与用户程序相联系,而系统调用是操作系统的一个进入点 函数库调用是在用户地址空间执行,而系统调用是在内核地址空间执行 函数库调用的运行时间属于「用户」时间,而系统调用的运行时间属于「系统」时间...五、正确理解库函数高效于系统调用 首先解释,上述说明的库函数性能远高于系统调用的前提是,库函数种没有使用系统调用。再来解释下某些包含系统调用的库函数,然而其性能确实也要高于系统调用。...当一个进程正在运行,遇到读写文件操作,会发生一个中断,中断后系统会把当前用户进程的一些寄存器信息保存在内核堆栈中,接着去处理中断服务程序,这里是要去执行系统调用,Linux 中通过执行 int $0x80

7.3K30

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。...我们再来看下对应的glibc的代码: // sysdeps/unix/sysv/linux/write.c /* Write NBYTES of BUF to FD.

2.3K40

详解Linux系统调用fork()函数

Linux系统中,fork()是一个非常重要的系统调用,它的作用是创建一个新的进程。...具体来说,fork()函数会在当前进程的地址空间中复制一份子进程,并且这个子进程几乎完全与父进程相同,包括进程代码、数据、堆栈以及打开的文件描述符等。...fork()函数的语法如下: #include pid_t fork(void); 其中,参数pid_t代表进程id,而fork()函数返回值则有以下两种情况: 如果返回0,表示当前进程是子进程...需要注意的是,fork()函数并不保证父进程和子进程的执行顺序。在fork()之后,操作系统可能会先执行父进程,也可能会先执行子进程,这完全取决于系统的调度算法。...需要注意的是,fork函数会返回两次,一次是在父进程中返回子进程的进程ID,一次是在子进程中返回0。

75130

Linux 系统下用源码包安装软件

下载源码安装包,解压或者直接双击打开(如果有安装zip或rar等压缩/解压缩软件的话),查找相关的安装说明文件,一般是README,INSTALL这两个文件,这两个文件一般会告诉你怎么安装你所下载的软件...例:用源码包tsung-1.5.1.tar.gz安装tsung软件 #步骤1、解压软件源码包 [root@localhost software]# tar -xvf tsung-1.5.1.tar.gz...#步骤2、进入解压后源码所在的目录 [root@localhost software]# cd tsung-1.5.1 #步骤3、运行configure程序文件(运行前不妨检查下,当前目录下是否有configure...configure --prefix=/usr/local/tsung --with-erlang=/usr/local/erlang 此处,运行configure程序文件,configure脚本会根据源码包中...Makefile.in文件中的指令,检查当前的系统环境和配置选项,并在当前目录中生成 Makefile 文件(及其它的文件), --prefix=installation_path,指定安装的路径,

3.5K10

linux系统下fcntl函数解析与标准IO函数介绍

-----今天是最后一篇文章关于linux系统下文件IO操作了,从明天起开始写文件属性的文章了,欢迎大家来学习,一起进步。(同时也欢迎大家批评指出错误,我会及时纠正过来的)。...标准IO是C库函数;而文件IO是linux系统的API,API类似于一种接口,是由操作系统提供的(说实话,在这之前,我这个人比较犟,好少会调用api,非得自己写一个函数,这样有的时候累的半死还不一定能够写出来...2、库函数比API还有一个优势就是:API在不同的操作系统之间是不能通用的,但是C库函数在不同操作系统中几乎是一样的。【所以C库函数具有可移植性而API不具有可移植性。...因此标准IO比文件IO性能要更高(这里的下一层是指硬件层存储区域,而我们的标准IO函数是应用层方面,它先向系统缓冲区操作,然后等待系统里面的write等函数操作,才把数据弄到硬件层上去)。...3、常用标准IO函数介绍: 常见的标准IO库函数有:fopen、fclose、fwrite、fread、ffulsh(刷新标准库函数的缓存,直接写进操作系统的缓冲区中)、fseek(其实在写这个的话,我自己也对这些函数的用法是一脸的懵逼

1.1K41

Linux系统下C++标准库函数

参考链接: C++ vfscanf() 1、字符串函数  头文件:  #include   函数名作用isalnum()测试字符是否为英文字母或数字isalpha()测试字符是否为英文字母...以前i=16位 l=32位 atol()将字符串转换成长整型数 现在i=32位 l=64位atoll()将字符串转换成长整型数 ll=64位 部分系统不支持使用strtol()将字符串转换成整数strtoul...  1)Linux权限说明  Linux权限说明作用S 提权和降权设置用户权限s 修改我当前组设置组权限t仅所有者可删除权限r 4读取权限w 2写入权限x 1执行权限第一个字母表示d 表明是一个文件夹...l 表明是以一个连接 其他方式表明是一个普通文件第2-4个字母表示所有者的权限第5-7个字母表示所在组的权限第8-10个字母表示其他组的权限 对进程也是有效  对内存也是有效  Linux下 一切皆文件...  UID作用0 root最高权限1000~10000(不包含10000)system 数据库 服务 tty 保留的用户10000(包含10000)以上其他用户 Android 每个应用会分配一个用户(系统应用例外

1.8K00

linux系统下lseek函数的详细用法

---前面的文章里面,仔细讲了在linux系统对文件的读写操作以及文件管理,为今天要讲的内容作了铺垫(如果您是刚接触这方面的内容,可以先看我之前写的文章,有错误的地方,还望指出来,在这里先说一声谢谢)。...这个指针不能被直接访问,linux系统用lseek函数来访问这个文件指针------当我们打开一个空文件时,默认情况下文件指针指向文件流的开始。所以这时候去write时写入就是从文件开头位置开始的。...二、从man手册来说lseek函数: 1、还是那句话,在linux系统下有问题,找男人(man手册),哈哈哈哈。...2、用lseekh函数计算文件长度: 1)linux中并没有一个函数可以直接返回一个文件的长度(因为不需要)。但是我们实际使用时经常会需要知道一个文件的长度,怎么办?...三、总结: 今天通过对lseek函数的学习,理解更加深刻了,其实还是那句话,在linux系统下用man手册来学习一个陌生函数时最好的办法了,只是说要有一定的英文水平(其实英文水平差,也不是阻碍学习的理由

1.6K30
领券