提交 3921ee21 编写于 作者: R Roman Zippel 提交者: Linus Torvalds

[PATCH] m68k: small flush_icache() cleanup

Make flush_icache() an inline function and clean it up a litte.
Signed-off-by: NRoman Zippel <zippel@linux-m68k.org>
Signed-off-by: NAndrew Morton <akpm@osdl.org>
Signed-off-by: NLinus Torvalds <torvalds@osdl.org>
上级 a7b1a1a3
...@@ -3,26 +3,30 @@ ...@@ -3,26 +3,30 @@
#include <linux/mm.h> #include <linux/mm.h>
/* cache code */
#define FLUSH_I_AND_D (0x00000808)
#define FLUSH_I (0x00000008)
/* /*
* Cache handling functions * Cache handling functions
*/ */
#define flush_icache() \ static inline void flush_icache(void)
({ \ {
if (CPU_IS_040_OR_060) \ if (CPU_IS_040_OR_060)
__asm__ __volatile__("nop\n\t" \ asm volatile ( "nop\n"
".chip 68040\n\t" \ " .chip 68040\n"
"cinva %%ic\n\t" \ " cpusha %bc\n"
".chip 68k" : ); \ " .chip 68k");
else { \ else {
unsigned long _tmp; \ unsigned long tmp;
__asm__ __volatile__("movec %%cacr,%0\n\t" \ asm volatile ( "movec %%cacr,%0\n"
"orw %1,%0\n\t" \ " or.w %1,%0\n"
"movec %0,%%cacr" \ " movec %0,%%cacr"
: "=&d" (_tmp) \ : "=&d" (tmp)
: "id" (FLUSH_I)); \ : "id" (FLUSH_I));
} \ }
}) }
/* /*
* invalidate the cache for the specified memory range. * invalidate the cache for the specified memory range.
...@@ -43,10 +47,6 @@ extern void cache_push(unsigned long paddr, int len); ...@@ -43,10 +47,6 @@ extern void cache_push(unsigned long paddr, int len);
*/ */
extern void cache_push_v(unsigned long vaddr, int len); extern void cache_push_v(unsigned long vaddr, int len);
/* cache code */
#define FLUSH_I_AND_D (0x00000808)
#define FLUSH_I (0x00000008)
/* This is needed whenever the virtual mapping of the current /* This is needed whenever the virtual mapping of the current
process changes. */ process changes. */
#define __flush_cache_all() \ #define __flush_cache_all() \
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册