nfsd: fix NULL dereference in nfsd_statfs()
The commit ebabe9a900
pass a struct path to vfs_statfs
introduced the struct path initialization, and this seems to trigger
an Oops on my machine.
fh_dentry field may be NULL and set later in fh_verify(), thus the
initialization of path must be after fh_verify().
Signed-off-by: Takashi Iwai <tiwai@suse.de>
Reviewed-by: Christoph Hellwig <hch@lst.de>
Reviewed-by: Minchan Kim <minchan.kim@gmail.com>
Signed-off-by: J. Bruce Fields <bfields@redhat.com>
This commit is contained in:
parent
f632265d0f
commit
f6360efb83
@ -2033,15 +2033,17 @@ out:
|
|||||||
__be32
|
__be32
|
||||||
nfsd_statfs(struct svc_rqst *rqstp, struct svc_fh *fhp, struct kstatfs *stat, int access)
|
nfsd_statfs(struct svc_rqst *rqstp, struct svc_fh *fhp, struct kstatfs *stat, int access)
|
||||||
{
|
{
|
||||||
struct path path = {
|
|
||||||
.mnt = fhp->fh_export->ex_path.mnt,
|
|
||||||
.dentry = fhp->fh_dentry,
|
|
||||||
};
|
|
||||||
__be32 err;
|
__be32 err;
|
||||||
|
|
||||||
err = fh_verify(rqstp, fhp, 0, NFSD_MAY_NOP | access);
|
err = fh_verify(rqstp, fhp, 0, NFSD_MAY_NOP | access);
|
||||||
if (!err && vfs_statfs(&path, stat))
|
if (!err) {
|
||||||
err = nfserr_io;
|
struct path path = {
|
||||||
|
.mnt = fhp->fh_export->ex_path.mnt,
|
||||||
|
.dentry = fhp->fh_dentry,
|
||||||
|
};
|
||||||
|
if (vfs_statfs(&path, stat))
|
||||||
|
err = nfserr_io;
|
||||||
|
}
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user