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