blob: 12af0490322f9d8d5354258c35f8fe4a4762c9d9 [file] [log] [blame]
David Howells642fb4d2006-01-06 00:11:41 -08001/* 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 Howells642fb4d2006-01-06 00:11:41 -080027#include <linux/fs.h>
Dimitri Gorokhovik131612d2006-12-29 16:48:24 -080028#include <linux/mm.h>
Adrian Bunk4488c592008-04-29 00:58:51 -070029#include <linux/ramfs.h>
Kirill A. Shutemov31b4beb2016-09-19 14:44:18 -070030#include <linux/sched.h>
Adrian Bunk4488c592008-04-29 00:58:51 -070031
32#include "internal.h"
David Howells642fb4d2006-01-06 00:11:41 -080033
Kirill A. Shutemov31b4beb2016-09-19 14:44:18 -070034static 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 Ven4b6f5d22006-03-28 01:56:42 -080041const struct file_operations ramfs_file_operations = {
Al Viroaad4f8b2014-04-02 14:33:16 -040042 .read_iter = generic_file_read_iter,
Al Viro81742022014-04-03 03:17:43 -040043 .write_iter = generic_file_write_iter,
David Howells642fb4d2006-01-06 00:11:41 -080044 .mmap = generic_file_mmap,
Christoph Hellwig1b061d92010-05-26 17:53:41 +020045 .fsync = noop_fsync,
Jens Axboe5ffc4ef2007-06-01 11:49:19 +020046 .splice_read = generic_file_splice_read,
Al Viro8d020762014-04-05 04:27:08 -040047 .splice_write = iter_file_splice_write,
David Howells642fb4d2006-01-06 00:11:41 -080048 .llseek = generic_file_llseek,
Kirill A. Shutemov31b4beb2016-09-19 14:44:18 -070049 .get_unmapped_area = ramfs_mmu_get_unmapped_area,
David Howells642fb4d2006-01-06 00:11:41 -080050};
51
Arjan van de Venc5ef1c42007-02-12 00:55:40 -080052const struct inode_operations ramfs_file_inode_operations = {
Nick Piggin3322e792010-05-27 22:42:19 +100053 .setattr = simple_setattr,
David Howells642fb4d2006-01-06 00:11:41 -080054 .getattr = simple_getattr,
55};