From: Al Viro Date: Sun, 10 Jun 2012 09:04:43 +0000 (-0400) Subject: don't modify od->filp at all X-Git-Tag: v3.6-rc1~152^2~83 X-Git-Url: https://www.infradead.org/git/?a=commitdiff_plain;h=3d8a00d2099ebc6d5a6e95fadaf861709d9919a8;p=users%2Fhch%2Fdma-mapping.git don't modify od->filp at all make put_filp() conditional on flag set by finish_open() Signed-off-by: Al Viro --- diff --git a/fs/namei.c b/fs/namei.c index 7a33f074e5bd..18b9326d951f 100644 --- a/fs/namei.c +++ b/fs/namei.c @@ -2708,10 +2708,8 @@ out: path_put(&nd->root); if (base) fput(base); - if (od.filp) { - BUG_ON(od.filp->f_path.dentry); + if (!(opened & FILE_OPENED)) put_filp(od.filp); - } if (res == ERR_PTR(-EOPENSTALE)) { if (flags & LOOKUP_RCU) res = ERR_PTR(-ECHILD); diff --git a/fs/open.c b/fs/open.c index 89589bd3993c..c87f98201c29 100644 --- a/fs/open.c +++ b/fs/open.c @@ -786,15 +786,14 @@ struct file *finish_open(struct opendata *od, struct dentry *dentry, int *opened) { struct file *res; + BUG_ON(*opened & FILE_OPENED); /* once it's opened, it's opened */ mntget(od->mnt); dget(dentry); res = do_dentry_open(dentry, od->mnt, od->filp, open, current_cred()); - if (!IS_ERR(res)) { + if (!IS_ERR(res)) *opened |= FILE_OPENED; - od->filp = NULL; - } return res; }