forked from OSchip/llvm-project
[mips] Use __clear_cache builtin instead of cacheflush() in Unix Memory::InvalidateInstructionCache()
MIPS64 Android bionic has removed cacheflush(). Use __clear_cache() instead for 32-bit and 64-bit MIPS Patch by Duane Sand <Duane.Sand@imgtec.com> llvm-svn: 211588
This commit is contained in:
parent
4dc8a78b04
commit
cf635fad02
|
@ -333,23 +333,15 @@ void Memory::InvalidateInstructionCache(const void *Addr,
|
||||||
for (intptr_t Line = StartLine; Line < EndLine; Line += LineSize)
|
for (intptr_t Line = StartLine; Line < EndLine; Line += LineSize)
|
||||||
asm volatile("icbi 0, %0" : : "r"(Line));
|
asm volatile("icbi 0, %0" : : "r"(Line));
|
||||||
asm volatile("isync");
|
asm volatile("isync");
|
||||||
# elif (defined(__arm__) || defined(__aarch64__)) && defined(__GNUC__)
|
# elif (defined(__arm__) || defined(__aarch64__) || defined(__mips__)) && defined(__GNUC__)
|
||||||
// FIXME: Can we safely always call this for __GNUC__ everywhere?
|
// FIXME: Can we safely always call this for __GNUC__ everywhere?
|
||||||
|
// Use compiler's builtin
|
||||||
const char *Start = static_cast<const char *>(Addr);
|
const char *Start = static_cast<const char *>(Addr);
|
||||||
const char *End = Start + Len;
|
const char *End = Start + Len;
|
||||||
__clear_cache(const_cast<char *>(Start), const_cast<char *>(End));
|
__clear_cache(const_cast<char *>(Start), const_cast<char *>(End));
|
||||||
# elif defined(__mips__)
|
# elif defined(__mips__)
|
||||||
const char *Start = static_cast<const char *>(Addr);
|
const char *Start = static_cast<const char *>(Addr);
|
||||||
# if defined(ANDROID)
|
|
||||||
// The declaration of "cacheflush" in Android bionic:
|
|
||||||
// extern int cacheflush(long start, long end, long flags);
|
|
||||||
const char *End = Start + Len;
|
|
||||||
long LStart = reinterpret_cast<long>(const_cast<char *>(Start));
|
|
||||||
long LEnd = reinterpret_cast<long>(const_cast<char *>(End));
|
|
||||||
cacheflush(LStart, LEnd, BCACHE);
|
|
||||||
# else
|
|
||||||
cacheflush(const_cast<char *>(Start), Len, BCACHE);
|
cacheflush(const_cast<char *>(Start), Len, BCACHE);
|
||||||
# endif
|
|
||||||
# endif
|
# endif
|
||||||
|
|
||||||
#endif // end apple
|
#endif // end apple
|
||||||
|
|
Loading…
Reference in New Issue