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