Hi, On Thu, Feb 28, 2013 at 04:31:44PM +0800, Peter Chen wrote: > > > > > > > If the probe fails, the ci13xxx_add_device will not return error, > > > > > > > (bus_probe_device doesn't has return value) > > > > > > > therefore, the platform layer can't know whether core's probe > > > > > > > is successful or not, if platform layer goes on using core's struct > > > > > > > which is initialized at core's probe, the error will occur. > > > > > > > > > > > > > > This error is showed when I only compile gadget, the host-only > > > > > > > controller reports "no supported roles", and fails probe, but imx > > > > > > > platform code doesn't know it, and goes on using core's private data. > > > > > > > > > > > > > > Signed-off-by: Peter Chen <peter.chen@xxxxxxxxxxxxx> > > > > > > > > > > > > this just tells you that platform code shouldn't be using the driver > > > > > > directly. passing probe_retval via platform_data is an abomination, fix > > > > > > the real problem instead, whatever it is. > > > > > > > > > > So you suggest the platform glue layer should not use core driver's data > > > > > directly, eg, for your dwc3, the platform glue layer should not use > > > > > struct dwc3 *dwc directly? > > > > > > > > yes, and it doesn't. Ever. > > > > > > > > > > If the dwc3 core fails to probe, but controller core clk is still on, is it > > > a valid case? > > > > of course not, but then again, core clk shouldn't be handled by glue > > layer. You need to figure out who owns the clock, if it feeds DWC3 why > > would you clk_get() and clk_prepare_enable() from glue ? Makes no sense. > > > > Sorry? I can't find clk_prepare_enable at dwc3/core.c, but at dwc3 core, it > try to access register at probe, unless platform layer open the clock, how > can the core visit the core register. Is it really this difficult to figure out ? Fair enough, below are all the details: To understand the reason why dwc3/core.c doesn't know about struct clk, you need to consider where the driver was originally written; it was written on an OMAP platform (actually first on a virtual model OMAP - somewhat like QEMU -, than on a PCIe FPGA prototype of the IP, then ARM-based FPGA prototype, then OMAP5, none of which needed explicit clock control, see below). OMAP's PM is written in such a way that a pm_runtime_get() will enable the device the all clocks necessary to be usable. Since OMAP would never need to use clocks directly and I would never be able to test that code, I decided not to add it. Now, if dwc3-exynos needs it, the sane thing to do would be add struct clk knowledge to dwc3/core.c but make it optional. If there are no clocks available, don't bail out. Just because dwc3/core.c doesn't know about clocks, it doesn't mean it's correct to hack it into the glue layer if that doesn't need the clock. Now that we know that's a bug, who's going to send me tested patches to teach dwc3/core.c about struct clk in a way that doesn't break PCIe, nor OMAP5 ? cheers -- balbi
Attachment:
signature.asc
Description: Digital signature