linux version: 3.4.67
kernel 代码
fs/read_write.c
write系统调用函数注解
SYSCALL_DEFINE3(write, unsigned int, fd, const char __user *, buf,
size_t, count)
{
struct file *file;
ssize_t ret = -EBADF;
int fput_needed;
file = fget_light(fd, &fput_needed); //通过fd从current进程文件对象table里找出file对象
if (file) {
loff_t pos = file_pos_read(file); //获取文件位置
ret = vfs_write(file, buf, count, &pos); //调用vfs_write,这里会调用特定文件系统的file_operations->write做写动作。
file_pos_write(file, pos); //更改文件位置
fput_light(file, fput_needed); // 释放file对象
}
return ret;
}
ssize_t vfs_write(struct file *file, const char __user *buf, size_t count, loff_t *pos)
{
ssize_t ret;
struct task_struct *tsk = current;
struct kstatfs stat;
//static long long store = 0;
unsigned char num = 0;
struct mount *mount_data;
char *file_list[10] = {"ccci_fsd", "ccci2_fsd", "eemcs_fsd", NULL};
mount_data = real_mount(file->f_path.mnt);
if (!(file->f_mode & FMODE_WRITE))
return -EBADF;
if (!file->f_op || (!file->f_op->write && !file->f_op->aio_write))
return -EINVAL;
if (unlikely(!access_ok(VERIFY_READ, buf, count)))
return -EFAULT;
ret = rw_verify_area(WRITE, file, pos, count);
if (ret >= 0) {
count = ret;
if (file->f_op->write)
ret = file->f_op->write(file, buf, count, pos); //调用真实文件系统的file_operations->write接口,做写入工作。
//注:从这可以看出vfs没有对写入文件内容进程缓存
else
ret = do_sync_write(file, buf, count, pos); //调用aio_write,和write有什么区别? 后面再研究。
if (ret > 0) {
fsnotify_modify(file); //fs nodify
add_wchar(current, ret);
}
inc_syscw(current);
}
return ret;
}
fs/read_write.c提供的内核常用方法
vfs_llseek
vfs_read
vfs_write