about summary refs log tree commit diff
path: root/nixpkgs/pkgs/development/compilers/ghdl/test-simple.nix
blob: 8d3c3d3095f2d090776221c150ef32d07aa62fc2 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
{ stdenv, ghdl-llvm, ghdl-mcode, backend }:

let
  ghdl = if backend == "llvm" then ghdl-llvm else ghdl-mcode;
in
stdenv.mkDerivation {
  name = "ghdl-test-simple";
  meta.timeout = 300;
  nativeBuildInputs = [ ghdl ];
  buildCommand = ''
    cp ${./simple.vhd} simple.vhd
    cp ${./simple-tb.vhd} simple-tb.vhd
    mkdir -p ghdlwork
    ghdl -a --workdir=ghdlwork --ieee=synopsys simple.vhd simple-tb.vhd
    ghdl -e --workdir=ghdlwork --ieee=synopsys -o sim-simple tb
  '' + (if backend == "llvm" then ''
    ./sim-simple --assert-level=warning > output.txt
  '' else ''
    ghdl -r --workdir=ghdlwork --ieee=synopsys tb > output.txt
  '') + ''
    diff output.txt ${./expected-output.txt} && touch $out
  '';
}