aboutsummaryrefslogtreecommitdiffstats
path: root/community/rust/musl-fix-jemalloc.patch
diff options
context:
space:
mode:
Diffstat (limited to 'community/rust/musl-fix-jemalloc.patch')
-rw-r--r--community/rust/musl-fix-jemalloc.patch61
1 files changed, 61 insertions, 0 deletions
diff --git a/community/rust/musl-fix-jemalloc.patch b/community/rust/musl-fix-jemalloc.patch
new file mode 100644
index 0000000000..345398a301
--- /dev/null
+++ b/community/rust/musl-fix-jemalloc.patch
@@ -0,0 +1,61 @@
+From 536011d929ecbd1170baf34e09580e567c971f95 Mon Sep 17 00:00:00 2001
+From: Shiz <hi@shiz.me>
+Date: Sat, 8 Apr 2017 20:36:00 +0200
+Subject: [PATCH] Fix jemalloc support for musl
+
+Just like DragonFlyBSD, using the same symbols as the system allocator will
+result in a segmentation fault at runtime due to allocator mismatches.
+As such, prefix the jemalloc symbols instead.
+
+Upstream-Issue: https://github.com/rust-lang/rust/pull/41168
+---
+ src/liballoc_jemalloc/build.rs | 2 +-
+ src/liballoc_jemalloc/lib.rs | 10 +++++-----
+ 2 files changed, 6 insertions(+), 6 deletions(-)
+
+diff --git a/src/liballoc_jemalloc/build.rs b/src/liballoc_jemalloc/build.rs
+index ae040a2..f3a0eeb 100644
+--- a/src/liballoc_jemalloc/build.rs
++++ b/src/liballoc_jemalloc/build.rs
+@@ -138,7 +138,7 @@ fn main() {
+ // should be good to go!
+ cmd.arg("--with-jemalloc-prefix=je_");
+ cmd.arg("--disable-tls");
+- } else if target.contains("dragonfly") {
++ } else if target.contains("dragonfly") || target.contains("musl") {
+ cmd.arg("--with-jemalloc-prefix=je_");
+ }
+
+diff --git a/src/liballoc_jemalloc/lib.rs b/src/liballoc_jemalloc/lib.rs
+index a7a67ef..83cc1ef 100644
+--- a/src/liballoc_jemalloc/lib.rs
++++ b/src/liballoc_jemalloc/lib.rs
+@@ -51,23 +51,23 @@ mod imp {
+ // request it as unprefixing cause segfaults (mismatches in allocators).
+ extern "C" {
+ #[cfg_attr(any(target_os = "macos", target_os = "android", target_os = "ios",
+- target_os = "dragonfly", target_os = "windows"),
++ target_os = "dragonfly", target_os = "windows", target_env = "musl"),
+ link_name = "je_mallocx")]
+ fn mallocx(size: size_t, flags: c_int) -> *mut c_void;
+ #[cfg_attr(any(target_os = "macos", target_os = "android", target_os = "ios",
+- target_os = "dragonfly", target_os = "windows"),
++ target_os = "dragonfly", target_os = "windows", target_env = "musl"),
+ link_name = "je_rallocx")]
+ fn rallocx(ptr: *mut c_void, size: size_t, flags: c_int) -> *mut c_void;
+ #[cfg_attr(any(target_os = "macos", target_os = "android", target_os = "ios",
+- target_os = "dragonfly", target_os = "windows"),
++ target_os = "dragonfly", target_os = "windows", target_env = "musl"),
+ link_name = "je_xallocx")]
+ fn xallocx(ptr: *mut c_void, size: size_t, extra: size_t, flags: c_int) -> size_t;
+ #[cfg_attr(any(target_os = "macos", target_os = "android", target_os = "ios",
+- target_os = "dragonfly", target_os = "windows"),
++ target_os = "dragonfly", target_os = "windows", target_env = "musl"),
+ link_name = "je_sdallocx")]
+ fn sdallocx(ptr: *mut c_void, size: size_t, flags: c_int);
+ #[cfg_attr(any(target_os = "macos", target_os = "android", target_os = "ios",
+- target_os = "dragonfly", target_os = "windows"),
++ target_os = "dragonfly", target_os = "windows", target_env = "musl"),
+ link_name = "je_nallocx")]
+ fn nallocx(size: size_t, flags: c_int) -> size_t;
+ }