[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <72f9de63-dc19-4467-b883-8637f95a8e82@oss.qualcomm.com>
Date: Tue, 24 Jun 2025 18:38:22 +0530
From: Krishna Kurapati <krishna.kurapati@....qualcomm.com>
To: Thinh Nguyen <Thinh.Nguyen@...opsys.com>
Cc: Greg Kroah-Hartman <gregkh@...uxfoundation.org>,
Bjorn Andersson <bjorn.andersson@....qualcomm.com>,
"linux-arm-msm@...r.kernel.org" <linux-arm-msm@...r.kernel.org>,
"linux-usb@...r.kernel.org" <linux-usb@...r.kernel.org>,
"linux-kernel@...r.kernel.org" <linux-kernel@...r.kernel.org>
Subject: Re: [PATCH v2 3/4] usb: dwc3: qcom: Facilitate autosuspend during
host mode
On 6/24/2025 5:29 AM, Thinh Nguyen wrote:
> On Tue, Jun 10, 2025, Krishna Kurapati wrote:
>> When in host mode, it is intended that the controller goes to suspend
>> state to save power and wait for interrupts from connected peripheral
>> to wake it up. This is particularly used in cases where a HID or Audio
>> device is connected. In such scenarios, the usb controller can enter
>> auto suspend and resume action after getting interrupts from the
>> connected device.
>>
>> Allow autosuspend for and xhci device and allow userspace to decide
>> whether to enable this functionality.
>>
>> a) Register to usb-core notifications in set_role vendor callback to
>> identify when root hubs are being created. Configure them to
>> use_autosuspend.
>>
>> b) Identify usb core notifications where the HCD is being added and
>> enable autosuspend for that particular xhci device.
>>
>> Signed-off-by: Krishna Kurapati <krishna.kurapati@....qualcomm.com>
[...]
>> +static int dwc3_xhci_event_notifier(struct notifier_block *nb,
>> + unsigned long event, void *ptr)
>> +{
>> + struct dwc3_qcom *qcom = container_of(nb, struct dwc3_qcom, xhci_nb);
>> + struct dwc3 *dwc = &qcom->dwc;
>> + struct usb_bus *ubus = ptr;
>> + struct usb_hcd *hcd;
>> +
>> + if (!dwc->xhci)
>> + goto done;
>> +
>> + hcd = platform_get_drvdata(dwc->xhci);
>> + if (!hcd)
>> + goto done;
>> +
>> + if (event != USB_BUS_ADD)
>> + goto done;
>> +
>> + if (strcmp(dev_name(ubus->sysdev), dev_name(dwc->sysdev)) != 0)
>
> Can this be false? If possible, I'd like to avoid these pointers and
> strcmp here.
>
Needed this to identify if the dwc3 pointer corresponds to this glue or
not. This can be false.
BTW, Dmitry suggested to just do "runtime_use_autosuspend" inside probe
of xhci-plat.c and remove this logic. Hope that would be fine ?
>> + goto done;
>> +
>> + if (event == USB_BUS_ADD) {
>
> This condition is redundant when you have the check a few lines above.
>
ACK.
>> + /*
>> + * Identify instant of creation of primary hcd and
>> + * mark xhci as autosuspend capable at this point.
>> + */
>> + pm_runtime_use_autosuspend(&dwc->xhci->dev);
>> + }
>> +
>> +done:
>> + return NOTIFY_DONE;
>> +}
>> +
>> static void dwc3_qcom_set_role_notifier(struct dwc3 *dwc, enum usb_role next_role)
>> {
>> struct dwc3_qcom *qcom = to_dwc3_qcom(dwc);
>> @@ -659,12 +694,22 @@ static void dwc3_qcom_set_role_notifier(struct dwc3 *dwc, enum usb_role next_rol
>> return;
>> }
>>
>> - if (qcom->current_role == USB_ROLE_DEVICE &&
>> - next_role != USB_ROLE_DEVICE)
>> + if (qcom->current_role == USB_ROLE_NONE) {
>> + if (next_role == USB_ROLE_DEVICE) {
>> + dwc3_qcom_vbus_override_enable(qcom, true);
>> + } else if (next_role == USB_ROLE_HOST) {
>> + qcom->xhci_nb.notifier_call = dwc3_xhci_event_notifier;
>> + usb_register_notify(&qcom->xhci_nb);
>> + }
>> + } else if (qcom->current_role == USB_ROLE_DEVICE &&
>> + next_role != USB_ROLE_DEVICE) {
>> dwc3_qcom_vbus_override_enable(qcom, false);
>> - else if ((qcom->current_role != USB_ROLE_DEVICE) &&
>> - (next_role == USB_ROLE_DEVICE))
>> - dwc3_qcom_vbus_override_enable(qcom, true);
>> + } else if (qcom->current_role == USB_ROLE_HOST) {
>> + if (next_role == USB_ROLE_NONE)
>> + usb_unregister_notify(&qcom->xhci_nb);
>> + else if (next_role == USB_ROLE_DEVICE)
>> + dwc3_qcom_vbus_override_enable(qcom, true);
>
> We don't unregister the notifier when switching from host to device?
>
ACK. My bad, missed it.
Thanks for the review.
Regards,
Krishna,
Powered by blists - more mailing lists