public inbox for linux-kernel@vger.kernel.org
 help / color / mirror / Atom feed
* [PATCH 2.6.18] sysfs: remove duplicated dput in sysfs_update_file
@ 2006-09-20  7:38 Hidetoshi Seto
  2006-09-20  7:49 ` [PATCH 2.6.18] sysfs: update obsolete comment " Hidetoshi Seto
                   ` (2 more replies)
  0 siblings, 3 replies; 5+ messages in thread
From: Hidetoshi Seto @ 2006-09-20  7:38 UTC (permalink / raw)
  To: Greg KH; +Cc: Linux Kernel list

Following function can drops d_count twice against one reference
by lookup_one_len.

<SOURCE>
/**
 * sysfs_update_file - update the modified timestamp on an object attribute.
 * @kobj: object we're acting for.
 * @attr: attribute descriptor.
 */
int sysfs_update_file(struct kobject * kobj, const struct attribute * attr)
{
        struct dentry * dir = kobj->dentry;
        struct dentry * victim;
        int res = -ENOENT;

        mutex_lock(&dir->d_inode->i_mutex);
        victim = lookup_one_len(attr->name, dir, strlen(attr->name));
        if (!IS_ERR(victim)) {
                /* make sure dentry is really there */
                if (victim->d_inode &&
                    (victim->d_parent->d_inode == dir->d_inode)) {
                        victim->d_inode->i_mtime = CURRENT_TIME;
                        fsnotify_modify(victim);

                        /**
                         * Drop reference from initial sysfs_get_dentry().
                         */
                        dput(victim);
                        res = 0;
                } else
                        d_drop(victim);

                /**
                 * Drop the reference acquired from sysfs_get_dentry() above.
                 */
                dput(victim);
        }
        mutex_unlock(&dir->d_inode->i_mutex);

        return res;
}
</SOURCE>

PCI-hotplug (drivers/pci/hotplug/pci_hotplug_core.c) is only user of
this function. I confirmed that dentry of /sys/bus/pci/slots/XXX/*
have negative d_count value.

This patch removes unnecessary dput().

Signed-off-by: Hidetoshi Seto <seto.hidetoshi@jp.fujitsu.com>

---
 fs/sysfs/file.c |    5 -----
 1 files changed, 5 deletions(-)

Index: linux-2.6.18/fs/sysfs/file.c
===================================================================
--- linux-2.6.18.orig/fs/sysfs/file.c
+++ linux-2.6.18/fs/sysfs/file.c
@@ -483,11 +483,6 @@
 		    (victim->d_parent->d_inode == dir->d_inode)) {
 			victim->d_inode->i_mtime = CURRENT_TIME;
 			fsnotify_modify(victim);
-
-			/**
-			 * Drop reference from initial sysfs_get_dentry().
-			 */
-			dput(victim);
 			res = 0;
 		} else
 			d_drop(victim);


^ permalink raw reply	[flat|nested] 5+ messages in thread

end of thread, other threads:[~2006-09-28  7:02 UTC | newest]

Thread overview: 5+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2006-09-20  7:38 [PATCH 2.6.18] sysfs: remove duplicated dput in sysfs_update_file Hidetoshi Seto
2006-09-20  7:49 ` [PATCH 2.6.18] sysfs: update obsolete comment " Hidetoshi Seto
2006-09-28  7:02   ` patch sysfs-update-obsolete-comment-in-sysfs_update_file.patch added to gregkh-2.6 tree gregkh
2006-09-21  3:19 ` [PATCH 2.6.18] sysfs: remove duplicated dput in sysfs_update_file Maneesh Soni
2006-09-28  7:02 ` patch sysfs-remove-duplicated-dput-in-sysfs_update_file.patch added to gregkh-2.6 tree gregkh

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox