On Tue, 5 Nov 2013, Alistair Popple wrote:

> The IBM Akebono board has a OHCI compliant USB host interface. This
> patch adds support for it to the OHCI platform driver.
> 
> As we use device tree to pass platform specific data instead of
> platform data we remove the check for platform data and instead
> provide reasonable defaults if no platform data is present. This is
> similar to what is currently done in ehci-platform.c.
> 
> Signed-off-by: Alistair Popple <alist...@popple.id.au>
> Cc: Alan Stern <st...@rowland.harvard.edu>
> Cc: linux-...@vger.kernel.org
> ---
>  drivers/usb/host/ohci-platform.c |   20 +++++++++++++++-----
>  1 file changed, 15 insertions(+), 5 deletions(-)
> 
> diff --git a/drivers/usb/host/ohci-platform.c 
> b/drivers/usb/host/ohci-platform.c
> index a4c6410..4331454 100644
> --- a/drivers/usb/host/ohci-platform.c
> +++ b/drivers/usb/host/ohci-platform.c
> @@ -23,6 +23,8 @@
>  #include <linux/usb/ohci_pdriver.h>
>  #include <linux/usb.h>
>  #include <linux/usb/hcd.h>
> +#include <linux/slab.h>
> +#include <linux/of.h>
>  
>  #include "ohci.h"
>  
> @@ -55,6 +57,8 @@ static const struct ohci_driver_overrides 
> platform_overrides __initconst = {
>       .reset =        ohci_platform_reset,
>  };
>  
> +static struct usb_ohci_pdata ohci_platform_defaults;
> +
>  static int ohci_platform_probe(struct platform_device *dev)
>  {
>       struct usb_hcd *hcd;
> @@ -63,14 +67,14 @@ static int ohci_platform_probe(struct platform_device 
> *dev)
>       int irq;
>       int err = -ENOMEM;
>  
> -     if (!pdata) {
> -             WARN_ON(1);
> -             return -ENODEV;
> -     }
> -
>       if (usb_disabled())
>               return -ENODEV;
>  
> +     /* Platforms using DT don't always provide platform data.
> +      * This should provide reasonable defaults. */

        /*
         * The accepted format for multi-line
         * comments is like this.
         */

> +     if (!pdata)
> +             dev->dev.platform_data = pdata = &ohci_platform_defaults;
> +
>       irq = platform_get_irq(dev, 0);
>       if (irq < 0) {
>               dev_err(&dev->dev, "no irq provided");
> @@ -171,6 +175,11 @@ static int ohci_platform_resume(struct device *dev)
>  #define ohci_platform_resume NULL
>  #endif /* CONFIG_PM */
>  
> +static const struct of_device_id ohci_of_match[] = {
> +     { .compatible = "ibm,akebono-ohci", },
> +     {},
> +};
> +
>  static const struct platform_device_id ohci_platform_table[] = {
>       { "ohci-platform", 0 },
>       { }
> @@ -191,6 +200,7 @@ static struct platform_driver ohci_platform_driver = {
>               .owner  = THIS_MODULE,
>               .name   = "ohci-platform",
>               .pm     = &ohci_platform_pm_ops,
> +             .of_match_table = ohci_of_match,
>       }
>  };

Update the comment formatting, and then you can resubmit with

Acked-by: Alan Stern <st...@rowland.harvard.edu>

_______________________________________________
Linuxppc-dev mailing list
Linuxppc-dev@lists.ozlabs.org
https://lists.ozlabs.org/listinfo/linuxppc-dev

Reply via email to