]> git.kernelconcepts.de Git - karo-tx-uboot.git/commitdiff
socfpga: fix clock manager register definition
authorPavel Machek <pavel@denx.de>
Sat, 19 Jul 2014 21:57:59 +0000 (23:57 +0200)
committerTom Rini <trini@ti.com>
Fri, 29 Aug 2014 19:50:50 +0000 (15:50 -0400)
Structure defining clock manager hardware was wrong, leading to
wrong registers being accessed and hang in MMC init.

This fixes structure to match hardware.

Signed-off-by: Pavel Machek <pavel@denx.de>
arch/arm/cpu/armv7/socfpga/clock_manager.c
arch/arm/include/asm/arch-socfpga/clock_manager.h
drivers/mmc/socfpga_dw_mmc.c

index 23d697dee2a7f6585a468959db6afdce8cb07e62..0228ac8c3b5e36db6c7e4a88a816252455b149c7 100644 (file)
@@ -110,8 +110,8 @@ void cm_basic_init(const cm_config_t *cfg)
         * gatting off the rest of the periperal clocks.
         */
        writel(~CLKMGR_PERPLLGRP_EN_NANDCLK_MASK &
-               readl(&clock_manager_base->per_pll_en),
-               &clock_manager_base->per_pll_en);
+               readl(&clock_manager_base->per_pll.en),
+               &clock_manager_base->per_pll.en);
 
        /* DO NOT GATE OFF DEBUG CLOCKS & BRIDGE CLOCKS */
        writel(CLKMGR_MAINPLLGRP_EN_DBGTIMERCLK_MASK |
@@ -120,12 +120,12 @@ void cm_basic_init(const cm_config_t *cfg)
                CLKMGR_MAINPLLGRP_EN_DBGATCLK_MASK |
                CLKMGR_MAINPLLGRP_EN_S2FUSER0CLK_MASK |
                CLKMGR_MAINPLLGRP_EN_L4MPCLK_MASK,
-               &clock_manager_base->main_pll_en);
+               &clock_manager_base->main_pll.en);
 
-       writel(0, &clock_manager_base->sdr_pll_en);
+       writel(0, &clock_manager_base->sdr_pll.en);
 
        /* now we can gate off the rest of the peripheral clocks */
-       writel(0, &clock_manager_base->per_pll_en);
+       writel(0, &clock_manager_base->per_pll.en);
 
        /* Put all plls in bypass */
        cm_write_bypass(
@@ -142,11 +142,11 @@ void cm_basic_init(const cm_config_t *cfg)
         * Some code might have messed with them.
         */
        writel(CLKMGR_MAINPLLGRP_VCO_RESET_VALUE,
-              &clock_manager_base->main_pll_vco);
+              &clock_manager_base->main_pll.vco);
        writel(CLKMGR_PERPLLGRP_VCO_RESET_VALUE,
-              &clock_manager_base->per_pll_vco);
+              &clock_manager_base->per_pll.vco);
        writel(CLKMGR_SDRPLLGRP_VCO_RESET_VALUE,
-              &clock_manager_base->sdr_pll_vco);
+              &clock_manager_base->sdr_pll.vco);
 
        /*
         * The clocks to the flash devices and the L4_MAIN clocks can
@@ -156,14 +156,14 @@ void cm_basic_init(const cm_config_t *cfg)
         * after exiting safe mode but before ungating the clocks.
         */
        writel(CLKMGR_PERPLLGRP_SRC_RESET_VALUE,
-              &clock_manager_base->per_pll_src);
+              &clock_manager_base->per_pll.src);
        writel(CLKMGR_MAINPLLGRP_L4SRC_RESET_VALUE,
-              &clock_manager_base->main_pll_l4src);
+              &clock_manager_base->main_pll.l4src);
 
        /* read back for the required 5 us delay. */
