From: Felipe Balbi <balbi@kernel.org>
To: gustavo panizzo <gfa@zumbi.com.ar>, Baolin Wang <baolin.wang@linaro.org>
Cc: Greg KH <gregkh@linuxfoundation.org>,
USB <linux-usb@vger.kernel.org>,
LKML <linux-kernel@vger.kernel.org>,
stable@vger.kernel.org, Brian Kim <brian.kim@hardkernel.com>
Subject: Re: [PATCH] usb: dwc3: Fix the USB 3.0 hub detection bug after warm boot
Date: Mon, 24 Jul 2017 12:53:27 +0300 [thread overview]
Message-ID: <87h8y240vc.fsf@linux.intel.com> (raw)
In-Reply-To: <20170721140544.j4obgspw7mcyikw5@zumbi.com.ar>
[-- Attachment #1: Type: text/plain, Size: 3522 bytes --]
Hi,
gustavo panizzo <gfa@zumbi.com.ar> writes:
>>> On Wed, Jul 12, 2017 at 02:08:04PM +0800, Baolin Wang wrote:
>>>>
>>>> Hi,
>>>>
>>>> On 12 July 2017 at 11:52, gustavo panizzo <gfa@zumbi.com.ar> wrote:
>>>>>
>>>>> The dwc3 could not release resources when the module is built-in
>>>>> because this module does not have shutdown method. This causes the USB
>>>>> 3.0 hub is not able to detect after warm boot.
>>>>>
>>>>> Original patch by Brian Kim, updated and submitted upstream by gustavo
>>>>> panizzo.
>>>>>
>>>>> Also see https://bugs.debian.org/843448
>>>>>
>>>>> Signed-off-by: Brian Kim <brian.kim@hardkernel.com>
>>>>> Signed-off-by: gustavo panizzo <gfa@zumbi.com.ar>
>>>>> ---
>>>>> drivers/usb/dwc3/core.c | 33 +++++++++++++++++++++++++++++++++
>>>>> 1 file changed, 33 insertions(+)
>>>>>
>>>>> diff --git a/drivers/usb/dwc3/core.c b/drivers/usb/dwc3/core.c
>>>>> index 326b302fc440..f92dfe213d89 100644
>>>>> --- a/drivers/usb/dwc3/core.c
>>>>> +++ b/drivers/usb/dwc3/core.c
>>>>> @@ -1259,6 +1259,38 @@ static int dwc3_probe(struct platform_device
>>>>> *pdev)
>>>>> return ret;
>>>>> }
>>>>>
>>>>> +static void dwc3_shutdown(struct platform_device *pdev)
>>>>> +{
>>>>> + struct dwc3 *dwc = platform_get_drvdata(pdev);
>>>>> + struct resource *res = platform_get_resource(pdev,
>>>>> IORESOURCE_MEM, 0);
>>>>> +
>>>>> + pm_runtime_get_sync(&pdev->dev);
>>>>> + /*
>>>>> + * restore res->start back to its original value so that, in case
>>>>> the
>>>>> + * probe is deferred, we don't end up getting error in request
>>>>> the
>>>>> + * memory region the next time probe is called.
>>>>> + */
>>>>> + res->start -= DWC3_GLOBALS_REGS_START;
>>>>> +
>>>>> + dwc3_debugfs_exit(dwc);
>>>>> + dwc3_core_exit_mode(dwc);
>>>>> + dwc3_event_buffers_cleanup(dwc);
>>>
>>>
>>> What about dwc3_event_buffers_cleanup? should I remove it from
>>> dwc3_shutdown()?
>>> It is already in dwc3_core_exit()
>>
>>I think so. We should avoid duplicate code.
>>
>>>>> + dwc3_free_event_buffers(dwc);
>>>>> +
>>>>> + usb_phy_set_suspend(dwc->usb2_phy, 1);
>>>>> + usb_phy_set_suspend(dwc->usb3_phy, 1);
>>>>> +
>>>>> + phy_power_off(dwc->usb2_generic_phy);
>>>>> + phy_power_off(dwc->usb3_generic_phy);
>>>>
>>>>
>>>> We've done these in dwc3_core_exit().
>
> This is the patch after testing on a Odroid XU4, on top of linux-next
> 964bcc1b4f57028d56dace7d9bc5924f2eb43f36 which translates to 4.13.0-rc1-next-20170717+
> I tested this patch for a week without problems with heavy USB and NIC usage.
> Please consider merging it
>
>
> Author: gustavo panizzo <gfa@zumbi.com.ar>
> Date: Wed Jul 12 11:26:55 2017 +0800
>
> usb: dwc3: Fix the USB 3.0 hub detection bug after warm boot
>
> The dwc3 could not release resources when the module is built-in
> because this module does not have shutdown method. This causes the USB
> 3.0 hub is not able to detect after warm boot.
>
> Original patch by Brian Kim, updated and submitted upstream by gustavo
> panizzo.
if the original patch is from Brian, then 'Author' should be
Brian. Please fix it.
I also don't get why all of a sudden we need to implement
->shutdown(). Why is it that we never needed it before and we need it now?
Care to bisect to find the first commit which started causing this
problem?
--
balbi
[-- Attachment #2: signature.asc --]
[-- Type: application/pgp-signature, Size: 832 bytes --]
next prev parent reply other threads:[~2017-07-24 9:53 UTC|newest]
Thread overview: 12+ messages / expand[flat|nested] mbox.gz Atom feed top
2017-07-12 3:52 [PATCH] usb: dwc3: Fix the USB 3.0 hub detection bug after warm boot gustavo panizzo
2017-07-12 6:08 ` Baolin Wang
2017-07-12 23:20 ` gustavo panizzo
2017-07-13 5:58 ` Baolin Wang
2017-07-21 14:05 ` gustavo panizzo
2017-07-24 9:53 ` Felipe Balbi [this message]
2017-07-29 23:53 ` gustavo panizzo
2017-09-07 6:51 ` gustavo panizzo
2017-09-07 10:51 ` Felipe Balbi
2017-09-15 9:01 ` gustavo panizzo
2017-09-16 4:24 ` gustavo panizzo
2017-09-18 8:11 ` Felipe Balbi
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=87h8y240vc.fsf@linux.intel.com \
--to=balbi@kernel.org \
--cc=baolin.wang@linaro.org \
--cc=brian.kim@hardkernel.com \
--cc=gfa@zumbi.com.ar \
--cc=gregkh@linuxfoundation.org \
--cc=linux-kernel@vger.kernel.org \
--cc=linux-usb@vger.kernel.org \
--cc=stable@vger.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.