1*83d290c5STom 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>
19d96ebc46SSiarhei Siamashka #elif defined(CONFIG_MACH_SUN6I) || defined(CONFIG_MACH_SUN8I) || \
20d96ebc46SSiarhei Siamashka       defined(CONFIG_MACH_SUN50I)
2114177e47SChen-Yu Tsai #include <asm/arch/clock_sun6i.h>
22e35377d7SHans de Goede #elif defined(CONFIG_MACH_SUN9I)
23e35377d7SHans de Goede #include <asm/arch/clock_sun9i.h>
2414177e47SChen-Yu Tsai #else
25643cf0eaSIan Campbell #include <asm/arch/clock_sun4i.h>
2614177e47SChen-Yu Tsai #endif
27643cf0eaSIan Campbell 
28643cf0eaSIan Campbell #ifndef __ASSEMBLY__
29643cf0eaSIan Campbell int clock_init(void);
30643cf0eaSIan Campbell int clock_twi_onoff(int port, int state);
310bd51251SHans de Goede void clock_set_de_mod_clock(u32 *clk_cfg, unsigned int hz);
32643cf0eaSIan Campbell void clock_init_safe(void);
33ed80584fSChen-Yu Tsai void clock_init_sec(void);
34643cf0eaSIan Campbell void clock_init_uart(void);
35643cf0eaSIan Campbell #endif
36643cf0eaSIan Campbell 
37643cf0eaSIan Campbell #endif /* _SUNXI_CLOCK_H */
38