On Sun, May 02, 2010 at 06:21:52PM +0300, saeed bishara wrote: > On Sun, May 2, 2010 at 6:14 PM, Russell King - ARM Linux > <linux@xxxxxxxxxxxxxxxx> wrote: > > drivers/usb/host/ohci-s3c2410.c: 2 > > drivers/usb/host/ohci-omap.c: 2 > > drivers/usb/host/r8a66597-hcd.c: 1 > > drivers/usb/host/ehci-mxc.c: 2 > > drivers/usb/host/ohci-da8xx.c: 2 > > drivers/usb/host/ohci-pxa27x.c: 1 > > drivers/usb/host/ohci-pnx4008.c: 1 > > drivers/usb/host/imx21-hcd.c: 1 > > drivers/usb/host/ohci-ep93xx.c: 1 > > drivers/usb/host/ehci-atmel.c: 2 > > drivers/usb/host/ehci-omap.c: 5 > > drivers/usb/host/ohci-at91.c: 2 > > > > So, five drivers need one clock, six drivers need two clocks, and one > > driver needs five clocks. So maybe you should be catering for the > > common case by providing two struct clk's, or maybe catering for the > > maximal case of five clocks? > well, I think that those drivers that have more than one clk can be > redesigned by adding virtual clk for the the usb host, and the clk > implementation for that soc should manage all the underlying physical > clocks. I've looked at the omap,at91 and atmel, and it looks to me > that this is doable. you see can see that the clk stuff in those > driver has nothing to do with usb itself. what do you think? Not happy with this for two reasons: 1. You're assuming that they can be managed as one entity; that doesn't seem true for some of the drivers. 2. I don't see any reason to force this complication into the clk layer for these platforms when they don't actually need it. Due to (1), using your current approach will result in those drivers scattering their clks across two structures, which as I've said in my previous email would be confusing. So I don't think this approach makes much sense. -- 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