-       readl(&clock_manager_base->main_pll_vco);
-       readl(&clock_manager_base->per_pll_vco);
-       readl(&clock_manager_base->sdr_pll_vco);
+       readl(&clock_manager_base->main_pll.vco);
+       readl(&clock_manager_base->per_pll.vco);
+       readl(&clock_manager_base->sdr_pll.vco);
 
 
        /*
@@ -172,17 +172,17 @@ void cm_basic_init(const cm_config_t *cfg)
         */
        writel(cfg->main_vco_base | CLEAR_BGP_EN_PWRDN |
                CLKMGR_MAINPLLGRP_VCO_REGEXTSEL_MASK,
-               &clock_manager_base->main_pll_vco);
+               &clock_manager_base->main_pll.vco);
 
        writel(cfg->peri_vco_base | CLEAR_BGP_EN_PWRDN |
                CLKMGR_PERPLLGRP_VCO_REGEXTSEL_MASK,
-               &clock_manager_base->per_pll_vco);
+               &clock_manager_base->per_pll.vco);
 
        writel(CLKMGR_SDRPLLGRP_VCO_OUTRESET_SET(0) |
                CLKMGR_SDRPLLGRP_VCO_OUTRESETALL_SET(0) |
                cfg->sdram_vco_base | CLEAR_BGP_EN_PWRDN |
                CLKMGR_SDRPLLGRP_VCO_REGEXTSEL_MASK,
-               &clock_manager_base->sdr_pll_vco);
+               &clock_manager_base->sdr_pll.vco);
 
        /*
         * Time starts here
@@ -194,38 +194,38 @@ void cm_basic_init(const cm_config_t *cfg)
        timeout = 7;
 
        /* main mpu */
-       writel(cfg->mpuclk, &clock_manager_base->main_pll_mpuclk);
+       writel(cfg->mpuclk, &clock_manager_base->main_pll.mpuclk);
 
        /* main main clock */
-       writel(cfg->mainclk, &clock_manager_base->main_pll_mainclk);
+       writel(cfg->mainclk, &clock_manager_base->main_pll.mainclk);
 
        /* main for dbg */
-       writel(cfg->dbgatclk, &clock_manager_base->main_pll_dbgatclk);
+       writel(cfg->dbgatclk, &clock_manager_base->main_pll.dbgatclk);
 
        /* main for cfgs2fuser0clk */
        writel(cfg->cfg2fuser0clk,
-              &clock_manager_base->main_pll_cfgs2fuser0clk);
+              &clock_manager_base->main_pll.cfgs2fuser0clk);
 
        /* Peri emac0 50 MHz default to RMII */
-       writel(cfg->emac0clk, &clock_manager_base->per_pll_emac0clk);
+       writel(cfg->emac0clk, &clock_manager_base->per_pll.emac0clk);
 
        /* Peri emac1 50 MHz default to RMII */
-       writel(cfg->emac1clk, &clock_manager_base->per_pll_emac1clk);
+       writel(cfg->emac1clk, &clock_manager_base->per_pll.emac1clk);
 
        /* Peri QSPI */
-       writel(cfg->mainqspiclk, &clock_manager_base->main_pll_mainqspiclk);
+       writel(cfg->mainqspiclk, &clock_manager_base->main_pll.mainqspiclk);
 
-       writel(cfg->perqspiclk, &clock_manager_base->per_pll_perqspiclk);
+       writel(cfg->perqspiclk, &clock_manager_base->per_pll.perqspiclk);
 
        /* Peri pernandsdmmcclk */
        writel(cfg->pernandsdmmcclk,
-              &clock_manager_base->per_pll_pernandsdmmcclk);
+              &clock_manager_base->per_pll.pernandsdmmcclk);
 
        /* Peri perbaseclk */
-       writel(cfg->perbaseclk, &clock_manager_base->per_pll_perbaseclk);
+       writel(cfg->perbaseclk, &clock_manager_base->per_pll.perbaseclk);
 
        /* Peri s2fuser1clk */
-       writel(cfg->s2fuser1clk, &clock_manager_base->per_pll_s2fuser1clk);
+       writel(cfg->s2fuser1clk, &clock_manager_base->per_pll.s2fuser1clk);
 
        /* 7 us must have elapsed before we can enable the VCO */
        while (get_timer(start) < timeout)
