From 0a7691e820e33b23f61c6ea0ef6fa72099d1a6ae Mon Sep 17 00:00:00 2001
From: Renato Andreola <renato.andreola@imagos.it>
Date: Mon, 23 Nov 2009 16:45:14 -0500
Subject: [PATCH] Nios2: do_boom_linux(): kernel gunzip input data integrity
 problem due to 	missing cache flush.

    Added instruction and data caches flush.

Signed-off-by: Scott McNutt <smcnutt@psyent.com>
---
 lib_nios2/bootm.c | 5 +++++
 1 file changed, 5 insertions(+)

diff --git a/lib_nios2/bootm.c b/lib_nios2/bootm.c
index 53fd5691ad..675bfac63a 100644
--- a/lib_nios2/bootm.c
+++ b/lib_nios2/bootm.c
@@ -24,6 +24,7 @@
 #include <common.h>
 #include <command.h>
 #include <asm/byteorder.h>
+#include <asm/cache.h>
 
 int do_bootm_linux(int flag, int argc, char *argv[], bootm_headers_t *images)
 {
@@ -32,6 +33,10 @@ int do_bootm_linux(int flag, int argc, char *argv[], bootm_headers_t *images)
 	if ((flag != 0) && (flag != BOOTM_STATE_OS_GO))
 		return 1;
 
+	/* flushes data and instruction caches before calling the kernel */
+	flush_dcache (0,CONFIG_SYS_DCACHE_SIZE);
+	flush_icache (0,CONFIG_SYS_ICACHE_SIZE);
+
 	/* For now we assume the Microtronix linux ... which only
 	 * needs to be called ;-)
 	 */
-- 
2.39.5