]> git.dujemihanovic.xyz Git - u-boot.git/commitdiff
x86: Change testing logic of mtrr commit
authorBin Meng <bmeng.cn@gmail.com>
Mon, 31 Jul 2023 13:56:02 +0000 (07:56 -0600)
committerBin Meng <bmeng.cn@gmail.com>
Tue, 1 Aug 2023 02:06:46 +0000 (10:06 +0800)
On Coral U-Boot SPL programs some MTRRs and FSPv2 in U-Boot proper
needs to program MTRRs too. With current testing logic of mtrr
commit in init_cache_f_r(), the mtrr commit is skipped which won't
work as the queued mtrr requests include setup for DRAM regions.

Change the logic to allow such configuration.

Signed-off-by: Bin Meng <bmeng.cn@gmail.com>
Tweak to put back CONFIG_FSP_VERSION2 at top:
Signed-off-by: Simon Glass <sjg@chromium.org>
arch/x86/lib/init_helpers.c

index f33194045f9eb015f1e3238935c90dc19a30e143..60a2707dcf1b0b730a86ac797a7a7f48c8a650c5 100644 (file)
@@ -21,8 +21,7 @@ int init_cache_f_r(void)
        /*
         * Supported configurations:
         *
-        * booting from slimbootloader - in that case the MTRRs are already set
-        *      up
+        * booting from slimbootloader - MTRRs are already set up
         * booting with FSPv1 - MTRRs are already set up
         * booting with FSPv2 - MTRRs must be set here
         * booting from coreboot - in this case there is no SPL, so we set up
@@ -30,8 +29,7 @@ int init_cache_f_r(void)
         * Note: if there is an SPL, then it has already set up MTRRs so we
         *      don't need to do that here
         */
-       do_mtrr &= !IS_ENABLED(CONFIG_SPL) &&
-               !IS_ENABLED(CONFIG_FSP_VERSION1) &&
+       do_mtrr &= !IS_ENABLED(CONFIG_FSP_VERSION1) &&
                !IS_ENABLED(CONFIG_SYS_SLIMBOOTLOADER);
 
        if (do_mtrr) {