@@ -234,29 +234,29 @@ void cm_basic_init(const cm_config_t *cfg)
        /* Enable vco */
        /* main pll vco */
        writel(cfg->main_vco_base | VCO_EN_BASE,
-              &clock_manager_base->main_pll_vco);
+              &clock_manager_base->main_pll.vco);
 
        /* periferal pll */
        writel(cfg->peri_vco_base | VCO_EN_BASE,
-              &clock_manager_base->per_pll_vco);
+              &clock_manager_base->per_pll.vco);
 
        /* sdram pll vco */
        writel(CLKMGR_SDRPLLGRP_VCO_OUTRESET_SET(0) |
                CLKMGR_SDRPLLGRP_VCO_OUTRESETALL_SET(0) |
                cfg->sdram_vco_base | VCO_EN_BASE,
-               &clock_manager_base->sdr_pll_vco);
+               &clock_manager_base->sdr_pll.vco);
 
        /* L3 MP and L3 SP */
-       writel(cfg->maindiv, &clock_manager_base->main_pll_maindiv);
+       writel(cfg->maindiv, &clock_manager_base->main_pll.maindiv);
 
-       writel(cfg->dbgdiv, &clock_manager_base->main_pll_dbgdiv);
+       writel(cfg->dbgdiv, &clock_manager_base->main_pll.dbgdiv);
 
-       writel(cfg->tracediv, &clock_manager_base->main_pll_tracediv);
+       writel(cfg->tracediv, &clock_manager_base->main_pll.tracediv);
 
        /* L4 MP, L4 SP, can0, and can1 */
-       writel(cfg->perdiv, &clock_manager_base->per_pll_div);
+       writel(cfg->perdiv, &clock_manager_base->per_pll.div);
 
-       writel(cfg->gpiodiv, &clock_manager_base->per_pll_gpiodiv);
+       writel(cfg->gpiodiv, &clock_manager_base->per_pll.gpiodiv);
 
 #define LOCKED_MASK \
        (CLKMGR_INTER_SDRPLLLOCKED_MASK  | \
@@ -267,70 +267,70 @@ void cm_basic_init(const cm_config_t *cfg)
 
        /* write the sdram clock counters before toggling outreset all */
        writel(cfg->ddrdqsclk & CLKMGR_SDRPLLGRP_DDRDQSCLK_CNT_MASK,
-              &clock_manager_base->sdr_pll_ddrdqsclk);
+              &clock_manager_base->sdr_pll.ddrdqsclk);
 
        writel(cfg->ddr2xdqsclk & CLKMGR_SDRPLLGRP_DDR2XDQSCLK_CNT_MASK,
-              &clock_manager_base->sdr_pll_ddr2xdqsclk);
+              &clock_manager_base->sdr_pll.ddr2xdqsclk);
 
        writel(cfg->ddrdqclk & CLKMGR_SDRPLLGRP_DDRDQCLK_CNT_MASK,
-              &clock_manager_base->sdr_pll_ddrdqclk);
+              &clock_manager_base->sdr_pll.ddrdqclk);
 
        writel(cfg->s2fuser2clk & CLKMGR_SDRPLLGRP_S2FUSER2CLK_CNT_MASK,
-              &clock_manager_base->sdr_pll_s2fuser2clk);
+              &clock_manager_base->sdr_pll.s2fuser2clk);
 
        /*
         * after locking, but before taking out of bypass
         * assert/deassert outresetall
         */
-       uint32_t mainvco = readl(&clock_manager_base->main_pll_vco);
+       uint32_t mainvco = readl(&clock_manager_base->main_pll.vco);
 
        /* assert main outresetall */
        writel(mainvco | CLKMGR_MAINPLLGRP_VCO_OUTRESETALL_MASK,
-              &clock_manager_base->main_pll_vco);
+              &clock_manager_base->main_pll.vco);
 
