Add support for Allwinner H6 CCU.
This commit is contained in:
parent
7351a5d259
commit
86f4652d7f
|
@ -1,4 +1,4 @@
|
|||
# $NetBSD: files.sunxi,v 1.48 2018/04/03 12:52:16 bouyer Exp $
|
||||
# $NetBSD: files.sunxi,v 1.49 2018/05/01 19:53:14 jmcneill Exp $
|
||||
#
|
||||
# Configuration info for Allwinner sunxi family SoCs
|
||||
#
|
||||
|
@ -59,6 +59,11 @@ device sun50ia64ccu: sunxi_ccu
|
|||
attach sun50ia64ccu at fdt with sunxi_a64_ccu
|
||||
file arch/arm/sunxi/sun50i_a64_ccu.c sunxi_a64_ccu
|
||||
|
||||
# CCU (H6)
|
||||
device sun50ih6ccu: sunxi_ccu
|
||||
attach sun50ih6ccu at fdt with sunxi_h6_ccu
|
||||
file arch/arm/sunxi/sun50i_h6_ccu.c sunxi_h6_ccu
|
||||
|
||||
# Misc. clock resets
|
||||
device sunxiresets
|
||||
attach sunxiresets at fdt with sunxi_resets
|
||||
|
|
|
@ -0,0 +1,354 @@
|
|||
/* $NetBSD: sun50i_h6_ccu.c,v 1.1 2018/05/01 19:53:14 jmcneill Exp $ */
|
||||
|
||||
/*-
|
||||
* Copyright (c) 2018 Jared McNeill <jmcneill@invisible.ca>
|
||||
* All rights reserved.
|
||||
*
|
||||
* Redistribution and use in source and binary forms, with or without
|
||||
* modification, are permitted provided that the following conditions
|
||||
* are met:
|
||||
* 1. Redistributions of source code must retain the above copyright
|
||||
* notice, this list of conditions and the following disclaimer.
|
||||
* 2. Redistributions in binary form must reproduce the above copyright
|
||||
* notice, this list of conditions and the following disclaimer in the
|
||||
* documentation and/or other materials provided with the distribution.
|
||||
*
|
||||
* THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
|
||||
* IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
|
||||
* OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
|
||||
* IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
|
||||
* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
|
||||
* BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
|
||||
* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
|
||||
* AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
|
||||
* OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
|
||||
* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
|
||||
* SUCH DAMAGE.
|
||||
*/
|
||||
|
||||
#include <sys/cdefs.h>
|
||||
|
||||
__KERNEL_RCSID(1, "$NetBSD: sun50i_h6_ccu.c,v 1.1 2018/05/01 19:53:14 jmcneill Exp $");
|
||||
|
||||
#include <sys/param.h>
|
||||
#include <sys/bus.h>
|
||||
#include <sys/device.h>
|
||||
#include <sys/systm.h>
|
||||
|
||||
#include <dev/fdt/fdtvar.h>
|
||||
|
||||
#include <arm/sunxi/sunxi_ccu.h>
|
||||
#include <arm/sunxi/sun50i_h6_ccu.h>
|
||||
|
||||
#define PLL_PERI0_CTRL_REG 0x020
|
||||
#define AHB3_CFG_REG 0x51c
|
||||
#define APB2_CFG_REG 0x524
|
||||
#define MBUS_CFG_REG 0x540
|
||||
#define DE_BGR_REG 0x60c
|
||||
#define DI_BGR_REG 0x62c
|
||||
#define GPU_BGR_REG 0x67c
|
||||
#define CE_BGR_REG 0x68c
|
||||
#define VE_BGR_REG 0x69c
|
||||
#define EMCE_BGR_REG 0x6bc
|
||||
#define VP9_BGR_REG 0x6cc
|
||||
#define DMA_BGR_REG 0x70c
|
||||
#define MSGBOX_BGR_REG 0x71c
|
||||
#define SPINLOCK_BGR_REG 0x72c
|
||||
#define HSTIMER_BGR_REG 0x73c
|
||||
#define DBGSYS_BGR_REG 0x78c
|
||||
#define PSI_BGR_REG 0x79c
|
||||
#define PWM_BGR_REG 0x7ac
|
||||
#define DRAM_CLK_REG 0x800
|
||||
#define NAND_BGR_REG 0x82c
|
||||
#define SMHC0_CLK_REG 0x830
|
||||
#define SMHC1_CLK_REG 0x834
|
||||
#define SMHC2_CLK_REG 0x838
|
||||
#define SMHC_BGR_REG 0x84c
|
||||
#define UART_BGR_REG 0x90c
|
||||
#define TWI_BGR_REG 0x91c
|
||||
#define SCR_BGR_REG 0x93c
|
||||
#define SPI_BGR_REG 0x96c
|
||||
#define EMAC_BGR_REG 0x97c
|
||||
#define TS_BGR_REG 0x9bc
|
||||
#define CIRTX_BGR_REG 0x9cc
|
||||
#define THS_BGR_REG 0x9fc
|
||||
#define I2S_PCM_BGR_REG 0xa1c
|
||||
#define OWA_BGR_REG 0xa2c
|
||||
#define DMIC_BGR_REG 0xa4c
|
||||
#define AUDIO_HUB_BGR_REG 0xa6c
|
||||
#define USB0_CLK_REG 0xa70
|
||||
#define USB1_CLK_REG 0xa74
|
||||
#define USB3_CLK_REG 0xa7c
|
||||
#define USB_BGR_REG 0xa8c
|
||||
#define PCIE_BGR_REG 0xabc
|
||||
#define HDMI_BGR_REG 0xb1c
|
||||
#define DISPLAY_IF_TOP_BGR_REG 0xb5c
|
||||
#define TCON_LCD_BGR_REG 0xb7c
|
||||
#define TCON_TV_BGR_REG 0xb9c
|
||||
#define CSI_BGR_REG 0xc2c
|
||||
#define HDMI_HDCP_BGR_REG 0xc4c
|
||||
|
||||
static int sun50i_h6_ccu_match(device_t, cfdata_t, void *);
|
||||
static void sun50i_h6_ccu_attach(device_t, device_t, void *);
|
||||
|
||||
static const char * const compatible[] = {
|
||||
"allwinner,sun50i-h6-ccu",
|
||||
NULL
|
||||
};
|
||||
|
||||
CFATTACH_DECL_NEW(sunxi_h6_ccu, sizeof(struct sunxi_ccu_softc),
|
||||
sun50i_h6_ccu_match, sun50i_h6_ccu_attach, NULL, NULL);
|
||||
|
||||
static struct sunxi_ccu_reset sun50i_h6_ccu_resets[] = {
|
||||
SUNXI_CCU_RESET(H6_RST_MBUS, MBUS_CFG_REG, 30),
|
||||
|
||||
SUNXI_CCU_RESET(H6_RST_BUS_DE, DE_BGR_REG, 16),
|
||||
|
||||
SUNXI_CCU_RESET(H6_RST_BUS_DEINTERLACE, DI_BGR_REG, 16),
|
||||
|
||||
SUNXI_CCU_RESET(H6_RST_BUS_GPU, GPU_BGR_REG, 16),
|
||||
|
||||
SUNXI_CCU_RESET(H6_RST_BUS_CE, CE_BGR_REG, 16),
|
||||
|
||||
SUNXI_CCU_RESET(H6_RST_BUS_VE, VE_BGR_REG, 16),
|
||||
|
||||
SUNXI_CCU_RESET(H6_RST_BUS_EMCE, EMCE_BGR_REG, 16),
|
||||
|
||||
SUNXI_CCU_RESET(H6_RST_BUS_VP9, VP9_BGR_REG, 16),
|
||||
|
||||
SUNXI_CCU_RESET(H6_RST_BUS_DMA, DMA_BGR_REG, 16),
|
||||
|
||||
SUNXI_CCU_RESET(H6_RST_BUS_MSGBOX, MSGBOX_BGR_REG, 16),
|
||||
|
||||
SUNXI_CCU_RESET(H6_RST_BUS_SPINLOCK, SPINLOCK_BGR_REG, 16),
|
||||
|
||||
SUNXI_CCU_RESET(H6_RST_BUS_HSTIMER, HSTIMER_BGR_REG, 16),
|
||||
|
||||
SUNXI_CCU_RESET(H6_RST_BUS_DBG, DBGSYS_BGR_REG, 16),
|
||||
|
||||
SUNXI_CCU_RESET(H6_RST_BUS_PSI, PSI_BGR_REG, 16),
|
||||
|
||||
SUNXI_CCU_RESET(H6_RST_BUS_PWM, PWM_BGR_REG, 16),
|
||||
|
||||
/* H6_RST_BUS_IOMMU: No bit defined in user manual */
|
||||
|
||||
SUNXI_CCU_RESET(H6_RST_BUS_DRAM, DRAM_CLK_REG, 30),
|
||||
|
||||
SUNXI_CCU_RESET(H6_RST_BUS_NAND, NAND_BGR_REG, 16),
|
||||
|
||||
SUNXI_CCU_RESET(H6_RST_BUS_MMC0, SMHC_BGR_REG, 16),
|
||||
SUNXI_CCU_RESET(H6_RST_BUS_MMC1, SMHC_BGR_REG, 17),
|
||||
SUNXI_CCU_RESET(H6_RST_BUS_MMC2, SMHC_BGR_REG, 18),
|
||||
|
||||
SUNXI_CCU_RESET(H6_RST_BUS_UART0, UART_BGR_REG, 16),
|
||||
SUNXI_CCU_RESET(H6_RST_BUS_UART1, UART_BGR_REG, 17),
|
||||
SUNXI_CCU_RESET(H6_RST_BUS_UART2, UART_BGR_REG, 18),
|
||||
SUNXI_CCU_RESET(H6_RST_BUS_UART3, UART_BGR_REG, 19),
|
||||
|
||||
SUNXI_CCU_RESET(H6_RST_BUS_I2C0, TWI_BGR_REG, 16),
|
||||
SUNXI_CCU_RESET(H6_RST_BUS_I2C1, TWI_BGR_REG, 17),
|
||||
SUNXI_CCU_RESET(H6_RST_BUS_I2C2, TWI_BGR_REG, 18),
|
||||
SUNXI_CCU_RESET(H6_RST_BUS_I2C3, TWI_BGR_REG, 19),
|
||||
|
||||
SUNXI_CCU_RESET(H6_RST_BUS_SCR0, SCR_BGR_REG, 16),
|
||||
SUNXI_CCU_RESET(H6_RST_BUS_SCR1, SCR_BGR_REG, 17),
|
||||
|
||||
SUNXI_CCU_RESET(H6_RST_BUS_SPI0, SPI_BGR_REG, 16),
|
||||
SUNXI_CCU_RESET(H6_RST_BUS_SPI1, SPI_BGR_REG, 17),
|
||||
|
||||
SUNXI_CCU_RESET(H6_RST_BUS_EMAC, EMAC_BGR_REG, 16),
|
||||
|
||||
SUNXI_CCU_RESET(H6_RST_BUS_TS, TS_BGR_REG, 16),
|
||||
|
||||
SUNXI_CCU_RESET(H6_RST_BUS_IR_TX, CIRTX_BGR_REG, 16),
|
||||
|
||||
SUNXI_CCU_RESET(H6_RST_BUS_THS, THS_BGR_REG, 16),
|
||||
|
||||
SUNXI_CCU_RESET(H6_RST_BUS_I2S0, I2S_PCM_BGR_REG, 16),
|
||||
SUNXI_CCU_RESET(H6_RST_BUS_I2S1, I2S_PCM_BGR_REG, 17),
|
||||
SUNXI_CCU_RESET(H6_RST_BUS_I2S2, I2S_PCM_BGR_REG, 18),
|
||||
SUNXI_CCU_RESET(H6_RST_BUS_I2S3, I2S_PCM_BGR_REG, 19),
|
||||
|
||||
SUNXI_CCU_RESET(H6_RST_BUS_SPDIF, OWA_BGR_REG, 16),
|
||||
|
||||
SUNXI_CCU_RESET(H6_RST_BUS_DMIC, DMIC_BGR_REG, 16),
|
||||
|
||||
SUNXI_CCU_RESET(H6_RST_BUS_AUDIO_HUB, AUDIO_HUB_BGR_REG, 16),
|
||||
|
||||
SUNXI_CCU_RESET(H6_RST_USB_PHY0, USB0_CLK_REG, 30),
|
||||
|
||||
SUNXI_CCU_RESET(H6_RST_USB_PHY1, USB1_CLK_REG, 30),
|
||||
|
||||
SUNXI_CCU_RESET(H6_RST_USB_PHY3, USB3_CLK_REG, 30),
|
||||
SUNXI_CCU_RESET(H6_RST_USB_HSIC, USB3_CLK_REG, 28),
|
||||
|
||||
SUNXI_CCU_RESET(H6_RST_BUS_OHCI0, USB_BGR_REG, 16),
|
||||
SUNXI_CCU_RESET(H6_RST_BUS_OHCI3, USB_BGR_REG, 19),
|
||||
SUNXI_CCU_RESET(H6_RST_BUS_EHCI0, USB_BGR_REG, 20),
|
||||
SUNXI_CCU_RESET(H6_RST_BUS_XHCI, USB_BGR_REG, 21),
|
||||
SUNXI_CCU_RESET(H6_RST_BUS_EHCI3, USB_BGR_REG, 23),
|
||||
SUNXI_CCU_RESET(H6_RST_BUS_OTG, USB_BGR_REG, 24),
|
||||
|
||||
SUNXI_CCU_RESET(H6_RST_BUS_PCIE, PCIE_BGR_REG, 16),
|
||||
SUNXI_CCU_RESET(H6_RST_PCIE_POWERUP, PCIE_BGR_REG, 17),
|
||||
|
||||
SUNXI_CCU_RESET(H6_RST_BUS_HDMI, HDMI_BGR_REG, 16),
|
||||
SUNXI_CCU_RESET(H6_RST_BUS_HDMI_SUB, HDMI_BGR_REG, 17),
|
||||
|
||||
SUNXI_CCU_RESET(H6_RST_BUS_TCON_TOP, DISPLAY_IF_TOP_BGR_REG, 16),
|
||||
|
||||
SUNXI_CCU_RESET(H6_RST_BUS_TCON_LCD0, TCON_LCD_BGR_REG, 16),
|
||||
|
||||
SUNXI_CCU_RESET(H6_RST_BUS_TCON_TV0, TCON_TV_BGR_REG, 16),
|
||||
|
||||
SUNXI_CCU_RESET(H6_RST_BUS_CSI, CSI_BGR_REG, 16),
|
||||
|
||||
SUNXI_CCU_RESET(H6_RST_BUS_HDCP, HDMI_HDCP_BGR_REG, 16),
|
||||
};
|
||||
|
||||
static const char *ahb3_parents[] = { "hosc", "losc", "psi", "pll_periph0" };
|
||||
static const char *apb2_parents[] = { "hosc", "losc", "psi", "pll_periph0" };
|
||||
static const char *mod_parents[] = { "hosc", "pll_periph0_2x", "pll_periph1_2x" };
|
||||
|
||||
static struct sunxi_ccu_clk sun50i_h6_ccu_clks[] = {
|
||||
SUNXI_CCU_FIXED_FACTOR(H6_CLK_OSC12M, "osc12m", "hosc", 2, 1),
|
||||
|
||||
SUNXI_CCU_NKMP(H6_CLK_PLL_PERIPH0_4X, "pll_periph0_4x", "hosc",
|
||||
PLL_PERI0_CTRL_REG, /* reg */
|
||||
__BITS(15,8), /* n */
|
||||
0, /* k */
|
||||
__BIT(1), /* m */
|
||||
__BIT(0), /* p */
|
||||
__BIT(31), /* enable */
|
||||
0),
|
||||
SUNXI_CCU_FIXED_FACTOR(H6_CLK_PLL_PERIPH0_2X, "pll_periph0_2x", "pll_periph0_4x", 2, 1),
|
||||
SUNXI_CCU_FIXED_FACTOR(H6_CLK_PLL_PERIPH0, "pll_periph0", "pll_periph0_4x", 4, 1),
|
||||
|
||||
SUNXI_CCU_NM(H6_CLK_AHB3, "ahb3", ahb3_parents,
|
||||
AHB3_CFG_REG, /* reg */
|
||||
__BITS(9,8), /* n */
|
||||
__BITS(1,0), /* m */
|
||||
__BITS(25,24), /* sel */
|
||||
0, /* enable */
|
||||
SUNXI_CCU_NM_POWER_OF_TWO),
|
||||
|
||||
SUNXI_CCU_NM(H6_CLK_APB2, "apb2", apb2_parents,
|
||||
APB2_CFG_REG, /* reg */
|
||||
__BITS(9,8), /* n */
|
||||
__BITS(1,0), /* m */
|
||||
__BITS(25,24), /* sel */
|
||||
0, /* enable */
|
||||
SUNXI_CCU_NM_POWER_OF_TWO),
|
||||
|
||||
SUNXI_CCU_NM(H6_CLK_MMC0, "mmc0", mod_parents,
|
||||
SMHC0_CLK_REG, /* reg */
|
||||
__BITS(9,8), /* n */
|
||||
__BITS(3,0), /* m */
|
||||
__BITS(25,24), /* sel */
|
||||
__BIT(31), /* enable */
|
||||
SUNXI_CCU_NM_POWER_OF_TWO|SUNXI_CCU_NM_ROUND_DOWN),
|
||||
SUNXI_CCU_NM(H6_CLK_MMC1, "mmc1", mod_parents,
|
||||
SMHC1_CLK_REG, /* reg */
|
||||
__BITS(9,8), /* n */
|
||||
__BITS(3,0), /* m */
|
||||
__BITS(25,24), /* sel */
|
||||
__BIT(31), /* enable */
|
||||
SUNXI_CCU_NM_POWER_OF_TWO|SUNXI_CCU_NM_ROUND_DOWN),
|
||||
SUNXI_CCU_NM(H6_CLK_MMC2, "mmc2", mod_parents,
|
||||
SMHC2_CLK_REG, /* reg */
|
||||
__BITS(9,8), /* n */
|
||||
__BITS(3,0), /* m */
|
||||
__BITS(25,24), /* sel */
|
||||
__BIT(31), /* enable */
|
||||
SUNXI_CCU_NM_POWER_OF_TWO|SUNXI_CCU_NM_ROUND_DOWN),
|
||||
SUNXI_CCU_GATE(H6_CLK_BUS_MMC0, "bus-mmc0", "mmc0",
|
||||
SMHC_BGR_REG, 0),
|
||||
SUNXI_CCU_GATE(H6_CLK_BUS_MMC1, "bus-mmc1", "mmc1",
|
||||
SMHC_BGR_REG, 1),
|
||||
SUNXI_CCU_GATE(H6_CLK_BUS_MMC2, "bus-mmc2", "mmc2",
|
||||
SMHC_BGR_REG, 2),
|
||||
|
||||
SUNXI_CCU_GATE(H6_CLK_BUS_UART0, "bus-uart0", "apb2",
|
||||
UART_BGR_REG, 0),
|
||||
SUNXI_CCU_GATE(H6_CLK_BUS_UART1, "bus-uart1", "apb2",
|
||||
UART_BGR_REG, 1),
|
||||
SUNXI_CCU_GATE(H6_CLK_BUS_UART2, "bus-uart2", "apb2",
|
||||
UART_BGR_REG, 2),
|
||||
SUNXI_CCU_GATE(H6_CLK_BUS_UART3, "bus-uart3", "apb2",
|
||||
UART_BGR_REG, 3),
|
||||
|
||||
SUNXI_CCU_GATE(H6_CLK_BUS_I2C0, "bus-i2c0", "apb2",
|
||||
TWI_BGR_REG, 0),
|
||||
SUNXI_CCU_GATE(H6_CLK_BUS_I2C1, "bus-i2c1", "apb2",
|
||||
TWI_BGR_REG, 1),
|
||||
SUNXI_CCU_GATE(H6_CLK_BUS_I2C2, "bus-i2c2", "apb2",
|
||||
TWI_BGR_REG, 2),
|
||||
SUNXI_CCU_GATE(H6_CLK_BUS_I2C3, "bus-i2c3", "apb2",
|
||||
TWI_BGR_REG, 3),
|
||||
|
||||
SUNXI_CCU_GATE(H6_CLK_USB_OHCI0, "usb-ohci0", "ahb3",
|
||||
USB0_CLK_REG, 31),
|
||||
SUNXI_CCU_GATE(H6_CLK_USB_PHY0, "usb-phy0", "ahb3",
|
||||
USB0_CLK_REG, 29),
|
||||
|
||||
SUNXI_CCU_GATE(H6_CLK_USB_PHY1, "usb-phy1", "ahb3",
|
||||
USB1_CLK_REG, 29),
|
||||
|
||||
SUNXI_CCU_GATE(H6_CLK_USB_OHCI3, "usb-ohci3", "ahb3",
|
||||
USB3_CLK_REG, 31),
|
||||
SUNXI_CCU_GATE(H6_CLK_USB_PHY3, "usb-phy3", "ahb3",
|
||||
USB3_CLK_REG, 29),
|
||||
SUNXI_CCU_GATE(H6_CLK_USB_HSIC_12M, "usb-hsic-12m", "osc12m",
|
||||
USB3_CLK_REG, 27),
|
||||
SUNXI_CCU_GATE(H6_CLK_USB_HSIC, "usb-hsic", "ahb3",
|
||||
USB3_CLK_REG, 26),
|
||||
|
||||
SUNXI_CCU_GATE(H6_CLK_BUS_OHCI0, "bus-ohci0", "ahb3",
|
||||
USB_BGR_REG, 0),
|
||||
SUNXI_CCU_GATE(H6_CLK_BUS_OHCI3, "bus-ohci3", "ahb3",
|
||||
USB_BGR_REG, 3),
|
||||
SUNXI_CCU_GATE(H6_CLK_BUS_EHCI0, "bus-ehci0", "ahb3",
|
||||
USB_BGR_REG, 4),
|
||||
SUNXI_CCU_GATE(H6_CLK_BUS_XHCI, "bus-xhci", "ahb3",
|
||||
USB_BGR_REG, 5),
|
||||
SUNXI_CCU_GATE(H6_CLK_BUS_EHCI3, "bus-ehci3", "ahb3",
|
||||
USB_BGR_REG, 7),
|
||||
SUNXI_CCU_GATE(H6_CLK_BUS_OTG, "bus-otg", "ahb3",
|
||||
USB_BGR_REG, 8),
|
||||
|
||||
SUNXI_CCU_GATE(H6_CLK_BUS_EMAC, "bus-emac", "ahb3",
|
||||
EMAC_BGR_REG, 0),
|
||||
};
|
||||
|
||||
static int
|
||||
sun50i_h6_ccu_match(device_t parent, cfdata_t cf, void *aux)
|
||||
{
|
||||
struct fdt_attach_args * const faa = aux;
|
||||
|
||||
return of_match_compatible(faa->faa_phandle, compatible);
|
||||
}
|
||||
|
||||
static void
|
||||
sun50i_h6_ccu_attach(device_t parent, device_t self, void *aux)
|
||||
{
|
||||
struct sunxi_ccu_softc * const sc = device_private(self);
|
||||
struct fdt_attach_args * const faa = aux;
|
||||
|
||||
sc->sc_dev = self;
|
||||
sc->sc_phandle = faa->faa_phandle;
|
||||
sc->sc_bst = faa->faa_bst;
|
||||
|
||||
sc->sc_resets = sun50i_h6_ccu_resets;
|
||||
sc->sc_nresets = __arraycount(sun50i_h6_ccu_resets);
|
||||
|
||||
sc->sc_clks = sun50i_h6_ccu_clks;
|
||||
sc->sc_nclks = __arraycount(sun50i_h6_ccu_clks);
|
||||
|
||||
if (sunxi_ccu_attach(sc) != 0)
|
||||
return;
|
||||
|
||||
aprint_naive("\n");
|
||||
aprint_normal(": H6 CCU\n");
|
||||
|
||||
sunxi_ccu_print(sc);
|
||||
}
|
|
@ -0,0 +1,235 @@
|
|||
/* $NetBSD: sun50i_h6_ccu.h,v 1.1 2018/05/01 19:53:14 jmcneill Exp $ */
|
||||
|
||||
/*-
|
||||
* Copyright (c) 2018 Jared McNeill <jmcneill@invisible.ca>
|
||||
* All rights reserved.
|
||||
*
|
||||
* Redistribution and use in source and binary forms, with or without
|
||||
* modification, are permitted provided that the following conditions
|
||||
* are met:
|
||||
* 1. Redistributions of source code must retain the above copyright
|
||||
* notice, this list of conditions and the following disclaimer.
|
||||
* 2. Redistributions in binary form must reproduce the above copyright
|
||||
* notice, this list of conditions and the following disclaimer in the
|
||||
* documentation and/or other materials provided with the distribution.
|
||||
*
|
||||
* THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
|
||||
* IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
|
||||
* OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
|
||||
* IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
|
||||
* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
|
||||
* BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
|
||||
* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
|
||||
* AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
|
||||
* OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
|
||||
* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
|
||||
* SUCH DAMAGE.
|
||||
*/
|
||||
|
||||
#ifndef _SUN50I_H6_CCU_H
|
||||
#define _SUN50I_H6_CCU_H
|
||||
|
||||
#define H6_RST_MBUS 0
|
||||
#define H6_RST_BUS_DE 1
|
||||
#define H6_RST_BUS_DEINTERLACE 2
|
||||
#define H6_RST_BUS_GPU 3
|
||||
#define H6_RST_BUS_CE 4
|
||||
#define H6_RST_BUS_VE 5
|
||||
#define H6_RST_BUS_EMCE 6
|
||||
#define H6_RST_BUS_VP9 7
|
||||
#define H6_RST_BUS_DMA 8
|
||||
#define H6_RST_BUS_MSGBOX 9
|
||||
#define H6_RST_BUS_SPINLOCK 10
|
||||
#define H6_RST_BUS_HSTIMER 11
|
||||
#define H6_RST_BUS_DBG 12
|
||||
#define H6_RST_BUS_PSI 13
|
||||
#define H6_RST_BUS_PWM 14
|
||||
#define H6_RST_BUS_IOMMU 15
|
||||
#define H6_RST_BUS_DRAM 16
|
||||
#define H6_RST_BUS_NAND 17
|
||||
#define H6_RST_BUS_MMC0 18
|
||||
#define H6_RST_BUS_MMC1 19
|
||||
#define H6_RST_BUS_MMC2 20
|
||||
#define H6_RST_BUS_UART0 21
|
||||
#define H6_RST_BUS_UART1 22
|
||||
#define H6_RST_BUS_UART2 23
|
||||
#define H6_RST_BUS_UART3 24
|
||||
#define H6_RST_BUS_I2C0 25
|
||||
#define H6_RST_BUS_I2C1 26
|
||||
#define H6_RST_BUS_I2C2 27
|
||||
#define H6_RST_BUS_I2C3 28
|
||||
#define H6_RST_BUS_SCR0 29
|
||||
#define H6_RST_BUS_SCR1 30
|
||||
#define H6_RST_BUS_SPI0 31
|
||||
#define H6_RST_BUS_SPI1 32
|
||||
#define H6_RST_BUS_EMAC 33
|
||||
#define H6_RST_BUS_TS 34
|
||||
#define H6_RST_BUS_IR_TX 35
|
||||
#define H6_RST_BUS_THS 36
|
||||
#define H6_RST_BUS_I2S0 37
|
||||
#define H6_RST_BUS_I2S1 38
|
||||
#define H6_RST_BUS_I2S2 39
|
||||
#define H6_RST_BUS_I2S3 40
|
||||
#define H6_RST_BUS_SPDIF 41
|
||||
#define H6_RST_BUS_DMIC 42
|
||||
#define H6_RST_BUS_AUDIO_HUB 43
|
||||
#define H6_RST_USB_PHY0 44
|
||||
#define H6_RST_USB_PHY1 45
|
||||
#define H6_RST_USB_PHY3 46
|
||||
#define H6_RST_USB_HSIC 47
|
||||
#define H6_RST_BUS_OHCI0 48
|
||||
#define H6_RST_BUS_OHCI3 49
|
||||
#define H6_RST_BUS_EHCI0 50
|
||||
#define H6_RST_BUS_XHCI 51
|
||||
#define H6_RST_BUS_EHCI3 52
|
||||
#define H6_RST_BUS_OTG 53
|
||||
#define H6_RST_BUS_PCIE 54
|
||||
#define H6_RST_PCIE_POWERUP 55
|
||||
#define H6_RST_BUS_HDMI 56
|
||||
#define H6_RST_BUS_HDMI_SUB 57
|
||||
#define H6_RST_BUS_TCON_TOP 58
|
||||
#define H6_RST_BUS_TCON_LCD0 59
|
||||
#define H6_RST_BUS_TCON_TV0 60
|
||||
#define H6_RST_BUS_CSI 61
|
||||
#define H6_RST_BUS_HDCP 62
|
||||
|
||||
#define H6_CLK_OSC12M 0
|
||||
#define H6_CLK_PLL_CPUX 1
|
||||
#define H6_CLK_PLL_DDR0 2
|
||||
#define H6_CLK_PLL_PERIPH0 3
|
||||
#define H6_CLK_PLL_PERIPH0_2X 4
|
||||
#define H6_CLK_PLL_PERIPH0_4X 5
|
||||
#define H6_CLK_PLL_PERIPH1 6
|
||||
#define H6_CLK_PLL_PERIPH1_2X 7
|
||||
#define H6_CLK_PLL_PERIPH1_4X 8
|
||||
#define H6_CLK_PLL_GPU 9
|
||||
#define H6_CLK_PLL_VIDEO0 10
|
||||
#define H6_CLK_PLL_VIDEO0_4X 11
|
||||
#define H6_CLK_PLL_VIDEO1 12
|
||||
#define H6_CLK_PLL_VIDEO1_4X 13
|
||||
#define H6_CLK_PLL_VE 14
|
||||
#define H6_CLK_PLL_DE 15
|
||||
#define H6_CLK_PLL_HSIC 16
|
||||
#define H6_CLK_PLL_AUDIO_BASE 17
|
||||
#define H6_CLK_PLL_AUDIO 18
|
||||
#define H6_CLK_PLL_AUDIO_2X 19
|
||||
#define H6_CLK_PLL_AUDIO_4X 20
|
||||
#define H6_CLK_CPUX 21
|
||||
#define H6_CLK_AXI 22
|
||||
#define H6_CLK_CPUX_APB 23
|
||||
#define H6_CLK_PSI_AHB1_AHB2 24
|
||||
#define H6_CLK_AHB3 25
|
||||
#define H6_CLK_APB1 26
|
||||
#define H6_CLK_APB2 27
|
||||
#define H6_CLK_MBUS 28
|
||||
#define H6_CLK_DE 29
|
||||
#define H6_CLK_BUS_DE 30
|
||||
#define H6_CLK_DEINTERLACE 31
|
||||
#define H6_CLK_BUS_DEINTERLACE 32
|
||||
#define H6_CLK_GPU 33
|
||||
#define H6_CLK_BUS_GPU 34
|
||||
#define H6_CLK_CE 35
|
||||
#define H6_CLK_BUS_CE 36
|
||||
#define H6_CLK_VE 37
|
||||
#define H6_CLK_BUS_VE 38
|
||||
#define H6_CLK_EMCE 39
|
||||
#define H6_CLK_BUS_EMCE 40
|
||||
#define H6_CLK_VP9 41
|
||||
#define H6_CLK_BUS_VP9 42
|
||||
#define H6_CLK_BUS_DMA 43
|
||||
#define H6_CLK_BUS_MSGBOX 44
|
||||
#define H6_CLK_BUS_SPINLOCK 45
|
||||
#define H6_CLK_BUS_HSTIMER 46
|
||||
#define H6_CLK_AVS 47
|
||||
#define H6_CLK_BUS_DBG 48
|
||||
#define H6_CLK_BUS_PSI 49
|
||||
#define H6_CLK_BUS_PWM 50
|
||||
#define H6_CLK_BUS_IOMMU 51
|
||||
#define H6_CLK_DRAM 52
|
||||
#define H6_CLK_MBUS_DMA 53
|
||||
#define H6_CLK_MBUS_VE 54
|
||||
#define H6_CLK_MBUS_CE 55
|
||||
#define H6_CLK_MBUS_TS 56
|
||||
#define H6_CLK_MBUS_NAND 57
|
||||
#define H6_CLK_MBUS_CSI 58
|
||||
#define H6_CLK_MBUS_DEINTERLACE 59
|
||||
#define H6_CLK_BUS_DRAM 60
|
||||
#define H6_CLK_NAND0 61
|
||||
#define H6_CLK_NAND1 62
|
||||
#define H6_CLK_BUS_NAND 63
|
||||
#define H6_CLK_MMC0 64
|
||||
#define H6_CLK_MMC1 65
|
||||
#define H6_CLK_MMC2 66
|
||||
#define H6_CLK_BUS_MMC0 67
|
||||
#define H6_CLK_BUS_MMC1 68
|
||||
#define H6_CLK_BUS_MMC2 69
|
||||
#define H6_CLK_BUS_UART0 70
|
||||
#define H6_CLK_BUS_UART1 71
|
||||
#define H6_CLK_BUS_UART2 72
|
||||
#define H6_CLK_BUS_UART3 73
|
||||
#define H6_CLK_BUS_I2C0 74
|
||||
#define H6_CLK_BUS_I2C1 75
|
||||
#define H6_CLK_BUS_I2C2 76
|
||||
#define H6_CLK_BUS_I2C3 77
|
||||
#define H6_CLK_BUS_SCR0 78
|
||||
#define H6_CLK_BUS_SCR1 79
|
||||
#define H6_CLK_SPI0 80
|
||||
#define H6_CLK_SPI1 81
|
||||
#define H6_CLK_BUS_SPI0 82
|
||||
#define H6_CLK_BUS_SPI1 83
|
||||
#define H6_CLK_BUS_EMAC 84
|
||||
#define H6_CLK_TS 85
|
||||
#define H6_CLK_BUS_TS 86
|
||||
#define H6_CLK_IR_TX 87
|
||||
#define H6_CLK_BUS_IR_TX 88
|
||||
#define H6_CLK_BUS_THS 89
|
||||
#define H6_CLK_I2S3 90
|
||||
#define H6_CLK_I2S0 91
|
||||
#define H6_CLK_I2S1 92
|
||||
#define H6_CLK_I2S2 93
|
||||
#define H6_CLK_BUS_I2S0 94
|
||||
#define H6_CLK_BUS_I2S1 95
|
||||
#define H6_CLK_BUS_I2S2 96
|
||||
#define H6_CLK_BUS_I2S3 97
|
||||
#define H6_CLK_SPDIF 98
|
||||
#define H6_CLK_BUS_SPDIF 99
|
||||
#define H6_CLK_DMIC 100
|
||||
#define H6_CLK_BUS_DMIC 101
|
||||
#define H6_CLK_AUDIO_HUB 102
|
||||
#define H6_CLK_BUS_AUDIO_HUB 103
|
||||
#define H6_CLK_USB_OHCI0 104
|
||||
#define H6_CLK_USB_PHY0 105
|
||||
#define H6_CLK_USB_PHY1 106
|
||||
#define H6_CLK_USB_OHCI3 107
|
||||
#define H6_CLK_USB_PHY3 108
|
||||
#define H6_CLK_USB_HSIC_12M 109
|
||||
#define H6_CLK_USB_HSIC 110
|
||||
#define H6_CLK_BUS_OHCI0 111
|
||||
#define H6_CLK_BUS_OHCI3 112
|
||||
#define H6_CLK_BUS_EHCI0 113
|
||||
#define H6_CLK_BUS_XHCI 114
|
||||
#define H6_CLK_BUS_EHCI3 115
|
||||
#define H6_CLK_BUS_OTG 116
|
||||
#define H6_CLK_PCIE_REF_100M 117
|
||||
#define H6_CLK_PCIE_REF 118
|
||||
#define H6_CLK_PCIE_REF_OUT 119
|
||||
#define H6_CLK_PCIE_MAXI 120
|
||||
#define H6_CLK_PCIE_AUX 121
|
||||
#define H6_CLK_BUS_PCIE 122
|
||||
#define H6_CLK_HDMI 123
|
||||
#define H6_CLK_HDMI_SLOW 124
|
||||
#define H6_CLK_HDMI_CEC 125
|
||||
#define H6_CLK_BUS_HDMI 126
|
||||
#define H6_CLK_BUS_TCON_TOP 127
|
||||
#define H6_CLK_TCON_LCD0 128
|
||||
#define H6_CLK_BUS_TCON_LCD0 129
|
||||
#define H6_CLK_TCON_TV0 130
|
||||
#define H6_CLK_BUS_TCON_TV0 131
|
||||
#define H6_CLK_CSI_CCI 132
|
||||
#define H6_CLK_CSI_TOP 133
|
||||
#define H6_CLK_CSI_MCLK 134
|
||||
#define H6_CLK_BUS_CSI 135
|
||||
#define H6_CLK_HDCP 136
|
||||
#define H6_CLK_BUS_HDCP 137
|
||||
|
||||
#endif /* !_SUN50I_H6_CCU_H */
|
Loading…
Reference in New Issue