From: Maneesh Soni <maneesh@in.ibm.com>
To: Hidetoshi Seto <seto.hidetoshi@jp.fujitsu.com>
Cc: Greg KH <gregkh@suse.de>,
Linux Kernel list <linux-kernel@vger.kernel.org>
Subject: Re: [PATCH 2.6.18] sysfs: remove duplicated dput in sysfs_update_file
Date: Thu, 21 Sep 2006 08:49:21 +0530 [thread overview]
Message-ID: <20060921031921.GA7183@in.ibm.com> (raw)
In-Reply-To: <4510EFD8.2050608@jp.fujitsu.com>
On Wed, Sep 20, 2006 at 04:38:00PM +0900, Hidetoshi Seto wrote:
> 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);
>
> -
>
Looks good to me..
Thanks
Maneesh
next prev parent reply other threads:[~2006-09-21 3:19 UTC|newest]
Thread overview: 5+ messages / expand[flat|nested] mbox.gz Atom feed top
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 ` Maneesh Soni [this message]
2006-09-28 7:02 ` patch sysfs-remove-duplicated-dput-in-sysfs_update_file.patch " gregkh
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20060921031921.GA7183@in.ibm.com \
--to=maneesh@in.ibm.com \
--cc=gregkh@suse.de \
--cc=linux-kernel@vger.kernel.org \
--cc=seto.hidetoshi@jp.fujitsu.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox