1643cf0eaSIan Campbell /* 2643cf0eaSIan Campbell * (C) Copyright 2007-2011 3643cf0eaSIan Campbell * Allwinner Technology Co., Ltd. <www.allwinnertech.com> 4643cf0eaSIan Campbell * Tom Cubie <tangliang@allwinnertech.com> 5643cf0eaSIan Campbell * 6643cf0eaSIan Campbell * SPDX-License-Identifier: GPL-2.0+ 7643cf0eaSIan Campbell */ 8643cf0eaSIan Campbell 9643cf0eaSIan Campbell #ifndef _SUNXI_CLOCK_H 10643cf0eaSIan Campbell #define _SUNXI_CLOCK_H 11643cf0eaSIan Campbell 12643cf0eaSIan Campbell #include <linux/types.h> 13643cf0eaSIan Campbell 14643cf0eaSIan Campbell #define CLK_GATE_OPEN 0x1 15643cf0eaSIan Campbell #define CLK_GATE_CLOSE 0x0 16643cf0eaSIan Campbell 17643cf0eaSIan Campbell /* clock control module regs definition */ 18ed41e62fSIan Campbell #if defined(CONFIG_MACH_SUN6I) || defined(CONFIG_MACH_SUN8I) 1914177e47SChen-Yu Tsai #include <asm/arch/clock_sun6i.h> 20*e35377d7SHans de Goede #elif defined(CONFIG_MACH_SUN9I) 21*e35377d7SHans de Goede #include <asm/arch/clock_sun9i.h> 2214177e47SChen-Yu Tsai #else 23643cf0eaSIan Campbell #include <asm/arch/clock_sun4i.h> 2414177e47SChen-Yu Tsai #endif 25643cf0eaSIan Campbell 26643cf0eaSIan Campbell #ifndef __ASSEMBLY__ 27643cf0eaSIan Campbell int clock_init(void); 28643cf0eaSIan Campbell int clock_twi_onoff(int port, int state); 290bd51251SHans de Goede void clock_set_de_mod_clock(u32 *clk_cfg, unsigned int hz); 30643cf0eaSIan Campbell void clock_init_safe(void); 31643cf0eaSIan Campbell void clock_init_uart(void); 32643cf0eaSIan Campbell #endif 33643cf0eaSIan Campbell 34643cf0eaSIan Campbell #endif /* _SUNXI_CLOCK_H */ 35