blob: 8176c24e65997e3501450a59b7912275f8d75652 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
|
//===-- 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
abort();
#endif
#endif
}
|