mirror of
				git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
				synced 2025-09-18 22:14:16 +00:00 
			
		
		
		
	 543ade1fc9
			
		
	
	
		543ade1fc9
		
	
	
	
	
		
			
			This patch cleans up generic_file_*_read/write() interfaces. Christoph Hellwig gave me the idea for this clean ups. In a nutshell, all filesystems should set .aio_read/.aio_write methods and use do_sync_read/ do_sync_write() as their .read/.write methods. This allows us to cleanup all variants of generic_file_* routines. Final available interfaces: generic_file_aio_read() - read handler generic_file_aio_write() - write handler generic_file_aio_write_nolock() - no lock write handler __generic_file_aio_write_nolock() - internal worker routine Signed-off-by: Badari Pulavarty <pbadari@us.ibm.com> Signed-off-by: Christoph Hellwig <hch@lst.de> Signed-off-by: Andrew Morton <akpm@osdl.org> Signed-off-by: Linus Torvalds <torvalds@osdl.org>
		
			
				
	
	
		
			64 lines
		
	
	
	
		
			1.4 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			64 lines
		
	
	
	
		
			1.4 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /*
 | |
|  *  linux/fs/ufs/file.c
 | |
|  *
 | |
|  * Copyright (C) 1998
 | |
|  * Daniel Pirkl <daniel.pirkl@email.cz>
 | |
|  * Charles University, Faculty of Mathematics and Physics
 | |
|  *
 | |
|  *  from
 | |
|  *
 | |
|  *  linux/fs/ext2/file.c
 | |
|  *
 | |
|  * Copyright (C) 1992, 1993, 1994, 1995
 | |
|  * Remy Card (card@masi.ibp.fr)
 | |
|  * Laboratoire MASI - Institut Blaise Pascal
 | |
|  * Universite Pierre et Marie Curie (Paris VI)
 | |
|  *
 | |
|  *  from
 | |
|  *
 | |
|  *  linux/fs/minix/file.c
 | |
|  *
 | |
|  *  Copyright (C) 1991, 1992  Linus Torvalds
 | |
|  *
 | |
|  *  ext2 fs regular file handling primitives
 | |
|  */
 | |
| 
 | |
| #include <linux/fs.h>
 | |
| #include <linux/ufs_fs.h>
 | |
| #include <linux/buffer_head.h>	/* for sync_mapping_buffers() */
 | |
| 
 | |
| static int ufs_sync_file(struct file *file, struct dentry *dentry, int datasync)
 | |
| {
 | |
| 	struct inode *inode = dentry->d_inode;
 | |
| 	int err;
 | |
| 	int ret;
 | |
| 
 | |
| 	ret = sync_mapping_buffers(inode->i_mapping);
 | |
| 	if (!(inode->i_state & I_DIRTY))
 | |
| 		return ret;
 | |
| 	if (datasync && !(inode->i_state & I_DIRTY_DATASYNC))
 | |
| 		return ret;
 | |
| 
 | |
| 	err = ufs_sync_inode(inode);
 | |
| 	if (ret == 0)
 | |
| 		ret = err;
 | |
| 	return ret;
 | |
| }
 | |
| 
 | |
| 
 | |
| /*
 | |
|  * We have mostly NULL's here: the current defaults are ok for
 | |
|  * the ufs filesystem.
 | |
|  */
 | |
|  
 | |
| const struct file_operations ufs_file_operations = {
 | |
| 	.llseek		= generic_file_llseek,
 | |
| 	.read		= do_sync_read,
 | |
| 	.aio_read	= generic_file_aio_read,
 | |
| 	.write		= do_sync_write,
 | |
| 	.aio_write	= generic_file_aio_write,
 | |
| 	.mmap		= generic_file_mmap,
 | |
| 	.open           = generic_file_open,
 | |
| 	.fsync		= ufs_sync_file,
 | |
| 	.sendfile	= generic_file_sendfile,
 | |
| };
 |