You've already forked linux-packaging-mono
acceptance-tests
data
docs
external
Newtonsoft.Json
api-doc-tools
api-snapshot
aspnetwebstack
bdwgc
binary-reference-assemblies
bockbuild
boringssl
cecil
cecil-legacy
corefx
corert
helix-binaries
ikdasm
ikvm
illinker-test-assets
linker
llvm-project
clang
clang-tools-extra
compiler-rt
cmake
docs
include
lib
test
BlocksRuntime
asan
builtins
TestCases
Unit
arm
ppc
absvdi2_test.c
absvsi2_test.c
absvti2_test.c
adddf3vfp_test.c
addsf3vfp_test.c
addtf3_test.c
addvdi3_test.c
addvsi3_test.c
addvti3_test.c
ashldi3_test.c
ashlti3_test.c
ashrdi3_test.c
ashrti3_test.c
bswapdi2_test.c
bswapsi2_test.c
clear_cache_test.c
clzdi2_test.c
clzsi2_test.c
clzti2_test.c
cmpdi2_test.c
cmpti2_test.c
comparedf2_test.c
comparesf2_test.c
cpu_model_test.c
ctzdi2_test.c
ctzsi2_test.c
ctzti2_test.c
divdc3_test.c
divdf3vfp_test.c
divdi3_test.c
divmodsi4_test.c
divsc3_test.c
divsf3vfp_test.c
divsi3_test.c
divtc3_test.c
divtf3_test.c
divti3_test.c
divxc3_test.c
enable_execute_stack_test.c
endianness.h
eqdf2vfp_test.c
eqsf2vfp_test.c
eqtf2_test.c
extebdsfdf2vfp_test.c
extenddftf2_test.c
extendhfsf2_test.c
extendsftf2_test.c
ffsdi2_test.c
ffssi2_test.c
ffsti2_test.c
fixdfdi_test.c
fixdfsivfp_test.c
fixdfti_test.c
fixsfdi_test.c
fixsfsivfp_test.c
fixsfti_test.c
fixtfdi_test.c
fixtfsi_test.c
fixtfti_test.c
fixunsdfdi_test.c
fixunsdfsi_test.c
fixunsdfsivfp_test.c
fixunsdfti_test.c
fixunssfdi_test.c
fixunssfsi_test.c
fixunssfsivfp_test.c
fixunssfti_test.c
fixunstfdi_test.c
fixunstfsi_test.c
fixunstfti_test.c
fixunsxfdi_test.c
fixunsxfsi_test.c
fixunsxfti_test.c
fixxfdi_test.c
fixxfti_test.c
floatdidf_test.c
floatdisf_test.c
floatditf_test.c
floatdixf_test.c
floatsidfvfp_test.c
floatsisfvfp_test.c
floatsitf_test.c
floattidf_test.c
floattisf_test.c
floattitf_test.c
floattixf_test.c
floatundidf_test.c
floatundisf_test.c
floatunditf_test.c
floatundixf_test.c
floatunsitf_test.c
floatunssidfvfp_test.c
floatunssisfvfp_test.c
floatuntidf_test.c
floatuntisf_test.c
floatuntitf_test.c
floatuntixf_test.c
fp_test.h
gcc_personality_test.c
gcc_personality_test_helper.cxx
gedf2vfp_test.c
gesf2vfp_test.c
getf2_test.c
gtdf2vfp_test.c
gtsf2vfp_test.c
gttf2_test.c
ledf2vfp_test.c
lesf2vfp_test.c
letf2_test.c
lit.cfg
lit.site.cfg.in
lshrdi3_test.c
lshrti3_test.c
ltdf2vfp_test.c
ltsf2vfp_test.c
lttf2_test.c
moddi3_test.c
modsi3_test.c
modti3_test.c
muldc3_test.c
muldf3vfp_test.c
muldi3_test.c
mulodi4_test.c
mulosi4_test.c
muloti4_test.c
mulsc3_test.c
mulsf3vfp_test.c
multc3_test.c
multf3_test.c
multi3_test.c
mulvdi3_test.c
mulvsi3_test.c
mulvti3_test.c
mulxc3_test.c
nedf2vfp_test.c
negdf2vfp_test.c
negdi2_test.c
negsf2vfp_test.c
negti2_test.c
negvdi2_test.c
negvsi2_test.c
negvti2_test.c
nesf2vfp_test.c
netf2_test.c
paritydi2_test.c
paritysi2_test.c
parityti2_test.c
popcountdi2_test.c
popcountsi2_test.c
popcountti2_test.c
powidf2_test.c
powisf2_test.c
powitf2_test.c
powixf2_test.c
subdf3vfp_test.c
subsf3vfp_test.c
subtf3_test.c
subvdi3_test.c
subvsi3_test.c
subvti3_test.c
test
trampoline_setup_test.c
truncdfhf2_test.c
truncdfsf2_test.c
truncdfsf2vfp_test.c
truncsfhf2_test.c
trunctfdf2_test.c
trunctfsf2_test.c
ucmpdi2_test.c
ucmpti2_test.c
udivdi3_test.c
udivmoddi4_test.c.REMOVED.git-id
udivmodsi4_test.c
udivmodti4_test.c.REMOVED.git-id
udivsi3_test.c
udivti3_test.c
umoddi3_test.c
umodsi3_test.c
umodti3_test.c
unorddf2vfp_test.c
unordsf2vfp_test.c
unordtf2_test.c
timing
CMakeLists.txt
lit.cfg
lit.site.cfg.in
cfi
dfsan
esan
fuzzer
hwasan
interception
lsan
msan
profile
safestack
sanitizer_common
scudo
tsan
ubsan
ubsan_minimal
xray
CMakeLists.txt
lit.common.cfg
lit.common.configured.in
unittests
www
.arcconfig
.gitignore
CMakeLists.txt
CODE_OWNERS.TXT
CREDITS.TXT
LICENSE.TXT
README.txt
eng
libcxx
libcxxabi
libunwind
lld
lldb
llvm
nuget
openmp
polly
Directory.Build.props
Directory.Build.targets
NuGet.config
azure-pipelines.yml
build.cmd
build.sh
dir.common.props
global.json
llvm.proj
mxe-Win64.cmake.in
nuget-buildtasks
nunit-lite
roslyn-binaries
rx
xunit-binaries
how-to-bump-roslyn-binaries.md
ikvm-native
llvm
m4
man
mcs
mono
msvc
netcore
po
runtime
samples
scripts
support
tools
COPYING.LIB
LICENSE
Makefile.am
Makefile.in
NEWS
README.md
acinclude.m4
aclocal.m4
autogen.sh
code_of_conduct.md
compile
config.guess
config.h.in
config.rpath
config.sub
configure.REMOVED.git-id
configure.ac.REMOVED.git-id
depcomp
install-sh
ltmain.sh.REMOVED.git-id
missing
mkinstalldirs
mono-uninstalled.pc.in
test-driver
winconfig.h
88 lines
2.6 KiB
C
88 lines
2.6 KiB
C
![]() |
// REQUIRES: native-run
|
||
|
// UNSUPPORTED: arm, aarch64
|
||
|
// RUN: %clang_builtins %s %librt -o %t && %run %t
|
||
|
//===-- clear_cache_test.c - Test clear_cache -----------------------------===//
|
||
|
//
|
||
|
// The LLVM Compiler Infrastructure
|
||
|
//
|
||
|
// This file is dual licensed under the MIT and the University of Illinois Open
|
||
|
// Source Licenses. See LICENSE.TXT for details.
|
||
|
//
|
||
|
//===----------------------------------------------------------------------===//
|
||
|
|
||
|
|
||
|
#include <stdio.h>
|
||
|
#include <string.h>
|
||
|
#include <stdint.h>
|
||
|
#if defined(_WIN32)
|
||
|
#include <windows.h>
|
||
|
static uintptr_t get_page_size() {
|
||
|
SYSTEM_INFO si;
|
||
|
GetSystemInfo(&si);
|
||
|
return si.dwPageSize;
|
||
|
}
|
||
|
#else
|
||
|
#include <unistd.h>
|
||
|
#include <sys/mman.h>
|
||
|
|
||
|
static uintptr_t get_page_size() {
|
||
|
return sysconf(_SC_PAGE_SIZE);
|
||
|
}
|
||
|
#endif
|
||
|
|
||
|
extern void __clear_cache(void* start, void* end);
|
||
|
|
||
|
|
||
|
typedef int (*pfunc)(void);
|
||
|
|
||
|
// Make these static to avoid ILT jumps for incremental linking on Windows.
|
||
|
static int func1() { return 1; }
|
||
|
static int func2() { return 2; }
|
||
|
|
||
|
void *__attribute__((noinline))
|
||
|
memcpy_f(void *dst, const void *src, size_t n) {
|
||
|
// ARM and MIPS nartually align functions, but use the LSB for ISA selection
|
||
|
// (THUMB, MIPS16/uMIPS respectively). Ensure that the ISA bit is ignored in
|
||
|
// the memcpy
|
||
|
#if defined(__arm__) || defined(__mips__)
|
||
|
return (void *)((uintptr_t)memcpy(dst, (void *)((uintptr_t)src & ~1), n) |
|
||
|
((uintptr_t)src & 1));
|
||
|
#else
|
||
|
return memcpy(dst, (void *)((uintptr_t)src), n);
|
||
|
#endif
|
||
|
}
|
||
|
|
||
|
unsigned char execution_buffer[128] __attribute__((aligned(8)));
|
||
|
|
||
|
int main()
|
||
|
{
|
||
|
// make executable the page containing execution_buffer
|
||
|
uintptr_t page_size = get_page_size();
|
||
|
char* start = (char*)((uintptr_t)execution_buffer & (-page_size));
|
||
|
char* end = (char*)((uintptr_t)(&execution_buffer[128+page_size]) & (-page_size));
|
||
|
#if defined(_WIN32)
|
||
|
DWORD dummy_oldProt;
|
||
|
MEMORY_BASIC_INFORMATION b;
|
||
|
if (!VirtualQuery(start, &b, sizeof(b)))
|
||
|
return 1;
|
||
|
if (!VirtualProtect(b.BaseAddress, b.RegionSize, PAGE_EXECUTE_READWRITE, &b.Protect))
|
||
|
#else
|
||
|
if (mprotect(start, end-start, PROT_READ|PROT_WRITE|PROT_EXEC) != 0)
|
||
|
#endif
|
||
|
return 1;
|
||
|
|
||
|
// verify you can copy and execute a function
|
||
|
pfunc f1 = (pfunc)memcpy_f(execution_buffer, func1, 128);
|
||
|
__clear_cache(execution_buffer, &execution_buffer[128]);
|
||
|
if ((*f1)() != 1)
|
||
|
return 1;
|
||
|
|
||
|
// verify you can overwrite a function with another
|
||
|
pfunc f2 = (pfunc)memcpy_f(execution_buffer, func2, 128);
|
||
|
__clear_cache(execution_buffer, &execution_buffer[128]);
|
||
|
if ((*f2)() != 2)
|
||
|
return 1;
|
||
|
|
||
|
return 0;
|
||
|
}
|