nixpkgs/pkgs/development/compilers/bupc/default.nix

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

41 lines
1.4 KiB
Nix
Raw Normal View History

{ lib, stdenv, fetchurl, perl, coreutils }:
2016-04-15 20:37:17 +00:00
stdenv.mkDerivation rec {
pname = "berkeley_upc";
2022-08-07 12:24:55 +00:00
version = "2020.12.0";
2016-04-15 20:37:17 +00:00
src = fetchurl {
url = "http://upc.lbl.gov/download/release/berkeley_upc-${version}.tar.gz";
2022-08-07 12:24:55 +00:00
sha256 = "sha256-JdpFORlXHpCQE+TivoQQnjQlxQN7C8BNfHvTOSwXbYQ=";
2016-04-15 20:37:17 +00:00
};
postPatch = ''
patchShebangs .
'';
# Used during the configure phase
ENVCMD = "${coreutils}/bin/env";
buildInputs = [ perl ];
meta = with lib; {
2016-04-15 20:37:17 +00:00
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/";
2016-04-15 20:37:17 +00:00
license = licenses.mit;
2022-08-01 16:33:27 +00:00
platforms = platforms.linux;
2016-04-15 20:37:17 +00:00
maintainers = with maintainers; [ zimbatm ];
};
}