[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <51C2E12F.4000603@cogentembedded.com>
Date: Thu, 20 Jun 2013 15:02:07 +0400
From: Sergei Shtylyov <sergei.shtylyov@...entembedded.com>
To: Aaron Lu <aaron.lu@...el.com>
CC: Tejun Heo <tj@...nel.org>, Matthew Garrett <mjg@...hat.com>,
Liu Jiang <liuj97@...il.com>,
Dirk Griesbach <spamthis@...enet.de>,
linux-ide@...r.kernel.org, linux-kernel@...r.kernel.org,
Liu Jiang <jiang.liu@...wei.com>,
Aaron Lu <aaron.lwe@...il.com>
Subject: Re: [PATCH] libata: remove dead code from libata-acpi.c
Hello.
On 20-06-2013 6:26, Aaron Lu wrote:
>>>>> From: Liu Jiang <liu97@...il.com>
>>>>>
>>>>> Commit 30dcf76acc69 "libata: migrate ACPI code over to new bindings"
>>>>> removed ACPI dock notification related code, but there's some dead
>>>>> code left, so clean up it.
[...]
> Subject: [PATCH] libata-acpi: add back ACPI based hotplug functionality
> Commit 30dcf76acc mistakenly dropped the code to register hotplug
Please specify the summary line for this commit, the same as was
done by Liu above (may use parens instead of quotes).
> notificaion handler for ATA port/devices, causing regression for people
> using ATA bay, as bug #59871 shows.
> Fix this by adding back the hotplug notification handler registration
> code. Since this code has to be run once and notification needs to be
> installed on every ATA port/devices handle no matter if there is actual
> device attached, we can't do this in binding time for ATA device ACPI
> handle, as the binding only occurs when a SCSI device is created, i.e.
> there is device attached. So introduced the ata_acpi_hotplug_init
> function to loop scan all ATA ACPI handles and if it is available,
> install the notification handler for it during ATA init time.
> With the ATA ACPI handle binding to SCSI device tree, it is possible now
> that when the SCSI hotplug work removes the SCSI device, the ACPI unbind
> function will find that the corresponding ACPI device has already been
> deleted by dock driver, causing a scaring message like:
> [ 128.263966] scsi 4:0:0:0: Oops, 'acpi_handle' corrupt
> Fix this by waiting for SCSI hotplug task finish in our notificaion
> handler, so that the removal of ACPI device done in ACPI unbind function
> triggered by the removal of SCSI device is run earlier when ACPI device
> is still available.
> References: https://bugzilla.kernel.org/show_bug.cgi?id=59871
> Reported-and-bisected-by: Dirk Griesbach <spamthis@...enet.de>
> Cc: <stable@...r.kernel.org>
> Signed-off-by: Aaron Lu <aaron.lu@...el.com>
> ---
> drivers/ata/libata-acpi.c | 34 +++++++++++++++++++++++++++++++++-
> drivers/ata/libata-core.c | 2 ++
> drivers/ata/libata.h | 2 ++
> 3 files changed, 37 insertions(+), 1 deletion(-)
> diff --git a/drivers/ata/libata-acpi.c b/drivers/ata/libata-acpi.c
> index 87f2f39..0ad54bb 100644
> --- a/drivers/ata/libata-acpi.c
> +++ b/drivers/ata/libata-acpi.c
[...]
> @@ -214,6 +216,36 @@ static const struct acpi_dock_ops ata_acpi_ap_dock_ops = {
> .uevent = ata_acpi_ap_uevent,
> };
>
> +void ata_acpi_hotplug_init(struct ata_host *host)
> +{
> + int i;
> +
> + for (i = 0; i < host->n_ports; i++) {
> + struct ata_port *ap = host->ports[i];
> + acpi_handle handle;
> + struct ata_device *dev;
> +
> + if (!ap)
> + continue;
> +
> + handle = ata_ap_acpi_handle(ap);
> + if (handle) {
> + /* we might be on a docking station */
> + register_hotplug_dock_device(handle,
> + &ata_acpi_ap_dock_ops, ap);
Please indent this line under the next character after ( above.
> + }
> +
> + ata_for_each_dev(dev, &ap->link, ALL) {
> + handle = ata_dev_acpi_handle(dev);
> + if (handle) {
> + /* we might be on a docking station */
> + register_hotplug_dock_device(handle,
> + &ata_acpi_dev_dock_ops, dev);
Same comment.
WBR, Sergei
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/
Powered by blists - more mailing lists