On Mon, 21 Jan 2019, Miquel Raynal wrote:

> Add suspend/resume callbacks to reset the host controller properly
> during S2RAM operation.
> 
> Signed-off-by: Miquel Raynal <miquel.ray...@bootlin.com>
> ---
>  drivers/usb/host/ehci-orion.c | 25 +++++++++++++++++++++++++
>  1 file changed, 25 insertions(+)
> 
> diff --git a/drivers/usb/host/ehci-orion.c b/drivers/usb/host/ehci-orion.c
> index 3109f082949e..dab22aa57c0b 100644
> --- a/drivers/usb/host/ehci-orion.c
> +++ b/drivers/usb/host/ehci-orion.c
> @@ -182,6 +182,30 @@ static int ehci_orion_drv_reset(struct usb_hcd *hcd)
>       return ret;
>  }
>  
> +static int __maybe_unused ehci_orion_drv_suspend(struct device *dev)
> +{
> +     struct usb_hcd *hcd = dev_get_drvdata(dev);
> +     struct ehci_hcd *ehci = hcd_to_ehci(hcd);
> +
> +     ehci_prepare_ports_for_controller_suspend(ehci,
> +                                               device_may_wakeup(dev));
> +
> +     return ehci_suspend(hcd, false);

This is a little odd.  Why not just call

        ehci_suspend(hcd, device_may_wakeup(dev));

directly and let it take care of calling
ehci_prepare_ports_for_controller_suspend() for you?  If you have a
good reason for doing things this way, please mention that reason in
the Changelog.

> +}
> +
> +static int __maybe_unused ehci_orion_drv_resume(struct device *dev)
> +{
> +     struct usb_hcd *hcd = dev_get_drvdata(dev);
> +     struct ehci_hcd *ehci = hcd_to_ehci(hcd);
> +
> +     ehci_prepare_ports_for_controller_resume(ehci);
> +
> +     return ehci_resume(hcd, false);

Same thing here.

> +}
> +
> +static SIMPLE_DEV_PM_OPS(ehci_orion_pm_ops, ehci_orion_drv_suspend,
> +                      ehci_orion_drv_resume);
> +
>  static const struct ehci_driver_overrides orion_overrides __initconst = {
>       .extra_priv_size =      sizeof(struct orion_ehci_hcd),
>       .reset = ehci_orion_drv_reset,
> @@ -334,6 +358,7 @@ static struct platform_driver ehci_orion_driver = {
>       .driver = {
>               .name   = "orion-ehci",
>               .of_match_table = ehci_orion_dt_ids,
> +             .pm = &ehci_orion_pm_ops,
>       },
>  };

Alan Stern

Reply via email to