aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorAl Viro <viro@zeniv.linux.org.uk>2018-04-30 19:51:43 -0400
committerAl Viro <viro@zeniv.linux.org.uk>2018-05-22 14:27:59 -0400
commit6b9cceead0d1fc478fbc25a7d8d8f006d061a1a2 (patch)
tree2d0674a495d9ebf91dcf5cd2a265522b88c14c46
parent18fbbfc2bfab4c45074bddb16c478b4366a265d5 (diff)
hfs: use d_splice_alias()
code is simpler that way Signed-off-by: Al Viro <viro@zeniv.linux.org.uk>
-rw-r--r--fs/hfs/dir.c20
-rw-r--r--fs/hfs/inode.c3
2 files changed, 8 insertions, 15 deletions
diff --git a/fs/hfs/dir.c b/fs/hfs/dir.c
index 75b254280ff6..3bf2ae0e467c 100644
--- a/fs/hfs/dir.c
+++ b/fs/hfs/dir.c
@@ -31,21 +31,15 @@ static struct dentry *hfs_lookup(struct inode *dir, struct dentry *dentry,
31 hfs_cat_build_key(dir->i_sb, fd.search_key, dir->i_ino, &dentry->d_name); 31 hfs_cat_build_key(dir->i_sb, fd.search_key, dir->i_ino, &dentry->d_name);
32 res = hfs_brec_read(&fd, &rec, sizeof(rec)); 32 res = hfs_brec_read(&fd, &rec, sizeof(rec));
33 if (res) { 33 if (res) {
34 hfs_find_exit(&fd); 34 if (res != -ENOENT)
35 if (res == -ENOENT) { 35 inode = ERR_PTR(res);
36 /* No such entry */ 36 } else {
37 inode = NULL; 37 inode = hfs_iget(dir->i_sb, &fd.search_key->cat, &rec);
38 goto done; 38 if (!inode)
39 } 39 inode = ERR_PTR(-EACCES);
40 return ERR_PTR(res);
41 } 40 }
42 inode = hfs_iget(dir->i_sb, &fd.search_key->cat, &rec);
43 hfs_find_exit(&fd); 41 hfs_find_exit(&fd);
44 if (!inode) 42 return d_splice_alias(inode, dentry);
45 return ERR_PTR(-EACCES);
46done:
47 d_add(dentry, inode);
48 return NULL;
49} 43}
50 44
51/* 45/*
diff --git a/fs/hfs/inode.c b/fs/hfs/inode.c
index 2538b49cc349..0612fa367bd1 100644
--- a/fs/hfs/inode.c
+++ b/fs/hfs/inode.c
@@ -544,8 +544,7 @@ static struct dentry *hfs_file_lookup(struct inode *dir, struct dentry *dentry,
544 hlist_add_fake(&inode->i_hash); 544 hlist_add_fake(&inode->i_hash);
545 mark_inode_dirty(inode); 545 mark_inode_dirty(inode);
546out: 546out:
547 d_add(dentry, inode); 547 return d_splice_alias(inode, dentry);
548 return NULL;
549} 548}
550 549
551void hfs_evict_inode(struct inode *inode) 550void hfs_evict_inode(struct inode *inode)