-       uint32_t periphvco = readl(&clock_manager_base->per_pll_vco);
+       uint32_t periphvco = readl(&clock_manager_base->per_pll.vco);
 
        /* assert pheriph outresetall */
        writel(periphvco | CLKMGR_PERPLLGRP_VCO_OUTRESETALL_MASK,
-              &clock_manager_base->per_pll_vco);
+              &clock_manager_base->per_pll.vco);
 
        /* assert sdram outresetall */
        writel(cfg->sdram_vco_base | VCO_EN_BASE|
                CLKMGR_SDRPLLGRP_VCO_OUTRESETALL_SET(1),
-               &clock_manager_base->sdr_pll_vco);
+               &clock_manager_base->sdr_pll.vco);
 
        /* deassert main outresetall */
        writel(mainvco & ~CLKMGR_MAINPLLGRP_VCO_OUTRESETALL_MASK,
-              &clock_manager_base->main_pll_vco);
+              &clock_manager_base->main_pll.vco);
 
        /* deassert pheriph outresetall */
        writel(periphvco & ~CLKMGR_PERPLLGRP_VCO_OUTRESETALL_MASK,
-              &clock_manager_base->per_pll_vco);
+              &clock_manager_base->per_pll.vco);
 
        /* deassert sdram outresetall */
        writel(CLKMGR_SDRPLLGRP_VCO_OUTRESETALL_SET(0) |
                cfg->sdram_vco_base | VCO_EN_BASE,
-               &clock_manager_base->sdr_pll_vco);
+               &clock_manager_base->sdr_pll.vco);
 
        /*
         * now that we've toggled outreset all, all the clocks
         * are aligned nicely; so we can change any phase.
         */
        cm_write_with_phase(cfg->ddrdqsclk,
-                           (uint32_t)&clock_manager_base->sdr_pll_ddrdqsclk,
+                           (uint32_t)&clock_manager_base->sdr_pll.ddrdqsclk,
                            CLKMGR_SDRPLLGRP_DDRDQSCLK_PHASE_MASK);
 
        /* SDRAM DDR2XDQSCLK */
        cm_write_with_phase(cfg->ddr2xdqsclk,
-                           (uint32_t)&clock_manager_base->sdr_pll_ddr2xdqsclk,
+                           (uint32_t)&clock_manager_base->sdr_pll.ddr2xdqsclk,
                            CLKMGR_SDRPLLGRP_DDR2XDQSCLK_PHASE_MASK);
 
        cm_write_with_phase(cfg->ddrdqclk,
-                           (uint32_t)&clock_manager_base->sdr_pll_ddrdqclk,
+                           (uint32_t)&clock_manager_base->sdr_pll.ddrdqclk,
                            CLKMGR_SDRPLLGRP_DDRDQCLK_PHASE_MASK);
 
        cm_write_with_phase(cfg->s2fuser2clk,
-                           (uint32_t)&clock_manager_base->sdr_pll_s2fuser2clk,
+                           (uint32_t)&clock_manager_base->sdr_pll.s2fuser2clk,
                            CLKMGR_SDRPLLGRP_S2FUSER2CLK_PHASE_MASK);
 
        /* Take all three PLLs out of bypass when safe mode is cleared. */
@@ -351,11 +351,11 @@ void cm_basic_init(const cm_config_t *cfg)
         * now that safe mode is clear with clocks gated
         * it safe to change the source mux for the flashes the the L4_MAIN
         */
-       writel(cfg->persrc, &clock_manager_base->per_pll_src);
-       writel(cfg->l4src, &clock_manager_base->main_pll_l4src);
+       writel(cfg->persrc, &clock_manager_base->per_pll.src);
+       writel(cfg->l4src, &clock_manager_base->main_pll.l4src);
 
        /* Now ungate non-hw-managed clocks */
-       writel(~0, &clock_manager_base->main_pll_en);
-       writel(~0, &clock_manager_base->per_pll_en);
-       writel(~0, &clock_manager_base->sdr_pll_en);
+       writel(~0, &clock_manager_base->main_pll.en);
+       writel(~0, &clock_manager_base->per_pll.en);
+       writel(~0, &clock_manager_base->sdr_pll.en);
 }
