1/*- 2 * SPDX-License-Identifier: BSD-2-Clause-FreeBSD 3 * 4 * Copyright (c) 2020 Oleksandr Tymoshenko <gonzo@FreeBSD.org> 5 * 6 * Redistribution and use in source and binary forms, with or without 7 * modification, are permitted provided that the following conditions 8 * are met: 9 * 1. Redistributions of source code must retain the above copyright 10 * notice, this list of conditions and the following disclaimer. 11 * 2. Redistributions in binary form must reproduce the above copyright 12 * notice, this list of conditions and the following disclaimer in the 13 * documentation and/or other materials provided with the distribution. 14 * 15 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND 16 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 17 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 18 * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE 19 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 20 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 21 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 22 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 23 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 24 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 25 * SUCH DAMAGE. 26 * 27 * $FreeBSD$ 28 */ 29 30#ifndef __IMX8MQ_CCM_H__ 31#define __IMX8MQ_CCM_H__ 32 33#define IMX8MQ_CLK_DUMMY 0 34#define IMX8MQ_CLK_32K 1 35#define IMX8MQ_CLK_25M 2 36#define IMX8MQ_CLK_27M 3 37#define IMX8MQ_CLK_EXT1 4 38#define IMX8MQ_CLK_EXT2 5 39#define IMX8MQ_CLK_EXT3 6 40#define IMX8MQ_CLK_EXT4 7 41 42#define IMX8MQ_ARM_PLL_REF_SEL 8 43#define IMX8MQ_ARM_PLL_REF_DIV 9 44#define IMX8MQ_ARM_PLL 10 45#define IMX8MQ_ARM_PLL_BYPASS 11 46#define IMX8MQ_ARM_PLL_OUT 12 47 48#define IMX8MQ_GPU_PLL_REF_SEL 13 49#define IMX8MQ_GPU_PLL_REF_DIV 14 50#define IMX8MQ_GPU_PLL 15 51#define IMX8MQ_GPU_PLL_BYPASS 16 52#define IMX8MQ_GPU_PLL_OUT 17 53 54#define IMX8MQ_VPU_PLL_REF_SEL 18 55#define IMX8MQ_VPU_PLL_REF_DIV 19 56#define IMX8MQ_VPU_PLL 20 57#define IMX8MQ_VPU_PLL_BYPASS 21 58#define IMX8MQ_VPU_PLL_OUT 22 59 60#define IMX8MQ_AUDIO_PLL1_REF_SEL 23 61#define IMX8MQ_AUDIO_PLL1_REF_DIV 24 62#define IMX8MQ_AUDIO_PLL1 25 63#define IMX8MQ_AUDIO_PLL1_BYPASS 26 64#define IMX8MQ_AUDIO_PLL1_OUT 27 65 66#define IMX8MQ_AUDIO_PLL2_REF_SEL 28 67#define IMX8MQ_AUDIO_PLL2_REF_DIV 29 68#define IMX8MQ_AUDIO_PLL2 30 69#define IMX8MQ_AUDIO_PLL2_BYPASS 31 70#define IMX8MQ_AUDIO_PLL2_OUT 32 71 72#define IMX8MQ_VIDEO_PLL1_REF_SEL 33 73#define IMX8MQ_VIDEO_PLL1_REF_DIV 34 74#define IMX8MQ_VIDEO_PLL1 35 75#define IMX8MQ_VIDEO_PLL1_BYPASS 36 76#define IMX8MQ_VIDEO_PLL1_OUT 37 77 78#define IMX8MQ_SYS3_PLL1_REF_SEL 54 79#define IMX8MQ_SYS3_PLL1 56 80 81#define IMX8MQ_DRAM_PLL1_REF_SEL 62 82 83#define IMX8MQ_SYS1_PLL_40M 70 84#define IMX8MQ_SYS1_PLL_80M 71 85#define IMX8MQ_SYS1_PLL_100M 72 86#define IMX8MQ_SYS1_PLL_133M 73 87#define IMX8MQ_SYS1_PLL_160M 74 88#define IMX8MQ_SYS1_PLL_200M 75 89#define IMX8MQ_SYS1_PLL_266M 76 90#define IMX8MQ_SYS1_PLL_400M 77 91#define IMX8MQ_SYS1_PLL_800M 78 92 93#define IMX8MQ_SYS2_PLL_50M 79 94#define IMX8MQ_SYS2_PLL_100M 80 95#define IMX8MQ_SYS2_PLL_125M 81 96#define IMX8MQ_SYS2_PLL_166M 82 97#define IMX8MQ_SYS2_PLL_200M 83 98#define IMX8MQ_SYS2_PLL_250M 84 99#define IMX8MQ_SYS2_PLL_333M 85 100#define IMX8MQ_SYS2_PLL_500M 86 101#define IMX8MQ_SYS2_PLL_1000M 87 102 103#define IMX8MQ_CLK_ENET_AXI 104 104#define IMX8MQ_CLK_USB_BUS 110 105 106#define IMX8MQ_CLK_AHB 116 107 108#define IMX8MQ_CLK_ENET_REF 137 109#define IMX8MQ_CLK_ENET_TIMER 138 110#define IMX8MQ_CLK_ENET_PHY_REF 139 111#define IMX8MQ_CLK_USDHC1 142 112#define IMX8MQ_CLK_USDHC2 143 113#define IMX8MQ_CLK_I2C1 144 114#define IMX8MQ_CLK_I2C2 145 115#define IMX8MQ_CLK_I2C3 146 116#define IMX8MQ_CLK_I2C4 147 117#define IMX8MQ_CLK_UART1 148 118#define IMX8MQ_CLK_UART2 149 119#define IMX8MQ_CLK_UART3 150 120#define IMX8MQ_CLK_UART4 151 121#define IMX8MQ_CLK_USB_CORE_REF 152 122#define IMX8MQ_CLK_USB_PHY_REF 153 123 124#define IMX8MQ_CLK_ENET1_ROOT 182 125#define IMX8MQ_CLK_I2C1_ROOT 184 126#define IMX8MQ_CLK_I2C2_ROOT 185 127#define IMX8MQ_CLK_I2C3_ROOT 186 128#define IMX8MQ_CLK_I2C4_ROOT 187 129#define IMX8MQ_CLK_UART1_ROOT 202 130#define IMX8MQ_CLK_UART2_ROOT 203 131#define IMX8MQ_CLK_UART3_ROOT 204 132#define IMX8MQ_CLK_UART4_ROOT 205 133#define IMX8MQ_CLK_USB1_CTRL_ROOT 206 134#define IMX8MQ_CLK_USB2_CTRL_ROOT 207 135#define IMX8MQ_CLK_USB1_PHY_ROOT 208 136#define IMX8MQ_CLK_USB2_PHY_ROOT 209 137#define IMX8MQ_CLK_USDHC1_ROOT 210 138#define IMX8MQ_CLK_USDHC2_ROOT 211 139 140#define IMX8MQ_SYS1_PLL_OUT 231 141#define IMX8MQ_SYS2_PLL_OUT 232 142#define IMX8MQ_SYS3_PLL_OUT 233 143 144#define IMX8MQ_CLK_IPG_ROOT 236 145 146#define IMX8MQ_CLK_GPIO1_ROOT 259 147#define IMX8MQ_CLK_GPIO2_ROOT 260 148#define IMX8MQ_CLK_GPIO3_ROOT 261 149#define IMX8MQ_CLK_GPIO4_ROOT 262 150#define IMX8MQ_CLK_GPIO5_ROOT 263 151 152#define IMX8MQ_VIDEO2_PLL1_REF_SEL 266 153 154#define IMX8MQ_SYS1_PLL_40M_CG 267 155#define IMX8MQ_SYS1_PLL_80M_CG 268 156#define IMX8MQ_SYS1_PLL_100M_CG 269 157#define IMX8MQ_SYS1_PLL_133M_CG 270 158#define IMX8MQ_SYS1_PLL_160M_CG 271 159#define IMX8MQ_SYS1_PLL_200M_CG 272 160#define IMX8MQ_SYS1_PLL_266M_CG 273 161#define IMX8MQ_SYS1_PLL_400M_CG 274 162#define IMX8MQ_SYS1_PLL_800M_CG 275 163#define IMX8MQ_SYS2_PLL_50M_CG 276 164#define IMX8MQ_SYS2_PLL_100M_CG 277 165#define IMX8MQ_SYS2_PLL_125M_CG 278 166#define IMX8MQ_SYS2_PLL_166M_CG 279 167#define IMX8MQ_SYS2_PLL_200M_CG 280 168#define IMX8MQ_SYS2_PLL_250M_CG 281 169#define IMX8MQ_SYS2_PLL_333M_CG 282 170#define IMX8MQ_SYS2_PLL_500M_CG 283 171#define IMX8MQ_SYS2_PLL_1000M_CG 284 172 173#endif 174