| /* file-mmu.c: ramfs MMU-based file operations | 
 |  * | 
 |  * Resizable simple ram filesystem for Linux. | 
 |  * | 
 |  * Copyright (C) 2000 Linus Torvalds. | 
 |  *               2000 Transmeta Corp. | 
 |  * | 
 |  * Usage limits added by David Gibson, Linuxcare Australia. | 
 |  * This file is released under the GPL. | 
 |  */ | 
 |  | 
 | /* | 
 |  * NOTE! This filesystem is probably most useful | 
 |  * not as a real filesystem, but as an example of | 
 |  * how virtual filesystems can be written. | 
 |  * | 
 |  * It doesn't get much simpler than this. Consider | 
 |  * that this file implements the full semantics of | 
 |  * a POSIX-compliant read-write filesystem. | 
 |  * | 
 |  * Note in particular how the filesystem does not | 
 |  * need to implement any data structures of its own | 
 |  * to keep track of the virtual data: using the VFS | 
 |  * caches is sufficient. | 
 |  */ | 
 |  | 
 | #include <linux/fs.h> | 
 | #include <linux/mm.h> | 
 | #include <linux/ramfs.h> | 
 |  | 
 | #include "internal.h" | 
 |  | 
 | const struct address_space_operations ramfs_aops = { | 
 | 	.readpage	= simple_readpage, | 
 | 	.write_begin	= simple_write_begin, | 
 | 	.write_end	= simple_write_end, | 
 | 	.set_page_dirty = __set_page_dirty_no_writeback, | 
 | }; | 
 |  | 
 | const struct file_operations ramfs_file_operations = { | 
 | 	.read		= do_sync_read, | 
 | 	.aio_read	= generic_file_aio_read, | 
 | 	.write		= do_sync_write, | 
 | 	.aio_write	= generic_file_aio_write, | 
 | 	.mmap		= generic_file_mmap, | 
 | 	.fsync		= simple_sync_file, | 
 | 	.splice_read	= generic_file_splice_read, | 
 | 	.splice_write	= generic_file_splice_write, | 
 | 	.llseek		= generic_file_llseek, | 
 | }; | 
 |  | 
 | const struct inode_operations ramfs_file_inode_operations = { | 
 | 	.getattr	= simple_getattr, | 
 | }; |