1 /* 2 * (C) Copyright 2011 3 * Stefano Babic, DENX Software Engineering, sbabic@denx.de. 4 * 5 * See file CREDITS for list of people who contributed to this 6 * project. 7 * 8 * This program is free software; you can redistribute it and/or 9 * modify it under the terms of the GNU General Public License as 10 * published by the Free Software Foundation; either version 2 of 11 * the License, or (at your option) any later version. 12 * 13 * This program is distributed in the hope that it will be useful, 14 * but WITHOUT ANY WARRANTY; without even the implied warranty of 15 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 16 * GNU General Public License for more details. 17 * 18 * You should have received a copy of the GNU General Public License 19 * along with this program; if not, write to the Free Software 20 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, 21 * MA 02111-1307 USA 22 */ 23 24 #ifndef __ASM_ARCH_CLOCK_H 25 #define __ASM_ARCH_CLOCK_H 26 27 #include <common.h> 28 29 #ifdef CONFIG_MX35_HCLK_FREQ 30 #define MXC_HCLK CONFIG_MX35_HCLK_FREQ 31 #else 32 #define MXC_HCLK 24000000 33 #endif 34 35 #ifdef CONFIG_MX35_CLK32 36 #define MXC_CLK32 CONFIG_MX35_CLK32 37 #else 38 #define MXC_CLK32 32768 39 #endif 40 41 enum mxc_clock { 42 MXC_ARM_CLK, 43 MXC_AHB_CLK, 44 MXC_IPG_CLK, 45 MXC_IPG_PERCLK, 46 MXC_UART_CLK, 47 MXC_ESDHC1_CLK, 48 MXC_ESDHC2_CLK, 49 MXC_ESDHC3_CLK, 50 MXC_USB_CLK, 51 MXC_CSPI_CLK, 52 MXC_FEC_CLK, 53 MXC_I2C_CLK, 54 }; 55 56 enum mxc_main_clock { 57 CPU_CLK, 58 AHB_CLK, 59 IPG_CLK, 60 IPG_PER_CLK, 61 NFC_CLK, 62 USB_CLK, 63 HSP_CLK, 64 }; 65 66 enum mxc_peri_clock { 67 UART1_BAUD, 68 UART2_BAUD, 69 UART3_BAUD, 70 SSI1_BAUD, 71 SSI2_BAUD, 72 CSI_BAUD, 73 MSHC_CLK, 74 ESDHC1_CLK, 75 ESDHC2_CLK, 76 ESDHC3_CLK, 77 SPDIF_CLK, 78 SPI1_CLK, 79 SPI2_CLK, 80 }; 81 82 u32 imx_get_uartclk(void); 83 u32 imx_get_fecclk(void); 84 unsigned int mxc_get_clock(enum mxc_clock clk); 85 86 #endif /* __ASM_ARCH_CLOCK_H */ 87