From: Barto <mister.freeman@laposte.net>
To: Zhang Rui <rui.zhang@intel.com>, Bjorn Helgaas <bhelgaas@google.com>
Cc: linux-pci <linux-pci@vger.kernel.org>,
chuansheng.liu@intel.com, Tejun Heo <tj@kernel.org>,
Alan Stern <stern@rowland.harvard.edu>,
Aaron Lu <aaron.lu@intel.com>,
MyMailClone@t-online.de, "Rafael J. Wysocki" <rjw@rjwysocki.net>
Subject: Re: [PATCH] PCI: Disable async suspend/resume for Jmicron chip
Date: Fri, 28 Aug 2015 19:53:15 +0200 [thread overview]
Message-ID: <55E0A00B.8020508@laposte.net> (raw)
In-Reply-To: <1440750106.5982.2.camel@rzhang1-mobl4>
I will test this new patch at the end of this email,
Jay should do the same in order to be sure that the small changes made
by Zhang Rui in this new patch really works
Le 28/08/2015 10:21, Zhang Rui a écrit :
>> In the interest of making progress on this, I reworked this to be
what I'm
>> looking for. It's not significantly different code-wise from what you
>> posted originally, so I left your Signed-off-by. But let me know if I
>> messed it up.
>>
>>
>>
>> commit 09981db5b0c9a6865aa39126b71bc87718577e4b
>> Author: Zhang Rui <rui.zhang@intel.com>
>> Date: Mon Aug 24 15:27:11 2015 -0500
>>
>> PCI: Disable async suspend/resume for JMicron multi-function
SATA/AHCI
>>
>> On multi-function JMicron SATA/PATA/AHCI devices, the PATA
controller at
>> function 1 doesn't work if it is powered on before the SATA
controller at
>> function 0. The result is that PATA doesn't work after resume, and
>> messages like this:
>>
>> pata_jmicron 0000:02:00.1: Refused to change power state,
currently in D3
>> irq 17: nobody cared (try booting with the "irqpoll" option)
>>
>> e6b7e41cdd8c ("ata: Disabling the async PM for JMicron chip 363/361")
>> solved this problem for JMicron 361 and 363 devices. With async
suspend
>> disabled, we always power on function 0 before function 1.
>>
>> Barto then reported the same problem with a JMicron 368 (see
comment #57 in
>> the bugzilla).
>>
>> Rather than extending the blacklist piecemeal, disable async
suspend for
>> all JMicron multi-function SATA/PATA/AHCI devices.
>>
>> This quirk could stay in the ahci and pata_jmicron drivers, but
it's likely
>> the problem will occur even if pata_jmicron isn't loaded until
after the
>> suspend/resume. Making it a PCI quirk ensures that we'll
preserve the
>> power-on order even if the drivers aren't loaded.
>>
>> [bhelgaas: changelog, limit to multi-function, limit to IDE/ATA]
>> Link: https://bugzilla.kernel.org/show_bug.cgi?id=81551
>> Reported-by: Barto <mister.freeman@laposte.net>
>> Signed-off-by: Zhang Rui <rui.zhang@intel.com>
>> Signed-off-by: Bjorn Helgaas <bhelgaas@google.com>
>>
>> diff --git a/drivers/ata/ahci.c b/drivers/ata/ahci.c
>> index 7e62751..a466602 100644
>> --- a/drivers/ata/ahci.c
>> +++ b/drivers/ata/ahci.c
>> @@ -351,6 +351,7 @@ static const struct pci_device_id ahci_pci_tbl[] = {
>> /* JMicron 362B and 362C have an AHCI function with IDE class code */
>> { PCI_VDEVICE(JMICRON, 0x2362), board_ahci_ign_iferr },
>> { PCI_VDEVICE(JMICRON, 0x236f), board_ahci_ign_iferr },
>> + /* May need to update quirk_jmicron_async_suspend() for additions */
>>
>> /* ATI */
>> { PCI_VDEVICE(ATI, 0x4380), board_ahci_sb600 }, /* ATI SB600 */
>> @@ -1451,18 +1452,6 @@ static int ahci_init_one(struct pci_dev *pdev,
const struct pci_device_id *ent)
>> else if (pdev->vendor == 0x177d && pdev->device == 0xa01c)
>> ahci_pci_bar = AHCI_PCI_BAR_CAVIUM;
>>
>> - /*
>> - * The JMicron chip 361/363 contains one SATA controller and one
>> - * PATA controller,for powering on these both controllers, we must
>> - * follow the sequence one by one, otherwise one of them can not be
>> - * powered on successfully, so here we disable the async suspend
>> - * method for these chips.
>> - */
>> - if (pdev->vendor == PCI_VENDOR_ID_JMICRON &&
>> - (pdev->device == PCI_DEVICE_ID_JMICRON_JMB363 ||
>> - pdev->device == PCI_DEVICE_ID_JMICRON_JMB361))
>> - device_disable_async_suspend(&pdev->dev);
>> -
>> /* acquire resources */
>> rc = pcim_enable_device(pdev);
>> if (rc)
>> diff --git a/drivers/ata/pata_jmicron.c b/drivers/ata/pata_jmicron.c
>> index 47e418b..4d1a5d2 100644
>> --- a/drivers/ata/pata_jmicron.c
>> +++ b/drivers/ata/pata_jmicron.c
>> @@ -143,18 +143,6 @@ static int jmicron_init_one (struct pci_dev
*pdev, const struct pci_device_id *i
>> };
>> const struct ata_port_info *ppi[] = { &info, NULL };
>>
>> - /*
>> - * The JMicron chip 361/363 contains one SATA controller and one
>> - * PATA controller,for powering on these both controllers, we must
>> - * follow the sequence one by one, otherwise one of them can not be
>> - * powered on successfully, so here we disable the async suspend
>> - * method for these chips.
>> - */
>> - if (pdev->vendor == PCI_VENDOR_ID_JMICRON &&
>> - (pdev->device == PCI_DEVICE_ID_JMICRON_JMB363 ||
>> - pdev->device == PCI_DEVICE_ID_JMICRON_JMB361))
>> - device_disable_async_suspend(&pdev->dev);
>> -
>> return ata_pci_bmdma_init_one(pdev, ppi, &jmicron_sht, NULL, 0);
>> }
>>
>> diff --git a/drivers/pci/quirks.c b/drivers/pci/quirks.c
>> index b6af4b0..5e35a9d 100644
>> --- a/drivers/pci/quirks.c
>> +++ b/drivers/pci/quirks.c
>> @@ -1570,6 +1570,18 @@
DECLARE_PCI_FIXUP_RESUME_EARLY(PCI_VENDOR_ID_JMICRON,
PCI_DEVICE_ID_JMICRON_JMB3
>>
>> #endif
>>
>> +static void quirk_jmicron_async_suspend(struct pci_dev *dev)
>> +{
>> + if (dev->multifunction) {
>> + device_disable_async_suspend(&dev->dev);
>> + dev_info(&dev->dev, "async suspend disabled to avoid
multi-function power-on ordering issue\n");
>> + }
>> +}
>> +DECLARE_PCI_FIXUP_CLASS_FINAL(PCI_VENDOR_ID_JMICRON, PCI_ANY,
PCI_CLASS_STORAGE_IDE, 8, quirk_jmicron_async_suspend);
>> +DECLARE_PCI_FIXUP_CLASS_FINAL(PCI_VENDOR_ID_JMICRON, PCI_ANY,
PCI_CLASS_STORAGE_SATA_AHCI, 0, quirk_jmicron_async_suspend);
>> +DECLARE_PCI_FIXUP_FINAL(PCI_VENDOR_ID_JMICRON, 0x2362,
quirk_jmicron_async_suspend);
>> +DECLARE_PCI_FIXUP_FINAL(PCI_VENDOR_ID_JMICRON, 0x236f,
quirk_jmicron_async_suspend);
>> +
>> #ifdef CONFIG_X86_IO_APIC
>> static void quirk_alder_ioapic(struct pci_dev *pdev)
>> {
>
>
>
next prev parent reply other threads:[~2015-08-28 17:54 UTC|newest]
Thread overview: 21+ messages / expand[flat|nested] mbox.gz Atom feed top
2015-07-28 1:42 [PATCH] PCI: Disable async suspend/resume for Jmicron chip Zhang Rui
2015-07-28 1:48 ` Liu, Chuansheng
2015-07-28 2:06 ` Aaron Lu
2015-07-28 17:58 ` Tejun Heo
2015-07-29 1:39 ` Zhang Rui
2015-08-14 20:17 ` Bjorn Helgaas
[not found] ` <3296684.6OYqAkrTIu@linux-tez8>
2015-08-15 14:39 ` Bjorn Helgaas
[not found] ` <143984396.fBJoMvWU1G@linux-tez8>
2015-08-15 20:57 ` Bjorn Helgaas
2015-08-15 16:57 ` Zhang Rui
2015-08-15 21:45 ` Bjorn Helgaas
2015-08-15 23:40 ` Barto
2015-08-25 2:49 ` Bjorn Helgaas
2015-08-25 20:21 ` Yinghai Lu
2015-08-25 20:50 ` Bjorn Helgaas
2015-08-28 8:21 ` Zhang Rui
2015-08-28 17:53 ` Barto [this message]
2015-08-28 18:30 ` Barto
[not found] ` <2907359.7nsusuUeG0@linux-tez8>
2015-08-28 18:50 ` Barto
2015-08-28 19:19 ` Bjorn Helgaas
2015-08-28 20:36 ` Barto
2015-08-28 20:54 ` Bjorn Helgaas
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=55E0A00B.8020508@laposte.net \
--to=mister.freeman@laposte.net \
--cc=MyMailClone@t-online.de \
--cc=aaron.lu@intel.com \
--cc=bhelgaas@google.com \
--cc=chuansheng.liu@intel.com \
--cc=linux-pci@vger.kernel.org \
--cc=rjw@rjwysocki.net \
--cc=rui.zhang@intel.com \
--cc=stern@rowland.harvard.edu \
--cc=tj@kernel.org \
/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 an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.