diff options
author | ed <ed@FreeBSD.org> | 2010-10-21 19:02:02 +0000 |
---|---|---|
committer | ed <ed@FreeBSD.org> | 2010-10-21 19:02:02 +0000 |
commit | 653bb6745595746d04ad4acacaaab66caaaeb69b (patch) | |
tree | 4cfe2eee875a959effca0881df14c079103447fa /lib/clear_cache.c | |
download | FreeBSD-src-653bb6745595746d04ad4acacaaab66caaaeb69b.zip FreeBSD-src-653bb6745595746d04ad4acacaaab66caaaeb69b.tar.gz |
Import compiler-rt r117047.
Diffstat (limited to 'lib/clear_cache.c')
-rw-r--r-- | lib/clear_cache.c | 40 |
1 files changed, 40 insertions, 0 deletions
diff --git a/lib/clear_cache.c b/lib/clear_cache.c new file mode 100644 index 0000000..ddc48bc --- /dev/null +++ b/lib/clear_cache.c @@ -0,0 +1,40 @@ +/* ===-- clear_cache.c - Implement __clear_cache ---------------------------=== + * + * The LLVM Compiler Infrastructure + * + * This file is distributed under the University of Illinois Open Source + * License. See LICENSE.TXT for details. + * + * ===----------------------------------------------------------------------=== + */ + +#include <stdlib.h> + +#if __APPLE__ + #include <libkern/OSCacheControl.h> +#endif + +/* + * The compiler generates calls to __clear_cache() when creating + * trampoline functions on the stack for use with nested functions. + * It is expected to invalidate the instruction cache for the + * specified range. + */ + +void __clear_cache(void* start, void* end) +{ +#if __i386__ || __x86_64__ +/* + * Intel processors have a unified instruction and data cache + * so there is nothing to do + */ +#else + #if __APPLE__ + /* On Darwin, sys_icache_invalidate() provides this functionality */ + sys_icache_invalidate(start, end-start); + #else + compilerrt_abort(); + #endif +#endif +} + |