mirror of https://github.com/VLSIDA/OpenRAM.git
52 lines
1.3 KiB
Nix
52 lines
1.3 KiB
Nix
{
|
|
description = "OpenRAM development environment (Nix)";
|
|
|
|
inputs = {
|
|
nixpkgs.url = "github:NixOS/nixpkgs/nixpkgs-unstable";
|
|
};
|
|
|
|
outputs = { self, nixpkgs }:
|
|
let
|
|
systems = [ "x86_64-linux" ];
|
|
forAllSystems = f: nixpkgs.lib.genAttrs systems (system: f system);
|
|
in
|
|
{
|
|
devShells = forAllSystems (system:
|
|
let
|
|
pkgs = import nixpkgs { inherit system; };
|
|
in
|
|
{
|
|
default = pkgs.mkShell {
|
|
packages = [
|
|
# PDK management — ciel: install/switch open PDK revisions (e.g. sky130, gf180)
|
|
pkgs.ciel
|
|
|
|
# EDA / verification tools
|
|
pkgs.klayout
|
|
pkgs.magic-vlsi
|
|
# Use the LVS-focused netgen package; the generic netgen package
|
|
# may require a local build that can fail on some hosts.
|
|
pkgs.netgen-vlsi
|
|
pkgs.ngspice
|
|
pkgs.iverilog
|
|
pkgs.xyce
|
|
pkgs.xyce-parallel
|
|
pkgs.trilinos
|
|
pkgs.trilinos-mpi
|
|
|
|
# Dev conveniences
|
|
pkgs.git
|
|
pkgs.gnumake
|
|
pkgs.curl
|
|
];
|
|
|
|
shellHook = ''
|
|
export OPENRAM_USE_CONDA=0
|
|
echo "OpenRAM: using tools from Nix devShell"
|
|
'';
|
|
};
|
|
});
|
|
};
|
|
}
|
|
|