summaryrefslogtreecommitdiff
path: root/sys/arch/armv7/sunxi
diff options
context:
space:
mode:
Diffstat (limited to 'sys/arch/armv7/sunxi')
-rw-r--r--sys/arch/armv7/sunxi/sxiccmu.c254
-rw-r--r--sys/arch/armv7/sunxi/sxiccmuvar.h30
2 files changed, 3 insertions, 281 deletions
diff --git a/sys/arch/armv7/sunxi/sxiccmu.c b/sys/arch/armv7/sunxi/sxiccmu.c
index 5cf08d985c0..67a97d5afe5 100644
--- a/sys/arch/armv7/sunxi/sxiccmu.c
+++ b/sys/arch/armv7/sunxi/sxiccmu.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: sxiccmu.c,v 1.12 2016/08/22 19:29:32 kettenis Exp $ */
+/* $OpenBSD: sxiccmu.c,v 1.13 2016/08/22 19:43:49 kettenis Exp $ */
/*
* Copyright (c) 2007,2009 Dale Rahn <drahn@openbsd.org>
* Copyright (c) 2013 Artturi Alm
@@ -42,63 +42,6 @@
#define DPRINTF(x)
#endif
-#define CCMU_SCLK_GATING (1U << 31)
-#define CCMU_GET_CLK_DIV_RATIO_N(x) (((x) >> 16) & 0x03)
-#define CCMU_GET_CLK_DIV_RATIO_M(x) ((x) & 0x07)
-
-#define CCMU_PLL6_CFG 0x28
-#define CCMU_PLL6_EN (1U << 31)
-#define CCMU_PLL6_BYPASS_EN (1 << 30)
-#define CCMU_PLL6_SATA_CLK_EN (1 << 14)
-#define CCMU_PLL6_FACTOR_N (31 << 8)
-#define CCMU_PLL6_FACTOR_K (3 << 4)
-#define CCMU_PLL6_FACTOR_M (3 << 0)
-
-#define CCMU_AHB_GATING0 0x60
-#define CCMU_AHB_GATING_USB0 (1 << 0)
-#define CCMU_AHB_GATING_EHCI0 (1 << 1)
-#define CCMU_AHB_GATING_OHCI0 (1 << 2)
-#define CCMU_AHB_GATING_EHCI1 (1 << 3)
-#define CCMU_AHB_GATING_OHCI1 (1 << 4)
-#define CCMU_AHB_GATING_SS (1 << 5)
-#define CCMU_AHB_GATING_DMA (1 << 6)
-#define CCMU_AHB_GATING_BIST (1 << 7)
-#define CCMU_AHB_GATING_SDMMCx(x) (1 << (8 + (x)))
-#define CCMU_AHB_GATING_NAND (1 << 13)
-#define CCMU_AHB_GATING_EMAC (1 << 17)
-#define CCMU_AHB_GATING_SATA (1 << 25)
-
-#define CCMU_AHB_GATING1 0x64
-#define CCMU_AHB_GATING_MALI400 (1 << 20)
-#define CCMU_AHB_GATING_MP (1 << 18)
-#define CCMU_AHB_GATING_GMAC (1 << 17)
-#define CCMU_AHB_GATING_DE_FE1 (1 << 15)
-#define CCMU_AHB_GATING_DE_FE0 (1 << 14)
-#define CCMU_AHB_GATING_DE_BE1 (1 << 13)
-#define CCMU_AHB_GATING_DE_BE0 (1 << 12)
-#define CCMU_AHB_GATING_HDMI (1 << 11)
-#define CCMU_AHB_GATING_CSI1 (1 << 9)
-#define CCMU_AHB_GATING_CSI0 (1 << 8)
-#define CCMU_AHB_GATING_LCD1 (1 << 5)
-#define CCMU_AHB_GATING_LCD0 (1 << 4)
-#define CCMU_AHB_GATING_TVE1 (1 << 3)
-#define CCMU_AHB_GATING_TVE0 (1 << 2)
-#define CCMU_AHB_GATING_TVD (1 << 1)
-#define CCMU_AHB_GATING_VE (1 << 0)
-
-#define CCMU_APB_GATING0 0x68
-#define CCMU_APB_GATING_PIO (1 << 5)
-#define CCMU_APB_GATING1 0x6c
-#define CCMU_APB_GATING_UARTx(x) (1 << (16 + (x)))
-#define CCMU_APB_GATING_TWIx(x) (1 << (x))
-#define CCMU_APB_GATING_TWI4 (1 << 15)
-
-#define CCMU_NAND_CLK 0x80
-#define CCMU_NAND_CLK_SRC_GATING_OSC24M (0 << 24)
-#define CCMU_NAND_CLK_SRC_GATING_PLL6 (1 << 24)
-#define CCMU_NAND_CLK_SRC_GATING_PLL5 (2 << 24)
-#define CCMU_NAND_CLK_SRC_GATING_MASK (3 << 24)
-
#define CCMU_SDx_CLK(x) (0x88 + (x) * 4)
#define CCMU_SDx_CLK_GATING (1U << 31)
#define CCMU_SDx_CLK_SRC_GATING_OSC24M (0 << 24)
@@ -110,32 +53,6 @@
#define CCMU_SDx_CLK_FACTOR_M (7 << 0)
#define CCMU_SDx_CLK_FACTOR_M_SHIFT 0
-#define CCMU_SATA_CLK 0xc8
-#define CCMU_SATA_CLK_SRC_GATING (1 << 24)
-
-#define CCMU_USB_CLK 0xcc
-#define CCMU_USB_PHY (1 << 8)
-#define CCMU_SCLK_GATING_OHCI1 (1 << 7)
-#define CCMU_SCLK_GATING_OHCI0 (1 << 6)
-#define CCMU_OHCI_CLK_SRC (1 << 4)
-#define CCMU_USB2_RESET (1 << 2)
-#define CCMU_USB1_RESET (1 << 1)
-#define CCMU_USB0_RESET (1 << 0)
-
-#define CCMU_GMAC_CLK_REG 0x164
-#define CCMU_GMAC_CLK_TXC_DIV (0x3 << 8)
-#define CCMU_GMAC_CLK_TXC_DIV_1000 0
-#define CCMU_GMAC_CLK_TXC_DIV_100 1
-#define CCMU_GMAC_CLK_TXC_DIV_10 2
-#define CCMU_GMAC_CLK_RXDC (0x7 << 5)
-#define CCMU_GMAC_CLK_RXIE (1 << 4)
-#define CCMU_GMAC_CLK_TXIE (1 << 3)
-#define CCMU_GMAC_CLK_PIT (1 << 2)
-#define CCMU_GMAC_CLK_TCS (0x3 << 0)
-#define CCMU_GMAC_CLK_TCS_MII 0
-#define CCMU_GMAC_CLK_TCS_EXT_125 1
-#define CCMU_GMAC_CLK_TCS_INT_RGMII 2
-
struct sxiccmu_softc {
struct device sc_dev;
bus_space_tag_t sc_iot;
@@ -494,175 +411,6 @@ sxiccmu_reset(void *cookie, uint32_t *cells, int assert)
SXISET4(sc, reg * 4, (1U << bit));
}
-/* XXX spl? */
-void
-sxiccmu_enablemodule(int mod)
-{
- struct sxiccmu_softc *sc = sxiccmu_cd.cd_devs[0];
- uint32_t reg;
-
- DPRINTF(("\nsxiccmu_enablemodule: mod %d\n", mod));
-
- /* XXX reorder? */
- switch (mod) {
- case CCMU_EHCI0:
- SXISET4(sc, CCMU_AHB_GATING0, CCMU_AHB_GATING_EHCI0);
- SXISET4(sc, CCMU_USB_CLK, CCMU_USB1_RESET | CCMU_USB_PHY);
- break;
- case CCMU_EHCI1:
- SXISET4(sc, CCMU_AHB_GATING0, CCMU_AHB_GATING_EHCI1);
- SXISET4(sc, CCMU_USB_CLK, CCMU_USB2_RESET | CCMU_USB_PHY);
- break;
- case CCMU_OHCI0:
- SXISET4(sc, CCMU_USB_CLK, CCMU_OHCI_CLK_SRC);
- SXISET4(sc, CCMU_AHB_GATING0, CCMU_AHB_GATING_OHCI0);
- SXISET4(sc, CCMU_USB_CLK, CCMU_SCLK_GATING_OHCI0);
- break;
- case CCMU_OHCI1:
- SXISET4(sc, CCMU_USB_CLK, CCMU_OHCI_CLK_SRC);
- SXISET4(sc, CCMU_AHB_GATING0, CCMU_AHB_GATING_OHCI1);
- SXISET4(sc, CCMU_USB_CLK, CCMU_SCLK_GATING_OHCI1);
- break;
- case CCMU_AHCI:
- reg = SXIREAD4(sc, CCMU_PLL6_CFG);
- reg &= ~(CCMU_PLL6_BYPASS_EN | CCMU_PLL6_FACTOR_M |
- CCMU_PLL6_FACTOR_N);
- reg |= CCMU_PLL6_EN | CCMU_PLL6_SATA_CLK_EN;
- reg |= 25 << 8;
- reg |= (reg >> 4 & 3);
- SXIWRITE4(sc, CCMU_PLL6_CFG, reg);
-
- SXISET4(sc, CCMU_AHB_GATING0, CCMU_AHB_GATING_SATA);
- delay(1000);
-
- SXIWRITE4(sc, CCMU_SATA_CLK, CCMU_SCLK_GATING);
- break;
- case CCMU_EMAC:
- SXISET4(sc, CCMU_AHB_GATING0, CCMU_AHB_GATING_EMAC);
- break;
- case CCMU_GMAC_MII:
- SXISET4(sc, CCMU_AHB_GATING1, CCMU_AHB_GATING_GMAC);
- SXICMS4(sc, CCMU_GMAC_CLK_REG,
- CCMU_GMAC_CLK_PIT|CCMU_GMAC_CLK_TCS,
- CCMU_GMAC_CLK_TCS_MII);
- break;
- case CCMU_GMAC_RGMII:
- SXISET4(sc, CCMU_AHB_GATING1, CCMU_AHB_GATING_GMAC);
- SXICMS4(sc, CCMU_GMAC_CLK_REG,
- CCMU_GMAC_CLK_PIT|CCMU_GMAC_CLK_TCS,
- CCMU_GMAC_CLK_PIT|CCMU_GMAC_CLK_TCS_INT_RGMII);
- break;
- case CCMU_DMA:
- SXISET4(sc, CCMU_AHB_GATING0, CCMU_AHB_GATING_DMA);
- break;
- case CCMU_UART0:
- case CCMU_UART1:
- case CCMU_UART2:
- case CCMU_UART3:
- case CCMU_UART4:
- case CCMU_UART5:
- case CCMU_UART6:
- case CCMU_UART7:
- SXISET4(sc, CCMU_APB_GATING1,
- CCMU_APB_GATING_UARTx(mod - CCMU_UART0));
- break;
- case CCMU_SDMMC0:
- case CCMU_SDMMC1:
- case CCMU_SDMMC2:
- case CCMU_SDMMC3:
- SXISET4(sc, CCMU_AHB_GATING0,
- CCMU_AHB_GATING_SDMMCx(mod - CCMU_SDMMC0));
- break;
- case CCMU_TWI0:
- case CCMU_TWI1:
- case CCMU_TWI2:
- case CCMU_TWI3:
- case CCMU_TWI4:
- SXISET4(sc, CCMU_APB_GATING1, mod == CCMU_TWI4
- ? CCMU_APB_GATING_TWI4
- : CCMU_APB_GATING_TWIx(mod - CCMU_TWI0));
- break;
- case CCMU_PIO:
- SXISET4(sc, CCMU_APB_GATING0, CCMU_APB_GATING_PIO);
- break;
- default:
- break;
- }
-}
-
-void
-sxiccmu_disablemodule(int mod)
-{
- struct sxiccmu_softc *sc = sxiccmu_cd.cd_devs[0];
-
- DPRINTF(("\nsxiccmu_disablemodule: mod %d\n", mod));
-
- switch (mod) {
- case CCMU_EHCI0:
- SXICLR4(sc, CCMU_AHB_GATING0, CCMU_AHB_GATING_EHCI0);
- SXICLR4(sc, CCMU_USB_CLK, CCMU_USB1_RESET | CCMU_USB_PHY);
- break;
- case CCMU_EHCI1:
- SXICLR4(sc, CCMU_AHB_GATING0, CCMU_AHB_GATING_EHCI1);
- SXICLR4(sc, CCMU_USB_CLK, CCMU_USB2_RESET | CCMU_USB_PHY);
- break;
- case CCMU_OHCI0:
- SXICLR4(sc, CCMU_AHB_GATING0, CCMU_AHB_GATING_OHCI0);
- SXICLR4(sc, CCMU_USB_CLK, CCMU_SCLK_GATING_OHCI0);
- case CCMU_OHCI1:
- SXICLR4(sc, CCMU_AHB_GATING0, CCMU_AHB_GATING_OHCI1);
- SXICLR4(sc, CCMU_USB_CLK, CCMU_SCLK_GATING_OHCI1);
- break;
- case CCMU_AHCI:
- /* XXX possibly wrong */
- SXICLR4(sc, CCMU_AHB_GATING0, CCMU_AHB_GATING_SATA);
- SXIWRITE4(sc, CCMU_SATA_CLK, 0);
- break;
- case CCMU_EMAC:
- SXICLR4(sc, CCMU_AHB_GATING0, CCMU_AHB_GATING_EMAC);
- break;
- case CCMU_GMAC_MII:
- case CCMU_GMAC_RGMII:
- SXICLR4(sc, CCMU_AHB_GATING1, CCMU_AHB_GATING_GMAC);
- break;
- case CCMU_DMA:
- SXICLR4(sc, CCMU_AHB_GATING0, CCMU_AHB_GATING_DMA);
- break;
- case CCMU_UART0:
- case CCMU_UART1:
- case CCMU_UART2:
- case CCMU_UART3:
- case CCMU_UART4:
- case CCMU_UART5:
- case CCMU_UART6:
- case CCMU_UART7:
- SXICLR4(sc, CCMU_APB_GATING1,
- CCMU_APB_GATING_UARTx(mod - CCMU_UART0));
- break;
- case CCMU_SDMMC0:
- case CCMU_SDMMC1:
- case CCMU_SDMMC2:
- case CCMU_SDMMC3:
- SXICLR4(sc, CCMU_AHB_GATING0,
- CCMU_AHB_GATING_SDMMCx(mod - CCMU_SDMMC0));
- break;
- case CCMU_TWI0:
- case CCMU_TWI1:
- case CCMU_TWI2:
- case CCMU_TWI3:
- case CCMU_TWI4:
- SXICLR4(sc, CCMU_APB_GATING1, mod == CCMU_TWI4
- ? CCMU_APB_GATING_TWI4
- : CCMU_APB_GATING_TWIx(mod - CCMU_TWI0));
- break;
- case CCMU_PIO:
- SXICLR4(sc, CCMU_APB_GATING0, CCMU_APB_GATING_PIO);
- break;
- default:
- break;
- }
-}
-
void
sxiccmu_set_sd_clock(int mod, int freq)
{
diff --git a/sys/arch/armv7/sunxi/sxiccmuvar.h b/sys/arch/armv7/sunxi/sxiccmuvar.h
index 0a6e1bd19db..9cd081f194a 100644
--- a/sys/arch/armv7/sunxi/sxiccmuvar.h
+++ b/sys/arch/armv7/sunxi/sxiccmuvar.h
@@ -1,4 +1,4 @@
-/* $OpenBSD: sxiccmuvar.h,v 1.4 2016/08/20 19:34:44 kettenis Exp $ */
+/* $OpenBSD: sxiccmuvar.h,v 1.5 2016/08/22 19:43:49 kettenis Exp $ */
/*
* Copyright (c) 2007,2009 Dale Rahn <drahn@openbsd.org>
*
@@ -15,37 +15,11 @@
* OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
*/
-void sxiccmu_enablemodule(int);
-void sxiccmu_disablemodule(int);
-
void sxiccmu_set_sd_clock(int, int);
enum CCMU_MODULES {
- CCMU_EHCI0,
- CCMU_EHCI1,
- CCMU_OHCI0,
- CCMU_OHCI1,
- CCMU_AHCI,
- CCMU_EMAC,
- CCMU_GMAC_MII,
- CCMU_GMAC_RGMII,
- CCMU_DMA,
- CCMU_UART0,
- CCMU_UART1,
- CCMU_UART2,
- CCMU_UART3,
- CCMU_UART4,
- CCMU_UART5,
- CCMU_UART6,
- CCMU_UART7,
- CCMU_TWI0,
- CCMU_TWI1,
- CCMU_TWI2,
- CCMU_TWI3,
- CCMU_TWI4,
CCMU_SDMMC0,
CCMU_SDMMC1,
CCMU_SDMMC2,
- CCMU_SDMMC3,
- CCMU_PIO
+ CCMU_SDMMC3
};