Merge pull request #56 from luc-tielen/update-nix-setup

Update nix setup
This commit is contained in:
Andor Penzes 2019-12-23 21:34:24 +01:00 committed by GitHub
commit 6b7dd3d24f
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
13 changed files with 64 additions and 205 deletions

3
.gitignore vendored
View File

@ -18,13 +18,16 @@ cabal.sandbox.config
*.eventlog
.stack-work/
cabal.project.local
cabal.project.local~
.HTF/
output/
*.ibc
*.agdai
.output
.grin-output/
grin/.end-to-end-test/
.vscode/
*.out
*.out.ll
*.out.s
.ghc.environment.*

13
default.nix Normal file
View File

@ -0,0 +1,13 @@
let
haskell = import ./nix/haskell.nix;
llvm-overlay = self: super: {
llvm-config = self.llvm_7;
};
extra-overlays = [ llvm-overlay ];
pkgs = import ./nix/packages.nix (haskell // {
overlays = haskell.overlays ++ extra-overlays;
});
in
pkgs.haskell-nix.stackProject {
src = pkgs.haskell-nix.haskellLib.cleanGit { src = ./.; };
}

View File

@ -17,7 +17,7 @@ import System.IO
import Grin.Grin
import Grin.PrimOpsPrelude
import Grin.Parse hiding (value)
import Grin.Parse
import Grin.Nametable as Nametable
import Pipeline.Pipeline

View File

@ -1,41 +0,0 @@
{ Diff, mkDerivation, ansi-wl-pprint, base, bimap, bytestring, comonad
, containers, criterion, deepseq, directory, extra, filepath, free
, functor-infix, generic-random, ghc, ghc-paths, haskeline, hspec
, hspec-discover, llvm-hs, llvm-hs-pretty, llvm-hs-pure
, logict, megaparsec, microlens, microlens-mtl, microlens-platform
, microlens-th, monad-gen, mtl, neat-interpolation
, optparse-applicative, pretty-show, pretty-simple, process
, QuickCheck, quickcheck-instances, recursion-schemes, set-extra
, stdenv, template-haskell, text, text-short
, transformers, unix, vector
}:
mkDerivation {
pname = "grin";
version = "0.1.0.0";
src = ./.;
isLibrary = true;
isExecutable = true;
libraryHaskellDepends = [
Diff ansi-wl-pprint base bimap bytestring comonad containers deepseq
directory extra filepath free functor-infix generic-random ghc
hspec llvm-hs llvm-hs-pretty llvm-hs-pure logict megaparsec
microlens microlens-mtl microlens-platform microlens-th monad-gen
mtl neat-interpolation optparse-applicative pretty-show
pretty-simple process QuickCheck quickcheck-instances recursion-schemes
set-extra template-haskell text text-short transformers vector
];
executableHaskellDepends = [
ansi-wl-pprint base containers directory filepath ghc ghc-paths
haskeline llvm-hs-pretty megaparsec microlens microlens-mtl
microlens-platform microlens-th mtl optparse-applicative
pretty-show pretty-simple process recursion-schemes text
transformers unix
];
testHaskellDepends = [
base containers deepseq functor-infix hspec hspec-discover
QuickCheck vector
];
benchmarkHaskellDepends = [ base criterion ];
homepage = "https://github.com/githubuser/grin#readme";
license = stdenv.lib.licenses.bsd3;
}

View File

@ -82,6 +82,7 @@ import qualified AbstractInterpretation.EffectTracking.CodeGenBase as ET
import qualified AbstractInterpretation.Sharing.CodeGen as Sharing
import qualified Reducer.LLVM.CodeGen as CGLLVM
import qualified Reducer.LLVM.JIT as JITLLVM
import System.Environment ( lookupEnv )
import System.Directory
import qualified System.Process
import Data.Bifunctor
@ -718,23 +719,27 @@ saveLLVM path = do
pipelineLog "* to LLVM *"
void $ liftIO $ CGLLVM.toLLVM llName code
pipelineLog"* LLVM X64 codegen *"
callCommand $ printf "opt-7 -O3 %s | llc-7 -o %s" llName (sName :: String)
llcExe <- liftIO $ fromMaybe "llc-7" <$> lookupEnv "GRIN_LLC"
optExe <- liftIO $ fromMaybe "opt-7" <$> lookupEnv "GRIN_OPT"
callCommand $ printf "%s -O3 %s | %s -o %s" optExe llName llcExe (sName :: String)
saveExecutable :: Bool -> Path -> PipelineM ()
saveExecutable debugSymbols path = do
pipelineLog "* generate llvm x64 optcode *"
let grinOptCodePath = Rel "grin-opt-code"
clangExe <- liftIO $ fromMaybe "clang-7" <$> lookupEnv "GRIN_CC"
llcExe <- liftIO $ fromMaybe "llc-7" <$> lookupEnv "GRIN_LLC"
pipelineStep $ SaveLLVM grinOptCodePath
grinOptCodeFile <- relPath grinOptCodePath
fname <- relPath path
pipelineLog "* generate executable *"
callCommand $ printf
("llc-7 -O3 -relocation-model=pic -filetype=obj %s.ll" ++ if debugSymbols then " -debugger-tune=gdb" else "")
grinOptCodeFile
("%s -O3 -relocation-model=pic -filetype=obj %s.ll" ++ if debugSymbols then " -debugger-tune=gdb" else "")
llcExe grinOptCodeFile
cfg <- ask
callCommand $ printf
("clang-7 -O3 %s %s.o -s -o %s" ++ if debugSymbols then " -g" else "")
(intercalate " " $ _poCFiles cfg) grinOptCodeFile fname
("%s -O3 %s %s.o -s -o %s" ++ if debugSymbols then " -g" else "")
clangExe (intercalate " " $ _poCFiles cfg) grinOptCodeFile fname
debugTransformation :: (Exp -> Exp) -> PipelineM ()
debugTransformation t = do

