From: "Rafael J. Wysocki" <rjw@sisk.pl>
To: Toshi Kani <toshi.kani@hp.com>
Cc: ACPI Devel Maling List <linux-acpi@vger.kernel.org>,
LKML <linux-kernel@vger.kernel.org>,
Bjorn Helgaas <bhelgaas@google.com>
Subject: Re: [PATCH] ACPI: Do not fail acpi_bind_one() if device is already bound correctly
Date: Sat, 03 Aug 2013 02:47:04 +0200 [thread overview]
Message-ID: <3596381.TNBAQz9C67@vostro.rjw.lan> (raw)
In-Reply-To: <1375483118.10300.113.camel@misato.fc.hp.com>
On Friday, August 02, 2013 04:38:38 PM Toshi Kani wrote:
> On Fri, 2013-08-02 at 00:33 +0200, Rafael J. Wysocki wrote:
> > From: Rafael J. Wysocki <rafael.j.wysocki@intel.com>
> >
> > Modify acpi_bind_one() so that it doesn't fail if the device
> > represented by its first argument has already been bound to the
> > given ACPI handle (second argument), because that is not a good
> > enough reason for returning an error code.
>
> While it seems reasonable to allow such case, I do not think we will hit
> this case under the normal scenarios. So, I do not think we need to
> make this change now unless it actually solves Yasuaki's issue (which I
> am guessing not).
In theory it should be possible to call acpi_bind_one() twice in a row
for the same dev and the same handle without failure, that simply is
logical. The patch may not fix any problems visible now, but returning an
error code in such a case is simply incorrect.
Thanks,
Rafael
> > Signed-off-by: Rafael J. Wysocki <rafael.j.wysocki@intel.com>
> > ---
> > drivers/acpi/glue.c | 15 +++++++++++----
> > 1 file changed, 11 insertions(+), 4 deletions(-)
> >
> > Index: linux-pm/drivers/acpi/glue.c
> > ===================================================================
> > --- linux-pm.orig/drivers/acpi/glue.c
> > +++ linux-pm/drivers/acpi/glue.c
> > @@ -143,7 +143,10 @@ int acpi_bind_one(struct device *dev, ac
> > list_for_each_entry(pn, &acpi_dev->physical_node_list, node)
> > if (pn->dev == dev) {
> > dev_warn(dev, "Already associated with ACPI node\n");
> > - goto err_free;
> > + if (ACPI_HANDLE(dev) == handle)
> > + retval = 0;
> > +
> > + goto out_free;
> > }
> >
> > /* allocate physical node id according to physical_node_id_bitmap */
> > @@ -152,7 +155,7 @@ int acpi_bind_one(struct device *dev, ac
> > ACPI_MAX_PHYSICAL_NODE);
> > if (physical_node->node_id >= ACPI_MAX_PHYSICAL_NODE) {
> > retval = -ENOSPC;
> > - goto err_free;
> > + goto out_free;
> > }
> >
> > set_bit(physical_node->node_id, acpi_dev->physical_node_id_bitmap);
> > @@ -185,10 +188,14 @@ int acpi_bind_one(struct device *dev, ac
> > put_device(dev);
> > return retval;
> >
> > - err_free:
> > + out_free:
> > mutex_unlock(&acpi_dev->physical_node_lock);
> > kfree(physical_node);
> > - goto err;
> > + if (retval)
> > + goto err;
> > +
> > + put_device(dev);
> > + return 0;
> > }
> > EXPORT_SYMBOL_GPL(acpi_bind_one);
> >
> >
> > --
> > To unsubscribe from this list: send the line "unsubscribe linux-acpi" in
> > the body of a message to majordomo@vger.kernel.org
> > More majordomo info at http://vger.kernel.org/majordomo-info.html
>
>
> --
> To unsubscribe from this list: send the line "unsubscribe linux-acpi" in
> the body of a message to majordomo@vger.kernel.org
> More majordomo info at http://vger.kernel.org/majordomo-info.html
--
I speak only for myself.
Rafael J. Wysocki, Intel Open Source Technology Center.
next prev parent reply other threads:[~2013-08-03 0:36 UTC|newest]
Thread overview: 10+ messages / expand[flat|nested] mbox.gz Atom feed top
2013-08-01 22:33 [PATCH] ACPI: Do not fail acpi_bind_one() if device is already bound correctly Rafael J. Wysocki
2013-08-02 2:48 ` Lan Tianyu
2013-08-02 13:43 ` Rafael J. Wysocki
2013-08-02 15:16 ` Lan Tianyu
2013-08-02 22:38 ` Toshi Kani
2013-08-03 0:47 ` Rafael J. Wysocki [this message]
2013-08-04 0:32 ` Toshi Kani
2013-08-04 14:03 ` Rafael J. Wysocki
2013-08-05 22:20 ` Toshi Kani
2013-08-05 22:47 ` Rafael J. Wysocki
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=3596381.TNBAQz9C67@vostro.rjw.lan \
--to=rjw@sisk.pl \
--cc=bhelgaas@google.com \
--cc=linux-acpi@vger.kernel.org \
--cc=linux-kernel@vger.kernel.org \
--cc=toshi.kani@hp.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