2016-01-25 14:13 GMT+09:00 Marek Vasut <[email protected]>: > On Monday, January 25, 2016 at 05:59:30 AM, Masahiro Yamada wrote: >> This driver is designed in a generic manner, so clocks should be >> handled genericly as well. >> >> Signed-off-by: Masahiro Yamada <[email protected]> >> --- >> >> Changes in v2: >> - rephrase git-log >> - rebase on commit 12f229ea >> - do not store clk devices and IDs in the private data >> >> drivers/usb/host/ehci-generic.c | 15 +++++++++++++++ >> 1 file changed, 15 insertions(+) >> >> diff --git a/drivers/usb/host/ehci-generic.c >> b/drivers/usb/host/ehci-generic.c index 1292caa..98f9db7 100644 >> --- a/drivers/usb/host/ehci-generic.c >> +++ b/drivers/usb/host/ehci-generic.c >> @@ -5,6 +5,7 @@ >> */ >> >> #include <common.h> >> +#include <clk.h> >> #include <dm.h> >> #include "ehci.h" >> >> @@ -21,6 +22,20 @@ static int ehci_usb_probe(struct udevice *dev) >> { >> struct ehci_hccr *hccr = (struct ehci_hccr *)dev_get_addr(dev); >> struct ehci_hcor *hcor; >> + int i = 0; >> + >> + while (1) { > > You can do for (i = 0; ; i++) {} here ;-) > >> + struct udevice *clk_dev; >> + int clk_id; >> + >> + clk_id = clk_get_by_index(dev, i, &clk_dev); >> + if (clk_id < 0) >> + break; >> + if (clk_enable(clk_dev, clk_id)) >> + printf("failed to enable clock (dev=%s, id=%d)\n", >> + clk_dev->name, clk_id); >> + i++; >> + } >> >> hcor = (struct ehci_hcor *)((uintptr_t)hccr + >> HC_LENGTH(ehci_readl(&hccr->cr_capbase))); > > What about disabling the clock? Is it doable with the current clock framework > or shall we abandon it for now ?
clk_disable() is not supported in U-Boot, at least for now. (see include/clk.h and you will only find clk_enable.) I think this patch is the best I can do now. (ccing Simon, again) -- Best Regards Masahiro Yamada _______________________________________________ U-Boot mailing list [email protected] http://lists.denx.de/mailman/listinfo/u-boot