View File

@ -1,20 +0,0 @@
{ mkDerivation, base, bifunctors, comonad, containers, distributive
, exceptions, mtl, prelude-extras, profunctors, semigroupoids
, semigroups, stdenv, template-haskell, transformers
, transformers-compat
}:
mkDerivation {
pname = "free";
version = "4.12.4";
sha256 = "c9fe45aae387855626ecb5a0fea6afdb207143cb00af3b1f715d1032d2d08784";
revision = "2";
editedCabalFile = "0gmib9bmswrqhl47cp5b871v9f44v9yidzxpljkszy49y9qdf560";
libraryHaskellDepends = [
base bifunctors comonad containers distributive exceptions mtl
prelude-extras profunctors semigroupoids semigroups
template-haskell transformers transformers-compat
];
homepage = "http://github.com/ekmett/free/";
description = "Monads for free";
license = stdenv.lib.licenses.bsd3;
}

7
nix/haskell-nix-src.json Normal file
View File

@ -0,0 +1,7 @@
{
"url": "https://github.com/input-output-hk/haskell.nix",
"rev": "ebdc0030e6973629c1ed7dba53c1b1d154c3e75e",
"date": "2019-12-11T01:12:46+00:00",
"sha256": "1q25sw8kz7r0wwzq780qq1cgsiy1g7iwnywckixa28psim8rp2nw",
"fetchSubmodules": false
}

8
nix/haskell.nix Normal file
View File

@ -0,0 +1,8 @@
let
spec = builtins.fromJSON (builtins.readFile ./haskell-nix-src.json);
haskell-nix-src = builtins.fetchGit {
name = "haskell-lib";
inherit (spec) url rev;
};
in
import haskell-nix-src

View File

@ -1,20 +0,0 @@
{ mkDerivation, array, base, bytestring, directory, filepath
, llvm-hs, llvm-hs-pure, mtl, pretty-show, stdenv, tasty
, tasty-golden, tasty-hspec, tasty-hunit, text, transformers
, wl-pprint-text
}:
mkDerivation {
pname = "llvm-hs-pretty";
version = "0.2.0.0";
sha256 = "90ce478f6386f836e3b646186c4fe4d72598cc938d8fbb150718a1bbf4f4738c";
libraryHaskellDepends = [
array base bytestring llvm-hs-pure text wl-pprint-text
];
testHaskellDepends = [
base directory filepath llvm-hs llvm-hs-pure mtl pretty-show tasty
tasty-golden tasty-hspec tasty-hunit text transformers
];
homepage = "https://github.com/llvm-hs/llvm-hs-pretty";
description = "Pretty printer for LLVM IR";
license = stdenv.lib.licenses.mit;
}

View File

@ -1,20 +0,0 @@
{ mkDerivation, attoparsec, base, bytestring, containers, fail
, hspec, mtl, stdenv, tasty, tasty-hunit, tasty-quickcheck
, template-haskell, text, transformers, unordered-containers
}:
mkDerivation {
pname = "llvm-hs-pure";
version = "5.1.2";
sha256 = "c4d0993aacda72107e6d34865421f128b8c27b586b95a68e2a3e94700645d954";
libraryHaskellDepends = [
attoparsec base bytestring containers fail mtl template-haskell
transformers unordered-containers
];
testHaskellDepends = [
base bytestring containers hspec mtl tasty tasty-hunit
tasty-quickcheck text transformers unordered-containers
];
homepage = "http://github.com/llvm-hs/llvm-hs/";
description = "Pure Haskell LLVM functionality (no FFI)";
license = stdenv.lib.licenses.bsd3;
}

View File

