forked from Imagelibrary/rtems
D-cache clean&&invalidate for Tiny6410
This commit is contained in:
committed by
Sebastian Huber
parent
ef8e851975
commit
76de8a8e6b
@@ -609,6 +609,27 @@ static inline void arm_cp15_data_cache_test_and_clean(void)
|
|||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* In DDI0301H_arm1176jzfs_r0p7_trm
|
||||||
|
* 'MCR p15, 0, <Rd>, c7, c14, 0' means
|
||||||
|
* Clean and Invalidate Entire Data Cache
|
||||||
|
*/
|
||||||
|
static inline void arm_cp15_data_cache_clean_and_invalidate(void)
|
||||||
|
{
|
||||||
|
ARM_SWITCH_REGISTERS;
|
||||||
|
|
||||||
|
uint32_t sbz = 0;
|
||||||
|
|
||||||
|
__asm__ volatile (
|
||||||
|
ARM_SWITCH_TO_ARM
|
||||||
|
"mcr p15, 0, %[sbz], c7, c14, 0\n"
|
||||||
|
ARM_SWITCH_BACK
|
||||||
|
: ARM_SWITCH_OUTPUT
|
||||||
|
: [sbz] "r" (sbz)
|
||||||
|
: "memory"
|
||||||
|
);
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
static inline void arm_cp15_data_cache_clean_and_invalidate_line(const void *mva)
|
static inline void arm_cp15_data_cache_clean_and_invalidate_line(const void *mva)
|
||||||
{
|
{
|
||||||
ARM_SWITCH_REGISTERS;
|
ARM_SWITCH_REGISTERS;
|
||||||
|
|||||||
Reference in New Issue
Block a user