]> git.dujemihanovic.xyz Git - u-boot.git/commitdiff
powerpc/85xx: Fix synchronization of timebase on MP boot
authorKumar Gala <galak@kernel.crashing.org>
Sun, 13 Mar 2011 15:55:53 +0000 (10:55 -0500)
committerKumar Gala <galak@kernel.crashing.org>
Tue, 15 Mar 2011 06:25:51 +0000 (01:25 -0500)
There is a small ordering issue in the master core in that we need to
make sure the disabling of the timebase in the SoC is visible before we
set the value to 0.  We can simply just read back the value to
synchronizatize the write, before we set TB to 0.

Reported-by: Dan Hettena
Tested-by: Dan Hettena
Signed-off-by: Kumar Gala <galak@kernel.crashing.org>
arch/powerpc/cpu/mpc85xx/mp.c

index 6c0da83176e8683516945a1cdf9e61b3c513a03f..758e6d7045f8ffe1da4f6b4ce2eb6027975689ce 100644 (file)
@@ -276,8 +276,13 @@ static void plat_mp_up(unsigned long bootpg)
 
        /* enable time base at the platform */
        out_be32(&rcpm->ctbenrl, 0);
+
+       /* readback to sync write */
+       in_be32(&rcpm->ctbenrl);
+
        mtspr(SPRN_TBWU, 0);
        mtspr(SPRN_TBWL, 0);
+
        out_be32(&rcpm->ctbenrl, (1 << nr_cpus) - 1);
 
 #ifdef CONFIG_MPC8xxx_DISABLE_BPTR
@@ -347,6 +352,10 @@ static void plat_mp_up(unsigned long bootpg)
        else
                devdisr |= MPC85xx_DEVDISR_TB0;
        out_be32(&gur->devdisr, devdisr);
+
+       /* readback to sync write */
+       in_be32(&gur->devdisr);
+
        mtspr(SPRN_TBWU, 0);
        mtspr(SPRN_TBWL, 0);