blob: 42382a8ae2ff365694bf7a37a1618733fbabaf73 [file] [log] [blame]
Ian Campbell49aeca32014-05-05 11:52:23 +01001/*
2 * (C) Copyright 2007-2011
3 * Allwinner Technology Co., Ltd. <www.allwinnertech.com>
4 * Tom Cubie <tangliang@allwinnertech.com>
5 *
6 * SPDX-License-Identifier: GPL-2.0+
7 */
8
9#ifndef _SUNXI_CLOCK_H
10#define _SUNXI_CLOCK_H
11
12#include <linux/types.h>
13
14#define CLK_GATE_OPEN 0x1
15#define CLK_GATE_CLOSE 0x0
16
17/* clock control module regs definition */
Ian Campbell8f32aaa2014-10-24 21:20:47 +010018#if defined(CONFIG_MACH_SUN6I) || defined(CONFIG_MACH_SUN8I)
Chen-Yu Tsai3a045422014-10-03 20:16:25 +080019#include <asm/arch/clock_sun6i.h>
20#else
Ian Campbell49aeca32014-05-05 11:52:23 +010021#include <asm/arch/clock_sun4i.h>
Chen-Yu Tsai3a045422014-10-03 20:16:25 +080022#endif
Ian Campbell49aeca32014-05-05 11:52:23 +010023
24#ifndef __ASSEMBLY__
25int clock_init(void);
26int clock_twi_onoff(int port, int state);
27void clock_set_pll1(unsigned int hz);
Hans de Goede9f072732014-10-22 14:42:48 +020028unsigned int clock_get_pll5p(void);
Ian Campbell49aeca32014-05-05 11:52:23 +010029unsigned int clock_get_pll6(void);
30void clock_init_safe(void);
31void clock_init_uart(void);
32#endif
33
34#endif /* _SUNXI_CLOCK_H */