文章目录 一、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. 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就可以了,下面测试一下。
文章目录 一、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
文章目录 一、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
文章目录 一、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
文章目录 一、do_munmap 函数执行流程 二、do_munmap 函数源码 munmap 系统调用函数 调用了 vm_munmap 函数 , 在 vm_munmap 函数 中 , 又调用了 do_munmap...函数 , do_munmap 函数 是 删除 内存映射 的 核心函数 ; 一、do_munmap 函数执行流程 ---- do_munmap 函数执行流程 : 根据 unsigned long start...; /* Fix up all other VM information */ remove_vma_list(mm, vma); 二、do_munmap 函数源码 ---- do_munmap...函数 , 定义在 Linux 内核源码 linux-4.12\mm\mmap.c#2620 位置 ; do_munmap 函数源码如下 : /* Munmap is split into 2 main...: linux-4.12\mm\mmap.c#2620
本文以x86_64平台为例,分析linux下的系统调用是如何被执行的。...假设目标系统调用是write,其对应的内核源码为: // fs/read_write.c SYSCALL_DEFINE3(write, unsigned int, fd, const char __user...接着,在宏的定义中,先声明了三个函数,分别为__x64_sys_write、_se_sys_write、__do_sys_write,紧接着,定义了__x64_sys_write和_se_sys_write...Runs on 64-bit Linux only. # To assemble and run: # # gcc -c hello.s && ld hello.o && ....kernel space部分就已经分析完毕了,下篇文章我们结合对应的c源码,看下user space的部分是如何实现的。
文章目录 一、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
程序中调用了 printf() 函数,而库函数 printf 本质上是调用了系统调用 write() 函数,实现了终端信息的打印功能。 二、库函数 库函数可以理解为是对系统调用的一层封装。...所有 C 函数库是相同的,而各个操作系统的系统调用是不同的。 函数库调用是调用函数库中的一个程序,而系统调用是调用系统内核的服务。...函数库调用是与用户程序相联系,而系统调用是操作系统的一个进入点 函数库调用是在用户地址空间执行,而系统调用是在内核地址空间执行 函数库调用的运行时间属于「用户」时间,而系统调用的运行时间属于「系统」时间...五、正确理解库函数高效于系统调用 首先解释,上述说明的库函数性能远高于系统调用的前提是,库函数种没有使用系统调用。再来解释下某些包含系统调用的库函数,然而其性能确实也要高于系统调用。...当一个进程正在运行,遇到读写文件操作,会发生一个中断,中断后系统会把当前用户进程的一些寄存器信息保存在内核堆栈中,接着去处理中断服务程序,这里是要去执行系统调用,Linux 中通过执行 int $0x80
read和write函数 1. read函数 包含头文件 #include 函数原型 ssize_t read(int fd, void *buf, size_t count);...name"); return -1; } int fd = open(argv[1], O_RDWR | O_CREAT); write(fd, "hello linux...STDIN_FILENO STDERR_FILENO*/ } close(fd); return 0; } 我们知道,在C语言中,字符串都是以 '\0' 结尾的,比如 "hello linux...write(fd, "hello linux...", 15); 我们来测试下程序,首先明确一点,字符串会写入相应文件,但是不会打印在屏幕中,这个后面分析。...name"); return -1; } int fd = open(argv[1], O_RDWR | O_CREAT); write(fd, "hello linux
Linux系统调用– recv/recvfrom函数详解 功能描述: 从套接字上接收一个消息。对于recvfrom,可同时应用于面向连接的和无连接的套接字。
上一篇文章 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.
在Linux系统中,fork()是一个非常重要的系统调用,它的作用是创建一个新的进程。...具体来说,fork()函数会在当前进程的地址空间中复制一份子进程,并且这个子进程几乎完全与父进程相同,包括进程代码、数据、堆栈以及打开的文件描述符等。...fork()函数的语法如下: #include pid_t fork(void); 其中,参数pid_t代表进程id,而fork()函数返回值则有以下两种情况: 如果返回0,表示当前进程是子进程...需要注意的是,fork()函数并不保证父进程和子进程的执行顺序。在fork()之后,操作系统可能会先执行父进程,也可能会先执行子进程,这完全取决于系统的调度算法。...需要注意的是,fork函数会返回两次,一次是在父进程中返回子进程的进程ID,一次是在子进程中返回0。
1.文件重命名 在linux的shell解释器中输入mv 原文件名 新文件名即可进行重命名,实际上C库函数提供了具有相同功能的系统调用函数rename。...所需头文件:#include 函数原型: int rename(const char *oldpath,const char *newpath) 参数: oldpath原文件名...该函数用法比较简单,不做实例验证,大家可以自行验证。 2.修改当前进行(应用程序)的路径 cd。...所需头文件: #include 函数原型: int chdir(const char *path) 参数: path即为要切换的路径。...5.删除一个空目录 rmdir 所需头文件: #include 函数原型:int rmdir(const char* pathname) 参数:空目录的名字。
下载源码安装包,解压或者直接双击打开(如果有安装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,指定安装的路径,
-----今天是最后一篇文章关于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(其实在写这个的话,我自己也对这些函数的用法是一脸的懵逼
我们知道write函数写入的数据不是实时同步硬盘的,系统提供了一个函数让我们的数据可以实时地同步到硬盘,那就是sync。...该函数把inode table里的,即进程打开的文件对应的inode节点,写入到buffer里。
write函数的部分逻辑和read相似。我们先看入口函数。...我们看bmap函数。...new_block(int dev) { struct buffer_head * bh; struct super_block * sb; int i,j; // 获取文件系统的超级块信息...我们回到file_write函数,处理完块的逻辑后,就需要把块的内容读进来,因为是新块,所以内容都是0。其中bread函数的逻辑可以参考read函数分析那篇文章。...所以我们看到,我们写文件的时候,数据不是直接到硬盘的,只是在缓存里,系统会有线程定期更新缓存到硬盘。
进程通过系统调用,从而进入中断处理,中断处理从系统调用表里找到sys_read函数执行。...如果没有的话,就调用ll_rw_block函数到硬盘读。我们看一下ll_rw_block及相关函数。...系统有一张表,保存了驱动程序需要处理的请求和处理函数。...系统调度其他进程执行。 时间过了很久… 硬盘读好了数据,给系统发了中断。从硬盘驱动的初始化函数中(参考上面的hd_init)我们发现。硬盘中断的处理函数是hd_interrupt。...该函数是用汇编定义的。
参考链接: 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 每个应用会分配一个用户(系统应用例外
领取专属 10元无门槛券
手把手带您无忧上云