183d290c5STom Rini /* SPDX-License-Identifier: GPL-2.0+ */ 2643cf0eaSIan Campbell /* 3643cf0eaSIan Campbell * (C) Copyright 2007-2011 4643cf0eaSIan Campbell * Allwinner Technology Co., Ltd. <www.allwinnertech.com> 5643cf0eaSIan Campbell * Tom Cubie <tangliang@allwinnertech.com> 6643cf0eaSIan Campbell */ 7643cf0eaSIan Campbell 8643cf0eaSIan Campbell #ifndef _SUNXI_CLOCK_H 9643cf0eaSIan Campbell #define _SUNXI_CLOCK_H 10643cf0eaSIan Campbell 11643cf0eaSIan Campbell #include <linux/types.h> 12643cf0eaSIan Campbell 13643cf0eaSIan Campbell #define CLK_GATE_OPEN 0x1 14643cf0eaSIan Campbell #define CLK_GATE_CLOSE 0x0 15643cf0eaSIan Campbell 16643cf0eaSIan Campbell /* clock control module regs definition */ 17f542948bSvishnupatekar #if defined(CONFIG_MACH_SUN8I_A83T) 18f542948bSvishnupatekar #include <asm/arch/clock_sun8i_a83t.h> 19*0558676dSIcenowy Zheng #elif defined(CONFIG_MACH_SUN50I_H6) 20*0558676dSIcenowy Zheng #include <asm/arch/clock_sun50i_h6.h> 21d96ebc46SSiarhei Siamashka #elif defined(CONFIG_MACH_SUN6I) || defined(CONFIG_MACH_SUN8I) || \ 22d96ebc46SSiarhei Siamashka defined(CONFIG_MACH_SUN50I) 2314177e47SChen-Yu Tsai #include <asm/arch/clock_sun6i.h> 24e35377d7SHans de Goede #elif defined(CONFIG_MACH_SUN9I) 25e35377d7SHans de Goede #include <asm/arch/clock_sun9i.h> 2614177e47SChen-Yu Tsai #else 27643cf0eaSIan Campbell #include <asm/arch/clock_sun4i.h> 2814177e47SChen-Yu Tsai #endif 29643cf0eaSIan Campbell 30643cf0eaSIan Campbell #ifndef __ASSEMBLY__ 31643cf0eaSIan Campbell int clock_init(void); 32643cf0eaSIan Campbell int clock_twi_onoff(int port, int state); 330bd51251SHans de Goede void clock_set_de_mod_clock(u32 *clk_cfg, unsigned int hz); 34643cf0eaSIan Campbell void clock_init_safe(void); 35ed80584fSChen-Yu Tsai void clock_init_sec(void); 36643cf0eaSIan Campbell void clock_init_uart(void); 37643cf0eaSIan Campbell #endif 38643cf0eaSIan Campbell 39643cf0eaSIan Campbell #endif /* _SUNXI_CLOCK_H */ 40