Re: Problem with OHCI on OMAP4430

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On Fri, 26 Oct 2012, Mohan V wrote:

> >> When the USB bus is in suspend, a device connected to OHCI port does
> >> not get detected, whereas the device connected to EHCI port is getting detected.
> >
> > Can you provide a dmesg log showing the OHCI problem with
> > CONFIG_USB_DEBUG enabled?
> >
> Please find the attached log (ohci-detect.log), where the device is
> disconnected from the
> OHCI port and then does not get detected when connected again.
> We are using android 3.0 kernel.

I'm not going to be able to help very much with an Android kernel.  
Does the same problem occur with a vanilla non-Android 3.6 kernel?  If 
it doesn't, that indicates the problem was caused by some 
Android-specific changes.

Are you referring to this part of the log?

> ------------------------Device not getting detected when connected---------------------------
> 
> / # [  135.621002] usbhs_wakeup: Enabling clocks
> [  135.625762] usbhs_runtime_resume:++++++
> [  135.630371] usbhs_runtime_resume:------
> [  135.638183] USB IO PAD Wakeup event triggered##################
> [  135.644958] usbhs_runtime_suspend:++++++
> [  135.649749] usbhs_runtime_suspend:-----

It appears that ohci_irq() didn't run.  Did
ohci_finish_controller_resume() get called?

My guess is your usbhs_runtime_resume() routine has a bug.  Maybe the 
usbhs_runtime_suspend() routine does too.

> We sometime see the crash in "ohci_hub_status_data" function. So, when
> we add the
> below check at the entry of the function, there is no crash. Please
> find attached crash log.
> (ohci-crash.log)

I don't understand the crash log.  What is the cause of the crash?  Is 
there some error involving spin_lock_irqrestore() in 
ohci_hub_status_data()

>         if (!HC_IS_RUNNING(hcd->state)) {
> 		return 0;
> 	}
> 
> But the device does not get detected subsequently with this change. There is
> a similar check in ehci-hub.c.

No, there isn't.  Not since the 3.1 kernel.  In any case, ehci-hcd is 
different from ohci-hcd; you shouldn't expect their hub_status_data 
routines to be the same.

Alan Stern

--
To unsubscribe from this list: send the line "unsubscribe linux-usb" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html


[Index of Archives]     [Linux Media]     [Linux Input]     [Linux Audio Users]     [Yosemite News]     [Linux Kernel]     [Linux SCSI]     [Old Linux USB Devel Archive]

  Powered by Linux