forked from OSchip/llvm-project
builtins: make sure that flags is setup properly for __clear_cache
On Linux ARM, the syscall will take 3 arguments (start, end, flags). Ensure that we do not pass garbage to the flags, which can cause the cacheflush call to fail, and therefore cause an abort at runtime. llvm-svn: 280877
This commit is contained in:
parent
3989c9f96f
commit
d14c2c0139
|
@ -110,10 +110,12 @@ void __clear_cache(void *start, void *end) {
|
||||||
#elif defined(__linux__)
|
#elif defined(__linux__)
|
||||||
register int start_reg __asm("r0") = (int) (intptr_t) start;
|
register int start_reg __asm("r0") = (int) (intptr_t) start;
|
||||||
const register int end_reg __asm("r1") = (int) (intptr_t) end;
|
const register int end_reg __asm("r1") = (int) (intptr_t) end;
|
||||||
|
const register int flags __asm("r2") = 0;
|
||||||
const register int syscall_nr __asm("r7") = __ARM_NR_cacheflush;
|
const register int syscall_nr __asm("r7") = __ARM_NR_cacheflush;
|
||||||
__asm __volatile("svc 0x0"
|
__asm __volatile("svc 0x0"
|
||||||
: "=r"(start_reg)
|
: "=r"(start_reg)
|
||||||
: "r"(syscall_nr), "r"(start_reg), "r"(end_reg));
|
: "r"(syscall_nr), "r"(start_reg), "r"(end_reg),
|
||||||
|
"r"(flags));
|
||||||
if (start_reg != 0) {
|
if (start_reg != 0) {
|
||||||
compilerrt_abort();
|
compilerrt_abort();
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue