diff options
author | Al Viro <viro@zeniv.linux.org.uk> | 2018-04-30 19:51:43 -0400 |
---|---|---|
committer | Al Viro <viro@zeniv.linux.org.uk> | 2018-05-22 14:27:59 -0400 |
commit | 6b9cceead0d1fc478fbc25a7d8d8f006d061a1a2 (patch) | |
tree | 2d0674a495d9ebf91dcf5cd2a265522b88c14c46 | |
parent | 18fbbfc2bfab4c45074bddb16c478b4366a265d5 (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.c | 20 | ||||
-rw-r--r-- | fs/hfs/inode.c | 3 |
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); | ||
46 | done: | ||
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); |
546 | out: | 546 | out: |
547 | d_add(dentry, inode); | 547 | return d_splice_alias(inode, dentry); |
548 | return NULL; | ||
549 | } | 548 | } |
550 | 549 | ||
551 | void hfs_evict_inode(struct inode *inode) | 550 | void hfs_evict_inode(struct inode *inode) |