2  * tiny-shmem.c: simple shmemfs and tmpfs using ramfs code
 
   4  * Matt Mackall <mpm@selenic.com> January, 2004
 
   5  * derived from mm/shmem.c and fs/ramfs/inode.c
 
   7  * This is intended for small system where the benefits of the full
 
   8  * shmem code (swap-backed and resource-limited) are outweighed by
 
   9  * their complexity. On systems without swap this code should be
 
  10  * effectively equivalent, but much lighter weight.
 
  14 #include <linux/init.h>
 
  15 #include <linux/devfs_fs_kernel.h>
 
  16 #include <linux/vfs.h>
 
  17 #include <linux/mount.h>
 
  18 #include <linux/file.h>
 
  20 #include <linux/module.h>
 
  21 #include <linux/swap.h>
 
  22 #include <linux/ramfs.h>
 
  24 static struct file_system_type tmpfs_fs_type = {
 
  26         .get_sb         = ramfs_get_sb,
 
  27         .kill_sb        = kill_litter_super,
 
  30 static struct vfsmount *shm_mnt;
 
  32 static int __init init_tmpfs(void)
 
  34         BUG_ON(register_filesystem(&tmpfs_fs_type) != 0);
 
  39         shm_mnt = kern_mount(&tmpfs_fs_type);
 
  40         BUG_ON(IS_ERR(shm_mnt));
 
  44 module_init(init_tmpfs)
 
  47  * shmem_file_setup - get an unlinked file living in tmpfs
 
  49  * @name: name for dentry (to be seen in /proc/<pid>/maps
 
  50  * @size: size to be set for the file
 
  53 struct file *shmem_file_setup(char *name, loff_t size, unsigned long flags)
 
  58         struct dentry *dentry, *root;
 
  62                 return (void *)shm_mnt;
 
  66         this.len = strlen(name);
 
  67         this.hash = 0; /* will go */
 
  68         root = shm_mnt->mnt_root;
 
  69         dentry = d_alloc(root, &this);
 
  74         file = get_empty_filp();
 
  79         inode = ramfs_get_inode(root->d_sb, S_IFREG | S_IRWXUGO, 0);
 
  83         d_instantiate(dentry, inode);
 
  84         inode->i_nlink = 0;     /* It is unlinked */
 
  86         file->f_vfsmnt = mntget(shm_mnt);
 
  87         file->f_dentry = dentry;
 
  88         file->f_mapping = inode->i_mapping;
 
  89         file->f_op = &ramfs_file_operations;
 
  90         file->f_mode = FMODE_WRITE | FMODE_READ;
 
  92         /* notify everyone as to the change of file size */
 
  93         error = do_truncate(dentry, size, 0, file);
 
 104         return ERR_PTR(error);
 
 108  * shmem_zero_setup - setup a shared anonymous mapping
 
 110  * @vma: the vma to be mmapped is prepared by do_mmap_pgoff
 
 112 int shmem_zero_setup(struct vm_area_struct *vma)
 
 115         loff_t size = vma->vm_end - vma->vm_start;
 
 117         file = shmem_file_setup("dev/zero", size, vma->vm_flags);
 
 119                 return PTR_ERR(file);
 
 124         vma->vm_ops = &generic_file_vm_ops;
 
 128 int shmem_unuse(swp_entry_t entry, struct page *page)
 
 133 int shmem_mmap(struct file *file, struct vm_area_struct *vma)
 
 137         return ramfs_nommu_mmap(file, vma);
 
 144 unsigned long shmem_get_unmapped_area(struct file *file,
 
 150         return ramfs_nommu_get_unmapped_area(file, addr, len, pgoff, flags);