@ -1,26 +0,0 @@
{ mkDerivation, array, attoparsec, base, bytestring, Cabal
, containers, exceptions, llvm-config, llvm-hs-pure, mtl
, pretty-show, QuickCheck, stdenv, tasty, tasty-hunit
, tasty-quickcheck, template-haskell, temporary, transformers
, utf8-string
}:
mkDerivation {
pname = "llvm-hs";
version = "5.1.3";
sha256 = "ccdac4683f56135ba83ed0883231f686d1784e9bc7f072a34fcf041e0661976b";
revision = "1";
editedCabalFile = "0r8xgz6r2miw1l3az343jwz8f9jgzqywxnzl2xhanv05g3i462yh";
setupHaskellDepends = [ base Cabal containers ];
libraryHaskellDepends = [
array attoparsec base bytestring containers exceptions llvm-hs-pure
mtl template-haskell transformers utf8-string
];
libraryToolDepends = [ llvm-config ];
testHaskellDepends = [
base bytestring containers llvm-hs-pure mtl pretty-show QuickCheck
tasty tasty-hunit tasty-quickcheck temporary transformers
];
homepage = "http://github.com/llvm-hs/llvm-hs/";
description = "General purpose LLVM bindings";
license = stdenv.lib.licenses.bsd3;
}

10
nix/packages.nix Normal file
View File

@ -0,0 +1,10 @@
let
commit = "4c6e9a553872366e485766fa8b574b54b15957f8";
nixpkgs = builtins.fetchTarball {
name = "nixpkgs-19.09";
url = "https://github.com/nixos/nixpkgs/archive/${commit}.tar.gz";
sha256 = "1az9yg2lwwfw3aypi6bdsk7ghld2963vqdp8ajkxciyxdfkaxb3b";
};
pkgs = import nixpkgs;
in
pkgs

View File

@ -1,74 +1,14 @@
{ fetchFromGitHub ? (import <nixpkgs> {}).fetchFromGitHub
# peg nix packages to specific version
, pkgs ?
import
( fetchFromGitHub
{
owner = "NixOS";
repo = "nixpkgs-channels";
rev = "696c6bed4e8e2d9fd9b956dea7e5d49531e9d13f";
sha256 = "1v3yrpj542niyxp0h3kffsdjwlrkvj0mg4ljb85d142gyn3sdzd4";
}
) {}
}:
let
# extract the Haskell dependencies of a package
extractHaskellDependencies = (hpkg:
with builtins;
let
isHaskellPkg = x: (isAttrs x) && (x ? pname) && (x ? version) && (x ? env);
packagesFromDrv = x:
let
inputs =
(x.buildInputs or []) ++
(x.nativeBuildInputs or []) ++
(x.propagatedBuildInputs or []) ++
(x.propagatedNativeBuildInputs or []);
in
(filter isHaskellPkg inputs);
go1 = s: xs: foldl' go2 s xs;
go2 = s: x:
if s ? "${x.pname}"
then s
else go1 (s // {"${x.pname}" = x;}) (packagesFromDrv x);
in assert isAttrs hpkg; attrNames (go1 {} (packagesFromDrv hpkg)));
# Haskell custom overrides
haskellPackages = pkgs.haskell.packages.ghc822.override (old:
{ overrides = self: super:
{
free = self.callPackage ./nix/free.nix {};
functor-infix = pkgs.haskell.lib.doJailbreak (super.functor-infix);
llvm-hs = self.callPackage ./nix/llvm-hs.nix {llvm-config = pkgs.llvm_5;};
llvm-hs-pure = self.callPackage ./nix/llvm-hs-pure.nix {};
llvm-hs-pretty = pkgs.haskell.lib.dontCheck (self.callPackage ./nix/llvm-hs-pretty.nix {});
};
});
# the grin package
grin = pkgs.haskellPackages.callPackage ./grin {};
# grin's dependencies
grinDeps = extractHaskellDependencies grin;
# use a GHC with all the Hakell dependencies and the documentation for them and a Hoogle server to search them
ghcWith = haskellPackages.ghcWithHoogle (hs: map (x: builtins.getAttr x hs) grinDeps);
llc5 = pkgs.runCommand "llc5"
{
buildInputs = [pkgs.llvm_5];
}
''
mkdir -p $out/bin
cd $out/bin
ln -s ${pkgs.llvm_5}/bin/llc llc-5.0
'';
pkgs = import ./nix/packages.nix {};
haskellPkgs = import ./.;
in
# environment setup with all the needed tools
pkgs.runCommand "grin-shell"
{
shellHook = ''
eval $(egrep ^export ${ghcWith}/bin/ghc)
'';
buildInputs = [ghcWith llc5 pkgs.llvm_5 haskellPackages.cabal-install];
}
"touch $out"
haskellPkgs.shellFor {
buildInputs = with pkgs.haskellPackages; [
hlint
ghcid
];
GRIN_CC = "${pkgs.clang_7}/bin/clang";
GRIN_OPT = "${pkgs.llvm_7}/bin/opt";
GRIN_LLC = "${pkgs.llvm_7}/bin/llc";
}