aboutsummaryrefslogtreecommitdiffstats
path: root/arch/arm/mach-lpc32xx/clock.c
diff options
context:
space:
mode:
Diffstat (limited to 'arch/arm/mach-lpc32xx/clock.c')
-rw-r--r--arch/arm/mach-lpc32xx/clock.c68
1 files changed, 67 insertions, 1 deletions
diff --git a/arch/arm/mach-lpc32xx/clock.c b/arch/arm/mach-lpc32xx/clock.c
index b64f98537b5d..8a4e7cb74ae1 100644
--- a/arch/arm/mach-lpc32xx/clock.c
+++ b/arch/arm/mach-lpc32xx/clock.c
@@ -739,14 +739,77 @@ static struct clk clk_rtc = {
739 .get_rate = local_return_parent_rate, 739 .get_rate = local_return_parent_rate,
740}; 740};
741 741
742static int local_usb_enable(struct clk *clk, int enable)
743{
744 u32 tmp;
745
746 if (enable) {
747 /* Set up I2C pull levels */
748 tmp = __raw_readl(LPC32XX_CLKPWR_I2C_CLK_CTRL);
749 tmp |= LPC32XX_CLKPWR_I2CCLK_USBI2CHI_DRIVE;
750 __raw_writel(tmp, LPC32XX_CLKPWR_I2C_CLK_CTRL);
751 }
752
753 return local_onoff_enable(clk, enable);
754}
755
742static struct clk clk_usbd = { 756static struct clk clk_usbd = {
743 .parent = &clk_usbpll, 757 .parent = &clk_usbpll,
744 .enable = local_onoff_enable, 758 .enable = local_usb_enable,
745 .enable_reg = LPC32XX_CLKPWR_USB_CTRL, 759 .enable_reg = LPC32XX_CLKPWR_USB_CTRL,
746 .enable_mask = LPC32XX_CLKPWR_USBCTRL_HCLK_EN, 760 .enable_mask = LPC32XX_CLKPWR_USBCTRL_HCLK_EN,
747 .get_rate = local_return_parent_rate, 761 .get_rate = local_return_parent_rate,
748}; 762};
749 763
764#define OTG_ALWAYS_MASK (LPC32XX_USB_OTG_OTG_CLOCK_ON | \
765 LPC32XX_USB_OTG_I2C_CLOCK_ON)
766
767static int local_usb_otg_enable(struct clk *clk, int enable)
768{
769 int to = 1000;
770
771 if (enable) {
772 __raw_writel(clk->enable_mask, clk->enable_reg);
773
774 while (((__raw_readl(LPC32XX_USB_OTG_CLK_STAT) &
775 clk->enable_mask) != clk->enable_mask) && (to > 0))
776 to--;
777 } else {
778 __raw_writel(OTG_ALWAYS_MASK, clk->enable_reg);
779
780 while (((__raw_readl(LPC32XX_USB_OTG_CLK_STAT) &
781 OTG_ALWAYS_MASK) != OTG_ALWAYS_MASK) && (to > 0))
782 to--;
783 }
784
785 if (to)
786 return 0;
787 else
788 return -1;
789}
790
791static struct clk clk_usb_otg_dev = {
792 .parent = &clk_usbpll,
793 .enable = local_usb_otg_enable,
794 .enable_reg = LPC32XX_USB_OTG_CLK_CTRL,
795 .enable_mask = LPC32XX_USB_OTG_AHB_M_CLOCK_ON |
796 LPC32XX_USB_OTG_OTG_CLOCK_ON |
797 LPC32XX_USB_OTG_DEV_CLOCK_ON |
798 LPC32XX_USB_OTG_I2C_CLOCK_ON,
799 .get_rate = local_return_parent_rate,
800};
801
802static struct clk clk_usb_otg_host = {
803 .parent = &clk_usbpll,
804 .enable = local_usb_otg_enable,
805 .enable_reg = LPC32XX_USB_OTG_CLK_CTRL,
806 .enable_mask = LPC32XX_USB_OTG_AHB_M_CLOCK_ON |
807 LPC32XX_USB_OTG_OTG_CLOCK_ON |
808 LPC32XX_USB_OTG_HOST_CLOCK_ON |
809 LPC32XX_USB_OTG_I2C_CLOCK_ON,
810 .get_rate = local_return_parent_rate,
811};
812
750static int tsc_onoff_enable(struct clk *clk, int enable) 813static int tsc_onoff_enable(struct clk *clk, int enable)
751{ 814{
752 u32 tmp; 815 u32 tmp;
@@ -1145,6 +1208,9 @@ static struct clk_lookup lookups[] = {
1145 CLKDEV_INIT("31060000.ethernet", NULL, &clk_net), 1208 CLKDEV_INIT("31060000.ethernet", NULL, &clk_net),
1146 CLKDEV_INIT("dev:clcd", NULL, &clk_lcd), 1209 CLKDEV_INIT("dev:clcd", NULL, &clk_lcd),
1147 CLKDEV_INIT("31020000.usbd", "ck_usbd", &clk_usbd), 1210 CLKDEV_INIT("31020000.usbd", "ck_usbd", &clk_usbd),
1211 CLKDEV_INIT("31020000.ohci", "ck_usbd", &clk_usbd),
1212 CLKDEV_INIT("31020000.usbd", "ck_usb_otg", &clk_usb_otg_dev),
1213 CLKDEV_INIT("31020000.ohci", "ck_usb_otg", &clk_usb_otg_host),
1148 CLKDEV_INIT("lpc32xx_rtc", NULL, &clk_rtc), 1214 CLKDEV_INIT("lpc32xx_rtc", NULL, &clk_rtc),
1149}; 1215};
1150 1216