Commit d8b16b3d authored by Sage Weil's avatar Sage Weil

ceph: fix bad pointer dereference in ceph_fill_trace

We dereference *in a few lines down, but only set it on rename.  It is
apparently pretty rare for this to trigger, but I have been hitting it
with a clustered MDSs.
Signed-off-by: default avatarSage Weil <sage@newdream.net>
parent df9f86fa
...@@ -1055,7 +1055,8 @@ int ceph_fill_trace(struct super_block *sb, struct ceph_mds_request *req, ...@@ -1055,7 +1055,8 @@ int ceph_fill_trace(struct super_block *sb, struct ceph_mds_request *req,
ininfo = rinfo->targeti.in; ininfo = rinfo->targeti.in;
vino.ino = le64_to_cpu(ininfo->ino); vino.ino = le64_to_cpu(ininfo->ino);
vino.snap = le64_to_cpu(ininfo->snapid); vino.snap = le64_to_cpu(ininfo->snapid);
if (!dn->d_inode) { in = dn->d_inode;
if (!in) {
in = ceph_get_inode(sb, vino); in = ceph_get_inode(sb, vino);
if (IS_ERR(in)) { if (IS_ERR(in)) {
pr_err("fill_trace bad get_inode " pr_err("fill_trace bad get_inode "
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment