Как очистить и аннулировать кэш процессора ARM v7 из режима пользователя в Linux 2.6.35
Я попытался очистить и аннулировать кэш процессора ARM v7 для строки команд, потому что коды команд могут измениться при выполнении.
Для достижения эффекта я попробовал 2 варианта. Вот они:
Я использовал функцию GCC __clear_cache (), но она не дала требуемого результата. Коды инструкций в кеше не изменились.
Я искал исходные коды для GCC и нашел файл uclinux-eabi.h, где я нашел следующий код для очистки кэша:
/* 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)); \ }
Этот вариант тоже не дал результата.
Может кто знает, что я делаю не так?
1 ответ
У меня была похожая проблема. __clear_cache() работает, но только если рассматриваемая область памяти была выделена с помощью mmap() с установленным PROT_EXEC. Linux не будет сбрасывать кэш инструкций, если вы предоставите ему диапазон памяти, который поступает из обычной памяти malloc(), даже если процессор, кажется, рад выполнить код из памяти malloc().
См. https://community.arm.com/groups/processors/blog/2010/02/17/caches-and-self-modifying-code пример кода, как это сделать.