SAMA5D4: Bootloader needs to flush D-Cache to memory before disabling the caches
This commit is contained in:
parent
8c0fb3f9e7
commit
c509cd55b2
@ -103,6 +103,10 @@ int dram_main(int argc, char *argv)
|
|||||||
|
|
||||||
/* DRAM was already initialized at boot time, so we are ready to load the
|
/* DRAM was already initialized at boot time, so we are ready to load the
|
||||||
* Intel HEX stream into DRAM.
|
* Intel HEX stream into DRAM.
|
||||||
|
*
|
||||||
|
* Hmm.. With no hardware handshake, there is a possibility of data loss
|
||||||
|
* to overruning incoming data buffer. So far I have not seen this at
|
||||||
|
* 115200 8N1, but still it is a possibility.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
printf("Send Intel HEX file now\n");
|
printf("Send Intel HEX file now\n");
|
||||||
@ -121,11 +125,18 @@ int dram_main(int argc, char *argv)
|
|||||||
for(;;);
|
for(;;);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* No success indication.. The following cache/MMu operations will clobber
|
/* No success indication.. The following cache/MMU operations will clobber
|
||||||
* any I/O that we attempt (Hmm.. unless, perhaps, if we delayed. But who
|
* any I/O that we attempt (Hmm.. unless, perhaps, if we delayed. But who
|
||||||
* wants a delay?).
|
* wants a delay?).
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
/* Flush the entire data cache assure that everything is in memory before
|
||||||
|
* we disable caching.
|
||||||
|
*/
|
||||||
|
|
||||||
|
cp15_clean_dcache((uintptr_t)SAM_DDRCS_VSECTION,
|
||||||
|
(uintptr_t)(SAM_DDRCS_VSECTION + CONFIG_SAMA5_DDRCS_SIZE));
|
||||||
|
|
||||||
/* Interrupts must be disabled through the following. In this configuration,
|
/* Interrupts must be disabled through the following. In this configuration,
|
||||||
* there should only be timer interrupts. Your NuttX configuration must use
|
* there should only be timer interrupts. Your NuttX configuration must use
|
||||||
* CONFIG_SERIAL_LOWCONSOLE=y or printf() will hang when the interrupts
|
* CONFIG_SERIAL_LOWCONSOLE=y or printf() will hang when the interrupts
|
||||||
|
Loading…
Reference in New Issue
Block a user