在Linux中装载和更改文件时使用的系统调用序列

在Linux中装载和更改文件时使用的系统调用序列,linux,filesystems,kernel,kernel-module,Linux,Filesystems,Kernel,Kernel Module,我正在从事一个Linux项目。 我想知道当我们使用mount命令挂载文件系统时,以什么顺序调用哪些系统调用,以及在读取、写入和删除该文件系统中的文件时调用哪些系统调用 这方面有什么好的资源吗 谢谢使用strace怎么样 例如: > sudo strace mount /tmp/loop_image mount_point/ -o loop execve("/bin/mount", ["mount", "/tmp/loop_image", "mount_point/", "-o", "lo

我正在从事一个Linux项目。 我想知道当我们使用mount命令挂载文件系统时,以什么顺序调用哪些系统调用,以及在读取、写入和删除该文件系统中的文件时调用哪些系统调用

这方面有什么好的资源吗


谢谢

使用
strace
怎么样

例如:

> sudo strace mount /tmp/loop_image mount_point/ -o loop

execve("/bin/mount", ["mount", "/tmp/loop_image", "mount_point/", "-o", "loop"], [/* 19 vars */]) = 0
brk(0)                                  = 0x195c000
access("/etc/ld.so.nohwcap", F_OK)      = -1 ENOENT (No such file or directory)
mmap(NULL, 8192, PROT_READ|PROT_WRITE, MAP_PRIVATE|MAP_ANONYMOUS, -1, 0) = 0x7faeb36c6000
access("/etc/ld.so.preload", R_OK)      = -1 ENOENT (No such file or directory)
open("/etc/ld.so.cache", O_RDONLY|O_CLOEXEC) = 3
fstat(3, {st_mode=S_IFREG|0644, st_size=136922, ...}) = 0
mmap(NULL, 136922, PROT_READ, MAP_PRIVATE, 3, 0) = 0x7faeb36a4000
... etc ...
这里只有几个系统调用,我跳过了其余的,但我认为通过这种方式,您可以看到在执行mount时调用了什么

您也可以将
strace
用于您自己的程序,这样您就可以使用所需的用例创建简单的程序,并查看在内核端调用了什么。

是一个系统调用。