diff options
author | Tejun Heo <htejun@gmail.com> | 2007-06-13 15:27:22 -0400 |
---|---|---|
committer | Greg Kroah-Hartman <gregkh@suse.de> | 2007-07-11 19:09:08 -0400 |
commit | 608e266a2d4e62c1b98c1c573064b6afe8c06a58 (patch) | |
tree | 73d670ab6c315b42273bc9d2731ec2b8e7c199af /fs/sysfs/inode.c | |
parent | f0b0af4792d751106e2003f96af76fa95e10c68d (diff) |
sysfs: make kobj point to sysfs_dirent instead of dentry
As kobj sysfs dentries and inodes are gonna be made reclaimable,
dentry can't be used as naming token for sysfs file/directory, replace
kobj->dentry with kobj->sd. The only external interface change is
shadow directory handling. All other changes are contained in kobj
and sysfs.
Signed-off-by: Tejun Heo <htejun@gmail.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
Diffstat (limited to 'fs/sysfs/inode.c')
-rw-r--r-- | fs/sysfs/inode.c | 11 |
1 files changed, 6 insertions, 5 deletions
diff --git a/fs/sysfs/inode.c b/fs/sysfs/inode.c index e2f6ef138d20..1be853706e99 100644 --- a/fs/sysfs/inode.c +++ b/fs/sysfs/inode.c | |||
@@ -275,22 +275,23 @@ void sysfs_drop_dentry(struct sysfs_dirent *sd) | |||
275 | } | 275 | } |
276 | } | 276 | } |
277 | 277 | ||
278 | int sysfs_hash_and_remove(struct dentry * dir, const char * name) | 278 | int sysfs_hash_and_remove(struct sysfs_dirent *dir_sd, const char *name) |
279 | { | 279 | { |
280 | struct dentry *dir; | ||
280 | struct sysfs_dirent **pos, *sd; | 281 | struct sysfs_dirent **pos, *sd; |
281 | struct sysfs_dirent *parent_sd; | ||
282 | int found = 0; | 282 | int found = 0; |
283 | 283 | ||
284 | if (!dir) | 284 | if (!dir_sd) |
285 | return -ENOENT; | 285 | return -ENOENT; |
286 | 286 | ||
287 | dir = dir_sd->s_dentry; | ||
288 | |||
287 | if (dir->d_inode == NULL) | 289 | if (dir->d_inode == NULL) |
288 | /* no inode means this hasn't been made visible yet */ | 290 | /* no inode means this hasn't been made visible yet */ |
289 | return -ENOENT; | 291 | return -ENOENT; |
290 | 292 | ||
291 | parent_sd = dir->d_fsdata; | ||
292 | mutex_lock_nested(&dir->d_inode->i_mutex, I_MUTEX_PARENT); | 293 | mutex_lock_nested(&dir->d_inode->i_mutex, I_MUTEX_PARENT); |
293 | for (pos = &parent_sd->s_children; *pos; pos = &(*pos)->s_sibling) { | 294 | for (pos = &dir_sd->s_children; *pos; pos = &(*pos)->s_sibling) { |
294 | sd = *pos; | 295 | sd = *pos; |
295 | 296 | ||
296 | if (!sysfs_type(sd)) | 297 | if (!sysfs_type(sd)) |