Source-Changes-HG archive

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]

[src/trunk]: src/sys/arch/arm/imx Modified imx6 Clock Controller Module (CCM).



details:   https://anonhg.NetBSD.org/src/rev/30bbde2a183e
branches:  trunk
changeset: 452786:30bbde2a183e
user:      hkenken <hkenken%NetBSD.org@localhost>
date:      Wed Jul 24 11:58:00 2019 +0000

description:
Modified imx6 Clock Controller Module (CCM).

+ Add imx6_get_clock_by_id().

diffstat:

 sys/arch/arm/imx/files.imx6    |    6 +-
 sys/arch/arm/imx/imx6_board.c  |    8 +-
 sys/arch/arm/imx/imx6_ccm.c    |  353 ++++++++++++++++++++++++++++++++++------
 sys/arch/arm/imx/imx6_ccmreg.h |    5 +-
 sys/arch/arm/imx/imx6_ccmvar.h |   16 +-
 sys/arch/arm/imx/imx6_clk.c    |   94 ++++++++++
 sys/arch/arm/imx/imx6_reg.h    |    5 +-
 7 files changed, 421 insertions(+), 66 deletions(-)

diffs (truncated from 649 to 300 lines):

diff -r d80c314c4c7a -r 30bbde2a183e sys/arch/arm/imx/files.imx6
--- a/sys/arch/arm/imx/files.imx6       Wed Jul 24 11:40:36 2019 +0000
+++ b/sys/arch/arm/imx/files.imx6       Wed Jul 24 11:58:00 2019 +0000
@@ -1,4 +1,4 @@
-#      $NetBSD: files.imx6,v 1.15 2019/06/20 08:16:19 hkenken Exp $
+#      $NetBSD: files.imx6,v 1.16 2019/07/24 11:58:00 hkenken Exp $
 #
 # Configuration info for the Freescale i.MX6
 #
@@ -34,8 +34,8 @@
 # iMX6 Clock Control Module
 device imxccm : clk
 attach imxccm at axi
-file   arch/arm/imx/imx6_ccm.c                 imxccm  needs-flag
-defflag opt_imx6clk.h                          IMXCCMDEBUG
+file   arch/arm/imx/imx6_ccm.c                 imxccm needs-flag
+file   arch/arm/imx/imx6_clk.c                 imxccm
 defparam opt_imx6clk.h                         IMX6_OSC_FREQ
 defparam opt_imx6clk.h                         IMX6_CKIL_FREQ
 defparam opt_imx6clk.h                         IMX6_CKIH_FREQ
