[U-Boot] [PATCH] mx6: invalidate D-cache only when booting from USB

Vincent Stehlé vincent.stehle at freescale.com
Fri May 22 16:52:57 CEST 2015


Add a detection at runtime of the boot from USB on i.MX6, and invalidate
the D-cache only in that case.

The USB boot detection method is taken from Freescale u-boot commit
1309b1ed78b3 ("ENGR00315499-8 Auto check if boot from usb").

This repairs u-boot when it is built with CONFIG_SKIP_LOWLEVEL_INIT
defined, and is booted from another u-boot, which booted from SD card,
for example.

Signed-off-by: Vincent Stehlé <vincent.stehle at freescale.com>
Cc: Stefano Babic <sbabic at denx.de>
Cc: Fabio Estevam <fabio.estevam at freescale.com>
Cc: Frank Li <Frank.li at freescale.com>
Cc: Nitin Garg <nitin.garg at freescale.com>
---
 arch/arm/cpu/armv7/mx6/soc.c | 15 ++++++++++++++-
 1 file changed, 14 insertions(+), 1 deletion(-)

diff --git a/arch/arm/cpu/armv7/mx6/soc.c b/arch/arm/cpu/armv7/mx6/soc.c
index 21ef9d0..774f078 100644
--- a/arch/arm/cpu/armv7/mx6/soc.c
+++ b/arch/arm/cpu/armv7/mx6/soc.c
@@ -350,6 +350,18 @@ int board_postclk_init(void)
 	return 0;
 }
 
+/*
+ * Determine if we booted from USB.
+ *
+ * We look at the USBPH0_PWD0.RXPWDRX register to determine if the USB
+ * PHY is powered on or off. If the USB PHY is turned on, we assume that
+ * the ROM booted us from USB.
+ */
+static bool is_boot_from_usb(void)
+{
+	return !(readl(USB_PHY0_BASE_ADDR) & (1<<20));
+}
+
 #ifndef CONFIG_SYS_DCACHE_OFF
 void enable_caches(void)
 {
@@ -360,7 +372,8 @@ void enable_caches(void)
 #endif
 
 	/* Avoid random hang when download by usb */
-	invalidate_dcache_all();
+	if (is_boot_from_usb())
+		invalidate_dcache_all();
 
 	/* Enable D-cache. I-cache is already enabled in start.S */
 	dcache_enable();
-- 
2.1.4



More information about the U-Boot mailing list