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 | }; |