diff -r d80c314c4c7a -r 30bbde2a183e sys/arch/arm/imx/imx6_board.c
--- a/sys/arch/arm/imx/imx6_board.c     Wed Jul 24 11:40:36 2019 +0000
+++ b/sys/arch/arm/imx/imx6_board.c     Wed Jul 24 11:58:00 2019 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: imx6_board.c,v 1.12 2018/10/18 09:01:52 skrll Exp $    */
+/*     $NetBSD: imx6_board.c,v 1.13 2019/07/24 11:58:00 hkenken Exp $  */
 
 /*
  * Copyright (c) 2012  Genetec Corporation.  All rights reserved.
@@ -27,12 +27,14 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(1, "$NetBSD: imx6_board.c,v 1.12 2018/10/18 09:01:52 skrll Exp $");
+__KERNEL_RCSID(1, "$NetBSD: imx6_board.c,v 1.13 2019/07/24 11:58:00 hkenken Exp $");
 
 #include "arml2cc.h"
 #include "opt_cputypes.h"
 #include "opt_imx.h"
 
+#define        _INTR_PRIVATE
+
 #include <sys/param.h>
 #include <sys/bus.h>
 #include <sys/cpu.h>
@@ -189,7 +191,7 @@
        uint32_t v;
 
        v = bus_space_read_4(imx6_ioreg_bst, imx6_ioreg_bsh,
-           AIPS1_CCM_ANALOG_BASE + CCM_ANALOG_PLL_ARM);
+           AIPS1_CCM_BASE + CCM_ANALOG_BASE + CCM_ANALOG_PLL_ARM);
        clk = IMX6_OSC_FREQ * (v & CCM_ANALOG_PLL_ARM_DIV_SELECT) / 2;
        v = bus_space_read_4(imx6_ioreg_bst, imx6_ioreg_bsh,
            AIPS1_CCM_BASE + CCM_CACRR);
diff -r d80c314c4c7a -r 30bbde2a183e sys/arch/arm/imx/imx6_ccm.c
--- a/sys/arch/arm/imx/imx6_ccm.c       Wed Jul 24 11:40:36 2019 +0000
+++ b/sys/arch/arm/imx/imx6_ccm.c       Wed Jul 24 11:58:00 2019 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: imx6_ccm.c,v 1.10 2019/06/20 08:16:19 hkenken Exp $    */
+/*     $NetBSD: imx6_ccm.c,v 1.11 2019/07/24 11:58:00 hkenken Exp $    */
 
 /*
  * Copyright (c) 2010-2012, 2014  Genetec Corporation.  All rights reserved.
@@ -30,10 +30,9 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: imx6_ccm.c,v 1.10 2019/06/20 08:16:19 hkenken Exp $");
+__KERNEL_RCSID(0, "$NetBSD: imx6_ccm.c,v 1.11 2019/07/24 11:58:00 hkenken Exp $");
 
 #include "opt_imx.h"
-#include "opt_imx6clk.h"
 #include "opt_cputypes.h"
 
 #include "locators.h"
@@ -48,9 +47,6 @@
 #include <sys/param.h>
 
 #include <machine/cpu.h>
-#ifdef CPU_CORTEXA9
-#include <arm/cortex/a9tmr_var.h>
-#endif
 
 #include <arm/imx/imx6_ccmvar.h>
 #include <arm/imx/imx6_ccmreg.h>
@@ -60,15 +56,6 @@
 
 #include <dev/clk/clk_backend.h>
 
-struct imxccm_softc {
-       device_t sc_dev;
-       bus_space_tag_t sc_iot;
-       bus_space_handle_t sc_ioh;
-       bus_space_handle_t sc_ioh_analog;
-
-       struct clk_domain sc_clkdom;
-};
-
 /* Clock Parents Tables */
 static const char *step_p[] = {
        "osc",
@@ -369,6 +356,275 @@
        "sata_ref_100m"
 };
 
