diff options
Diffstat (limited to 'fs/dcache.c')
-rw-r--r-- | fs/dcache.c | 21 |
1 files changed, 12 insertions, 9 deletions
diff --git a/fs/dcache.c b/fs/dcache.c index 1710d2484fd9..c6fd1f27da57 100644 --- a/fs/dcache.c +++ b/fs/dcache.c | |||
@@ -174,9 +174,12 @@ static struct dentry *d_kill(struct dentry *dentry) | |||
174 | dentry_stat.nr_dentry--; /* For d_free, below */ | 174 | dentry_stat.nr_dentry--; /* For d_free, below */ |
175 | /*drops the locks, at that point nobody can reach this dentry */ | 175 | /*drops the locks, at that point nobody can reach this dentry */ |
176 | dentry_iput(dentry); | 176 | dentry_iput(dentry); |
177 | parent = dentry->d_parent; | 177 | if (IS_ROOT(dentry)) |
178 | parent = NULL; | ||
179 | else | ||
180 | parent = dentry->d_parent; | ||
178 | d_free(dentry); | 181 | d_free(dentry); |
179 | return dentry == parent ? NULL : parent; | 182 | return parent; |
180 | } | 183 | } |
181 | 184 | ||
182 | /* | 185 | /* |
@@ -666,11 +669,12 @@ static void shrink_dcache_for_umount_subtree(struct dentry *dentry) | |||
666 | BUG(); | 669 | BUG(); |
667 | } | 670 | } |
668 | 671 | ||
669 | parent = dentry->d_parent; | 672 | if (IS_ROOT(dentry)) |
670 | if (parent == dentry) | ||
671 | parent = NULL; | 673 | parent = NULL; |
672 | else | 674 | else { |
675 | parent = dentry->d_parent; | ||
673 | atomic_dec(&parent->d_count); | 676 | atomic_dec(&parent->d_count); |
677 | } | ||
674 | 678 | ||
675 | list_del(&dentry->d_u.d_child); | 679 | list_del(&dentry->d_u.d_child); |
676 | detached++; | 680 | detached++; |
@@ -1723,7 +1727,7 @@ static int d_isparent(struct dentry *p1, struct dentry *p2) | |||
1723 | { | 1727 | { |
1724 | struct dentry *p; | 1728 | struct dentry *p; |
1725 | 1729 | ||
1726 | for (p = p2; p->d_parent != p; p = p->d_parent) { | 1730 | for (p = p2; !IS_ROOT(p); p = p->d_parent) { |
1727 | if (p->d_parent == p1) | 1731 | if (p->d_parent == p1) |
1728 | return 1; | 1732 | return 1; |
1729 | } | 1733 | } |
@@ -2168,10 +2172,9 @@ int is_subdir(struct dentry * new_dentry, struct dentry * old_dentry) | |||
2168 | seq = read_seqbegin(&rename_lock); | 2172 | seq = read_seqbegin(&rename_lock); |
2169 | for (;;) { | 2173 | for (;;) { |
2170 | if (new_dentry != old_dentry) { | 2174 | if (new_dentry != old_dentry) { |
2171 | struct dentry * parent = new_dentry->d_parent; | 2175 | if (IS_ROOT(new_dentry)) |
2172 | if (parent == new_dentry) | ||
2173 | break; | 2176 | break; |
2174 | new_dentry = parent; | 2177 | new_dentry = new_dentry->d_parent; |
2175 | continue; | 2178 | continue; |
2176 | } | 2179 | } |
2177 | result = 1; | 2180 | result = 1; |