Cómo borrar e invalidar la caché del procesador ARM v7 desde el modo de usuario en Linux 2.6.35
ntenté borrar e invalidar el caché del procesador ARM v7 para la línea de instrucciones, porque los códigos de instrucciones pueden cambiar en la ejecución.
Para alcanzar el efecto, probé 2 variantes. Aquí están
Usé GCC__limpiar cache( pero no dio el resultado requerido. Los códigos de instrucciones en el caché no cambiaron.
Busqué un código fuente para GCC y encontré el uclinux-eabi.h archivo donde encontré el siguiente código para borrar el caché:
/* Clear the instruction cache from `beg' to `end'. This makes an
inline system call to SYS_cacheflush. */
#undef CLEAR_INSN_CACHE
#define CLEAR_INSN_CACHE(BEG, END) \
{ \
register unsigned long _beg __asm ("a1") = (unsigned long) (BEG); \
register unsigned long _end __asm ("a2") = (unsigned long) (END); \
register unsigned long _flg __asm ("a3") = 0; \
register unsigned long _scno __asm ("r7") = 0xf0002; \
__asm __volatile \
( \
"swi 0x0 @ sys_cacheflush" \
: "=r" (_beg) \
: "0" (_beg), "r" (_end), "r" (_flg), "r" (_scno)); \
}
Esta variante tampoco dio el resultado.
Quizás alguien sabe lo que hago ma