| David Howells | 642fb4d | 2006-01-06 00:11:41 -0800 | [diff] [blame] | 1 | /* file-mmu.c: ramfs MMU-based file operations | 
 | 2 |  * | 
 | 3 |  * Resizable simple ram filesystem for Linux. | 
 | 4 |  * | 
 | 5 |  * Copyright (C) 2000 Linus Torvalds. | 
 | 6 |  *               2000 Transmeta Corp. | 
 | 7 |  * | 
 | 8 |  * Usage limits added by David Gibson, Linuxcare Australia. | 
 | 9 |  * This file is released under the GPL. | 
 | 10 |  */ | 
 | 11 |  | 
 | 12 | /* | 
 | 13 |  * NOTE! This filesystem is probably most useful | 
 | 14 |  * not as a real filesystem, but as an example of | 
 | 15 |  * how virtual filesystems can be written. | 
 | 16 |  * | 
 | 17 |  * It doesn't get much simpler than this. Consider | 
 | 18 |  * that this file implements the full semantics of | 
 | 19 |  * a POSIX-compliant read-write filesystem. | 
 | 20 |  * | 
 | 21 |  * Note in particular how the filesystem does not | 
 | 22 |  * need to implement any data structures of its own | 
 | 23 |  * to keep track of the virtual data: using the VFS | 
 | 24 |  * caches is sufficient. | 
 | 25 |  */ | 
 | 26 |  | 
| David Howells | 642fb4d | 2006-01-06 00:11:41 -0800 | [diff] [blame] | 27 | #include <linux/fs.h> | 
| Dimitri Gorokhovik | 131612d | 2006-12-29 16:48:24 -0800 | [diff] [blame] | 28 | #include <linux/mm.h> | 
| Adrian Bunk | 4488c59 | 2008-04-29 00:58:51 -0700 | [diff] [blame] | 29 | #include <linux/ramfs.h> | 
 | 30 |  | 
 | 31 | #include "internal.h" | 
| David Howells | 642fb4d | 2006-01-06 00:11:41 -0800 | [diff] [blame] | 32 |  | 
| Christoph Hellwig | f5e54d6 | 2006-06-28 04:26:44 -0700 | [diff] [blame] | 33 | const struct address_space_operations ramfs_aops = { | 
| David Howells | 642fb4d | 2006-01-06 00:11:41 -0800 | [diff] [blame] | 34 | 	.readpage	= simple_readpage, | 
| Nick Piggin | 800d15a | 2007-10-16 01:25:03 -0700 | [diff] [blame] | 35 | 	.write_begin	= simple_write_begin, | 
 | 36 | 	.write_end	= simple_write_end, | 
| Ken Chen | 4662629 | 2007-02-10 01:43:17 -0800 | [diff] [blame] | 37 | 	.set_page_dirty = __set_page_dirty_no_writeback, | 
| David Howells | 642fb4d | 2006-01-06 00:11:41 -0800 | [diff] [blame] | 38 | }; | 
 | 39 |  | 
| Arjan van de Ven | 4b6f5d2 | 2006-03-28 01:56:42 -0800 | [diff] [blame] | 40 | const struct file_operations ramfs_file_operations = { | 
| Badari Pulavarty | 543ade1 | 2006-09-30 23:28:48 -0700 | [diff] [blame] | 41 | 	.read		= do_sync_read, | 
 | 42 | 	.aio_read	= generic_file_aio_read, | 
 | 43 | 	.write		= do_sync_write, | 
 | 44 | 	.aio_write	= generic_file_aio_write, | 
| David Howells | 642fb4d | 2006-01-06 00:11:41 -0800 | [diff] [blame] | 45 | 	.mmap		= generic_file_mmap, | 
| Christoph Hellwig | 1b061d9 | 2010-05-26 17:53:41 +0200 | [diff] [blame] | 46 | 	.fsync		= noop_fsync, | 
| Jens Axboe | 5ffc4ef | 2007-06-01 11:49:19 +0200 | [diff] [blame] | 47 | 	.splice_read	= generic_file_splice_read, | 
| Octavian Purdila | 8b3d356 | 2008-07-04 09:33:33 +0200 | [diff] [blame] | 48 | 	.splice_write	= generic_file_splice_write, | 
| David Howells | 642fb4d | 2006-01-06 00:11:41 -0800 | [diff] [blame] | 49 | 	.llseek		= generic_file_llseek, | 
 | 50 | }; | 
 | 51 |  | 
| Arjan van de Ven | c5ef1c4 | 2007-02-12 00:55:40 -0800 | [diff] [blame] | 52 | const struct inode_operations ramfs_file_inode_operations = { | 
| Nick Piggin | 3322e79 | 2010-05-27 22:42:19 +1000 | [diff] [blame] | 53 | 	.setattr	= simple_setattr, | 
| David Howells | 642fb4d | 2006-01-06 00:11:41 -0800 | [diff] [blame] | 54 | 	.getattr	= simple_getattr, | 
 | 55 | }; |