enable clocks as needed

This commit is contained in:
macallan 2015-04-21 19:57:41 +00:00
parent de18a25b0d
commit d3361f56e7

View File

@ -1,4 +1,4 @@
/* $NetBSD: apbus.c,v 1.11 2015/03/25 11:25:10 macallan Exp $ */ /* $NetBSD: apbus.c,v 1.12 2015/04/21 19:57:41 macallan Exp $ */
/*- /*-
* Copyright (c) 2014 Michael Lorenz * Copyright (c) 2014 Michael Lorenz
@ -29,7 +29,7 @@
/* catch-all for on-chip peripherals */ /* catch-all for on-chip peripherals */
#include <sys/cdefs.h> #include <sys/cdefs.h>
__KERNEL_RCSID(0, "$NetBSD: apbus.c,v 1.11 2015/03/25 11:25:10 macallan Exp $"); __KERNEL_RCSID(0, "$NetBSD: apbus.c,v 1.12 2015/04/21 19:57:41 macallan Exp $");
#include "locators.h" #include "locators.h"
#define _MIPS_BUS_DMA_PRIVATE #define _MIPS_BUS_DMA_PRIVATE
@ -63,29 +63,31 @@ struct mips_bus_dma_tag apbus_dmat = {
}; };
typedef struct apbus_dev { typedef struct apbus_dev {
const char *name; const char *name; /* driver name */
bus_addr_t addr; bus_addr_t addr; /* base address */
uint32_t irq; uint32_t irq; /* interrupt */
uint32_t clk0; /* bit(s) in CLKGR0 */
uint32_t clk1; /* bit(s) in CLKGR1 */
} apbus_dev_t; } apbus_dev_t;
static const apbus_dev_t apbus_devs[] = { static const apbus_dev_t apbus_devs[] = {
{ "dwctwo", JZ_DWC2_BASE, 21}, { "dwctwo", JZ_DWC2_BASE, 21, CLK_OTG0 | CLK_UHC, CLK_OTG1},
{ "ohci", JZ_OHCI_BASE, 5 }, { "ohci", JZ_OHCI_BASE, 5, CLK_UHC, 0},
{ "ehci", JZ_EHCI_BASE, 20}, { "ehci", JZ_EHCI_BASE, 20, CLK_UHC, 0},
{ "dme", JZ_DME_BASE, -1}, /* irq via gpio abuse */ { "dme", JZ_DME_BASE, -1, 0, 0},
{ "jzgpio", JZ_GPIO_A_BASE, 17}, { "jzgpio", JZ_GPIO_A_BASE, 17, 0, 0},
{ "jzgpio", JZ_GPIO_B_BASE, 16}, { "jzgpio", JZ_GPIO_B_BASE, 16, 0, 0},
{ "jzgpio", JZ_GPIO_C_BASE, 15}, { "jzgpio", JZ_GPIO_C_BASE, 15, 0, 0},
{ "jzgpio", JZ_GPIO_D_BASE, 14}, { "jzgpio", JZ_GPIO_D_BASE, 14, 0, 0},
{ "jzgpio", JZ_GPIO_E_BASE, 13}, { "jzgpio", JZ_GPIO_E_BASE, 13, 0, 0},
{ "jzgpio", JZ_GPIO_F_BASE, 12}, { "jzgpio", JZ_GPIO_F_BASE, 12, 0, 0},
{ "jziic", JZ_SMB0_BASE, 60}, { "jziic", JZ_SMB0_BASE, 60, CLK_SMB0, 0},
{ "jziic", JZ_SMB1_BASE, 59}, { "jziic", JZ_SMB1_BASE, 59, CLK_SMB1, 0},
{ "jziic", JZ_SMB2_BASE, 58}, { "jziic", JZ_SMB2_BASE, 58, CLK_SMB2, 0},
{ "jziic", JZ_SMB3_BASE, 57}, { "jziic", JZ_SMB3_BASE, 57, 0, CLK_SMB3},
{ "jziic", JZ_SMB4_BASE, 56}, { "jziic", JZ_SMB4_BASE, 56, 0, CLK_SMB4},
{ "jzfb", -1, -1}, { "jzfb", JZ_LCDC0_BASE, 31, CLK_LCD, CLK_HDMI},
{ NULL, -1, -1} { NULL, -1, -1, 0, 0}
}; };
void void
@ -144,20 +146,9 @@ apbus_attach(device_t parent, device_t self, void *aux)
/* enable clocks */ /* enable clocks */
reg = readreg(JZ_CLKGR1); reg = readreg(JZ_CLKGR1);
reg &= ~(1 << 0); /* SMB3 clock */ reg &= ~CLK_AHB_MON; /* AHB_MON clock */
reg &= ~(1 << 8); /* OTG1 clock */
reg &= ~(1 << 11); /* AHB_MON clock */
reg &= ~(1 << 12); /* SMB4 clock */
writereg(JZ_CLKGR1, reg); writereg(JZ_CLKGR1, reg);
reg = readreg(JZ_CLKGR0);
reg &= ~(1 << 2); /* OTG0 clock */
reg &= ~(1 << 5); /* SMB0 clock */
reg &= ~(1 << 6); /* SMB1 clock */
reg &= ~(1 << 24); /* UHC clock */
reg &= ~(1 << 25); /* SMB2 clock */
writereg(JZ_CLKGR0, reg);
/* wake up the USB part */ /* wake up the USB part */
reg = readreg(JZ_OPCR); reg = readreg(JZ_OPCR);
reg |= OPCR_SPENDN0 | OPCR_SPENDN1; reg |= OPCR_SPENDN0 | OPCR_SPENDN1;
@ -206,6 +197,19 @@ apbus_attach(device_t parent, device_t self, void *aux)
aa.aa_bst = apbus_memt; aa.aa_bst = apbus_memt;
aa.aa_pclk = pclk; aa.aa_pclk = pclk;
/* enable clocks as needed */
if (adv->clk0 != 0) {
reg = readreg(JZ_CLKGR0);
reg &= ~adv->clk0;
writereg(JZ_CLKGR0, reg);
}
if (adv->clk1 != 0) {
reg = readreg(JZ_CLKGR1);
reg &= ~adv->clk1;
writereg(JZ_CLKGR1, reg);
}
(void) config_found_ia(self, "apbus", &aa, apbus_print); (void) config_found_ia(self, "apbus", &aa, apbus_print);
} }
} }