[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <51ECDDE3.1040209@ti.com>
Date: Mon, 22 Jul 2013 12:53:15 +0530
From: George Cherian <george.cherian@...com>
To: Shuduo Sang <sangshuduo@...il.com>
CC: Sarah Sharp <sarah.a.sharp@...ux.intel.com>,
<linux-usb@...r.kernel.org>, <balbi@...com>,
<linux-kernel@...r.kernel.org>, <gregkh@...uxfoundation.org>
Subject: Re: [PATCH v2] usb: host: xhci: Enable XHCI_SPURIOUS_SUCCESS for
all controllers with xhci 1.0
Hi Shuduo,
On 7/22/2013 12:35 PM, Shuduo Sang wrote:
> Hi Sarah and George,
>
> I met this issue at my side too. Per lspci output and HCIVERSION, I
> see the host is Lynx
> Point xhci 1.0 host.
>
> I notice George's patch has not been merged in kernel 3.11-rc1.
Just to make sure, without the patch are you getting the following error.
"ERROR Transfer event TRB DMA ptr not part of current TD"
> Then I manually applied George's patch against 3.10.0 but the issue
> still happen when I use
> camera to capture picture.
Can you explain what is the exact issue you face after applying the patch?
Are you still getting
"ERROR Transfer event TRB DMA ptr not part of current TD"
> So I doubt some corner test has not been
> covered by patch.
> Pls let me know what I can do if you need more information.
>
> Thanks,
> Shuduo
>
> On Tue, Jul 2, 2013 at 11:27 AM, Sarah Sharp
> <sarah.a.sharp@...ux.intel.com> wrote:
>> Thanks George, this looks fine. I will munge the description a bit when
>> I commit it, and mark it for stable as well.
>>
>> Unfortunately, due to the timing of the merge window, this patch will
>> have to wait for 2-3 weeks until 3.11-rc1 is out.
>>
>> Sarah Sharp
>>
>> On Mon, Jul 01, 2013 at 10:59:12AM +0530, George Cherian wrote:
>>> Xhci controllers with hci_version > 0.96 gives spurious success
>>> events on short packet completion. During webcam capture the
>>> "ERROR Transfer event TRB DMA ptr not part of current TD" was observed.
>>> The same application works fine with synopsis controllers hci_version 0.96.
>>> The same Issue is seen with Intel Pantherpoint xhci controller. So enabling
>>> this quirk in xhci_gen_setup if controller verion is greater than 0.96.
>>> For xhci-pci move the quirk to much generic place xhci_gen_setup.
>>>
>>> Signed-off-by: George Cherian <george.cherian@...com>
>>> ---
>>> drivers/usb/host/xhci-pci.c | 1 -
>>> drivers/usb/host/xhci.c | 7 +++++++
>>> 2 files changed, 7 insertions(+), 1 deletion(-)
>>>
>>> diff --git a/drivers/usb/host/xhci-pci.c b/drivers/usb/host/xhci-pci.c
>>> index cc24e39..f00cb20 100644
>>> --- a/drivers/usb/host/xhci-pci.c
>>> +++ b/drivers/usb/host/xhci-pci.c
>>> @@ -93,7 +93,6 @@ static void xhci_pci_quirks(struct device *dev, struct xhci_hcd *xhci)
>>> }
>>> if (pdev->vendor == PCI_VENDOR_ID_INTEL &&
>>> pdev->device == PCI_DEVICE_ID_INTEL_PANTHERPOINT_XHCI) {
>>> - xhci->quirks |= XHCI_SPURIOUS_SUCCESS;
>>> xhci->quirks |= XHCI_EP_LIMIT_QUIRK;
>>> xhci->limit_active_eps = 64;
>>> xhci->quirks |= XHCI_SW_BW_CHECKING;
>>> diff --git a/drivers/usb/host/xhci.c b/drivers/usb/host/xhci.c
>>> index d8f640b..0f7be59 100644
>>> --- a/drivers/usb/host/xhci.c
>>> +++ b/drivers/usb/host/xhci.c
>>> @@ -4697,6 +4697,13 @@ int xhci_gen_setup(struct usb_hcd *hcd, xhci_get_quirks_t get_quirks)
>>>
>>> get_quirks(dev, xhci);
>>>
>>> + /* In xhci controllers which follow xhci 1.0 spec gives a spurious
>>> + * success event after a short transfer. This quirk will ignore such
>>> + * spurious event.
>>> + */
>>> + if (xhci->hci_version > 0x96)
>>> + xhci->quirks |= XHCI_SPURIOUS_SUCCESS;
>>> +
>>> /* Make sure the HC is halted. */
>>> retval = xhci_halt(xhci);
>>> if (retval)
>>> --
>>> 1.8.1.4
>>>
>> --
>> 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/
--
-George
--
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