sbcl: improve bootstrap and add arm support
clisp bootstrap is very slow and clisp doesn't compile on arm now it is possible to also bootstrap using ccl: sbclBootstrapHost = "${ccl}/bin/${ccl.CCL_RUNTIME} -b -n"; or alternatively using clisp sbclBootstrapHost = "${clisp}/bin/clisp -norc";
This commit is contained in:
parent
64bde29a31
commit
29f120d7b2
@ -1,24 +1,53 @@
|
|||||||
{ stdenv, fetchurl }:
|
{ stdenv, fetchurl, makeWrapper }:
|
||||||
|
|
||||||
|
let
|
||||||
|
options = rec {
|
||||||
|
x86_64-darwin = rec {
|
||||||
|
version = "1.1.8";
|
||||||
|
system = "x86-64-darwin";
|
||||||
|
sha256 = "006pr88053wclvbjfjdypnbiw8wymbzdzi7a6kbkpdfn4zf5943j";
|
||||||
|
};
|
||||||
|
x86_64-linux = rec {
|
||||||
|
version = "1.2.15";
|
||||||
|
system = "x86-64-linux";
|
||||||
|
sha256 = "1bpbfz9x2w73hy2kh8p0kd4m1p6pin90h2zycq52r3bbz8yv47aw";
|
||||||
|
};
|
||||||
|
i686-linux = rec {
|
||||||
|
version = "1.2.7";
|
||||||
|
system = "x86-linux";
|
||||||
|
sha256 = "07f3bz4br280qvn85i088vpzj9wcz8wmwrf665ypqx181pz2ai3j";
|
||||||
|
};
|
||||||
|
armv7l-linux = rec {
|
||||||
|
version = "1.2.14";
|
||||||
|
system = "armhf-linux";
|
||||||
|
sha256 = "0sp5445rbvms6qvzhld0kwwvydw51vq5iaf4kdqsf2d9jvaz3yx5";
|
||||||
|
};
|
||||||
|
armv6l-linux = armv7l-linux;
|
||||||
|
};
|
||||||
|
cfg = options.${stdenv.system};
|
||||||
|
in
|
||||||
stdenv.mkDerivation rec {
|
stdenv.mkDerivation rec {
|
||||||
name = "sbcl-bootstrap-${version}";
|
name = "sbcl-bootstrap-${version}";
|
||||||
version = "1.1.8";
|
version = cfg.version;
|
||||||
|
|
||||||
src = if stdenv.isDarwin
|
src = fetchurl {
|
||||||
then fetchurl {
|
url = "mirror://sourceforge/project/sbcl/sbcl/${version}/sbcl-${version}-${cfg.system}-binary.tar.bz2";
|
||||||
url = mirror://sourceforge/project/sbcl/sbcl/1.1.8/sbcl-1.1.8-x86-64-darwin-binary.tar.bz2;
|
sha256 = cfg.sha256;
|
||||||
sha256 = "006pr88053wclvbjfjdypnbiw8wymbzdzi7a6kbkpdfn4zf5943j";
|
};
|
||||||
}
|
|
||||||
else fetchurl {
|
buildInputs = [ makeWrapper ];
|
||||||
url = mirror://sourceforge/project/sbcl/sbcl/1.1.8/sbcl-1.1.8-x86-64-linux-binary.tar.bz2;
|
|
||||||
sha256 = "0lh1jglxlfwk4cm6sgwk1jnb6ikhbrkx7p5aha2nbmkd6zl96prx";
|
|
||||||
};
|
|
||||||
|
|
||||||
installPhase = ''
|
installPhase = ''
|
||||||
mkdir -p $out/bin
|
|
||||||
cp -p src/runtime/sbcl $out/bin
|
|
||||||
mkdir -p $out/share/sbcl
|
mkdir -p $out/share/sbcl
|
||||||
|
cp -p src/runtime/sbcl $out/share/sbcl
|
||||||
cp -p output/sbcl.core $out/share/sbcl
|
cp -p output/sbcl.core $out/share/sbcl
|
||||||
|
mkdir -p $out/bin
|
||||||
|
makeWrapper $out/share/sbcl/sbcl $out/bin/sbcl \
|
||||||
|
--add-flags "--core $out/share/sbcl/sbcl.core"
|
||||||
|
'';
|
||||||
|
|
||||||
|
postFixup = if stdenv.isArm then "" else ''
|
||||||
|
patchelf --set-interpreter $(cat $NIX_CC/nix-support/dynamic-linker) $out/share/sbcl/sbcl
|
||||||
'';
|
'';
|
||||||
|
|
||||||
meta = {
|
meta = {
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
{ stdenv, fetchurl, sbclBootstrap, clisp, which}:
|
{ stdenv, fetchurl, sbclBootstrap, sbclBootstrapHost ? "${sbclBootstrap}/bin/sbcl --disable-debugger --no-userinit --no-sysinit", which }:
|
||||||
|
|
||||||
stdenv.mkDerivation rec {
|
stdenv.mkDerivation rec {
|
||||||
name = "sbcl-${version}";
|
name = "sbcl-${version}";
|
||||||
@ -9,10 +9,7 @@ stdenv.mkDerivation rec {
|
|||||||
sha256 = "0l8nrf5qnr8c9hr6bn1kd86mnr2s37b493azh9rrk3v59f56wnnr";
|
sha256 = "0l8nrf5qnr8c9hr6bn1kd86mnr2s37b493azh9rrk3v59f56wnnr";
|
||||||
};
|
};
|
||||||
|
|
||||||
buildInputs = [ which ]
|
buildInputs = [ which ];
|
||||||
++ (stdenv.lib.optional stdenv.isDarwin sbclBootstrap)
|
|
||||||
++ (stdenv.lib.optional stdenv.isLinux clisp)
|
|
||||||
;
|
|
||||||
|
|
||||||
patchPhase = ''
|
patchPhase = ''
|
||||||
echo '"${version}.nixos"' > version.lisp-expr
|
echo '"${version}.nixos"' > version.lisp-expr
|
||||||
@ -22,7 +19,10 @@ stdenv.mkDerivation rec {
|
|||||||
(pushnew x features))
|
(pushnew x features))
|
||||||
(disable (x)
|
(disable (x)
|
||||||
(setf features (remove x features))))
|
(setf features (remove x features))))
|
||||||
(enable :sb-thread))) " > customize-target-features.lisp
|
#-arm
|
||||||
|
(enable :sb-thread)
|
||||||
|
#+arm
|
||||||
|
(enable :arm))) " > customize-target-features.lisp
|
||||||
|
|
||||||
pwd
|
pwd
|
||||||
|
|
||||||
@ -64,13 +64,9 @@ stdenv.mkDerivation rec {
|
|||||||
export HOME=$PWD/test-home
|
export HOME=$PWD/test-home
|
||||||
'';
|
'';
|
||||||
|
|
||||||
buildPhase = if stdenv.isLinux
|
buildPhase = ''
|
||||||
then ''
|
sh make.sh --prefix=$out --xc-host="${sbclBootstrapHost}"
|
||||||
sh make.sh clisp --prefix=$out
|
'';
|
||||||
''
|
|
||||||
else ''
|
|
||||||
sh make.sh --prefix=$out --xc-host='${sbclBootstrap}/bin/sbcl --core ${sbclBootstrap}/share/sbcl/sbcl.core --disable-debugger --no-userinit --no-sysinit'
|
|
||||||
'';
|
|
||||||
|
|
||||||
installPhase = ''
|
installPhase = ''
|
||||||
INSTALL_ROOT=$out sh install.sh
|
INSTALL_ROOT=$out sh install.sh
|
||||||
|
@ -4701,9 +4701,7 @@ let
|
|||||||
rustfmt = callPackage ../development/tools/rust/rustfmt { };
|
rustfmt = callPackage ../development/tools/rust/rustfmt { };
|
||||||
|
|
||||||
sbclBootstrap = callPackage ../development/compilers/sbcl/bootstrap.nix {};
|
sbclBootstrap = callPackage ../development/compilers/sbcl/bootstrap.nix {};
|
||||||
sbcl = callPackage ../development/compilers/sbcl {
|
sbcl = callPackage ../development/compilers/sbcl {};
|
||||||
clisp = clisp;
|
|
||||||
};
|
|
||||||
# For StumpWM
|
# For StumpWM
|
||||||
sbcl_1_2_5 = callPackage ../development/compilers/sbcl/1.2.5.nix {
|
sbcl_1_2_5 = callPackage ../development/compilers/sbcl/1.2.5.nix {
|
||||||
clisp = clisp;
|
clisp = clisp;
|
||||||
|
Loading…
Reference in New Issue
Block a user