Nios2: do_boom_linux(): kernel gunzip input data integrity problem due to
authorRenato Andreola <renato.andreola@imagos.it>
Mon, 23 Nov 2009 21:45:14 +0000 (16:45 -0500)
committerScott McNutt <smcnutt@psyent.com>
Mon, 23 Nov 2009 21:45:14 +0000 (16:45 -0500)
missing cache flush.

    Added instruction and data caches flush.

Signed-off-by: Scott McNutt <smcnutt@psyent.com>
lib_nios2/bootm.c

index 53fd5691ad7dd9c288d0b252fa061db0f99edd6b..675bfac63a59d5475d160d887fa45b2dbb8618f8 100644 (file)
@@ -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 ;-)
         */