On Tue, 21 Dec 2010, Anoop P wrote: > From: Anoop P A <anoop.pa@xxxxxxxxx> > > This patch includes. > > 1. USB host driver for MSP71xx family SoC on-chip USB controller. > 2. Platform support for USB controller. It also contains changes to the core USB hub driver code. You should mention things like that in the patch description. ... > diff --git a/drivers/usb/core/hub.c b/drivers/usb/core/hub.c > index 27115b4..f2a45ba 100644 > --- a/drivers/usb/core/hub.c > +++ b/drivers/usb/core/hub.c > @@ -3377,12 +3377,43 @@ static void hub_events(void) > } > > if (portchange & USB_PORT_STAT_C_OVERCURRENT) { > +#ifdef CONFIG_USB_EHCI_HCD_PMC_MSP > +#define OVER_CURR_DELAY 100 What happens if CONFIG_USB_EHCI_HCD_PMC_MSP is defined, but an overcurrent status is detected on an external hub instead of the root hub? > + /* clear OCC bit */ > + clear_port_feature(hdev, i, > + USB_PORT_FEAT_C_OVER_CURRENT); > + > + /* This step is required to toggle the PP bit > + * to 0 and 1 (by hub_power_on) in order the > + * CSC bit to be transitioned > + * properly for device hotplug > + */ > + /* clear PP bit */ > + clear_port_feature(hdev, i, > + USB_PORT_FEAT_POWER); > + > + /* resume power */ > + hub_power_on(hub, true); > + > + /* delay 100 usec */ > + udelay(OVER_CURR_DELAY); > + > + /* read OCA bit */ > + if (portstatus & > + (1<<USB_PORT_FEAT_OVER_CURRENT)) { > + /* declare overcurrent */ > + dev_err(hub_dev, > + "over-current change on port %d\n", > + i); > + } > +#else > dev_err (hub_dev, > "over-current change on port %d\n", > i); > clear_port_feature(hdev, i, > USB_PORT_FEAT_C_OVER_CURRENT); > hub_power_on(hub, true); > +#endif > } "#ifdef" inside code like this is strongly discouraged. This should be written using a separate subroutine. ... > diff --git a/drivers/usb/host/ehci-pmcmsp.c b/drivers/usb/host/ehci-pmcmsp.c > new file mode 100644 > index 0000000..b1b4f21 > --- /dev/null > +++ b/drivers/usb/host/ehci-pmcmsp.c > +static const struct hc_driver ehci_msp_hc_driver = { > + .description = hcd_name, > + .product_desc = "PMC MSP EHCI", > + .hcd_priv_size = sizeof(struct ehci_hcd), > + > + /* > + * generic hardware linkage > + */ > +#ifdef CONFIG_MSP_HAS_DUAL_USB > + .irq = ehci_msp_irq, > +#else > + .irq = ehci_irq, > +#endif > + .flags = HCD_MEMORY | HCD_USB2, > + > + /* > + * basic lifecycle operations > + */ > + .reset = ehci_msp_setup, > + .start = ehci_run, > +#ifdef CONFIG_PM > + .suspend = ehci_msp_suspend, > + .resume = ehci_msp_resume, > +#endif /*CONFIG_PM*/ > + .stop = ehci_stop, > + > + /* > + * managing i/o requests and associated device resources > + */ > + .urb_enqueue = ehci_urb_enqueue, > + .urb_dequeue = ehci_urb_dequeue, > + .endpoint_disable = ehci_endpoint_disable, > + > + /* > + * scheduling support > + */ > + .get_frame_number = ehci_get_frame, > + > + /* > + * root hub support > + */ > + .hub_status_data = ehci_hub_status_data, > + .hub_control = ehci_hub_control, > +}; This appears to have been copied from a really old version of ehci-pci.c. You should start with the most up-to-date code. Alan Stern