Merge pull request #38995 from yorickvP/rocksdb-jemalloc

rocksdb: use jemalloc 4.5.0

Changed files
+47 -34
pkgs
development
top-level
+35
pkgs/development/libraries/jemalloc/common.nix
···
+
{ stdenv, fetchurl, version, sha256, ... }@args:
+
+
stdenv.mkDerivation (rec {
+
name = "jemalloc-${version}";
+
inherit version;
+
+
src = fetchurl {
+
url = "https://github.com/jemalloc/jemalloc/releases/download/${version}/${name}.tar.bz2";
+
inherit sha256;
+
};
+
+
# By default, jemalloc puts a je_ prefix onto all its symbols on OSX, which
+
# then stops downstream builds (mariadb in particular) from detecting it. This
+
# option should remove the prefix and give us a working jemalloc.
+
configureFlags = stdenv.lib.optional stdenv.isDarwin "--with-jemalloc-prefix="
+
# jemalloc is unable to correctly detect transparent hugepage support on
+
# ARM (https://github.com/jemalloc/jemalloc/issues/526), and the default
+
# kernel ARMv6/7 kernel does not enable it, so we explicitly disable support
+
++ stdenv.lib.optional stdenv.isArm "--disable-thp";
+
doCheck = true;
+
+
enableParallelBuilding = true;
+
+
meta = with stdenv.lib; {
+
homepage = http://jemalloc.net;
+
description = "General purpose malloc(3) implementation";
+
longDescription = ''
+
malloc(3)-compatible memory allocator that emphasizes fragmentation
+
avoidance and scalable concurrency support.
+
'';
+
license = licenses.bsd2;
+
platforms = platforms.all;
+
maintainers = with maintainers; [ wkennington ];
+
};
+
} // (builtins.removeAttrs args [ "stdenv" "fetchurl" "version" "sha256" ]))
+3 -33
pkgs/development/libraries/jemalloc/default.nix
···
{ stdenv, fetchurl, fetchpatch }:
-
-
stdenv.mkDerivation rec {
-
name = "jemalloc-${version}";
+
import ./common.nix {
+
inherit stdenv fetchurl;
version = "5.0.1";
-
-
src = fetchurl {
-
url = "https://github.com/jemalloc/jemalloc/releases/download/${version}/${name}.tar.bz2";
-
sha256 = "4814781d395b0ef093b21a08e8e6e0bd3dab8762f9935bbfb71679b0dea7c3e9";
-
};
-
-
# By default, jemalloc puts a je_ prefix onto all its symbols on OSX, which
-
# then stops downstream builds (mariadb in particular) from detecting it. This
-
# option should remove the prefix and give us a working jemalloc.
-
configureFlags = stdenv.lib.optional stdenv.isDarwin "--with-jemalloc-prefix="
-
# jemalloc is unable to correctly detect transparent hugepage support on
-
# ARM (https://github.com/jemalloc/jemalloc/issues/526), and the default
-
# kernel ARMv6/7 kernel does not enable it, so we explicitly disable support
-
++ stdenv.lib.optional stdenv.isArm "--disable-thp";
-
doCheck = true;
-
+
sha256 = "4814781d395b0ef093b21a08e8e6e0bd3dab8762f9935bbfb71679b0dea7c3e9";
patches = stdenv.lib.optional stdenv.isAarch64 (fetchpatch {
url = "https://patch-diff.githubusercontent.com/raw/jemalloc/jemalloc/pull/1035.patch";
sha256 = "02y0q3dp253bipxv4r954nqipbjbj92p6ww9bx5bk3d8pa81wkqq";
});
-
-
enableParallelBuilding = true;
-
-
meta = with stdenv.lib; {
-
homepage = http://jemalloc.net;
-
description = "General purpose malloc(3) implementation";
-
longDescription = ''
-
malloc(3)-compatible memory allocator that emphasizes fragmentation
-
avoidance and scalable concurrency support.
-
'';
-
license = licenses.bsd2;
-
platforms = platforms.all;
-
maintainers = with maintainers; [ wkennington ];
-
};
}
+6
pkgs/development/libraries/jemalloc/jemalloc450.nix
···
+
{ stdenv, fetchurl }:
+
import ./common.nix {
+
inherit stdenv fetchurl;
+
version = "4.5.0";
+
sha256 = "10373xhpc10pgmai9fkc1z0rs029qlcb3c0qfnvkbwdlcibdh2cl";
+
}
+3 -1
pkgs/top-level/all-packages.nix
···
jemalloc = callPackage ../development/libraries/jemalloc { };
+
jemalloc450 = callPackage ../development/libraries/jemalloc/jemalloc450.nix { };
+
jshon = callPackage ../development/tools/parsing/jshon { };
json2hcl = callPackage ../development/tools/json2hcl { };
···
rlog = callPackage ../development/libraries/rlog { };
-
rocksdb = callPackage ../development/libraries/rocksdb { };
+
rocksdb = callPackage ../development/libraries/rocksdb { jemalloc = jemalloc450; };
rocksdb_lite = rocksdb.override { enableLite = true; };