On Sun, May 2, 2010 at 6:14 PM, Russell King - ARM Linux <linux@xxxxxxxxxxxxxxxx> wrote: > On Sun, May 02, 2010 at 06:05:32PM +0300, saeed bishara wrote: >> On Sun, May 2, 2010 at 5:36 PM, Russell King - ARM Linux >> <linux@xxxxxxxxxxxxxxxx> wrote: >> > On Sun, May 02, 2010 at 05:22:40PM +0300, Saeed Bishara wrote: >> >> @@ -110,6 +111,9 @@ struct usb_hcd { >> >> u64 rsrc_start; /* memory/io resource start */ >> >> u64 rsrc_len; /* memory/io resource length */ >> >> unsigned power_budget; /* in mA, 0 = no limit */ >> >> +#if defined(CONFIG_HAVE_CLK) >> >> + struct clk *clk; >> >> +#endif >> > >> > We have other hci's using the clk API, why do we need to add this for >> > them too? In other words, why can't the orion HCI driver work like >> > the other HCI drivers such as ohci-pxa27x.c or ehci-omap.c ? >> > >> if most of those drivers need clk structure then why not to add it to >> the usb_hcd which hold the common stuff? > > 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? > > Having these patches with this patch submission may actually help your > case by showing the benefits of such a cleanup - eg, if it eliminates > private driver data structures entirely, it's definitely worth it. your right, I have had to send kind of RFC for this issue. > -- 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