|
@@ -1800,13 +1800,18 @@ static int build_dentry_path(struct dentry *dentry,
|
|
int *pfreepath)
|
|
int *pfreepath)
|
|
{
|
|
{
|
|
char *path;
|
|
char *path;
|
|
|
|
+ struct inode *dir;
|
|
|
|
|
|
- if (ceph_snap(d_inode(dentry->d_parent)) == CEPH_NOSNAP) {
|
|
|
|
- *pino = ceph_ino(d_inode(dentry->d_parent));
|
|
|
|
|
|
+ rcu_read_lock();
|
|
|
|
+ dir = d_inode_rcu(dentry->d_parent);
|
|
|
|
+ if (dir && ceph_snap(dir) == CEPH_NOSNAP) {
|
|
|
|
+ *pino = ceph_ino(dir);
|
|
|
|
+ rcu_read_unlock();
|
|
*ppath = dentry->d_name.name;
|
|
*ppath = dentry->d_name.name;
|
|
*ppathlen = dentry->d_name.len;
|
|
*ppathlen = dentry->d_name.len;
|
|
return 0;
|
|
return 0;
|
|
}
|
|
}
|
|
|
|
+ rcu_read_unlock();
|
|
path = ceph_mdsc_build_path(dentry, ppathlen, pino, 1);
|
|
path = ceph_mdsc_build_path(dentry, ppathlen, pino, 1);
|
|
if (IS_ERR(path))
|
|
if (IS_ERR(path))
|
|
return PTR_ERR(path);
|
|
return PTR_ERR(path);
|