diff options
author | rapha <rapha@cvs.openbsd.org> | 2013-05-14 12:01:18 +0000 |
---|---|---|
committer | rapha <rapha@cvs.openbsd.org> | 2013-05-14 12:01:18 +0000 |
commit | 99bf894cfc6332dd801b0f155785c194fd8a7eb5 (patch) | |
tree | 8e8b8c95ecef3bb60a7f6bf28392e969d29c8a9f /sys/arch/beagle | |
parent | 2828074c6ecffd191578998d7133ee45cedb3b13 (diff) |
Add basic prcm support for am335x.
Use separate headers and enable/disablemodule functions for the
different boards. A lot of work by patrick@.
ok patrick@, bmercer@
Diffstat (limited to 'sys/arch/beagle')
-rw-r--r-- | sys/arch/beagle/dev/am335x_prcmreg.h | 48 | ||||
-rw-r--r-- | sys/arch/beagle/dev/omap3_prcmreg.h | 197 | ||||
-rw-r--r-- | sys/arch/beagle/dev/omehci.c | 8 | ||||
-rw-r--r-- | sys/arch/beagle/dev/omohci.c | 4 | ||||
-rw-r--r-- | sys/arch/beagle/dev/omusbtll.c | 10 | ||||
-rw-r--r-- | sys/arch/beagle/dev/prcm.c | 358 | ||||
-rw-r--r-- | sys/arch/beagle/dev/prcmvar.h | 90 |
7 files changed, 441 insertions, 274 deletions
diff --git a/sys/arch/beagle/dev/am335x_prcmreg.h b/sys/arch/beagle/dev/am335x_prcmreg.h new file mode 100644 index 00000000000..e5713315b88 --- /dev/null +++ b/sys/arch/beagle/dev/am335x_prcmreg.h @@ -0,0 +1,48 @@ +/* $OpenBSD: am335x_prcmreg.h,v 1.1 2013/05/14 12:01:17 rapha Exp $ */ +/* + * Copyright (c) 2013 Raphael Graf <r@undefined.ch> + * + * Permission to use, copy, modify, and distribute this software for any + * purpose with or without fee is hereby granted, provided that the above + * copyright notice and this permission notice appear in all copies. + * + * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES + * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF + * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR + * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES + * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN + * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF + * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. + */ + +#define AM335X_CLKCTRL_MODULEMODE_ENABLE 2 +#define AM335X_CLKCTRL_MODULEMODE_DISABLE 0 +#define AM335X_CLKCTRL_MODULEMODE_MASK 0x00000003 + +#define PRCM_AM335X_CM_PER 0x0000 +#define PRCM_AM335X_USB0_CLKCTRL 0x001c +#define PRCM_AM335X_MMC0_CLKCTRL 0x003c +#define PRCM_AM335X_TIMER2_CLKCTRL 0x0080 +#define PRCM_AM335X_TIMER3_CLKCTRL 0x0084 +#define PRCM_AM335X_GPIO1_CLKCTRL 0x00ac +#define PRCM_AM335X_GPIO2_CLKCTRL 0x00b0 +#define PRCM_AM335X_GPIO3_CLKCTRL 0x00b4 +#define PRCM_AM335X_CM_WKUP 0x0400 +#define PRCM_AM335X_GPIO0_CLKCTRL 0x0408 +#define PRCM_AM335X_TIMER0_CLKCTRL 0x0410 +#define PRCM_AM335X_CM_DPLL 0x0500 +#define PRCM_AM335X_CLKSEL_TIMER2_CLK 0x0508 +#define PRCM_AM335X_CLKSEL_TIMER3_CLK 0x050c +#define PRCM_AM335X_CM_MPU 0x0600 +#define PRCM_AM335X_CM_DEVICE 0x0700 +#define PRCM_AM335X_CM_RTC 0x0800 +#define PRCM_AM335X_CM_GFX 0x0900 +#define PRCM_AM335X_CM_CEFUSE 0x0a00 +#define PRCM_AM335X_PRM_IRQ 0x0b00 +#define PRCM_AM335X_PRM_PER 0x0c00 +#define PRCM_AM335X_PRM_WKUP 0x0d00 +#define PRCM_AM335X_PRM_MPU 0x0e00 +#define PRCM_AM335X_PRM_DEVICE 0x0f00 +#define PRCM_AM335X_PRM_RTC 0x1000 +#define PRCM_AM335X_PRM_GFX 0x1100 +#define PRCM_AM335X_PRM_CEFUSE 0x1200 diff --git a/sys/arch/beagle/dev/omap3_prcmreg.h b/sys/arch/beagle/dev/omap3_prcmreg.h new file mode 100644 index 00000000000..217b26a265b --- /dev/null +++ b/sys/arch/beagle/dev/omap3_prcmreg.h @@ -0,0 +1,197 @@ +/* $OpenBSD: omap3_prcmreg.h,v 1.1 2013/05/14 12:01:17 rapha Exp $ */ +/* + * Copyright (c) 2007, 2009, 2012 Dale Rahn <drahn@dalerahn.com> + * + * Permission to use, copy, modify, and distribute this software for any + * purpose with or without fee is hereby granted, provided that the above + * copyright notice and this permission notice appear in all copies. + * + * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES + * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF + * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR + * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES + * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN + * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF + * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. + */ + +/* XXX - verify these definitions and correctly merge them with omap4 */ +#define CM_FCLKEN_IVA2 0x0000 +#define CM_CLKEN_PLL_IVA2 0x0004 +#define CM_IDLEST_IVA2 0x0020 +#define CM_IDLEST_PLL_IVA2 0x0024 +#define CM_AUTOIDLE_PLL_IVA2 0x0034 +#define CM_CLKSEL1_PLL_IVA2 0x0040 +#define CM_CLKSEL2_PLL_IVA2 0x0044 +#define CM_CLKSTCTRL_IVA2 0x0048 +#define CM_CLKSTST_IVA2 0x004c + +#define CM_CLKSEL_MPU 0x0940 +#define CM_CLKSTCTRL_MPU 0x0948 +#define RM_RSTST_MPU 0x0958 +#define PM_WKDEP_MPU 0x09C8 +#define PM_EVGENCTRL_MPU 0x09D4 +#define PM_EVEGENONTIM_MPU 0x09D8 +#define PM_EVEGENOFFTIM_MPU 0x09DC +#define PM_PWSTCTRL_MPU 0x09E0 +#define PM_PWSTST_MPU 0x09E4 + +#define CM_ICLKEN1_CORE 0x0a10 +#define CM_ICLKEN1_CORE_MSK 0x7ffffed2 +#define CM_ICLKEN2_CORE 0x0a14 +#define CM_ICLKEN2_CORE_MSK 0x0000001f +#define CM_ICLKEN3_CORE 0x0a18 +#define CM_ICLKEN3_CORE_MSK 0x00000004 +#define CM_ICLKEN4_CORE 0x0a1C +#define CM_IDLEST1_CORE 0x0a20 +#define CM_IDLEST2_CORE 0x0a24 +#define CM_IDLEST4_CORE 0x0a2C +#define CM_AUTOIDLE1_CORE 0x0a30 +#define CM_AUTOIDLE2_CORE 0x0a34 +#define CM_AUTOIDLE3_CORE 0x0a38 +#define CM_AUTOIDLE4_CORE 0x0a3C +#define CM_CLKSEL1_CORE 0x0a40 +#define CM_CLKSEL2_CORE 0x0a44 +#define CM_CLKSTCTRL_CORE 0x0a48 +#define PM_WKEN1_CORE 0x0aA0 +#define PM_WKEN2_CORE 0x0aA4 +#define PM_WKST1_CORE 0x0aB0 +#define PM_WKST2_CORE 0x0aB4 +#define PM_WKDEP_CORE 0x0aC8 +#define PM_PWSTCTRL_CORE 0x0aE0 +#define PM_PWSTST_CORE 0x0aE4 +#define CM_FCLKEN_GFX 0x0b00 +#define CM_ICLKEN_GFX 0x0b10 + +#define CM_IDLEST_GFX 0x0b20 +#define CM_CLKSEL_GFX 0x0b40 +#define CM_CLKSTCTRL_GFX 0x0b48 +#define RM_RSTCTRL_GFX 0x0b50 +#define RM_RSTST_GFX 0x0b58 +#define PM_WKDEP_GFX 0x0bC8 +#define PM_PWSTCTRL_GFX 0x0bE0 +#define PM_PWSTST_GFX 0x0bE4 +#define CM_FCLKEN_WKUP 0x0c00 +#define CM_FCLKEN_WKUP_GPT1 1 +#define CM_FCLKEN_WKUP_GPIOS 4 +#define CM_FCLKEN_WKUP_MPU_WDT 8 +#define CM_ICLKEN_WKUP 0xc10 +#define CM_ICLKEN_WKUP_GPT1 0x01 +#define CM_ICLKEN_WKUP_32KSYNC 0x02 +#define CM_ICLKEN_WKUP_GPIOS 0x04 +#define CM_ICLKEN_WKUP_MPU_WDT 0x08 +#define CM_ICLKEN_WKUP_WDT1 0x10 +#define CM_ICLKEN_WKUP_OMAPCTRL 0x20 +#define CM_IDLEST_WKUP 0x0c20 +#define CM_AUTOIDLE_WKUP 0x0c30 +#define CM_CLKSEL_WKUP 0x0c40 +#define RM_RSTCTRL_WKUP 0x0c50 +#define RM_RSTTIME_WKUP 0x0c54 +#define RM_RSTST_WKUP 0x0c58 +#define PM_WKEN_WKUP 0x0cA0 +#define PM_WKST_WKUP 0x0cB0 +#define CM_CLKEN_PLL 0x0d00 +#define CM_CLKEN2_PLL 0x0d04 +#define CM_IDLEST_CKGEN 0x0d20 +#define CM_AUTOIDLE_PLL 0x0d30 +#define CM_AUTOIDLE2_PLL 0x0d34 +#define CM_CLKSEL1_PLL 0x0d40 +#define CM_CLKSEL2_PLL 0x0d44 +#define CM_CLKSEL3_PLL 0x0d48 +#define CM_CLKSEL4_PLL 0x0d4C +#define CM_CLKSEL5_PLL 0x0d50 +#define CM_FCLKEN_PER 0x1000 +#define CM_ICLKEN_PER 0x1010 +#define CM_IDLEST_PER 0x1020 +#define CM_AUTOIDLE_PER 0x1030 +#define CM_CLKSEL_PER 0x1040 +#define CM_SLEEPDEP_PER 0x1044 +#define CM_CLKSTCTRL_PER 0x1048 +#define CM_CLKSTST_PER 0x104C + +#define CM_CLKSEL1_EMU 0x5140 +#define CM_CLKSTCTRL_EMU 0x5148 +#define CM_CLKSTST_EMU 0x514C +#define CM_CLKSEL2_EMU 0x5150 +#define CM_CLKSEL3_EMU 0x5154 + +#define CM_POLCTRL 0x529C + +#define CM_IDLEST_NEON 0x5320 +#define CM_CLKSTCTRL_NEON 0x5348 + +#define CM_FCLKEN_USBHOST 0x5400 +#define CM_ICLKEN_USBHOST 0x5410 +#define CM_IDLEST_USBHOST 0x5420 +#define CM_AUTOIDLE_USBHOST 0x5430 +#define CM_SLEEPDEP_USBHOST 0x5444 +#define CM_CLKSTCTRL_USBHOST 0x5448 +#define CM_CLKSTST_USBHOST 0x544C + +/* from prcmvar.h */ +#define CM_FCLKEN1_CORE 0x0a00 +#define CM_FCLKEN1_CORE_MSK 0x41fffe00 +#define CM_FCLKEN2_CORE 0x0a04 +#define CM_FCLKEN2_CORE_MSK 0x00000000 +#define CM_FCLKEN3_CORE 0x0a08 +#define CM_FCLKEN3_CORE_MSK 0x00000007 + +#define PRCM_REG_CORE_CLK1 0 +#define PRCM_REG_CORE_CLK1_FADDR CM_FCLKEN1_CORE +#define PRCM_REG_CORE_CLK1_IADDR CM_ICLKEN1_CORE +#define PRCM_REG_CORE_CLK1_FMASK CM_FCLKEN1_CORE_MSK +#define PRCM_REG_CORE_CLK1_IMASK CM_ICLKEN1_CORE_MSK +#define PRCM_REG_CORE_CLK1_BASE (PRCM_REG_CORE_CLK1*32) +#define PRCM_CLK_EN_MMC3 (PRCM_REG_CORE_CLK1_BASE + 30) +#define PRCM_CLK_EN_ICR (PRCM_REG_CORE_CLK1_BASE + 29) +#define PRCM_CLK_EN_AES2 (PRCM_REG_CORE_CLK1_BASE + 28) +#define PRCM_CLK_EN_SHA12 (PRCM_REG_CORE_CLK1_BASE + 27) +#define PRCM_CLK_EN_DES2 (PRCM_REG_CORE_CLK1_BASE + 26) +#define PRCM_CLK_EN_MMC2 (PRCM_REG_CORE_CLK1_BASE + 25) +#define PRCM_CLK_EN_MMC1 (PRCM_REG_CORE_CLK1_BASE + 24) +#define PRCM_CLK_EN_MSPRO (PRCM_REG_CORE_CLK1_BASE + 23) +#define PRCM_CLK_EN_HDQ (PRCM_REG_CORE_CLK1_BASE + 22) +#define PRCM_CLK_EN_MCSPI4 (PRCM_REG_CORE_CLK1_BASE + 21) +#define PRCM_CLK_EN_MCSPI3 (PRCM_REG_CORE_CLK1_BASE + 20) +#define PRCM_CLK_EN_MCSPI2 (PRCM_REG_CORE_CLK1_BASE + 19) +#define PRCM_CLK_EN_MCSPI1 (PRCM_REG_CORE_CLK1_BASE + 18) +#define PRCM_CLK_EN_I2C3 (PRCM_REG_CORE_CLK1_BASE + 17) +#define PRCM_CLK_EN_I2C2 (PRCM_REG_CORE_CLK1_BASE + 16) +#define PRCM_CLK_EN_I2C1 (PRCM_REG_CORE_CLK1_BASE + 15) +#define PRCM_CLK_EN_UART2 (PRCM_REG_CORE_CLK1_BASE + 14) +#define PRCM_CLK_EN_UART1 (PRCM_REG_CORE_CLK1_BASE + 13) +#define PRCM_CLK_EN_GPT11 (PRCM_REG_CORE_CLK1_BASE + 12) +#define PRCM_CLK_EN_GPT10 (PRCM_REG_CORE_CLK1_BASE + 11) +#define PRCM_CLK_EN_MCBSP5 (PRCM_REG_CORE_CLK1_BASE + 10) +#define PRCM_CLK_EN_MCBSP1 (PRCM_REG_CORE_CLK1_BASE + 9) +#define PRCM_CLK_EN_MAILBOXES (PRCM_REG_CORE_CLK1_BASE + 7) +#define PRCM_CLK_EN_OMAPCTRL (PRCM_REG_CORE_CLK1_BASE + 6) +#define PRCM_CLK_EN_HSOTGUSB (PRCM_REG_CORE_CLK1_BASE + 4) +#define PRCM_CLK_EN_SDRC (PRCM_REG_CORE_CLK1_BASE + 1) + +#define PRCM_REG_CORE_CLK2 1 +#define PRCM_REG_CORE_CLK2_FADDR CM_FCLKEN2_CORE +#define PRCM_REG_CORE_CLK2_IADDR CM_ICLKEN2_CORE +#define PRCM_REG_CORE_CLK2_FMASK CM_FCLKEN2_CORE_MSK +#define PRCM_REG_CORE_CLK2_IMASK CM_ICLKEN2_CORE_MSK +#define PRCM_REG_CORE_CLK2_BASE (PRCM_REG_CORE_CLK2*32) + +#define PRCM_REG_CORE_CLK3 2 +#define PRCM_REG_CORE_CLK3_FADDR CM_FCLKEN3_CORE +#define PRCM_REG_CORE_CLK3_IADDR CM_ICLKEN3_CORE +#define PRCM_REG_CORE_CLK3_FMASK CM_FCLKEN3_CORE_MSK +#define PRCM_REG_CORE_CLK3_IMASK CM_ICLKEN3_CORE_MSK +#define PRCM_REG_CORE_CLK3_BASE (PRCM_REG_CORE_CLK3*32) + +#define CM_CORE_EN_USBTLL (PRCM_REG_CORE_CLK3_BASE + 2) +#define CM_CORE_EN_TS (PRCM_REG_CORE_CLK3_BASE + 1) +#define CM_CORE_EN_CPEFUSE (PRCM_REG_CORE_CLK3_BASE + 0) + +#define PRCM_REG_USBHOST 3 +#define PRCM_REG_USBHOST_FADDR 0x1400 +#define PRCM_REG_USBHOST_IADDR 0x1410 +#define PRCM_REG_USBHOST_FMASK 0x3 +#define PRCM_REG_USBHOST_IMASK 0x1 +#define PRCM_REG_USBHOST_BASE (PRCM_REG_USBHOST*32) + +#define PRCM_CLK_EN_USB (PRCM_REG_USBHOST_BASE + 0) diff --git a/sys/arch/beagle/dev/omehci.c b/sys/arch/beagle/dev/omehci.c index 831c06b9b1c..5efe9ed6f08 100644 --- a/sys/arch/beagle/dev/omehci.c +++ b/sys/arch/beagle/dev/omehci.c @@ -1,4 +1,4 @@ -/* $OpenBSD: omehci.c,v 1.12 2013/04/20 17:43:53 deraadt Exp $ */ +/* $OpenBSD: omehci.c,v 1.13 2013/05/14 12:01:17 rapha Exp $ */ /* * Copyright (c) 2005 David Gwynne <dlg@openbsd.org> @@ -79,7 +79,7 @@ omehci_attach(struct device *parent, struct device *self, void *aux) bus_space_barrier(sc->sc.iot, sc->sc.ioh, 0, sc->sc.sc_size, BUS_SPACE_BARRIER_READ|BUS_SPACE_BARRIER_WRITE); - prcm_enableclock(PRCM_CLK_EN_USB); + prcm_enablemodule(PRCM_USB); #if 0 omehci_enable(sc); @@ -165,13 +165,13 @@ omehci_activate(struct device *self, int act) sc->sc.sc_bus.use_polling++; #if 0 ohci_activate(&sc->sc, act); - prcm_disableclock(PRCM_CLK_EN_USB); + prcm_disablemodule(PRCM_USB); #endif sc->sc.sc_bus.use_polling--; break; case DVACT_RESUME: sc->sc.sc_bus.use_polling++; - prcm_enableclock(PRCM_CLK_EN_USB); + prcm_enablemodule(PRCM_USB); #if 0 omehci_enable(sc); ohci_activate(&sc->sc, act); diff --git a/sys/arch/beagle/dev/omohci.c b/sys/arch/beagle/dev/omohci.c index 2073550b561..bde69971558 100644 --- a/sys/arch/beagle/dev/omohci.c +++ b/sys/arch/beagle/dev/omohci.c @@ -1,4 +1,4 @@ -/* $OpenBSD: omohci.c,v 1.7 2013/04/20 17:43:53 deraadt Exp $ */ +/* $OpenBSD: omohci.c,v 1.8 2013/05/14 12:01:17 rapha Exp $ */ /* * Copyright (c) 2005 David Gwynne <dlg@openbsd.org> @@ -193,7 +193,7 @@ omohci_attach(struct device *parent, struct device *self, void *aux) return; } - prcm_enableclock(PRCM_CLK_EN_USB); + prcm_enablemodule(PRCM_USB); bus_space_write_4(sc->sc.iot, sc->sc.ioh, OTG_SYSCON_2, OTG_SYSCON2_UHOST_EN | OTG_SYSCON2_MODE_HOST); diff --git a/sys/arch/beagle/dev/omusbtll.c b/sys/arch/beagle/dev/omusbtll.c index 91d96162a4b..9a20eac5e20 100644 --- a/sys/arch/beagle/dev/omusbtll.c +++ b/sys/arch/beagle/dev/omusbtll.c @@ -1,4 +1,4 @@ -/* $OpenBSD: omusbtll.c,v 1.4 2011/11/10 19:37:01 uwe Exp $ */ +/* $OpenBSD: omusbtll.c,v 1.5 2013/05/14 12:01:17 rapha Exp $ */ /* * Copyright (c) 2010 Dale Rahn <drahn@openbsd.org> * @@ -112,15 +112,15 @@ omusbtll_attach(struct device *parent, struct device *self, void *args) sc->sc_iot = oa->oa_iot; if (bus_space_map(sc->sc_iot, oa->oa_dev->mem[0].addr, oa->oa_dev->mem[0].size, 0, &sc->sc_ioh)) { - printf("omgpio_attach: bus_space_map failed!\n"); + printf("%s: bus_space_map failed!\n", __func__); return; } #if 0 - prcm_enableclock(PRCM_CLK_EN_USBHOST1); - prcm_enableclock(PRCM_CLK_EN_USBHOST2); + prcm_enablemodule(PRCM_USBHOST1); + prcm_enablemodule(PRCM_USBHOST2); #endif - prcm_enableclock(CM_CORE_EN_USBTLL); + prcm_enablemodule(PRCM_USBTLL); delay(10000); diff --git a/sys/arch/beagle/dev/prcm.c b/sys/arch/beagle/dev/prcm.c index 6115304082f..f32c1d5ceee 100644 --- a/sys/arch/beagle/dev/prcm.c +++ b/sys/arch/beagle/dev/prcm.c @@ -1,4 +1,4 @@ -/* $OpenBSD: prcm.c,v 1.10 2013/05/03 17:58:15 patrick Exp $ */ +/* $OpenBSD: prcm.c,v 1.11 2013/05/14 12:01:17 rapha Exp $ */ /* * Copyright (c) 2007,2009 Dale Rahn <drahn@openbsd.org> * @@ -32,123 +32,12 @@ #include <beagle/dev/omapvar.h> #include <beagle/dev/prcmvar.h> -#define CM_FCLKEN_IVA2 0x0000 -#define CM_CLKEN_PLL_IVA2 0x0004 -#define CM_IDLEST_IVA2 0x0020 -#define CM_IDLEST_PLL_IVA2 0x0024 -#define CM_AUTOIDLE_PLL_IVA2 0x0034 -#define CM_CLKSEL1_PLL_IVA2 0x0040 -#define CM_CLKSEL2_PLL_IVA2 0x0044 -#define CM_CLKSTCTRL_IVA2 0x0048 -#define CM_CLKSTST_IVA2 0x004c +#include <beagle/dev/am335x_prcmreg.h> +#include <beagle/dev/omap3_prcmreg.h> #define PRCM_REVISION 0x0800 #define PRCM_SYSCONFIG 0x0810 -#define CM_CLKSEL_MPU 0x0940 -#define CM_CLKSTCTRL_MPU 0x0948 -#define RM_RSTST_MPU 0x0958 -#define PM_WKDEP_MPU 0x09C8 -#define PM_EVGENCTRL_MPU 0x09D4 -#define PM_EVEGENONTIM_MPU 0x09D8 -#define PM_EVEGENOFFTIM_MPU 0x09DC -#define PM_PWSTCTRL_MPU 0x09E0 -#define PM_PWSTST_MPU 0x09E4 - -#define CM_ICLKEN1_CORE 0x0a10 -#define CM_ICLKEN1_CORE_MSK 0x7ffffed2 -#define CM_ICLKEN2_CORE 0x0a14 -#define CM_ICLKEN2_CORE_MSK 0x0000001f -#define CM_ICLKEN3_CORE 0x0a18 -#define CM_ICLKEN3_CORE_MSK 0x00000004 -#define CM_ICLKEN4_CORE 0x0a1C -#define CM_IDLEST1_CORE 0x0a20 -#define CM_IDLEST2_CORE 0x0a24 -#define CM_IDLEST4_CORE 0x0a2C -#define CM_AUTOIDLE1_CORE 0x0a30 -#define CM_AUTOIDLE2_CORE 0x0a34 -#define CM_AUTOIDLE3_CORE 0x0a38 -#define CM_AUTOIDLE4_CORE 0x0a3C -#define CM_CLKSEL1_CORE 0x0a40 -#define CM_CLKSEL2_CORE 0x0a44 -#define CM_CLKSTCTRL_CORE 0x0a48 -#define PM_WKEN1_CORE 0x0aA0 -#define PM_WKEN2_CORE 0x0aA4 -#define PM_WKST1_CORE 0x0aB0 -#define PM_WKST2_CORE 0x0aB4 -#define PM_WKDEP_CORE 0x0aC8 -#define PM_PWSTCTRL_CORE 0x0aE0 -#define PM_PWSTST_CORE 0x0aE4 -#define CM_FCLKEN_GFX 0x0b00 -#define CM_ICLKEN_GFX 0x0b10 - -#define CM_IDLEST_GFX 0x0b20 -#define CM_CLKSEL_GFX 0x0b40 -#define CM_CLKSTCTRL_GFX 0x0b48 -#define RM_RSTCTRL_GFX 0x0b50 -#define RM_RSTST_GFX 0x0b58 -#define PM_WKDEP_GFX 0x0bC8 -#define PM_PWSTCTRL_GFX 0x0bE0 -#define PM_PWSTST_GFX 0x0bE4 -#define CM_FCLKEN_WKUP 0x0c00 -#define CM_FCLKEN_WKUP_GPT1 1 -#define CM_FCLKEN_WKUP_GPIOS 4 -#define CM_FCLKEN_WKUP_MPU_WDT 8 -#define CM_ICLKEN_WKUP 0xc10 -#define CM_ICLKEN_WKUP_GPT1 0x01 -#define CM_ICLKEN_WKUP_32KSYNC 0x02 -#define CM_ICLKEN_WKUP_GPIOS 0x04 -#define CM_ICLKEN_WKUP_MPU_WDT 0x08 -#define CM_ICLKEN_WKUP_WDT1 0x10 -#define CM_ICLKEN_WKUP_OMAPCTRL 0x20 -#define CM_IDLEST_WKUP 0x0c20 -#define CM_AUTOIDLE_WKUP 0x0c30 -#define CM_CLKSEL_WKUP 0x0c40 -#define RM_RSTCTRL_WKUP 0x0c50 -#define RM_RSTTIME_WKUP 0x0c54 -#define RM_RSTST_WKUP 0x0c58 -#define PM_WKEN_WKUP 0x0cA0 -#define PM_WKST_WKUP 0x0cB0 -#define CM_CLKEN_PLL 0x0d00 -#define CM_CLKEN2_PLL 0x0d04 -#define CM_IDLEST_CKGEN 0x0d20 -#define CM_AUTOIDLE_PLL 0x0d30 -#define CM_AUTOIDLE2_PLL 0x0d34 -#define CM_CLKSEL1_PLL 0x0d40 -#define CM_CLKSEL2_PLL 0x0d44 -#define CM_CLKSEL3_PLL 0x0d48 -#define CM_CLKSEL4_PLL 0x0d4C -#define CM_CLKSEL5_PLL 0x0d50 -#define CM_FCLKEN_PER 0x1000 -#define CM_ICLKEN_PER 0x1010 -#define CM_IDLEST_PER 0x1020 -#define CM_AUTOIDLE_PER 0x1030 -#define CM_CLKSEL_PER 0x1040 -#define CM_SLEEPDEP_PER 0x1044 -#define CM_CLKSTCTRL_PER 0x1048 -#define CM_CLKSTST_PER 0x104C - -#define CM_CLKSEL1_EMU 0x5140 -#define CM_CLKSTCTRL_EMU 0x5148 -#define CM_CLKSTST_EMU 0x514C -#define CM_CLKSEL2_EMU 0x5150 -#define CM_CLKSEL3_EMU 0x5154 - -#define CM_POLCTRL 0x529C - -#define CM_IDLEST_NEON 0x5320 -#define CM_CLKSTCTRL_NEON 0x5348 - -#define CM_FCLKEN_USBHOST 0x5400 -#define CM_ICLKEN_USBHOST 0x5410 -#define CM_IDLEST_USBHOST 0x5420 -#define CM_AUTOIDLE_USBHOST 0x5430 -#define CM_SLEEPDEP_USBHOST 0x5444 -#define CM_CLKSTCTRL_USBHOST 0x5448 -#define CM_CLKSTST_USBHOST 0x544C - -uint32_t prcm_imask_cur[PRCM_REG_MAX]; -uint32_t prcm_fmask_cur[PRCM_REG_MAX]; uint32_t prcm_imask_mask[PRCM_REG_MAX]; uint32_t prcm_fmask_mask[PRCM_REG_MAX]; uint32_t prcm_imask_addr[PRCM_REG_MAX]; @@ -156,15 +45,30 @@ uint32_t prcm_fmask_addr[PRCM_REG_MAX]; #define SYS_CLK 13 /* SYS_CLK speed in MHz */ -bus_space_tag_t prcm_iot; -bus_space_handle_t prcm_ioh; +struct prcm_softc { + struct device sc_dev; + bus_space_tag_t sc_iot; + bus_space_handle_t sc_ioh; + void (*sc_enablemodule)(struct prcm_softc *sc, int mod); + void (*sc_setclock)(struct prcm_softc *sc, + int clock, int speed); +}; + +int prcm_match(struct device *, void *, void *); +void prcm_attach(struct device *, struct device *, void *); +int prcm_setup_dpll5(struct prcm_softc *); +uint32_t prcm_v3_bit(int mod); +uint32_t prcm_am335x_clkctrl(int mod); -int prcm_match(struct device *, void *, void *); -void prcm_attach(struct device *, struct device *, void *); -int prcm_setup_dpll5(void); +void prcm_am335x_enablemodule(struct prcm_softc *, int); +void prcm_am335x_setclock(struct prcm_softc *, int, int); + +void prcm_v3_setup(struct prcm_softc *); +void prcm_v3_enablemodule(struct prcm_softc *, int); +void prcm_v3_setclock(struct prcm_softc *, int, int); struct cfattach prcm_ca = { - sizeof (struct device), NULL, prcm_attach + sizeof (struct prcm_softc), NULL, prcm_attach }; struct cfdriver prcm_cd = { @@ -175,47 +79,42 @@ void prcm_attach(struct device *parent, struct device *self, void *args) { struct omap_attach_args *oa = args; + struct prcm_softc *sc = (struct prcm_softc *) self; u_int32_t reg; - prcm_iot = oa->oa_iot; + sc->sc_iot = oa->oa_iot; - if (bus_space_map(prcm_iot, oa->oa_dev->mem[0].addr, - oa->oa_dev->mem[0].size, 0, &prcm_ioh)) + if (bus_space_map(sc->sc_iot, oa->oa_dev->mem[0].addr, + oa->oa_dev->mem[0].size, 0, &sc->sc_ioh)) panic("prcm_attach: bus_space_map failed!"); - reg = bus_space_read_4(prcm_iot, prcm_ioh, PRCM_REVISION); + reg = bus_space_read_4(sc->sc_iot, sc->sc_ioh, PRCM_REVISION); printf(" rev %d.%d\n", reg >> 4 & 0xf, reg & 0xf); - - /* Setup the 120MHZ DPLL5 clock, to be used by USB. */ - prcm_setup_dpll5(); - /* XXX */ -#if 1 - printf("CM_FCLKEN1_CORE %x\n", bus_space_read_4(prcm_iot, prcm_ioh, CM_FCLKEN1_CORE)); - printf("CM_ICLKEN1_CORE %x\n", bus_space_read_4(prcm_iot, prcm_ioh, CM_ICLKEN1_CORE)); - printf("CM_AUTOIDLE1_CORE %x\n", bus_space_read_4(prcm_iot, prcm_ioh, CM_AUTOIDLE1_CORE)); + switch (board_id) { + case BOARD_ID_AM335X_BEAGLEBONE: + sc->sc_enablemodule = prcm_am335x_enablemodule; + sc->sc_setclock = prcm_am335x_setclock; + break; + case BOARD_ID_OMAP3_BEAGLE: + case BOARD_ID_OMAP3_OVERO: + sc->sc_enablemodule = prcm_v3_enablemodule; + sc->sc_setclock = prcm_v3_setclock; + prcm_v3_setup(sc); + break; + case BOARD_ID_OMAP4_PANDA: + sc->sc_enablemodule = NULL; + sc->sc_setclock = NULL; + break; + } +} - printf("CM_FCLKEN_WKUP %x\n", bus_space_read_4(prcm_iot, prcm_ioh, CM_FCLKEN_WKUP)); - printf(" CM_IDLEST_WKUP %x\n", bus_space_read_4(prcm_iot, prcm_ioh, CM_IDLEST_WKUP)); -// bus_space_write_4(prcm_iot, prcm_ioh, -#endif +void +prcm_v3_setup(struct prcm_softc *sc) +{ + /* Setup the 120MHZ DPLL5 clock, to be used by USB. */ + prcm_setup_dpll5(sc); -#if 0 - reg = bus_space_read_4(prcm_iot, prcm_ioh, CM_FCLKEN1_CORE); - reg |= CM_FCLKEN1_CORE_GP3|CM_FCLKEN1_CORE_GP2; - bus_space_write_4(prcm_iot, prcm_ioh, CM_FCLKEN1_CORE, reg); - reg = bus_space_read_4(prcm_iot, prcm_ioh, CM_ICLKEN1_CORE); - reg |= CM_ICLKEN1_CORE_GP3|CM_ICLKEN1_CORE_GP2; - bus_space_write_4(prcm_iot, prcm_ioh, CM_ICLKEN1_CORE, reg); - - reg = bus_space_read_4(prcm_iot, prcm_ioh, CM_FCLKEN_WKUP); - reg |= CM_FCLKEN_WKUP_MPU_WDT | CM_FCLKEN_WKUP_GPT1; - bus_space_write_4(prcm_iot, prcm_ioh, CM_FCLKEN_WKUP, reg); - - reg = bus_space_read_4(prcm_iot, prcm_ioh, CM_ICLKEN_WKUP); - reg |= CM_ICLKEN_WKUP_MPU_WDT | CM_ICLKEN_WKUP_GPT1; - bus_space_write_4(prcm_iot, prcm_ioh, CM_ICLKEN_WKUP, reg); -#endif prcm_fmask_mask[PRCM_REG_CORE_CLK1] = PRCM_REG_CORE_CLK1_FMASK; prcm_imask_mask[PRCM_REG_CORE_CLK1] = PRCM_REG_CORE_CLK1_IMASK; prcm_fmask_addr[PRCM_REG_CORE_CLK1] = PRCM_REG_CORE_CLK1_FADDR; @@ -235,41 +134,133 @@ prcm_attach(struct device *parent, struct device *self, void *args) prcm_imask_mask[PRCM_REG_USBHOST] = PRCM_REG_USBHOST_IMASK; prcm_fmask_addr[PRCM_REG_USBHOST] = PRCM_REG_USBHOST_FADDR; prcm_imask_addr[PRCM_REG_USBHOST] = PRCM_REG_USBHOST_IADDR; - } void prcm_setclock(int clock, int speed) { -#if 1 + struct prcm_softc *sc = prcm_cd.cd_devs[0]; + + if (!sc->sc_setclock) + panic("%s: not initialised!", __func__); + + sc->sc_setclock(sc, clock, speed); +} + +void +prcm_am335x_setclock(struct prcm_softc *sc, int clock, int speed) +{ + u_int32_t oreg, reg, mask; + + /* set CLKSEL register */ + if (clock == 1) { + oreg = bus_space_read_4(sc->sc_iot, sc->sc_ioh, + PRCM_AM335X_CLKSEL_TIMER2_CLK); + mask = 3; + reg = oreg & ~mask; + reg |=0x02; + bus_space_write_4(sc->sc_iot, sc->sc_ioh, + PRCM_AM335X_CLKSEL_TIMER2_CLK, reg); + } else if (clock == 2) { + oreg = bus_space_read_4(sc->sc_iot, sc->sc_ioh, + PRCM_AM335X_CLKSEL_TIMER3_CLK); + mask = 3; + reg = oreg & ~mask; + reg |=0x02; + bus_space_write_4(sc->sc_iot, sc->sc_ioh, + PRCM_AM335X_CLKSEL_TIMER3_CLK, reg); + } +} + +void +prcm_v3_setclock(struct prcm_softc *sc, int clock, int speed) +{ u_int32_t oreg, reg, mask; + if (clock == 1) { - oreg = bus_space_read_4(prcm_iot, prcm_ioh, CM_CLKSEL_WKUP); + oreg = bus_space_read_4(sc->sc_iot, sc->sc_ioh, CM_CLKSEL_WKUP); mask = 1; reg = (oreg &~mask) | (speed & mask); - printf(" prcm_setclock old %08x new %08x", oreg, reg ); - bus_space_write_4(prcm_iot, prcm_ioh, CM_CLKSEL_WKUP, reg); + printf("%s: old %08x new %08x", __func__, oreg, reg); + bus_space_write_4(sc->sc_iot, sc->sc_ioh, CM_CLKSEL_WKUP, reg); } else if (clock >= 2 && clock <= 9) { int shift = (clock-2); - oreg = bus_space_read_4(prcm_iot, prcm_ioh, CM_CLKSEL_PER); - + oreg = bus_space_read_4(sc->sc_iot, sc->sc_ioh, CM_CLKSEL_PER); mask = 1 << (shift); reg = (oreg & ~mask) | ( (speed << shift) & mask); - printf(" prcm_setclock old %08x new %08x", oreg, reg); - - bus_space_write_4(prcm_iot, prcm_ioh, CM_CLKSEL_PER, reg); + printf("%s: old %08x new %08x", __func__, oreg, reg); + bus_space_write_4(sc->sc_iot, sc->sc_ioh, CM_CLKSEL_PER, reg); } else - panic("prcm_setclock invalid clock %d", clock); -#endif + panic("%s: invalid clock %d", __func__, clock); +} + +uint32_t +prcm_v3_bit(int mod) +{ + switch(mod) { + case PRCM_MMC: + return PRCM_CLK_EN_MMC1; + case PRCM_USB: + return PRCM_CLK_EN_USB; + default: + panic("%s: module not found\n", __func__); + } +} + +uint32_t +prcm_am335x_clkctrl(int mod) +{ + switch(mod) { + case PRCM_TIMER2: + return PRCM_AM335X_TIMER2_CLKCTRL; + case PRCM_TIMER3: + return PRCM_AM335X_TIMER3_CLKCTRL; + case PRCM_MMC: + return PRCM_AM335X_MMC0_CLKCTRL; + case PRCM_USB: + return PRCM_AM335X_USB0_CLKCTRL; + default: + panic("%s: module not found\n", __func__); + } } void -prcm_enableclock(int bit) +prcm_enablemodule(int mod) { - u_int32_t fclk, iclk, fmask, imask, mbit; + struct prcm_softc *sc = prcm_cd.cd_devs[0]; + + if (!sc->sc_enablemodule) + panic("%s: not initialised!", __func__); + + sc->sc_enablemodule(sc, mod); +} + +void +prcm_am335x_enablemodule(struct prcm_softc *sc, int mod) +{ + uint32_t clkctrl; + int reg; + + /*set enable bits in CLKCTRL register */ + reg = prcm_am335x_clkctrl(mod); + clkctrl = bus_space_read_4(sc->sc_iot, sc->sc_ioh, reg); + clkctrl &=~AM335X_CLKCTRL_MODULEMODE_MASK; + clkctrl |= AM335X_CLKCTRL_MODULEMODE_ENABLE; + bus_space_write_4(sc->sc_iot, sc->sc_ioh, reg, clkctrl); + + /* wait until module is enabled */ + while (bus_space_read_4(sc->sc_iot, sc->sc_ioh, reg) & 0x30000) + ; +} + +void +prcm_v3_enablemodule(struct prcm_softc *sc, int mod) +{ + uint32_t bit; + uint32_t fclk, iclk, fmask, imask, mbit; int freg, ireg, reg; - printf("prcm_enableclock %d:", bit); + bit = prcm_v3_bit(mod); reg = bit >> 5; freg = prcm_fmask_addr[reg]; @@ -277,25 +268,16 @@ prcm_enableclock(int bit) fmask = prcm_fmask_mask[reg]; imask = prcm_imask_mask[reg]; - mbit = 1 << (bit & 0x1f); -#if 0 - printf("reg %d faddr 0x%08x iaddr 0x%08x, fmask 0x%08x " - "imask 0x%08x mbit %x", reg, freg, ireg, fmask, imask, mbit); -#endif + mbit = 1 << (bit & 0x1f); if (fmask & mbit) { /* dont access the register if bit isn't present */ - fclk = bus_space_read_4(prcm_iot, prcm_ioh, freg); - prcm_fmask_cur[reg] = fclk | mbit; - bus_space_write_4(prcm_iot, prcm_ioh, freg, fclk | mbit); - printf(" fclk %08x %08x", fclk, fclk | mbit); + fclk = bus_space_read_4(sc->sc_iot, sc->sc_ioh, freg); + bus_space_write_4(sc->sc_iot, sc->sc_ioh, freg, fclk | mbit); } - if (imask & mbit) { /* dont access the register if bit isn't present */ - iclk = bus_space_read_4(prcm_iot, prcm_ioh, ireg); - prcm_imask_cur[reg] = iclk | mbit; - bus_space_write_4(prcm_iot, prcm_ioh, ireg, iclk | mbit); - printf(" iclk %08x %08x", iclk, iclk | mbit); + iclk = bus_space_read_4(sc->sc_iot, sc->sc_ioh, ireg); + bus_space_write_4(sc->sc_iot, sc->sc_ioh, ireg, iclk | mbit); } - printf ("\n"); + printf("\n"); } /* @@ -307,7 +289,7 @@ prcm_enableclock(int bit) * SYS_CLK, running at 13MHz. */ int -prcm_setup_dpll5(void) +prcm_setup_dpll5(struct prcm_softc *sc) { uint32_t val; @@ -317,10 +299,10 @@ prcm_setup_dpll5(void) * with 120 (sprugn4h.pdf, 13.4.11.4.1 SSC Configuration) */ val = ((120 & 0x7ff) << 8) | ((SYS_CLK - 1) & 0x7f); - bus_space_write_4(prcm_iot, prcm_ioh, CM_CLKSEL4_PLL, val); + bus_space_write_4(sc->sc_iot, sc->sc_ioh, CM_CLKSEL4_PLL, val); /* Clock divider from the PLL to the 120MHz clock. */ - bus_space_write_4(prcm_iot, prcm_ioh, CM_CLKSEL5_PLL, val); + bus_space_write_4(sc->sc_iot, sc->sc_ioh, CM_CLKSEL5_PLL, val); /* * spruf98o.pdf, page 2319: @@ -328,13 +310,13 @@ prcm_setup_dpll5(void) * EN_PERIPH2_DPLL is 0x7 */ val = (7 << 4) | (7 << 0); - bus_space_write_4(prcm_iot, prcm_ioh, CM_CLKEN2_PLL, val); + bus_space_write_4(sc->sc_iot, sc->sc_ioh, CM_CLKEN2_PLL, val); /* Disable the interconnect clock auto-idle. */ - bus_space_write_4(prcm_iot, prcm_ioh, CM_AUTOIDLE2_PLL, 0x0); + bus_space_write_4(sc->sc_iot, sc->sc_ioh, CM_AUTOIDLE2_PLL, 0x0); /* Wait until DPLL5 is locked and there's clock activity. */ - while ((val = bus_space_read_4(prcm_iot, prcm_ioh, + while ((val = bus_space_read_4(sc->sc_iot, sc->sc_ioh, CM_IDLEST_CKGEN) & 0x01) == 0x00) { #ifdef DIAGNOSTIC printf("CM_IDLEST_PLL = 0x%08x\n", val); diff --git a/sys/arch/beagle/dev/prcmvar.h b/sys/arch/beagle/dev/prcmvar.h index cfc72df9f04..a65f0a4f516 100644 --- a/sys/arch/beagle/dev/prcmvar.h +++ b/sys/arch/beagle/dev/prcmvar.h @@ -1,4 +1,4 @@ -/* $OpenBSD: prcmvar.h,v 1.4 2010/02/13 06:03:37 drahn Exp $ */ +/* $OpenBSD: prcmvar.h,v 1.5 2013/05/14 12:01:17 rapha Exp $ */ /* * Copyright (c) 2007,2009 Dale Rahn <drahn@openbsd.org> * @@ -16,81 +16,21 @@ */ void prcm_setclock(int clock, int speed); +void prcm_enablemodule(int mod); +void prcm_disablemodule(int mod); + #define PRCM_CLK_SPEED_32 0 #define PRCM_CLK_SPEED_SYS 1 -void prcm_enableclock(int bit); - -#define CM_FCLKEN1_CORE 0x0a00 -#define CM_FCLKEN1_CORE_MSK 0x41fffe00 - -#define CM_FCLKEN2_CORE 0x0a04 -#define CM_FCLKEN2_CORE_MSK 0x00000000 -#define CM_FCLKEN3_CORE 0x0a08 -#define CM_FCLKEN3_CORE_MSK 0x00000007 - -#define PRCM_REG_CORE_CLK1 0 -#define PRCM_REG_CORE_CLK1_FADDR CM_FCLKEN1_CORE -#define PRCM_REG_CORE_CLK1_IADDR CM_ICLKEN1_CORE -#define PRCM_REG_CORE_CLK1_FMASK CM_FCLKEN1_CORE_MSK -#define PRCM_REG_CORE_CLK1_IMASK CM_ICLKEN1_CORE_MSK -#define PRCM_REG_CORE_CLK1_BASE (PRCM_REG_CORE_CLK1*32) -#define PRCM_CLK_EN_MMC3 (PRCM_REG_CORE_CLK1_BASE + 30) -#define PRCM_CLK_EN_ICR (PRCM_REG_CORE_CLK1_BASE + 29) -#define PRCM_CLK_EN_AES2 (PRCM_REG_CORE_CLK1_BASE + 28) -#define PRCM_CLK_EN_SHA12 (PRCM_REG_CORE_CLK1_BASE + 27) -#define PRCM_CLK_EN_DES2 (PRCM_REG_CORE_CLK1_BASE + 26) -#define PRCM_CLK_EN_MMC2 (PRCM_REG_CORE_CLK1_BASE + 25) -#define PRCM_CLK_EN_MMC1 (PRCM_REG_CORE_CLK1_BASE + 24) -#define PRCM_CLK_EN_MSPRO (PRCM_REG_CORE_CLK1_BASE + 23) -#define PRCM_CLK_EN_HDQ (PRCM_REG_CORE_CLK1_BASE + 22) -#define PRCM_CLK_EN_MCSPI4 (PRCM_REG_CORE_CLK1_BASE + 21) -#define PRCM_CLK_EN_MCSPI3 (PRCM_REG_CORE_CLK1_BASE + 20) -#define PRCM_CLK_EN_MCSPI2 (PRCM_REG_CORE_CLK1_BASE + 19) -#define PRCM_CLK_EN_MCSPI1 (PRCM_REG_CORE_CLK1_BASE + 18) -#define PRCM_CLK_EN_I2C3 (PRCM_REG_CORE_CLK1_BASE + 17) -#define PRCM_CLK_EN_I2C2 (PRCM_REG_CORE_CLK1_BASE + 16) -#define PRCM_CLK_EN_I2C1 (PRCM_REG_CORE_CLK1_BASE + 15) -#define PRCM_CLK_EN_UART2 (PRCM_REG_CORE_CLK1_BASE + 14) -#define PRCM_CLK_EN_UART1 (PRCM_REG_CORE_CLK1_BASE + 13) -#define PRCM_CLK_EN_GPT11 (PRCM_REG_CORE_CLK1_BASE + 12) -#define PRCM_CLK_EN_GPT10 (PRCM_REG_CORE_CLK1_BASE + 11) -#define PRCM_CLK_EN_MCBSP5 (PRCM_REG_CORE_CLK1_BASE + 10) -#define PRCM_CLK_EN_MCBSP1 (PRCM_REG_CORE_CLK1_BASE + 9) -#define PRCM_CLK_EN_MAILBOXES (PRCM_REG_CORE_CLK1_BASE + 7) -#define PRCM_CLK_EN_OMAPCTRL (PRCM_REG_CORE_CLK1_BASE + 6) -#define PRCM_CLK_EN_HSOTGUSB (PRCM_REG_CORE_CLK1_BASE + 4) -#define PRCM_CLK_EN_SDRC (PRCM_REG_CORE_CLK1_BASE + 1) - -#define PRCM_REG_CORE_CLK2 1 -#define PRCM_REG_CORE_CLK2_FADDR CM_FCLKEN2_CORE -#define PRCM_REG_CORE_CLK2_IADDR CM_ICLKEN2_CORE -#define PRCM_REG_CORE_CLK2_FMASK CM_FCLKEN2_CORE_MSK -#define PRCM_REG_CORE_CLK2_IMASK CM_ICLKEN2_CORE_MSK -#define PRCM_REG_CORE_CLK2_BASE (PRCM_REG_CORE_CLK2*32) - -#define PRCM_REG_CORE_CLK3 2 -#define PRCM_REG_CORE_CLK3_FADDR CM_FCLKEN3_CORE -#define PRCM_REG_CORE_CLK3_IADDR CM_ICLKEN3_CORE -#define PRCM_REG_CORE_CLK3_FMASK CM_FCLKEN3_CORE_MSK -#define PRCM_REG_CORE_CLK3_IMASK CM_ICLKEN3_CORE_MSK -#define PRCM_REG_CORE_CLK3_BASE (PRCM_REG_CORE_CLK3*32) - -#define CM_CORE_EN_USBTLL (PRCM_REG_CORE_CLK3_BASE + 2) -#define CM_CORE_EN_TS (PRCM_REG_CORE_CLK3_BASE + 1) -#define CM_CORE_EN_CPEFUSE (PRCM_REG_CORE_CLK3_BASE + 0) - -#define PRCM_REG_USBHOST 3 -#define PRCM_REG_USBHOST_FADDR 0x1400 -#define PRCM_REG_USBHOST_IADDR 0x1410 -#define PRCM_REG_USBHOST_FMASK 0x3 -#define PRCM_REG_USBHOST_IMASK 0x1 -#define PRCM_REG_USBHOST_BASE (PRCM_REG_USBHOST*32) - -#define PRCM_CLK_EN_USB (PRCM_REG_USBHOST_BASE + 0) - -#define PRCM_REG_MAX 4 - -#define CM_CORE_EN_ - +enum PRCM_MODULES { + PRCM_TIMER0, + PRCM_TIMER1, + PRCM_TIMER2, + PRCM_TIMER3, + PRCM_MMC, + PRCM_USB, + PRCM_USBTLL +}; + +#define PRCM_REG_MAX 6 /* need interface for CM_AUTOIDLE */ |