diff options
author | J0WI <J0WI@users.noreply.github.com> | 2019-08-09 15:14:59 +0200 |
---|---|---|
committer | Leo <thinkabit.ukim@gmail.com> | 2019-08-11 17:26:20 -0300 |
commit | 8cfd3538acb4e2fcaa7aa9e6ad90e8c342bdc0f6 (patch) | |
tree | a4a06930da4100ea3844ded19d1ae126dc445aa2 /unmaintained/llvm3.9/fix-memory-mf_exec-on-aarch64.patch | |
parent | 6b24b21a0b36fb04b962e46fe2809a54d0e47b2d (diff) | |
download | aports-8cfd3538acb4e2fcaa7aa9e6ad90e8c342bdc0f6.tar.bz2 aports-8cfd3538acb4e2fcaa7aa9e6ad90e8c342bdc0f6.tar.xz |
unmaintained/llvm3.9: move from community
Diffstat (limited to 'unmaintained/llvm3.9/fix-memory-mf_exec-on-aarch64.patch')
-rw-r--r-- | unmaintained/llvm3.9/fix-memory-mf_exec-on-aarch64.patch | 33 |
1 files changed, 33 insertions, 0 deletions
diff --git a/unmaintained/llvm3.9/fix-memory-mf_exec-on-aarch64.patch b/unmaintained/llvm3.9/fix-memory-mf_exec-on-aarch64.patch new file mode 100644 index 0000000000..a70b397333 --- /dev/null +++ b/unmaintained/llvm3.9/fix-memory-mf_exec-on-aarch64.patch @@ -0,0 +1,33 @@ +Fix failures in AllocationTests/MappedMemoryTest.* on aarch64: + + Failing Tests (8): + LLVM-Unit :: Support/./SupportTests/AllocationTests/MappedMemoryTest.AllocAndRelease/3 + LLVM-Unit :: Support/./SupportTests/AllocationTests/MappedMemoryTest.DuplicateNear/3 + LLVM-Unit :: Support/./SupportTests/AllocationTests/MappedMemoryTest.EnabledWrite/3 + LLVM-Unit :: Support/./SupportTests/AllocationTests/MappedMemoryTest.MultipleAllocAndRelease/3 + LLVM-Unit :: Support/./SupportTests/AllocationTests/MappedMemoryTest.SuccessiveNear/3 + LLVM-Unit :: Support/./SupportTests/AllocationTests/MappedMemoryTest.UnalignedNear/3 + LLVM-Unit :: Support/./SupportTests/AllocationTests/MappedMemoryTest.ZeroNear/3 + LLVM-Unit :: Support/./SupportTests/AllocationTests/MappedMemoryTest.ZeroSizeNear/3 + +Upstream-Issue: https://bugs.llvm.org/show_bug.cgi?id=14278#c10 + +--- a/lib/Support/Unix/Memory.inc ++++ b/lib/Support/Unix/Memory.inc +@@ -54,7 +54,7 @@ + llvm::sys::Memory::MF_EXEC: + return PROT_READ | PROT_WRITE | PROT_EXEC; + case llvm::sys::Memory::MF_EXEC: +-#if defined(__FreeBSD__) ++#if defined(__FreeBSD__) || (defined(__linux__) && (defined(__aarch64__) || defined(__powerpc64__))) + // On PowerPC, having an executable page that has no read permission + // can have unintended consequences. The function InvalidateInstruction- + // Cache uses instructions dcbf and icbi, both of which are treated by +@@ -62,6 +62,7 @@ + // executing these instructions will result in a segmentation fault. + // Somehow, this problem is not present on Linux, but it does happen + // on FreeBSD. ++ // The same problem is present even on aarch64 Linux (at least on musl). + return PROT_READ | PROT_EXEC; + #else + return PROT_EXEC; |