mount命令是大家在平时使用linux的时候经常使用的一个命令,相信很多人都很熟悉这个命令,它的作用是把一个设备挂载到根文件系统的某一个目录上边去,但是有没有人对他的内部实现有过一些了解的呢,我今天就像从linux的源代码剖析,一层一层的剥开它实现的奥秘。
首先mount是一个系统调用,在用户空间使用mount函数以后,会调用软中断,进入内核空间。然后根据传入的参数,调用对应的中端门,随后进入sys_mount函数,这个函数定义在fs/namespace.c里,定义如下
首先mount是一个系统调用,在用户空间使用mount函数以后,会调用软中断,进入内核空间。然后根据传入的参数,调用对应的中端门,随后进入sys_mount函数,这个函数定义在fs/namespace.c里,定义如下
/*传入的dev_name是mount的设备名,dir_name是挂载点,type是文件系统类型,flags是标记,data是私有数据*/
asmlinkage long sys_mount(char __user * dev_name, char __user * dir_name,
char __user * type, unsigned long flags,
void __user * data)
{
int retval;
unsigned long data_page;
unsigned long type_page;
unsigned long dev_page;
char *dir_page;
/*type是字符串的文件系统名字,比如"ext4"这样的字符串,这个函数就是把挂载的选项字符串复制到内核里的一块地方*/
retval = copy_mount_options(type, &type_page);
if (retval < 0)
return retval;
/*把用户空间传来的dir_name参数复制到内核的一块内存里边*/
dir_page = getname(dir_name);
retval = PTR_ERR(dir_page);
if (IS_ERR(dir_page))
goto out1;
/*把dev_name复制到内核的一个空闲页上*/
retval = copy_mount_options(dev_name, &dev_page);
if (retval < 0)
goto out2;
/*把data数据复制到内核的一个空闲页上*/
retval = copy_mount_options(data, &data_page);
if (retval < 0)
goto out3;
/*锁住内核,防止其他进程抢占*/
lock_kernel();
/*进入mount的主要工作*/
retval = do_mount((char *)dev_page, dir_page, (char *)type_page,
flags, (void *)data_page);
/*释放锁,并释放内存*/
unlock_kernel();
free_page(data_page);
out3:
free_page(dev_page);
out2:
putname(dir_page);
out1:
free_page(type_page);
return retval;
}