blob: 92d4463dff5fa2a7a19e6bea9e9d7ef6381b23fd [file] [log] [blame]
Tom Rini10e47792018-05-06 17:58:06 -04001/* SPDX-License-Identifier: GPL-2.0+ */
Peng Fan684ccd92017-02-22 16:21:42 +08002/*
3 * Copyright (C) 2016 Freescale Semiconductor, Inc.
Peng Fan684ccd92017-02-22 16:21:42 +08004 */
5
6#ifndef _ASM_ARCH_CLOCK_H
7#define _ASM_ARCH_CLOCK_H
8
Peng Fan684ccd92017-02-22 16:21:42 +08009#include <asm/arch/pcc.h>
10#include <asm/arch/scg.h>
11
12/* Mainly for compatible to imx common code. */
13enum mxc_clock {
14 MXC_ARM_CLK = 0,
15 MXC_AHB_CLK,
16 MXC_IPG_CLK,
17 MXC_UART_CLK,
18 MXC_CSPI_CLK,
19 MXC_AXI_CLK,
20 MXC_DDR_CLK,
21 MXC_ESDHC_CLK,
22 MXC_ESDHC2_CLK,
23 MXC_I2C_CLK,
24};
25
26u32 mxc_get_clock(enum mxc_clock clk);
27u32 get_lpuart_clk(void);
Ye Li3edefd52019-07-22 01:24:53 +000028#ifdef CONFIG_SYS_I2C_IMX_LPI2C
Ye Lib7f9c3e2017-02-22 16:21:44 +080029int enable_i2c_clk(unsigned char enable, unsigned i2c_num);
30u32 imx_get_i2cclk(unsigned i2c_num);
31#endif
Peng Fan684ccd92017-02-22 16:21:42 +080032#ifdef CONFIG_MXC_OCOTP
33void enable_ocotp_clk(unsigned char enable);
34#endif
Tom Riniceed5d22017-05-12 22:33:27 -040035#ifdef CONFIG_USB_EHCI_HCD
Peng Fan684ccd92017-02-22 16:21:42 +080036void enable_usboh3_clk(unsigned char enable);
37#endif
38void init_clk_usdhc(u32 index);
39void clock_init(void);
Peng Fana26ba6d2017-02-22 16:21:53 +080040void hab_caam_clock_enable(unsigned char enable);
Peng Fan684ccd92017-02-22 16:21:42 +080041#endif