index 966add3e913a67275b6fb40f37cc18fcc2036573..babac0e87823799d8db49622f9c3306a1fed69d2 100644 (file)
@@ -43,6 +43,52 @@ typedef struct {
 
 extern void cm_basic_init(const cm_config_t *cfg);
 
+struct socfpga_clock_manager_main_pll {
+       u32     vco;
+       u32     misc;
+       u32     mpuclk;
+       u32     mainclk;
+       u32     dbgatclk;
+       u32     mainqspiclk;
+       u32     mainnandsdmmcclk;
+       u32     cfgs2fuser0clk;
+       u32     en;
+       u32     maindiv;
+       u32     dbgdiv;
+       u32     tracediv;
+       u32     l4src;
+       u32     stat;
+       u32     _pad_0x38_0x40[2];
+};
+
+struct socfpga_clock_manager_per_pll {
+       u32     vco;
+       u32     misc;
+       u32     emac0clk;
+       u32     emac1clk;
+       u32     perqspiclk;
+       u32     pernandsdmmcclk;
+       u32     perbaseclk;
+       u32     s2fuser1clk;
+       u32     en;
+       u32     div;
+       u32     gpiodiv;
+       u32     src;
+       u32     stat;
+       u32     _pad_0x34_0x40[3];
+};
+
+struct socfpga_clock_manager_sdr_pll {
+       u32     vco;
+       u32     ctrl;
+       u32     ddrdqsclk;
+       u32     ddr2xdqsclk;
+       u32     ddrdqclk;
+       u32     s2fuser2clk;
+       u32     en;
+       u32     stat;
+};
+
 struct socfpga_clock_manager {
        u32     ctrl;
        u32     bypass;
@@ -51,50 +97,10 @@ struct socfpga_clock_manager {
        u32     dbctrl;
        u32     stat;
        u32     _pad_0x18_0x3f[10];
-       u32     mainpllgrp;
-       u32     perpllgrp;
-       u32     sdrpllgrp;
+       struct socfpga_clock_manager_main_pll main_pll;
+       struct socfpga_clock_manager_per_pll per_pll;
+       struct socfpga_clock_manager_sdr_pll sdr_pll;
        u32     _pad_0xe0_0x200[72];
-
-       u32     main_pll_vco;
-       u32     main_pll_misc;
-       u32     main_pll_mpuclk;
-       u32     main_pll_mainclk;
-       u32     main_pll_dbgatclk;
-       u32     main_pll_mainqspiclk;
-       u32     main_pll_mainnandsdmmcclk;
-       u32     main_pll_cfgs2fuser0clk;
-       u32     main_pll_en;
-       u32     main_pll_maindiv;
-       u32     main_pll_dbgdiv;
-       u32     main_pll_tracediv;
-       u32     main_pll_l4src;
-       u32     main_pll_stat;
-       u32     main_pll__pad_0x38_0x40[2];
-
-       u32     per_pll_vco;
-       u32     per_pll_misc;
-       u32     per_pll_emac0clk;
-       u32     per_pll_emac1clk;
-       u32     per_pll_perqspiclk;
-       u32     per_pll_pernandsdmmcclk;
-       u32     per_pll_perbaseclk;
-       u32     per_pll_s2fuser1clk;
-       u32     per_pll_en;
-       u32     per_pll_div;
-       u32     per_pll_gpiodiv;
-       u32     per_pll_src;
-       u32     per_pll_stat;
-       u32     per_pll__pad_0x34_0x40[3];
-
-       u32     sdr_pll_vco;
-       u32     sdr_pll_ctrl;
-       u32     sdr_pll_ddrdqsclk;
-       u32     sdr_pll_ddr2xdqsclk;
-       u32     sdr_pll_ddrdqclk;
-       u32     sdr_pll_s2fuser2clk;
-       u32     sdr_pll_en;
-       u32     sdr_pll_stat;
 };
 
 #define CLKMGR_MAINPLLGRP_EN_S2FUSER0CLK_MASK 0x00000200
index bc53a5da272582429a833e79653f2a7632458da7..417ca4c2ae6bde1800e8e8008f652e9ef1b5161c 100644 (file)
@@ -24,7 +24,7 @@ static void socfpga_dwmci_clksel(struct dwmci_host *host)
        unsigned int smplsel;
 
        /* Disable SDMMC clock. */
-       clrbits_le32(&clock_manager_base->per_pll_en,
+       clrbits_le32(&clock_manager_base->per_pll.en,
                CLKMGR_PERPLLGRP_EN_SDMMCCLK_MASK);
 
        /* Configures drv_sel and smpl_sel */
@@ -39,7 +39,7 @@ static void socfpga_dwmci_clksel(struct dwmci_host *host)
                readl(&system_manager_base->sdmmcgrp_ctrl));
 
        /* Enable SDMMC clock */
-       setbits_le32(&clock_manager_base->per_pll_en,
+       setbits_le32(&clock_manager_base->per_pll.en,
                CLKMGR_PERPLLGRP_EN_SDMMCCLK_MASK);
 }