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> |
Kirill A. Shutemov | 31b4beb | 2016-09-19 14:44:18 -0700 | [diff] [blame] | 30 | #include <linux/sched.h> |
Adrian Bunk | 4488c59 | 2008-04-29 00:58:51 -0700 | [diff] [blame] | 31 | |
| 32 | #include "internal.h" |
David Howells | 642fb4d | 2006-01-06 00:11:41 -0800 | [diff] [blame] | 33 | |
Kirill A. Shutemov | 31b4beb | 2016-09-19 14:44:18 -0700 | [diff] [blame] | 34 | static unsigned long ramfs_mmu_get_unmapped_area(struct file *file, |
| 35 | unsigned long addr, unsigned long len, unsigned long pgoff, |
| 36 | unsigned long flags) |
| 37 | { |
| 38 | return current->mm->get_unmapped_area(file, addr, len, pgoff, flags); |
| 39 | } |
| 40 | |
Arjan van de Ven | 4b6f5d2 | 2006-03-28 01:56:42 -0800 | [diff] [blame] | 41 | const struct file_operations ramfs_file_operations = { |
Al Viro | aad4f8b | 2014-04-02 14:33:16 -0400 | [diff] [blame] | 42 | .read_iter = generic_file_read_iter, |
Al Viro | 8174202 | 2014-04-03 03:17:43 -0400 | [diff] [blame] | 43 | .write_iter = generic_file_write_iter, |
David Howells | 642fb4d | 2006-01-06 00:11:41 -0800 | [diff] [blame] | 44 | .mmap = generic_file_mmap, |
Christoph Hellwig | 1b061d9 | 2010-05-26 17:53:41 +0200 | [diff] [blame] | 45 | .fsync = noop_fsync, |
Jens Axboe | 5ffc4ef | 2007-06-01 11:49:19 +0200 | [diff] [blame] | 46 | .splice_read = generic_file_splice_read, |
Al Viro | 8d02076 | 2014-04-05 04:27:08 -0400 | [diff] [blame] | 47 | .splice_write = iter_file_splice_write, |
David Howells | 642fb4d | 2006-01-06 00:11:41 -0800 | [diff] [blame] | 48 | .llseek = generic_file_llseek, |
Kirill A. Shutemov | 31b4beb | 2016-09-19 14:44:18 -0700 | [diff] [blame] | 49 | .get_unmapped_area = ramfs_mmu_get_unmapped_area, |
David Howells | 642fb4d | 2006-01-06 00:11:41 -0800 | [diff] [blame] | 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 | }; |