]> Git Repo - linux.git/commitdiff
pstore: Protect unlink with read_mutex
authorNamhyung Kim <[email protected]>
Wed, 19 Oct 2016 01:23:40 +0000 (10:23 +0900)
committerKees Cook <[email protected]>
Wed, 16 Nov 2016 00:34:31 +0000 (16:34 -0800)
When update_ms is set, pstore_get_records() will be called when there's
a new entry.  But unlink can be called at the same time and might
contend with the open-read-close loop.  Depending on the implementation
of platform driver, it may be safe or not.  But I think it'd be better
to protect those race in the first place.

Cc: Stefan Hajnoczi <[email protected]>
Signed-off-by: Namhyung Kim <[email protected]>
Signed-off-by: Kees Cook <[email protected]>
fs/pstore/inode.c

index 0d6bbcf47d5243ede507f44383565c1f9df4e486..57c0646479f51cc0baa9bd82ba3cbb5689f41696 100644 (file)
@@ -199,11 +199,14 @@ static int pstore_unlink(struct inode *dir, struct dentry *dentry)
        if (err)
                return err;
 
-       if (p->psi->erase)
+       if (p->psi->erase) {
+               mutex_lock(&p->psi->read_mutex);
                p->psi->erase(p->type, p->id, p->count,
                              d_inode(dentry)->i_ctime, p->psi);
-       else
+               mutex_unlock(&p->psi->read_mutex);
+       } else {
                return -EPERM;
+       }
 
        return simple_unlink(dir, dentry);
 }
This page took 0.055283 seconds and 4 git commands to generate.