[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-Id: <20080917131419.e6b7622e.akpm@linux-foundation.org>
Date: Wed, 17 Sep 2008 13:14:19 -0700
From: Andrew Morton <akpm@...ux-foundation.org>
To: Nick Piggin <npiggin@...e.de>
Cc: mingo@...e.hu, a.p.zijlstra@...llo.nl,
linux-kernel@...r.kernel.org, mpm@...enic.com,
Hugh Dickins <hugh@...itas.com>
Subject: Re: [patch] mm: tiny-shmem fix lor, mmap_sem vs i_mutex
On Mon, 15 Sep 2008 00:12:31 +0200
Nick Piggin <npiggin@...e.de> wrote:
> tiny-shmem calls do_truncate in shmem_file_setup. do_truncate takes i_mutex,
> and shmem_file_setup is called with mmap_sem held. However i_mutex nests
> outside mmap_sem.
>
> Copy the code in shmem.c to avoid this problem.
>
It's a bit unfortunate (as in: arse-about) that we end up creating new
files deep within the mmap code, but I guess we won't be changing that
in a hurry.
> ---
> Index: linux-2.6/mm/tiny-shmem.c
> ===================================================================
> --- linux-2.6.orig/mm/tiny-shmem.c
> +++ linux-2.6/mm/tiny-shmem.c
> @@ -65,31 +65,25 @@ struct file *shmem_file_setup(char *name
> if (!dentry)
> goto put_memory;
>
> + error = -ENFILE;
> + file = get_empty_filp();
> + if (!file)
> + goto put_dentry;
> +
> error = -ENOSPC;
> inode = ramfs_get_inode(root->d_sb, S_IFREG | S_IRWXUGO, 0);
> if (!inode)
> - goto put_dentry;
> -
> - d_instantiate(dentry, inode);
> - error = -ENFILE;
> - file = alloc_file(shm_mnt, dentry, FMODE_WRITE | FMODE_READ,
> - &ramfs_file_operations);
> - if (!file)
> - goto put_dentry;
> -
> - inode->i_nlink = 0; /* It is unlinked */
> -
> - /* notify everyone as to the change of file size */
> - error = do_truncate(dentry, size, 0, file);
> - if (error < 0)
> goto close_file;
>
> + d_instantiate(dentry, inode);
> + inode->i_size = size;
> + inode->i_nlink = 0; /* It is unlinked */
> + init_file(file, shm_mnt, dentry, FMODE_WRITE | FMODE_READ,
> + &ramfs_file_operations);
> return file;
>
> close_file:
> put_filp(file);
> - return ERR_PTR(error);
> -
> put_dentry:
> dput(dentry);
> put_memory:
That's a fairly substantial change. Was it runtime tested?
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/
Powered by blists - more mailing lists