{
        struct lgm_clk_divider *div = to_lgm_clk_divider(hw);
 
-       lgm_set_clk_val(div->membase, div->reg, div->shift_gate,
-                       div->width_gate, enable);
+       if (div->flags != DIV_CLK_NO_MASK)
+               lgm_set_clk_val(div->membase, div->reg, div->shift_gate,
+                               div->width_gate, enable);
        return 0;
 }
 
 
 #define CLOCK_FLAG_VAL_INIT    BIT(16)
 #define MUX_CLK_SW             BIT(17)
 #define GATE_CLK_HW            BIT(18)
+#define DIV_CLK_NO_MASK                BIT(19)
 
 #define LGM_MUX(_id, _name, _pdata, _f, _reg,          \
                _shift, _width, _cf, _v)                \
 
        LGM_FIXED(LGM_CLK_SLIC, "slic", NULL, 0, CGU_IF_CLK1,
                  8, 2, CLOCK_FLAG_VAL_INIT, 8192000, 2),
        LGM_FIXED(LGM_CLK_DOCSIS, "v_docsis", NULL, 0, 0, 0, 0, 0, 16000000, 0),
-       LGM_DIV(LGM_CLK_DCL, "dcl", "v_ifclk", 0, CGU_PCMCR,
-               25, 3, 0, 0, 0, 0, dcl_div),
+       LGM_DIV(LGM_CLK_DCL, "dcl", "v_ifclk", CLK_SET_RATE_PARENT, CGU_PCMCR,
+               25, 3, 0, 0, DIV_CLK_NO_MASK, 0, dcl_div),
        LGM_MUX(LGM_CLK_PCM, "pcm", pcm_p, 0, CGU_C55_PCMCR,
                0, 1, CLK_MUX_ROUND_CLOSEST, 0),
        LGM_FIXED_FACTOR(LGM_CLK_DDR_PHY, "ddr_phy", "ddr",