+/* DT clock ID to clock name mappings */
+static struct imx_clock_id {
+       u_int           id;
+       const char      *name;
+} imx6_clock_ids[] = {
+       { IMX6CLK_DUMMY,                "dummy" },
+       { IMX6CLK_CKIL,                 "ckil" },
+       { IMX6CLK_CKIH,                 "ckih" },
+       { IMX6CLK_OSC,                  "osc" },
+       { IMX6CLK_PLL2_PFD0_352M,       "pll2_pfd0_352m" },
+       { IMX6CLK_PLL2_PFD1_594M,       "pll2_pfd1_594m" },
+       { IMX6CLK_PLL2_PFD2_396M,       "pll2_pfd2_396m" },
+       { IMX6CLK_PLL3_PFD0_720M,       "pll3_pfd0_720m" },
+       { IMX6CLK_PLL3_PFD1_540M,       "pll3_pfd1_540m" },
+       { IMX6CLK_PLL3_PFD2_508M,       "pll3_pfd2_508m" },
+       { IMX6CLK_PLL3_PFD3_454M,       "pll3_pfd3_454m" },
+       { IMX6CLK_PLL2_198M,            "pll2_198m" },
+       { IMX6CLK_PLL3_120M,            "pll3_120m" },
+       { IMX6CLK_PLL3_80M,             "pll3_80m" },
+       { IMX6CLK_PLL3_60M,             "pll3_60m" },
+       { IMX6CLK_TWD,                  "twd" },
+       { IMX6CLK_STEP,                 "step" },
+       { IMX6CLK_PLL1_SW,              "pll1_sw" },
+       { IMX6CLK_PERIPH_PRE,           "periph_pre" },
+       { IMX6CLK_PERIPH2_PRE,          "periph2_pre" },
+       { IMX6CLK_PERIPH_CLK2_SEL,      "periph_clk2_sel" },
+       { IMX6CLK_PERIPH2_CLK2_SEL,     "periph2_clk2_sel" },
+       { IMX6CLK_AXI_SEL,              "axi_sel" },
+       { IMX6CLK_ESAI_SEL,             "esai_sel" },
+       { IMX6CLK_ASRC_SEL,             "asrc_sel" },
+       { IMX6CLK_SPDIF_SEL,            "spdif_sel" },
+       { IMX6CLK_GPU2D_AXI,            "gpu2d_axi" },
+       { IMX6CLK_GPU3D_AXI,            "gpu3d_axi" },
+       { IMX6CLK_GPU2D_CORE_SEL,       "gpu2d_core_sel" },
+       { IMX6CLK_GPU3D_CORE_SEL,       "gpu3d_core_sel" },
+       { IMX6CLK_GPU3D_SHADER_SEL,     "gpu3d_shader_sel" },
+       { IMX6CLK_IPU1_SEL,             "ipu1_sel" },
+       { IMX6CLK_IPU2_SEL,             "ipu2_sel" },
+       { IMX6CLK_LDB_DI0_SEL,          "ldb_di0_sel" },
+       { IMX6CLK_LDB_DI1_SEL,          "ldb_di1_sel" },
+       { IMX6CLK_IPU1_DI0_PRE_SEL,     "ipu1_di0_pre_sel" },
+       { IMX6CLK_IPU1_DI1_PRE_SEL,     "ipu1_di1_pre_sel" },
+       { IMX6CLK_IPU2_DI0_PRE_SEL,     "ipu2_di0_pre_sel" },
+       { IMX6CLK_IPU2_DI1_PRE_SEL,     "ipu2_di1_pre_sel" },
+       { IMX6CLK_IPU1_DI0_SEL,         "ipu1_di0_sel" },
+       { IMX6CLK_IPU1_DI1_SEL,         "ipu1_di1_sel" },
+       { IMX6CLK_IPU2_DI0_SEL,         "ipu2_di0_sel" },
+       { IMX6CLK_IPU2_DI1_SEL,         "ipu2_di1_sel" },
+       { IMX6CLK_HSI_TX_SEL,           "hsi_tx_sel" },
+       { IMX6CLK_PCIE_AXI_SEL,         "pcie_axi_sel" },
+       { IMX6CLK_SSI1_SEL,             "ssi1_sel" },
+       { IMX6CLK_SSI2_SEL,             "ssi2_sel" },
+       { IMX6CLK_SSI3_SEL,             "ssi3_sel" },
+       { IMX6CLK_USDHC1_SEL,           "usdhc1_sel" },
+       { IMX6CLK_USDHC2_SEL,           "usdhc2_sel" },
+       { IMX6CLK_USDHC3_SEL,           "usdhc3_sel" },
+       { IMX6CLK_USDHC4_SEL,           "usdhc4_sel" },
+       { IMX6CLK_ENFC_SEL,             "enfc_sel" },
+       { IMX6CLK_EIM_SEL,              "eim_sel" },
+       { IMX6CLK_EIM_SLOW_SEL,         "eim_slow_sel" },
+       { IMX6CLK_VDO_AXI_SEL,          "vdo_axi_sel" },
+       { IMX6CLK_VPU_AXI_SEL,          "vpu_axi_sel" },
+       { IMX6CLK_CKO1_SEL,             "cko1_sel" },
+       { IMX6CLK_PERIPH,               "periph" },
+       { IMX6CLK_PERIPH2,              "periph2" },
+       { IMX6CLK_PERIPH_CLK2,          "periph_clk2" },
+       { IMX6CLK_PERIPH2_CLK2,         "periph2_clk2" },
+       { IMX6CLK_IPG,                  "ipg" },
+       { IMX6CLK_IPG_PER,              "ipg_per" },
+       { IMX6CLK_ESAI_PRED,            "esai_pred" },
+       { IMX6CLK_ESAI_PODF,            "esai_podf" },
+       { IMX6CLK_ASRC_PRED,            "asrc_pred" },
+       { IMX6CLK_ASRC_PODF,            "asrc_podf" },
+       { IMX6CLK_SPDIF_PRED,           "spdif_pred" },
+       { IMX6CLK_SPDIF_PODF,           "spdif_podf" },
+       { IMX6CLK_CAN_ROOT,             "can_root" },
+       { IMX6CLK_ECSPI_ROOT,           "ecspi_root" },
+       { IMX6CLK_GPU2D_CORE_PODF,      "gpu2d_core_podf" },
+       { IMX6CLK_GPU3D_CORE_PODF,      "gpu3d_core_podf" },
+       { IMX6CLK_GPU3D_SHADER,         "gpu3d_shader" },
+       { IMX6CLK_IPU1_PODF,            "ipu1_podf" },
+       { IMX6CLK_IPU2_PODF,            "ipu2_podf" },
+       { IMX6CLK_LDB_DI0_PODF,         "ldb_di0_podf" },
+       { IMX6CLK_LDB_DI1_PODF,         "ldb_di1_podf" },
+       { IMX6CLK_IPU1_DI0_PRE,         "ipu1_di0_pre" },
+       { IMX6CLK_IPU1_DI1_PRE,         "ipu1_di1_pre" },
+       { IMX6CLK_IPU2_DI0_PRE,         "ipu2_di0_pre" },
+       { IMX6CLK_IPU2_DI1_PRE,         "ipu2_di1_pre" },
+       { IMX6CLK_HSI_TX_PODF,          "hsi_tx_podf" },
+       { IMX6CLK_SSI1_PRED,            "ssi1_pred" },
+       { IMX6CLK_SSI1_PODF,            "ssi1_podf" },
+       { IMX6CLK_SSI2_PRED,            "ssi2_pred" },
+       { IMX6CLK_SSI2_PODF,            "ssi2_podf" },
+       { IMX6CLK_SSI3_PRED,            "ssi3_pred" },
+       { IMX6CLK_SSI3_PODF,            "ssi3_podf" },
+       { IMX6CLK_UART_SERIAL_PODF,     "uart_serial_podf" },
+       { IMX6CLK_USDHC1_PODF,          "usdhc1_podf" },
+       { IMX6CLK_USDHC2_PODF,          "usdhc2_podf" },
+       { IMX6CLK_USDHC3_PODF,          "usdhc3_podf" },
+       { IMX6CLK_USDHC4_PODF,          "usdhc4_podf" },
+       { IMX6CLK_ENFC_PRED,            "enfc_pred" },
+       { IMX6CLK_ENFC_PODF,            "enfc_podf" },
+       { IMX6CLK_EIM_PODF,             "eim_podf" },
+       { IMX6CLK_EIM_SLOW_PODF,        "eim_slow_podf" },
+       { IMX6CLK_VPU_AXI_PODF,         "vpu_axi_podf" },
+       { IMX6CLK_CKO1_PODF,            "cko1_podf" },
+       { IMX6CLK_AXI,                  "axi" },
+       { IMX6CLK_MMDC_CH0_AXI_PODF,    "mmdc_ch0_axi_podf" },
+       { IMX6CLK_MMDC_CH1_AXI_PODF,    "mmdc_ch1_axi_podf" },
+       { IMX6CLK_ARM,                  "arm" },
+       { IMX6CLK_AHB,                  "ahb" },
+       { IMX6CLK_APBH_DMA,             "apbh_dma" },
+       { IMX6CLK_ASRC,                 "asrc" },
+       { IMX6CLK_CAN1_IPG,             "can1_ipg" },
+       { IMX6CLK_CAN1_SERIAL,          "can1_serial" },
+       { IMX6CLK_CAN2_IPG,             "can2_ipg" },
+       { IMX6CLK_CAN2_SERIAL,          "can2_serial" },
+       { IMX6CLK_ECSPI1,               "ecspi1" },
+       { IMX6CLK_ECSPI2,               "ecspi2" },
+       { IMX6CLK_ECSPI3,               "ecspi3" },
+       { IMX6CLK_ECSPI4,               "ecspi4" },
+       { IMX6CLK_ECSPI5,               "ecspi5" },
+       { IMX6CLK_ENET,                 "enet" },
+       { IMX6CLK_ESAI_EXTAL,           "esai_extal" },
+       { IMX6CLK_GPT_IPG,              "gpt_ipg" },
+       { IMX6CLK_GPT_IPG_PER,          "gpt_ipg_per" },
+       { IMX6CLK_GPU2D_CORE,           "gpu2d_core" },
+       { IMX6CLK_GPU3D_CORE,           "gpu3d_core" },
+       { IMX6CLK_HDMI_IAHB,            "hdmi_iahb" },
+       { IMX6CLK_HDMI_ISFR,            "hdmi_isfr" },
+       { IMX6CLK_I2C1,                 "i2c1" },
+       { IMX6CLK_I2C2,                 "i2c2" },
+       { IMX6CLK_I2C3,                 "i2c3" },
+       { IMX6CLK_IIM,                  "iim" },
+       { IMX6CLK_ENFC,                 "enfc" },
+       { IMX6CLK_IPU1,                 "ipu1" },
+       { IMX6CLK_IPU1_DI0,             "ipu1_di0" },
+       { IMX6CLK_IPU1_DI1,             "ipu1_di1" },
+       { IMX6CLK_IPU2,                 "ipu2" },
+       { IMX6CLK_IPU2_DI0,             "ipu2_di0" },
+       { IMX6CLK_LDB_DI0,              "ldb_di0" },
+       { IMX6CLK_LDB_DI1,              "ldb_di1" },
+       { IMX6CLK_IPU2_DI1,             "ipu2_di1" },
+       { IMX6CLK_HSI_TX,               "hsi_tx" },
+       { IMX6CLK_MLB,                  "mlb" },
+       { IMX6CLK_MMDC_CH0_AXI,         "mmdc_ch0_axi" },
+       { IMX6CLK_MMDC_CH1_AXI,         "mmdc_ch1_axi" },
+       { IMX6CLK_OCRAM,                "ocram" },
+       { IMX6CLK_OPENVG_AXI,           "openvg_axi" },
+       { IMX6CLK_PCIE_AXI,             "pcie_axi" },
+       { IMX6CLK_PWM1,                 "pwm1" },
+       { IMX6CLK_PWM2,                 "pwm2" },
+       { IMX6CLK_PWM3,                 "pwm3" },
+       { IMX6CLK_PWM4,                 "pwm4" },
+       { IMX6CLK_PER1_BCH,             "per1_bch" },
+       { IMX6CLK_GPMI_BCH_APB,         "gpmi_bch_apb" },
+       { IMX6CLK_GPMI_BCH,             "gpmi_bch" },
+       { IMX6CLK_GPMI_IO,              "gpmi_io" },
+       { IMX6CLK_GPMI_APB,             "gpmi_apb" },
+       { IMX6CLK_SATA,                 "sata" },
+       { IMX6CLK_SDMA,                 "sdma" },
+       { IMX6CLK_SPBA,                 "spba" },
+       { IMX6CLK_SSI1,                 "ssi1" },
+       { IMX6CLK_SSI2,                 "ssi2" },
+       { IMX6CLK_SSI3,                 "ssi3" },
+       { IMX6CLK_UART_IPG,             "uart_ipg" },
+       { IMX6CLK_UART_SERIAL,          "uart_serial" },
+       { IMX6CLK_USBOH3,               "usboh3" },
+       { IMX6CLK_USDHC1,               "usdhc1" },
+       { IMX6CLK_USDHC2,               "usdhc2" },
+       { IMX6CLK_USDHC3,               "usdhc3" },
+       { IMX6CLK_USDHC4,               "usdhc4" },
+       { IMX6CLK_VDO_AXI,              "vdo_axi" },
+       { IMX6CLK_VPU_AXI,              "vpu_axi" },
+       { IMX6CLK_CKO1,                 "cko1" },
+       { IMX6CLK_PLL1_SYS,             "pll1_sys" },
+       { IMX6CLK_PLL2_BUS,             "pll2_bus" },
+       { IMX6CLK_PLL3_USB_OTG,         "pll3_usb_otg" },
+       { IMX6CLK_PLL4_AUDIO,           "pll4_audio" },
+       { IMX6CLK_PLL5_VIDEO,           "pll5_video" },
+       { IMX6CLK_PLL8_MLB,             "pll8_mlb" },
+       { IMX6CLK_PLL7_USB_HOST,        "pll7_usb_host" },
+       { IMX6CLK_PLL6_ENET,            "pll6_enet" },
+       { IMX6CLK_SSI1_IPG,             "ssi1_ipg" },
+       { IMX6CLK_SSI2_IPG,             "ssi2_ipg" },
+       { IMX6CLK_SSI3_IPG,             "ssi3_ipg" },
+       { IMX6CLK_ROM,                  "rom" },
+       { IMX6CLK_USBPHY1,              "usbphy1" },
+       { IMX6CLK_USBPHY2,              "usbphy2" },
+       { IMX6CLK_LDB_DI0_DIV_3_5,      "ldb_di0_div_3_5" },
+       { IMX6CLK_LDB_DI1_DIV_3_5,      "ldb_di1_div_3_5" },
+       { IMX6CLK_SATA_REF,             "sata_ref" },
+       { IMX6CLK_SATA_REF_100M,        "sata_ref_100m" },
+       { IMX6CLK_PCIE_REF,             "pcie_ref" },
+       { IMX6CLK_PCIE_REF_125M,        "pcie_ref_125m" },



Home | Main Index | Thread Index | Old Index