summary refs log tree commit diff
path: root/pkgs/development/compilers/bupc/default.nix
blob: ad10845e98cfce671be524a22fa22e8c1062f76b (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
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
{ stdenv, fetchurl, perl, coreutils }:

stdenv.mkDerivation rec {
  name = "berkeley_upc-2.22.0";

  src = fetchurl {
    url = "http://upc.lbl.gov/download/release/${name}.tar.gz";
    sha256 = "041l215x8z1cvjcx7kwjdgiaf9rl2d778k6kiv8q09bc68nwd44m";
  };

  postPatch = ''
    patchShebangs .
  '';

  # Used during the configure phase
  ENVCMD = "${coreutils}/bin/env";

  nativeBuildInputs = [ coreutils ];
  buildInputs = [ perl ];

  meta = with stdenv.lib; {
    description = "A compiler for the Berkely Unified Parallel C language";
    longDescription = ''
      Unified Parallel C (UPC) is an extension of the C programming language
      designed for high performance computing on large-scale parallel
      machines.The language provides a uniform programming model for both
      shared and distributed memory hardware. The programmer is presented with
      a single shared, partitioned address space, where variables may be
      directly read and written by any processor, but each variable is
      physically associated with a single processor. UPC uses a Single Program
      Multiple Data (SPMD) model of computation in which the amount of
      parallelism is fixed at program startup time, typically with a single
      thread of execution per processor.
    '';
    homepage = https://upc.lbl.gov/;
    license = licenses.mit;
    platforms = with platforms; [ linux ];
    maintainers = with maintainers; [ zimbatm ];
  };
}