• Mike Turquette's avatar
    OMAP3630: Clock: Workaround for DPLL HS divider limitation · a7e069fc
    Mike Turquette authored
    This patch implements a workaround for the DPLL HS divider limitation
    in OMAP3630 as given by Errata ID: i556.
    
    Errata:
    When PWRDN bit is set, it resets the internal HSDIVIDER divide-by value (Mx).
    The reset value gets loaded instead of the previous value.
    The following HSDIVIDERs exhibit above behavior:
    . DPLL4 : M6 / M5 / M4 / M3 / M2 (CM_CLKEN_PLL[31:26] register bits)
    . DPLL3 : M3 (CM_CLKEN_PLL[12] register bit).
    
    Work Around:
    It is mandatory to apply the following sequence to ensure the write
    value will
    be loaded in DPLL HSDIVIDER FSM:
    The global sequence when using PWRDN bit is the following:
    . Disable Mx HSDIVIDER clock output related functional clock enable bits
            (in CM_FCLKEN_xxx / CM_ICLKEN_xxx)
    . Enable PWRDN bit of HSDIVIDER
    . Disable PWRDN bit of HSDIVIDER
    . Read current HSDIVIDER register value
    . Write different value in HSDIVIDER register
    . Write expected value in HSDIVIDER register
    . Enable Mx HSDIVIDER clock output related functional clocks
            (CM_FCLKEN_xxx / CM_ICLKEN_xxx)
    Signed-off-by: default avatarMike Turquette <mturquette@ti.com>
    Signed-off-by: default avatarVishwanath BS <vishwanath.bs@ti.com>
    Signed-off-by: default avatarVijaykumar GN <vijaykumar.gn@ti.com>
    [paul@pwsan.com: updated patch to apply; made workaround function static;
     marked as being 36xx-specific]
    Signed-off-by: default avatarPaul Walmsley <paul@pwsan.com>
    a7e069fc
clock34xx_data.c 100 KB